Versions Compared

Key

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

Table of Contents

...

FIXEdge Java 1.10.4 is released on 19,04,2024

New Features and Improvements

Expand
titleBL Histories functionality

With the 1.10.4 release, FIXEdge Java provides the opportunity to enhance data handling and storage on the business layer—Histories which can be set up through DSL Rules.

Key Updates:

  1. RDBMS Support: FIXEdge Java now has the capability to interact with external databases, offering support for Relational Database Management Systems (RDBMS). It is possible to configure a specific database to both receive and send data based on the type of query submitted.

  2. Enhanced Data Maintenance: This release provides ability to maintain information, allowing to create, update, insert, and delete data as needed on the business layer—Histories.

  3. Declared Type and Inquiries: Depending on the declared type, information can be processed in memory or through the database. The InMemoryHistory feature enables storage of information directly in the memory, while the JDBCHistory feature allows for information storage directly in the JDBC database.

    For more details, please refer to our guide on History implementation:
    History implementation in DSL - EPAM-B2BITS products for Capital Markets - FIX Products Knowledge base (atlassian.net)


Expand
titleDrools (7.74.1version) Integration

The 1.10.4 release introduces the integration with Drools (Drools - Drools - Business Rules Management System (Java™, Open Source)

Drools assists in segregating and analyzing logic and data within business operations. It is not intended to replace the existing Business Layer, but rather to enhance it. Drools comes as a standard part of the FIXEdge Java (FEJ) package and can be utilized without the need for any extra components. This feature provides the users a capability to create/use own existing Drools logic inside FEJ. Messages are redirected according to Drools logic, providing a more streamlined and efficient routing process.


Expand
titleReal-time configuration of the JMS adapter in FEJ from H2

The real-time configuration of the JMS adapter from H2 enables the immediate addition, removal, and modification of JMS sessions directly from H2 by processing the obtained information via FIXEdge Java (FEJ). Previously, it was necessary to restart the server to perform these actions, which would interrupt any ongoing sessions. Now JMS TA sessions can be dynamically configured from H2. 

...

Expand
titleRPM Packages Changes

The 1.10.4 release brings enhancements to the FEJ in RPM package with modifications to the folder structure and properties.

Key Updates:

  1. Systemd Service: The systemd service name now is configured to start FEJ with YAJSW script.

  2. Data and Logs: The /var/data/fixedge-java directory will now be used for FIX logs and replication data. If this directory does not exist, it will be automatically checked and created.


Other Features

  • Server registration without Consul:
    This release enhances server visibility and manageability. Servers can now be registered and be visible in H2 without requiring Consul. FEJ now automatically checks the availability and statuses of servers, sending notifications to H2 if any of the servers are stopped.

  • Repeating group in scope of Groovy DSL for BL:
    As part of the FIXEdge Java 1.10.4 release, improvements have been made to the DSL functionality providing advanced features for handling Repeating Groups in FIX messages.

     DSL instructions for working with Repeating Groups on BL has been added, providing a higher level of abstraction of the existing API:

    - Access to different levels of nesting of an entry has been provided.
    - Operations on a group and its elements (entry, nested group) has been Implemented, including conditions on size, existence, and content, as well as actions such as adding, deleting, and editing.
    - Support for working with tags and their contents for specific entries or templates (entryAny/entryAll), has been added similar to the existing operations with regular fields.

    The new functionality is an addition to the existing one and was developed for 'MessageRules' condition and action block. 

    For the full syntax and instructions, please refer to the corresponding documentation.

Fixed Bugs

  • Transition to an updated version of YAJSW has been made to maintain compatibility with the appropriate version of commons-text.jar. This move helps prevent potential arbitrary code execution by an attacker.


Improvement and correction of FEJ work through H2

  • FIXEdge Java Session Update
    Problem description: When an update was made to the session Host and Port parameters, the new settings were not being applied. This issue was preventing the establishment of sessions.
    Solution: 
    FIXEdge Java properly applies new Host and Port parameters after receiving a session update. This fix ensures that session's host and port parameters are updated correctly.

  • Issue with timestamps in the incoming FIX message log when metrics are enabled
    Problem description: Problem with the incoming FIX message log incorrectly saving timestamps when metrics were activated. Different messages erroneously were been given the exact same timestamp.
    Solution
    : When metrics are enabled, FIXEdge Java accurately logs timestamps in the incoming FIX message log. Every message will be correctly marked with a unique timestamp.
  • Issue with nanoseconds saved in incoming FIX log when enabling metrics
    Problem description: The incoming log possessed nanoseconds precision. The outgoing log possessed milliseconds precision.

    Solution: Both incoming and outgoing logs can measure accuracy in seconds, milliseconds, microseconds or nanoseconds depending on the chosen parameters.

  • FEJ FIX session cannot be stopped/connected after changing SenderCompID/TargetCompID
    Problem description: After changing the Sender and Target CompIDs in H2 UI, the session could not be stopped or connected to.  No errors were displayed on the UI or in the logs, and only a restart of FEJ would restore the session's functionality.
    Solution:
      Even after changing the SenderCompID and TargetCompIDs, stopping and connecting to the session will function without needing a system restart.


FIXEdge Java 1.10.3 Release Notes

...

  • There is no ability to disable the BouncyCastle security provider.
    • Problem description: The BouncyCastle security provider is used by Administrative Remote Shell CLI by default. There was no possibility to disable this security provider (if a user wanted to use their own).
    • Solution: The option org.apache.sshd.registerBouncyCastle was fixed for disabling the registration of the BouncyCastle security provider.
  • Remote Shell Command "server opts" prints invalid information about opened FIX ports.
    • Problem description"server opts" command output was corrupted.
    • Solution: The command output was fixed to print a list of opened ports.
  • JMS Producer doesn't reconnect automatically.
    • Problem descriptionJMS Producer stopped reconnecting when an exceptional connection break occurred.
    • Solution: The reconnect logic was fixed.
  • Race conditions in JMS Producer after reconnect.
    • Problem description: JMS Producer did the reconnect procedure in two separate threads and started two sending threads at the same time.
    • Solution: The reconnect logic was fixed.
  • Incorrect value for the QueueMaxFileSize property for JMS clients.
  • The JMS Producer loses messages during reconnect.
    • Problem description: The JMS Producer was occasionally losing messages when it wasn't able to convert them to a JMS Message object.
    • Solution: The error handling logic was fixed.
  • The JMS Producer started but is not operable if its queue file is corrupted.
    • Problem description: The JMS Producer ignored problems with JMS queue initialization (queue file was corrupted). This led to the continuous problem with sending data by that Producer as data couldn't be added to the queue.
    • Solution: The JMS Producer fails to start if it has problems with its initialization.

...

Bugs and fixes

  • SSL acceptor session with a defined acceptor port couldn't be started.
    • Problem description: The SSL FIX server instance wasn't defined and started during FEJ server initialization and thereby SSL acceptors can be connected as no opened SSL ports.
    • Solution: The SSL FIX server instance is initialized during FEJ server start.
  • SSL Acceptor couldn't restrict connection by a specific version of SSL protocol.
    • Problem description: The configuration property sslProtocol works differently for an acceptor session. It defines a family of allowed SSL protocols for an acceptor.
    • Solution: A new acceptedSslServerProtocols option is added to restrict a connection via a specific SSL protocol.
  • Session storage type is spontaneously changed after reloading a FIX session via FIXICC UI.
    • Problem description: All FIX acceptors held the link to the same instance of the configuration object and any change of such configuration affected all acceptors sessions.
    • Solution: The acceptor session receives a clone of a configuration object during its initialization.
  • FEJ didn't log an error in case of failed FIX session authorization.
    • Problem description: FEJ does not log a validation error if the FIX session connects with invalid credentials or without them.
    • Solution: Logging of such a type of error was added.
  • FEJ incorrectly interpreted empty username/password properties.
    • Problem descriptionFEJ expected the Logon(A) message with empty Username(553) and Password(554) tags in case of username/password properties are configured without values.
    • Solution: FEJ ignores username/password properties if they are empty.
  • An acceptor session sent incoming username/password back.
    • Problem description: An acceptor session sent an incoming username/password back, but it just had to match them with the configured ones.
    • Solution: The acceptor session validates an incoming username/password and doesn't send them back in the Logon(A) answer.
  • Sequence reset for FIX session via Remote Shell CLI didn't work.
    • Problem description: The "session reset <session_id>" command returned an error message and didn't reset FIX session sequences.
    • Solution: The Remote Shell CLI command is fixed.
  • Invalid SSL parameters of the particular FIX session locked the entire FEJ initialization.
    • Problem description: An error during starting of a FIX session with invalid SSL parameters (invalid path to key/trustStore, invalid passwords, invalid stores types, etc.) broke the scheduler thread and it failed to start the rest sessions.
    • Solution: Errors during a session start are isolated.
  • FEJ server couldn't be started from a folder that has a space in its name.
    • Problem description: Paths in the start script wasn't properly quoted.
    • Solution: The FEJ server start script is fixed.

...

  • Kafka Endpoint can't publish/consume messages in a custom format. 
    • Problem description:  serializer/deserializer classes were hardcoded to work with FIX messages in key-value string format. 
    • Solution: Hardcode was removed and new interfaces for serialization/deserialization of MessageEvent instance into custom format were provided.
  • The scheduler doesn't start the session in the middle of the day.
    • Problem description:  FIX session does not start if FEJ server has started after its start time but before its stop time.
    • Solution: The scheduler logic was fixed and now it can start FIX sessions if the FEJ is started during their working hours.

...