FIXICC H2: Deployment Guide
Environment requirements
Hardware
A physical or virtual server with:
- 2 core CPU
- 2Gb RAM
- 40G storage
Software
- FIXICC H2 machine:
- RHEL 7 / RHEL 8
- OpenJDK 1.8
- (Optional since FIXICC H2 23Q1 release) Consul agent in client mode
- FIXEdge Cpp/Java machine:
- (Optional since FIXICC H2 23Q1 release) Consul agent in client mode
- On the network:
- PostgreSQL Database or HSQL Database (since FIXICC H2 23Q1 release):
- 1 user with DDL privileges to run the database migration or run normal FIXICC H2 operation
- 1 user without DDL privileges to run normal FIXICC H2 operation
- (Optional since FIXICC H2 23Q1 release) Consul cluster - can be deployed on the same machines as FIXEdge Cpp/Java or FIXICC H2
- PostgreSQL Database or HSQL Database (since FIXICC H2 23Q1 release):
- Client workstations:
- Chrome browser
Pre-configuration
Before you start working with the FIXICC H2, install and configure the FIX Engine and Consul application.
Consul configuration
To find the Consul installation instructions, please follow the link.
For non-production use, you can run the Consul in developer mode with the command:
consul agent -dev
For production use - please follow the link.
To configure the encrypted connection from FIXICC H2 to the Consul on the Consul side, please follow the link.
FIXICC H2 without Consul
The ability to use FIXICC H2 without Consul is available since FIXICC H2 23Q1 release.
FIXICC H2 configuration
- The fixicch2.consulEnabled property must be set to 'false' in the local.app.properties configuration file.
Example:
############################################################################### # Other # ############################################################################### cuba.rest.anonymousEnabled=true cuba.anonymousLogin=anonymous cuba.dbmsType = postgres cuba.dataSourceProvider = application cuba.dataSource.username = cuba cuba.dataSource.password = cuba cuba.dataSource.dbName = fixicch2 cuba.dataSource.host = localhost cuba.dataSource.port = 5432 fixicch2.fixServerType = all fixicch2.prometheus.host = localhost fixicch2.consulEnabled=false
- The following actions must be performed to connect to FIXEdge Java or FIXEdge C++ and FIXEye-Agent:
- Run FIXICC H2 and log in.
- Navigate to the Configuration → Show all servers in the left navigation menu. The Servers page will be opened.
- Click the Add button. The Server editor page will be opened.
Enter Server Name, Type, IP, Admin Port and FIX Port for the Server and IP and Port for FIXEye Agent. Click the OK button.
Admin Port for FIXEdge Java server is set to '9010', and FIX Port is set to '8911' by default.
Admin Port for FIXEdge C++ server is set to '8903', and FIX Port is set to '8901' by default.
Port for FIXEye Agent is usually set to '8882'.
FIXEdge Java configuration
The following properties must be defined in the fixedge.properties file:
service.discovery.enabled=false server.useFixicch2ConfigManager=true fixicch2.enable=true # Fixicch2 REST API to load fix session and schedules configs and to subscribe on session and schedules changes fixicch2.url=<fixicc_h2_url>
FIXEdge C++ configuration
The following properties must be defined in the FIXEdge.properties file:
Components.Service.FIXICCH2 = configuration-service Components.Service.FIXICCH2.Host = <host> Components.Service.FIXICCH2.Port = 8080 Components.Service.FIXICCH2.ReconnectInterval = <some_interval> Components.Service.FIXICCH2.HeartBeatIntervalS = <optional, otherwise default 30 seconds: the interval at which FIXICC H2 expects to receive heartbeat messages from FIXEdge C++. Set this value to '0' to disable heartbeats.> Components.Component.Configuration = FIXICCH2
FIXEye Agent configuration
The Consul.Enabled property must be set to 'false' in the fixeye-agent.properties file:
Consul.Enabled = false
FIXICC H2 settings
You should choose a directory on your workstation for FIXICC H2 files.
The FIXICC H2 instance is in the app.jar file. To complete the configuration, please create a local.app.properties file.
You can place the app.jar file for the FIXICC H2 application and local.app.properties (FIXICC H2 properties file) in the same directory, or store them separately.
Before you start your work, please set the database type for data storage.
The FIXICC H2 is compatible with PostgreSQL databases.
Please configure the FIXICC H2 according to the instance of the local.app.properties in your FIXICC H2 package, and set the following properties:
Name | Mandatory | Example value | Default Value | Description |
---|---|---|---|---|
cuba.dbmsType | Y | postgres | - | The property defines the type of the RDBMS. |
cuba.dataSourceProvider | Y | application | - | The property defines the data source. |
cuba.dataSource.username | Y | CUBA | - | The property defines the username for the database. Possible values: string |
cuba.dataSource.password | Y | cuba | - | The property defines the password for the database. Possible values: string |
cuba.dataSource.dbName | Y | PTGSDB | - | The property defines the name of the database. Possible values: string |
cuba.dataSource.host | Y | 10.68.21.182 | - | The property defines the host for the database. Possible values: string |
cuba.dataSource.port | Y | 1521 | - | The property defines the port for the database. Possible values: string |
fixicch2.consul.encrypted_connection | N | true | false | The property defines whether HTTPS will be used or not. Possible values: true | false |
fixicch2.consul.port | N | 8501 | 8500 | The property defines the port for Consul. Possible values: string |
fixicch2.fixServerType | N | FIXEdge CPP | all | The property defines the type of server to work with. Possible values: FIXEdge CPP | FIXEdge Java | any other value means both types of the server |
fixicch2.consulEnabled | N | true | true | The property is available since FIXICC H2 23Q1 release. The property defines whether FIXICC H2 connection to Consul will be enabled or not. Possible values: true | false |
fixicch2.prometheus.host | N | localhost | - | The property defines the host for Prometheus. Possible values: string |
fixicch2.prometheus.port | N | 9090 | 9090 | The property defines the port for Prometheus. Possible values: string |
fixicch2.prometheus.pollInterval | N | 5 | 5 | The property defines the time interval between requests to Prometheus. Possible values: int |
fixicch2.metrics.support.fe | N | false | false | The property defines whether live counters for the FIXEdge C++ server will be shown or not. Possible values: true | false |
fixicch2.metrics.support.fej | N | true | true | The property defines whether live counters for the FIXEdge Java server will be shown or not. Possible values: true | false |
fixicch2.unknownServer.autoRegistration | N | true | true | The property defines whether auto-adding of the server configuration will be enabled. Possible values: true | false |
cuba.dbmsType = postgres cuba.dataSourceProvider = application cuba.dataSource.username = C##CUBA cuba.dataSource.password =cuba cuba.dataSource.dbName = PTGSDB cuba.dataSource.host = 10.68.21.182 cuba.dataSource.port =1521 fixicch2.consul.encrypted_connection =true fixicch2.consul.port =8501 fixicch2.consul.insecure_connection_enabled =false fixicch2.fixServerType = FIXEdge CPP fixicch2.prometheus.port = localhost fixicch2.prometheus.port = 9090 fixicch2.prometheus.pollInterval = 5 fixicch2.metrics.support.fe = false fixicch2.metrics.support.fej = true fixicch2.unknownServer.autoRegistration = true
The following optional properties can also be configurated on the Application Properties page via FIXICC H2:
Name | Example value | Default Value | Description |
---|---|---|---|
fixicch2.fixServerType | FIXEdge CPP | all | The property defines the type of server to work with. Possible values: FIXEdge CPP | FIXEdge Java | any other value means both types of the server |
fixicch2.maxTimeToWaitServerStatusUpdate | 8 | 10 | The property defines the max time slot in minutes to update the server status from the Consul. If there were no events during the specified period, the Consul sends the response. Possible values: int < 10 |
fixicch2.metricsUpdatePeriod | 4 | 1 | The property defines the period of time in seconds for requesting metrics from the FIXEdge server. Possible values: int |
fixicch2.mode | production | production | The property defines the instance of FIXICC H2. Possible values: string |
fixicch2.notificationTimeZone | UTC | UTC | The property defines the time zone to display the correct time of notifications. Possible values: string |
fixicch2.pauseToReconnect | 2000 | 2000 | The property defines the pause between reconnection attempts. Possible values: int |
fixicch2.prometheus.host | localhost | - | The property defines the host for Prometheus. Possible values: string |
fixicch2.prometheus.port | 9090 | 9090 | The property defines the port for Prometheus. Possible values: string |
fixicch2.prometheus.pollInterval | 5 | 5 | The property defines the time interval between requests to Prometheus. Possible values: int |
fixicch2.metrics.support.fe | false | false | The property defines whether live counters for the FIXEdge C++ server will be shown or not. Possible values: true | false |
fixicch2.metrics.support.fej | true | true | The property defines whether live counters for the FIXEdge Java server will be shown or not. Possible values: true | false |
fixicch2.unknownServer.autoRegistration | true | true | The property defines whether auto-adding of the server configuration will be enabled. Possible values: true | false |
If parameters from the table above were configured in the local.app.properties file, values from the file would be applied despite values being changed through the Application Properties page.
Logging configuration
To configure the logging level for the FIXICC H2 application, please create the logback.xml file and put it in the directory where the local.app.properties file is stored.
The logback.xml file is not mandatory.
For additional information please refer to the link.
Example:
HTTPS support
To run FIXICC H2 with HTTPS support you need to provide it with a key store and trust store in JKS format. For production installations, you need to create JKS from the certificate and private key provided by a trusted certificate authority.
For testing purposes, you can generate a self-signed certificate by yourself.
keytool -genkey -noprompt -alias jetty -keyalg RSA -dname 'CN=admin, OU=EPM-BFIX, O=EPAM Systems, L=Unknown, S=Unknown, C=Unknown' -keystore keystore.jks -storepass fixicch2 -keypass fixicch2
Note here the name of the file (keystore.jks) and passwords (fixicch2).
To run FIXICC H2 with HTTPS enabled, you need to provide the following parameters:
Name | Example value | Where | Description |
---|---|---|---|
fixicch2.secure_http_port | 8443 | Java system property | The property defines the HTTPS port to listen. Possible values: string |
fixicch2.key_store_path | keystore.jks | Java system property | The property defines the path to the key store (.jks file). Possible values: string |
fixicch2.trust_store_path | keystore.jks | Java system property | The property defines the path to the trust store (.jks file). This value is used during the validation of client certificates and is typically set to the same value as the fixicch2.key_store_path property. Possible values: string |
FIXICC_H2_KEY_STORE_PASSWORD | fixicch2 | Environment variable | The property defines the key store password in plain text. Possible values: string |
FIXICC_H2_KEY_MANAGER_PASSWORD | fixicch2 | Environment variable | The property defines the key manager password in plain text. Possible values: string |
FIXICC_H2_TRUST_STORE_PASSWORD | fixicch2 | Environment variable | The property defines the trust store password in plain text. Possible values: string |
For more information please refer to the Jetty Documentation page (keyStorePath , keyStorePassword , keyManagerPassword , trustStorePath , and trustStorePassword properties).
For example, to start FIXICC H2 with the keys generated as above run the following command:
export FIXICC_H2_KEY_STORE_PASSWORD=fixicch2 export FIXICC_H2_KEY_MANAGER_PASSWORD=fixicch2 export FIXICC_H2_TRUST_STORE_PASSWORD=fixicch2 java -Dapp.home=/opt/fixicch2-home -Dfixicch2.secure_http_port=8433 -Dfixicch2.key_store_path=keystore.jks -Dfixicch2.trust_store_path=keystore.jks -jar /opt/fixicch2/app.jar
We strongly recommend configuring all connections (FIXICC H2 ↔ Engine, FIXICC H2 ↔ Consul, FIXICC H2 ↔ FIXEye Agent) via HTTPS.
Start application
Start the FIXICC H2 from the command line with the following command:
java -Dapp.home=/opt/fixicch2-home -jar /opt/fixicch2/app.jar
This will start FIXICC H2 on port 8080, you can access it by browsing http://fixicc-h2-machine:8080/app.
Where:
- "/opt/fixicch2-home" is the directory with the local.app.properties file, you should type the full path for the file.
- "/opt/fixicch2/" is the directory with the app.jar file, you should type the full path for the file.
Changing FIXICC H2 port
To run FIXICC H2 on another HTTP port you need to specify the fixicch2.http_port Java system property, e.g. to run FIXICC H2 on port 9090, you should start the FIXICC H2 from the command line with the following command:
java -Dapp.home=/opt/fixicch2-home -Dfixicch2.http_port=9090 -jar /opt/fixicch2/app.jar
FIX Log Viewer Settings
To configure the search in the FIX logs:
- Deploy FIXEye Agent (version 2.3.0 or higher) by following instruction.
How to Configure and Use LDAP for FIXICC H2
Please refer to the LDAP Github page for more information.
Precondition: Configure your directory server before enabling the LDAP FIXICC H2 add-on.
1. Configure LDAP plugin and Connection in FIXICC H2 configuration file local.app.properties
Fill in the following mandatory parameters (values are samples and must be replaced):
ldap.contextSourceUrl=ldap://adhost-or-ip:389 ldap.contextSourceUserName=cn=ldapuser,cn=Users,dc=fixicch2,dc=local ldap.contextSourceBase=cn=Users,dc=fixicch2,dc=local ldap.contextSourcePassword=password ldap.addonEnabled=true
To correctly specify the contextSourceUserName parameter, you need to use the user's Distinguished Name (DN). The DN typically includes the cn (common name) or uid (user ID), along with the domain components (dc).
The easiest way to find the exact value is to use the ADSI Edit tool:
- Open ADSI Edit
- connect to your directory
- navigate to the user object
- right-click the user object and click Properties
- In the opened pop-up window in the Attribute Editor tab find the distinguishedName parameter
- Use in config file value of distinguishedName parameter
- Save changes and start/restart FIXICC H2 application
Check yourself
- If the plugin is enabled in local.app.properties then in FIXICC H2 UI in the left navigation panel under the Administration section you should see the LDAP navigation tree:
- If ldap Url, UserName, Base, and Password parameters are correct then you should be able to pass successfully connection test under: Administration->LDAP Config->Test Connection button:
2. Configure attributes that will be used for matching rules
- In FIXICC H2 UI navigate to the Administration->LDAP->LDAP Config
- In the Schema Settings section click the Create button, add the name of attribute, and click the OK button.
E.g., add the “memberOf” parameter:
- A new attribute will be added to the table, if required add additional attributes and then click the OK button:
- Alternatively, provide correct values corresponding to LDAP configuration in AD (see "How to define the correct Schema Base" section below) to the Schema Settings fields and use Refresh LDAP Attributes button to receive all attributes at once:
3. Configure LDAP Matching Rules
- In FIXICC H2 UI navigate to the Administration->LDAP->LDAP Matching Rules
- Click the Create Matchin Rule button and select Create Simple Rule
- Fill in the Description field – it will be the name of the rule, e.g., Admins
- Under the Conditions section click the Create button, select the attribute (list of attributes will contain values defined in step 2.), enter a valid value, and click the OK button.
E.g., for the memberOf parameter, we can use the name of securityGroup:
- For Access Group select Company
- In the Roles section click the Add button and select the appropriate role (e.g., in our case for admins we need to add a system-full-access role)
- Click the OK button, then click the Apply button at the bottom of the Matching Rules tab, to confirm saving changes.
Check yourself
- If the Matching Rule was correctly configured and changes saved then it should be visible under Administration->LDAP->LDAP Matching Rules in the top section table when re-open this tab or re-login to the application:
- If all required matching rules are created, you can test them right from the LDAP Matching Rule tab (Administration->LDAP->LDAP Matching Rules). For this purpose, enter a user login in the User Login field and click the Test Rules button.
After that, the applied matching rules, access groups, and roles are displayed in the corresponding fields and tables. This functionality is useful when you need to check the accuracy of a rule application. - If all rules and permissions are correctly set, then the user should be able to log in to the FIXICC H2 UI and have a specified level of permissions.
4. Disable local user login
Update local.app.properties file and cuba.web.standardAuthenticationUsers property as follows (leave empty value):
cuba.web.standardAuthenticationUsers=
- Start/Restart FIXICC H2 application
Check yourself
If the property was correctly set then when trying to log in with non-LDAP local user error will be shown (only LDAP users will be able to log in):
How to define the correct Schema Base
To determine the correct value for the Schema Base in an existing Active Directory (AD), you can follow these steps:
1) Using ADSI Edit
- Open ADSI Edit:
- Press Win + R, type ADSIEdit.msc, and press Enter.
- Connect to Schema:
- In the left pane, right-click on ADSI Edit and select Connect to.
- In the Connection Settings window, under "Select a well known Naming Context," choose Schema and click OK.
- Locate Schema Base:
- In the left pane, expand the schema for your domain controller.
- Right-click on CN=Schema,CN=Configuration,DC=yourdomain,DC=com and select Properties.
- The distinguished name (DN) you see here is your Schema Base[1].
2) Using Command Prompt
- Open Command Prompt:
- Press Win + R, type cmd, and press Enter.
- Run DSQuery Command:
Enter the following command:
sh dsquery * "cn=schema,cn=configuration,dc=yourdomain,dc=com" -scope base -attr objectVersion
- This command will return the schema version and confirm the Schema Base DN.
3) Using PowerShell
- Open PowerShell:
- Search for PowerShell in the Start menu and open it.
- Run Get-ItemProperty Command:
Enter the following command:
powershell Get-ItemProperty 'AD:\\CN=Schema,CN=Configuration,DC=yourdomain,DC=com' -Name objectVersion
- This command retrieves the schema version and confirms the Schema Base DN.
LDAP Properties
The following properties are available in the local.app.properties file:
Name | Example value | Default value | Description |
---|---|---|---|
ldap.contextSourceUrl | ldap://localhost:389 | ldap://localhost:10389 | The property defines a URL for reaching the LDAP server. Possible values: string |
ldap.contextSourceUserName | cn=admin,dc=epm-bfix,dc=local | uid=admin,ou=system | The property defines the username (principal) used for authentication. This is normally the distinguished name of the admin user. Possible values: string |
ldap.contextSourceBase | dc=epm-bfix,dc=local | dc=springframework,dc=org | The property defines a base DN. If configured, all operations on contexts retrieved from ContextSource will be relative to this DN. By default, an empty name is set (i.e. all operations are related to the directory root). Possible values: string |
ldap.contextSourcePassword | ADMIN_PASSWORD | secret | The property defines a password used for authentication. Login with default parameters for the first time. Then you can change the password in env docker-compose. Possible values: string |
ldap.referral | follow | follow | The property defines the strategy to handle referrals, as described in thedocumentation. Possible values: string |
ldap.sessionExpiringPeriodSec | 120 | 30 | The property defines a period of time in seconds after which the system terminates a session if the user was deactivated or a new access group/matching rules were assigned to them. Possible values: int |
ldap.userSynchronizationBatchSize | 100 | 100 | The property defines the number of users that can be synchronized during the execution of the synchronizeUsersFromLdap() scheduled task. Possible values: int |
ldap.userSynchronizationOnlyActiveProperty | true | true | The property defines whether the synchronizeUsersFromLdap() scheduled task will update only the value of the Active attributes or all user details. If set to 'true', the synchronizeUsersFromLdap() scheduled task updates only the value of the Active attribute. Otherwise, the system updates all user details. Possible values: true | false |
ldap.cubaGroupForSynchronization | Company | Company | The property defines access groups that will be checked when the system executes the synchronizeUsersFromLdap() scheduled task. Possible values: string |
ldap.cubaGroupForSynchronizationInverse | false | false | The property defines whether the system will check all groups when executing the synchronizeUsersFromLdap() scheduled task (except for the ones specified in the ldap.cubaGroupForSynchronization property). If set to 'true', the system checks all groups when executing the synchronizeUsersFromLdap() scheduled task. Possible values: true | false |
ldap.synchronizeCommonInfoFromLdap | true | true | The property defines whether the synchronizeUsersFromLdap() scheduled task will update the values of the following user attributes in accordance with their state on the LDAP server side: Email, Name, First name, Last name, Middle name, Position, and Language. If set to 'true', the synchronizeUsersFromLdap() scheduled task will update the values of these user attributes in accordance with their state on the LDAP server side. Possible values: true | false |
cuba.web.standardAuthenticationUsers | admin, anonymous | admin, anonymous | The property defines users that can log in to the system using standard CUBA credentials. Possible values: string |
ldap.expiringSessionNotificationCron | */10 * * * * * | */10 * * * * * | The property defines the CRON expression for retrieving expired sessions from the middleware layer. Possible values: CRON |
ldap.addonEnabled | true | false | The property defines whether the LDAP add-on will be enabled. Possible values: true | false |
ldap.expiringSessionsEnable | true | true | The property defines whether the system will send notifications to inform the user that their session is about to expire. Possible values: true | false |