fast-protocol
v0.1.15
Published
FAST streaming protocol for Node.js (Encoder/Decoder for Javascript) (FAST protocol version 1.1)
Downloads
26
Maintainers
Readme
fast-protocol
fast-protocol is a javascript/node.js module providing encoder/decoder functions for FAST -> 'FIX Adapted for Streaming' protocol version 1.1.
Attention
Currently the module is still in development, see known limitations below.
Install
npm install fast-protocol
Features
- Load FAST xml template definition from file
- Provide FAST message encoding and decoding
Known limitations
- no 'streaming' support, only datagram or complete buffer can be encoded/decoded
- no templateRef support
- no individual operator support for decimal
- only 'global' dictionary
- limited error handling features implemented yet
Importing
var fastStream = require('fast-protocol')
Simple Examples
Encoding
The following example shows simple encoding usage:
// load fast stream module
var FastStream = require('fast-protocol')
// create encoder using FAST template definition from file
var encoder = new FastStream.Encoder('emdi-7.0.xml')
// encode message
var buffer = encoder.encode('RDPacketHeader', { SenderCompID: 1,
PacketSeqNum: [ 0, 8, 58, 9 ],
SendingTime: [ 21, 105, 89, 139, 55, 77, 80, 126 ] })
// process buffer
...
Decoding - using single callback function
// load fast stream module
var FastStream = require('fast-protocol')
// create message decoder
var decoder = new FastStream.Decoder('emdi-7.0.xml')
// read binary buffer - user specific function
var buffer = readBuffer()
// decode buffer content
decoder.decode(buffer, function(msg, name) {
console.log(name, JSON.stringify(msg, null, 2))
})
Decoding - using message specific callback function
You can also provide a javascript object with message specific callback functions, like this example:
// load fast stream module
var FastStream = require('fast-protocol')
// create message decoder
var decoder = new FastStream.Decoder('emdi-7.0.xml')
// read binary buffer - user specific function
var buffer = readBuffer()
// decode buffer content
decoder.decode(buffer, {
RDPacketHeader: function(msg) {
// process RDPacketHeader
console.log('PacketHeader', JSON.stringify(msg, null, 2))
},
ProductSnapshot: function(msg) {
// process ProductSnapshot
console.log('ProductSnapshot', JSON.stringify(msg, null, 2))
}
})
Test coverage
Decode/Encode tests have been run using Xetra T7 EMDI market data of 03.01.2019; market data of the entire day has been decoded/encoded correctly - 100 % conformity achieved.
API Documentation
t.b.d.
Contributing
Everyone is welcome!