Skip to main content

Pure Python FIX protocol engine

Project description

FIXcore

Pure Python FIX protocol engine — mirrors the QuickFIX architecture (QuickFIX/n, QuickFIX/J).

Features

  • Full FIX 4.2 session layer (Logon, Logout, Heartbeat, TestRequest, ResendRequest, SequenceReset, Reject) with gap-fill, out-of-order buffering, hard-reset recovery, and logon/logout timeouts
  • Hardened session recovery: byte-faithful resend (repeating groups survive replay), automatic ResendRequest retry for stalled gaps, duplicate-connection refusal, and spec-compliant Rejects for malformed admin fields instead of dropped connections
  • Message encode/decode (checksum, BodyLength, field-order validation) and repeating groups
  • Opt-in per-session validation against a QuickFIX DataDictionary — required fields and out-of-range enum values, with spec-compliant Rejects
  • Async transport: SocketAcceptor + SocketInitiator with auto-reconnect
  • Durable FileStore (fsync + atomic sequence-number writes) and MemoryStore
  • MessageCracker dispatch mixin
  • Lightweight browser GUI via aiohttp (fixcore-gui) — session management, message builder, live message log

Quick start

pip install fixcore-engine
pip install "fixcore-engine[gui]"  # includes aiohttp for the GUI

Validation (opt-in)

Validation is off by default (raw FIX passthrough). Enable it per session via QuickFIX-compatible settings:

[SESSION]
UseDataDictionary=Y             ; load the spec: group-aware decode + (by default) validation
DataDictionary=specs/FIX42.xml
ValidateIncomingMessage=N       ; keep group-aware decode but DON'T reject non-conforming inbound (default Y)
ValidateFieldsOutOfRange=Y      ; also reject out-of-range enum values (e.g. Side=Z)

UseDataDictionary=Y loads the spec so repeating groups decode into proper instances. By default it also validates inbound app messages (required fields, known MsgType) and Rejects violations. Set ValidateIncomingMessage=N to keep the group-aware decode while delivering non-conforming messages as-is — useful for permissive/testing peers that need to inspect off-spec traffic rather than reject it.

Development

pip install -e ".[dev,gui]"
pytest
fixcore-gui

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

fixcore_engine-0.6.0.tar.gz (84.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

fixcore_engine-0.6.0-py3-none-any.whl (65.5 kB view details)

Uploaded Python 3

File details

Details for the file fixcore_engine-0.6.0.tar.gz.

File metadata

  • Download URL: fixcore_engine-0.6.0.tar.gz
  • Upload date:
  • Size: 84.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for fixcore_engine-0.6.0.tar.gz
Algorithm Hash digest
SHA256 2bcf4cddd0b0e86a1e25652c604ec9b758cfbae8fb3e224a63d732126e3ef00d
MD5 8df7183f9879141b7d219150da1189cd
BLAKE2b-256 f3b5710de96425add531c9bd8e9ad2e2eada8246e676a36f67a0ecffdeef6828

See more details on using hashes here.

File details

Details for the file fixcore_engine-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: fixcore_engine-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 65.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for fixcore_engine-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 1a7a3e6d67d0dc273105efd9850bc9635c5afac5f976348c1dbb4a25894784ab
MD5 2aa2d70e027a664776f6239ad1f9a598
BLAKE2b-256 0bc04ef36efd6cf907e5042ec087f8813cc84caeba73a83ed256826f8b9f25c8

See more details on using hashes here.

Supported by

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