This guide provides information on how to build and deploy TermIt.
- JDK 11 or newer (tested up to JDK 11 LTS)
- Apache Maven 3.5.x or newer
To build TermIt for non-development deployment, use Maven and select the production
profile.
In addition, full text search in TermIt supports three modes:
- Default label-based substring matching
- RDF4J repository with Lucene index
- GraphDB repository with Lucene index
Options 2. and 3. have their respective Maven profiles - rdf4j
and graphdb
. Select one of them
or let the system use the default one.
Moreover, TermIt can be packaged either as an executable JAR (using Spring Boot) or as a WAR that can be deployed in any Servlet API 4-compatible application server.
Maven profiles standalone
(active by default) and war
can be used to activate them respectively.
The rest of the configuration is done in the application.yml
file in src/main/resources
.
Most of the parameters there should be self-explanatory or have documentation in the Configuration
class.
Note that for proper functionality of the frontend, termit.cors.allowedOrigins
must be set to the host and port from which the
termi-ui
accesses TermIt backend. This parameter defaults to http://localhost:3000
but that is usable only for local development.
There is one parameter not used by the application itself, but by Spring - spring.profiles.active
. There are several Spring profiles currently used
by the application:
lucene
- decides whether Lucene text indexing is enabled and should be used in full text search queries.admin-registration-only
- decides whether new users can be registered only by application admin, or whether anyone can register.no-cache
- disables EhCache which is used to cache lists of resources and vocabularies for faster retrieval.
The lucene
Spring profile is activated automatically by the rdf4j
and graphdb
Maven profiles. admin-registration-only
and no-cache
have to be added
either in application.yml
directly, or one can pass the parameter to Maven build, e.g.:
mvn clean package -P graphdb "-Dspring.profiles.active=lucene,admin-registration-only"
mvn clean package -B -P production,graphdb "-Ddeployment=DEV"
clean package -B -P production,rdf4j,war "-Ddeployment=STAGE"
The deployment
parameter is used to parameterize log messages and JMX beans and is important in case multiple deployments
of TermIt are running in the same Tomcat.
Building TermIt on Windows sometimes requires Maven to be configured to use the UTF-8 encoding. In certain cases,
Maven would otherwise use the default Windows encoding (e.g., CP-1250) which can cause issues when accessing URLs with Czech accents
(e.g. the ontology/termit-glosář.ttl
file required for generating application vocabulary).
This configuration can be done, for example, via the MAVEN_OPTS
environmental variable. Either set it temporarily by calling
set MAVEN_OPTS= -Dfile.encoding="UTF-8"
or configure it permanently by setting the MAVEN_OPTS
variable in System Settings.
- JDK 11 or later (tested with JDK 11)
- (WAR) Apache Tomcat 8.5 or 9.x (recommended) or any Servlet API 4-compatible application server
- For deployment of a WAR build artifact.
- Do not use Apache Tomcat 10.x, it is based on the new Jakarta EE and TermIt would not work on it due to package namespace issues (
javax
->jakarta
)
Application deployment is simple - just deploy the WAR file (in case of the war
Maven build profile) to an
application server or run the JAR file (in case of the standalone
Maven build profile).
What is important is the correct setup of the repository. We will describe two options:
- GraphDB
- RDF4J
In order to support inference used by the application, a custom ruleset has to be specified for the TermIt repository.
- Start by creating a GraphDB repository with custom ruleset
- Use the ruleset provided in TermIt at
rulesets/rules-termit-graphdb.pie
- Create the repository, configure it as you like (ensure the repository ID matches TermIt repository configuration)
- Create the following Lucene connectors in GraphDB:
- Label index
- name: label_index
- Field name: label, title
- Property chain: http://www.w3.org/2000/01/rdf-schema#label, http://purl.org/dc/terms/title
- Languages: Leave empty (for indexing all languages) or specify the language tag - see below
- Types: http://www.w3.org/2004/02/skos/core#Concept, http://onto.fel.cvut.cz/ontologies/slovník/agendový/popis-dat/pojem/slovník
- Analyzer: Analyzer appropriate for the system language, e.g. org.apache.lucene.analysis.cz.CzechAnalyzer
- Definition and comment index
- name: defcom_index
- Field name: definition, comment, description
- Languages: Leave empty (for indexing all languages) or specify the language tag - see below
- Property chain: http://www.w3.org/2004/02/skos/core#definition, http://www.w3.org/2000/01/rdf-schema#comment, http://purl.org/dc/terms/description
- Types and Analyzer as above
- Label index
Language can be set for each connector. This is useful in case the data contain labels, definitions, and comments in multiple languages. In this case,
if connector language is not specified, FTS results will contain text snippets with text in all the available languages. For instance, assume
there is a term with label území
@cs and area
@en. Now, if no language is specified for the label connector, the resulting text snippet may
look as follows: <em>území</em> area
, which may not be desired. If the connector language is set to cs
, the result snippet will contain
only <em>území</em>
. See the documentation for more details.
In order to support the inference used by the application, new rules need to be added to RDF4J because its own RDFS rule engine does not support OWL stuff like inverse properties (which are used in the model).
For RDF4J 2.x:
- Start by creating an RDF4J repository of type RDFS+SPIN with Lucene support
- Upload SPIN rules from
rulesets/rules-termit-spin.ttl
into the repository - There is no need to configure Lucene connectors, it by default indexes all properties in RDF4J (alternatively, it is possible to upload a repository configuration directly into the system repository - see examples at [1]
-
For RDF4J 3.x:
- Start by creating an RDF4J repository with RDFS and SPIN inference and Lucene support
- Upload SPIN rules from
rulesets/rules-termit-spin.ttl
into the repository - There is no need to configure Lucene connectors, it by default indexes all properties in RDF4J
-
TermIt needs the repository to provide some inference. Beside loading the appropriate rulesets (see above), it is also necessary to load the ontological models into the repository.
-
Upload the following RDF files into the newly created repository:
ontology/termit-glosář.ttl
ontology/termit-model.ttl
http://onto.fel.cvut.cz/ontologies/slovník/agendový/popis-dat/model
http://onto.fel.cvut.cz/ontologies/slovník/agendový/popis-dat/glosář
https://www.w3.org/TR/skos-reference/skos.rdf
-
Deploy TermIt. It will generate a default admin account, write its credentials to standard output and into a hidden file in the current user's home.
For proper functionality of the text analysis service, Annotace has to be running and its URL configured in application.yml
.
Note that if the repository server to which TermIt is connecting is secured (strongly recommended), it is necessary to put the repository user
username and password into application.yml
so that TermIt persistence can access the repository. The configuration parameter are in Configuration.Repository
class,
but here's a quick example:
termit:
repository:
url: http://localhost:7200/repositories/termit
username: termit
password: supersecretpassword
TermIt can operate in two authentication modes:
- Internal authentication means
- Keycloak -based
By default, Keycloak is disabled (see keycloak.enabled
in application.yml
). To enable it, set keycloak.enabled
to true
and
provide additional required Keycloak parameters - see the Keycloak Spring Boot integration docs.
TermIt will automatically configure its security (it is using Spring's ConditionalOnProperty
)
accordingly.