Skip to main content

A parser for FIX messages

Project description

jetblack-fixparser

A parser for FIX messages.

Installation

The package can be installed with pip.

pip install jetblack-fixparser

Protocol Files

While FIX is a standard, the structure of the fields and messages is configurable. This configuration is typically loaded from a file. The source repository contains a number of such files in the /etc folder in YAML format. There is also a QuickFix loader.

The YAML format makes use of defaults. All message fields default to type field, so only group and component fields need to be explicitly specified. Also all message fields are consider optional, non-optional fields must be marked as required: true.

Usage

Decoding

To decode a FIX bytes buffer -

from jetblack_fixparser import load_yaml_protocol, FixMessage

buffer = b'8=FIX.4.4|9=94|35=3|49=A|56=AB|128=B1|34=214|50=U1|52=20100304-09:42:23.130|45=176|371=15|372=X|373=1|58=txt|10=058|',

protocol = load_yaml_protocol(
    'FIX44.yaml',
    is_millisecond_time=True,
    is_float_decimal=True
)

fix_message = FixMessage.decode(
    protocol,
    buffer,
    sep=b'|',
    strict=True,
    validate=True,
    convert_sep_for_checksum=True
)

print(fix_message.message)

Note that strict validation is enabled. This ensures all required fields are specified. Also the separator is changed from NULL to | to so they can be displayed. However the checksum was calculated with the original field separator so the convert_sep_for_checksum is set to true.

Encoding

To encode a dictionary describing a FIX message -

from datetime import datetime, timezone
from jetblack_fixparser import load_yaml_protocol, FixMessage

protocol = load_yaml_protocol(
    'FIX44.yaml',
    is_millisecond_time=True,
    is_float_decimal=True,
    is_type_enum=None
)
sending_time = datetime(2020, 1, 1, 12, 30, 0, tzinfo=timezone.utc)

fix_message = FixMessage(
    protocol,
    {
        'MsgType': 'LOGON',
        'MsgSeqNum': 42,
        'SenderCompID': "SENDER",
        'TargetCompID': "TARGET",
        'SendingTime': sending_time,
        'EncryptMethod': "NONE",
        'HeartBtInt': 30
    }
)
buffer = fix_message.encode(regenerate_integrity=True)

print(buffer)

Note that the BeginString, BodyLength and Checksum fields were automatically generated.

Factories

To encode and decode a message using a factory -

from datetime import datetime, timezone
from jetblack_fixparser import load_yaml_protocol, FixMessage, FixMessageFactory

protocol = load_yaml_protocol(
    'FIX44.yaml',
    is_millisecond_time=True,
    is_float_decimal=True,
    is_type_enum=None
)

factory = FixMessageFactory(protocol, "SENDER", "TARGET")

sending_time = datetime(2020, 1, 1, 12, 30, 0, tzinfo=timezone.utc)
fix_messages = factory.create(
        'LOGON',
        42,
        sending_time,
        {
            'EncryptMethod': "NONE",
            'HeartBtInt': 30
        }
    )

buffer = fix_message.encode(regenerate_integrity=True)
roundtrip = FixMessage.decode(protocol, buffer)
assert fix_message.message == roundtrip.message

Because the sender and target remain the same, we can simplify message generation with the factory.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

jetblack-fixparser-2.4.0.tar.gz (20.7 kB view details)

Uploaded Source

Built Distribution

jetblack_fixparser-2.4.0-py3-none-any.whl (28.2 kB view details)

Uploaded Python 3

File details

Details for the file jetblack-fixparser-2.4.0.tar.gz.

File metadata

  • Download URL: jetblack-fixparser-2.4.0.tar.gz
  • Upload date:
  • Size: 20.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.12 CPython/3.10.10 Darwin/21.6.0

File hashes

Hashes for jetblack-fixparser-2.4.0.tar.gz
Algorithm Hash digest
SHA256 3e0b84c9e982c83e03621caf4adf6907833ceecbe0337814a41bed0ebfb9a666
MD5 f1f81832a5d516bc26cedd8f9814f1fc
BLAKE2b-256 d88c5e7cb0efb487980a757ab5e57e13711a19e19be0f507a9fcac288db63a8d

See more details on using hashes here.

File details

Details for the file jetblack_fixparser-2.4.0-py3-none-any.whl.

File metadata

File hashes

Hashes for jetblack_fixparser-2.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 d0ab2ff810e0fcc9e85a05f524734b79bfff30b803e32dc00e5d3f31a3a40521
MD5 405f36962ca956805f7de5ab56565862
BLAKE2b-256 ee9c31fe100913f3f70a87968bf9d83cd4f733f5bc477603a08cfe4176be2fa9

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page