jspurefix 1.2.0 → 2.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.travis.yml +1 -1
- package/README.md +48 -2
- package/appveyor.yml +46 -11
- package/data/session/certs/ca/ca.crt +33 -0
- package/data/session/certs/ca/ca.key +54 -0
- package/data/session/certs/client/client.crt +31 -0
- package/data/session/certs/client/client.key +51 -0
- package/data/session/certs/server/server.crt +31 -0
- package/data/session/certs/server/server.key +51 -0
- package/data/session/genkey.ps1 +179 -0
- package/dist/a-session-msg-factory.d.ts +0 -0
- package/dist/a-session-msg-factory.js +1 -0
- package/dist/a-session-msg-factory.js.map +1 -0
- package/dist/ascii-encoder.test.d.ts +0 -0
- package/dist/ascii-encoder.test.js +1 -0
- package/dist/ascii-encoder.test.js.map +1 -0
- package/dist/ascii-parser.test.d.ts +0 -0
- package/dist/ascii-parser.test.js +1 -0
- package/dist/ascii-parser.test.js.map +1 -0
- package/dist/ascii-segment.test.d.ts +0 -0
- package/dist/ascii-segment.test.js +1 -0
- package/dist/ascii-segment.test.js.map +1 -0
- package/dist/ascii-store-replay.test.d.ts +0 -0
- package/dist/ascii-store-replay.test.js +1 -0
- package/dist/ascii-store-replay.test.js.map +1 -0
- package/dist/ascii-tag-pos.test.d.ts +0 -0
- package/dist/ascii-tag-pos.test.js +1 -0
- package/dist/ascii-tag-pos.test.js.map +1 -0
- package/dist/buffer/{ascii-chars.d.ts → ascii/ascii-chars.d.ts} +0 -0
- package/dist/buffer/{ascii-chars.js → ascii/ascii-chars.js} +0 -0
- package/dist/buffer/ascii/ascii-chars.js.map +1 -0
- package/dist/buffer/ascii/ascii-encoder.d.ts +5 -3
- package/dist/buffer/ascii/ascii-encoder.js +82 -48
- package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
- package/dist/buffer/ascii/ascii-parser-state.d.ts +3 -10
- package/dist/buffer/ascii/ascii-parser-state.js +37 -25
- package/dist/buffer/ascii/ascii-parser-state.js.map +1 -1
- package/dist/buffer/ascii/ascii-parser.d.ts +7 -7
- package/dist/buffer/ascii/ascii-parser.js +50 -24
- package/dist/buffer/ascii/ascii-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-segment-parser.d.ts +2 -2
- package/dist/buffer/ascii/ascii-segment-parser.js +34 -13
- package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-view.d.ts +2 -4
- package/dist/buffer/ascii/ascii-view.js +11 -15
- package/dist/buffer/ascii/ascii-view.js.map +1 -1
- package/dist/buffer/ascii/index.d.ts +1 -0
- package/dist/buffer/ascii/index.js +1 -0
- package/dist/buffer/ascii/index.js.map +1 -1
- package/dist/buffer/ascii/parse-state.d.ts +8 -0
- package/dist/buffer/ascii/parse-state.js +13 -0
- package/dist/buffer/ascii/parse-state.js.map +1 -0
- package/dist/buffer/ascii/time-formatter.js +1 -1
- package/dist/buffer/ascii/time-formatter.js.map +1 -1
- package/dist/buffer/elastic-buffer.js +29 -8
- package/dist/buffer/elastic-buffer.js.map +1 -1
- package/dist/buffer/encode-proxy.d.ts +1 -1
- package/dist/buffer/encode-proxy.js +16 -17
- package/dist/buffer/encode-proxy.js.map +1 -1
- package/dist/buffer/fixml/fixml-encoder.d.ts +2 -1
- package/dist/buffer/fixml/fixml-encoder.js +43 -20
- package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
- package/dist/buffer/fixml/fixml-parser.js +47 -24
- package/dist/buffer/fixml/fixml-parser.js.map +1 -1
- package/dist/buffer/fixml/fixml-view.d.ts +2 -2
- package/dist/buffer/fixml/fixml-view.js +13 -13
- package/dist/buffer/fixml/fixml-view.js.map +1 -1
- package/dist/buffer/fixml/populated-attributes.d.ts +5 -0
- package/dist/buffer/fixml/populated-attributes.js +3 -0
- package/dist/buffer/fixml/populated-attributes.js.map +1 -0
- package/dist/buffer/index.d.ts +4 -8
- package/dist/buffer/index.js +4 -8
- package/dist/buffer/index.js.map +1 -1
- package/dist/buffer/msg-encoder.d.ts +2 -1
- package/dist/buffer/msg-encoder.js.map +1 -1
- package/dist/buffer/msg-view.d.ts +3 -3
- package/dist/buffer/msg-view.js +8 -5
- package/dist/buffer/msg-view.js.map +1 -1
- package/dist/buffer/segment/segment-description.d.ts +26 -0
- package/dist/buffer/segment/segment-description.js +72 -0
- package/dist/buffer/segment/segment-description.js.map +1 -0
- package/dist/buffer/segment/segment-summary.d.ts +13 -0
- package/dist/buffer/segment/segment-summary.js +20 -0
- package/dist/buffer/segment/segment-summary.js.map +1 -0
- package/dist/buffer/segment/segment-type.d.ts +8 -0
- package/dist/buffer/segment/segment-type.js +13 -0
- package/dist/buffer/segment/segment-type.js.map +1 -0
- package/dist/buffer/segment-description.d.ts +2 -9
- package/dist/buffer/segment-description.js +5 -13
- package/dist/buffer/segment-description.js.map +1 -1
- package/dist/buffer/segment-type.d.ts +8 -0
- package/dist/buffer/segment-type.js +13 -0
- package/dist/buffer/segment-type.js.map +1 -0
- package/dist/buffer/structure.d.ts +3 -3
- package/dist/buffer/structure.js +1 -1
- package/dist/buffer/structure.js.map +1 -1
- package/dist/buffer/tag/tag-pos.d.ts +12 -0
- package/dist/buffer/tag/tag-pos.js +55 -0
- package/dist/buffer/tag/tag-pos.js.map +1 -0
- package/dist/buffer/tag/tag-type.d.ts +13 -0
- package/dist/buffer/tag/tag-type.js +18 -0
- package/dist/buffer/tag/tag-type.js.map +1 -0
- package/dist/buffer/tag/tags.d.ts +21 -0
- package/dist/buffer/tag/tags.js +122 -0
- package/dist/buffer/tag/tags.js.map +1 -0
- package/dist/buffer/tag-type.d.ts +13 -0
- package/dist/buffer/tag-type.js +18 -0
- package/dist/buffer/tag-type.js.map +1 -0
- package/dist/buffer/tags.d.ts +3 -14
- package/dist/buffer/tags.js +23 -36
- package/dist/buffer/tags.js.map +1 -1
- package/dist/config/get-js-fx-logger.d.ts +4 -0
- package/dist/config/get-js-fx-logger.js +3 -0
- package/dist/config/get-js-fx-logger.js.map +1 -0
- package/dist/config/index.d.ts +1 -0
- package/dist/config/index.js +1 -0
- package/dist/config/index.js.map +1 -1
- package/dist/config/js-fix-config.d.ts +4 -1
- package/dist/config/js-fix-config.js +3 -3
- package/dist/config/js-fix-config.js.map +1 -1
- package/dist/config/js-fix-logger.d.ts +0 -3
- package/dist/config/js-fix-logger.js.map +1 -1
- package/dist/dict-parser.js +30 -25
- package/dist/dict-parser.js.map +1 -1
- package/dist/dictionary/compiler/compiler-type.js +7 -7
- package/dist/dictionary/compiler/compiler-type.js.map +1 -1
- package/dist/dictionary/compiler/enum-compiler.d.ts +1 -0
- package/dist/dictionary/compiler/enum-compiler.js +11 -1
- package/dist/dictionary/compiler/enum-compiler.js.map +1 -1
- package/dist/dictionary/compiler/msg-compiler.js +8 -6
- package/dist/dictionary/compiler/msg-compiler.js.map +1 -1
- package/dist/dictionary/contained/contained-component-field.js +2 -1
- package/dist/dictionary/contained/contained-component-field.js.map +1 -1
- package/dist/dictionary/contained/contained-field-dispatch.d.ts +1 -14
- package/dist/dictionary/contained/contained-field-dispatch.js +4 -4
- package/dist/dictionary/contained/contained-field-dispatch.js.map +1 -1
- package/dist/dictionary/contained/contained-field-dispatcher.d.ts +14 -0
- package/dist/dictionary/contained/contained-field-dispatcher.js +3 -0
- package/dist/dictionary/contained/contained-field-dispatcher.js.map +1 -0
- package/dist/dictionary/contained/contained-field-set.d.ts +1 -1
- package/dist/dictionary/contained/contained-field-set.js +12 -11
- package/dist/dictionary/contained/contained-field-set.js.map +1 -1
- package/dist/dictionary/contained/contained-field-type.d.ts +5 -0
- package/dist/dictionary/contained/contained-field-type.js +10 -0
- package/dist/dictionary/contained/contained-field-type.js.map +1 -0
- package/dist/dictionary/contained/contained-field.d.ts +1 -5
- package/dist/dictionary/contained/contained-field.js +1 -7
- package/dist/dictionary/contained/contained-field.js.map +1 -1
- package/dist/dictionary/contained/contained-group-field.js +2 -1
- package/dist/dictionary/contained/contained-group-field.js.map +1 -1
- package/dist/dictionary/contained/contained-simple-field.js +2 -1
- package/dist/dictionary/contained/contained-simple-field.js.map +1 -1
- package/dist/dictionary/{fields-dispatch.d.ts → contained/field-dispatcher.d.ts} +3 -2
- package/dist/dictionary/contained/field-dispatcher.js +3 -0
- package/dist/dictionary/contained/field-dispatcher.js.map +1 -0
- package/dist/dictionary/contained/fields-dispatch.d.ts +6 -0
- package/dist/dictionary/contained/fields-dispatch.js +42 -0
- package/dist/dictionary/contained/fields-dispatch.js.map +1 -0
- package/dist/dictionary/contained/index.d.ts +2 -0
- package/dist/dictionary/contained/index.js +2 -0
- package/dist/dictionary/contained/index.js.map +1 -1
- package/dist/dictionary/contained-set-type.d.ts +5 -0
- package/dist/dictionary/contained-set-type.js +10 -0
- package/dist/dictionary/contained-set-type.js.map +1 -0
- package/dist/dictionary/definition/component-field-definition.js +2 -2
- package/dist/dictionary/definition/component-field-definition.js.map +1 -1
- package/dist/dictionary/definition/fix-definitions.d.ts +2 -1
- package/dist/dictionary/definition/fix-definitions.js.map +1 -1
- package/dist/dictionary/definition/group-field-definition.js +2 -2
- package/dist/dictionary/definition/group-field-definition.js.map +1 -1
- package/dist/dictionary/definition/index.d.ts +0 -1
- package/dist/dictionary/definition/index.js +0 -1
- package/dist/dictionary/definition/index.js.map +1 -1
- package/dist/dictionary/definition/message-definition.js +2 -2
- package/dist/dictionary/definition/message-definition.js.map +1 -1
- package/dist/dictionary/definition/simple-field-definition.d.ts +1 -1
- package/dist/dictionary/definition/simple-field-definition.js +5 -4
- package/dist/dictionary/definition/simple-field-definition.js.map +1 -1
- package/dist/dictionary/dict-primitive.d.ts +0 -11
- package/dist/dictionary/dict-primitive.js +0 -7
- package/dist/dictionary/dict-primitive.js.map +1 -1
- package/dist/dictionary/fix-definition-source.d.ts +6 -0
- package/dist/dictionary/fix-definition-source.js +11 -0
- package/dist/dictionary/fix-definition-source.js.map +1 -0
- package/dist/dictionary/fix-versions.d.ts +0 -9
- package/dist/dictionary/fix-versions.js +1 -39
- package/dist/dictionary/fix-versions.js.map +1 -1
- package/dist/dictionary/index.d.ts +1 -5
- package/dist/dictionary/index.js +1 -5
- package/dist/dictionary/index.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/abbreviations-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/base-parser.d.ts +2 -4
- package/dist/dictionary/parser/fix-repository/base-parser.js +1 -2
- package/dist/dictionary/parser/fix-repository/base-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/components-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/components-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/components-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/data-types-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/data-types-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/data-types-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/enums-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/enums-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/enums-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/fields-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/fields-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/fields-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/messages-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/messages-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/messages-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.d.ts +1 -3
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.js +2 -3
- package/dist/dictionary/parser/fix-repository/msg-contents-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.d.ts +5 -0
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-abbreviation.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-component.d.ts +10 -0
- package/dist/dictionary/parser/fix-repository/repository-component.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-component.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.d.ts +6 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-data-type.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-enum.d.ts +7 -0
- package/dist/{standard_header.js → dictionary/parser/fix-repository/repository-enum.js} +1 -1
- package/dist/dictionary/parser/fix-repository/repository-enum.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-field.d.ts +11 -0
- package/dist/dictionary/parser/fix-repository/repository-field.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-field.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-message.d.ts +11 -0
- package/dist/dictionary/parser/fix-repository/repository-message.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-message.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.d.ts +9 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.js +3 -0
- package/dist/dictionary/parser/fix-repository/repository-msg-content.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.d.ts +0 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.js +1 -0
- package/dist/dictionary/parser/fix-repository/repository-msg.js.map +1 -0
- package/dist/dictionary/parser/fix-repository/repository-type.d.ts +0 -53
- package/dist/dictionary/parser/fix-repository/repository-type.js +0 -2
- package/dist/dictionary/parser/fix-repository/repository-type.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository-xml-parser.js +10 -10
- package/dist/dictionary/parser/fix-repository/repository-xml-parser.js.map +1 -1
- package/dist/dictionary/parser/fix-repository/repository.d.ts +12 -1
- package/dist/dictionary/parser/fix-repository/repository.js +50 -28
- package/dist/dictionary/parser/fix-repository/repository.js.map +1 -1
- package/dist/dictionary/parser/fixml/components-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/components-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/fields-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/fields-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/fix-xsd-parser.js +3 -2
- package/dist/dictionary/parser/fixml/fix-xsd-parser.js.map +1 -1
- package/dist/dictionary/parser/fixml/include-graph.js.map +1 -1
- package/dist/dictionary/parser/fixml/xsd-parser.d.ts +1 -1
- package/dist/dictionary/parser/fixml/xsd-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/field-definition-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/field-definition-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/field-definition-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/field-set-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/field-set-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/message-parser.d.ts +4 -4
- package/dist/dictionary/parser/quickfix/message-parser.js +3 -3
- package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/node-parser.d.ts +4 -5
- package/dist/dictionary/parser/quickfix/node-parser.js +4 -4
- package/dist/dictionary/parser/quickfix/node-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/parse-state.d.ts +8 -0
- package/dist/dictionary/parser/quickfix/parse-state.js +13 -0
- package/dist/dictionary/parser/quickfix/parse-state.js.map +1 -0
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -9
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +28 -35
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
- package/dist/dictionary/sax-node.d.ts +6 -0
- package/dist/{header.js → dictionary/sax-node.js} +1 -1
- package/dist/dictionary/sax-node.js.map +1 -0
- package/dist/dictionary/set-reduce.d.ts +5 -12
- package/dist/dictionary/set-reduce.js +28 -26
- package/dist/dictionary/set-reduce.js.map +1 -1
- package/dist/dictionary/type-dispatcher.d.ts +12 -0
- package/dist/dictionary/type-dispatcher.js +3 -0
- package/dist/dictionary/type-dispatcher.js.map +1 -0
- package/dist/dictionary/version-util.d.ts +4 -0
- package/dist/dictionary/version-util.js +36 -0
- package/dist/dictionary/version-util.js.map +1 -0
- package/dist/execution-report.test.d.ts +0 -0
- package/dist/execution-report.test.js +1 -0
- package/dist/execution-report.test.js.map +1 -0
- package/dist/experiment.d.ts +0 -0
- package/dist/experiment.js +1 -0
- package/dist/experiment.js.map +1 -0
- package/dist/fix-repo-dict.test.d.ts +0 -0
- package/dist/fix-repo-dict.test.js +1 -0
- package/dist/fix-repo-dict.test.js.map +1 -0
- package/dist/fix-session-state-args.d.ts +0 -0
- package/dist/fix-session-state-args.js +1 -0
- package/dist/fix-session-state-args.js.map +1 -0
- package/dist/fix-session-state.d.ts +0 -0
- package/dist/fix-session-state.js +1 -0
- package/dist/fix-session-state.js.map +1 -0
- package/dist/fix-session.d.ts +0 -0
- package/dist/fix-session.js +1 -0
- package/dist/fix-session.js.map +1 -0
- package/dist/fix.txt +1 -1
- package/dist/fixml-alloc-parse.test.d.ts +0 -0
- package/dist/fixml-alloc-parse.test.js +1 -0
- package/dist/fixml-alloc-parse.test.js.map +1 -0
- package/dist/fixml-mkt-data-fut-parse.test.d.ts +0 -0
- package/dist/fixml-mkt-data-fut-parse.test.js +1 -0
- package/dist/fixml-mkt-data-fut-parse.test.js.map +1 -0
- package/dist/fixml-mkt-data-settle-parse.test.d.ts +0 -0
- package/dist/fixml-mkt-data-settle-parse.test.js +1 -0
- package/dist/fixml-mkt-data-settle-parse.test.js.map +1 -0
- package/dist/fixml-tc-bi-lateral-parse.test.d.ts +0 -0
- package/dist/fixml-tc-bi-lateral-parse.test.js +1 -0
- package/dist/fixml-tc-bi-lateral-parse.test.js.map +1 -0
- package/dist/includes.test.d.ts +0 -0
- package/dist/includes.test.js +1 -0
- package/dist/includes.test.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/dist/jsfix-cmd.d.ts +5 -0
- package/dist/jsfix-cmd.js +28 -21
- package/dist/jsfix-cmd.js.map +1 -1
- package/dist/launcher.d.ts +0 -0
- package/dist/launcher.js +1 -0
- package/dist/launcher.js.map +1 -0
- package/dist/logon.test.d.ts +0 -0
- package/dist/logon.test.js +1 -0
- package/dist/logon.test.js.map +1 -0
- package/dist/make-fix-session.d.ts +0 -0
- package/dist/make-fix-session.js +1 -0
- package/dist/make-fix-session.js.map +1 -0
- package/dist/memory-store.test.d.ts +0 -0
- package/dist/memory-store.test.js +1 -0
- package/dist/memory-store.test.js.map +1 -0
- package/dist/object.json +473 -698
- package/dist/qf-full-msg.test.d.ts +0 -0
- package/dist/qf-full-msg.test.js +1 -0
- package/dist/qf-full-msg.test.js.map +1 -0
- package/dist/repo-full-ascii-msg.test.d.ts +0 -0
- package/dist/repo-full-ascii-msg.test.js +1 -0
- package/dist/repo-full-ascii-msg.test.js.map +1 -0
- package/dist/runtime/DITokens.d.ts +20 -0
- package/dist/runtime/DITokens.js +25 -0
- package/dist/runtime/DITokens.js.map +1 -0
- package/dist/runtime/app-launcher.d.ts +27 -0
- package/dist/runtime/app-launcher.js +131 -0
- package/dist/runtime/app-launcher.js.map +1 -0
- package/dist/runtime/di-tokens.d.ts +28 -0
- package/dist/runtime/di-tokens.js +33 -0
- package/dist/runtime/di-tokens.js.map +1 -0
- package/dist/runtime/engine-factory.d.ts +4 -0
- package/dist/runtime/engine-factory.js +3 -0
- package/dist/runtime/engine-factory.js.map +1 -0
- package/dist/runtime/index.d.ts +5 -0
- package/dist/runtime/index.js +18 -0
- package/dist/runtime/index.js.map +1 -0
- package/dist/runtime/launcher.d.ts +29 -0
- package/dist/runtime/launcher.js +131 -0
- package/dist/runtime/launcher.js.map +1 -0
- package/dist/runtime/make-config.d.ts +11 -0
- package/dist/runtime/make-config.js +57 -0
- package/dist/runtime/make-config.js.map +1 -0
- package/dist/runtime/session-container.d.ts +16 -0
- package/dist/runtime/session-container.js +168 -0
- package/dist/runtime/session-container.js.map +1 -0
- package/dist/runtime/session-launcher.d.ts +26 -0
- package/dist/runtime/session-launcher.js +131 -0
- package/dist/runtime/session-launcher.js.map +1 -0
- package/dist/sample/http/oms/app.d.ts +1 -1
- package/dist/sample/http/oms/app.js +16 -12
- package/dist/sample/http/oms/app.js.map +1 -1
- package/dist/sample/http/oms/http-client.js +22 -2
- package/dist/sample/http/oms/http-client.js.map +1 -1
- package/dist/sample/http/oms/http-server.js +21 -2
- package/dist/sample/http/oms/http-server.js.map +1 -1
- package/dist/sample/launcher.d.ts +21 -3
- package/dist/sample/launcher.js +88 -11
- package/dist/sample/launcher.js.map +1 -1
- package/dist/sample/tcp/qf-md/app.d.ts +1 -1
- package/dist/sample/tcp/qf-md/app.js +11 -11
- package/dist/sample/tcp/qf-md/app.js.map +1 -1
- package/dist/sample/tcp/qf-md/md-client.js +21 -2
- package/dist/sample/tcp/qf-md/md-client.js.map +1 -1
- package/dist/sample/tcp/qf-md/md-server.js +20 -2
- package/dist/sample/tcp/qf-md/md-server.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -1
- package/dist/sample/tcp/recovering-skeleton/app.js +36 -16
- package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +3 -1
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +30 -8
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +22 -3
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -1
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +21 -2
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -1
- package/dist/sample/tcp/skeleton/app.d.ts +1 -1
- package/dist/sample/tcp/skeleton/app.js +8 -13
- package/dist/sample/tcp/skeleton/app.js.map +1 -1
- package/dist/sample/tcp/skeleton/skeleton-session.d.ts +5 -1
- package/dist/sample/tcp/skeleton/skeleton-session.js +45 -4
- package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.d.ts +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.js +4 -24
- package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
- package/dist/sample/tcp/trade-capture/app-launcher.d.ts +6 -0
- package/dist/sample/tcp/trade-capture/app-launcher.js +21 -0
- package/dist/sample/tcp/trade-capture/app-launcher.js.map +1 -0
- package/dist/sample/tcp/trade-capture/app-launher.d.ts +0 -0
- package/dist/sample/tcp/trade-capture/app-launher.js +1 -0
- package/dist/sample/tcp/trade-capture/app-launher.js.map +1 -0
- package/dist/sample/tcp/trade-capture/app.d.ts +1 -1
- package/dist/sample/tcp/trade-capture/app.js +4 -21
- package/dist/sample/tcp/trade-capture/app.js.map +1 -1
- package/dist/sample/tcp/trade-capture/jsfix.test_client.txt +11 -14
- package/dist/sample/tcp/trade-capture/jsfix.test_server.txt +10 -14
- package/dist/sample/tcp/trade-capture/trade-capture-client.d.ts +1 -0
- package/dist/sample/tcp/trade-capture/trade-capture-client.js +7 -3
- package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -1
- package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -1
- package/dist/sample/tcp/trade-capture/trade-factory.js +7 -1
- package/dist/sample/tcp/trade-capture/trade-factory.js.map +1 -1
- package/dist/segment-description.d.ts +0 -0
- package/dist/segment-description.js +1 -0
- package/dist/segment-description.js.map +1 -0
- package/dist/segment-summary.d.ts +0 -0
- package/dist/segment-summary.js +1 -0
- package/dist/segment-summary.js.map +1 -0
- package/dist/segment-type.d.ts +0 -0
- package/dist/segment-type.js +1 -0
- package/dist/segment-type.js.map +1 -0
- package/dist/session-description.d.ts +0 -0
- package/dist/session-description.js +1 -0
- package/dist/session-description.js.map +1 -0
- package/dist/session-msg-factory.d.ts +0 -0
- package/dist/session-msg-factory.js +1 -0
- package/dist/session-msg-factory.js.map +1 -0
- package/dist/session-state.d.ts +0 -0
- package/dist/session-state.js +1 -0
- package/dist/session-state.js.map +1 -0
- package/dist/session-state.test.d.ts +0 -0
- package/dist/session-state.test.js +1 -0
- package/dist/session-state.test.js.map +1 -0
- package/dist/session.test.d.ts +0 -0
- package/dist/session.test.js +1 -0
- package/dist/session.test.js.map +1 -0
- package/dist/setup.d.ts +0 -0
- package/dist/setup.js +1 -0
- package/dist/setup.js.map +1 -0
- package/dist/skeleton-runner.d.ts +0 -0
- package/dist/skeleton-runner.js +1 -0
- package/dist/skeleton-runner.js.map +1 -0
- package/dist/store/fix-msg-ascii-store-resend.d.ts +3 -2
- package/dist/store/fix-msg-ascii-store-resend.js +30 -21
- package/dist/store/fix-msg-ascii-store-resend.js.map +1 -1
- package/dist/store/fix-msg-memory-store.d.ts +11 -8
- package/dist/store/fix-msg-memory-store.js +108 -42
- package/dist/store/fix-msg-memory-store.js.map +1 -1
- package/dist/store/fix-msg-store-record.d.ts +4 -0
- package/dist/store/fix-msg-store-record.js +7 -0
- package/dist/store/fix-msg-store-record.js.map +1 -1
- package/dist/store/fix-msg-store-state.d.ts +6 -0
- package/dist/store/fix-msg-store-state.js +3 -0
- package/dist/store/fix-msg-store-state.js.map +1 -0
- package/dist/store/fix-msg-store.d.ts +8 -9
- package/dist/store/fix-msg-store.js.map +1 -1
- package/dist/structure.json +225 -485
- package/dist/tag-pos.d.ts +0 -0
- package/dist/tag-pos.js +1 -0
- package/dist/tag-pos.js.map +1 -0
- package/dist/tag-type.d.ts +0 -0
- package/dist/tag-type.js +1 -0
- package/dist/tag-type.js.map +1 -0
- package/dist/tags.d.ts +0 -0
- package/dist/tags.js +1 -0
- package/dist/tags.js.map +1 -0
- package/dist/test/ascii/ascii-encoder.test.d.ts +1 -0
- package/dist/test/ascii/ascii-encoder.test.js +507 -0
- package/dist/test/ascii/ascii-encoder.test.js.map +1 -0
- package/dist/test/ascii/ascii-parser.test.d.ts +1 -0
- package/dist/test/ascii/ascii-parser.test.js +123 -0
- package/dist/test/ascii/ascii-parser.test.js.map +1 -0
- package/dist/test/ascii/ascii-segment.test.d.ts +1 -0
- package/dist/test/ascii/ascii-segment.test.js +86 -0
- package/dist/test/ascii/ascii-segment.test.js.map +1 -0
- package/dist/test/ascii/ascii-store-replay.test.d.ts +1 -0
- package/dist/test/ascii/ascii-store-replay.test.js +92 -0
- package/dist/test/ascii/ascii-store-replay.test.js.map +1 -0
- package/dist/test/ascii/ascii-tag-pos.test.d.ts +1 -0
- package/dist/test/ascii/ascii-tag-pos.test.js +105 -0
- package/dist/test/ascii/ascii-tag-pos.test.js.map +1 -0
- package/dist/test/ascii/execution-report.test.d.ts +1 -0
- package/dist/test/ascii/execution-report.test.js +489 -0
- package/dist/test/ascii/execution-report.test.js.map +1 -0
- package/dist/test/ascii/fix-log-replay.test.d.ts +1 -0
- package/dist/test/{memory-store-test.js → ascii/fix-log-replay.test.js} +11 -23
- package/dist/test/ascii/fix-log-replay.test.js.map +1 -0
- package/dist/test/ascii/fix-repo-dict.test.d.ts +1 -0
- package/dist/test/ascii/fix-repo-dict.test.js +128 -0
- package/dist/test/ascii/fix-repo-dict.test.js.map +1 -0
- package/dist/test/ascii/includes.test.d.ts +1 -0
- package/dist/test/ascii/includes.test.js +43 -0
- package/dist/test/ascii/includes.test.js.map +1 -0
- package/dist/test/ascii/logon.test.d.ts +1 -0
- package/dist/test/ascii/logon.test.js +91 -0
- package/dist/test/ascii/logon.test.js.map +1 -0
- package/dist/test/ascii/memory-store.test.d.ts +1 -0
- package/dist/test/ascii/memory-store.test.js +75 -0
- package/dist/test/ascii/memory-store.test.js.map +1 -0
- package/dist/test/ascii/qf-full-msg.test.d.ts +1 -0
- package/dist/test/ascii/qf-full-msg.test.js +81 -0
- package/dist/test/ascii/qf-full-msg.test.js.map +1 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.d.ts +1 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.js +87 -0
- package/dist/test/ascii/repo-full-ascii-msg.test.js.map +1 -0
- package/dist/test/ascii/session-state.test.d.ts +1 -0
- package/dist/test/ascii/session-state.test.js +73 -0
- package/dist/test/ascii/session-state.test.js.map +1 -0
- package/dist/test/ascii/session.test.d.ts +1 -0
- package/dist/test/ascii/session.test.js +280 -0
- package/dist/test/ascii/session.test.js.map +1 -0
- package/dist/test/ascii/time-formatter.test.d.ts +1 -0
- package/dist/test/ascii/time-formatter.test.js +80 -0
- package/dist/test/ascii/time-formatter.test.js.map +1 -0
- package/dist/test/ascii/view-decode.test.d.ts +1 -0
- package/dist/test/ascii/view-decode.test.js +183 -0
- package/dist/test/ascii/view-decode.test.js.map +1 -0
- package/dist/test/ascii-encoder.test.d.ts +1 -0
- package/dist/test/{ascii-encode.test.js → ascii-encoder.test.js} +140 -48
- package/dist/test/ascii-encoder.test.js.map +1 -0
- package/dist/test/ascii-parser.test.d.ts +1 -1
- package/dist/test/ascii-parser.test.js +31 -48
- package/dist/test/ascii-parser.test.js.map +1 -1
- package/dist/test/ascii-segment.test.d.ts +1 -1
- package/dist/test/ascii-segment.test.js +19 -39
- package/dist/test/ascii-segment.test.js.map +1 -1
- package/dist/test/ascii-store-replay.test.d.ts +1 -1
- package/dist/test/ascii-store-replay.test.js +32 -44
- package/dist/test/ascii-store-replay.test.js.map +1 -1
- package/dist/test/ascii-tag-pos.test.d.ts +1 -1
- package/dist/test/ascii-tag-pos.test.js +8 -8
- package/dist/test/ascii-tag-pos.test.js.map +1 -1
- package/dist/test/elastic-buffer.test.d.ts +1 -1
- package/dist/test/elastic-buffer.test.js +3 -1
- package/dist/test/elastic-buffer.test.js.map +1 -1
- package/dist/test/encode-proxy.test.d.ts +1 -1
- package/dist/test/encode-proxy.test.js +9 -9
- package/dist/test/encode-proxy.test.js.map +1 -1
- package/dist/test/env/experiment.d.ts +23 -0
- package/dist/test/env/experiment.js +33 -0
- package/dist/test/env/experiment.js.map +1 -0
- package/dist/test/env/parsing-result.d.ts +10 -0
- package/dist/test/env/parsing-result.js +14 -0
- package/dist/test/env/parsing-result.js.map +1 -0
- package/dist/test/env/setup.d.ts +39 -0
- package/dist/test/env/setup.js +98 -0
- package/dist/test/env/setup.js.map +1 -0
- package/dist/test/env/skeleton-runner.d.ts +15 -0
- package/dist/test/env/skeleton-runner.js +108 -0
- package/dist/test/env/skeleton-runner.js.map +1 -0
- package/dist/test/env/test-recovery.d.ts +13 -0
- package/dist/test/env/test-recovery.js +41 -0
- package/dist/test/env/test-recovery.js.map +1 -0
- package/dist/test/env/to-views.d.ts +11 -0
- package/dist/test/env/to-views.js +56 -0
- package/dist/test/env/to-views.js.map +1 -0
- package/dist/test/execution-report.test.d.ts +1 -1
- package/dist/test/execution-report.test.js +53 -49
- package/dist/test/execution-report.test.js.map +1 -1
- package/dist/test/experiment.d.ts +23 -0
- package/dist/test/experiment.js +33 -0
- package/dist/test/experiment.js.map +1 -0
- package/dist/test/expieriment.d.ts +23 -0
- package/dist/test/expieriment.js +33 -0
- package/dist/test/expieriment.js.map +1 -0
- package/dist/test/fix-log-replay.test.d.ts +1 -1
- package/dist/test/fix-log-replay.test.js +7 -5
- package/dist/test/fix-log-replay.test.js.map +1 -1
- package/dist/test/fix-repo-dict.test.d.ts +1 -1
- package/dist/test/fix-repo-dict.test.js +6 -5
- package/dist/test/fix-repo-dict.test.js.map +1 -1
- package/dist/test/fixml/fixml-alloc-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-alloc-parse.test.js +161 -0
- package/dist/test/fixml/fixml-alloc-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js +61 -0
- package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js +34 -0
- package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js.map +1 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.d.ts +1 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js +97 -0
- package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js.map +1 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.d.ts +1 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.js +143 -0
- package/dist/test/fixml/repo-full-fixml-msg.test.js.map +1 -0
- package/dist/test/fixml-alloc-parse.test.d.ts +1 -1
- package/dist/test/fixml-alloc-parse.test.js +2 -1
- package/dist/test/fixml-alloc-parse.test.js.map +1 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.d.ts +1 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.js +2 -1
- package/dist/test/fixml-mkt-data-fut-parse.test.js.map +1 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.d.ts +1 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.js +2 -1
- package/dist/test/fixml-mkt-data-settle-parse.test.js.map +1 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.d.ts +1 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.js +2 -1
- package/dist/test/fixml-tc-bi-lateral-parse.test.js.map +1 -1
- package/dist/test/includes.test.d.ts +1 -1
- package/dist/test/includes.test.js +1 -0
- package/dist/test/includes.test.js.map +1 -1
- package/dist/test/logon.test.d.ts +1 -1
- package/dist/test/logon.test.js +11 -11
- package/dist/test/logon.test.js.map +1 -1
- package/dist/test/memory-store.test.d.ts +1 -1
- package/dist/test/memory-store.test.js +35 -27
- package/dist/test/memory-store.test.js.map +1 -1
- package/dist/test/qf-full-msg.test.d.ts +1 -1
- package/dist/test/qf-full-msg.test.js +25 -19
- package/dist/test/qf-full-msg.test.js.map +1 -1
- package/dist/test/repo-full-ascii-msg.test.d.ts +1 -1
- package/dist/test/repo-full-ascii-msg.test.js +28 -22
- package/dist/test/repo-full-ascii-msg.test.js.map +1 -1
- package/dist/test/repo-full-fixml-msg.test.d.ts +1 -1
- package/dist/test/repo-full-fixml-msg.test.js +21 -18
- package/dist/test/repo-full-fixml-msg.test.js.map +1 -1
- package/dist/test/session-state.test.d.ts +1 -1
- package/dist/test/session-state.test.js +2 -1
- package/dist/test/session-state.test.js.map +1 -1
- package/dist/test/session.test.d.ts +1 -1
- package/dist/test/session.test.js +152 -163
- package/dist/test/session.test.js.map +1 -1
- package/dist/test/setup.d.ts +45 -0
- package/dist/test/setup.js +102 -0
- package/dist/test/setup.js.map +1 -0
- package/dist/test/skeleton-runner.d.ts +15 -0
- package/dist/test/skeleton-runner.js +108 -0
- package/dist/test/skeleton-runner.js.map +1 -0
- package/dist/test/time-formatter.test.d.ts +1 -1
- package/dist/test/time-formatter.test.js +3 -1
- package/dist/test/time-formatter.test.js.map +1 -1
- package/dist/test/to-views.d.ts +1 -1
- package/dist/test/to-views.js +5 -4
- package/dist/test/to-views.js.map +1 -1
- package/dist/test/view-decode.test.d.ts +1 -1
- package/dist/test/view-decode.test.js +9 -33
- package/dist/test/view-decode.test.js.map +1 -1
- package/dist/time-formatter.test.d.ts +0 -0
- package/dist/time-formatter.test.js +1 -0
- package/dist/time-formatter.test.js.map +1 -0
- package/dist/to-views.d.ts +0 -0
- package/dist/to-views.js +1 -0
- package/dist/to-views.js.map +1 -0
- package/dist/token.txt +246 -308
- package/dist/transport/FixEntity.d.ts +8 -0
- package/dist/transport/FixEntity.js +12 -0
- package/dist/transport/FixEntity.js.map +1 -0
- package/dist/transport/a-session-msg-factory.d.ts +23 -0
- package/dist/transport/a-session-msg-factory.js +58 -0
- package/dist/transport/a-session-msg-factory.js.map +1 -0
- package/dist/transport/ascii/ascii-msg-transmitter.js +50 -12
- package/dist/transport/ascii/ascii-msg-transmitter.js.map +1 -1
- package/dist/transport/ascii/ascii-session-msg-factory.d.ts +16 -0
- package/dist/transport/ascii/ascii-session-msg-factory.js +47 -0
- package/dist/transport/ascii/ascii-session-msg-factory.js.map +1 -0
- package/dist/transport/ascii/ascii-session.d.ts +10 -1
- package/dist/transport/ascii/ascii-session.js +98 -41
- package/dist/transport/ascii/ascii-session.js.map +1 -1
- package/dist/transport/ascii/index.d.ts +1 -1
- package/dist/transport/ascii/index.js +1 -1
- package/dist/transport/ascii/index.js.map +1 -1
- package/dist/transport/duplex/http-duplex.d.ts +1 -1
- package/dist/transport/duplex/http-duplex.js +2 -2
- package/dist/transport/duplex/http-duplex.js.map +1 -1
- package/dist/transport/duplex/tcp-duplex.js +22 -2
- package/dist/transport/duplex/tcp-duplex.js.map +1 -1
- package/dist/transport/factory/index.d.ts +1 -0
- package/dist/{sample/tcp/trade_capture → transport/factory}/index.js +1 -2
- package/dist/transport/factory/index.js.map +1 -0
- package/dist/transport/{msg-transport.d.ts → factory/msg-transport.d.ts} +4 -4
- package/dist/transport/factory/msg-transport.js +61 -0
- package/dist/transport/factory/msg-transport.js.map +1 -0
- package/dist/transport/fix-acceptor.d.ts +2 -2
- package/dist/transport/fix-acceptor.js.map +1 -1
- package/dist/transport/fix-entity.d.ts +8 -0
- package/dist/transport/fix-entity.js +12 -0
- package/dist/transport/fix-entity.js.map +1 -0
- package/dist/transport/fix-initiator.d.ts +2 -2
- package/dist/transport/fix-initiator.js.map +1 -1
- package/dist/transport/fix-msg-factory.d.ts +1 -1
- package/dist/transport/fix-msg-factory.js.map +1 -1
- package/dist/transport/fix-session-state-args.d.ts +8 -0
- package/dist/transport/fix-session-state-args.js +3 -0
- package/dist/transport/fix-session-state-args.js.map +1 -0
- package/dist/transport/fix-session-state.d.ts +8 -38
- package/dist/transport/fix-session-state.js +26 -56
- package/dist/transport/fix-session-state.js.map +1 -1
- package/dist/transport/fix-session.d.ts +9 -2
- package/dist/transport/fix-session.js +115 -59
- package/dist/transport/fix-session.js.map +1 -1
- package/dist/transport/fixml/fixml-msg-transmitter.js +23 -5
- package/dist/transport/fixml/fixml-msg-transmitter.js.map +1 -1
- package/dist/transport/fixml/fixml-session-msg-factory.d.ts +13 -0
- package/dist/transport/fixml/fixml-session-msg-factory.js +68 -0
- package/dist/transport/fixml/fixml-session-msg-factory.js.map +1 -0
- package/dist/transport/fixml/fixml-session.d.ts +1 -1
- package/dist/transport/fixml/fixml-session.js +3 -3
- package/dist/transport/fixml/fixml-session.js.map +1 -1
- package/dist/transport/fixml/index.d.ts +1 -2
- package/dist/transport/fixml/index.js +1 -2
- package/dist/transport/fixml/index.js.map +1 -1
- package/dist/transport/http/html-options.d.ts +8 -0
- package/dist/{hop_no_hops.js → transport/http/html-options.js} +1 -1
- package/dist/transport/http/html-options.js.map +1 -0
- package/dist/transport/http/html-route.d.ts +5 -0
- package/dist/{hop.js → transport/http/html-route.js} +1 -1
- package/dist/transport/http/html-route.js.map +1 -0
- package/dist/transport/http/http-acceptor-listener.d.ts +7 -0
- package/dist/transport/http/http-acceptor-listener.js +68 -0
- package/dist/transport/http/http-acceptor-listener.js.map +1 -0
- package/dist/transport/http/http-acceptor.js +31 -11
- package/dist/transport/http/http-acceptor.js.map +1 -1
- package/dist/transport/http/http-adapter.d.ts +7 -0
- package/dist/{trailer.js → transport/http/http-adapter.js} +1 -1
- package/dist/transport/http/http-adapter.js.map +1 -0
- package/dist/transport/http/http-initiator.d.ts +9 -3
- package/dist/transport/http/http-initiator.js +57 -26
- package/dist/transport/http/http-initiator.js.map +1 -1
- package/dist/transport/http/http-json-sample-adapter.d.ts +2 -1
- package/dist/transport/http/http-json-sample-adapter.js +21 -2
- package/dist/transport/http/http-json-sample-adapter.js.map +1 -1
- package/dist/transport/http/http-transaction.d.ts +1 -1
- package/dist/transport/http/http-transaction.js.map +1 -1
- package/dist/transport/http/http-transport-description.d.ts +8 -0
- package/dist/transport/http/http-transport-description.js +3 -0
- package/dist/transport/http/http-transport-description.js.map +1 -0
- package/dist/transport/http/index.d.ts +1 -0
- package/dist/transport/http/index.js +1 -0
- package/dist/transport/http/index.js.map +1 -1
- package/dist/transport/index.d.ts +11 -10
- package/dist/transport/index.js +11 -10
- package/dist/transport/index.js.map +1 -1
- package/dist/transport/{make-fixl-session.d.ts → make-fix-session.d.ts} +0 -0
- package/dist/transport/make-fix-session.js +3 -0
- package/dist/transport/make-fix-session.js.map +1 -0
- package/dist/transport/msg-application.d.ts +12 -0
- package/dist/transport/msg-application.js +3 -0
- package/dist/transport/msg-application.js.map +1 -0
- package/dist/transport/msg-transmitter.d.ts +5 -5
- package/dist/transport/msg-transmitter.js +2 -3
- package/dist/transport/msg-transmitter.js.map +1 -1
- package/dist/transport/session/a-session-msg-factory.d.ts +23 -0
- package/dist/transport/session/a-session-msg-factory.js +58 -0
- package/dist/transport/session/a-session-msg-factory.js.map +1 -0
- package/dist/transport/session/fix-session-state-args.d.ts +8 -0
- package/dist/transport/session/fix-session-state-args.js +3 -0
- package/dist/transport/session/fix-session-state-args.js.map +1 -0
- package/dist/transport/session/fix-session-state.d.ts +32 -0
- package/dist/transport/session/fix-session-state.js +133 -0
- package/dist/transport/session/fix-session-state.js.map +1 -0
- package/dist/transport/session/fix-session.d.ts +50 -0
- package/dist/transport/session/fix-session.js +291 -0
- package/dist/transport/session/fix-session.js.map +1 -0
- package/dist/transport/session/make-fix-session.d.ts +5 -0
- package/dist/transport/session/make-fix-session.js +3 -0
- package/dist/transport/session/make-fix-session.js.map +1 -0
- package/dist/transport/session/session-description.d.ts +17 -0
- package/dist/transport/session/session-description.js +3 -0
- package/dist/transport/session/session-description.js.map +1 -0
- package/dist/transport/session/session-msg-factory.d.ts +15 -0
- package/dist/transport/session/session-msg-factory.js +3 -0
- package/dist/transport/session/session-msg-factory.js.map +1 -0
- package/dist/transport/session/session-state.d.ts +25 -0
- package/dist/transport/session/session-state.js +30 -0
- package/dist/transport/session/session-state.js.map +1 -0
- package/dist/transport/session-description.d.ts +1 -48
- package/dist/transport/session-description.js.map +1 -1
- package/dist/transport/session-msg-factory.d.ts +7 -20
- package/dist/transport/session-msg-factory.js +0 -150
- package/dist/transport/session-msg-factory.js.map +1 -1
- package/dist/transport/session-state.d.ts +25 -0
- package/dist/transport/session-state.js +30 -0
- package/dist/transport/session-state.js.map +1 -0
- package/dist/transport/tcp/index.d.ts +3 -2
- package/dist/transport/tcp/index.js +3 -2
- package/dist/transport/tcp/index.js.map +1 -1
- package/dist/transport/tcp/recovering-tcp-initiator.d.ts +7 -9
- package/dist/transport/tcp/recovering-tcp-initiator.js +41 -16
- package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -1
- package/dist/transport/tcp/tcp-acceptor-listener.d.ts +7 -0
- package/dist/transport/tcp/tcp-acceptor-listener.js +70 -0
- package/dist/transport/tcp/tcp-acceptor-listener.js.map +1 -0
- package/dist/transport/tcp/tcp-acceptor.d.ts +7 -0
- package/dist/transport/tcp/tcp-acceptor.js +79 -43
- package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
- package/dist/transport/tcp/tcp-initiator-connector.d.ts +10 -0
- package/dist/transport/tcp/tcp-initiator-connector.js +97 -0
- package/dist/transport/tcp/tcp-initiator-connector.js.map +1 -0
- package/dist/transport/tcp/tcp-initiator.d.ts +4 -2
- package/dist/transport/tcp/tcp-initiator.js +82 -36
- package/dist/transport/tcp/tcp-initiator.js.map +1 -1
- package/dist/transport/tcp/tcp-transport-description.d.ts +6 -0
- package/dist/transport/tcp/tcp-transport-description.js +3 -0
- package/dist/transport/tcp/tcp-transport-description.js.map +1 -0
- package/dist/transport/tcp/tls-options-factory.d.ts +9 -0
- package/dist/transport/tcp/tls-options-factory.js +53 -0
- package/dist/transport/tcp/tls-options-factory.js.map +1 -0
- package/dist/transport/tcp/tls-options.d.ts +10 -5
- package/dist/transport/tcp/tls-options.js +0 -49
- package/dist/transport/tcp/tls-options.js.map +1 -1
- package/dist/transport/tick-action.d.ts +8 -0
- package/dist/transport/tick-action.js +13 -0
- package/dist/transport/tick-action.js.map +1 -0
- package/dist/types/FIX4.4/repo/enum/all-enum.js.map +1 -1
- package/dist/util/buffer-helper.js +1 -1
- package/dist/util/buffer-helper.js.map +1 -1
- package/dist/util/definition-factory.d.ts +10 -0
- package/dist/util/definition-factory.js +56 -0
- package/dist/util/definition-factory.js.map +1 -0
- package/dist/util/dictionary-path.d.ts +4 -0
- package/dist/util/dictionary-path.js +3 -0
- package/dist/util/dictionary-path.js.map +1 -0
- package/dist/util/index.d.ts +1 -1
- package/dist/util/index.js +1 -1
- package/dist/util/index.js.map +1 -1
- package/dist/util/json-helper.d.ts +3 -1
- package/dist/util/json-helper.js +13 -12
- package/dist/util/json-helper.js.map +1 -1
- package/dist/util/message-generator.d.ts +1 -1
- package/dist/util/message-generator.js +16 -15
- package/dist/util/message-generator.js.map +1 -1
- package/dist/util/replay.d.ts +6 -3
- package/dist/util/replay.js +24 -26
- package/dist/util/replay.js.map +1 -1
- package/package.json +27 -20
- package/script/build.cmd +1 -0
- package/script/build.sh +2 -0
- package/script/genkey.ps1 +179 -179
- package/script/test.cmd +3 -0
- package/src/buffer/{ascii-chars.ts → ascii/ascii-chars.ts} +0 -0
- package/src/buffer/ascii/ascii-encoder.ts +80 -38
- package/src/buffer/ascii/ascii-parser-state.ts +7 -12
- package/src/buffer/ascii/ascii-parser.ts +23 -16
- package/src/buffer/ascii/ascii-segment-parser.ts +14 -8
- package/src/buffer/ascii/ascii-view.ts +4 -9
- package/src/buffer/ascii/index.ts +1 -0
- package/src/buffer/ascii/parse-state.ts +8 -0
- package/src/buffer/ascii/time-formatter.ts +3 -3
- package/src/buffer/elastic-buffer.ts +7 -2
- package/src/buffer/encode-proxy.ts +10 -5
- package/src/buffer/fixml/fixml-encoder.ts +15 -11
- package/src/buffer/fixml/fixml-parser.ts +16 -6
- package/src/buffer/fixml/fixml-view.ts +4 -4
- package/src/buffer/fixml/populated-attributes.ts +6 -0
- package/src/buffer/index.ts +4 -8
- package/src/buffer/msg-encoder.ts +2 -1
- package/src/buffer/msg-view.ts +13 -6
- package/src/buffer/{segment-description.ts → segment/segment-description.ts} +4 -11
- package/src/buffer/{segment-summary.ts → segment/segment-summary.ts} +0 -0
- package/src/buffer/segment/segment-type.ts +8 -0
- package/src/buffer/structure.ts +3 -3
- package/src/buffer/{tag-pos.ts → tag/tag-pos.ts} +0 -0
- package/src/buffer/tag/tag-type.ts +13 -0
- package/src/buffer/{tags.ts → tag/tags.ts} +4 -16
- package/src/config/get-js-fx-logger.ts +4 -0
- package/src/config/index.ts +1 -0
- package/src/config/js-fix-config.ts +5 -2
- package/src/config/js-fix-logger.ts +0 -3
- package/src/dictionary/compiler/compiler-type.ts +3 -3
- package/src/dictionary/compiler/enum-compiler.ts +12 -1
- package/src/dictionary/compiler/msg-compiler.ts +8 -7
- package/src/dictionary/contained/contained-component-field.ts +2 -1
- package/src/dictionary/contained/contained-field-dispatch.ts +3 -7
- package/src/dictionary/contained/contained-field-dispatcher.ts +9 -0
- package/src/dictionary/contained/contained-field-set.ts +5 -3
- package/src/dictionary/contained/contained-field-type.ts +5 -0
- package/src/dictionary/contained/contained-field.ts +1 -6
- package/src/dictionary/contained/contained-group-field.ts +2 -1
- package/src/dictionary/contained/contained-simple-field.ts +2 -1
- package/src/dictionary/contained/field-dispatcher.ts +9 -0
- package/src/dictionary/contained/fields-dispatch.ts +46 -0
- package/src/dictionary/contained/index.ts +2 -0
- package/src/dictionary/contained-set-type.ts +5 -0
- package/src/dictionary/definition/component-field-definition.ts +1 -1
- package/src/dictionary/definition/fix-definitions.ts +2 -1
- package/src/dictionary/definition/group-field-definition.ts +1 -1
- package/src/dictionary/definition/index.ts +0 -1
- package/src/dictionary/definition/message-definition.ts +1 -1
- package/src/dictionary/definition/simple-field-definition.ts +3 -1
- package/src/dictionary/dict-primitive.ts +0 -13
- package/src/dictionary/fix-definition-source.ts +6 -0
- package/src/dictionary/fix-versions.ts +0 -32
- package/src/dictionary/index.ts +1 -5
- package/src/dictionary/parser/fix-repository/abbreviations-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/base-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/components-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/data-types-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/enums-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/fields-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/messages-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/msg-contents-parser.ts +2 -3
- package/src/dictionary/parser/fix-repository/repository-abbreviation.ts +6 -0
- package/src/dictionary/parser/fix-repository/repository-component.ts +11 -0
- package/src/dictionary/parser/fix-repository/repository-data-type.ts +7 -0
- package/src/dictionary/parser/fix-repository/repository-enum.ts +8 -0
- package/src/dictionary/parser/fix-repository/repository-field.ts +12 -0
- package/src/dictionary/parser/fix-repository/repository-message.ts +12 -0
- package/src/dictionary/parser/fix-repository/repository-msg-content.ts +10 -0
- package/src/dictionary/parser/fix-repository/repository-type.ts +0 -59
- package/src/dictionary/parser/fix-repository/repository-xml-parser.ts +10 -9
- package/src/dictionary/parser/fix-repository/repository.ts +69 -38
- package/src/dictionary/parser/fixml/components-parser.ts +6 -3
- package/src/dictionary/parser/fixml/fields-parser.ts +1 -1
- package/src/dictionary/parser/fixml/fix-xsd-parser.ts +2 -1
- package/src/dictionary/parser/fixml/include-graph.ts +2 -1
- package/src/dictionary/parser/fixml/xsd-parser.ts +2 -1
- package/src/dictionary/parser/quickfix/field-definition-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/field-set-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/message-parser.ts +4 -5
- package/src/dictionary/parser/quickfix/node-parser.ts +3 -6
- package/src/dictionary/parser/quickfix/parse-state.ts +8 -0
- package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +9 -15
- package/src/dictionary/sax-node.ts +7 -0
- package/src/dictionary/set-reduce.ts +30 -31
- package/src/dictionary/type-dispatcher.ts +7 -0
- package/src/dictionary/version-util.ts +25 -0
- package/src/index.ts +1 -0
- package/src/jsfix-cmd.ts +31 -16
- package/src/runtime/di-tokens.ts +48 -0
- package/src/runtime/engine-factory.ts +5 -0
- package/src/runtime/index.ts +5 -0
- package/src/runtime/make-config.ts +35 -0
- package/src/runtime/session-container.ts +180 -0
- package/src/runtime/session-launcher.ts +127 -0
- package/src/sample/http/oms/app.ts +20 -12
- package/src/sample/http/oms/http-client.ts +5 -2
- package/src/sample/http/oms/http-server.ts +5 -1
- package/src/sample/tcp/qf-md/app.ts +12 -12
- package/src/sample/tcp/qf-md/md-client.ts +4 -1
- package/src/sample/tcp/qf-md/md-server.ts +3 -1
- package/src/sample/tcp/recovering-skeleton/app.ts +37 -15
- package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +16 -9
- package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +4 -2
- package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +4 -2
- package/src/sample/tcp/skeleton/app.ts +10 -15
- package/src/sample/tcp/skeleton/skeleton-session.ts +29 -3
- package/src/sample/tcp/tls-trade-capture/app.ts +8 -31
- package/src/sample/tcp/trade-capture/app-launcher.ts +22 -0
- package/src/sample/tcp/trade-capture/app.ts +3 -26
- package/src/sample/tcp/trade-capture/trade-capture-client.ts +10 -4
- package/src/sample/tcp/trade-capture/trade-capture-server.ts +2 -1
- package/src/sample/tcp/trade-capture/trade-factory.ts +7 -1
- package/src/store/fix-msg-ascii-store-resend.ts +38 -26
- package/src/store/fix-msg-memory-store.ts +105 -42
- package/src/store/fix-msg-store-record.ts +11 -0
- package/src/store/fix-msg-store-state.ts +6 -0
- package/src/store/fix-msg-store.ts +8 -13
- package/src/transport/ascii/ascii-msg-transmitter.ts +23 -13
- package/src/transport/ascii/ascii-session-msg-factory.ts +62 -0
- package/src/transport/ascii/ascii-session.ts +102 -34
- package/src/transport/ascii/index.ts +1 -1
- package/src/transport/duplex/http-duplex.ts +3 -3
- package/src/transport/duplex/tcp-duplex.ts +4 -1
- package/src/transport/factory/index.ts +1 -0
- package/src/transport/factory/msg-transport.ts +55 -0
- package/src/transport/fix-acceptor.ts +2 -2
- package/src/transport/fix-entity.ts +9 -0
- package/src/transport/fix-initiator.ts +2 -2
- package/src/transport/fixml/fixml-msg-transmitter.ts +8 -4
- package/src/transport/fixml/fixml-session-msg-factory.ts +76 -0
- package/src/transport/fixml/fixml-session.ts +2 -2
- package/src/transport/fixml/index.ts +1 -2
- package/src/transport/http/html-options.ts +8 -0
- package/src/transport/http/html-route.ts +6 -0
- package/src/transport/http/http-acceptor-listener.ts +42 -0
- package/src/transport/http/http-acceptor.ts +12 -8
- package/src/transport/http/http-adapter.ts +7 -0
- package/src/transport/http/http-initiator.ts +40 -25
- package/src/transport/http/http-json-sample-adapter.ts +7 -2
- package/src/transport/http/http-transaction.ts +1 -1
- package/src/transport/http/http-transport-description.ts +9 -0
- package/src/transport/http/index.ts +1 -0
- package/src/transport/index.ts +11 -10
- package/src/transport/msg-application.ts +13 -0
- package/src/transport/msg-transmitter.ts +5 -5
- package/src/transport/session/a-session-msg-factory.ts +81 -0
- package/src/transport/session/fix-session-state-args.ts +9 -0
- package/src/transport/{fix-session-state.ts → session/fix-session-state.ts} +23 -43
- package/src/transport/{fix-session.ts → session/fix-session.ts} +111 -46
- package/src/transport/{make-fixl-session.ts → session/make-fix-session.ts} +1 -1
- package/src/transport/session/session-description.ts +18 -0
- package/src/transport/{fix-msg-factory.ts → session/session-msg-factory.ts} +2 -2
- package/src/transport/session/session-state.ts +25 -0
- package/src/transport/tcp/index.ts +3 -2
- package/src/transport/tcp/recovering-tcp-initiator.ts +24 -13
- package/src/transport/tcp/tcp-acceptor-listener.ts +45 -0
- package/src/transport/tcp/tcp-acceptor.ts +65 -40
- package/src/transport/tcp/tcp-initiator-connector.ts +71 -0
- package/src/transport/tcp/tcp-initiator.ts +71 -42
- package/src/transport/tcp/tcp-transport-description.ts +7 -0
- package/src/transport/tcp/tls-options-factory.ts +55 -0
- package/src/transport/tcp/tls-options.ts +9 -51
- package/src/transport/tick-action.ts +8 -0
- package/src/types/FIX4.4/repo/enum/all-enum.ts +0 -1
- package/src/util/definition-factory.ts +47 -0
- package/src/util/dictionary-path.ts +4 -0
- package/src/util/index.ts +1 -1
- package/src/util/json-helper.ts +14 -4
- package/src/util/message-generator.ts +6 -3
- package/src/util/replay.ts +26 -21
- package/tsconfig.json +2 -0
- package/dist/buffer/ascii-chars.js.map +0 -1
- package/dist/dictionary/fields-dispatch.js +0 -40
- package/dist/dictionary/fields-dispatch.js.map +0 -1
- package/dist/header.d.ts +0 -31
- package/dist/header.js.map +0 -1
- package/dist/hop.d.ts +0 -4
- package/dist/hop.js.map +0 -1
- package/dist/hop_no_hops.d.ts +0 -5
- package/dist/hop_no_hops.js.map +0 -1
- package/dist/sample/http/oms/jsfix.test_http-client.txt +0 -170
- package/dist/sample/http/oms/jsfix.test_http-server.txt +0 -170
- package/dist/sample/tcp/qf-md/jsfix.test_client.txt +0 -18
- package/dist/sample/tcp/qf-md/jsfix.test_server.txt +0 -17
- package/dist/sample/tcp/recovering-skeleton/jsfix.test_client.txt +0 -96
- package/dist/sample/tcp/recovering-skeleton/jsfix.test_server.txt +0 -93
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.d.ts +0 -17
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.js +0 -70
- package/dist/sample/tcp/recovering-skeleton/skeleton-session.js.map +0 -1
- package/dist/sample/tcp/skeleton/jsfix.test_client.txt +0 -6
- package/dist/sample/tcp/skeleton/jsfix.test_server.txt +0 -6
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_client.txt +0 -1871
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_server.txt +0 -3059
- package/dist/sample/tcp/trade_capture/app.d.ts +0 -1
- package/dist/sample/tcp/trade_capture/app.js +0 -24
- package/dist/sample/tcp/trade_capture/app.js.map +0 -1
- package/dist/sample/tcp/trade_capture/index.d.ts +0 -2
- package/dist/sample/tcp/trade_capture/index.js.map +0 -1
- package/dist/sample/tcp/trade_capture/jsfix.test_client.txt +0 -193
- package/dist/sample/tcp/trade_capture/jsfix.test_server.txt +0 -193
- package/dist/sample/tcp/trade_capture/trade-capture-client.d.ts +0 -16
- package/dist/sample/tcp/trade_capture/trade-capture-client.js +0 -57
- package/dist/sample/tcp/trade_capture/trade-capture-client.js.map +0 -1
- package/dist/sample/tcp/trade_capture/trade-capture-server.d.ts +0 -18
- package/dist/sample/tcp/trade_capture/trade-capture-server.js +0 -72
- package/dist/sample/tcp/trade_capture/trade-capture-server.js.map +0 -1
- package/dist/sample/tcp/trade_capture/trade-factory.d.ts +0 -11
- package/dist/sample/tcp/trade_capture/trade-factory.js +0 -81
- package/dist/sample/tcp/trade_capture/trade-factory.js.map +0 -1
- package/dist/standard_header.d.ts +0 -31
- package/dist/standard_header.js.map +0 -1
- package/dist/standard_trailer.d.ts +0 -6
- package/dist/standard_trailer.js +0 -3
- package/dist/standard_trailer.js.map +0 -1
- package/dist/store/fix-msg-ascii-store-recovery.d.ts +0 -12
- package/dist/store/fix-msg-ascii-store-recovery.js +0 -60
- package/dist/store/fix-msg-ascii-store-recovery.js.map +0 -1
- package/dist/store/fix-resend-record.d.ts +0 -12
- package/dist/store/fix-resend-record.js +0 -12
- package/dist/store/fix-resend-record.js.map +0 -1
- package/dist/test/ascii-encode.test.d.ts +0 -1
- package/dist/test/ascii-encode.test.js.map +0 -1
- package/dist/test/ascii-store-recovery.test.d.ts +0 -1
- package/dist/test/ascii-store-recovery.test.js +0 -50
- package/dist/test/ascii-store-recovery.test.js.map +0 -1
- package/dist/test/memory-store-test.d.ts +0 -1
- package/dist/test/memory-store-test.js.map +0 -1
- package/dist/trailer.d.ts +0 -6
- package/dist/trailer.js.map +0 -1
- package/dist/transport/fixml/acceptor.d.ts +0 -3
- package/dist/transport/fixml/acceptor.js +0 -38
- package/dist/transport/fixml/acceptor.js.map +0 -1
- package/dist/transport/make-config.d.ts +0 -4
- package/dist/transport/make-config.js +0 -31
- package/dist/transport/make-config.js.map +0 -1
- package/dist/transport/make-fixl-session.js +0 -3
- package/dist/transport/make-fixl-session.js.map +0 -1
- package/dist/transport/msg-store.d.ts +0 -2
- package/dist/transport/msg-store.js +0 -3
- package/dist/transport/msg-store.js.map +0 -1
- package/dist/transport/msg-transport.js +0 -57
- package/dist/transport/msg-transport.js.map +0 -1
- package/dist/transport/tcp/acceptor.d.ts +0 -3
- package/dist/transport/tcp/acceptor.js +0 -40
- package/dist/transport/tcp/acceptor.js.map +0 -1
- package/dist/transport/tcp/initiator.d.ts +0 -3
- package/dist/transport/tcp/initiator.js +0 -67
- package/dist/transport/tcp/initiator.js.map +0 -1
- package/dist/transport/tcp/recovering-initiator.d.ts +0 -17
- package/dist/transport/tcp/recovering-initiator.js +0 -30
- package/dist/transport/tcp/recovering-initiator.js.map +0 -1
- package/dist/transport/tcp/recovering_initiator.d.ts +0 -12
- package/dist/transport/tcp/recovering_initiator.js +0 -25
- package/dist/transport/tcp/recovering_initiator.js.map +0 -1
- package/dist/types/FIX4.4/quickfix/set/header.d.ts +0 -31
- package/dist/types/FIX4.4/quickfix/set/header.js +0 -3
- package/dist/types/FIX4.4/quickfix/set/header.js.map +0 -1
- package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +0 -6
- package/dist/types/FIX4.4/quickfix/set/trailer.js +0 -3
- package/dist/types/FIX4.4/quickfix/set/trailer.js.map +0 -1
- package/dist/util/dictionary-definitions.d.ts +0 -8
- package/dist/util/dictionary-definitions.js +0 -51
- package/dist/util/dictionary-definitions.js.map +0 -1
- package/src/dictionary/fields-dispatch.ts +0 -45
- package/src/sample/launcher.ts +0 -46
- package/src/transport/fixml/acceptor.ts +0 -29
- package/src/transport/make-config.ts +0 -19
- package/src/transport/msg-transport.ts +0 -67
- package/src/transport/session-description.ts +0 -70
- package/src/transport/session-msg-factory.ts +0 -195
- package/src/transport/tcp/acceptor.ts +0 -31
- package/src/transport/tcp/initiator.ts +0 -59
- package/src/util/dictionary-definitions.ts +0 -41
|
@@ -3,20 +3,15 @@
|
|
|
3
3
|
*/
|
|
4
4
|
|
|
5
5
|
import { IFixMsgStoreRecord } from './fix-msg-store-record'
|
|
6
|
+
import { IFixMsgStoreState } from './fix-msg-store-state'
|
|
6
7
|
|
|
7
8
|
export interface IFixMsgStore {
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
*/
|
|
14
|
-
setExcMsgType (exclude: string[]): void
|
|
15
|
-
put (record: IFixMsgStoreRecord): boolean
|
|
16
|
-
exits (seqNum: number): boolean
|
|
17
|
-
getSeqNum (seqNum: number): IFixMsgStoreRecord
|
|
9
|
+
clear (): Promise<IFixMsgStoreState>
|
|
10
|
+
getState (): Promise<IFixMsgStoreState>
|
|
11
|
+
put (record: IFixMsgStoreRecord): Promise<IFixMsgStoreState>
|
|
12
|
+
get (seq: number): Promise<IFixMsgStoreRecord>
|
|
13
|
+
exists (seq: number): Promise<boolean>
|
|
18
14
|
// if to = 0, then to the end of sequence
|
|
19
|
-
getSeqNumRange (from: number, to?: number): IFixMsgStoreRecord[]
|
|
20
|
-
|
|
21
|
-
getMsgType (msgType: string): IFixMsgStoreRecord[]
|
|
15
|
+
getSeqNumRange (from: number, to?: number): Promise<IFixMsgStoreRecord[]>
|
|
16
|
+
getMsgType (msgType: string): Promise<IFixMsgStoreRecord[]>
|
|
22
17
|
}
|
|
@@ -1,10 +1,15 @@
|
|
|
1
|
-
import { AsciiChars, AsciiEncoder, TimeFormatter } from '../../buffer'
|
|
1
|
+
import { AsciiChars, AsciiEncoder, TimeFormatter } from '../../buffer/ascii'
|
|
2
2
|
import { MsgTransmitter } from '../msg-transmitter'
|
|
3
3
|
import { ILooseObject } from '../../collections/collection'
|
|
4
|
-
import { ContainedFieldSet
|
|
4
|
+
import { ContainedFieldSet } from '../../dictionary/contained'
|
|
5
|
+
import { MessageDefinition } from '../../dictionary/definition'
|
|
5
6
|
import { IJsFixConfig } from '../../config'
|
|
6
7
|
import { IStandardHeader } from '../../types/FIX4.4/repo'
|
|
8
|
+
import { inject, injectable } from 'tsyringe'
|
|
9
|
+
import { DITokens } from '../../runtime/di-tokens'
|
|
10
|
+
import { ElasticBuffer } from '../../buffer'
|
|
7
11
|
|
|
12
|
+
@injectable()
|
|
8
13
|
export class AsciiMsgTransmitter extends MsgTransmitter {
|
|
9
14
|
public msgSeqNum: number
|
|
10
15
|
public time: Date
|
|
@@ -12,17 +17,17 @@ export class AsciiMsgTransmitter extends MsgTransmitter {
|
|
|
12
17
|
private readonly header: ContainedFieldSet
|
|
13
18
|
private readonly trailer: ContainedFieldSet
|
|
14
19
|
|
|
15
|
-
constructor (public readonly config: IJsFixConfig) {
|
|
16
|
-
|
|
17
|
-
super(config.definitions, config.description)
|
|
20
|
+
constructor (@inject(DITokens.IJsFixConfig) public readonly config: IJsFixConfig) {
|
|
21
|
+
super(config.sessionContainer.resolve<ElasticBuffer>(DITokens.TransmitBuffer), config.definitions, config.description)
|
|
18
22
|
this.msgSeqNum = (config.description.LastSentSeqNum || 0) + 1 // adding 1 as this the next sequence # to use.
|
|
19
23
|
const buffer = this.buffer
|
|
20
24
|
const tf: TimeFormatter = new TimeFormatter(buffer)
|
|
21
25
|
this.encoder = new AsciiEncoder(buffer, config.definitions, tf,
|
|
22
26
|
config.delimiter || AsciiChars.Soh,
|
|
23
27
|
config.logDelimiter || AsciiChars.Pipe)
|
|
24
|
-
|
|
25
|
-
this.
|
|
28
|
+
const components = config.definitions.component
|
|
29
|
+
this.header = components.get('StandardHeader')
|
|
30
|
+
this.trailer = components.get('StandardTrailer')
|
|
26
31
|
}
|
|
27
32
|
|
|
28
33
|
private checksum (): number {
|
|
@@ -41,12 +46,16 @@ export class AsciiMsgTransmitter extends MsgTransmitter {
|
|
|
41
46
|
public encodeMessage (msgType: string, obj: ILooseObject): void {
|
|
42
47
|
const encoder: AsciiEncoder = this.encoder as AsciiEncoder
|
|
43
48
|
const factory = this.config.factory
|
|
44
|
-
|
|
45
|
-
const
|
|
46
|
-
|
|
47
|
-
|
|
49
|
+
let headerProps: Partial<IStandardHeader> = {}
|
|
50
|
+
const { StandardHeader, ...bodyProps } = obj
|
|
51
|
+
if (StandardHeader) {
|
|
52
|
+
const { BeginString, BodyLength, MsgType, SenderCompID, SendingTime, TargetCompID, TargetSubID, ...hp } = StandardHeader
|
|
53
|
+
headerProps = hp // pick up any optional applied by application
|
|
54
|
+
headerProps.OrigSendingTime = SendingTime // when first sent
|
|
48
55
|
}
|
|
49
|
-
|
|
56
|
+
|
|
57
|
+
const sendingTime = this.time || new Date()
|
|
58
|
+
const hdr: ILooseObject = factory.header(msgType, this.msgSeqNum, sendingTime, headerProps)
|
|
50
59
|
|
|
51
60
|
// Only increment sequence number if this is not a duplicate message.
|
|
52
61
|
if (!headerProps.PossDupFlag) {
|
|
@@ -57,10 +66,11 @@ export class AsciiMsgTransmitter extends MsgTransmitter {
|
|
|
57
66
|
buffer.reset()
|
|
58
67
|
const msgDef: MessageDefinition = this.definitions.message.get(msgType)
|
|
59
68
|
if (!msgDef) {
|
|
69
|
+
this.emit('error', new Error(`ascii transmitter cannot find definition for ${msgType}`))
|
|
60
70
|
return
|
|
61
71
|
}
|
|
62
72
|
encoder.encode(hdr, this.header.name)
|
|
63
|
-
encoder.encode(
|
|
73
|
+
encoder.encode(bodyProps, msgDef.name)
|
|
64
74
|
const lenPos = encoder.bodyLengthPos
|
|
65
75
|
const bodyLength: number = Math.max(4, this.config.description.BodyLengthChars || 7)
|
|
66
76
|
const len = buffer.getPos() - encoder.msgTypePos
|
|
@@ -0,0 +1,62 @@
|
|
|
1
|
+
import { ISessionDescription } from '../session/session-description'
|
|
2
|
+
import { ILooseObject } from '../../collections/collection'
|
|
3
|
+
import { MsgType } from '../../types'
|
|
4
|
+
import { ASessionMsgFactory, ObjectMutator } from '../session/a-session-msg-factory'
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
EncryptMethod,
|
|
8
|
+
ILogon,
|
|
9
|
+
ILogout,
|
|
10
|
+
IStandardHeader
|
|
11
|
+
} from '../../types/FIX4.4/repo'
|
|
12
|
+
|
|
13
|
+
export class AsciiSessionMsgFactory extends ASessionMsgFactory {
|
|
14
|
+
|
|
15
|
+
constructor (readonly description: ISessionDescription, mutator: ObjectMutator = null) {
|
|
16
|
+
super(description, mutator)
|
|
17
|
+
this.isAscii = description.application.protocol === 'ascii'
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public logon (): ILooseObject {
|
|
21
|
+
const description = this.description
|
|
22
|
+
const o: ILogon = {
|
|
23
|
+
Username: description.Username,
|
|
24
|
+
Password: description.Password,
|
|
25
|
+
HeartBtInt: description.HeartBtInt,
|
|
26
|
+
ResetSeqNumFlag: description.ResetSeqNumFlag,
|
|
27
|
+
EncryptMethod: EncryptMethod.None
|
|
28
|
+
} as ILogon
|
|
29
|
+
return this.mutate(o, MsgType.Logon)
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
public logout (text: string): ILooseObject {
|
|
33
|
+
const o: ILogout = {
|
|
34
|
+
Text: text
|
|
35
|
+
} as ILogout
|
|
36
|
+
return this.mutate(o, MsgType.Logout)
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
public header (msgType: string, seqNum: number, time: Date, overrideData?: Partial<IStandardHeader>): ILooseObject {
|
|
40
|
+
const description = this.description
|
|
41
|
+
const bodyLength: number = Math.max(4, description.BodyLengthChars || 7)
|
|
42
|
+
const placeHolder = Math.pow(10, bodyLength - 1) + 1
|
|
43
|
+
const o: IStandardHeader = {
|
|
44
|
+
BeginString: description.BeginString,
|
|
45
|
+
BodyLength: placeHolder,
|
|
46
|
+
MsgType: msgType,
|
|
47
|
+
SenderCompID: description.SenderCompId,
|
|
48
|
+
MsgSeqNum: seqNum,
|
|
49
|
+
SendingTime: time,
|
|
50
|
+
TargetCompID: description.TargetCompID,
|
|
51
|
+
TargetSubID: description.TargetSubID,
|
|
52
|
+
...overrideData
|
|
53
|
+
}
|
|
54
|
+
return this.mutate(o, 'StandardHeader')
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
export class SessionMsgFactory extends AsciiSessionMsgFactory {
|
|
59
|
+
constructor (public readonly description: ISessionDescription, public mutator: ObjectMutator = null) {
|
|
60
|
+
super(description, mutator)
|
|
61
|
+
}
|
|
62
|
+
}
|
|
@@ -1,18 +1,25 @@
|
|
|
1
|
-
import { MsgView
|
|
1
|
+
import { MsgView } from '../../buffer'
|
|
2
2
|
import { MsgTag, MsgType, SessionRejectReason } from '../../types'
|
|
3
3
|
import { IJsFixConfig } from '../../config'
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
4
|
+
import { FixSession } from '../session/fix-session'
|
|
5
|
+
import { FixMsgAsciiStoreResend, FixMsgMemoryStore, IFixMsgStore, IFixMsgStoreRecord } from '../../store'
|
|
6
|
+
import { SessionState } from '../tcp'
|
|
7
|
+
import { TickAction } from '../tick-action'
|
|
8
|
+
import { IMsgApplication } from '../msg-application'
|
|
9
|
+
import { SegmentType } from '../../buffer/segment/segment-type'
|
|
7
10
|
|
|
8
11
|
export abstract class AsciiSession extends FixSession {
|
|
9
12
|
|
|
10
13
|
public heartbeat: boolean = true
|
|
14
|
+
protected store: IFixMsgStore = null
|
|
15
|
+
protected resender: FixMsgAsciiStoreResend
|
|
11
16
|
|
|
12
17
|
protected constructor (public readonly config: IJsFixConfig) {
|
|
13
18
|
super(config)
|
|
14
19
|
this.requestLogoutType = this.respondLogoutType = MsgType.Logout
|
|
15
20
|
this.requestLogonType = MsgType.Logon
|
|
21
|
+
this.store = new FixMsgMemoryStore(this.config.description.SenderCompId, this.config)
|
|
22
|
+
this.resender = new FixMsgAsciiStoreResend(this.store, this.config)
|
|
16
23
|
}
|
|
17
24
|
|
|
18
25
|
private checkSeqNo (msgType: string, view: MsgView): boolean {
|
|
@@ -33,14 +40,18 @@ export abstract class AsciiSession extends FixSession {
|
|
|
33
40
|
this.sessionLogger.warning(`terminate as seqDelta (${seqDelta}) < 0 lastSeq = ${lastSeq} seqNo = ${seqNo}`)
|
|
34
41
|
this.stop()
|
|
35
42
|
} else if (seqDelta > 1) {
|
|
36
|
-
//
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
+
// resend request required as have missed messages.
|
|
44
|
+
|
|
45
|
+
// We process a Logon beforehand to confirm the connection even we out of sync
|
|
46
|
+
if (msgType === MsgType.Logon) {
|
|
47
|
+
this.peerLogon(view)
|
|
48
|
+
}
|
|
49
|
+
// If the out of sync message is a resend request itself, then we handle it first in order
|
|
50
|
+
// to avoid triggering an endless loop of both sides sending resend requests in response to resend requests.
|
|
51
|
+
if (msgType === MsgType.ResendRequest) {
|
|
52
|
+
this.onResendRequest(view)
|
|
43
53
|
}
|
|
54
|
+
this.sendResendRequest(lastSeq, seqNo)
|
|
44
55
|
} else {
|
|
45
56
|
ret = true
|
|
46
57
|
state.lastPeerMsgSeqNum = seqNo
|
|
@@ -50,6 +61,17 @@ export abstract class AsciiSession extends FixSession {
|
|
|
50
61
|
}
|
|
51
62
|
}
|
|
52
63
|
|
|
64
|
+
protected checkForwardMsg (msgType: string, view: MsgView): void {
|
|
65
|
+
const okToForward = this.validStateApplicationMsg()
|
|
66
|
+
if (okToForward) {
|
|
67
|
+
this.sessionLogger.info(`ascii forwarding msgType = '${msgType}' to application`)
|
|
68
|
+
this.setState(SessionState.ActiveNormalSession)
|
|
69
|
+
this.onApplicationMsg(msgType, view)
|
|
70
|
+
} else {
|
|
71
|
+
this.terminate(new Error(`msgType ${msgType} received in state ${this.stateString()}`))
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
|
|
53
75
|
private sendReject (msgType: string, seqNo: number, msg: string, reason: number): void {
|
|
54
76
|
const factory = this.config.factory
|
|
55
77
|
const reject = factory.reject(msgType, seqNo, msg, reason)
|
|
@@ -57,6 +79,12 @@ export abstract class AsciiSession extends FixSession {
|
|
|
57
79
|
this.send(MsgType.Reject, reject)
|
|
58
80
|
}
|
|
59
81
|
|
|
82
|
+
protected sendResendRequest (lastSeq: number, receivedSeq: number) {
|
|
83
|
+
const resend = this.config.factory.resendRequest(lastSeq + 1, 0)
|
|
84
|
+
this.sessionLogger.warning(`received seq ${receivedSeq}, but last known seq is ${lastSeq}. Sending resend request for all messages > ${lastSeq}`)
|
|
85
|
+
this.send(MsgType.ResendRequest, resend)
|
|
86
|
+
}
|
|
87
|
+
|
|
60
88
|
private checkIntegrity (msgType: string, view: MsgView): boolean {
|
|
61
89
|
const state = this.sessionState
|
|
62
90
|
const seqNum = view.getTyped(MsgTag.MsgSeqNum)
|
|
@@ -101,14 +129,14 @@ export abstract class AsciiSession extends FixSession {
|
|
|
101
129
|
case SessionState.InitiationLogonResponse: {
|
|
102
130
|
const targetCompId = view.getString(MsgTag.TargetCompID)
|
|
103
131
|
if (targetCompId !== state.compId) {
|
|
104
|
-
const msg: string = `msgType ${msgType} unexpected TargetCompID ${targetCompId}`
|
|
132
|
+
const msg: string = `msgType ${msgType} unexpected TargetCompID ${targetCompId} expecting ${state.compId})`
|
|
105
133
|
this.sendReject(msgType, seqNum, msg, SessionRejectReason.CompIDProblem)
|
|
106
134
|
return false
|
|
107
135
|
}
|
|
108
136
|
|
|
109
137
|
const peerCompId = view.getString(MsgTag.SenderCompID)
|
|
110
138
|
if (peerCompId !== state.peerCompId) {
|
|
111
|
-
const msg: string = `msgType ${msgType} unexpected SenderCompID ${peerCompId}`
|
|
139
|
+
const msg: string = `msgType ${msgType} unexpected SenderCompID ${peerCompId} expecting ${state.compId}`
|
|
112
140
|
this.sendReject(msgType, seqNum, msg, SessionRejectReason.CompIDProblem)
|
|
113
141
|
return false
|
|
114
142
|
}
|
|
@@ -127,21 +155,44 @@ export abstract class AsciiSession extends FixSession {
|
|
|
127
155
|
* Override to resend stored messages following a sequence reset.
|
|
128
156
|
* @protected
|
|
129
157
|
*/
|
|
130
|
-
// tslint:disable-next-line:no-empty
|
|
131
158
|
protected onResendRequest (view: MsgView) {
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
159
|
+
// if no records are in store then send a gap fill for entire sequence
|
|
160
|
+
this.setState(SessionState.HandleResendRequest)
|
|
161
|
+
const [beginSeqNo, endSeqNo] = view.getTypedTags([MsgTag.BeginSeqNo, MsgTag.EndSeqNo])
|
|
162
|
+
this.sessionLogger.info(`onResendRequest getResendRequest beginSeqNo = ${beginSeqNo}, endSeqNo = ${endSeqNo}`)
|
|
163
|
+
this.resender.getResendRequest(beginSeqNo, endSeqNo).then((records: IFixMsgStoreRecord[]) => {
|
|
164
|
+
const validRecords = records.filter(rec => rec.obj !== null)
|
|
165
|
+
this.sessionLogger.info(`sending ${validRecords.length}`)
|
|
166
|
+
validRecords.forEach(rec => {
|
|
167
|
+
this.send(rec.msgType, rec.obj)
|
|
168
|
+
})
|
|
169
|
+
this.setState(SessionState.ActiveNormalSession)
|
|
170
|
+
}).catch(e => {
|
|
171
|
+
this.sessionLogger.error(e)
|
|
172
|
+
})
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
okForLogon (): boolean {
|
|
176
|
+
const state = this.sessionState.state
|
|
177
|
+
if (this.acceptor) {
|
|
178
|
+
return state === SessionState.WaitingForALogon
|
|
179
|
+
}
|
|
180
|
+
return state === SessionState.InitiationLogonSent
|
|
135
181
|
}
|
|
136
182
|
|
|
137
183
|
protected onSessionMsg (msgType: string, view: MsgView): void {
|
|
138
184
|
|
|
139
|
-
const factory = this.config.factory
|
|
140
185
|
const logger = this.sessionLogger
|
|
141
186
|
|
|
142
187
|
switch (msgType) {
|
|
143
188
|
case MsgType.Logon: {
|
|
144
|
-
|
|
189
|
+
// only valid to receive a logon when in LogonSent or WaitingALogon
|
|
190
|
+
// else will drop connection immediately.
|
|
191
|
+
if (this.okForLogon()) {
|
|
192
|
+
this.peerLogon(view)
|
|
193
|
+
} else {
|
|
194
|
+
this.terminate(new Error(`state ${this.stateString()} is illegal for Logon`))
|
|
195
|
+
}
|
|
145
196
|
break
|
|
146
197
|
}
|
|
147
198
|
|
|
@@ -152,17 +203,18 @@ export abstract class AsciiSession extends FixSession {
|
|
|
152
203
|
|
|
153
204
|
case MsgType.TestRequest: {
|
|
154
205
|
const req: string = view.getString(MsgTag.TestReqID)
|
|
155
|
-
this.
|
|
206
|
+
this.sendHeartbeat(req)
|
|
156
207
|
break
|
|
157
208
|
}
|
|
158
209
|
|
|
159
210
|
case MsgType.Heartbeat: {
|
|
160
211
|
this.sessionState.lastTestRequestAt = null
|
|
212
|
+
this.setState(SessionState.ActiveNormalSession)
|
|
161
213
|
break
|
|
162
214
|
}
|
|
163
215
|
|
|
164
216
|
case MsgType.ResendRequest: {
|
|
165
|
-
logger.info(`peer sends '${msgType}' resend
|
|
217
|
+
logger.info(`peer sends '${msgType}' resend request.`)
|
|
166
218
|
this.onResendRequest(view)
|
|
167
219
|
break
|
|
168
220
|
}
|
|
@@ -194,9 +246,7 @@ export abstract class AsciiSession extends FixSession {
|
|
|
194
246
|
switch (msgType) {
|
|
195
247
|
case MsgType.Logon: {
|
|
196
248
|
this.setState(SessionState.PeerLogonRejected)
|
|
197
|
-
this.
|
|
198
|
-
this.tick()
|
|
199
|
-
}, 200)
|
|
249
|
+
this.startTimer()
|
|
200
250
|
break
|
|
201
251
|
}
|
|
202
252
|
}
|
|
@@ -222,36 +272,54 @@ export abstract class AsciiSession extends FixSession {
|
|
|
222
272
|
}
|
|
223
273
|
}
|
|
224
274
|
|
|
275
|
+
private startTimer (interval: number = 200) {
|
|
276
|
+
this.timer = setInterval(() => {
|
|
277
|
+
this.tick()
|
|
278
|
+
}, interval)
|
|
279
|
+
}
|
|
280
|
+
|
|
225
281
|
private peerLogon (view: MsgView) {
|
|
226
282
|
const logger = this.sessionLogger
|
|
227
|
-
const heartBtInt = view.
|
|
228
|
-
const peerCompId = view.getTyped(MsgTag.SenderCompID)
|
|
229
|
-
const userName = view.getString(MsgTag.Username)
|
|
283
|
+
const [heartBtInt, peerCompId, userName, password] = view.getTypedTags([MsgTag.HeartBtInt, MsgTag.SenderCompID, MsgTag.Username, MsgTag.Password])
|
|
230
284
|
logger.info(`peerLogon Username = ${userName}, heartBtInt = ${heartBtInt}, peerCompId = ${peerCompId}, userName = ${userName}`)
|
|
231
285
|
const state = this.sessionState
|
|
232
286
|
state.peerHeartBeatSecs = view.getTyped(MsgTag.HeartBtInt)
|
|
233
287
|
state.peerCompId = view.getTyped(MsgTag.SenderCompID)
|
|
288
|
+
const res = this.onLogon(view, userName, password)
|
|
289
|
+
// currently not using this.
|
|
290
|
+
logger.info(`peerLogon onLogon returns ${res}`)
|
|
234
291
|
if (this.acceptor) {
|
|
235
292
|
this.setState(SessionState.InitiationLogonResponse)
|
|
236
|
-
|
|
293
|
+
logger.info('acceptor responds to logon request')
|
|
294
|
+
this.sendLogon() // if res send response else reject, terminate
|
|
237
295
|
} else { // as an initiator the acceptor has responded
|
|
296
|
+
logger.info('initiator receives logon response')
|
|
238
297
|
this.setState(SessionState.InitiationLogonReceived)
|
|
239
298
|
}
|
|
240
299
|
if (this.heartbeat) {
|
|
241
300
|
logger.debug(`start heartbeat timer.`)
|
|
242
|
-
this.
|
|
243
|
-
this.tick()
|
|
244
|
-
}, 200)
|
|
301
|
+
this.startTimer()
|
|
245
302
|
}
|
|
246
303
|
logger.info(`system ready, inform app`)
|
|
247
304
|
this.onReady(view)
|
|
248
305
|
}
|
|
249
306
|
|
|
307
|
+
private sendTestRequest () {
|
|
308
|
+
const factory = this.config.factory
|
|
309
|
+
this.setState(SessionState.AwaitingProcessingResponseToTestRequest)
|
|
310
|
+
this.send(MsgType.TestRequest, factory.testRequest())
|
|
311
|
+
}
|
|
312
|
+
|
|
313
|
+
private sendHeartbeat (testReqId: string) {
|
|
314
|
+
const factory = this.config.factory
|
|
315
|
+
this.send(MsgType.Heartbeat, factory.heartbeat(testReqId))
|
|
316
|
+
}
|
|
317
|
+
|
|
250
318
|
private tick (): void {
|
|
319
|
+
if (!this.transport) return
|
|
251
320
|
const sessionState = this.sessionState
|
|
252
321
|
const action: TickAction = sessionState.calcAction(new Date())
|
|
253
322
|
const application: IMsgApplication = this.transport.config.description.application
|
|
254
|
-
const factory = this.config.factory
|
|
255
323
|
const logger = this.sessionLogger
|
|
256
324
|
|
|
257
325
|
switch (action) {
|
|
@@ -262,13 +330,13 @@ export abstract class AsciiSession extends FixSession {
|
|
|
262
330
|
|
|
263
331
|
case TickAction.TestRequest: {
|
|
264
332
|
logger.debug(`send test req. state = ${sessionState.toString()}`)
|
|
265
|
-
this.
|
|
333
|
+
this.sendTestRequest()
|
|
266
334
|
break
|
|
267
335
|
}
|
|
268
336
|
|
|
269
337
|
case TickAction.Heartbeat: {
|
|
270
338
|
logger.debug(`send heartbeat. state = ${sessionState.toString()}`)
|
|
271
|
-
this.
|
|
339
|
+
this.sendHeartbeat(sessionState.now.toUTCString())
|
|
272
340
|
break
|
|
273
341
|
}
|
|
274
342
|
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export * from './ascii-session'
|
|
2
|
-
export * from './ascii-msg-
|
|
2
|
+
export * from './ascii-session-msg-factory'
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { FixDuplex } from './fix-duplex'
|
|
2
2
|
import { Readable, Writable } from 'stream'
|
|
3
|
-
import
|
|
4
|
-
import
|
|
3
|
+
import * as rp from 'request-promise-native'
|
|
4
|
+
import { IHttpAdapter } from '../http/http-adapter'
|
|
5
5
|
|
|
6
6
|
export class HttpDuplex extends FixDuplex {
|
|
7
7
|
public constructor (public readonly adapter: IHttpAdapter) {
|
|
@@ -28,7 +28,7 @@ export class HttpDuplex extends FixDuplex {
|
|
|
28
28
|
try {
|
|
29
29
|
const adapter = this.adapter
|
|
30
30
|
const options = adapter.getOptions(data)
|
|
31
|
-
|
|
31
|
+
rp(options).then((message: any) => {
|
|
32
32
|
const body = adapter.endMessage(message)
|
|
33
33
|
forward.push(body)
|
|
34
34
|
done()
|
|
@@ -1,8 +1,11 @@
|
|
|
1
1
|
import { FixDuplex } from './fix-duplex'
|
|
2
2
|
import * as net from 'net'
|
|
3
|
+
import { inject, injectable } from 'tsyringe'
|
|
4
|
+
import { DITokens } from '../../runtime/di-tokens'
|
|
3
5
|
|
|
6
|
+
@injectable()
|
|
4
7
|
export class TcpDuplex extends FixDuplex {
|
|
5
|
-
constructor (public readonly socket: net.Socket) {
|
|
8
|
+
constructor (@inject(DITokens.duplexParam) public readonly socket: net.Socket) {
|
|
6
9
|
super()
|
|
7
10
|
this.readable = socket
|
|
8
11
|
this.writable = socket
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './msg-transport'
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { MsgParser } from '../../buffer'
|
|
2
|
+
import { MsgTransmitter } from '../msg-transmitter'
|
|
3
|
+
import { FixDuplex } from '../duplex'
|
|
4
|
+
import { IJsFixConfig } from '../../config'
|
|
5
|
+
import { DITokens } from '../../runtime/di-tokens'
|
|
6
|
+
import { Readable } from 'stream'
|
|
7
|
+
import { inject, injectable } from 'tsyringe'
|
|
8
|
+
|
|
9
|
+
@injectable()
|
|
10
|
+
export class MsgTransport {
|
|
11
|
+
public readonly transmitter: MsgTransmitter
|
|
12
|
+
public readonly receiver: MsgParser
|
|
13
|
+
|
|
14
|
+
constructor (@inject(DITokens.sessionId) public readonly id: number,
|
|
15
|
+
@inject(DITokens.IJsFixConfig) public readonly config: IJsFixConfig,
|
|
16
|
+
@inject(DITokens.FixDuplex) public readonly duplex: FixDuplex) {
|
|
17
|
+
|
|
18
|
+
const delimiter = config.delimiter
|
|
19
|
+
if (!delimiter) {
|
|
20
|
+
throw new Error(`no delimiter char given.`)
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
const sessionContainer = this.config.sessionContainer
|
|
24
|
+
sessionContainer.registerInstance<Readable>(DITokens.readStream, this.duplex.readable)
|
|
25
|
+
|
|
26
|
+
// let parser replace delimiter with Pipe so fix log does not require
|
|
27
|
+
// expensive replace
|
|
28
|
+
|
|
29
|
+
this.transmitter = sessionContainer.resolve<MsgTransmitter>(DITokens.MsgTransmitter)
|
|
30
|
+
this.receiver = sessionContainer.resolve<MsgParser>(DITokens.MsgParser)
|
|
31
|
+
|
|
32
|
+
// pipe the encoder to say a socket.
|
|
33
|
+
if (duplex.writable) {
|
|
34
|
+
this.transmitter.encodeStream.pipe(duplex.writable)
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
public end (): void {
|
|
39
|
+
this.duplex.end()
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
public wait (): Promise<any> {
|
|
43
|
+
return new Promise<any>((resolve, reject) => {
|
|
44
|
+
this.receiver.on('end', () => {
|
|
45
|
+
resolve(this.id)
|
|
46
|
+
})
|
|
47
|
+
this.receiver.on('error', (e) => {
|
|
48
|
+
reject(e)
|
|
49
|
+
})
|
|
50
|
+
this.transmitter.on('error', (e) => {
|
|
51
|
+
reject(e)
|
|
52
|
+
})
|
|
53
|
+
})
|
|
54
|
+
}
|
|
55
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as events from 'events'
|
|
2
|
-
import { MsgTransport } from './
|
|
3
|
-
import { IMsgApplication } from './session-description'
|
|
2
|
+
import { MsgTransport } from './factory'
|
|
4
3
|
import { INumericKeyed } from '../collections/collection'
|
|
4
|
+
import { IMsgApplication } from './msg-application'
|
|
5
5
|
|
|
6
6
|
export abstract class FixAcceptor extends events.EventEmitter {
|
|
7
7
|
public transports: INumericKeyed<MsgTransport> = {}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
1
|
+
import { MsgTransport } from './factory'
|
|
2
|
+
import { IMsgApplication } from './msg-application'
|
|
3
3
|
|
|
4
4
|
export abstract class FixInitiator {
|
|
5
5
|
protected constructor (public readonly application: IMsgApplication) {
|
|
@@ -1,14 +1,18 @@
|
|
|
1
|
-
import { FixmlEncoder } from '../../buffer'
|
|
1
|
+
import { FixmlEncoder } from '../../buffer/fixml'
|
|
2
2
|
import { IJsFixConfig } from '../../config'
|
|
3
3
|
import { MsgTransmitter } from '../msg-transmitter'
|
|
4
4
|
import { ILooseObject } from '../../collections/collection'
|
|
5
|
+
import { inject, injectable } from 'tsyringe'
|
|
6
|
+
import { DITokens } from '../../runtime/di-tokens'
|
|
7
|
+
import { ElasticBuffer } from '../../buffer'
|
|
5
8
|
|
|
9
|
+
@injectable()
|
|
6
10
|
export class FixmlMsgTransmitter extends MsgTransmitter {
|
|
7
11
|
public time: Date
|
|
8
12
|
|
|
9
|
-
constructor (public readonly config: IJsFixConfig) {
|
|
10
|
-
super(config.definitions, config.description)
|
|
11
|
-
this.encoder =
|
|
13
|
+
constructor (@inject(DITokens.IJsFixConfig) public readonly config: IJsFixConfig) {
|
|
14
|
+
super(config.sessionContainer.resolve<ElasticBuffer>(DITokens.TransmitBuffer), config.definitions, config.description)
|
|
15
|
+
this.encoder = config.sessionContainer.resolve<FixmlEncoder>(DITokens.MsgEncoder)
|
|
12
16
|
}
|
|
13
17
|
|
|
14
18
|
public encodeMessage (msgType: string, obj: ILooseObject): void {
|
|
@@ -0,0 +1,76 @@
|
|
|
1
|
+
import { ISessionDescription } from '../session/session-description'
|
|
2
|
+
import { ILooseObject } from '../../collections/collection'
|
|
3
|
+
import { MsgType } from '../../types'
|
|
4
|
+
import { ASessionMsgFactory, ObjectMutator } from '../session/a-session-msg-factory'
|
|
5
|
+
|
|
6
|
+
import {
|
|
7
|
+
IStandardHeader,
|
|
8
|
+
IUserRequest,
|
|
9
|
+
IUserResponse,
|
|
10
|
+
UserRequestType,
|
|
11
|
+
UserStatus
|
|
12
|
+
} from '../../types/FIXML50SP2'
|
|
13
|
+
|
|
14
|
+
export class FixmlSessionMsgFactory extends ASessionMsgFactory {
|
|
15
|
+
|
|
16
|
+
constructor (readonly description: ISessionDescription, mutator: ObjectMutator = null) {
|
|
17
|
+
super(description, mutator)
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public logon (userRequestId: string = '', isResponse: boolean = false): ILooseObject {
|
|
21
|
+
return this.fixmlLogon(userRequestId, isResponse)
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
public logout (msgType: string, text: string): ILooseObject {
|
|
25
|
+
return this.fixmlLogout(msgType, msgType !== 'UserReq')
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
public header (msgType: string, seqNum: number = 0, time: Date = new Date(), overrideData?: Partial<IStandardHeader>): ILooseObject {
|
|
29
|
+
const description = this.description
|
|
30
|
+
const o: IStandardHeader = {
|
|
31
|
+
SenderCompID: description.SenderCompId,
|
|
32
|
+
TargetCompID: description.TargetCompID,
|
|
33
|
+
SenderSubID: description.SenderSubID,
|
|
34
|
+
TargetSubID: description.TargetSubID
|
|
35
|
+
} as IStandardHeader
|
|
36
|
+
return this.mutate(o, 'StandardHeader')
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
private fixmlLogon (userRequestId: string, isResponse: boolean): ILooseObject {
|
|
40
|
+
const description = this.description
|
|
41
|
+
if (!isResponse) {
|
|
42
|
+
const o: IUserRequest = {
|
|
43
|
+
Username: description.Username,
|
|
44
|
+
Password: description.Password,
|
|
45
|
+
UserRequestID: userRequestId,
|
|
46
|
+
UserRequestType: UserRequestType.LogOnUser
|
|
47
|
+
} as IUserRequest
|
|
48
|
+
return this.mutate(o, MsgType.Logon)
|
|
49
|
+
} else {
|
|
50
|
+
const o: IUserResponse = {
|
|
51
|
+
Username: description.Username,
|
|
52
|
+
UserRequestID: userRequestId,
|
|
53
|
+
UserStatus: UserStatus.LoggedIn
|
|
54
|
+
} as IUserResponse
|
|
55
|
+
return this.mutate(o, MsgType.Logon)
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
private fixmlLogout (userRequestId: string, isResponse: boolean): ILooseObject {
|
|
60
|
+
if (!isResponse) {
|
|
61
|
+
const o: IUserRequest = {
|
|
62
|
+
Username: this.description.Username,
|
|
63
|
+
UserRequestID: userRequestId,
|
|
64
|
+
UserRequestType: UserRequestType.LogOffUser
|
|
65
|
+
} as IUserRequest
|
|
66
|
+
return this.mutate(o, MsgType.Logout)
|
|
67
|
+
} else {
|
|
68
|
+
const o: IUserResponse = {
|
|
69
|
+
Username: this.description.Username,
|
|
70
|
+
UserRequestID: userRequestId,
|
|
71
|
+
UserStatus: UserStatus.NotLoggedIn
|
|
72
|
+
} as IUserResponse
|
|
73
|
+
return this.mutate(o, MsgType.Logout)
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|