Version: 2.45
Doc. ID: UG-CS
Date | Version | Description | Author |
---|---|---|---|
28.08.2014 | 0.1 | Initial version | |
28.09.2014 | 0.2 | Translation to English | |
09.10.2014 | 0.3 | Minor updates and corrections. Security Categories removed. | |
09.10.2014 | 0.4 | Add service CA OCSP responder changed to Add top CA OCSP responder | |
14.10.2014 | 0.5 | Title page, header, footer modified | |
28.11.2014 | 0.6 | Logback information added (Chapter 17). Introduction added (Chapter 1). Security Officer user role added (Section 2.1). System Settings added (Chapter 4). Configuration Management added (Chapter 5). Database Management Chapter deleted. | |
1.12.2014 | 1.0 | Minor corrections | |
23.01.2015 | 1.1 | License information. Certification services management and time stamping services management chapters updated (Chapters 11 and 12). | |
30.04.2015 | 1.2 | “sdsb” changed to “xroad” | |
30.06.2015 | 1.3 | Minor corrections done | |
3.07.2015 | 1.4 | Audit Log chapter added (Chapter 14) | |
31.08.2015 | 1.5 | Information about high availability added (Chapter 3) | |
15.09.2015 | 1.6 | Reference to the audit log events added | |
17.09.2015 | 1.7 | Corrections related to high availability added | |
18.09.2015 | 1.8 | Minor corrections done | |
21.09.2015 | 1.9 | References fixed | |
22.10.2015 | 1.10 | Corrections in Chapter 17 | |
04.11.2015 | 1.11 | Updates related to backup and restore (Chapter 13) | |
30.11.2015 | 2.0 | Management service provider configuration updated (Section 4.2); management requests system updated (Chapter 6); key label added to configuration signing key generation (Section 5.4.1); section about adding a subsystem to an X-Road member added (Section 7.3); only subsystems can be registered as Security Server clients or be members of global groups; certification service settings updated (11.1). Editorial changes made. | |
17.12.2015 | 2.1 | Added user instructions for monitoring. | |
14.4.2016 | 2.2 | Added chapter for additional configuration options. | |
5.9.2016 | 2.3 | Added instructions for configuring OCSP fetch interval. | |
20.01.2017 | 2.4 | Added license text and version history | Sami Kallio |
05.03.2018 | 2.5 | Added terms and abbreviations reference and document links | Tatu Repo |
18.08.2018 | 2.6 | Corrected ocspFetchInterval default value (Chapter 16.2) |
Petteri Kivimäki |
15.11.2018 | 2.7 | Minor corrections for Ubuntu 18 | Jarkko Hyöty |
23.01.2019 | 2.8 | Information about automatic approval of auth cert registration requests added. Updates in Chapters 6-8. | Petteri Kivimäki |
06.02.2019 | 2.9 | Information about automatic approval of Security Server client registration requests added. Updates in Chapters 6-8. | Petteri Kivimäki |
02.07.2019 | 2.10 | Security Server owner change added (Chapter 7.10) | Petteri Kivimäki |
14.08.2019 | 2.11 | Added automatic backups | Ilkka Seppälä |
11.09.2019 | 2.12 | Remove Ubuntu 14.04 support | Jarkko Hyöty |
26.11.2019 | 2.13 | Update Chapter 3 with remote database support possiblity | Ilkka Seppälä |
03.12.2019 | 2.14 | Remove HA setup dependency on BDR | Jarkko Hyöty |
13.03.2020 | 2.15 | Add instructions for migrating to remote database | Ilkka Seppälä |
30.03.2020 | 2.16 | Added description of pre-restore backups | Ilkka Seppälä |
04.08.2021 | 2.17 | Add more details about restoring configuration from the command line | Ilkka Seppälä |
11.08.2021 | 2.18 | Update chapter 3.2 about checking the cluster status. | Ilkka Seppälä |
25.08.2021 | 2.19 | Update X-Road references from version 6 to 7 | Caro Hautamäki |
23.09.2022 | 2.20 | Added new Registration Web Service | Eneli Reimets |
26.09.2022 | 2.21 | Remove Ubuntu 18.04 support | Andres Rosenthal |
17.04.2023 | 2.22 | Remove central services support | Justas Samuolis |
19.04.2023 | 2.23 | Removed unused properties from db.properties | Mikk-Erik Bachmannn |
19.05.2023 | 2.24 | New Central Server updates | Eneli Reimets |
01.06.2023 | 2.25 | Update references | Petteri Kivimäki |
31.05.2023 | 2.26 | Added 3.3 API key considerations in High-Availability setup paragraph | Ričardas Bučiūnas |
05.06.2023 | 2.27 | Update HA cluster status endpoint path | Andres Rosenthal |
02.06.2023 | 2.28 | Added security hardening paragraph | Ričardas Bučiūnas |
09.06.2023 | 2.29 | Added REST API paragraph | Vytautas Paliliūnas |
19.06.2023 | 2.30 | Remove table schema_migrations | Eneli Reimets |
28.06.2023 | 2.31 | Update database properties to match new Spring datasource style | Raido Kaju |
10.07.2023 | 2.32 | Update system services | Petteri Kivimäki |
11.07.2023 | 2.33 | Minor updates | Petteri Kivimäki |
20.11.2023 | 2.34 | Security server address change management request | Justas Samuolis |
09.12.2023 | 2.35 | Minor updates | Petteri Kivimäki |
09.12.2023 | 2.36 | Management service TLS certificate | Eneli Reimets |
12.12.2023 | 2.37 | Add a reference to LDAP configuration in Security Server guide | Ričardas Bučiūnas |
12.12.2023 | 2.38 | Client subsystem disabling and enabling management requests | Madis Loitmaa |
15.12.2023 | 2.39 | Publishing global configuration over HTTPS | Eneli Reimets |
20.12.2023 | 2.40 | Automatic configuration signing key rotation | Andres Rosenthal |
19.01.2024 | 2.41 | Minor updates | Eneli Reimets |
26.03.2024 | 2.42 | Passing additional parameters to psql | Ovidijus Narkevicius |
08.04.2024 | 2.43 | Taking configuration download url from shared parameters | Eneli Reimets |
09.06.2024 | 2.44 | Added ACME information for Approved CAs | Mikk-Erik Bachmann |
01.08.2024 | 2.45 | Minor updates | Petteri Kivimäki |
- License
- 1. Introduction
- 2. User and Role Management
- 3. Standalone and High-Availability Systems
- 4. System Settings
- 5. Configuration Management
- 5.1 Viewing the Configuration Settings
- 5.2 Downloading the Configuration Anchor
- 5.3 Re-Creating the Configuration Anchor
- 5.4 Changing the Configuration Signing Keys
- 5.5 Managing the Contents of a Configuration Part
- 5.6 Uploading a Trusted Anchor
- 5.7 Viewing the Contents of a Trusted Anchor
- 5.8 Deleting a Trusted Anchor
- 5.9 Publishing global configuration over HTTPS
- 6. The Management Requests System
- 7 Managing the X-Road Members
- 7.1 Adding a Member
- 7.2 Viewing the Member Details
- 7.3 Adding a Subsystem to an X-Road Member
- 7.4 Registering a Member's Security Server
- 7.5 Registering a Client to a Security Server
- 7.6 Removing a Client from a Security Server
- 7.7 Changing the Owner of Security Server
- 7.8 Deleting a Subsystem
- 7.9 Deleting an X-Road Member
- 8. Managing the Security Servers
- 9. Managing the Global Groups
- 10. Managing the Approved Certification Services
- 11. Managing the Approved Timestamping Services
- 12. Configuration Backup and Restore
- 12.1 Backing Up the System Configuration
- 12.2 Restoring the System Configuration in the User Interface
- 12.3 Restoring the Configuration from the Command Line
- 12.4 Downloading, Uploading and Deleting Configuration Backup Files
- 12.5 Automatic Backups
- 12.6 Backup Encryption Configuration
- 12.7 Verifying Backup Archive Consistency
- 13. Audit Log
- 14. Monitoring
- 15. Additional configuration options
- 16. Logs and System Services
- 17 Management REST API
- 18 Migrating to Remote Database Host
- 19 Additional Security Hardening
- 20 Passing additional parameters to psql
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/.
The intended audience of this User Guide are X-Road Central Server administrators who are responsible for everyday management of the X-Road Central Server.
Instructions for the installation and initial configuration of the Central Server can be found in the Central Server Installation Guide CSI. Instructions for installing the Central Server in a cluster for achieving high availability can be found in the Central Server High Availability Installation Guide IG-CSHA.
See X-Road terms and abbreviations documentation [TA-TERMS].
- [CSI] X-Road 7. Central Server Installation Guide. Document ID: IG-CS
- [IG-CSHA] X-Road 7. Central Server High Availability Installation Guide. Document ID: IG-CSHA
- [JSON] Introducing JSON, http://json.org/
- [SPEC-AL] X-Road: Audit log events. Document ID: SPEC-AL
- [SSI] X-Road 7. Security Server Installation Guide. Document ID: IG-SS
- [IG-CS] X-Road 7. Central Server Installation Guide. Document ID: IG-CS
- [UC-GCONF] X-Road 7: Use Case Model for Global Configuration Distribution. Document ID: UC-GCONF
- [RFC-OCSP] Online Certificate Status Protocol – OCSP, https://tools.ietf.org/html/rfc6960
- [TA-TERMS] X-Road Terms and Abbreviations. Document ID: TA-TERMS.
- [UG-SYSPAR] X-Road: System Parameters User Guide. Document ID: UG-SYSPAR.
- [REST_UI-API] X-Road Central Server Admin API OpenAPI Specification: https://github.com/nordic-institute/X-Road/blob/develop/src/central-server/openapi-model/src/main/resources/openapi-definition.yaml.
- [UG-SS] X-Road 7. Security Server User Guide. Document ID: UG-SS
The Central Server supports the following user roles:
- Registration Officer (
xroad-registration-officer
) is responsible for handling the information about X-Road members. - System Administrator (
xroad-system-administrator
) is responsible for the installation, configuration, and maintenance of the Central Server. - Security Officer (
xroad-security-officer
) is responsible for the application of the security policy and security requirements.
One user can have multiple roles, and multiple users can fulfill the same role. Each role has a corresponding system group, created upon the installation of the system. The system user names are used for logging in to the user interface of the Central Server.
The document indicates in sections similar to the following example, which user role is required for performing a particular action in the user interface. For example
Access rights: System Administrator
Caution: If the logged-in user does not have a permission to carry out a task, the button that initiates the action is hidden (and neither is it possible to run the task using its corresponding keyboard combinations or mouse actions). Only the permitted information and actions are visible and available to the user.
During the installation, a super user equipped with all the roles is created. You can create additional users that have restricted rights. User management is carried out in root user's permissions using the command line.
To add a new user, issue the command:
adduser username
To grant permissions to the user you created, add it to the corresponding system groups, for example:
adduser username xroad-registration-officer
adduser username xroad-system-administrator
adduser username xroad-security-officer
To remove a user’s permission, remove the user from the corresponding system group, for example:
deluser username xroad-registration-officer
To remove a user, enter:
deluser username
X-Road leverages PAM (Pluggable Authentication Modules) for user authentication, which facilitates LDAP integration.
A detailed setup guide can be found under security server user guide 2.3 LDAP user authentication. Please note that x-road property path will be different in case of Central Server. Refer to ug-syspar_x-road_v6_system_parameters.md for relevant properties.
API keys are used to authenticate API calls to Central Server's management REST API. API keys are associated with roles that define the permissions granted to the API key. If an API key is lost, it can be revoked.
In addition to the user roles, an API key can be added to the Management Services role. The Management Services role is used for registration and management services to authenticate and successfully communicate with the management REST API. Registration and management services are automatically configured with valid API keys during installation.
Access rights: System Administrator
To create API key, follow these steps.
- In the Navigation tabs, select Settings --> API Keys, click Create API key.
- In the window that opens, check selected roles checkbox and then click Next.
- In the next window click Create Key.
- Copy and save the API key in a secure place. The API key is visible only at the time of key generation. It will not be presented again and cannot be retrieved later.
- Click Finish.
To edit API key related roles, follow these steps.
- In the Navigation tabs, select Settings --> API Keys.
- Select a API key and click Edit.
- In the window that opens, check selected roles checkbox and click Save.
To revoke API key from roles, follow these steps.
- In the Navigation tabs, select Settings --> API Keys.
- Select a API key and click Revoke key.
- Confirm the revoking by clicking Yes.
The Central Server can be installed and configured in several ways:
- A standalone server with local database
- A standalone server with remote database
- A cluster of Central Servers (nodes) using a remote database. The system continues to function if one or more of the Central Server nodes are experiencing problems or are down for maintenance. If the database is highly available (e.g using hot-standby with automatic fail-over or multi-master replication), the system can also recover from database problems with minimal downtime.
When the system is configured with the most basic option standalone server with local database, there is no high-availability support. If either the web server or the database server break, the system goes down.
In the case of an HA setup, the Central Servers share configuration via an optionally highly-available database. While most of the system settings described in this document apply to the whole cluster, some have a meaning that is local to each node. In addition, all the configuration signing keys are local to each node and must be generated separately. This distinction will be stated explicitly throughout this document, where necessary.
In an HA setup, if the system is configured using different nodes in parallel, the effect will be similar to several people updating the configuration of a standalone server at the same time.
In order to detect the type of deployment and the name of the node in the cluster in the case of HA setup, the logged-in user should check the instance identifier displayed in the left upper corner of the user interface. In the case of an HA setup, the name of the node is displayed in the right upper corner of the user interface.
Access rights: Registration Office, System Administrator, Security Officer
In order to check the status of the nodes in an HA setup, execute the following command on the Central Server node's command line:
curl --header "Authorization: X-Road-ApiKey token=<api key>" -k https://localhost:4000/api/v1/system/high-availability-cluster/status`
Note: This endpoint requires authentication which can be provided with a valid API KEY (with at least one of the aforementioned roles) in the Authorization
header of the request. See Managing API Keys for instructions regarding setting up an API KEY.
API keys are cached in memory, which is typically not a problem in non-clustered Central Server configuration. However, in case of High-Availability setup, the caches of different nodes can become out of sync.
For instance, revoking an API key from node 1
may not be recognized by node 2
, which can still grant access to REST API endpoints with the revoked API key. To address this issue, there are a few potential solutions:
- Option A: Consider decreasing time-to-live value for API key cache from the default of 60 seconds to a more lenient value. Doing so will reduce the risk of stale values being returned, thus improving security.
- Option B: Direct all REST API operations to the same Central Server node.
- Option C: Always restart REST API modules when API key operations are executed.
- Option D: Disable Api key cache. (See admin-service parameters for more details). This option will degrade API throughput and should only be used when other options do not work.
Access rights: Security Officer
To add a member class, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the Member Classes section and click Add.
- In the window that opens, enter the member class code and description. Click Save.
To edit the description of a member class, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the Member Classes section, select a member class and click Edit.
- In the window that opens, enter the member class description and click Save.
To delete a member class, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the Member Classes section, select a member class and click Yes.
Only the member classes that are used by none of the X-Road members can be deleted.
The Central Server provides management services to the Security Servers that are part of the (local) X-Road infrastructure (see Chapter 6).
A subsystem of an X-Road member acting as a service provider for the management services must be appointed in the Central Server (see 4.2.1), registered as a client of the management services’ Security Server (see 4.2.2) and configured to provide the services in the management services’ Security Server (see 4.2.3).
The management services’ Security Server must be installed and registered in the Central Server before the management service provider can be registered as a client of the Security Server and the management services can be configured (see SSI).
Access rights: Security Officer
To appoint the management service provider in the Central Server, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the Management Services section and click Edit on the Service Provider Identifier field.
- In the window that opens, find the subsystem of an X-Road member to be appointed as the management service provider and check the subsystem checkbox and then click Select.
The management service provider can be registered as a Security Server client as described in this section only if the management service provider is not registered as a client of any Security Servers. In case the management service provider is already a client of a Security Server then the Edit button is not shown next to the identifier of the Management Services' Security Server.
To register the appointed management service provider as a Security Server client to the management services’ Security Server, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the Management Services section and click Edit button next to the identifier of the Management Services' Security Server.
- In the window that opens, find the Security Server that will be used as the management services’ Security Server and check checkbox.
- Click Select button to submit the registration request.
On successful registration the identifier of the management services’ Security Server is displayed and Edit button should hide.
Access rights: Security server’s Service Administrator
The data necessary for configuring the management services in the Security Server can be found at the Central Server Settings tab -> System Settings -> Management Services section.
To configure management services in the management services’ Security Server, follow these steps.
- In the Clients tab of the Security Server, select the client who will provide the management services. On the details view click Services sub-tab.
- Click Add WSDL, enter the management services WSDL address in the window that opens and click Add.
- Expand the WSDL, by clicking the > icon, select a service by click Service Code.
- In the window that opens, enter the management services address. If necessary, edit other service parameters. Check the Apply to All in WSDL checkbox and click Save. Ensure that the parameters of all the management services have changed.
- Activate the management service’s WSDL by selecting the row of the WSDL and clicking Enable.
- Navigate to the Service Clients tab.
- Click Add subject and search for the global group security-server-owners. Select the group and click Next.
- In the window that opens, check management services checkboxes (authCertDeletion, clientDeletion, clientReg, ownerChange) and click Add Selected to add the security-server-owners group’s access rights list.
Access rights: Security Officer
In the System Settings view (Settings tab --> System Settings), the Central Server's public DNS name or its external IP address is displayed. This address is used by the Security Servers to access the services provided by the Central Server (configuration download, management services).
ATTENTION! When the Central Server address is changed,
- the management services address in the management services’ Security Server needs to be reconfigured,
- the internal configuration anchor need to be redistributed to the Security Server administrators and
- the external configuration anchor needs to be redistributed to the federation partners.
The services provided by the Central Server must be available from both the new and old address, until all servers using the services have uploaded the configuration anchor containing the new address.
In an HA setup, the address of the Central Server is local to the node that is being configured.
In an HA setup, internal and external configuration anchors contain information about each Central Server that is part of the cluster. If the address of one of the servers is changed, configuration anchors will be re-generated automatically on all the nodes.
To change the Central Server address, follow these steps.
- In the Navigation tabs, select Settings --> System Settings.
- Locate the System Parameters section and click Edit.
- Enter the Central Server’s address and click Save. When the address is changed, the system:
- changes the management services WSDL address,
- changes the management services address,
- changes the configuration source addresses,
- generates new configuration anchors for the internal and external configuration sources.
- After the Central Server address is changed, act as follows.
- Download the internal configuration source anchor and distribute the anchor along with the anchor’s hash value to the Security Server administrators of the local X-Road infrastructure.
NOTE: Starting from version 7.5.0 new Central Server address is automatically distributed to Security Servers within the global configuration. Distribution will take place within two global configuration refresh cycles. However, the new Central Server address is not updated to the configuration anchor stored on the Security Server. If the Security Server's local copy of the global configuration expires, the Security Server returns using the Central Server address from the configuration anchor. Therefore, if the Security Server's local copy of the global configuration is expired, importing a new version of the configuration anchor is required if the current Central Server address doesn't match with the address in the original configuration anchor.
- In case of federated X-Road systems, download the external configuration source anchor and distribute the anchor along with the anchor’s hash value to the federation partners.
NOTE: Starting from version 7.5.0 new Central Server address is automatically distributed to the federation partners within the global configuration. Distribution will take place within two global configuration refresh cycles. However, the new Central Server address is not updated to the configuration anchor stored on the Security Server. If the Security Server's local copy of the global configuration expires, the Security Server returns using the Central Server address from the configuration anchor. Therefore, if the Security Server's local copy of the global configuration is expired, importing a new version of the configuration anchor is required if the current Central Server address doesn't match with the address in the original configuration anchor.
- Reconfigure the management services addresses in the management service Security Server.
Access rights: Security Officer
Registration and Management Service TLS certificate is used to secure the communication between:
- the management Security Server and the member management web service;
- a Security Server and the registration web service.
To see Registration and Management Service TLS certificate info, follow these steps.
- In the Navigation tabs, select Settings --> TLS certificates.
- Locate the Management service TLS certificate section and click certificate hash.
To download Management Service TLS certificate, follow these steps.
- In the Navigation tabs, select Settings --> TLS certificates.
- Locate the Management service TLS certificate section.
- Click button Download certificate and save the prompted file.
To re-create Management Service key and self-signed certificate, follow these steps.
- In the Navigation tabs, select Settings --> TLS certificates.
- Locate the Management service TLS certificate section and click button Re-create key.
- Confirm the re-creating by clicking Confirm.
- Complete the activities defined in section 4.4.1.1 Necessary activities after changing certificate
To generate Management Service certificate signing request, follow these steps.
- In the Navigation tabs, select Settings --> TLS certificates.
- Locate the Management service TLS certificate section and click button Generate CSR.
- Read the information and enter Distinguished name and click button Generate CSR.
- Save prompted file into a safe place.
- Apply for a TSL/SSL certificate from a trusted Certificate Authority (CA) using the CSR file.
To upload Management Service certificate, follow these steps.
- In the Navigation tabs, select Settings --> TLS certificates.
- Locate the Management service TLS certificate section and click button Upload certificate.
- Find the proper certificate file and click Open, to finish certificate uploading click button Upload.
- Complete the activities defined in section 4.4.1.1 Necessary activities after changing certificate
When the key and certificate are rotated, and mTLS is enabled between the management Security Server and the management services, the new certificate must be updated to the management Security Server. To add new certificate follow Security Server User Guide UG-SS instruction in section "Managing Information System TLS Certificates".
ATTENTION!
- The changed TLS certificate is added in the global configuration
private-params.xml
part. The global configuration generation interval on the Central Server and the global configuration fetching interval on the Security Server depend on the system parameters. The system parameters are specified in the UG-SYSPAR section "Center parameters: [admin-service]" and "Configuration Client parameters: [configuration-client]". With the default values, a new Registration and Management service TLS certificate is usable for the authentication certificate registration request on the Security Server side after ~1.5 min. - The changed TLS certificate is automatically detected by Nginx within five minutes after the change.
Access rights: Security Officer, System Administrator
The Global Configuration view consists of three sub-tabs.
- The Internal Configuration view. The internal configuration is distributed by the Central Server to the Security Servers of the local X-Road infrastructure. The information needed to download and verify the internal configuration is included in the internal configuration anchor, which must be distributed to the Security Server administrators and uploaded to the Security Servers. Along with the internal configuration anchor, the anchor file hash value must be distributed. The hash value is used by the Security Server administrators to verify the integrity of the anchor file.
- The External Configuration view. The external configuration is distributed by the Central Server to the federation partners (either to the Security Servers directly or through a configuration proxy). The information needed to download and verify the external configuration is included in the external configuration anchor, which must be distributed to the federation partner’s Central Server (or configuration proxy) administrators and uploaded to the Central Server (or configuration proxy). Along with the external configuration anchor, the anchor file hash value must be distributed. The hash value is used by the federation partners to verify the integrity of the anchor file.
- The Trusted Anchors view. A trusted anchor is the configuration anchor of the configuration source(s) distributing the external configuration of a federation partner. Upon loading the trusted anchor into the Central Server, the anchor is included into the internal configuration, allowing the Security Servers to download the external configuration of a federation partner as well as the internal configuration of the local X-Road infrastructure.
Access rights: Security Officer
To download a configuration anchor, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate.
- In the Anchor section, click Download and save the prompted file.
Access rights: Security Officer
Normally, the configuration anchors are generated (and in an HA setup, distributed to every node) automatically by the system upon changes in the data included in the anchor (one or more Central Server addresses, signing keys). The re-creation of an anchor is necessary mostly for recovering from error situations.
To re-create an anchor, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate.
- In the Anchor section, click Re-create.
Access rights: Security Officer
Key change can be either
- regular change – the key is changed periodically (for example, annually) to minimize the risk of exposure;
- emergency change – the key and all its back-ups have been destroyed or the key has been exposed.
As the key change must be carried out efficiently without disrupting the operation of X-Road, the procedure is completed in two stages, wherein the old key and the new key can exist in parallel.
Note that in an HA setup, each node has its own set of configuration signing keys. The old and new key can exist in parallel on each node. Regular key change should cover all the nodes in a cluster and the new configuration anchor should be distributed after the keys have been changed on each node.
The steps of key change are as follows:
- First, a new key is generated (on each node in HA setups) and the configuration anchor containing the public key part(s) of the key(s) is distributed to X-Road participants. Until all participants have received the public key(s), the old (i.e. current) key(s) is/are used for signing configuration.
- Then, after all participants have received & applied the new public key(s), the old key(s) is/are removed and the new key(s) is/are used to sign configuration.
To perform a regular key change, follow these steps.
- Generate, but do not activate a new configuration signing key (see 5.4.1) (in an HA setup, for each node). The system uses the old (active) key(s) to sign the configuration. Upon the generation of a new key, the system generates a new anchor for the corresponding configuration sources.
- If there are pre 7.4.0 Security Servers within the ecosystem (including federations) then download the anchor (see 5.2) containing the public key part(s) of the new signing key(s) and distribute the anchor along with the anchor file hash value either to these Security Servers' administrators (in case of internal configuration anchor) or to the federation partners (in case of external configuration anchor).
NOTE: Starting from version 7.4.0 new configuration signing keys are automatically distributed to Security Servers within the global configuration. Distribution will take place within two global configuration refresh cycles. However, the new sign keys are not updated to the configuration anchor stored on the Security Server. If the Security Server's local copy of the global configuration expires, the Security Server returns using sign keys from the configuration anchor. Therefore, if the Security Server's local copy of the global configuration is expired, importing a new version of the configuration anchor is required if the current sign keys don't match with the sign keys in the original configuration anchor.
- Activate the new signing key(s) (see 5.4.2). The new signing key(s) should only be activated after all the affected Security Servers have received & applied the new public key (either through automatic configuration signing key rotation or uploading the distributed anchor manually). The Central Servers use the active key to sign configuration. If a server administrator has not applied the new public key before the key is activated, the verification of the downloaded configuration in the Security Servers will fail and the services exchange with the X-Road participants described in the configuration will be discontinued.
- Delete the old signing key (in an HA setup, delete the old keys on all the nodes) (see 5.4.3). Upon the deletion of a key, the system generates a new configuration anchor.
- Download the generated anchor (it does not contain the public key part(s) of the old signing key(s)) and distribute the anchor along with the anchor file hash value either to the Security Server administrators (in case of internal configuration anchor) or to the federation partners (in case of external configuration anchor).
To perform an emergency key change, the new key must be activated and the old key deleted immediately after the generation of the new key (in the steps described above, step 2 is skipped). The configuration anchor distributed to the Security Server administrators (in case of internal configuration anchor) or to the federation partners (in case of external configuration anchor) must only contain the public key part of the new signing key.
Access rights: Security Officer
To generate a configuration signing key, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate.
- In the Signing Keys section, expand the token's information by clicking the caret next to the token name and then click Add key.
- In a window that opens, insert signing key friendly name, and click Add.
- Add key button is only active when the token has been logged in to.
The system will automatically generate the corresponding configuration anchor containing the public key part of the generated key. If the generated key is the only signing key for the configuration source, the key will automatically be set as active.
Access rights: Security Officer
To activate a configuration signing key, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate.
- In the Signing Keys section, expand the token's information by clicking the caret next to the token name and select an inactive key (only for an inactive key are the Activate and Delete buttons displayed) and click Activate.
Access rights: Security Officer
To delete a configuration signing key, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate.
- In the Signing Keys section,expand the token's information by clicking the caret next to the token name and select an inactive key (only for an inactive key are the Activate and Delete buttons displayed) and click Delete.
- Confirm the deletion by clicking Confirm.
Access rights: Security Officer, System Administrator
The contents of a configuration part can be viewed by downloading the configuration part file. Also, configuration file can be uploaded.
To download or upload a configuration file, follow these steps.
- In the Navigation tabs, select Global Configuration and select either the Internal Configuration or External Configuration sub-tab, as appropriate
- In the Configuration Parts section, select a configuration part file and click Download or Upload
Access rights: Security Officer
To upload a trusted anchor, follow these steps.
- In the Navigation tabs, select Global Configuration and select the Trusted Anchors sub-tab.
- Click Upload button, find the external configuration anchor received from a federation partner and click Open.
- Verify the integrity of the anchor file by comparing the displayed anchor file hash value with the hash value provided by the federation partner and confirm the anchor upload by clicking Confirm.
In case a previous anchor from the same federation partner has been uploaded to the system, the new anchor will replace the old one.
Access rights: Security Officer, System Administrator
The contents of a trusted anchor can be viewed by downloading the anchor file. To download an anchor file, follow these steps.
- In the Navigation tabs, select Global Configuration and select the Trusted Anchors sub-tab.
- In an anchor section, click Download.
- Save or open the prompted file.
Access rights: Security Officer
To delete an anchor file, follow these steps.
- In the Navigation tabs, select Global Configuration and select the Trusted Anchors sub-tab.
- In the anchor section, click Delete.
- Confirm the deletion by clicking Yes.
Starting from version 7.4.0, the Central Server supports publishing global configuration over HTTP and HTTPS. Instead, before version 7.4.0, only HTTP was supported.
Starting from version 7.4.0, a new private key and a self-signed TLS certificate are created automatically when installing a new Central Server or upgrading an existing installation from an older version. After the installation or upgrade, the Central Server Administrator must manually apply for a TLS certificate from a trusted Certificate Authority (CA) and then configure the certificate. The CA must be trusted by the Security Server's Java installation. More information about configuring the TLS certificate on the Central Server is available in the Central Server Installation Guide CSI.
Applying for a TLS certificate issued by a trusted CA is required, because the Security Server does not trust the new automatically generated self-signed certificate by default. The Security Server supports disabling certificate verification, but disabling it in production environments is not recommended. More information is available in the [configuration-client]
section of the System Parameters User Guide UG-SYSPAR.
NOTE: When upgrading from a version < 7.4.0 to a version 7.4.*, the configuration anchor must be re-generated and imported to all the Security Servers to enable downloading global configuration over HTTPS.
NOTE: Starting from version 7.5.0, it's not required to re-generate and import the configuration anchor to all the Security Servers to enable downloading global configuration over HTTPS.
As the registration of associations in the X-Road governing authority is security-critical, the following measures are applied to increase security by default:
- The registration request must be submitted to the X-Road Central Server through the Security Server. Manual approval is still required by default.
- The association must be approved by the X-Road governing authority.
There are three types of registration requests:
- authentication certificate registration request (see Sections 7.4 and 8.3);
- Security Server client registration request (see Section 7.5);
- Security Server owner change request (see Section 7.7)
It is possible to streamline the registration process of authentication certificates and Security Server clients by enabling automatic approval.
- authentication certificate registration requests
- When automatic approval is enabled, it is enough to submit an authentication certificate registration request to the X-Road Central Server through the Security Server, and the request will be automatically approved immediately.
- Automatic approval is applied to existing members only.
- By default, automatic approval of authentication certificate registration requests is disabled. It can be enabled by setting the
auto-approve-auth-cert-reg-requests
property value totrue
on Central Server.
- Security Server client registration requests
- When automatic approval is enabled, it is enough to submit a Security Server client registration request to the X-Road Central Server through the Security Server, and the request will be automatically approved immediately.
- Automatic approval is applied to existing members only. In addition, automatic approval is applied only if the client registration request has been signed by the member owning the subsystem to be registered as a Security Server client.
- By default, automatic approval of Security Server client registration requests is disabled. It can be enabled by setting the
auto-approve-client-reg-requests
property value totrue
on Central Server.
- Security Server owner change requests
- When automatic approval is enabled, it is enough to submit a Security Server owner change request to the X-Road Central Server through the Security Server, and the request will be automatically approved immediately.
- Automatic approval is applied to existing members only.
- By default, automatic approval of Security Server owner change requests is disabled. It can be enabled by setting the
auto-approve-owner-change-requests
property value totrue
on Central Server.
A registration request can be in one of the following states. See Figure 1 for the state diagram.
Figure 1. State diagram for registration requests
Pending – a registration request has been submitted from a Security Server. From this state, the request can move to the following states.
- “Approved”, if the registration request is approved in the Central Server (see 7.4, 7.5 and 8.3). The association between the objects of the registration request has been created.
- “Rejected”, if the registration request is declined in the Central Server (see 7.4, 7.5 and 8.3).
- “Revoked”.
- Registration request received from a Security Server are automatically revoked by deletion requests sent from the Security Server for the same object that was submitted for registration with the registration request.
If automatic approval of authentication certificate registration requests, Security Server client registration requests and/or Security Server owner change requests is enabled, the request is approved automatically. Therefore, the request moves directly to Approved state.
Deleted requests is submitted through a Security Server or formalized in the Central Server.
Deletion requests are
- authentication certificate deletion request (see Section 8.4);
- Security Server client deletion request (see Section 7.6).
Address change request is submitted through a Security Server to change its address. The request does not require any additional approvals on the Central Server.
Security Server can disable client subsystem temporarily by issuing "Disable client" request. Disabled client can be enabled again to with "Enable client" request. These requests do not require any additional approvals on Central Server.
Access rights: Registration Officer
To open the detail view, follow these steps.
- In the Management Requests tab.
- Select from the table a request and click Id field.
- Uncheck "Show only pending requests" checkbox, if you want to see all requests.
There are three data sections in the view.
- Information about the request.
- Request ID – the identifier of the request;
- Received – the date and time of saving the request in the Central Server;
- Source – the source of the request. The request can be either submitted through a Security Server (SECURITY_SERVER) or automatically generated in the Central Server (CENTER);
- Status (only for registration requests) – the state of the request, see Figure 1;
- Comments – the source event for the automatic generation of the request. For example, when a Security Server is deleted from the Central Server, deletion requests are automatically generated for all the clients and authentication certificates registered for this Security Server. In the "Comments" field of the generated requests, a comment with the server identifier is added in such case. This field is left empty for requests that are not automatically generated by the Central Server.
- Information about the Security Server associated with the request.
- Owner Name – the name of the Security Server owner (X-Road member);
- Owner Class – the member class of the Security Server owner;
- Owner Code – the member code of the Security Server owner;
- Server Code – the code of the Security Server;
- Address – the address of the Security Server. The field is filled only for authentication certificate registration and Security Server address change requests.
- Information about the request object – that is, the client or the authentication certificate being registered or deleted.
For the authentication certificate:
- CA – the name of the certification authority that issued the certificate;
- Serial Number – the serial number of the certificate;
- Subject – all attributes of the certificate's Subject field;
- Expires – the expiration date of the certificate;
For the Security Server client:
- Name – the name of the X-Road member managing the subsystem;
- Class – the member class of the X-Road member managing the subsystem;
- Code – the member code of the X-Road member managing the subsystem;
- Subsystem – the code of the subsystem.
Access rights: Registration Officer
To add a new X-Road member, follow these steps.
- In the Members tab, click Add member.
- In the window that opens, enter the member's information and click Add. The new member appears in the list of members.
Access rights: Registration Officer
To open the detail view, follow these steps.
- In the Members tab.
- Select from the table an X-Road member and click members name.
The view consists of five sections and a tab Subsystems.
- "Member name"
- "Member class"
- "Member code"
- "Owned Servers" – displays the codes of servers owned by this member.
- "Global Groups" – displays information about the group membership of the member or its subsystems.
- "Subsystems" tab – displays a list of member's subsystems. If a subsystem is not a client of any Security Servers, then subsystem status is UNREGISTERED.
Access rights: Registration Officer
To add a subsystem to an X-Road member, follow these steps.
- In the Members tab, select the member to whom you wish to add a subsystem and click members name.
- In the view that opens, locate the Subsystems tab and click Add new subsystem to database.
- Enter the code of the subsystem and click Add.
Access rights: Registration Officer
The actions required to register an X-Road member's Security Server depend on whether automatic approval of authentication certificate registration requests is enabled or disabled (default).
When automatic approval of authentication certificate registration requests is enabled, the following action must be taken:
- An authentication certificate registration request must be sent from the Security Server to the Central Server by the Security Server administrator.
Automatic approval of authentication certificate registration requests is disabled by default. In that case, to register an X-Road member's Security Server, the following actions must be taken.
- An authentication certificate registration request must be sent from the Security Server to the Central Server by the Security Server administrator;
- The requests must be approved or declined by the Central Server administrator.
To approve a request, it can be done either through in the Management request view list or in the Management request details view.
On the approval of the request
- the request moves to the "Approved" state;
- the registered Security Server appears both in the "Owned Servers" section of its owner’s detail view and in the list of Security Servers (in the Security Servers tab);
- the Security Server's owner is added to the global "security-server-owners" group.
To decline a request, it can be done either through in the Management request view list or in the Management request details view. On the decline of the request
- the request moves to the "Rejected" state.
Access rights: Registration Officer
The actions required to register a subsystem of an X-Road member as a Security Server client depend on whether automatic approval of Security Server client registration requests is enabled or disabled (default).
When automatic approval of Security Server client registration requests is enabled, the following action must be taken:
- A Security Server client registration request must be sent from the Security Server to the Central Server by the Security Server administrator.
Automatic approval of Security Server client registration requests is disabled by default. In that case, to register a subsystem of an X-Road member as a Security Server client, the following actions must be taken.
- A Security Server client registration request must be sent from the Security Server to the Central Server by the Security Server administrator;
- The requests must be approved or declined by the Central Server administrator.
To approve a request, it can be done either through in the Management request view list or in the Management request details view.
On the approval of the request, follow these steps.
- The request moves to the "Approved" state.
- The client's information is displayed in the "Clients" section of the detailed view of the Security Server to which the client was registered.
To decline a request, it can be done either through in the Management request view list or in the Management request details view. On the decline of the request
- the request moves to the "Rejected" state.
Access rights: Registration Officer
The association between an X-Road member and a Security Server is deleted by the corresponding Security Server's client deletion request. The request can be submitted through the Security Server or in the Central Server.
The association between the Security Server's owner and the Security Server cannot be deleted.
Removing a client from the Security Server clients can be carried out through a member's detail view.
To submit a Security Server client deletion request through a member's detail view, follow these steps.
- In the Members tab, select the member whose subsystem is to be removed from a Security Server and click members name.
- In the window that opens, select Subsystems tab and select the client subsystem, and click Unregister.
- Review the information displayed on the client deletion request and click Delete to submit the request.
Access rights: Registration Officer
The actions required to change a Security Server's owner depend on whether automatic approval of Security Server owner change requests is enabled or disabled (default).
When automatic approval of Security Server owner change requests is enabled, the following action must be taken:
- A Security Server owner change request must be sent from the Security Server to the Central Server by the Security Server administrator.
Automatic approval of Security Server owner change requests is disabled by default. In that case, to change the owner of a Security Server, the following action must be taken.
- A Security Server owner change request must be sent from the Security Server to the Central Server by the Security Server administrator.
- The requests must be approved or declined by the Central Server administrator.
To approve/decline a request, it can be done either through in the Management request view list or in the Management request details view.
Access rights: Registration Officer
In the Central Server, the X-Road member's subsystem can be deleted only if the subsystem is not associated with any Security Servers, that is, not registered as a client of any Security Servers.
To delete an X-Road member's subsystem, follow these steps.
- In the Members tab, select the member whose subsystem you wish to delete and click members name.
- In the window that opens, select Subsystems tab and select the client subsystem, and click Delete. Note: The "Delete" button is displayed only if the subsystem is not a client of any Security Servers.
Access rights: Registration Officer
When an X-Road member is deleted, information about all Security Servers in its ownership will be deleted as well.
To delete an X-Road member, follow these steps.
- In the Members tab, select a member that you wish to delete, and click members name.
- In the view that opens, click Delete member "<member name>". In the confirmation window that opens, enter member code and click Delete.
Access rights: Registration Officer
To open the detail view, follow these steps. In the Members tab, select a member that you wish to delete, and click members name.
- In the Security Servers tab.
- Choose from the table a Security Server and click server code.
The view contains three sections.
- "Details" – information about the server and its owner.
- "Clients" – information about clients registered for this Security Server. Hint: Click a client's member name to open the client's detail view.
- "Authentication Certificates" – information about the Security Server's registered authentication certificates. Hint: Click a certificate's certification authority to open the certificate's detail view.
Access rights: Registration Officer
By default, the Security Server's address is provided in the registration request of the authentication certificate sent from the Security Server. The address must be changed if it was not set when the request was submitted or if it is no longer valid.
There are several reasons why setting the Security Server’s address matters.
- The services that are relayed through a Security Server become available once the Security Server’s address is set.
- By registering the addresses of Security Servers, the service clients are certain to receive a response to their queries in a reasonable time, even if the relaying Security Server is overloaded with service requests (e.g., the requests from addresses belonging to registered Security Servers are served before requests coming from unknown addresses).
The request can be submitted through the Security Server or changed in the Central Server.
To change the Security Server address from the Central Server, follow these steps.
- In the Security Servers tab, select the Security Server whose address you wish to change and click server code.
- In the view that opens, locate the "Address" section and click Edit adjacent to the "Address" field.
- Enter the Security Server's address and click Save.
Access rights: Registration Officer
The actions required to register a Security Server's authentication certificate depend on whether automatic approval of authentication certificate registration requests is enabled or disabled (default).
When automatic approval of authentication certificate registration requests is enabled, the following action must be taken:
- An authentication certificate registration request must be sent from the Security Server to the Central Server by the Security Server administrator.
Automatic approval of authentication certificate registration requests is disabled by default. In that case, to register a Security Server's authentication certificate, the following actions must be taken.
- An authentication certificate registration request must be sent from the Security Server to the Central Server by the Security Server administrator;
- The requests must be approved or declined by the Central Server administrator.
To approve/decline a request, it can be done either through in the Management request view list or in the Management request details view.
Upon approving the request
- the request moves to the "Approved" state;
- the registered authentication certificate appears in the Security Server's detail view, in the "Authentication Certificates" section.
To decline the request
- the request moves to the "Rejected" state;
Access rights: Registration Officer
The authentication certificate registered for a Security Server is deleted when an authentication certificate deletion request is received for that certificate. The request can be submitted through the Security Server or in the Central Server.
To submit an authentication certificate deletion request in the Central Server, follow these steps.
- In the Security Servers tab, select the Security Server whose certificate you wish to delete and click server code.
- In the view that opens, locate the Authentication Certificates section, find the correct authentication certificate and click Delete.
- Review the information displayed on the deletion request and enter Security Server code and click Delete to submit the request.
- The submitted request appears in the management requests view (Management Requests tab).
Access rights: Registration Officer
To delete a Security Server, follow these steps.
- In the Security Servers tab, select the Security Server that you wish to delete and click server code.
- In the view that opens, on the bottom left, click Delete Security Server "<server code>". Confirm the action by entering Security Server code and clicking Delete.
If the Security Server being deleted has registered clients or authentication certificates, deletion requests for those associations are automatically generated.
Access rights: Registration Officer
To add a new global group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources and click Add Global Group.
- In the window that opens, enter the new group's code and description, and click Add. The new group is added to the list of global groups.
Access rights: Registration Officer
To see the details of a global group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources.
- Select a global group from the table and click code.
In the global group detail view, a list of the group's members is displayed. The detail view allows you to change the group's description, delete the group, and add or remove its members.
Access rights: Registration Officer
To change the description of a global group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources.
- Select a global group from the table and click its Code.
- In the view that opens, click Edit, change the group’s description and click Save.
Access rights: Registration Officer
Note that the members of the global group security-server-owners are managed automatically by the Central Server and cannot be added or removed manually.
To add members (can be X-Road members or subsystems) to a global group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources.
- Select a global group from the table and click its Code.
- In the view that opens, click Add Members.
- Select one or more subsystems from the list and click Add. Or filter a selection of subsystems with the search function.
To remove members from a group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources.
- Select a global group from the table and click its Code.
- Click Remove button on the selected subsystem row.
- In the confirmation window that opens, enter the member code and then click Delete.
Access rights: Registration Officer
To delete a global group, follow these steps.
- In the Navigation tabs, select Settings --> Global Resources.
- Select a global group from the table and click its Code.
- In the view that opens, click Delete Group and in the confirmation window click Yes.
Access rights: System Administrator
To add a certification service, follow these steps.
- In the Trust Services tab, click Add certification service
- Locate the certification service CA certificate file and click Upload.
- Set the certification service settings as follows.
- If the certification service issues only authentication certificates, check the "This CA can only be used for TLS authentication" checkbox. However, if the certification service issues additionally or only signing certificates, leave the checkbox empty.
- Enter the fully qualified class name that implements the ee.ria.xroad.common.certificateprofile.CertificateProfileInfo interface to the field Certificate profile info (for example: ee.ria.xroad.common.certificateprofile.impl.SkKlass3CertificateProfileInfoProvider).
- If the certification service supports ACME, then check the "This CA can be used for ACME" checkbox. This will reveal additional ACME specific fields:
- ACME server directory URL (required): used by the Security Servers to do certificate related operations via the ACME Server API.
- ACME server IP address(es): a list of ACME Server source IPs that are used to complete the ACME HTTP challenge with the Security Server. Multiple addresses are separated by a comma. This information is shown in the Security Server UI.
- Authentication certificate profile ID: profile ID used for some ACME servers to let them know the certificate usage type when ordering an authentication certificate.
- Signing certificate profile ID: profile ID used for some ACME servers to let them know the certificate usage type when ordering a signing certificate.
- If the CA certificate contains the certification service CA’s OCSP service information, and the PKI does not have intermediate CAs, the procedure is complete.
- If necessary, enter the certification service CA’s OCSP service URL and certificate in the OCSP Responders tab by clicking Add.
- Information about intermediate CAs can be added in the Intermediate CAs tab. To add a new intermediate CA
- click Add;
- in the window that opens, locate the certificate file of the intermediate CA and click Save;
- to add OCSP service information to the new intermediate CA, click on the added intermediate CA, in the window that opens, locate OCSP Responders tab and click Add.
Access rights: System Administrator
While it is not possible to change the certification service's CA certificate, it is possible to
- change the service settings;
- add, change, and delete the certificate service CA’s OCSP services;
- add, change, and delete the certificates and OCSP service information of intermediate CAs.
To edit a certification service, follow these steps.
- In the Trust Services tab, select Certification Services.
- Select from the list the certification service you want to edit and click on the approved certification service field.
Access rights: System Administrator
To delete a certification service from the list of approved services, follow these steps.
- In the Trust Services tab, select Certification Services.
- Select from the list the approved certification service you wish to remove and click on the approved certification service field.
- In the window that opens, click Delete trust service "<certification service name>" and in the confirmation window click Yes.
Access rights: System Administrator
To add an approved timestamping service, follow these steps.
- In the Trust Services tab, click Add timestamping service.
- In the window that opens, enter the timestamping service URL and locate the certificate file of the timestamping service and click Add.
- Information about the new timestamping service appears in the list.
Access rights: System Administrator
To change the timestamping service, follow these steps.
- In the Trust Services tab, select Timestamping Services, select a timestamping service from the list and click Edit.
- In the window that opens, edit the URL and/or upload new certificate. Click Save.
Access rights: System Administrator
To remove a timestamping service, follow these steps.
- In the Trust Services tab, select Timestamping Services, select a timestamping service from the list and click Delete.
- In the window that opens, click Yes.
Access rights: System Administrator
The Central Server backs up
the database (excluding the database schema) and
the directories /etc/xroad/
and /etc/nginx/sites-enabled/
.
Backups contain sensitive information that must be kept secret (for example, private keys and database credentials). In other words, leaking this information could easily lead to full compromise of Central Server. Therefore, it is highly recommended that backup archives are encrypted and stored securely. Should the information still leak for whatever reason the Central Server should be considered as compromised and reinstalled from scratch.
Central Server backups are signed and optionally encrypted. The GNU Privacy Guard [GnuPG] is used for encryption and signing. Central Server's backup encryption key is generated during Central Server initialisation. In addition to the automatically generated backup encryption key, additional public keys can be used to encrypt backups.
To back up the configuration, follow these steps.
- In the Settings tab, select Back Up and Restore sub-tab.
- Click Back up config. to start the backup process.
- When done, the configuration backup file appears in the list of configuration backup files.
To restore configuration, follow these steps.
- In the Settings tab, select Back Up and Restore sub-tab.
- Select a file from the list of configuration backup files and click Restore.
- Confirm to proceed.
- A popup notification shows after the restore whether the restoring was successful or not.
If something goes wrong while restoring the configuration it is possible to revert back to the old configuration. Central Server stores so called pre-restore configuration automatically to /var/lib/xroad/conf_prerestore_backup.tar
. Move it to /var/lib/xroad/backup/
folder and use the command line interface described in the next chapter (some specific switches with the restore command is required).
To restore configuration from the command line, the following data must be available:
- the instance ID of the Central Server and,
- in HA setup, the node name of the Central Server.
It is expected that the restore command is run by the xroad user.
Use the following command to restore configuration in non-HA setup:
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -i <instance_ID> -f <path + filename> [-P -N]
In HA setup, this command has an additional mandatory parameter, the node name:
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -i <instance_ID> -n <node_name> -f <path + filename> [-P -N]
For example (all in one line, non-HA setup):
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -i EE -f /var/lib/xroad/backup/conf_backup_20230515-114736.gpg
For example (all in one line, HA setup):
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -i EE -n node_0 -f /var/lib/xroad/backup/conf_backup_20230515-114736.gpg
In case original backup encryption and signing key is lost additional parameters can be specified to skip decryption and/or signature verification. Use -P
command line switch when backup archive is already decrypted externally and -N
switch to skip checking archive signature.
If a backup is restored on a new uninitialized (the initial configuration hasn't been completed) Central Server, the Central Server's gpg key must be manually created before restoring the backup:
/usr/share/xroad/scripts/generate_gpg_keypair.sh /etc/xroad/gpghome <instance_ID>
If it is absolutely necessary to restore the system from a backup made on a different Central Server, the forced mode of the restore command can be used with the –F option. For example:
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -F -P -f /var/lib/xroad/backup/conf_backup_20230515-114736.tar
In case backup archives were encrypted they have to be first unencrypted in external safe environment and then securely transported to Central Server filesystem.
It is possible to restore the configuration while skipping the database restoration by appending the -S switch, e.g.
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -i <instance_ID> -f <path + filename> -S
To see all the possible parameters use the -h switch, e.g.
/usr/share/xroad/scripts/restore_xroad_center_configuration.sh -h
The following actions can be performed in the Backup And Restore view.
To save the configuration backup file locally:
- click Download on the respective row and save the prompted file.
To delete the configuration backup file:
- click Delete on the respective row and confirm the action by clicking Yes.
To upload a configuration file from the local file system to the Central Server:
- click Upload backup, select a file to be uploaded and click Open. The uploaded configuration file appears in the list of configuration files.
By default the Central Server backs up its configuration automatically once every day. Backups older than 30 days are automatically removed from the server. If needed, the automatic backup policies can be adjusted by editing the /etc/cron.d/xroad-center
file.
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 [center]
section (add or edit this section).
[center]
backup-encryption-enabled = true
backup-encryption-keyids = <keyid1>, <keyid2>, ...
To turn backup encryption on, change the backup-encryption-enabled
property to true. 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 Central Server private key is lost. It is up to Central Server 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.
Additional keys for backup encryption should be generated and stored outside Central Server in a secure environment. After gpg keypair has been generated, public key can be exported to a file ([email protected] is the name of the key being exported) using this command:
gpg --output backupadmin.publickey --armor --export [email protected]
Resulting file backupadmin.publickey
should be moved to Central Server and imported to back up gpg keyring. Administrator should make sure that the key has not been changed during transfer, for example by validating the key fingerprint.
Private keys corresponding to additional backup encryption public keys must be handled safely and kept in secret. Any of them can be used to decrypt backups and thus mount attacks on the Central Servers.
Configuration example
Generate a keypair for encryption with defaults and no expiration and export the public key:
gpg [--homedir <admin gpghome>] --quick-generate-key [email protected] default default never
gpg [--homedir <admin gpghome>] --export [email protected] >[email protected]
Import the public key to the gpg keyring in /etc/xroad/gpghome
directory and take note of the key id.
gpg --homedir /etc/xroad/gpghome --import [email protected]
Edit the key and add ultimate trust.
gpg --homedir /etc/xroad/gpghome/ --edit-key <key id>
At the gpg>
prompt, type trust
, then type 5
for ultimate trust, then y
to confirm, then quit
.
Add the key id to /etc/xroad/conf.d/local.ini
file (editing the file requires restarting X-Road services), e.g.:
[center]
backup-encryption-enabled = true
backup-encryption-keyids = 87268CC66939CFF3
To decrypt the encrypted backups, use the following syntax:
gpg --homedir /etc/xroad/gpghome --output <output file name> --decrypt <backup name>
During restore Central Server verifies consistency of backup archives automatically, archives are not checked during upload. Also, it is possible to verify the consistency of the archives externally. For verifying the consistency externally, Central Server's public key is needed. When backups are encrypted, then a private key for decrypting archive is also needed. GPG uses "sign then encrypt" scheme, so it is not possible to verify encrypted archives without decrypting them.
Automatic backup verification is only possible when original Central Server keypair is available. Should keypair on the Central Server be lost for whatever reason, automatic verification is no longer possible. Therefore, it is recommended to export backup encryption public key and import it into separate secure environment. If backups are encrypted, Central Server public key should be imported to keyrings holding additional encryption keys, so that backups can be decrypted and verified in these separate environments.
To export Central Servers backup encryption public key use the following command:
gpg --homedir /etc/xroad/gpghome --armor --output server-public-key.gpg --export <instanceId>
where <instanceId>
is the Central Server instance id,
for example, EE
.
Resulting file (server-public-key.gpg
) should then be exported from Central Server and imported to GPG keystore used
for backup archive consistency verification.
The Central Server keeps an audit log of the events performed by the Central Server administrator. The audit log events are generated by the user interface and the management REST API when the user changes the system’s state or configuration. The user actions are logged regardless of whether the outcome of the action was a success or a failure. The complete list of the audit log events is described in SPEC-AL.
Actions that change the system’s state or configuration but are not carried out using the user interface or the management REST API are not logged (for example, X-Road software installation and upgrade, user creation and permission granting, and changing of the configuration files in the file system).
An audit log record contains correlation-id, which can be used to link the record to other log messages about the same request.
An audit log record contains:
- the description of the user action,
- the date and time of the event,
- the username of the user that performed the action,
- the authentication type used for this request (Session, ApiKey or HttpBasicPam)
Session
– session based authentication (web application)ApiKey
- direct API call using API key authenticationHttpBasicPam
– HTTP basic authentication with PAM login (for api key management API operations),
- the API url for this request,
- the IP address of the user, and
- the data related to the event.
For example, adding a new member in the Central Server produces the following log record:
2023-05-21T16:20:06+03:00 my-central-server-host correlation-id: [655a2150c4688558] INFO [X-Road Central Server Admin Service] 2023-05-21T16:20:06.267+03:00 - {"event":"Add member","user":"xrd","ipaddress":"192.0.2.1","auth":"Session","url":"/api/v1/members","data":{"memberName":"SS2 OWNER","memberClass":"TEST","memberCode":"SS2_OWNER"}}
The event is present in JSON JSON format, in order to ensure machine processability. The field event represents the description of the event, the field user represents the user name of the performer, and the field data represents data related with the event. The failed action event record contains an additional field reason for the error message. For example:
2023-05-21T12:16:11+03:00 my-central-server-host correlation-id: [f9ee1a7bdf3e3d19] INFO [X-Road Central Server Admin Service] 2023-05-21T12:16:11.232+03:00 - {"event":"Log in to token failed","user":"xrd","ipaddress":"192.0.2.1","reason":"Token action not possible","warning":false,"auth":"Session","url":"/api/v1/tokens/0/login","data":{"tokenId":"0","tokenSerialNumber":null,"tokenFriendlyName":"softToken-0"}}
By default, audit log is located in the file
/var/log/xroad/audit.log
The X-Road software writes the audit log to the syslog (rsyslog) using UDP interface (default port is 514). Corresponding configuration is located in the file
/etc/rsyslog.d/90-udp.conf
The audit log records are written with level INFO and facility LOCAL0. By default, log records of that level and facility are saved to the X-Road audit log file
/var/log/xroad/audit.log
The default behavior can be changed by editing the rsyslog configuration file
/etc/rsyslog.d/40-xroad.conf
Restart the rsyslog service to apply the changes made to the configuration file
service rsyslog restart
The audit log is rotated monthly by logrotate. To configure the audit log rotation, edit the logrotate configuration file
/etc/logrotate.d/xroad-center
In order to save hard disk space and avoid loss of the audit log records during Central Server crash, it is recommended to archive the audit log files periodically to an external storage or a log server.
The X-Road software does not offer special tools for archiving the audit log. The rsyslog can be configured to redirect the audit log to an external location.
Monitoring is taken to use by installing the monitoring support (see IG-CS and appointing the central monitoring client as specified below.
Identity of central monitoring client (if any) is configured using Central Server's admin user interface. Configuration is done by updating a specific optional configuration file (see UC-GCONF) monitoring-params.xml. This configuration file is distributed to all Security Servers through the global configuration distribution process (see UC-GCONF).
<tns:conf xmlns:id="http://x-road.eu/xsd/identifiers" xmlns:tns="http://x-road.eu/xsd/xroad.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://x-road.eu/xsd/xroad.xsd">
<monitoringClient>
<monitoringClientId id:objectType="SUBSYSTEM">
<id:xRoadInstance>fdev</id:xRoadInstance>
<id:memberClass>GOV</id:memberClass>
<id:memberCode>1710128-9</id:memberCode>
<id:subsystemCode>LIPPIS</id:subsystemCode>
</monitoringClientId>
</monitoringClient>
</tns:conf>
One can configure either one member or a member's subsystem to be the central monitoring client. Permission to execute monitoring queries is strictly limited to that single member or subsystem - defining one subsystem to be a monitoring client does not grant the corresponding member access to querying monitoring data (and vice versa).
To disable central monitoring client altogether, update configuration to one which has no client:
<tns:conf xmlns:id="http://x-road.eu/xsd/identifiers" xmlns:tns="http://x-road.eu/xsd/xroad.xsd" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://x-road.eu/xsd/xroad.xsd">
<monitoringClient>
</monitoringClient>
</tns:conf>
For additional robustness the OCSP RFC-OCSP response verifier can be configured to skip checking of nextUpdate parameter. By default the checking is turned on and to turn it off the user has to take action.
Configuration is done by updating a specific optional configuration file (see UC-GCONF) nextupdate-params.xml. This configuration file is distributed to all Security Servers through the global configuration distribution process (see UC-GCONF).
<xro:conf xmlns:xro="http://x-road.eu/xsd/xroad.xsd">
<verifyNextUpdate>true</verifyNextUpdate>
</xro:conf>
With verifyNextUpdate element value “false” the nextUpdate parameter checking is switched off.
The xroad-signer component has a specific interval how often it downloads new OCSP RFC-OCSP responses. By default the fetch interval is configured to 1200 seconds. To use something else than the default value a global configuration extension part (see UC-GCONF) of specific format can be uploaded to Central Server.
<xro:conf xmlns:xro="http://x-road.eu/xsd/xroad.xsd">
<ocspFetchInterval>1200</ocspFetchInterval>
</xro:conf>
The value is the fetch interval in seconds for new OCSP responses.
Most significant Central Server services are the following:
Service | Purpose | Log |
---|---|---|
xroad-center | X-Road Central Server admin UI and REST management API | /var/log/xroad/centralserver-admin-service.log |
xroad-center-registration-service | X-Road Central Server Registration Service | /var/log/xroad/centralserver-registration-service.log |
xroad-center-management-service | X-Road Central Server Management Service | /var/log/xroad/centralserver-management-service.log |
xroad-signer | The service that manages key settings | /var/log/xroad/signer.log |
nginx | The Web server that distributes global configuration | /var/log/nginx/ |
System services can be managed using the systemd facility. To start a service, issue the following command as a root user:
systemctl start <service>
To stop a service, enter:
systemctl stop <service>
To read logs, a user must have root user's rights or belong to the xroad system group.
For logging, the Logback system is used.
Logback configuration files are stored in the /etc/xroad/conf.d/
directory.
Default settings for logging are the following:
- logging level: INFO;
- rolling policy: whenever file size reaches 100 MB.
Central Server has a REST API that can be used to do all the same server configuration operations that can be done using the web UI.
Management REST API is protected with an API key based authentication. To execute REST calls, API keys need to be created.
REST API is protected by TLS. Since server uses self-signed certificate, the caller needs to accept this (for example
with curl
you might use --insecure
or -k
option).
Requests sent to REST API have a limit for maximum size. If a too large request is sent to REST API, it will not be processed, and http status 413 Payload too large will be returned. There is a different limit for binary file uploads, and for other requests.
Limits are
- 10MB for file uploads
- 50KB for other requests
REST API is also rate limited. Rate limits apply per each calling IP. If the number of calls from one IP address exceeds the limit, endpoints return http status 429 Too Many Requests.
Limits are
- 600 requests per minute
- 20 requests per second
If the default limits are too restricting (or too loose), they can be overridden with admin-service parameters:
request-sizelimit-regular
request-sizelimit-binary-upload
rate-limit-requests-per-second
rate-limit-requests-per-minute
Size limit parameters support formats from Formats from DataSize,
for example 5MB
.
Access rights: System Administrator
An API key is linked to a role or roles, and grants access to the operations that are allowed for that role/roles. Separate REST endpoints exist for API key management. API key management endpoints are authenticated to with HTTP basic authentication (username and password) or with session authentication (for admin web application). Basic authentication access is limited to localhost by default, but this can be changed using System Parameters [UG-SYSPAR].
A new API key is created with a POST
request to /api/v1/api-keys
. Message body must contain the roles to be
associated with the key. Server responds with data that contains the actual API key. After this point the key
cannot be retrieved, as it is not stored in plaintext.
curl -X POST -u <user>:<password> https://localhost:4000/api/v1/api-keys --data '["XROAD_REGISTRATION_OFFICER"]' --header "Content-Type: application/json" -k
{
"id": 5,
"key": "68117d38-8613-40b4-a9ff-5afe5ea4d27b",
"roles": [
"XROAD_REGISTRATION_OFFICER"
]
}
In this example the created key was 68117d38-8613-40b4-a9ff-5afe5ea4d27b
.
Existing API keys can be listed with a GET
request to /api/v1/api-keys
. This lists all keys, regardless of who has created them.
curl -X GET -u <user>:<password> https://localhost:4000/api/v1/api-keys -k
[
...
{
"id": 5,
"roles": [
"XROAD_REGISTRATION_OFFICER"
]
},
{
"id": 6,
...
]
You can also retrieve a single API key with a GET
request to /api/v1/api-keys/{id}
.
curl -X GET -u <user>:<password> https://localhost:4000/api/v1/api-keys/59 -k
{
"id": 5,
"roles": [
"XROAD_REGISTRATION_OFFICER"
]
}
An existing API key is updated with a PUT
request to /api/v1/api-keys/{id}
. Message body must contain the roles to be
associated with the key. Server responds with data that contains the key id and roles associated with the key.
curl -X PUT -u <user>:<password> https://localhost:4000/api/v1/api-keys/5 --data '["XROAD_SECURITY_OFFICER”,”XROAD_REGISTRATION_OFFICER"]' --header "Content-Type: application/json" -k
{
"id": 5,
"roles": [
"XROAD_SECURITY_OFFICER",
"XROAD_REGISTRATION_OFFICER"
]
}
An API key can be revoked with a DELETE
request to /api/v1/api-keys/{id}
. Server responds with HTTP 200
if
revocation was successful and HTTP 404
if key did not exist.
curl -X DELETE -u <user>:<password> https://localhost:4000/api/v1/api-keys/5 -k
Access rights: Depends on the API.
Once a valid API key has been created, it is used by providing an Authorization: X-Road-ApiKey token=<api key>
HTTP
header in the REST calls. For example
curl --header "Authorization: X-Road-ApiKey token=ff6f55a8-cc63-4e83-aa4c-55f99dc77bbf" "https://localhost:4000/api/v1/clients" -k
{
"clients": [
{
"client_id": {
"instance_id": "CS",
"type": "MEMBER",
"member_class": "ORG",
"member_code": "999",
"encoded_id": "CS:ORG:999"
},
"member_name": "Foo Name"
},
...
The available APIs are documented in OpenAPI specification [REST_UI-API]. Access rights for different APIs follow the same rules as the corresponding UI operations. Access to regular APIs is allowed from all IP addresses by default, but this can be changed using System Parameters [UG-SYSPAR].
The REST API endpoints return an x-road-ui-correlation-id HTTP header. This header is also logged in centralserver-admin-service.log
, so it
can be used to find the log messages related to a specific API call.
The correlation ID header is returned for all requests, both successful and failed ones.
For example, these log messages are related to an API call with correlation ID 3d5f193102435242
:
2019-08-26 13:16:23,611 [https-jsse-nio-4000-exec-10] correlation-id:[3d5f193102435242] DEBUG o.s.s.w.c.HttpSessionSecurityContextRepository - The HttpSession is currently null, and the HttpSessionSecurityContextRepository is prohibited from creating an HttpSession (because the allowSessionCreation property is false) - SecurityContext thus not stored for next request
2019-08-26 13:16:23,611 [https-jsse-nio-4000-exec-10] correlation-id:[3d5f193102435242] WARN o.s.w.s.m.m.a.ExceptionHandlerExceptionResolver - Resolved [org.niis.xroad.restapi.exceptions.ConflictException: local group with code koodi6 already added]
2019-08-26 13:16:23,611 [https-jsse-nio-4000-exec-10] correlation-id:[3d5f193102435242] DEBUG o.s.s.w.a.ExceptionTranslationFilter - Chain processed normally
An error response from the REST API can include data integrity errors if incorrect data was provided with the request. When
Example request and response of adding a new member when member already exist:
POST https://cs:4000/api/v1/members
Request body:
{
"member_name": "Member",
"member_id": {
"member_class": "ORG",
"member_code": "MemberCode"
}
}
Response body:
{
"status": 409,
"error": {
"code": "member_exists",
"metadata": [
"CS/ORG/MemberCode"
]
}
}
Possible data integrity error codes and messages declared in Central Server ErrorMessage
Error response from the Management API can include additional warnings that you can ignore if seen necessary. The warnings can be ignored by your decision, by executing the same operation with ignore_warnings
boolean parameter set to true
. Always consider the warning before making the decision to ignore it.
An example case:
- Client executes a REST request, without
ignore_warnings
parameter, to backend. - Backend notices warnings and responds with error message that contains the warnings. Nothing is updated at this point.
- Client determines if warnings can be ignored.
- If the warnings can be ignored, client resends the REST request, but with
ignore_warnings
parameter set totrue
. - Backend ignores the warnings and executes the operation.
Error response with warnings always contains the error code warnings_detected
.
Like errors, warnings contain an identifier (code) and possibly some metadata.
Warning example when trying to upload backup file which already exist produces non-fatal validation warnings:
POST https://cs:4000/api/v1/backups/upload?ignore_warnings=false
Response:
{
"status": 400,
"error": {
"code": "warnings_detected"
},
"warnings": [
{
"code": "warning_file_already_exists",
"metadata": [
"backup.gpg"
]
}
]
}
Note that when you are using the admin UI and you encounter warnings, you will always be provided with a popup window with a CONTINUE
button in it. When you click the CONTINUE
button in the popup, the request is sent again but this time warnings will be ignored.
Since version 6.23.0 Central Server supports using remote databases. In case you have an already running standalone Central Server with local database, it is possible to migrate it to use remote database host instead. The instructions for this process are listed below.
Prerequisites
- Same version (12 or later) of PostgreSQL installed on the remote database host.
- Network connections to PostgreSQL port (tcp/5432) are allowed from the Central Server to the remote database server.
- Shutdown X-Road processes.
systemctl stop "xroad*"
- Dump the local database centerui_production to be migrated. The credentials of the database admin user can be found in
/etc/xroad.properties
. Notice that the versions of the local PostgreSQL client and remote PostgreSQL server must match.
pg_dump -F t -h 127.0.0.1 -p 5432 -U centerui_admin -f centerui_production.dat centerui_production
- Shut down and mask local postgresql so it won't start when xroad-proxy starts.
systemctl stop postgresql
systemctl mask postgresql
- Connect to the remote database server as the superuser postgres and create roles, databases and access permissions as follows.
psql -h <remote-db-url> -p <remote-db-port> -U postgres
CREATE DATABASE centerui_production ENCODING 'UTF8';
REVOKE ALL ON DATABASE centerui_production FROM PUBLIC;
CREATE ROLE centerui_admin LOGIN PASSWORD '<centerui_admin password>';
GRANT centerui_admin TO postgres;
GRANT CREATE,TEMPORARY,CONNECT ON DATABASE centerui_production TO centerui_admin;
\c centerui_production
CREATE EXTENSION hstore;
CREATE SCHEMA centerui AUTHORIZATION centerui_admin;
REVOKE ALL ON SCHEMA public FROM PUBLIC;
GRANT USAGE ON SCHEMA public TO centerui_admin;
CREATE ROLE centerui LOGIN PASSWORD '<centerui password>';
GRANT centerui TO postgres;
GRANT TEMPORARY,CONNECT ON DATABASE centerui_production TO centerui;
GRANT USAGE ON SCHEMA public TO centerui;
GRANT USAGE ON SCHEMA centerui TO centerui;
GRANT SELECT,UPDATE,INSERT,DELETE ON ALL TABLES IN SCHEMA centerui TO centerui;
GRANT SELECT,UPDATE ON ALL SEQUENCES IN SCHEMA centerui TO centerui;
GRANT EXECUTE ON ALL FUNCTIONS IN SCHEMA centerui to centerui;
- Restore the database dumps on the remote database host.
pg_restore -h <remote-db-url> -p <remote-db-port> -U centerui_admin -O -n centerui -1 -d centerui_production centerui_production.dat
- Create properties file
/etc/xroad.properties
if it does not exist.
sudo touch /etc/xroad.properties
sudo chown root:root /etc/xroad.properties
sudo chmod 600 /etc/xroad.properties
- Make sure
/etc/xroad.properties
is containing the admin user & its password.
centerui.database.admin_user = centerui_admin
centerui.database.admin_password = <centerui_admin password>
- Update
/etc/xroad/db.properties
contents with correct database host URLs and passwords.
spring.datasource.username=<database_username>
spring.datasource.password=<database_password>
spring.datasource.hikari.data-source-properties.currentSchema=<database_schema>
spring.datasource.url=jdbc:postgresql://<database_host>:<database_port>/<database>
- Start again the X-Road services.
systemctl start "xroad*"
For the guidelines on security hardening, please refer to UG-SEC.
By default any scripts(for example backup/restore) that uses psql
utility tries to parse /etc/xroad/db.properties
file for database related configurations like: database name, user, password, host, port. If the file is not found, the script may use default values which will point to local database. When such behaviour doesn't cover the requirements, it is possible to pass additional configurations to psql
utility using environment variables from file.
First step to pass additional configurations is to create db_libpq.env
file in /etc/xroad/
folder if it isn't created yet. It may also require adjustments of access rights to file.
Example of file contents:
export PGSSLMODE="verify-full"
export PGSSLCERT="/etc/xroad/ssl/internal.crt"
export PGSSLKEY="/etc/xroad/ssl/internal.key"
export PGSSLROOTCERT="/etc/xroad/ssl/root.crt"
#export PGTARGETSESSIONATTRS="read-write"
This example shows how SSL configurations for psql could look like. List of possible environment variables can be found in Postgres documentation.
Some of the variables like PGOPTIONS
, PGDATABASE
, PGUSER
, PGPASSWORD
are already used by scripts(created and initialized with values from /etc/xroad/db.properties
file) so adding same variables to db_libpq.env
won't have any effect on script behaviour.
In case it is needed to pass additional flags to internally initialized PGOPTIONS
variable, then PGOPTIONS_EXTRA
variable can be used. It will be appended to PGOPTIONS
variable.