Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

Table of Contents

Environment requirements

...

  1. FIXICC H2 machine:
    1. RHEL 7 / RHEL 8
    2. OpenJDK 1.8 
    3. Consul agent in client mode
  2. FIXEdge Cpp/Java machine:
    1. Consul agent in client mode
  3. On the network:
    1. PostgreSQL Database
      1. 1 user with DDL privileges (to run the database migration, can also be used to run normal FIXICC H2 operation)
      2. (Optional) 1 user without DDL privileges (to run normal FIXICC H2 operation)
    2. Consul cluster (can be deployed on the same machines as FIXEdge Cpp/Java or FIXICC H2)
  4. Client workstations:
    1. Chrome browser

...

Pre-Configuration

Info

The ability to use FIXICC H2 without Consul is available since FIXICC H2 23Q1 release.

Before you start working with the FIXICC H2, install and configure the FIX Engine and Consul application.

...

To find the Consul installation instructions, please follow this 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 this the link.

To configure the encrypted connection from FIXICC H2 to the Consul on the Consul side, please refer to this follow the link.

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 locala local.app.properties file.

You can place theapp.jar file for the FIXICC H2 application and localand local.app.properties(FIXICC H2 properties file) in the same directory, or store them separately.

...

Please configure the FIXICC H2 according to the instance of the local.app.properties in your FIXICC H2 package, and set the following properties:

NameMandatoryExample value

Default Value

Description
*
cuba.
dbmsType 
dbmsType Ypostgres

-

Type
The property defines the type of the RDBMS.
cuba.
dataSourceProvider 
dataSourceProvider Yapplication
 
application

-

The

value indicates that

property defines the data source

must be configured using application properties*

.

cuba.dataSource.
username C##CUBA 
username YCUBA 

-

The property defines the username for the database.

Possible values: string

*
cuba.dataSource.
password 
password Ycuba
 

-

The property defines the password for the database.

Possible values: string

*
cuba.dataSource.
dbName 
dbName YPTGSDB
 

-

The

database name*

property defines the name of the database.

Possible values: string

cuba.dataSource.
host 
host Y10.68.21.182
 

-

Host

The property defines the host for the database.

Possible values: string

*
cuba.dataSource.
port 1521 
port Y1521 

-

Port

The property defines the port for the database.

Possible values: string

fixicch2.consul.encrypted_connection

Ntrue

false

This property enables the use of HTTPS

The property defines whether HTTPS will be used or not.

Possible values: true | false

fixicch2.consul.port

N8501

8500

The

number of

property defines the port

configured

for

the

Consul.

Possible values: string

fixicch2.fixServerTypeNFIXEdge CPPall
Configures

The property defines the type of server to work with.

Allowed

Possible values: FIXEdge CPP

,

| FIXEdge Java

,

| any other value means

two types of supported servers.

both types of the server

fixicch2.consulEnabledNtruetrue
Info

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.hostNlocalhost

-

Host

The property defines the host for Prometheus.

Possible values: string

fixicch2.prometheus.port

N9090

9090

The

number of

property defines the port

configured

for Prometheus.

Possible values: string

fixicch2.prometheus.pollIntervalN55

The property defines the time interval between requests to Prometheus.

Possible values: int

fixicch2.metrics.support.feNfalsefalse

The property

to hide/show the

defines whether live counters for the FIXEdge C++ server will be shown or not.

Possible values: true | false

fixicch2.metrics.support.fejNtruetrue

The property

to hide/show the

defines whether live counters for

the FIXEdge Java

the FIXEdge Java server will be shown or not.

 Possible values: true | false

fixicch2.unknownServer.autoRegistrationNtruetrue

The property

sets the

defines whether auto-adding of the server configuration

* - marks the mandatory parameter

will be enabled.

Possible values: true | false

Configuration example:

Code Block
languagebash
titleThe FIXICC H2 properties file example
collapsetrue
local.app.properties
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 parameters optional properties can also be configurated through on the "Application Properties" Properties page on via FIXICC H2:

NameExample value

Default Value

Description
fixicch2.fixServerTypeFIXEdge CPPall
Configures

The property defines the type of server to work with.

Allowed

Possible values: FIXEdge CPP

,

| FIXEdge Java

,

| any other value means

two

both types of

supported servers.

the server

fixicch2.maxTimeToWaitServerStatusUpdate
10
810
Configures (in minutes)

The property defines the max time slot

for updating

in minutes to update the server status from the Consul. If there were no events during the specified period, the Consul sends the response.

The maximum value is 10 minutes.

Possible values: int < 10

fixicch2.metricsUpdatePeriod
1
41
Configures (

The property defines the period of time in seconds

) the period

for requesting metrics from the FIXEdge server. 

Possible values: int

fixicch2.modeproductionproduction
Marks

The property defines the instance of

the

FIXICC H2.

Possible values: string

fixicch2.notificationTimeZoneUTCUTC
Specifies

The property defines the time zone to display the correct time of

the notification

notifications.

Possible values: string

fixicch2.pauseToReconnect20002000
Specifies the

The property defines the pause between reconnection attempts.

Possible values: int

fixicch2.prometheus.
port
hostlocalhost

-

Host

The property defines the host for Prometheus.

Possible values: string

fixicch2.prometheus.port

9090

9090

The

number of

property defines the port

configured

for Prometheus.

Possible values: string

fixicch2.prometheus.pollInterval55

The property defines the time interval between requests to Prometheus.

Possible values: int

fixicch2.metrics.support.fefalsefalse

The property

to hide/show the

defines whether live counters for the FIXEdge C++ server will be shown or not.

Possible values: true | false

fixicch2.metrics.support.fejtruetrue

The property

to hide/show the

defines whether live counters for the FIXEdge Java server will be shown or not.

 Possible values: true | false

fixicch2.unknownServer.autoRegistrationtruetrue

The property

sets the

defines whether auto-adding of the server configuration will be enabled.

Possible values: true | false

Info

Notice: If the 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 logback.xml file the logback.xml file and put it in the same directory that where the local.app.properties file is located instored.

The logback.xml file is not mandatory.

For further additional information please refer to this the link.

Example:

Code Block
titleExample of the logback.xml
collapsetrue
<?xml version="1.0" encoding="UTF-8"?>

<configuration debug="false" packagingData="true">

    <property name="logDir" value="${app.home}/logs"/>

    <appender name="File" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${logDir}/app.log</file>

        <filter class="ch.qos.logback.classic.filter.ThresholdFilter">
            <level>INFO</level>
        </filter>

        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <!-- daily rollover -->
            <fileNamePattern>${logDir}/app.%d{yyyy-MM-dd}.log</fileNamePattern>
            <!-- keep 30 days' worth of history -->
            <maxHistory>5</maxHistory>
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
        </rollingPolicy>

        <encoder>
            <pattern>%d{yyyy-MM-dd HH:mm:ss.SSS} %-5level [%thread%X{cubaApp}%X{cubaUser}] %logger - %msg%n</pattern>
        </encoder>
    </appender>

    <root>
        <appender-ref ref="File"/>
    </root>
	
    <!-- Begin CUBA -->
    <logger name="com.haulmont.cuba" level="INFO"/>
    <logger name="com.haulmont.cuba.core.sys" level="INFO"/>
    <logger name="com.haulmont.cuba.core.sys.CubaDefaultListableBeanFactory" level="WARN"/>
    <logger name="com.haulmont.cuba.core.app.scheduling" level="INFO"/>
    <logger name="com.haulmont.cuba.web.sys" level="INFO"/>
    <logger name="com.haulmont.cuba.portal" level="INFO"/>
    <logger name="com.haulmont.restapi.sys" level="INFO"/>
    <logger name="com.haulmont.cuba.core.app.LockManager" level="INFO"/>
    <!-- End CUBA -->

    <logger name="eclipselink" level="WARN"/>
    <logger name="eclipselink.sql" level="INFO"/>
    <logger name="org.springframework" level="WARN"/>
    <logger name="com.vaadin" level="WARN"/>
    <logger name="org.atmosphere" level="WARN"/>
    <logger name="org.activiti" level="INFO"/>
    <logger name="org.jgroups" level="INFO"/>
    <logger name="freemarker" level="INFO"/>
    <logger name="org.thymeleaf.TemplateEngine" level="INFO"/>
    <logger name="com.zaxxer.hikari" level="INFO"/>
    <logger name="org.docx4j" level="WARN"/>
	<logger name="org.xlsx4j" level="WARN"/>
    <logger name="org.apache.fop.apps.FOUserAgent" level="WARN"/>
    <logger name="org.hibernate" level="WARN"/>
    <logger name="sun" level="INFO"/>
    <logger name="com.sun" level="INFO"/>
    <logger name="javax" level="INFO"/>
    <logger name="org.apache" level="INFO"/>
    <logger name="org.eclipse.jetty" level="INFO"/>
    <logger name="org.docx4j.utils.ResourceUtils" level="ERROR"/>
    <logger name="org.docx4j.Docx4jProperties" level="ERROR"/>
    <logger name="org.xlsx4j.jaxb.Context" level="ERROR"/>
    <logger name="org.docx4j.utils.XSLTUtils" level="ERROR"/>
    <logger name="org.docx4j.jaxb.JaxbValidationEventHandler" level="ERROR"/>
    <logger name="org.docx4j.TraversalUtil" level="ERROR"/>
    <logger name="org.docx4j.fonts" level="ERROR"/>

    <!-- Begin Perf4J  -->
    <appender name="PerfStatFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${logDir}/perfstat.log</file>
        <append>true</append>

        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${logDir}/perfstat.%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>5</maxHistory>
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
        </rollingPolicy>

        <encoder>
            <pattern>%msg%n</pattern>
        </encoder>
    </appender>

    <appender name="CoalescingStatistics" class="org.perf4j.logback.AsyncCoalescingStatisticsAppender">
        <param name="TimeSlice" value="60000"/>
        <appender-ref ref="PerfStatFile"/>
    </appender>

    <appender name="UIPerfStatFile" class="ch.qos.logback.core.rolling.RollingFileAppender">
        <file>${logDir}/perfstat-ui.log</file>
        <append>true</append>

        <rollingPolicy class="ch.qos.logback.core.rolling.TimeBasedRollingPolicy">
            <fileNamePattern>${logDir}/perfstat-ui.%d{yyyy-MM-dd}.log</fileNamePattern>
            <maxHistory>5</maxHistory>
            <cleanHistoryOnStart>true</cleanHistoryOnStart>
        </rollingPolicy>

        <encoder>
            <pattern>%msg%n</pattern>
        </encoder>
    </appender>

    <appender name="UICoalescingStatistics" class="org.perf4j.logback.AsyncCoalescingStatisticsAppender">
        <param name="TimeSlice" value="120000"/>
        <appender-ref ref="UIPerfStatFile"/>
    </appender>

    <logger name="org.perf4j.TimingLogger" additivity="false" level="INFO">
        <appender-ref ref="CoalescingStatistics"/>
    </logger>

    <logger name="com.haulmont.cuba.gui.logging.UIPerformanceLogger" additivity="false" level="INFO">
        <appender-ref ref="UICoalescingStatistics"/>
    </logger>
    <!-- End Perf4J  -->

</configuration>

...

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.

...

Info

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:

NameExample value

Where

Description

fixicch2.secure_http_port

8443Java system property

The property defines the HTTPS port to listen.

Possible values: string

fixicch2.key_store_pathkeystore.jksJava system property
Path

The property defines the path to the key store (.jks file).

Possible values: string

fixicch2.trust_store_pathkeystore.jksJava system property
Path

The property defines the path to the trust store (.jks file). This value is used

if validating

during the validation of client certificates and is typically set to the same

path

value as the

keystore

fixicch2.key_store_path property.

Possible values: string

FIXICC_H2_KEY_STORE_PASSWORDfixicch2Environment variable
Key

The property defines the key store password in plain text

Possible values: string

FIXICC_H2_KEY_MANAGER_PASSWORDfixicch2Environment variable
Key Manager password

The property defines the key manager password in plain text.

Possible values: string

FIXICC_H2_TRUST_STORE_PASSWORDfixicch2Environment variable
Trust

The property defines the trust store password in plain text.

Possible values: string

For details on these parameters more information please refer to the Jetty 9 Documentation on parameters keyStorePath , keyStorePassword , keyManagerPassword , trustStorePath  page (keyStorePath , keyStorePassword , keyManagerPassword , trustStorePath , and trustStorePassword  properties).

...

For example, to start FIXICC H2 with the keys generated as above run the following command:

Code Block
collapselanguagetruebash
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
Noteinfo

We strongly recommend configuring all connections (FIXICC H2↔engineH2 ↔ Engine, FIXICC H2 ↔ Consul, FIXICC H2 ↔ FIXEye agentAgent) via HTTPS.

Start application

Start the FIXICC H2 from the command line with the following command:

...

This will start FIXICC H2 on port 8080, you can access it by browsing to http://fixicc-h2-machine:8080/app.

...

  • "/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.

...

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:

...

  1. Deploy FIXEye Agent (version 2.3.0 or higher) by following the instruction.

LDAP authentication

To configure the FIXICC H2 authentication via LDAP you can follow the following instruction:

  1. Deploy the LDAP server.
  2. Set the following properties in the local.app.properties file:

    NameExample valueDefault valueDescription
    ldap.contextSourceUrlldap://localhost:389ldap://localhost:10389
    Defines

    The property defines a URL for reaching the LDAP server.

    Possible values: string

    ldap.contextSourceUserNamecn=admin,dc=epm-bfix,dc=localuid=admin,ou=system
    Indicates a username

    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=localdc=springframework,dc=org
    Defines

    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.contextSourcePasswordADMIN_PASSWORDsecret
    Defines

    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.

    compose.

    Possible values: string

    ldap.referralfollowfollow
    Defines

    The property defines the strategy to handle referrals, as described

    in this documentation

    in thedocumentation.

    Possible values: string

    ldap.sessionExpiringPeriodSec12030
    Indicates

    The property defines a period of time in seconds after which the system terminates a

    user

    session if

    you deactivate

    the user was deactivated or

    assign

    a new access group/matching rules were assigned to them.

    Possible values: int

    ldap.userSynchronizationBatchSize100100
    Defines

    The property defines the number of users that can be synchronized during the execution of

    the 

    the synchronizeUsersFromLdap()

     scheduled task

    scheduled task.

    Possible values: int

    ldap.userSynchronizationOnlyActivePropertytruetrue

    The property defines whether the synchronizeUsersFromLdap() scheduled task will update only the value of the Active attributes or all user details.

    If set

    to 

    to 'true',

    the 

    the synchronizeUsersFromLdap() scheduled task updates only the value of

    the Active attribute

    the Active attribute. Otherwise, the system updates all user details.

    Possible values: true | false

    ldap.cubaGroupForSynchronizationCompanyCompany
    Defines

    The property defines access groups that

    are

    will be checked when the system executes

    the ,

    the synchronizeUsersFromLdap() scheduled task.

    Possible values: string

    ldap.cubaGroupForSynchronizationInversefalsefalse
    If set to true

    The property defines whether the system

    checks

    will check all groups when executing the synchronizeUsersFromLdap()

     scheduled

    scheduled task (except for the ones specified

    in 

    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.synchronizeCommonInfoFromLdaptruetrue
    If set to true, the 

    The property defines whether the synchronizeUsersFromLdap()

     scheduled

    scheduled task

    updates

    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.standardAuthenticationUsersadmin, anonymousadmin, anonymous
    Defines

    The property defines users that can log in to the system using standard CUBA credentials.

    Possible values: string

    ldap.expiringSessionNotificationCron*/10 * * * * **/10 * * * * *
    Defines

    The property defines the

    cron

    CRON expression for retrieving expired sessions from the middleware layer.

    Possible values: CRON

    ldap.addonEnabledtruefalse
    If set to true,

    The property defines whether the LDAP add-on

    is

    will be enabled.

    Possible values: true | false

    ldap.expiringSessionsEnabletruetrue
    If set to true,

    The property defines whether the system

    sends

    will send notifications to inform the user that their session is about to expire.

    Possible values: true | false

  3. If the group and user weren't set earlier you should create a posixPOSIX group and a user in LDAP.
  4. Start the FIXICC H2.
  5. Select Administration -> LDAP -> LDAP Config in in the menu on the left -side side (items 1→2→3 in the figure below).
  6. Check the connection by clicking Test Connection  (item 4 in the figure below).
    Figure. The "Test Connection" button.
  7. If the connection is successful, the FIXICC H2 will show the following message:

    Figure. The successful LDAP connection.

  8. Go to the LDAP Matching Rules page by clicking LDAP Matching Rules Rules.
  9. Select the default rule in the table and click Edit or press Enter on your keyboard to keyboard to edit the default rule.
    Figure. The "LDAP Matching Rules" page.
  10. Add the Role - system-full-access or your own role (in this case, the role's permissions must provide access to Allow all screens):
  11. Click Add(see below):.
    Figure. The "Add" button for adding the permissions.



  12. Select the Role in the table (item 1 in the figure above).
  13. Confirm your choice by clicking Select (item 2 in the figure above).
  14. Logout Log out by clicking the arrow at the bottom of the left-side menu (see below).

    Figure. The "Logout" button.
  15. Login Log in with the user's data whose role was added to the LDAP Matching Rules.