# Security Server Installation Guide for Ubuntu
X-ROAD 7
Version: 2.54
Doc. ID: IG-SS
# Version history
Date | Version | Description | Author |
---|---|---|---|
01.12.2014 | 1.0 | Initial version | |
19.01.2015 | 1.1 | License information added | |
18.03.2015 | 1.2 | Meta-package for Security Server added. Legacy securelog module removed | |
02.04.2015 | 1.3 | “sdsb” change to “xroad” | |
27.05.2015 | 1.4 | Some typos fixed | |
30.06.2015 | 1.5 | Minor corrections done | |
06.07.2015 | 1.6 | New repository address | |
18.09.2015 | 1.7 | Reference data in 3.2 updated | |
18.09.2015 | 2.0 | Editorial changes made | |
13.10.2015 | 2.1 | Editorial changes made | |
10.12.2015 | 2.2 | Updated the installing of the support for hardware tokens (2.7) | |
17.12.2015 | 2.3 | Added xroad-addon-wsdlvalidator package | |
19.05.2016 | 2.4 | Merged changes from xtee6-doc repo. Updated table 2.2 with p 1.12, added chapter 2.8 and updated 3.2. | |
30.09.2016 | 2.5 | Added chapter „Different versions of xroad-* package after successful upgrade“. | |
07.12.2016 | 2.6 | Added operational data monitoring packages. 2 GB RAM -> 3 GB RAM | |
23.02.2017 | 2.7 | Converted to Github flavoured Markdown, added license text, adjusted tables for better output in PDF | Toomas Mölder |
13.04.2017 | 2.8 | Added token ID formatting | Cybernetica AS |
25.08.2017 | 2.9 | Update environmental monitoring installation information | Ilkka Seppälä |
15.09.2017 | 2.10 | Added package with configuration specific to Estonia xroad-securityserver-ee | Cybernetica AS |
05.03.2018 | 2.11 | Added terms and abbreviations reference and document links | Tatu Repo |
10.04.2018 | 2.12 | Updated chapter "Installing the Support for Hardware Tokens" with configurable parameters described in the configuration file 'devices.ini' | Cybernetica AS |
14.10.2018 | 2.13 | Update package repository address | Petteri Kivimäki |
25.10.2018 | 2.14 | Add RHEL7 as supported platform, update section 2.2 Reference data | Petteri Kivimäki |
15.11.2018 | 2.15 | Add Ubuntu 18 installation instructions | Jarkko Hyöty |
28.01.2018 | 2.16 | Update port 2080 documentation | Petteri Kivimäki |
30.05.2019 | 2.17 | Added package installation instructions on chapter "2.4 Preparing OS" | Raul Martinez |
11.09.2019 | 2.18 | Remove Ubuntu 14.04 from supported platforms | Jarkko Hyöty |
20.09.2019 | 2.19 | Add instructions for using remote databases | Ilkka Seppälä |
12.04.2020 | 2.20 | Add note about the default value of the connector-host property in the EE-package | Petteri Kivimäki |
29.04.2020 | 2.21 | Add instructions how to use remote database located in Microsoft Azure | Ilkka Seppälä |
12.06.2020 | 2.22 | Update reference data regarding JMX listening ports | Petteri Kivimäki |
24.06.2020 | 2.23 | Add repository sign key details in section 2.2 Reference data | Petteri Kivimäki |
24.06.2020 | 2.24 | Remove environmental and operational monitoring daemon JMX listening ports from section 2.2 Reference data | Petteri Kivimäki |
09.08.2020 | 2.25 | Update ports information in section 2.2 Reference data, add section 2.2.1 Network Diagram | Petteri Kivimäki |
17.08.2020 | 2.26 | Update for RHEL 8. | Jarkko Hyöty |
08.09.2020 | 2.27 | Fix minimum RAM requirement. | Ilkka Seppälä |
16.09.2020 | 2.28 | Describe deployment options and database customization options. | Ilkka Seppälä |
29.09.2020 | 2.29 | Add instructions for creating database structure and roles manually. | Ilkka Seppälä |
19.01.2021 | 2.30 | Add instructions for using an alternative Java distribution. | Jarkko Hyöty |
04.02.2021 | 2.31 | Minor updates. | Ilkka Seppälä |
13.04.2021 | 2.32 | Update minimum requirements in section 2.2 Reference data | Petteri Kivimäki |
16.04.2021 | 2.33 | Update remote database installation instructions | Jarkko Hyöty |
18.05.2021 | 2.34 | Update error handling section | Ilkka Seppälä |
02.06.2021 | 2.35 | Add backup encryption information | Andres Allkivi |
01.07.2021 | 2.36 | Update 3rd party key server | Petteri Kivimäki |
11.08.2021 | 2.37 | Minor updates | Petteri Kivimäki |
18.08.2021 | 2.38 | Minor updates to Annex D | Ilkka Seppälä |
25.08.2021 | 2.39 | Update X-Road references from version 6 to 7 | Caro Hautamäki |
26.08.2021 | 2.40 | Add instructions how to disable the messagelog addon before installing, add section 2.7 Disable the Messagelog Addon before Installation (optional) | Caro Hautamäki |
03.08.2021 | 2.41 | Minor fixes | Ilkka Seppälä |
06.09.2021 | 2.42 | Update list of running services | Jarkko Hyöty |
26.09.2022 | 2.43 | Remove Ubuntu 18.04 support | Andres Rosenthal |
23.05.2023 | 2.44 | Minor backup encryption configuration fixes | Eneli Reimets |
01.06.2023 | 2.45 | Update references | Petteri Kivimäki |
20.11.2023 | 2.46 | Update firewall configuration documentation | Taavi Meinberg |
27.11.2023 | 2.47 | Updated default proxy client http(s) ports | Mikk-Erik Bachmann |
19.12.2023 | 2.48 | Add RHEL 9 as supported platform | Justas Samuolis |
02.01.2024 | 2.49 | Loopback ports added | Justas Samuolis |
26.04.2024 | 2.50 | Ubuntu 24.04 support | Madis Loitmaa |
12.06.2024 | 2.51 | Add ACME server to the network diagram, add a section about enabling ACME support | Petteri Kivimäki |
25.06.2024 | 2.52 | Add global configuration download port 443 to the network diagram | Petteri Kivimäki |
24.09.2024 | 2.53 | Add mail server to the network diagram | Mikk-Erik Bachmann |
08.11.2024 | 2.54 | Update for configurable parameters in the /etc/xroad/devices.ini after added support for ECDSA keys | Ovidijus Narkevicius |
# License
This document is licensed under the Creative Commons Attribution-ShareAlike 3.0 Unported License. To view a copy of this license, visit http://creativecommons.org/licenses/by-sa/3.0/
# Table of Contents
- License
- 1 Introduction
- 2 Installation
- 2.1 Prerequisites to Installation
- 2.2 Reference Data
- 2.3 Requirements for the Security Server
- 2.4 Preparing OS
- 2.5 Setup Package Repository
- 2.6 Remote Database Setup (optional)
- 2.7 Disable the Messagelog Addon before Installation (optional)
- 2.8 Security Server Installation
- 2.9 Post-Installation Checks
- 2.10 Installing the Support for Hardware Tokens
- 2.11 Installing the Support for Environmental Monitoring
- 3 Security Server Initial Configuration
- 4 Installation Error handling
- Annex A Security Server Default Database Properties
- Annex B Default Database Users
- Annex C Deployment Options
- Annex D Create Database Structure Manually
# 1 Introduction
# 1.1 Target Audience
The intended audience of this Installation Guide are X-Road Security server system administrators responsible for installing and using X-Road software. The daily operation and maintenance of the Security Server is covered by its User Guide [UG-SS].
The document is intended for readers with a moderate knowledge of Linux server management, computer networks, and the X-Road working principles.
# 1.2 Terms and abbreviations
See X-Road terms and abbreviations documentation [TA-TERMS].
# 1.3 References
[UG-SS] X-Road 7. Security Server User Guide. Document ID: UG-SS
[TA-TERMS] X-Road Terms and Abbreviations. Document ID: TA-TERMS
[UG-SYSPAR] X-Road: System Parameters User Guide. Document ID: UG-SYSPAR
[IG-XLB] X-Road: External Load Balancer Installation Guide. Document ID: IG-XLB
# 2 Installation
# 2.1 Prerequisites to Installation
There are multiple alternatives how the Security Server can be deployed. The options are described in Annex C Deployment Options.
The Security Server is officially supported on the following platforms:
- Ubuntu Server 20.04, 22.04 or 24.04 Long-Term Support (LTS) operating system on a x86-64 platform.
- Red Hat Enterprise Linux (RHEL) 7, 8, 9 (x86-64). See IG-SS-RHEL for more information.
The software can be installed both on physical and virtualized hardware (of the latter, Xen and Oracle VirtualBox have been tested).
# 2.2 Reference Data
Note: The information in empty cells should be determined before the server’s installation, by the person performing the installation.
Caution: Data necessary for the functioning of the operating system is not included.
Ref | Explanation | |
---|---|---|
1.0 | Ubuntu 20.04, 22.04 or 24.04 (x86-64) 3 GB RAM, 3 GB free disk space | Minimum requirements without the monitoring and op-monitoring add-ons. With the add-ons minimum of 4 GB of RAM is required. |
1.1 | https://artifactory.niis.org/xroad-release-deb | X-Road package repository |
1.2 | https://artifactory.niis.org/api/gpg/key/public | The repository key. Hash: 935CC5E7FA5397B171749F80D6E3973B Fingerprint: A01B FE41 B9D8 EAF4 872F A3F1 FB0D 532C 10F6 EC5B 3rd party key server: Ubuntu key server (opens new window) |
1.3 | Account name in the user interface | |
1.4 | Inbound ports from external network | Ports for inbound connections from the external network to the Security Server |
TCP 80 | Incoming ACME challenge requests from ACME Servers | |
TCP 5500 | Message exchange between Security Servers | |
TCP 5577 | Querying of OCSP responses between Security Servers | |
1.5 | Outbound ports to external network | Ports for outbound connections from the Security Server to the external network |
TCP 5500 | Message exchange between Security Servers | |
TCP 5577 | Querying of OCSP responses between Security Servers | |
TCP 4001 | Communication with the Central Server | |
TCP 80,443 | Downloading global configuration from the Central Server | |
TCP 80,443 | Most common OCSP and time-stamping services | |
TCP 80,443 | Communication with ACME servers | |
1.6 | Inbound ports from internal network | Ports for inbound connections from the internal network to the Security Server |
TCP 4000 | User interface and management REST API (local network). Must not be accessible from the internet! | |
TCP 8080, 8443 | Information system access points (in the local network). Must not be accessible from the external network without strong authentication. If open to the external network, IP filtering is strongly recommended. | |
TCP 587 | Communication with the mail server | |
1.7 | Outbound ports to internal network | Ports for inbound connections from the internal network to the Security Server |
TCP 80, 443, other | Producer information system endpoints | |
TCP 2080 | Message exchange between Security Server and operational data monitoring daemon (by default on localhost) | |
1.8 | Security server internal IP address(es) and hostname(s) | |
1.9 | Security server public IP address, NAT address | |
1.10 | <by default, the server’s IP addresses and names are added to the certificate’s Distinguished Name (DN) field> | Information about the user interface TLS certificate |
1.11 | <by default, the server’s IP addresses and names are added to the certificate’s Distinguished Name (DN) field> | Information about the services TLS certificate |
# 2.2.1 Network Diagram
The network diagram below provides an example of a basic Security Server setup. Allowing incoming connections from the Monitoring Security Server on ports 5500/tcp and 5577/tcp is necessary for the X-Road Operator to be able to monitor the ecosystem and provide statistics and support for Members.
The table below lists the required connections between different components.
Connection Type | Source | Target | Target Ports | Protocol | Note |
---|---|---|---|---|---|
Out | Security Server | Central Server | 80, 443, 4001 | tcp | |
Out | Security Server | Management Security Server | 5500, 5577 | tcp | |
Out | Security Server | OCSP Service | 80 / 443 | tcp | |
Out | Security Server | Timestamping Service | 80 / 443 | tcp | |
Out | Security Server | Data Exchange Partner Security Server (Service Producer) | 5500, 5577 | tcp | |
Out | Security Server | Producer Information System | 80, 443, other | tcp | Target in the internal network |
Out | Security Server | ACME Server | 80 / 443 | tcp | |
Out | Security Server | Mail server | 587 | tcp | |
In | Monitoring Security Server | Security Server | 5500, 5577 | tcp | |
In | Data Exchange Partner Security Server (Service Consumer) | Security Server | 5500, 5577 | tcp | |
In | ACME Server | Security Server | 80 | tcp | |
In | Consumer Information System | Security Server | 8080, 8443 | tcp | Source in the internal network |
In | Admin | Security Server | 4000 | tcp | Source in the internal network |
The table below lists the open ports for Security Server components utilizing the loopback interface. A loopback interface is a virtual network interface on a computer, facilitating self-communication for processes and applications. This enables local communication and the ports must be accessible locally.
Component | Ports | Protocol | Note |
---|---|---|---|
PostgreSQL database | 5432 | tcp | Default PostgreSQL port |
OP Monitoring daemon | 2080 | tcp | |
Environmental monitoring | 2552 | tcp | |
Signer | 5559 | tcp | Signer admin port |
Signer | 5560 | tcp | Signer gRPC port |
Proxy | 5566 | tcp | Proxy admin port |
Proxy | 5567 | tcp | Proxy gRPC server port |
Configuration Client | 5675 | tcp | Configuration Client admin port |
Audit Log | 514 | udp |
# 2.3 Requirements for the Security Server
Minimum recommended hardware parameters:
- the server’s hardware (motherboard, CPU, network interface cards, storage system) must be supported by Ubuntu in general;
- a 64-bit dual-core Intel, AMD or compatible CPU; AES instruction set support is highly recommended;
- 4 GB RAM;
- a 100 Mbps network interface card;
- if necessary, interfaces for the use of hardware tokens.
Requirements to software and settings:
- an installed and configured Ubuntu 20.04 LTS, 22.04 or 24.04 LTS x86-64 operating system;
- if the Security Server is separated from other networks by a firewall and/or NAT, the necessary connections to and from the Security Server are allowed (reference data: 1.4; 1.5; 1.6; 1.7). The enabling of auxiliary services which are necessary for the functioning and management of the operating system (such as DNS, NTP, and SSH) stay outside the scope of this guide;
- if the Security Server has a private IP address, a corresponding NAT record must be created in the firewall (reference data: 1.9).
# 2.4 Preparing OS
Add an X-Road system administrator user (reference data: 1.3) whom all roles in the user interface are granted to. Add a new user with the command
sudo adduser <username>
User roles are discussed in detail in X-Road Security Server User Guide [UG-SS]. Do not use the user name
xroad
, it is reserved for the X-Road system user.Set the operating system locale. Add following line to the
/etc/environment
file.LC_ALL=en_US.UTF-8
Ensure that the packages
locales
andsoftware-properties-common
are presentsudo apt-get install locales software-properties-common
Ensure that the locale is available
sudo locale-gen en_US.UTF-8
# 2.5 Setup Package Repository
Add the X-Road repository’s signing key to the list of trusted keys (reference data: 1.2):
curl https://artifactory.niis.org/api/gpg/key/public | sudo apt-key add -
Add X-Road package repository (reference data: 1.1)
sudo apt-add-repository -y "deb https://artifactory.niis.org/xroad-release-deb $(lsb_release -sc)-current main"
Update package repository metadata:
sudo apt update
If you are installing the default setup with local PostgreSQL database and want to enable the messagelog addon, continue at section 2.8. If you need to customize database properties and e.g. use a remote database or disable the messagelog addon, read on.
# 2.6 Remote Database Setup (optional)
This is an optional step.
Optionally, the Security Server can use a remote database server. To avoid installing the default local PostgreSQL server during Security Server installation, first install the xroad-database-remote
-package.
sudo apt install xroad-database-remote
For the application level backup and restore feature to work correctly, it is important to verify that the local PostgreSQL client has the same or later major version than the remote database server and, if necessary, install a different version of the postgresql-client
package (see https://www.postgresql.org/download/linux/ubuntu/)
psql --version
psql (PostgreSQL) 12.6 (Ubuntu 12.6-0ubuntu0.20.04.1)
psql -h <database host> -U <superuser> -tAc 'show server_version'
10.16 (Ubuntu 10.16-0ubuntu0.18.04.1)
The Security Server installer can create the database and users for you, but you need to create a configuration file containing the database administrator credentials.
For advanced setup, e.g. when using separate servers for the databases, sharing a database with several Security Servers, or if storing the database administrator password on the Security Server is not an option, you can create the database users and structure manually as described in Annex D Create Database Structure Manually and then continue to section 2.7. Otherwise, perform the following steps:
Create the property file:
sudo touch /etc/xroad.properties
sudo chown root:root /etc/xroad.properties
sudo chmod 600 /etc/xroad.properties
Edit /etc/xroad.properties
. See the example below. Replace parameter values with your own.
postgres.connection.password = <database superuser password>
postgres.connection.user = <database superuser name, postgres by default>
Note. If Microsoft Azure database for PostgreSQL is used, the connection user needs to be in format username@hostname
.
Before continuing, test that the connection to the database works, e.g.
psql -h <database host> -U <superuser> -tAc 'show server_version'
For additional security, the postgresql.connection.*
properties can be removed from the /etc/xroad.properties
file after installation (keep the other properties added by the installer).
# 2.7 Disable the Messagelog Addon before Installation (optional)
It is possible to preconfigure the Security Server installation so that the messagelog addon will be automatically disabled after the installation process is done. This also skips the creation of the messagelog database.
In order to skip messagelog database creation and disable the messagelog addon, run the following command to add a boolean value into the debconf database before installing the Security Server
sudo debconf-set-selections <<< 'xroad-addon-messagelog xroad-addon-messagelog/enable-messagelog boolean false'
# 2.8 Security Server Installation
Issue the following command to install the Security Server packages (use package xroad-securityserver-ee
to include configuration specific to Estonia; use package xroad-securityserver-fi
to include configuration specific to Finland; use package xroad-securityserver-is
to include configuration specific to Iceland):
sudo apt install xroad-securityserver
Upon the first installation of the packages, the system asks for the following information.
Account name for the user who will be granted the rights to perform all activities in the user interface (reference data: 1.3).
Database server URL. Locally installed database is suggested as default but remote databases can be used as well. In case remote database is used, one should verify that the version of the local PostgreSQL client matches the version of the remote PostgreSQL server.
The Distinguished Name of the owner of the user interface's and management REST API's self-signed TLS certificate (Subject DN) and its alternative names (subjectAltName) (reference data: 1.8; 1.10). The certificate is used for securing connections to the user interface and to the management REST API. The name and IP addresses detected from the operating system are suggested as default values.
The Subject DN must be entered in the format:
/CN=server.domain.tld
All IP addresses and domain names in use must be entered as alternative names in the format:
IP:1.2.3.4,IP:4.3.2.1,DNS:servername,DNS:servername2.domain.tld
The Distinguished Name of the owner of the TLS certificate that is used for securing the HTTPS access point of information systems (reference data: 1.8; 1.11). The name and IP addresses detected from the system are suggested as default values.
The Subject DN must be entered in the format:
/CN=server.domain.tld
All IP addresses and domain names in use must be entered as alternative names in the format:
IP:1.2.3.4,IP:4.3.2.1,DNS:servername,DNS:servername2.domain.tld
The meta-package xroad-securityserver
also installs metaservices module xroad-addon-metaservices
, messagelog module xroad-addon-messagelog
and WSDL validator module xroad-addon-wsdlvalidator
. The meta-packages xroad-securityserver-ee
, xroad-securityserver-fi
, xroad-securityserver-is
, and xroad-securityserver-fo
install operational data monitoring module xroad-addon-opmonitoring
.
N.B. In case configuration specific to Estonia (package xroad-securityserver-ee
) is installed, connections from client applications are restricted to localhost by default. To enable client application connections from external sources, the value of the connector-host
property must be overridden in the /etc/xroad/conf.d/local.ini
configuration file. Changing the system parameter values is explained in the System Parameters User Guide [UG-SS].
# 2.9 Post-Installation Checks
The installation is successful if system services are started and the user interface is responding.
- Ensure from the command line that X-Road services are in the
running
state (example output follows):sudo systemctl list-units "xroad-*" UNIT LOAD ACTIVE SUB DESCRIPTION xroad-addon-messagelog.service loaded active running X-Road Messagelog Archiver xroad-base.service loaded active exited X-Road initialization xroad-confclient.service loaded active running X-Road confclient xroad-monitor.service loaded active running X-Road Monitor xroad-proxy-ui-api.service loaded active running X-Road Proxy UI REST API xroad-proxy.service loaded active running X-Road Proxy xroad-signer.service loaded active running X-Road signer
- Ensure that the Security Server user interface at https://SECURITYSERVER:4000/ (reference data: 1.8; 1.6) can be opened in a Web browser. To log in, use the account name chosen during the installation (reference data: 1.3). While the user interface is still starting up, the Web browser may display a connection refused -error.
# 2.10 Installing the Support for Hardware Tokens
To configure support for hardware security tokens (smartcard, USB token, Hardware Security Module), act as follows.
Install the hardware token support module using the following command:
sudo apt-get install xroad-addon-hwtokens
Install and configure a PKCS#11 driver for the hardware token according to the manufacturer's instructions.
Add the path to the PKCS#11 driver to the file
/etc/xroad/devices.ini
(as described in the example given in the file).After installing and configuring the driver, the
xroad-signer
service must be restarted:sudo systemctl restart xroad-signer
If you are running a high availability (HA) hardware token setup (such as a cluster with replicated tokens) then you may need to constrain the token identifier format such that the token replicas can be seen as the same token. The token identifier format can be changed in /etc/xroad/devices.ini
via the token_id_format
property (default value: {moduleType}{slotIndex}{serialNumber}{label}
). Removing certain parts of the identifier will allow the HA setup to work correctly when one of the tokens goes down and is replaced by a replica. For example, if the token replicas are reported to be on different slots the {slotIndex}
part should be removed from the identifier format.
Depending on the hardware token there may be a need for more additional configuration. All possible configurable parameters in the /etc/xroad/devices.ini
are described in the next table.
Parameter | Type | Default Value | Explanation |
---|---|---|---|
enabled | BOOLEAN | true | Indicates whether this device is enabled. |
library | STRING | The path to the pkcs#11 library of the device driver. | |
library_cant_create_os_threads | BOOLEAN | false | Indicates whether application threads, which are executing calls to the pkcs#11 library, may not use native operating system calls to spawn new threads (in other words, the library’s code may not create its own threads). |
os_locking_ok | BOOLEAN | false | Indicates whether the pkcs#11 library may use the native operation system threading model for locking. |
sign_verify_pin | BOOLEAN | false | Indicates whether the PIN should be entered per signing operation. |
token_id_format | STRING | {moduleType}{slotIndex}{serialNumber}{label} | Specifies the identifier format used to uniquely identify a token. In certain high availability setups may need be constrained to support replicated tokens (eg. by removing the slot index part which may be different for the token replicas). |
sign_mechanism | STRING | CKM_RSA_PKCS | Specifies the signing mechanism. Supported values: CKM_RSA_PKCS, CKM_RSA_PKCS_PSS. |
rsa_sign_mechanism | STRING | CKM_RSA_PKCS | Specifies the signing mechanism. Supported values: CKM_RSA_PKCS, CKM_RSA_PKCS_PSS. If value isn't provided then defaults to value of sign_mechanism if present. |
ec_sign_mechanism | STRING | CKM_ECDSA | Specifies the signing mechanism for EC keys. Supported values: CKM_ECDSA. |
pub_key_attribute_encrypt | BOOLEAN | true | Indicates whether public key can be used for encryption. |
pub_key_attribute_verify | BOOLEAN | true | Indicates whether public key can be used for verification. |
pub_key_attribute_wrap | BOOLEAN | Indicates whether public key can be used for wrapping other keys. | |
pub_key_attribute_allowed_mechanisms | STRING LIST | Specifies public key allowed mechanisms. Supported values: CKM_RSA_PKCS, CKM_SHA256_RSA_PKCS, CKM_SHA384_RSA_PKCS, CKM_SHA512_RSA_PKCS, and CKM_RSA_PKCS_PSS, CKM_SHA256_RSA_PKCS_PSS, CKM_SHA384_RSA_PKCS_PSS, CKM_SHA512_RSA_PKCS_PSS, CKM_ECDSA, CKM_ECDSA_SHA256, CKM_ECDSA_SHA384, CKM_ECDSA_SHA512. | |
priv_key_attribute_sensitive | BOOLEAN | true | Indicates whether private key is sensitive. |
priv_key_attribute_decrypt | BOOLEAN | true | Indicates whether private key can be used for encryption. |
priv_key_attribute_sign | BOOLEAN | true | Indicates whether private key can be used for signing. |
priv_key_attribute_unwrap | BOOLEAN | Indicates whether private key can be used for unwrapping wrapped keys. | |
priv_key_attribute_allowed_mechanisms | STRING LIST | Specifies private key allowed mechanisms. Supported values: CKM_RSA_PKCS, CKM_SHA256_RSA_PKCS, CKM_SHA384_RSA_PKCS, CKM_SHA512_RSA_PKCS, and CKM_RSA_PKCS_PSS, CKM_SHA256_RSA_PKCS_PSS, CKM_SHA384_RSA_PKCS_PSS, CKM_SHA512_RSA_PKCS_PSS, CKM_ECDSA, CKM_ECDSA_SHA256, CKM_ECDSA_SHA384, CKM_ECDSA_SHA512. |
Note 1: Only parameter library is mandatory, all the others are optional. Note 2: The item separator of the type STRING LIST is ",".
# 2.11 Installing the Support for Environmental Monitoring
The support for environmental monitoring functionality on a Security Server is provided by package xroad-monitor that is installed by default. The package installs and starts the xroad-monitor
process that will gather and make available the monitoring information.
# 3 Security Server Initial Configuration
During the Security Server initial configuration, the server’s X-Road membership information and the software token’s PIN are set.
# 3.1 Prerequisites
Configuring the Security Server assumes that the Security Server owner is a member of the X-Road.
# 3.2 Reference Data
ATTENTION: Reference items 2.1 - 2.3 in the reference data are provided to the Security Server owner by the X-Road central’s administrator.
The Security Server code and the software token’s PIN will be determined during the installation at the latest, by the person performing the installation.
Ref | Explanation | |
---|---|---|
2.1 | <global configuration anchor file> or <URL> | Global configuration anchor file |
2.2 | E.g. GOV - government COM - commercial | Member class of the Security Server's owner |
2.3 | <Security Server owner register code> | Member code of the Security Server's owner |
2.4 | <choose Security Server identificator name> | Security server's code |
2.5 | <choose PIN for software token> | Software token’s PIN |
# 3.3 Configuration
To perform the initial configuration, open the address
https://SECURITYSERVER:4000/
in a Web browser (reference data: 1.8; 1.6). To log in, use the account name chosen during the installation (reference data: 1.3).
Upon first log-in, the system asks for the following information.
The global configuration anchor file (reference data: 2.1).
Please verify anchor hash value with the published value.
If the configuration is successfully downloaded, the system asks for the following information.
The Security Server owner’s member class (reference data: 2.2).
The Security Server owner’s member code (reference data: 2.3).
If the member class and member code are correctly entered, the system displays the Security Server owner’s name as registered in the X-Road center.
Security server code (reference data: 2.4), which is chosen by the Security Server administrator and which has to be unique across all the Security Servers belonging to the same X-Road member.
Software token’s PIN (reference data: 2.5). The PIN will be used to protect the keys stored in the software token. The PIN must be stored in a secure place, because it will be no longer possible to use or recover the private keys in the token once the PIN has been lost.
# 3.4 Configuring Firewall
It is strongly recommended to protect the Security Server from unwanted access using a firewall (hardware or software based). The firewall can be applied to both incoming and outgoing connections depending on the security requirements of the environment where the Security Server is deployed.
Special attention should be paid with the firewall configuration since incorrect configuration may leave the Security Server vulnerable to exploits and attacks. This type of abuse could result in compromised access to the Security Server and the data that is exchanged through it.
It is recommended to allow incoming traffic to specific ports only from explicitly defined sources using IP filtering. Access for ports 8080
, 8443
and 4000
should be especially defined, as these ports are used for making X-Road queries and accessing the user interface.
When installing the Security Server, it is strongly recommended to look over the list of ports at 2.2 Reference Data and define firewall access rules for specific hosts based on their descriptions.
# 3.4.1 Accepting Connections
The Security Server has a special [proxy]
parameter connector-host which determines
the interfaces that the Security Server uses to listen for incoming connections. The default value for this parameter in the default X-Road packages is 0.0.0.0
,
which makes the Security Server accept connections from any server. For country-specific defaults, please refer to the system parameters documentation.
The parameter can be changed by following the System Parameters guide.
# 3.5 Configuring Configuration Backup Encryption
It is possible to automatically encrypt Security Server configuration backups. Security server uses The GNU Privacy Guard (https://www.gnupg.org)
for backup encryption and verification. Backups are always signed, but backup encryption is initially turned off.
To turn encryption on, please override the default configuration in the file /etc/xroad/conf.d/local.ini
, in the [proxy]
section (add or edit this section).
[proxy]
backup-encryption-enabled = true
backup-encryption-keyids = <keyid1>, <keyid2>, ...
To turn backup encryption on, please change the backup-encryption-enabled
property value to true
.
By default, backups are encrypted using Security Server's backup encryption key. Additional encryption keys can be imported in the /etc/xroad/gpghome keyring and key identifiers listed using the backup-encryption-keyids parameter. It is recommended to set up at least one additional key, otherwise the backups will be unusable in case Security Server's private key is lost. It is up to Security Server's administrator to check that keys used are sufficiently strong, there are no automatic checks.
Warning. All keys listed in backup-encryption-keyids must be present in the gpg keyring or backup fails.
All these keys are used to encrypt backups so that ANY of these keys can decrypt the backups. This is useful both for verifying encrypted backups' consistency and decrypting backups in case Security Server's backup encryption key gets lost for whatever reason.
To externally verify a backup archive's consistency, Security Server's backup encryption public key has to be exported and imported into external GPG keyring. Note that this can be done only after Security Server has been initialised - the Security Server backup encryption key is generated during initialisation.
To export Security Server's backup encryption public key use the following command:
gpg --homedir /etc/xroad/gpghome --armor --output server-public-key.gpg --export AA/GOV/TS1OWNER/TS1
where AA/GOV/TS1OWNER/TS1
is the Security Server id.
The key can then be moved to an external host and imported to GPG keyring with the following command:
gpg --homedir /your_gpg_homedir_here --import server-public-key.gpg
# 3.6 Enabling ACME Support
Automated Certificate Management Environment (ACME) protocol enables automated certificate management of the authentication and sign certificates on the Security Server. More information about the required configuration is available in the Security Server User Guide.
# 3.7 Enabling EC Keys for Authentication and Signing Certificates
Security Server supports EC based authentication and signing certificates since version 7.6.0. More information about the required configuration is available in the Security Server User Guide.
# 4 Installation Error handling
# 4.1 Cannot Set LC_ALL to Default Locale
If running the locale command results in the error message
locale: Cannot set LC_ALL to default locale: No such file or directory,
then the support for this particular language has not been installed. To install it, run the command (the example uses the English language):
sudo apt-get install language-pack-en
Then, to update the system’s locale files, run the following commands (the example uses the US locale):
sudo locale-gen en_US.UTF-8
sudo update-locale en_US.UTF-8
Set operating system locale. Add following line to /etc/environment
file:
LC_ALL=en_US.UTF-8
After updating the system’s locale settings, it is recommended to restart the operating system.
# 4.2 PostgreSQL Is Not UTF8 Compatible
If the Security Server installation is aborted with the error message
postgreSQL is not UTF8 compatible,
then the PostgreSQL package is installed with a wrong locale. One way to resolve it is to remove the data store created upon the PostgreSQL installation and recreate it with the correct encoding.
WARNING: All data in the database will be erased!
sudo pg_dropcluster --stop 10 main
LC_ALL="en_US.UTF-8" sudo pg_createcluster --start 10 main
To complete the interrupted installation, run the command
sudo apt-get -f install
# 4.3 Could Not Create Default Cluster
If the following error message is displayed during PostgreSQL installation:
Error: The locale requested by the environment is invalid.
Error: could not create default cluster. Please create it manually with pg_createcluster 10 main –start,
use the following command to create the PostgreSQL data cluster:
LC_ALL="en_US.UTF-8" sudo pg_createcluster --start 10 main
The interrupted installation can be finished using
sudo apt-get -f install
# 4.4 Is Postgres Running On Port 5432?
If the following error message appears during installation
Is postgres running on port 5432 ?
Aborting installation! please fix issues and rerun with apt-get -f install,
check if any of the following errors occurred during the installation of PostgreSQL.
Error installing the data cluster. Refer to section “Could not create default cluster”.
The PostgreSQL data cluster installed during the installation of the Security Server is not configured to listen on port 5432. To verify and configure the listening port, edit the PostgreSQL configuration file in
/etc/postgresql/10/main/postgresql.conf
. If you change the listening port, the postgresql service must be restarted.
The interrupted installation can be finished using
sudo apt-get -f install
# 4.5 Different versions of xroad-* packages after successful upgrade
Sometimes, after using sudo apt-get upgrade
command, some of the packages are not upgraded. In the following example xroad-securityserver
package version is still 6.8.3 although other packages are upgraded to 6.8.5:
# sudo dpkg -l | grep xroad-
ii xroad-addon-messagelog 6.8.5.20160929134539gitfe60f90
ii xroad-addon-metaservices 6.8.5.20160929134539gitfe60f90
ii xroad-addon-wsdlvalidator 6.8.5.20160929134539gitfe60f90
ii xroad-common 6.8.5.20160929134539gitfe60f90
ii xroad-jetty9 6.8.5.20160929134539gitfe60f90
ii xroad-proxy 6.8.5.20160929134539gitfe60f90
ii xroad-securityserver 6.8.3-3-201605131138
apt-get upgrade
command doesn’t install new packages - in this particular case new packages xroad-monitor
and xroad-addon-proxymonitor
installation is needed for upgrade of xroad-securityserver
package.
To be sure that packages are installed correctly please use sudo apt upgrade
or sudo apt full-upgrade
commands.
# 4.6 ERROR: Upgrade supported from version X.Y.Z or newer
The following error message may come up during the Security Server upgrade.
ERROR: Upgrade supported from version X.Y.Z or newer
Upgrading the packages from the current version to the target version is not supported directly. The fix is to upgrade the Security Server to the target version step by step.
For example, the following Security Server packages are currently installed.
root@test-ss:~# dpkg -l | grep xroad
ii xroad-addon-messagelog 7.1.2-1.ubuntu20.04 all X-Road AddOn: messagelog
ii xroad-addon-metaservices 7.1.2-1.ubuntu20.04 all X-Road AddOn: metaservices
ii xroad-addon-proxymonitor 7.1.2-1.ubuntu20.04 all X-Road AddOn: proxy monitoring metaservice
ii xroad-addon-wsdlvalidator 7.1.2-1.ubuntu20.04 all X-Road AddOn: wsdlvalidator
ii xroad-base 7.1.2-1.ubuntu20.04 amd64 X-Road base components
ii xroad-confclient 7.1.2-1.ubuntu20.04 amd64 X-Road configuration client components
ii xroad-database-local 7.1.2-1.ubuntu20.04 all Meta-package for X-Road local database dependencies
ii xroad-monitor 7.1.2-1.ubuntu20.04 all X-Road monitoring service
ii xroad-proxy 7.1.2-1.ubuntu20.04 all X-Road security server
ii xroad-proxy-ui-api 7.1.2-1.ubuntu20.04 all X-Road proxy UI REST API
ii xroad-securityserver 7.1.2-1.ubuntu20.04 all X-Road security server
ii xroad-signer 7.1.2-1.ubuntu20.04 amd64 X-Road signer component
The following packages are available in the repository.
root@test-ss:~# apt-cache madison xroad-securityserver
xroad-securityserver | 7.3.0-1.ubuntu20.04 | https://artifactory.niis.org/xroad-release-deb focal-current/main amd64 Packages
xroad-securityserver | 7.1.2-1.ubuntu20.04 | https://artifactory.niis.org/xroad-release-deb focal-current/main amd64 Packages
Now trying to upgrade the Security Server packages directly will produce the following error.
root@test-ss:~# apt-get upgrade xroad-securityserver
...
Preparing to unpack .../0-xroad-securityserver_7.3.0-1.ubuntu20.04_all.deb ...
ERROR: Upgrade supported from version 7.1.2 or newer.
The fix is to upgrade the Security Server in two separate steps. First, upgrade to 7.1.x with the following command.
apt install xroad-securityserver=7.1.2-1.ubuntu20.04 xroad-proxy=7.1.2-1.ubuntu20.04 xroad-monitor=7.1.2-1.ubuntu20.04 xroad-addon-metaservices=7.1.2-1.ubuntu20.04 xroad-addon-messagelog=7.1.2-1.ubuntu20.04 xroad-addon-proxymonitor=7.1.2-1.ubuntu20.04 xroad-addon-wsdlvalidator=7.1.2-1.ubuntu20.04 xroad-proxy-ui-api=7.1.2-1.ubuntu20.04 xroad-confclient=7.1.2-1.ubuntu20.04 xroad-signer=7.1.2-1.ubuntu20.04 xroad-database-local=7.1.2-1.ubuntu20.04 xroad-base=7.1.2-1.ubuntu20.04
An alternative approach to the previous command is to temporarily configure the server to use a repository that contains only the specific version of X-Road software we want to upgrade to. For example, configure the repository as deb https://artifactory.niis.org/xroad-release-deb focal-7.1.2 main
and then use the apt update
and apt upgrade xroad-centralserver
commands.
Finally, we can upgrade to our target version 7.3.x as follows.
apt upgrade xroad-securityserver
# Annex A Security Server Default Database Properties
/etc/xroad/db.properties
# connection.url format: jdbc:postgresql://<hostname>:<port>/<database name>
serverconf.hibernate.connection.url = jdbc:postgresql://127.0.0.1:5432/serverconf
serverconf.hibernate.connection.username = serverconf
serverconf.hibernate.connection.password = <randomly generated password>
serverconf.hibernate.connection.driver_class = org.postgresql.Driver
serverconf.hibernate.dialect = ee.ria.xroad.common.db.CustomPostgreSQLDialect
serverconf.hibernate.hikari.dataSource.currentSchema = serverconf,public
serverconf.hibernate.jdbc.use_streams_for_binary = true
messagelog.hibernate.connection.url = jdbc:postgresql://127.0.0.1:5432/messagelog
messagelog.hibernate.connection.username = messagelog
messagelog.hibernate.connection.password = <randomly generated password>
messagelog.hibernate.connection.driver_class = org.postgresql.Driver
messagelog.hibernate.dialect = ee.ria.xroad.common.db.CustomPostgreSQLDialect
messagelog.hibernate.hikari.dataSource.currentSchema = messagelog,public
messagelog.hibernate.jdbc.use_streams_for_binary = true
op-monitor.hibernate.connection.url = jdbc:postgresql://127.0.0.1:5432/op-monitor
op-monitor.hibernate.connection.username = opmonitor
op-monitor.hibernate.connection.password = <randomly generated password>
op-monitor.hibernate.connection.driver_class = org.postgresql.Driver
op-monitor.hibernate.hikari.dataSource.currentSchema = opmonitor,public
op-monitor.hibernate.jdbc.use_streams_for_binary = true
# Annex B Default Database Users
User | Database | Privileges | Description |
---|---|---|---|
serverconf | serverconf | TEMPORARY,CONNECT | The database user used to read/write the serverconf database during application runtime. |
serverconf_admin | serverconf | CREATE,TEMPORARY,CONNECT | The database user used to create/update the serverconf schema. |
messagelog | messagelog | TEMPORARY,CONNECT | The database user used to read/write the messagelog database during application runtime. |
messagelog_admin | messagelog | CREATE,TEMPORARY,CONNECT | The database user used to create/update the messagelog schema. |
opmonitor | op-monitor | TEMPORARY,CONNECT | The database user used to read/write the op-monitor database during application runtime. |
opmonitor_admin | op-monitor | CREATE,TEMPORARY,CONNECT | The database user used to create/update the op-monitor schema. |
postgres | ALL | ALL | PostgreSQL database default superuser. |
# Annex C Deployment Options
# C.1 General
X-Road Security Server has multiple deployment options. The simplest choice is to have a single Security Server with local database. This is usually fine for majority of the cases, but there are multiple reasons to tailor the deployment.
# C.2 Local Database
The simplest deployment option is to use a single Security Server with local database. For development and testing purposes there is rarely need for anything else, but for production the requirements may be stricter.
# C.3 Remote Database
It is possible to use a remote database with Security Server. This option is sometimes used in development and testing when there's need to externalize the database state.
Security server supports a variety of cloud databases including AWS RDS and Azure Database for PostgreSQL. This deployment option is useful when doing development in cloud environment, where use of cloud native database is the first choice.
# C.4 High Availability Setup
In production systems it's rarely acceptable to have a single point of failure. Security server supports provider side high availability setup via so called internal load balancing mechanism. The setup works so that the same member / member class / member code / subsystem / service code is configured on multiple Security Servers and X-Road will then route the request to the server that responds the fastest. Note that this deployment option does not provide performance benefits, just redundancy.
# C.5 Load Balancing Setup
Busy production systems may need scalable performance in addition to high availability. X-Road supports external load balancing mechanism to address both of these problems simultaneously. A load balancer is added in front of a Security Server cluster to route the requests based on selected algorithm. This deployment option is extensively documented in [IG-XLB].
# C.6 Summary
The following table lists a summary of the Security Server deployment options and indicates whether they are aimed for development or production use.
Deployment | Dev | Prod |
---|---|---|
Local database | x | |
Remote database | x | |
High-availability Setup | x | |
Load Balancing Setup | x |
# Annex D Create Database Structure Manually
Depending on installed components, the Security Server uses one to three databases (catalogs):
- serverconf for storing Security Server configuration (required)
- messagelog for storing message records (optional, but installed by default)
- op-monitor for operational monitoring data (optional)
These databases can be hosted on one database server (default setup), or you can use several servers.
Login to the database server(s) as the superuser (postgres
by default) to run the commands, e.g.
psql -h <database host>:<port> -U <superuser> -d postgres
Run the following commands to create the necessary database structures. If necessary, customize the database and role names to suit your environment (e.g when the same database server is shared between several Security Server instances, it is necessary to have separate database names and roles for each server).
serverconf (required)
By default, the database, database user, and schema use the same name of serverconf
, and the admin user is named with _admin
suffix (e.g. serverconf_admin
).
CREATE DATABASE <serverconf_database> ENCODING 'UTF8';
REVOKE ALL ON DATABASE <serverconf_database> FROM PUBLIC;
CREATE ROLE <serverconf_admin_user> LOGIN PASSWORD '<serverconf_admin_user password>';
GRANT <serverconf_admin_user> TO <superuser>;
GRANT CREATE,TEMPORARY,CONNECT ON DATABASE <serverconf_database> TO <serverconf_admin_user>;
\c <serverconf_database>
CREATE EXTENSION hstore;
CREATE SCHEMA <serverconf_schema> AUTHORIZATION <serverconf_admin_user>;
REVOKE ALL ON SCHEMA public FROM PUBLIC;
GRANT USAGE ON SCHEMA public TO <serverconf_admin_user>;
CREATE ROLE <serverconf_database_user> LOGIN PASSWORD '<serverconf_database_user password>';
GRANT <serverconf_database_user> TO <superuser>;
GRANT TEMPORARY,CONNECT ON DATABASE <serverconf_database> TO <serverconf_database_user>;
GRANT USAGE ON SCHEMA public TO <serverconf_database_user>;
GRANT USAGE ON SCHEMA <serverconf_schema> TO <serverconf_database_user>;
GRANT SELECT,UPDATE,INSERT,DELETE ON ALL TABLES IN SCHEMA <serverconf_schema> TO <serverconf_database_user>;
GRANT SELECT,UPDATE ON ALL SEQUENCES IN SCHEMA <serverconf_schema> TO <serverconf_database_user>;
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA <serverconf_schema> TO <serverconf_database_user>;
messagelog (required by xroad-addon-messagelog)
By default, the database, database user, and schema use the same name of messagelog
, and the admin user is named with _admin
suffix (e.g. messagelog_admin
).
CREATE DATABASE <messagelog_database> ENCODING 'UTF8';
REVOKE ALL ON DATABASE <messagelog_database> FROM PUBLIC;
CREATE ROLE <messagelog_admin_user> LOGIN PASSWORD '<messagelog_admin_user password>';
GRANT <messagelog_admin_user> TO <superuser>;
GRANT CREATE,TEMPORARY,CONNECT ON DATABASE <messagelog_database> TO <messagelog_admin_user>;
\c <messagelog_database>
CREATE SCHEMA <messagelog_schema> AUTHORIZATION <messagelog_admin_user>;
REVOKE ALL ON SCHEMA public FROM PUBLIC;
GRANT USAGE ON SCHEMA public TO <messagelog_admin_user>;
CREATE ROLE <messagelog_database_user> LOGIN PASSWORD '<messagelog_database_user password>';
GRANT <messagelog_database_user> TO <superuser>;
GRANT TEMPORARY,CONNECT ON DATABASE <messagelog_database> TO <messagelog_database_user>;
GRANT USAGE ON SCHEMA public TO <messagelog_database_user>;
GRANT USAGE ON SCHEMA <messagelog_schema> TO <messagelog_database_user>;
GRANT SELECT,UPDATE,INSERT,DELETE ON ALL TABLES IN SCHEMA <messagelog_schema> TO <messagelog_database_user>;
GRANT SELECT,UPDATE ON ALL SEQUENCES IN SCHEMA <messagelog_schema> TO <messagelog_database_user>;
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA <messagelog_schema> TO <messagelog_database_user>;
op-monitor (optional, required by xroad-opmonitor)
If operational monitoring is going to be installed, run additionally the following commands. Again, the database and role names can be customized to suit your environment.
By default, the database is named op-monitor
, database user and schema both are named opmonitor
, and the admin user is named with _admin
suffix (e.g. opmonitor_admin
).
CREATE DATABASE <opmonitor_database> ENCODING 'UTF8';
REVOKE ALL ON DATABASE <opmonitor_database> FROM PUBLIC;
CREATE ROLE <opmonitor_admin_user> LOGIN PASSWORD '<opmonitor_admin_user password>';
GRANT <opmonitor_admin_user> TO <superuser>;
GRANT CREATE,TEMPORARY,CONNECT ON DATABASE <opmonitor_database> TO <opmonitor_admin_user>;
\c <opmonitor_database>
CREATE SCHEMA <opmonitor_schema> AUTHORIZATION <opmonitor_admin_user>;
REVOKE ALL ON SCHEMA public FROM PUBLIC;
GRANT USAGE ON SCHEMA public TO <opmonitor_admin_user>;
CREATE ROLE <database_user> LOGIN PASSWORD '<opmonitor_database_user password>';
GRANT <opmonitor_database_user> TO <superuser>;
GRANT TEMPORARY,CONNECT ON DATABASE <opmonitor_database> TO <opmonitor_database_user>;
GRANT USAGE ON SCHEMA public TO <opmonitor_database_user>;
GRANT USAGE ON SCHEMA <opmonitor_schema> TO <opmonitor_database_user>;
GRANT SELECT,UPDATE,INSERT,DELETE ON ALL TABLES IN SCHEMA <opmonitor_schema> TO <opmonitor_database_user>;
GRANT SELECT,UPDATE ON ALL SEQUENCES IN SCHEMA <opmonitor_schema> TO <opmonitor_database_user>;
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA <opmonitor_schema> TO <opmonitor_database_user>;
Lastly, customize the database connection properties to match the values used when creating the database.
Note. When using Microsoft Azure PostgreSQL, the user names need to be in format username@hostname
in the properties files.
Create the configuration file /etc/xroad.properties
.
sudo touch /etc/xroad.properties
sudo chown root:root /etc/xroad.properties
sudo chmod 600 /etc/xroad.properties
Edit /etc/xroad.properties
and add/update the following properties (if you customized the role names, use your own). The admin users are used to run database migrations during the install and upgrades.
serverconf.database.admin_user = <serverconf_admin_user>
serverconf.database.admin_password = <serverconf_admin_user password>
messagelog.database.admin_user = <messagelog_admin_user>
messagelog.database.admin_password = <messagelog_admin_user password>
op-monitor.database.admin_user = <opmonitor_admin_user>
op-monitor.database.admin_password = <opmonitor_admin_user password>
Create the /etc/xroad/db.properties
file
sudo mkdir /etc/xroad
sudo chown xroad:xroad /etc/xroad
sudo chmod 751 /etc/xroad
sudo touch /etc/xroad/db.properties
sudo chmod 0640 /etc/xroad/db.properties
sudo chown xroad:xroad /etc/xroad/db.properties
Edit the /etc/xroad/db.properties
file and add/update the following connection properties (if you customized the database, user, and/or role names, use the customized values).
The database connection url format is jdbc:postgresql://<database host>:<port>/<database name>
serverconf.hibernate.connection.url = jdbc:postgresql://<database host>:<port>/<serverconf_database>
serverconf.hibernate.connection.username = <serverconf_database_user>
serverconf.hibernate.connection.password = <serverconf_database_user password>
serverconf.hibernate.hikari.dataSource.currentSchema = <serverconf_schema>,public
messagelog.hibernate.connection.url = jdbc:postgresql://<database host>:<port>/<messagelog_database>
messagelog.hibernate.connection.username = <messagelog_database_user>
messagelog.hibernate.connection.password = <messagelog_database_user password>
messagelog.hibernate.hikari.dataSource.currentSchema = <messagelog_schema>,public
op-monitor.hibernate.connection.url = jdbc:postgresql://<database host>:<port>/<opmonitor_database>
op-monitor.hibernate.connection.username = <opmonitor_database_user>
op-monitor.hibernate.connection.password = <opmonitor_database_user password>
op-monitor.hibernate.hikari.dataSource.currentSchema = <opmonitor_schema>,public