Versions Compared

Key

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

...

Table of Contents
maxLevel2

...

Table of Contents
maxLevel2


Note

FIX Antenna ANSI C is discontinued starting version 2.18.1.

FIX Antenna 2.28.0

The most important features of this release are the dedicated listen ports for acceptor sessions and the ability to use QuickFIX formatted dictionaries, see below. 

Dedicated listen ports allow the user to restrict an incoming connection to one dedicated port (regardless of whether it is secured or not) for a session via the engine properties file, and to a number of secured or unsecured ports within the API.

QuickFIX formatted dictionaries can now be used the same way as FixAntenna formatted dictionaries.

Starting with this release, build configurations are reduced to Visual Studio 2015 x64, Centos 7 gcc4.8, Centos 7 gcc5.2, Ubuntu gcc6.1

Features and improvements

  • Expand
    titleAdd ability to load FIX dictionaries in QuickFIX format

    FixAntenna C++ now supports QuickFix dictionaries natively.

  • Expand
    titleAdd the possibility to support a custom symbol instead of SOH

    Added a new parameter for a session: tagsDelimiter
    You can configure this parameter through SessionExtraParameters and through the engine.properties file. In order to set the parameter through the config file, you can use a symbol or a hex-code, for example:

    • |
    • ^
    • 0xAD
    • 0xF5

    Make sure you use an allowed value. Check the table. You can also call the static function FAProperties::checkTagsDelimiterValue.
    The default value for tagsDelimiter parameter is 0x01 (SOH).

  • Expand
    titleDedicated listen port for FIX acceptor sessions

    The listening ports that can be defined per acceptor session. The port is opened for listening only when the session is ready to accept connection. It's possible to have several sessions on the same port as long as SSL configurations match.

  • Expand
    titleAdd an option 'ResetSeqNumFromFirstLogon' to reset sequence numbers with values taken from the first logon message

    A new option ResetSeqNumFromFirstLogon was added that allows the engine to handle sequence numbers at logon without Resend Requests.

    It can be configured with its own cron-based schedule or using an existing session schedule.

  • Expand
    titleAdd an option 'ResetSeqNumOnNonGracefulTermination' to reset sequence numbers upon non-graceful termination

    A new property, ResetSeqNumOnNonGracefulTermination, was added that allows the session to reset local sequences to 1/1 upon a connection error or a failed Logon/Logout time frame check.

  • Expand
    titleAdd an option 'confirmingLogonStrategy' to control behavior when a logout is received instead of a logon
    Added the confirmingLogonStrategy session parameter. The list of strategies can be found here.
  • Expand
    titleSet the default value for DuplicateResendRequestLimit to 2
    Set the recommended value of DuplicateResendRequestLimit = 2 to the default in engine.properties . This option allows the FIX Engine to ignore duplicate resend request and respond to multiple similar resend request messages only once. See DuplicateResendRequestLimit for details.
  • Expand
    titleConnectToGateway sample now supports scheduling
    The ConnectToGateway sample was updated to support session scheduling with sequence reset and custom logons.
  • Expand
    title[.NET] Add the possibility to turn off sending back messages in EchoServer

    The echo server sample now has the ability to disable echo mode and just work as a FIX receiver.

    This can be configured using the EchoMode property in the engine.properties file.

    EchoMode is true by default.

  • Expand
    titleUpgrade the FA .NET EchoServer sample
    The EnableAutoSessionCreation property was added to the .net EchoServer sample that enables starting pre-configured sessions automatically at start-up.
  • Expand
    titleSupport schedule assignment in the EchoServer sample
    EchoServer now supports starting/stopping sessions by schedule. Initiator sessions are supported too.

API improvements

  • Expand
    titleAdd a custom login message to SessionExtraParameters
    A new customLogonMessage_ parameter was added to the session configuration parameters. It is available through API only.
  • Expand
    titleAdd an API to pass a session's SessionBackupParameters to FixEngineSessionsController
    The support of SessionBackupParameters has been added to FixEngineSessionsController.

Logging improvements

  • Expand
    titleImprove message reject reason for invalid repeating group size

    Detection of invalid group tags with the wrong group size was added.

  • Expand
    titleLicense system improvement. Use NOTE severity if 30 days remain.
    Previous message[WARN] <timestamp> <thread> [Engine] - The license for the '<company>' expires in 38 days. Please call +44 20 369-58-166 or contact us at SupportFIXAntenna@epam.com for further assistance.
    Current message[INFO] <timestamp> <thread> [Engine] - The license for the '<company>' expires in 38 days. Please call +44 20 369-58-166 or contact us at SupportFIXAntenna@epam.com for further assistance.
    [WARN] <timestamp> <thread> [Version] - The license for the '<company>' expires in 8 days. Please call +44 20 369-58-166 or contact us at SupportFIXAntenna@epam.com for further assistance.

Fixed bugs

  • Expand
    titleIncorrect number of next expected SeqNum when using Queue Strategy in FA

    Fixed the incorrect number of next expected SeqNum in logs when using Queue Strategy.

  • Expand
    titleTimeline file is missing in the package

    Added missing date_time_zonespec.csv to the FixAntenna C++ package.

  • Expand
    titleFIXT11 session was not initialized due to last message parsing error

    When using the FIXT1.1 protocol, a correct version of the session protocol is now used to validate storage on startup. This prevents occasional failures upon session initialization if the last message in the *.out storage does not contain the ApplVerID(1128) tag.

  • Expand
    titleA session stops and restarts if it is trying to send a session-level reject while the 373 tag does not have all the values in the dictionary

    Fixed a rare case when a session tries to reconnect after attempting to send a Session Level Reject(3) message that uses one of the following tags: 371, 372, 373, 1130, 1406, 1131, contains a value that is not presented in the dictionary, and validation is enabled.

  • Expand
    titleEchoServer: user can establish a session during a dayoff period

    EchoServer has been completely reworked to provide actual examples of API usage. EchoServer now has an option to disable automatic startup for sessions with configured schedules. If the property "StartSessionsWithSchedule" set to "true", configured sessions will be started on sample execution regardless of the configured schedule. If the property "StartSessionsWithSchedule" is set to "false" or not set at all, configured sessions will be started on sample execution only if a session has no configured schedule.

  • Expand
    titleFA does not close a session if tag 789 in an incoming logon is higher than expected

    Fixed the case when a FIX session does not react correctly when the NextExpectedSeqNum(789) tag in an incoming Logon message has a value higher than the sequence number that is next to be assigned. Now, a Logout message will be sent in a scenario like this, as described in the FIX specification.

  • Expand
    titleIncorrect count of the repeating group in the error message if the count of entry is zero

    Fixed the detection of the invalid number of entries in repeating groups. This occurs when there is no entry at all.

  • Expand
    titleThe property AllowZeroNumInGroup doesn't work in FA
    Fixed the AllowZeroNumInGroup property. It allows zero-sized repeating groups in incoming messages when set to true.
  • Expand
    titleRename "fix.crush.dmp" to "fix.crash.dmp"
    Renamed the crash dump file from fix.crush.dmp to fix.crash.dmp for the Win32 platform.

FIX Protocol specifications updates

  • Expand
    titleFIXTRADING: New Extension Pack 258
    The FIX 5.0 SP2 dictionary has been updated with 258 Extension Packs.

Documentation

FIX Antenna 2.27.1

January 30, 2020

The major features of this release are Scheduler component and flexible affinity mask setup, see below. Scheduler component allows user to build and execute flexibly defined schedules and override actions execution if required, see the documentation

This is the last release that supports Centos 6 and Visual Studio compilers prior to Visual Studio 2015. So, please be informed that centos 6 configurations along with Visual Studio prior 2015 will be discontinued starting next release. Windows configurations will be reduced to only one - Visual studio 2015 in particular since starting 2015 studio ABI  compatibility is maintained across compilers versions, So library built with 2015 studio can be used with 2015/2017/2019. Linux configurations will be reduced to only three: Centos 7 gcc4.8, Centos 7 gcc5.2, Ubuntu gcc6.1

Breaking changes

  • (SD4906754) Port accepted the connection is passed to the public API method:

    Code Block
    languagecpp
    virtual bool onIncomingConnection( const FIXMessage& logonMsg, const IPAddr& remoteAddr, int remotePort, int localPort )


    B2BITS_Events.h:

    The following methods signatures have been changes:

    Code Block
    languagecpp
    titleB2BITS_Events.h
    NewIncomingConnection( const std::string& address, int port );
    NewIncomingConnectionError( const std::string& address, int port, const std::string& msg );
    SessionLogonError( const SessionId& sessionId, const std::string& address, int port, const std::string& aReason );
    SessionLogonWarning(const SessionId& sessionId, const std::string& address, int port, const std::string& aReason);
    SessionWasRejected( const SessionId& sessionId, const std::string& address, int port, const std::string& aReason );

    with

    Code Block
    languagecpp
    titleB2BITS_Events.h
    NewIncomingConnection( const std::string& remoreAddress, int remotePort, const std::string& localAddress, int localPort );
    NewIncomingConnectionError( const std::string& remoreAddress, int remotePort, const std::string& localAddress, int localPort, const std::string& msg );
    SessionLogonError( const SessionId& sessionId, const std::string& remoreAddress, int remotePort, const std::string& localAddress, int localPort, const std::string& aReason );
    SessionLogonWarning(const SessionId& sessionId, const std::string& remoreAddress, int remotePort, const std::string& localAddress, int localPort, const std::string& aReason);
    SessionWasRejected( const SessionId& sessionId, const std::string& remoreAddress, int remotePort, const std::string& localAddress, int localPort, const std::string& aReason );
    Info

    Since the methods signatures were changed, user's application modification is required.

  • Type MessageStorageType has been changed to class. So MessageStorageType can't be used as a key in 'switch' anymore. User should use 'if..else if ...' instead of 'switch'. User application may require minor changes.

Features and improvements

  • Scheduler component is implemented. 
  • SSLCACertificate is mandatory if peer certificate validation is enabled.
  • Improve logging of errors for unhandled exceptions generating business rejects during processing the message.
  • Parameter Session.Default.SocketTcpMaxSeg is added. It configures the TCP_MAXSEG parameter of the session's TCP/IP connection. It is applicable to initiator sessions only,
  • Added callbacks onAfterMessageIsParsed and onBeforeMessageIsSerialized to FA.NET
  • Improved FIX message parser scalability in a multi-threaded environment.
  • Improved performance and reduced response time of the Session::put method in aggressive_send mode in case if the message can't be sent on spot(engine overload, broken connection, etc).
  • CPU resources consumption is optimized while receiving in even mode( using threads pool) that causes response time decreasing on message path from input to Session::process method.
  • Session parameter "Role" is case insensitive in engine.properties now,
  • New timestamp formats %date{FIXus}, %date{FIXns} %date{ISO8601us}, %date{ISO8601ns} with micro and nano precisions are added for application log output. see: Format of log entries in the log file
  • FIX Antenna accepts Hexadecimal values as a CPU affinity mask.

  • Affinity mask for CPU cores can be specified as comma-separated, semicolon-separated lists or as a range see details (Core binding and affinity mask usage in FIX Antenna C++ products).

    Info

    NOTE: The curly braces should be used in case of a single number configuration in order to keep backward compatibility. By default affinity parameter values are treated as affinity mask in decimal format. It the value is set in curly braces than cores number is used instead of the mask.

  • Improve description of AggressiveReceiveDelay parameter
  • EchoServer sample is redesigned to utilize new Engine::SessionsManager::onSessionTerminated callback.

API improvements

  • Engine::SessionsManager callbacks sink is extended with onSessionTerminated that is called when a session termination happens. This allows user application to react and force the session to reconnect if desired. See documentation.

...

Logging improvements

  • (SD4906754) Extended logging of incoming connection event

    text has been changed:

    Previous message

    <severity> <timestamp> <thread> [Engine] - New incoming connection was detected (from <target ip>:<target port>).

    Current message

    <severity> <timestamp> <thread> [Engine] - New incoming connection was detected (from <target ip>:<target port> to <local ip>:<local port>).

  • Improved logging of errors for unhandled exceptions generating business rejects during processing the message.

    text has been changed:


    Previous message

    [ERROR] <timestamp> <thread> [Engine] - Session <session> : Exception in Application::process() - "<exception text>"

    Current message

    [ERROR] <timestamp> <thread> [Engine] - Session <DEF, ABC> : Exception in Application::process() - "The message 'New Order - Single' (D) with sequence number 4 can't be processed properly because it causes an exception '<exception text>' at the application level. A business level reject message (j) will be sent to the counterparty."

  • Improved text of FIX Dictionary load warnings

    text has been changed:


    Previous message

    [WARN] <timestamp> <thread> [Engine] - Found duplicate in c:\Downloads\FIX_Antenna_Cpp_2.25.1_274\samples\EchoServer\bin\.\../../../data/fixdic40.xml: / 6

    Current message

    [WARN] <timestamp> <thread> [Engine] - Found duplicated value = '6' for node 'fielddef' with attributes { name='TrdRegPublicationReason' tag='2670' type='int' } in the dictionary fixdic40.xml

  • Improved exception in the logs for loading dictionary failure

    text has been changed:


    Previous message

    [WARN] <timestamp> <thread> [Engine] - 

    Current message

    [ERROR] <timestamp> <thread> [Engine] - FixEngine::init: Cannot load message '<msg>' in the protocol '<version>'. Duplicated tag in the message is found. Possible reason is field used outside the block. Tag: <tag>

  • A WARN record is logged in case when affinity configuration can't be applied
  • FIX Antenna prints the resulted affinity configuration in the log.

Fixed bugs

  • (SD4016506) Fixed a bug when session keeps disconnected state for several minutes after disconnection.
  • ConnectToGateway sample segfaults on Linux if the target endpoint is not available.
  • Fixed a typo in the thread name: was 'dispacher', replaced with 'dispatcher'.
  • Fixed a bug when SSL Ciphers list can't be passed to SSLContextConfigurator.
  • Fixed a bug when additional dictionary adds repeating groups incorrectly if leading tag is already present in the message.
  • Fixed a bug when additional dictionary adds repeating groups incorrectly if leading tag of the nested group becomes starting tag of the parent group.
  • Session's storage files occupy unnecessary large space in certain cases.
  • Certificate path was passed into SSL context instance setup routine instead of ciphers list in some cases.
  • FIX Antenna postpones the creation of dedicated sending threads for aggressive send mode instead of creating them on session get connected.
  • EPMBFIXSUP-3642, An initiator doesn't reestablish connection after receiving logout.
  • Fixed incorrect session state transition to WaitForConfirmLogout causing delays on Engine shutdown if DelayedProcessing.MaxDeliveryTries property was configured.
  • Fixed a bug when SourceIPAddress parameter works incorrectly via administrative session

Connectivity updates

  • CME iLink DropCopy dictionaries includes all changes till 31th of December  2019
  • FIX 5.0 SP2 dictionary has been updated with 248-252 Extension Packs

Documentation

FIX Antenna 2.26.0

January 23, 2019


New Features and improvements

SSL support changes:

  • An initiator can use a certificate signed by counterparty's CA certificate for authentication
  • FIX Session configuring API improved to support loading SSL certificates of types : pfx files, .pem encoded files, .der - binary encoded files in ASN1 standard. SSL certificates with and without passwords are supported.
  • API was extended with the class SSLContextConfigurator for getting certificates and passwords from the user. 
  • API was extended with SSLContextConfiguratorConverter interface to serialize/deserialize class SSLContextConfigurator to/from string. If user uses custom SSLContextConfigurator implementation, user should implement SSLContextConfiguratorConverter in order to avoid information loss. 
  • SSLRequireClientCertificate property was replaced by SSLValidatePeerCertificate.
  • Settings SSL, SSLCertificatePassword and SSLPrivateKeyPassword were introduced.
  • SSLCheckPrivateKey property was removed. Correspondence between the key and certificate will be checked automatically. FIX Antenna does not establish session if the key doesn't correspond to the certificate. 

For more information see:

Fixed critical bugs

  • AGGRESSIVE* (see SocketOpPriority) SSL FIX session sometimes stops message sending for long time.
  • A  flag Q (for queued FIX messages, see OutOfSequenceMessagesStrategy) is not replicated in FIX logs replicator
  • Missing timestamps in session logs after corrupted storage recovery        

FIX Antenna C++/.NET Market Data Adapters:

will be removed from the package starting next release.

Market Data Adapters will be delivered as a separate package to simplify release process, speed up delivery of updates including bug fixes and to improve its integration with customer code.

FIX Antenna 2.25.1

October 9, 2018

FIX Antenna C++/.NET v2.25.1


New Features and improvements

...

FIX Antenna C++ samples:


  • MICEX_MD_Scanner sample has been decommissioned from FA package
  • Script for preparing sources and libraries has been added for Decorator sample (Linux only). Sample Decorator uses Societe Generale dictionary as an example. 
  • List of parameters passing to decorator-generator tool has been slightly changed: output dir for the headers has been added and transport layer dictionaries should be passed with -f flag, e.g.: 

    Code Block
    buildwin.bat vs100 x64 ..\..\headers ..\..\lib -s FIXT11 -a FIX50SP2 -f ..\..\data\fixdic50sp2.xml -f ..\..\data\fixdict11.xml

Logging improvements:

  • Logging due to SSL ciphers changes has been changed

engine.log

Previous message
[INFO]  <timestamp> [thread] [Engine] - Session <TargetCompID, SenderCompID> : Connecting to 127.0.0.1:9017 using SSL (SSLv2, SSLv3, TLSv1, TLSv1_1, TLSv1_2)
Current message
[INFO] <timestamp> [thread] [Engine] - Session <TargetCompID, SenderCompID> : session with 127.0.0.1:9017 was established using SSL (SSLv2, SSLv3, TLSv1, TLSv1_1, TLSv1_2) with ciphers configuration: AES+aRSA:AES+aECDH:AES+aECDSA:@STRENGTH


Critical bugs and fixes

  • Tag number of the repeating group is invisible in message details window in FIX Client Simulator
  • Replication tool is unable to be created and started as a service. 
  • Sequence numbers are processed incorrectly in certain cases when DeliverAppMessagesOutOfOrder=true 
  • ProhibitDuplicatedTags  is always enabled  in FIX Antenna C++/.NET for Repeating groups since 2.17
  • Log Replicator doesn't work with growing log files.


FIX Antenna 2.24.0

May, 18, 2018

...

 Protection from abnormal user behavior 

  • The property for limitation of number of incoming simultaneous connections that haven't sent logon message yet from one host has been added (no limitation by default). 

  • The property for limitation of connection time for an incoming connection that hasn't sent logon message yet has been added (no limitation by default).
  • The property for limitation of the maximum size of the buffer of incoming messages has been added (no limitation by default).
    Refer to How to configure TCP protection for more information

...

FIX Antenna C++/.NET v2.23.0 (r241)

New Features and improvements

...

Extension Packs

...

...

FIX Antenna C++/.NET v2.22.0 (r232)

New Features and improvements

...

FIX Antenna C++/.NET v2.21.0 (r221)

New Features and improvements

...

FIX Antenna C++ v2.20.2 (r214)

MOEX Spectra Market Data Adapter:

Fixed bugs:

  • SpectraClient Sample processes snapshots incorrectly.

FIX Antenna 2.20.1

July 7, 2017

...

New Features and Improvements

Extension Packs:

MOEX ASTS Market Data Adapter:

  • Access to tag LastUpdateTime (779) of Incremental Refresh (X) message is supported in user-level callbacks.
  • Source-specific multicast feeds is supported for Myricom DBL connectivity mode.

...

API improvements

Critical bugs and fixes

...

  • Decorator-generated code has linker issues on Windows platform.
  • Tag DeliverToCompID(128) should be populated with value of OnBehalfOfCompID(115) tag of original message in case of session-level reject.
  • Recovered orders log increments appears twice in user callbacks in MOEX ASTS Market Data Adapter.

FIX Antenna 2.18.1

February 22, 2017

FIX Antenna C++ v2.18.1 (r154)

New Features and Improvements 

MOEX Spectra Market Data Adapter:

  • Field SecurityId in messages Security DefinitionSecurity Status of streams FUT-INFO and OPT-INFO now contain instrument ID value, equal to that transmitted via the PLAZA II gateway.

 Critical bugs and fixes

The following bugs have been fixed:

FIX Antenna 2.18.0

February 20, 2017

 FIX Antenna C/C++ v2.18.0 (r149)

New Features and Improvements

MOEX Spectra Market Data Adapter:

 MOEX ASTS Market Data Adapter:

...

  • Ability to utilize environment variables in configuration files has been added.

Please see How to configure properties with environment variables article for more details. 

...

  • Fixdic50sp2ep.xml dictionary works incorrectly.
  • Rounding works incorrectly for very large double price values.
  • FIX Engine works incorrectly in case of logs moving.
  • Memory leak for transient storage type occurs in the case of non-gracefully terminated session.
  • Asynchronous connection for Initiator doesn't work in some cases.

FIX Antenna 2.17.3

 December 20, 2016

 FIX Antenna C/C++ v2.17.3 (r121)

New Features and Improvements

MOEX Spectra Market Data Adapter:

  • Encoding format for SecurityID field for new order log feed has been changed.

Protection:

  • Compile- and run-time checks to detect buffer overflows (FORTYFY_SOURCE option of gcc compiler) had been enabled. 

Other improvements:

  • Affinity mask support in FIXAntenna has been extended for the systems with 64 cores.

Critical bugs and fixes

 The following bugs have been fixed:

  • Adding a user with a subnet range of IP's within the "Source IP Address" field under the "Security" tab doesn't work in FIXICC.

FIX Antenna 2.17.2

November 25, 2016

FIX Antenna C/C++ v2.17.2 (r108)

Extension Packs:

Other improvements:

  • FIX session properties HiddenLogonCredentials and MaskedTags have been added to Admin protocol.
  • FIX Engine now detects and recovers broken storage on startup.
  • Boost symbols have been hidden in Linux .so to avoid compatibility issues.

MOEX Market Data Adapters:

  • Dictionary and FAST template have been updated for Spectra FAST gate (supported from version 1.2.3).

FIXAntenna Samples:

...

  • FIXAntenna won't start when disk space runs out.
  • DBL session can't be destroyed in some cases.
  • FIX connection reject reason is not logged in some cases.
  • Incoming message is considered as garbled in specific conditions.
  • MOEX ASTS Market Data Adapter opens port on only one interface in DBL mode. 
  • Incorrect path to dictionary in BatsClient configuration file.
  • MOEX Spectra Market Data Adapter can't read initial snapshot.

...

  • Dictionary and FAST template has been updated for Spectra FAST gate (supported from version 1.2.3).

Other improvements:

...

FIX Antenna C/C++ v2.15.1 (r78090), FIX Antenna .NET v2.15.1 (r74001)

FIX Antenna 2.15.0

November 3, 2015

...

  • The properties in engine.properties file (SSLCertificate = cert.pem; SSLCACertificate = certCA.pem) uses EngineRoot as base if relative path is used

  • CQG MD Adaptor: converting CQG FAST 'Y'/'N' values to boolean was fixed
  • Reconnection of FIX Initiator session is allowed if SSL is used
  • Obsolete Currency tag(15) value for Turkish Lira in FIX dictionaries was excluded
  • 1128 tag will be placed to the position right after the tag 35 in case of parsing FAST message to Fix Message 

...

  • Session rejects (35=3) are visible in EventViewer
  • Added an ability to send FIX 5.0+ messages via simple client even if tag1128 is absent 

FIX Antenna 2.14.1

July 3, 2015

...