# Lucene RPC-Server
**Table of Contents**
* [Apache Lucene](#apache-lucene)
* [Requirements](#requirements)
* [Installation](#installation)
* [Build the Java RPC server](#build-the-java-rpc-server)
* [Confgure the server](#configure-the-java-rpc-server)
* [Manage Startup](#manage-startup-using-systemd)
* [Start the Server](#start-the-server)
* [Show Additional Status Info](#show-additional-status-info)
* [Creating a new Index](#creating-a-new-lucene-index)
* [Updating an existing index](#manage-startup-using-systemd)
* [Performing a query](#performing-a-query)
# Apache Lucene
Apache Lucene is a high-performance, full-featured text search engine library
written entirely in Java. It is a technology suitable for nearly any application
that requires full-text search, especially cross-platform.
## Requirements
This Java server has been tested with Open JDK Java Runtime 17.
To be able to index and search for non-ASCII characters your system should
support UTF-8 encodings.
PHP curl and xmlrpc are required for using the Java server features.
On Debian-based systems try:
````shell
> apt-get install php-curl php-xmlrpc openjdk-17-jdk-headless
````
Dependencies and the build process is managed via maven
```shell
> apt-get install maven
```
# Installation
## Build the Java RPC Server
```shell
> cd Services/WebServervices/RPC/lib
> mvn clean install
```
To build/compile the jar file for older LTS release than v17, start the maven build process with the following parameters:
```shell
# java 11
> mvn clean install -Dmaven.compiler.release=11
# java 21
> mvn clean install -Dmaven.compiler.source=21 -Dmaven.compiler.target=21
```
The newly generated ilServer.jar has been created in the target-directory.
Now move the target directory to any other location and grant read/write permission to the webserver user
```shell
> mv target /foo/bar
> chown -R www-data:www-data /foo/bar/target
```
## Configure the Java RPC Server
Create a config file readable by the webserver user/group with following contents. E.g in the external data directory
```shell
> vi /foo/bar/ilServer.ini
[Server]
IpAddress = 127.0.0.1
Port = 11111
IndexPath = /var/www/files/lucene
LogFile = /var/www/logs/ilServer.log
LogLevel = INFO
NumThreads = 2
RamBufferSize = 256
IndexMaxFileSizeMB = 500
[Client1]
ClientId = ACMECorp
NicId = 0
IliasIniPath = /var/www/html/ilias/ilias.ini.php
```
- IpAddress: normally localhost is sufficient
- Port: any free non pivileged port
- IndexPath: any directory with read/write access for the webserver user
- LogFile: Directory must exist. Read/write access for the webserver is required
- LogLevel: one of INFO, DEBUG, WARN, ERROR, FATAL
- NumThreads: The larger the number of NumThreads, the shorter the indexing time, at the expense of the overall CPU load.
- RamBufferSize: The maximum amount of memory in MB before index data is written to the file system
- IndexMaxFileSize: The maximum file size of ILIAS files that can be included in the index.
- ClientId: ClientId of ILIAS installation
- NicId: NicID of ILIAS installation
- IliasIniPath: absolute path to ilias.ini.php
### Configure the ILIAS RPC connection settings
Adapt the ILIAS setup config file variables (rpc_server_host and rpc_server_port) according
to [documentation of the command line setup](../../../../setup/README.md)
## Manage Startup using systemd
```shell
> vi /etc/systemd/system/ilserver.service
[Unit]
Description=ILIAS Java-Server
After=network.target
[Service]
User=www-data
Group=www-data
ExecStart=/usr/bin/java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini start
ExecStop=/usr/bin/java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini stop
TimeoutStopSec=10
[Install]
WantedBy=multi-user.target
> systemctl enable ilserver.service
```
## Start the Server
```shell
> systemctl start ilserver.service
```
## Show Additional Status Info
```shell
> java -jar {PATH_TO_EXTERNAL_DATA}/target/ilServer.jar {PATH_TO_EXTERNAL_DATA}/ilServer.ini status
```
Possible return values are:
```
Running
Stopped
Indexing
```
## Creating a new Lucene index:
```shell
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex
```
The `````` is a combination of the client id and the installation id.
You find these values with the setup status command:
```shell
> cd
> php setup/cli.php status
...
config:
common:
client_id: default
inst_id: 12345678
...
```
Example:
```shell
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex default_12345678
```
or
```shell
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini createIndex default_0
```
if no installation id is given.
## Updating an existing index:
```shell
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini updateIndex
```
## Performing a query
```shell
> java -jar /foo/bar/target/ilServer.jar /foo/bar/ilServer.ini search "ilias"
```