jspurefix 1.1.2 → 1.4.1
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 +43 -11
- package/data/FIX44-MD.xml +6596 -0
- package/data/examples/FIX.4.4/jsfix.test_client.txt +15 -13
- package/data/session/test-qf44-acceptor.json +21 -0
- package/data/session/test-qf44-initiator.json +22 -0
- package/dist/buffer/ascii/ascii-encoder.d.ts +9 -2
- package/dist/buffer/ascii/ascii-encoder.js +72 -31
- package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
- package/dist/buffer/ascii/ascii-parser.d.ts +1 -0
- package/dist/buffer/ascii/ascii-parser.js +7 -1
- package/dist/buffer/ascii/ascii-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-segment-parser.d.ts +0 -2
- package/dist/buffer/ascii/ascii-segment-parser.js +19 -25
- package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
- package/dist/buffer/ascii/ascii-view.d.ts +2 -0
- package/dist/buffer/ascii/ascii-view.js +4 -0
- package/dist/buffer/ascii/ascii-view.js.map +1 -1
- package/dist/buffer/ascii/time-formatter.js.map +1 -1
- package/dist/buffer/ascii-chars.d.ts +1 -0
- package/dist/buffer/ascii-chars.js +1 -0
- package/dist/buffer/ascii-chars.js.map +1 -1
- package/dist/buffer/elastic-buffer.d.ts +1 -0
- package/dist/buffer/elastic-buffer.js +8 -0
- package/dist/buffer/elastic-buffer.js.map +1 -1
- package/dist/buffer/encode-proxy.js.map +1 -1
- package/dist/buffer/fixml/fixml-encoder.d.ts +3 -0
- package/dist/buffer/fixml/fixml-encoder.js +6 -0
- package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
- package/dist/buffer/fixml/fixml-view.d.ts +2 -0
- package/dist/buffer/fixml/fixml-view.js +3 -0
- package/dist/buffer/fixml/fixml-view.js.map +1 -1
- package/dist/buffer/msg-encoder.d.ts +2 -0
- package/dist/buffer/msg-encoder.js.map +1 -1
- package/dist/buffer/msg-view.d.ts +2 -0
- package/dist/buffer/msg-view.js.map +1 -1
- package/dist/buffer/tags.js +5 -5
- package/dist/buffer/tags.js.map +1 -1
- package/dist/collections/dictionary.d.ts +1 -0
- package/dist/collections/dictionary.js +5 -0
- package/dist/collections/dictionary.js.map +1 -1
- package/dist/config/js-fix-config.d.ts +2 -0
- package/dist/config/js-fix-config.js +1 -0
- package/dist/config/js-fix-config.js.map +1 -1
- package/dist/dict-parser.js +2 -2
- package/dist/dict-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/field-set-parser.js +11 -4
- package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/message-parser.js +4 -0
- package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -0
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +15 -0
- package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
- package/dist/jsfix-cmd.js +2 -1
- package/dist/jsfix-cmd.js.map +1 -1
- package/dist/sample/http/oms/app.js +2 -0
- package/dist/sample/http/oms/app.js.map +1 -1
- package/dist/sample/launcher.d.ts +3 -2
- package/dist/sample/launcher.js +12 -3
- package/dist/sample/launcher.js.map +1 -1
- package/dist/sample/tcp/{trade_capture → qf-md}/app.d.ts +0 -0
- package/dist/sample/tcp/qf-md/app.js +22 -0
- package/dist/sample/tcp/qf-md/app.js.map +1 -0
- package/dist/sample/tcp/qf-md/md-client.d.ts +15 -0
- package/dist/sample/tcp/qf-md/md-client.js +42 -0
- package/dist/sample/tcp/qf-md/md-client.js.map +1 -0
- package/dist/sample/tcp/qf-md/md-factory.d.ts +4 -0
- package/dist/sample/tcp/qf-md/md-factory.js +35 -0
- package/dist/sample/tcp/qf-md/md-factory.js.map +1 -0
- package/dist/sample/tcp/qf-md/md-server.d.ts +16 -0
- package/dist/sample/tcp/qf-md/md-server.js +44 -0
- package/dist/sample/tcp/qf-md/md-server.js.map +1 -0
- package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -0
- package/dist/sample/tcp/recovering-skeleton/app.js +27 -0
- package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-2.d.ts +2 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-2.js +3 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-2.js.map +1 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +7 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +52 -0
- package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +16 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +45 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.d.ts +16 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +52 -0
- package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -0
- package/dist/sample/tcp/skeleton/app.js +2 -0
- 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 +22 -3
- package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.js +1 -1
- package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
- package/dist/sample/tcp/trade-capture/app.d.ts +1 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/app.js +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/app.js.map +1 -1
- package/dist/sample/tcp/{trade_capture → trade-capture}/index.d.ts +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/index.js +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/index.js.map +1 -1
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.d.ts +1 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.js +8 -4
- package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.d.ts +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.js +1 -1
- package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.d.ts +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.js +0 -0
- package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.js.map +1 -1
- package/dist/store/fix-msg-ascii-store-resend.d.ts +6 -2
- package/dist/store/fix-msg-ascii-store-resend.js +49 -22
- 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 +7 -3
- package/dist/store/fix-msg-store-record.js +5 -1
- package/dist/store/fix-msg-store-record.js.map +1 -1
- package/dist/store/fix-msg-store.d.ts +13 -9
- package/dist/store/fix-msg-store.js.map +1 -1
- package/dist/test/ascii-encode.test.js +20 -3
- package/dist/test/ascii-encode.test.js.map +1 -1
- package/dist/test/ascii-encoder.test.d.ts +1 -0
- package/dist/test/ascii-encoder.test.js +505 -0
- package/dist/test/ascii-encoder.test.js.map +1 -0
- package/dist/test/ascii-parser.test.js +8 -6
- package/dist/test/ascii-parser.test.js.map +1 -1
- package/dist/test/ascii-segment.test.js +6 -5
- package/dist/test/ascii-segment.test.js.map +1 -1
- package/dist/test/ascii-store-replay.test.js +59 -44
- package/dist/test/ascii-store-replay.test.js.map +1 -1
- package/dist/test/logon.test.js +1 -1
- package/dist/test/logon.test.js.map +1 -1
- package/dist/test/memory-store.test.js +24 -19
- package/dist/test/memory-store.test.js.map +1 -1
- package/dist/test/qf-full-msg.test.js +19 -14
- package/dist/test/qf-full-msg.test.js.map +1 -1
- package/dist/test/repo-full-ascii-msg.test.js +17 -15
- package/dist/test/repo-full-ascii-msg.test.js.map +1 -1
- package/dist/test/repo-full-fixml-msg.test.js +14 -14
- package/dist/test/repo-full-fixml-msg.test.js.map +1 -1
- package/dist/test/session-state.test.js +2 -2
- package/dist/test/session-state.test.js.map +1 -1
- package/dist/test/session.test.js +263 -143
- package/dist/test/session.test.js.map +1 -1
- package/dist/test/view-decode.test.js +2 -1
- package/dist/test/view-decode.test.js.map +1 -1
- 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.d.ts +1 -0
- package/dist/transport/ascii/ascii-msg-transmitter.js +39 -8
- 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 -2
- package/dist/transport/ascii/ascii-session.js +86 -31
- package/dist/transport/ascii/ascii-session.js.map +1 -1
- package/dist/transport/ascii/index.d.ts +1 -0
- package/dist/transport/ascii/index.js +1 -0
- package/dist/transport/ascii/index.js.map +1 -1
- package/dist/transport/ascii-session-msg-factory.d.ts +16 -0
- package/dist/transport/ascii-session-msg-factory.js +47 -0
- package/dist/transport/ascii-session-msg-factory.js.map +1 -0
- package/dist/transport/duplex/http-duplex.js +2 -2
- package/dist/transport/duplex/http-duplex.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.d.ts +38 -12
- package/dist/transport/fix-session-state.js +49 -15
- package/dist/transport/fix-session-state.js.map +1 -1
- package/dist/transport/fix-session.d.ts +13 -6
- package/dist/transport/fix-session.js +143 -39
- package/dist/transport/fix-session.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.js +1 -1
- package/dist/transport/fixml/fixml-session.js.map +1 -1
- package/dist/transport/fixml/index.d.ts +2 -1
- package/dist/transport/fixml/index.js +2 -1
- package/dist/transport/fixml/index.js.map +1 -1
- package/dist/transport/fixml-session-msg-factory.d.ts +13 -0
- package/dist/transport/fixml-session-msg-factory.js +68 -0
- package/dist/transport/fixml-session-msg-factory.js.map +1 -0
- package/dist/transport/http/http-acceptor.js +8 -7
- package/dist/transport/http/http-acceptor.js.map +1 -1
- package/dist/transport/index.d.ts +1 -1
- package/dist/transport/index.js +1 -1
- package/dist/transport/index.js.map +1 -1
- package/dist/transport/msg-transmitter.js +4 -3
- package/dist/transport/msg-transmitter.js.map +1 -1
- package/dist/transport/msg-transport.js +3 -2
- package/dist/transport/msg-transport.js.map +1 -1
- package/dist/transport/session-description.d.ts +1 -1
- package/dist/transport/session-description.js.map +1 -1
- package/dist/transport/session-msg-factory.d.ts +2 -2
- package/dist/transport/session-msg-factory.js +2 -2
- package/dist/transport/session-msg-factory.js.map +1 -1
- package/dist/transport/tcp/acceptor.js +5 -3
- package/dist/transport/tcp/acceptor.js.map +1 -1
- package/dist/transport/tcp/index.d.ts +1 -0
- package/dist/transport/tcp/index.js +1 -0
- package/dist/transport/tcp/index.js.map +1 -1
- package/dist/transport/tcp/initiator.js +1 -0
- package/dist/transport/tcp/initiator.js.map +1 -1
- package/dist/transport/tcp/recovering-initiator.d.ts +17 -0
- package/dist/transport/tcp/recovering-initiator.js +30 -0
- package/dist/transport/tcp/recovering-initiator.js.map +1 -0
- package/dist/transport/tcp/recovering-tcp-initiator.d.ts +28 -0
- package/dist/transport/tcp/recovering-tcp-initiator.js +120 -0
- package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -0
- package/dist/transport/tcp/tcp-acceptor.d.ts +7 -0
- package/dist/transport/tcp/tcp-acceptor.js +43 -11
- package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
- package/dist/transport/tcp/tcp-initiator.d.ts +4 -0
- package/dist/transport/tcp/tcp-initiator.js +72 -35
- package/dist/transport/tcp/tcp-initiator.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/advertisement.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/advertisement.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/allocation_instruction.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/allocation_instruction.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/allocation_instruction_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/allocation_instruction_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/allocation_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/allocation_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/allocation_report_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/allocation_report_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/assignment_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/assignment_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/bid_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/bid_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/bid_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/bid_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/business_message_reject.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/business_message_reject.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_assignment.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_assignment.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_inquiry.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_inquiry.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_inquiry_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_inquiry_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/collateral_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/collateral_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/confirmation.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/confirmation.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/confirmation_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/confirmation_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/confirmation_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/confirmation_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/cross_order_cancel_replace_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/cross_order_cancel_replace_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/cross_order_cancel_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/cross_order_cancel_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/derivative_security_list.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/derivative_security_list.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/derivative_security_list_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/derivative_security_list_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/dont_know_trade.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/dont_know_trade.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/email.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/email.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/execution_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/execution_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/heartbeat.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/heartbeat.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/index.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/index.js +4 -0
- package/dist/types/FIX4.4/quickfix/index.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/ioi.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/ioi.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/list_cancel_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/list_cancel_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/list_execute.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/list_execute.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/list_status.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/list_status.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/list_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/list_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/list_strike_price.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/list_strike_price.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/logon.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/logon.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/logout.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/logout.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/market_data_incremental_refresh.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/market_data_incremental_refresh.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/market_data_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/market_data_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/market_data_request_reject.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/market_data_request_reject.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/mass_quote.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/mass_quote.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/mass_quote_acknowledgement.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/mass_quote_acknowledgement.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/multileg_order_cancel_replace.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/multileg_order_cancel_replace.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/new_order_cross.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/new_order_cross.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/new_order_list.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/new_order_list.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/new_order_multileg.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/new_order_multileg.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/new_order_single.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/new_order_single.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/news.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/news.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_cancel_reject.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_cancel_reject.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_cancel_replace_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_cancel_replace_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_cancel_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_cancel_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_mass_cancel_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_mass_cancel_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_mass_cancel_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_mass_cancel_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_mass_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_mass_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/order_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/order_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/position_maintenance_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/position_maintenance_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/position_maintenance_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/position_maintenance_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/position_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/position_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_cancel.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_cancel.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_request_reject.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_request_reject.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_status_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_status_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/quote_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/quote_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/registration_instructions.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/registration_instructions.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/registration_instructions_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/registration_instructions_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/reject.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/reject.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/request_for_positions.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/request_for_positions.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/request_for_positions_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/request_for_positions_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/resend_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/resend_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/rfq_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/rfq_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_definition.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_definition.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_definition_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_definition_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_list.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_list.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_list_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_list_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_status.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_status.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_type_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_type_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/security_types.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/security_types.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/sequence_reset.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/sequence_reset.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/set/header.d.ts +31 -0
- package/dist/types/FIX4.4/quickfix/set/header.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/header.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/set/hop.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/set/hop.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/hop.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/set/hop_no_hops.d.ts +5 -0
- package/dist/types/FIX4.4/quickfix/set/hop_no_hops.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/hop_no_hops.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/set/standard_header.d.ts +31 -0
- package/dist/types/FIX4.4/quickfix/set/standard_header.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/standard_header.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/set/standard_trailer.d.ts +6 -0
- package/dist/types/FIX4.4/quickfix/set/standard_trailer.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/standard_trailer.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +6 -0
- package/dist/types/FIX4.4/quickfix/set/trailer.js +3 -0
- package/dist/types/FIX4.4/quickfix/set/trailer.js.map +1 -0
- package/dist/types/FIX4.4/quickfix/settlement_instruction_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/settlement_instruction_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/settlement_instructions.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/settlement_instructions.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/test_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/test_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trade_capture_report.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trade_capture_report.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trade_capture_report_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trade_capture_report_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trade_capture_report_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trade_capture_report_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trade_capture_report_request_ack.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trade_capture_report_request_ack.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trading_session_status.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trading_session_status.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/trading_session_status_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/trading_session_status_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/user_request.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/user_request.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/user_response.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/user_response.js.map +1 -1
- package/dist/types/FIX4.4/quickfix/xm_lnon_fix.d.ts +4 -0
- package/dist/types/FIX4.4/quickfix/xm_lnon_fix.js.map +1 -1
- package/dist/types/FIX4.4/repo/enum/all-enum.js.map +1 -1
- package/package.json +25 -21
- package/script/build.sh +1 -0
- package/src/buffer/ascii/ascii-encoder.ts +110 -33
- package/src/buffer/ascii/ascii-parser.ts +8 -1
- package/src/buffer/ascii/ascii-segment-parser.ts +44 -38
- package/src/buffer/ascii/ascii-view.ts +5 -0
- package/src/buffer/ascii/time-formatter.ts +2 -2
- package/src/buffer/ascii-chars.ts +1 -0
- package/src/buffer/elastic-buffer.ts +9 -0
- package/src/buffer/encode-proxy.ts +2 -2
- package/src/buffer/fixml/fixml-encoder.ts +8 -0
- package/src/buffer/fixml/fixml-view.ts +5 -0
- package/src/buffer/msg-encoder.ts +2 -0
- package/src/buffer/msg-view.ts +3 -0
- package/src/buffer/tags.ts +1 -1
- package/src/collections/dictionary.ts +6 -0
- package/src/config/js-fix-config.ts +2 -0
- package/src/dictionary/parser/quickfix/field-set-parser.ts +11 -4
- package/src/dictionary/parser/quickfix/message-parser.ts +4 -0
- package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +16 -0
- package/src/jsfix-cmd.ts +2 -1
- package/src/sample/http/oms/app.ts +2 -0
- package/src/sample/launcher.ts +17 -7
- package/src/sample/tcp/qf-md/app.ts +26 -0
- package/src/sample/tcp/qf-md/md-client.ts +51 -0
- package/src/sample/tcp/qf-md/md-factory.ts +34 -0
- package/src/sample/tcp/qf-md/md-server.ts +56 -0
- package/src/sample/tcp/recovering-skeleton/app.ts +33 -0
- package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +41 -0
- package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +54 -0
- package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +60 -0
- package/src/sample/tcp/skeleton/app.ts +2 -0
- package/src/sample/tcp/skeleton/skeleton-session.ts +26 -4
- package/src/sample/tcp/tls-trade-capture/app.ts +1 -1
- package/src/sample/tcp/{trade_capture → trade-capture}/app.ts +0 -0
- package/src/sample/tcp/{trade_capture → trade-capture}/index.ts +0 -0
- package/src/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.ts +10 -5
- package/src/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.ts +2 -2
- package/src/sample/tcp/{trade_capture → trade-capture}/trade-factory.ts +0 -0
- package/src/store/fix-msg-ascii-store-resend.ts +87 -0
- package/src/store/fix-msg-memory-store.ts +171 -0
- package/src/store/fix-msg-store-record.ts +23 -0
- package/src/store/fix-msg-store.ts +23 -0
- package/src/store/index.ts +4 -0
- package/src/transport/a-session-msg-factory.ts +81 -0
- package/src/transport/ascii/ascii-msg-transmitter.ts +32 -11
- package/src/transport/ascii/ascii-session-msg-factory.ts +62 -0
- package/src/transport/ascii/ascii-session.ts +100 -36
- package/src/transport/ascii/index.ts +1 -0
- package/src/transport/duplex/http-duplex.ts +2 -2
- package/src/transport/fix-msg-factory.ts +1 -1
- package/src/transport/fix-session-state.ts +67 -15
- package/src/transport/fix-session.ts +156 -43
- package/src/transport/fixml/fixml-session-msg-factory.ts +76 -0
- package/src/transport/fixml/fixml-session.ts +1 -1
- package/src/transport/fixml/index.ts +2 -1
- package/src/transport/http/http-acceptor.ts +7 -6
- package/src/transport/index.ts +1 -1
- package/src/transport/msg-transmitter.ts +4 -3
- package/src/transport/msg-transport.ts +3 -2
- package/src/transport/session-description.ts +1 -1
- package/src/transport/tcp/acceptor.ts +5 -3
- package/src/transport/tcp/index.ts +1 -0
- package/src/transport/tcp/initiator.ts +1 -0
- package/src/transport/tcp/recovering-tcp-initiator.ts +149 -0
- package/src/transport/tcp/tcp-acceptor.ts +46 -11
- package/src/transport/tcp/tcp-initiator.ts +77 -40
- package/src/types/FIX4.4/quickfix/advertisement.ts +4 -0
- package/src/types/FIX4.4/quickfix/allocation_instruction.ts +4 -0
- package/src/types/FIX4.4/quickfix/allocation_instruction_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/allocation_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/allocation_report_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/assignment_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/bid_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/bid_response.ts +4 -0
- package/src/types/FIX4.4/quickfix/business_message_reject.ts +5 -0
- package/src/types/FIX4.4/quickfix/collateral_assignment.ts +4 -0
- package/src/types/FIX4.4/quickfix/collateral_inquiry.ts +4 -0
- package/src/types/FIX4.4/quickfix/collateral_inquiry_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/collateral_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/collateral_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/collateral_response.ts +4 -0
- package/src/types/FIX4.4/quickfix/confirmation.ts +4 -0
- package/src/types/FIX4.4/quickfix/confirmation_ack.ts +5 -0
- package/src/types/FIX4.4/quickfix/confirmation_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/cross_order_cancel_replace_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/cross_order_cancel_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/derivative_security_list.ts +4 -0
- package/src/types/FIX4.4/quickfix/derivative_security_list_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/dont_know_trade.ts +4 -0
- package/src/types/FIX4.4/quickfix/email.ts +4 -0
- package/src/types/FIX4.4/quickfix/execution_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/heartbeat.ts +5 -0
- package/src/types/FIX4.4/quickfix/index.ts +4 -0
- package/src/types/FIX4.4/quickfix/ioi.ts +4 -0
- package/src/types/FIX4.4/quickfix/list_cancel_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/list_execute.ts +6 -1
- package/src/types/FIX4.4/quickfix/list_status.ts +4 -0
- package/src/types/FIX4.4/quickfix/list_status_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/list_strike_price.ts +4 -0
- package/src/types/FIX4.4/quickfix/logon.ts +4 -0
- package/src/types/FIX4.4/quickfix/logout.ts +6 -1
- package/src/types/FIX4.4/quickfix/market_data_incremental_refresh.ts +4 -0
- package/src/types/FIX4.4/quickfix/market_data_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/market_data_request_reject.ts +4 -0
- package/src/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.ts +4 -0
- package/src/types/FIX4.4/quickfix/mass_quote.ts +4 -0
- package/src/types/FIX4.4/quickfix/mass_quote_acknowledgement.ts +4 -0
- package/src/types/FIX4.4/quickfix/multileg_order_cancel_replace.ts +4 -0
- package/src/types/FIX4.4/quickfix/network_counterparty_system_status_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/network_counterparty_system_status_response.ts +4 -0
- package/src/types/FIX4.4/quickfix/new_order_cross.ts +4 -0
- package/src/types/FIX4.4/quickfix/new_order_list.ts +4 -0
- package/src/types/FIX4.4/quickfix/new_order_multileg.ts +4 -0
- package/src/types/FIX4.4/quickfix/new_order_single.ts +4 -0
- package/src/types/FIX4.4/quickfix/news.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_cancel_reject.ts +5 -0
- package/src/types/FIX4.4/quickfix/order_cancel_replace_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_cancel_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_mass_cancel_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_mass_cancel_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_mass_status_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/order_status_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/position_maintenance_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/position_maintenance_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/position_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_cancel.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_request_reject.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_response.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_status_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/quote_status_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/registration_instructions.ts +4 -0
- package/src/types/FIX4.4/quickfix/registration_instructions_response.ts +4 -0
- package/src/types/FIX4.4/quickfix/reject.ts +6 -1
- package/src/types/FIX4.4/quickfix/request_for_positions.ts +4 -0
- package/src/types/FIX4.4/quickfix/request_for_positions_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/resend_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/rfq_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_definition.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_definition_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_list.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_list_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_status.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_status_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/security_type_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/security_types.ts +4 -0
- package/src/types/FIX4.4/quickfix/sequence_reset.ts +5 -0
- package/src/types/FIX4.4/quickfix/set/hop.ts +5 -0
- package/src/types/FIX4.4/quickfix/set/hop_no_hops.ts +5 -0
- package/src/types/FIX4.4/quickfix/set/standard_header.ts +31 -0
- package/src/types/FIX4.4/quickfix/set/standard_trailer.ts +5 -0
- package/src/types/FIX4.4/quickfix/settlement_instruction_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/settlement_instructions.ts +4 -0
- package/src/types/FIX4.4/quickfix/test_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/trade_capture_report.ts +4 -0
- package/src/types/FIX4.4/quickfix/trade_capture_report_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/trade_capture_report_request.ts +4 -0
- package/src/types/FIX4.4/quickfix/trade_capture_report_request_ack.ts +4 -0
- package/src/types/FIX4.4/quickfix/trading_session_status.ts +5 -0
- package/src/types/FIX4.4/quickfix/trading_session_status_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/user_request.ts +5 -0
- package/src/types/FIX4.4/quickfix/user_response.ts +5 -0
- package/src/types/FIX4.4/quickfix/xm_lnon_fix.ts +5 -0
- package/src/types/FIX4.4/repo/enum/all-enum.ts +0 -1
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_client.txt +0 -77
- package/dist/sample/tcp/tls-trade-capture/jsfix.test_server.txt +0 -77
- package/dist/sample/tcp/trade_capture/jsfix.test_client.txt +0 -75
- package/dist/sample/tcp/trade_capture/jsfix.test_server.txt +0 -75
- package/dist/sample/tcp/trade_capture/trade-capture-client.js.map +0 -1
- package/dist/sample/tcp/trade_capture/trade-capture-server.js.map +0 -1
- package/src/transport/session-msg-factory.ts +0 -195
- package/src/transport/tcp/resilient-initiator.ts +0 -35
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const launcher_1 = require("../../launcher");
|
|
4
|
+
const skeleton_client_1 = require("./skeleton-client");
|
|
5
|
+
const recovering_tcp_initiator_1 = require("../../../transport/tcp/recovering-tcp-initiator");
|
|
6
|
+
const respawn_acceptor_1 = require("./respawn-acceptor");
|
|
7
|
+
const buffer_1 = require("../../../buffer");
|
|
8
|
+
class AppLauncher extends launcher_1.Launcher {
|
|
9
|
+
constructor() {
|
|
10
|
+
super('data/session/test-initiator.json', 'data/session/test-acceptor.json');
|
|
11
|
+
}
|
|
12
|
+
getAcceptor(config) {
|
|
13
|
+
config.logDelimiter = buffer_1.AsciiChars.Carat;
|
|
14
|
+
const respawn = new respawn_acceptor_1.RespawnAcceptor(config);
|
|
15
|
+
return respawn.waitFor();
|
|
16
|
+
}
|
|
17
|
+
getInitiator(config) {
|
|
18
|
+
return new recovering_tcp_initiator_1.RecoveringTcpInitiator(config, c => new skeleton_client_1.SkeletonClient(c)).run();
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
const l = new AppLauncher();
|
|
22
|
+
l.run().then(() => {
|
|
23
|
+
console.log('finished.');
|
|
24
|
+
}).catch((e) => {
|
|
25
|
+
console.error(e.message);
|
|
26
|
+
});
|
|
27
|
+
//# sourceMappingURL=app.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/app.ts"],"names":[],"mappings":";;AACA,6CAAyC;AACzC,uDAAkD;AAClD,8FAAwF;AACxF,yDAAoD;AACpD,4CAA4C;AAE5C,MAAM,WAAY,SAAQ,mBAAQ;IAEhC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAES,WAAW,CAAE,MAAoB;QAEzC,MAAM,CAAC,YAAY,GAAG,mBAAU,CAAC,KAAK,CAAA;QACtC,MAAM,OAAO,GAAG,IAAI,kCAAe,CAAC,MAAM,CAAC,CAAA;QAC3C,OAAO,OAAO,CAAC,OAAO,EAAE,CAAA;IAC1B,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,IAAI,iDAAsB,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,gCAAc,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAA;IAC7E,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAQ,EAAE,EAAE;IACpB,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAA","sourcesContent":["import { IJsFixConfig } from '../../../config'\r\nimport { Launcher } from '../../launcher'\r\nimport { SkeletonClient } from './skeleton-client'\r\nimport { RecoveringTcpInitiator } from '../../../transport/tcp/recovering-tcp-initiator'\r\nimport { RespawnAcceptor } from './respawn-acceptor'\r\nimport { AsciiChars } from '../../../buffer'\r\n\r\nclass AppLauncher extends Launcher {\r\n\r\n public constructor () {\r\n super(\r\n 'data/session/test-initiator.json',\r\n 'data/session/test-acceptor.json')\r\n }\r\n\r\n protected getAcceptor (config: IJsFixConfig): Promise<any> {\r\n // use a different log delimiter as an example\r\n config.logDelimiter = AsciiChars.Carat\r\n const respawn = new RespawnAcceptor(config)\r\n return respawn.waitFor()\r\n }\r\n\r\n protected getInitiator (config: IJsFixConfig): Promise<any> {\r\n return new RecoveringTcpInitiator(config, c => new SkeletonClient(c)).run()\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.run().then(() => {\r\n console.log('finished.')\r\n}).catch((e: Error) => {\r\n console.error(e.message)\r\n})\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"respawn-2.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/respawn-2.ts"],"names":[],"mappings":"AAAA,MAAO,KAAK;CAEX","sourcesContent":["class fffff {\r\n\r\n}"]}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.RespawnAcceptor = void 0;
|
|
13
|
+
const transport_1 = require("../../../transport");
|
|
14
|
+
const skeleton_server_1 = require("./skeleton-server");
|
|
15
|
+
class RespawnAcceptor {
|
|
16
|
+
constructor(config) {
|
|
17
|
+
this.config = config;
|
|
18
|
+
this.logger = config.logFactory.logger('RespawnAcceptor');
|
|
19
|
+
}
|
|
20
|
+
waitFor(respawns = 1) {
|
|
21
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
22
|
+
return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
|
|
23
|
+
let respawned = 0;
|
|
24
|
+
while (respawned <= respawns) {
|
|
25
|
+
try {
|
|
26
|
+
this.logger.info(`waitFor: waiting for acceptor respawned = ${respawned}`);
|
|
27
|
+
yield transport_1.acceptor(this.config, (c) => {
|
|
28
|
+
const dropConnectionTimeout = respawned === 0 ? 5 : -1;
|
|
29
|
+
this.logger.info(`waitFor: create a new acceptor session respawned = ${respawned}, dropConnectionTimeout = ${dropConnectionTimeout}`);
|
|
30
|
+
return new skeleton_server_1.SkeletonServer(c, dropConnectionTimeout);
|
|
31
|
+
});
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
catch (e) {
|
|
35
|
+
this.logger.info(`waitFor: error in acceptor respawned = ${respawned}`);
|
|
36
|
+
}
|
|
37
|
+
++respawned;
|
|
38
|
+
}
|
|
39
|
+
if (respawned > 0) {
|
|
40
|
+
this.logger.info(`acceptor respawned reject = ${respawned}`);
|
|
41
|
+
reject(respawned);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
this.logger.info(`resolve = ${respawned}`);
|
|
45
|
+
resolve(respawned);
|
|
46
|
+
}
|
|
47
|
+
}));
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.RespawnAcceptor = RespawnAcceptor;
|
|
52
|
+
//# sourceMappingURL=respawn-acceptor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"respawn-acceptor.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/respawn-acceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,kDAA6C;AAC7C,uDAAkD;AAElD,MAAa,eAAe;IAG1B,YAA6B,MAAoB;QAApB,WAAM,GAAN,MAAM,CAAc;QAC/C,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAA;IAC3D,CAAC;IAKY,OAAO,CAAE,WAAmB,CAAC;;YACxC,OAAO,IAAI,OAAO,CAAM,CAAO,OAAO,EAAE,MAAM,EAAE,EAAE;gBAChD,IAAI,SAAS,GAAG,CAAC,CAAA;gBACjB,OAAO,SAAS,IAAI,QAAQ,EAAE;oBAC5B,IAAI;wBACF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,SAAS,EAAE,CAAC,CAAA;wBAC1E,MAAM,oBAAQ,CAAC,IAAI,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE;4BAChC,MAAM,qBAAqB,GAAG,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;4BACtD,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,sDAAsD,SAAS,6BAA6B,qBAAqB,EAAE,CAAC,CAAA;4BACrI,OAAO,IAAI,gCAAc,CAAC,CAAC,EAAE,qBAAqB,CAAC,CAAA;wBACrD,CAAC,CAAC,CAAA;wBACF,MAAK;qBACN;oBAAC,OAAO,CAAC,EAAE;wBACV,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,0CAA0C,SAAS,EAAE,CAAC,CAAA;qBACxE;oBACD,EAAE,SAAS,CAAA;iBACZ;gBACD,IAAI,SAAS,GAAG,CAAC,EAAE;oBACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,+BAA+B,SAAS,EAAE,CAAC,CAAA;oBAC5D,MAAM,CAAC,SAAS,CAAC,CAAA;iBAClB;qBAAM;oBACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,aAAa,SAAS,EAAE,CAAC,CAAA;oBAC1C,OAAO,CAAC,SAAS,CAAC,CAAA;iBACnB;YACH,CAAC,CAAA,CAAC,CAAA;QACJ,CAAC;KAAA;CACF;AApCD,0CAoCC","sourcesContent":["import { IJsFixConfig, IJsFixLogger } from '../../../config'\r\nimport { acceptor } from '../../../transport'\r\nimport { SkeletonServer } from './skeleton-server'\r\n\r\nexport class RespawnAcceptor {\r\n private readonly logger: IJsFixLogger\r\n\r\n constructor (public readonly config: IJsFixConfig) {\r\n this.logger = config.logFactory.logger('RespawnAcceptor')\r\n }\r\n\r\n // if acceptor errors e.g. via a forced connection drop, then respawn\r\n // a set number of times.\r\n\r\n public async waitFor (respawns: number = 1): Promise<any> {\r\n return new Promise<any>(async (resolve, reject) => {\r\n let respawned = 0\r\n while (respawned <= respawns) {\r\n try {\r\n this.logger.info(`waitFor: waiting for acceptor respawned = ${respawned}`)\r\n await acceptor(this.config, (c) => {\r\n const dropConnectionTimeout = respawned === 0 ? 5 : -1\r\n this.logger.info(`waitFor: create a new acceptor session respawned = ${respawned}, dropConnectionTimeout = ${dropConnectionTimeout}`)\r\n return new SkeletonServer(c, dropConnectionTimeout)\r\n })\r\n break\r\n } catch (e) {\r\n this.logger.info(`waitFor: error in acceptor respawned = ${respawned}`)\r\n }\r\n ++respawned\r\n }\r\n if (respawned > 0) {\r\n this.logger.info(`acceptor respawned reject = ${respawned}`)\r\n reject(respawned)\r\n } else {\r\n this.logger.info(`resolve = ${respawned}`)\r\n resolve(respawned)\r\n }\r\n })\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MsgView } from '../../../buffer';
|
|
2
|
+
import { AsciiSession } from '../../../transport';
|
|
3
|
+
import { IJsFixConfig } from '../../../config';
|
|
4
|
+
export declare class SkeletonClient extends AsciiSession {
|
|
5
|
+
readonly config: IJsFixConfig;
|
|
6
|
+
readonly logoutSeconds: number;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
private readonly fixLog;
|
|
9
|
+
constructor(config: IJsFixConfig, logoutSeconds?: number);
|
|
10
|
+
protected onApplicationMsg(msgType: string, view: MsgView): void;
|
|
11
|
+
protected onDecoded(msgType: string, txt: string): void;
|
|
12
|
+
protected onEncoded(msgType: string, txt: string): void;
|
|
13
|
+
protected onLogon(view: MsgView, user: string, password: string): boolean;
|
|
14
|
+
protected onReady(view: MsgView): void;
|
|
15
|
+
protected onStopped(): void;
|
|
16
|
+
}
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SkeletonClient = void 0;
|
|
4
|
+
const transport_1 = require("../../../transport");
|
|
5
|
+
class SkeletonClient extends transport_1.AsciiSession {
|
|
6
|
+
constructor(config, logoutSeconds = 45) {
|
|
7
|
+
super(config);
|
|
8
|
+
this.config = config;
|
|
9
|
+
this.logoutSeconds = logoutSeconds;
|
|
10
|
+
this.logReceivedMsgs = true;
|
|
11
|
+
this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`);
|
|
12
|
+
this.logger = config.logFactory.logger(`${this.me}`);
|
|
13
|
+
}
|
|
14
|
+
onApplicationMsg(msgType, view) {
|
|
15
|
+
switch (msgType) {
|
|
16
|
+
default: {
|
|
17
|
+
this.logger.info(`received message type ${msgType}`);
|
|
18
|
+
break;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
onDecoded(msgType, txt) {
|
|
23
|
+
this.fixLog.info(txt);
|
|
24
|
+
}
|
|
25
|
+
onEncoded(msgType, txt) {
|
|
26
|
+
this.fixLog.info(txt);
|
|
27
|
+
}
|
|
28
|
+
onLogon(view, user, password) {
|
|
29
|
+
this.logger.info(`peer logs in user ${user}`);
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
onReady(view) {
|
|
33
|
+
this.logger.info('onReady');
|
|
34
|
+
const logoutSeconds = this.logoutSeconds;
|
|
35
|
+
this.logger.info(`will logout after ${logoutSeconds}`);
|
|
36
|
+
setTimeout(() => {
|
|
37
|
+
this.done();
|
|
38
|
+
}, logoutSeconds * 1000);
|
|
39
|
+
}
|
|
40
|
+
onStopped() {
|
|
41
|
+
this.logger.info('stopped');
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
exports.SkeletonClient = SkeletonClient;
|
|
45
|
+
//# sourceMappingURL=skeleton-client.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skeleton-client.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/skeleton-client.ts"],"names":[],"mappings":";;;AACA,kDAAiD;AAGjD,MAAa,cAAe,SAAQ,wBAAY;IAI9C,YAA6B,MAAoB,EACpB,gBAAwB,EAAE;QACrD,KAAK,CAAC,MAAM,CAAC,CAAA;QAFc,WAAM,GAAN,MAAM,CAAc;QACpB,kBAAa,GAAb,aAAa,CAAa;QAErD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,MAAM,CAAC,CAAA;QACzF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;IACtD,CAAC;IAES,gBAAgB,CAAE,OAAe,EAAE,IAAa;QAExD,QAAQ,OAAO,EAAE;YACf,OAAO,CAAC,CAAC;gBACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;gBACpD,MAAK;aACN;SACF;IACH,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAES,OAAO,CAAE,IAAa,EAAE,IAAY,EAAE,QAAgB;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAA;QAC7C,OAAO,IAAI,CAAA;IACb,CAAC;IAES,OAAO,CAAE,IAAa;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAC3B,MAAM,aAAa,GAAG,IAAI,CAAC,aAAa,CAAA;QACxC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,aAAa,EAAE,CAAC,CAAA;QACtD,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,EAAE,CAAA;QACb,CAAC,EAAE,aAAa,GAAG,IAAI,CAAC,CAAA;IAC1B,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC7B,CAAC;CACF;AAjDD,wCAiDC","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\n\r\nexport class SkeletonClient extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (public readonly config: IJsFixConfig,\r\n public readonly logoutSeconds: number = 45) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n // dispatch messages\r\n switch (msgType) {\r\n default: {\r\n this.logger.info(`received message type ${msgType}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`peer logs in user ${user}`)\r\n return true\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('onReady')\r\n const logoutSeconds = this.logoutSeconds\r\n this.logger.info(`will logout after ${logoutSeconds}`)\r\n setTimeout(() => {\r\n this.done()\r\n }, logoutSeconds * 1000)\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n}\r\n"]}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { MsgView } from '../../../buffer';
|
|
2
|
+
import { AsciiSession } from '../../../transport';
|
|
3
|
+
import { IJsFixConfig } from '../../../config';
|
|
4
|
+
export declare class SkeletonServer extends AsciiSession {
|
|
5
|
+
readonly config: IJsFixConfig;
|
|
6
|
+
readonly dropConnectionTimeout: number;
|
|
7
|
+
private readonly logger;
|
|
8
|
+
private readonly fixLog;
|
|
9
|
+
constructor(config: IJsFixConfig, dropConnectionTimeout: number);
|
|
10
|
+
protected onApplicationMsg(msgType: string, view: MsgView): void;
|
|
11
|
+
protected onDecoded(msgType: string, txt: string): void;
|
|
12
|
+
protected onEncoded(msgType: string, txt: string): void;
|
|
13
|
+
protected onLogon(view: MsgView, user: string, password: string): boolean;
|
|
14
|
+
protected onReady(view: MsgView): void;
|
|
15
|
+
protected onStopped(): void;
|
|
16
|
+
}
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.SkeletonServer = void 0;
|
|
4
|
+
const transport_1 = require("../../../transport");
|
|
5
|
+
class SkeletonServer extends transport_1.AsciiSession {
|
|
6
|
+
constructor(config, dropConnectionTimeout) {
|
|
7
|
+
super(config);
|
|
8
|
+
this.config = config;
|
|
9
|
+
this.dropConnectionTimeout = dropConnectionTimeout;
|
|
10
|
+
this.logReceivedMsgs = true;
|
|
11
|
+
this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`);
|
|
12
|
+
this.logger = config.logFactory.logger(`${this.me}`);
|
|
13
|
+
}
|
|
14
|
+
onApplicationMsg(msgType, view) {
|
|
15
|
+
switch (msgType) {
|
|
16
|
+
default: {
|
|
17
|
+
this.logger.info(`received message type ${msgType}`);
|
|
18
|
+
break;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
}
|
|
22
|
+
onDecoded(msgType, txt) {
|
|
23
|
+
this.fixLog.info(txt);
|
|
24
|
+
}
|
|
25
|
+
onEncoded(msgType, txt) {
|
|
26
|
+
this.fixLog.info(txt);
|
|
27
|
+
}
|
|
28
|
+
onLogon(view, user, password) {
|
|
29
|
+
this.logger.info(`peer logs in user ${user}`);
|
|
30
|
+
return true;
|
|
31
|
+
}
|
|
32
|
+
onReady(view) {
|
|
33
|
+
this.logger.info('onReady');
|
|
34
|
+
if (this.dropConnectionTimeout > 0) {
|
|
35
|
+
this.logger.info(`acceptor is ready for requests - drop connection in ${this.dropConnectionTimeout}`);
|
|
36
|
+
setTimeout(() => {
|
|
37
|
+
setImmediate(() => {
|
|
38
|
+
this.logger.info(`kill transport`);
|
|
39
|
+
this.stop(new Error(`loss of tcp. ${this.me}`));
|
|
40
|
+
});
|
|
41
|
+
}, this.dropConnectionTimeout * 1000);
|
|
42
|
+
}
|
|
43
|
+
else {
|
|
44
|
+
this.logger.info(`acceptor is ready for requests`);
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
onStopped() {
|
|
48
|
+
this.logger.info('stopped');
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
exports.SkeletonServer = SkeletonServer;
|
|
52
|
+
//# sourceMappingURL=skeleton-server.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"skeleton-server.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/skeleton-server.ts"],"names":[],"mappings":";;;AACA,kDAAiD;AAGjD,MAAa,cAAe,SAAQ,wBAAY;IAI9C,YAA6B,MAAoB,EACpB,qBAA6B;QACxD,KAAK,CAAC,MAAM,CAAC,CAAA;QAFc,WAAM,GAAN,MAAM,CAAc;QACpB,0BAAqB,GAArB,qBAAqB,CAAQ;QAExD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,MAAM,CAAC,CAAA;QACzF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;IACtD,CAAC;IAES,gBAAgB,CAAE,OAAe,EAAE,IAAa;QAExD,QAAQ,OAAO,EAAE;YACf,OAAO,CAAC,CAAC;gBACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;gBACpD,MAAK;aACN;SACF;IACH,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAES,OAAO,CAAE,IAAa,EAAE,IAAY,EAAE,QAAgB;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAA;QAC7C,OAAO,IAAI,CAAA;IACb,CAAC;IAES,OAAO,CAAE,IAAa;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAC3B,IAAI,IAAI,CAAC,qBAAqB,GAAG,CAAC,EAAE;YAClC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uDAAuD,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAA;YACrG,UAAU,CAAC,GAAG,EAAE;gBACd,YAAY,CAAC,GAAG,EAAE;oBAChB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;oBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;gBACjD,CAAC,CAAC,CAAA;YACJ,CAAC,EAAE,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,CAAA;SACtC;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAA;SACnD;IACH,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC7B,CAAC;CACF;AAvDD,wCAuDC","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\n\r\nexport class SkeletonServer extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (public readonly config: IJsFixConfig,\r\n public readonly dropConnectionTimeout: number) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n // dispatch messages\r\n switch (msgType) {\r\n default: {\r\n this.logger.info(`received message type ${msgType}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`peer logs in user ${user}`)\r\n return true\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('onReady')\r\n if (this.dropConnectionTimeout > 0) {\r\n this.logger.info(`acceptor is ready for requests - drop connection in ${this.dropConnectionTimeout}`)\r\n setTimeout(() => {\r\n setImmediate(() => {\r\n this.logger.info(`kill transport`)\r\n this.stop(new Error(`loss of tcp. ${this.me}`))\r\n })\r\n }, this.dropConnectionTimeout * 1000)\r\n } else {\r\n this.logger.info(`acceptor is ready for requests`)\r\n }\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n}\r\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/skeleton/app.ts"],"names":[],"mappings":";;AACA,6CAAyC;AACzC,yDAAoD;AACpD,kDAAwD;AAExD,MAAM,WAAY,SAAQ,mBAAQ;IAChC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAES,WAAW,CAAE,MAAoB;QACzC,OAAO,oBAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,kCAAe,CAAC,CAAC,CAAC,CAAC,CAAA;IACtD,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,qBAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,kCAAe,CAAC,CAAC,CAAC,CAAC,CAAA;IACvD,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAA","sourcesContent":["import { IJsFixConfig } from '../../../config'\r\nimport { Launcher } from '../../launcher'\r\nimport { SkeletonSession } from './skeleton-session'\r\nimport { initiator, acceptor } from '../../../transport'\r\n\r\nclass AppLauncher extends Launcher {\r\n public constructor () {\r\n super(\r\n 'data/session/test-initiator.json',\r\n 'data/session/test-acceptor.json')\r\n }\r\n\r\n protected getAcceptor (config: IJsFixConfig): Promise<any> {\r\n return acceptor(config, c => new SkeletonSession(c))\r\n }\r\n\r\n protected getInitiator (config: IJsFixConfig): Promise<any> {\r\n return initiator(config, c => new SkeletonSession(c))\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.run().then(() => {\r\n console.log('finished.')\r\n})\r\n"]}
|
|
1
|
+
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/skeleton/app.ts"],"names":[],"mappings":";;AACA,6CAAyC;AACzC,yDAAoD;AACpD,kDAAwD;AAExD,MAAM,WAAY,SAAQ,mBAAQ;IAChC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAES,WAAW,CAAE,MAAoB;QACzC,OAAO,oBAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,kCAAe,CAAC,CAAC,CAAC,CAAC,CAAA;IACtD,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,qBAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,kCAAe,CAAC,CAAC,CAAC,CAAC,CAAA;IACvD,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAQ,EAAE,EAAE;IACpB,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,OAAO,CAAC,CAAA;AACxB,CAAC,CAAC,CAAA","sourcesContent":["import { IJsFixConfig } from '../../../config'\r\nimport { Launcher } from '../../launcher'\r\nimport { SkeletonSession } from './skeleton-session'\r\nimport { initiator, acceptor } from '../../../transport'\r\n\r\nclass AppLauncher extends Launcher {\r\n public constructor () {\r\n super(\r\n 'data/session/test-initiator.json',\r\n 'data/session/test-acceptor.json')\r\n }\r\n\r\n protected getAcceptor (config: IJsFixConfig): Promise<any> {\r\n return acceptor(config, c => new SkeletonSession(c))\r\n }\r\n\r\n protected getInitiator (config: IJsFixConfig): Promise<any> {\r\n return initiator(config, c => new SkeletonSession(c))\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.run().then(() => {\r\n console.log('finished.')\r\n}).catch((e: Error) => {\r\n console.log(e.message)\r\n})\r\n"]}
|
|
@@ -1,13 +1,17 @@
|
|
|
1
1
|
import { MsgView } from '../../../buffer';
|
|
2
2
|
import { AsciiSession } from '../../../transport';
|
|
3
3
|
import { IJsFixConfig } from '../../../config';
|
|
4
|
+
import { ILooseObject } from '../../../collections/collection';
|
|
4
5
|
export declare class SkeletonSession extends AsciiSession {
|
|
5
6
|
readonly config: IJsFixConfig;
|
|
6
7
|
readonly logoutSeconds: number;
|
|
8
|
+
useInMemoryStore: boolean;
|
|
7
9
|
private readonly logger;
|
|
8
10
|
private readonly fixLog;
|
|
9
|
-
constructor(config: IJsFixConfig, logoutSeconds?: number);
|
|
11
|
+
constructor(config: IJsFixConfig, logoutSeconds?: number, useInMemoryStore?: boolean);
|
|
10
12
|
protected onApplicationMsg(msgType: string, view: MsgView): void;
|
|
13
|
+
private dispatch;
|
|
14
|
+
sendMessage(msgType: string, obj: ILooseObject): void;
|
|
11
15
|
protected onDecoded(msgType: string, txt: string): void;
|
|
12
16
|
protected onEncoded(msgType: string, txt: string): void;
|
|
13
17
|
protected onLogon(view: MsgView, user: string, password: string): boolean;
|
|
@@ -3,27 +3,46 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.SkeletonSession = void 0;
|
|
4
4
|
const transport_1 = require("../../../transport");
|
|
5
5
|
class SkeletonSession extends transport_1.AsciiSession {
|
|
6
|
-
constructor(config, logoutSeconds = 45) {
|
|
6
|
+
constructor(config, logoutSeconds = 45, useInMemoryStore = false) {
|
|
7
7
|
super(config);
|
|
8
8
|
this.config = config;
|
|
9
9
|
this.logoutSeconds = logoutSeconds;
|
|
10
|
+
this.useInMemoryStore = useInMemoryStore;
|
|
10
11
|
this.logReceivedMsgs = true;
|
|
11
12
|
this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`);
|
|
12
13
|
this.logger = config.logFactory.logger(`${this.me}`);
|
|
13
14
|
}
|
|
14
15
|
onApplicationMsg(msgType, view) {
|
|
16
|
+
if (this.useInMemoryStore) {
|
|
17
|
+
const rec = view.toMsgStoreRecord();
|
|
18
|
+
this.store.put(rec).then(r => {
|
|
19
|
+
this.logger.info(`store state ${JSON.stringify(r, null, 4)}`);
|
|
20
|
+
this.dispatch(msgType, view);
|
|
21
|
+
}).catch(e => {
|
|
22
|
+
this.logger.error(e);
|
|
23
|
+
});
|
|
24
|
+
}
|
|
25
|
+
else {
|
|
26
|
+
this.dispatch(msgType, view);
|
|
27
|
+
}
|
|
28
|
+
}
|
|
29
|
+
dispatch(msgType, view) {
|
|
30
|
+
const o = view.toObject();
|
|
15
31
|
switch (msgType) {
|
|
16
32
|
default: {
|
|
17
|
-
this.logger.info(`received message type ${msgType}`);
|
|
33
|
+
this.logger.info(`received message type ${msgType} ${JSON.stringify(o, null, 4)}`);
|
|
18
34
|
break;
|
|
19
35
|
}
|
|
20
36
|
}
|
|
21
37
|
}
|
|
38
|
+
sendMessage(msgType, obj) {
|
|
39
|
+
this.send(msgType, obj);
|
|
40
|
+
}
|
|
22
41
|
onDecoded(msgType, txt) {
|
|
23
42
|
this.fixLog.info(txt);
|
|
24
43
|
}
|
|
25
44
|
onEncoded(msgType, txt) {
|
|
26
|
-
this.fixLog.info(
|
|
45
|
+
this.fixLog.info(txt);
|
|
27
46
|
}
|
|
28
47
|
onLogon(view, user, password) {
|
|
29
48
|
this.logger.info(`peer logs in user ${user}`);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"skeleton-session.js","sourceRoot":"","sources":["../../../../src/sample/tcp/skeleton/skeleton-session.ts"],"names":[],"mappings":";;;AACA,kDAAiD;
|
|
1
|
+
{"version":3,"file":"skeleton-session.js","sourceRoot":"","sources":["../../../../src/sample/tcp/skeleton/skeleton-session.ts"],"names":[],"mappings":"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","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\nimport { ILooseObject } from '../../../collections/collection'\r\n\r\nexport class SkeletonSession extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (public readonly config: IJsFixConfig,\r\n public readonly logoutSeconds: number = 45,\r\n public useInMemoryStore: boolean = false) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n // dispatch messages\r\n if (this.useInMemoryStore) {\r\n const rec = view.toMsgStoreRecord()\r\n this.store.put(rec).then(r => {\r\n this.logger.info(`store state ${JSON.stringify(r, null, 4)}`)\r\n this.dispatch(msgType, view)\r\n }).catch(e => {\r\n this.logger.error(e)\r\n })\r\n } else {\r\n this.dispatch(msgType, view)\r\n }\r\n }\r\n\r\n private dispatch (msgType: string, view: MsgView) {\r\n const o = view.toObject()\r\n switch (msgType) {\r\n default: {\r\n this.logger.info(`received message type ${msgType} ${JSON.stringify(o, null, 4)}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n public sendMessage (msgType: string, obj: ILooseObject): void {\r\n this.send(msgType, obj)\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`peer logs in user ${user}`)\r\n return true\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('onReady')\r\n const logoutSeconds = this.logoutSeconds\r\n const t = this.config.description.application.type\r\n switch (t) {\r\n case 'initiator': {\r\n this.logger.info(`will logout after ${logoutSeconds}`)\r\n setTimeout(() => {\r\n this.done()\r\n }, logoutSeconds * 1000)\r\n break\r\n }\r\n\r\n case 'acceptor': {\r\n this.logger.info(`acceptor is ready for requests`)\r\n break\r\n }\r\n\r\n default: {\r\n this.logger.warning(`unknown type ${t}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n}\r\n"]}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
const trade_capture_1 = require("../
|
|
3
|
+
const trade_capture_1 = require("../trade-capture");
|
|
4
4
|
const launcher_1 = require("../../launcher");
|
|
5
5
|
const transport_1 = require("../../../transport");
|
|
6
6
|
class AppLauncher extends launcher_1.Launcher {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/tls-trade-capture/app.ts"],"names":[],"mappings":";;AAAA,oDAAyE;AAEzE,6CAAyC;AACzC,kDAAwD;AAExD,MAAM,WAAY,SAAQ,mBAAQ;IAChC;QACE,KAAK,CACH,sCAAsC,EACtC,qCAAqC,CAAC,CAAA;IAC1C,CAAC;IAES,WAAW,CAAE,MAAoB;QACzC,OAAO,oBAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;YAC1B,OAAO,IAAI,kCAAkB,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,qBAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;YAC3B,OAAO,IAAI,kCAAkB,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;IACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;AAClB,CAAC,CAAC,CAAA","sourcesContent":["import { TradeCaptureClient, TradeCaptureServer } from '../
|
|
1
|
+
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/tls-trade-capture/app.ts"],"names":[],"mappings":";;AAAA,oDAAyE;AAEzE,6CAAyC;AACzC,kDAAwD;AAExD,MAAM,WAAY,SAAQ,mBAAQ;IAChC;QACE,KAAK,CACH,sCAAsC,EACtC,qCAAqC,CAAC,CAAA;IAC1C,CAAC;IAES,WAAW,CAAE,MAAoB;QACzC,OAAO,oBAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;YAC1B,OAAO,IAAI,kCAAkB,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,qBAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE;YAC3B,OAAO,IAAI,kCAAkB,CAAC,CAAC,CAAC,CAAA;QAClC,CAAC,CAAC,CAAA;IACJ,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;IACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;AAClB,CAAC,CAAC,CAAA","sourcesContent":["import { TradeCaptureClient, TradeCaptureServer } from '../trade-capture'\r\nimport { IJsFixConfig } from '../../../config'\r\nimport { Launcher } from '../../launcher'\r\nimport { initiator, acceptor } from '../../../transport'\r\n\r\nclass AppLauncher extends Launcher {\r\n public constructor () {\r\n super(\r\n 'data/session/test-initiator-tls.json',\r\n 'data/session/test-acceptor-tls.json')\r\n }\r\n\r\n protected getAcceptor (config: IJsFixConfig): Promise<any> {\r\n return acceptor(config, c => {\r\n return new TradeCaptureServer(c)\r\n })\r\n }\r\n\r\n protected getInitiator (config: IJsFixConfig): Promise<any> {\r\n return initiator(config, c => {\r\n return new TradeCaptureClient(c)\r\n })\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.run().then(() => {\r\n console.log('finished.')\r\n}).catch(e => {\r\n console.error(e)\r\n})\r\n"]}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export {};
|
|
File without changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/
|
|
1
|
+
{"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/app.ts"],"names":[],"mappings":";;AAAA,iEAA2D;AAC3D,iEAA2D;AAE3D,6CAAyC;AACzC,kDAAwD;AAExD,MAAM,WAAY,SAAQ,mBAAQ;IAChC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAES,WAAW,CAAE,MAAoB;QACzC,OAAO,oBAAQ,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,yCAAkB,CAAC,CAAC,CAAC,CAAC,CAAA;IACzD,CAAC;IAES,YAAY,CAAE,MAAoB;QAC1C,OAAO,qBAAS,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,yCAAkB,CAAC,CAAC,CAAC,CAAC,CAAA;IAC1D,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE;IAChB,OAAO,CAAC,GAAG,CAAC,WAAW,CAAC,CAAA;AAC1B,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE;IACX,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;AAClB,CAAC,CAAC,CAAA","sourcesContent":["import { TradeCaptureClient } from './trade-capture-client'\r\nimport { TradeCaptureServer } from './trade-capture-server'\r\nimport { IJsFixConfig } from '../../../config'\r\nimport { Launcher } from '../../launcher'\r\nimport { initiator, acceptor } from '../../../transport'\r\n\r\nclass AppLauncher extends Launcher {\r\n public constructor () {\r\n super(\r\n 'data/session/test-initiator.json',\r\n 'data/session/test-acceptor.json')\r\n }\r\n\r\n protected getAcceptor (config: IJsFixConfig): Promise<any> {\r\n return acceptor(config, c => new TradeCaptureServer(c))\r\n }\r\n\r\n protected getInitiator (config: IJsFixConfig): Promise<any> {\r\n return initiator(config, c => new TradeCaptureClient(c))\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.run().then(() => {\r\n console.log('finished.')\r\n}).catch(e => {\r\n console.error(e)\r\n})\r\n"]}
|
|
File without changes
|
|
File without changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/sample/tcp/
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/index.ts"],"names":[],"mappings":";;;;;;;;;;;;AAAA,yDAAsC;AACtC,yDAAsC","sourcesContent":["export * from './trade-capture-client'\r\nexport * from './trade-capture-server'\r\n"]}
|
|
@@ -11,6 +11,7 @@ export declare class TradeCaptureClient extends AsciiSession {
|
|
|
11
11
|
protected onStopped(): void;
|
|
12
12
|
protected onDecoded(msgType: string, txt: string): void;
|
|
13
13
|
protected onEncoded(msgType: string, txt: string): void;
|
|
14
|
+
private logoutTimer;
|
|
14
15
|
protected onReady(view: MsgView): void;
|
|
15
16
|
protected onLogon(view: MsgView, user: string, password: string): boolean;
|
|
16
17
|
}
|
|
@@ -37,7 +37,12 @@ class TradeCaptureClient extends transport_1.AsciiSession {
|
|
|
37
37
|
this.fixLog.info(txt);
|
|
38
38
|
}
|
|
39
39
|
onEncoded(msgType, txt) {
|
|
40
|
-
this.fixLog.info(
|
|
40
|
+
this.fixLog.info(txt);
|
|
41
|
+
}
|
|
42
|
+
logoutTimer(logoutSeconds = 32) {
|
|
43
|
+
setTimeout(() => {
|
|
44
|
+
this.done();
|
|
45
|
+
}, logoutSeconds * 1000);
|
|
41
46
|
}
|
|
42
47
|
onReady(view) {
|
|
43
48
|
this.logger.info('ready');
|
|
@@ -45,11 +50,10 @@ class TradeCaptureClient extends transport_1.AsciiSession {
|
|
|
45
50
|
this.send(types_1.MsgType.TradeCaptureReportRequest, tcr);
|
|
46
51
|
const logoutSeconds = 32;
|
|
47
52
|
this.logger.info(`will logout after ${logoutSeconds}`);
|
|
48
|
-
|
|
49
|
-
this.done();
|
|
50
|
-
}, logoutSeconds * 1000);
|
|
53
|
+
this.logoutTimer();
|
|
51
54
|
}
|
|
52
55
|
onLogon(view, user, password) {
|
|
56
|
+
this.logger.info(`onLogon user ${user}`);
|
|
53
57
|
return true;
|
|
54
58
|
}
|
|
55
59
|
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trade-capture-client.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/trade-capture-client.ts"],"names":[],"mappings":"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","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { MsgType } from '../../../types'\r\nimport { ITradeCaptureReport, ITradeCaptureReportRequest, ITradeCaptureReportRequestAck } from '../../../types/FIX4.4/repo'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\nimport { Dictionary } from '../../../collections'\r\nimport { TradeFactory } from './trade-factory'\r\n\r\nexport class TradeCaptureClient extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n private reports: Dictionary<ITradeCaptureReport>\r\n\r\n constructor (public readonly config: IJsFixConfig) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.reports = new Dictionary<ITradeCaptureReport>()\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}:TradeCaptureClient`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n this.logger.info(`${view.toJson()}`)\r\n switch (msgType) {\r\n case MsgType.TradeCaptureReport: {\r\n // create an object and cast to the interface\r\n const tc: ITradeCaptureReport = view.toObject()\r\n this.reports.addUpdate(tc.TradeReportID, tc)\r\n this.logger.info(`[reports: ${this.reports.count()}] received tc ExecID = ${tc.ExecID} TradeReportID = ${tc.TradeReportID} Symbol = ${tc.Instrument.Symbol} ${tc.LastQty} @ ${tc.LastPx}`)\r\n break\r\n }\r\n\r\n case MsgType.TradeCaptureReportRequestAck: {\r\n const tc: ITradeCaptureReportRequestAck = view.toObject()\r\n this.logger.info(`received tcr ack ${tc.TradeRequestID} ${tc.TradeRequestStatus}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n private logoutTimer (logoutSeconds: number = 32) {\r\n setTimeout(() => {\r\n this.done()\r\n }, logoutSeconds * 1000)\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('ready')\r\n const tcr: ITradeCaptureReportRequest = TradeFactory.tradeCaptureReportRequest('all-trades', new Date())\r\n // send request to server\r\n this.send(MsgType.TradeCaptureReportRequest, tcr)\r\n const logoutSeconds = 32\r\n this.logger.info(`will logout after ${logoutSeconds}`)\r\n this.logoutTimer()\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`onLogon user ${user}`)\r\n return true\r\n }\r\n}\r\n"]}
|
|
File without changes
|
|
@@ -45,7 +45,7 @@ class TradeCaptureServer extends transport_1.AsciiSession {
|
|
|
45
45
|
this.fixLog.info(txt);
|
|
46
46
|
}
|
|
47
47
|
onEncoded(msgType, txt) {
|
|
48
|
-
this.fixLog.info(
|
|
48
|
+
this.fixLog.info(txt);
|
|
49
49
|
}
|
|
50
50
|
tradeCaptureReportRequest(tcr) {
|
|
51
51
|
this.logger.info(`received tcr ${tcr.TradeRequestID}`);
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"trade-capture-server.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/trade-capture-server.ts"],"names":[],"mappings":"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","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { MsgType } from '../../../types'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\n// interfaces generated by compiler to make messages easy in an IDE\r\nimport { ITradeCaptureReportRequest, ITradeCaptureReport, MsgTag, SessionRejectReason, SubscriptionRequestType, TradeRequestStatus } from '../../../types/FIX4.4/repo'\r\nimport { TradeFactory } from './trade-factory'\r\n\r\nexport class TradeCaptureServer extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n private readonly tradeFactory: TradeFactory = new TradeFactory()\r\n private timerHandle: NodeJS.Timer = null\r\n\r\n constructor (public readonly config: IJsFixConfig) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.logger = config.logFactory.logger(`${this.me}:TradeCaptureServer`)\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n this.logger.info(`${view.toJson()}`)\r\n switch (msgType) {\r\n case MsgType.TradeCaptureReportRequest: {\r\n this.tradeCaptureReportRequest(view.toObject())\r\n break\r\n }\r\n\r\n default: {\r\n const seqNum = view.getTyped(MsgTag.MsgSeqNum)\r\n this.send(msgType, this.config.factory.reject(msgType, seqNum, `${this.me}: unexpected msg type '${msgType}'`, SessionRejectReason.InvalidMsgType))\r\n break\r\n }\r\n }\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n // server waits for client to make a request\r\n this.logger.info('ready for requests.')\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n if (this.timerHandle) {\r\n clearInterval(this.timerHandle)\r\n }\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n return true\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n private tradeCaptureReportRequest (tcr: ITradeCaptureReportRequest): void {\r\n this.logger.info(`received tcr ${tcr.TradeRequestID}`)\r\n // send back an ack.\r\n this.send(MsgType.TradeCaptureReportRequestAck, TradeFactory.tradeCaptureReportRequestAck(tcr, TradeRequestStatus.Accepted))\r\n // send some trades\r\n const batch: ITradeCaptureReport[] = this.tradeFactory.batchOfTradeCaptureReport(5)\r\n batch.forEach((tc: ITradeCaptureReport) => {\r\n this.send(MsgType.TradeCaptureReport, tc)\r\n })\r\n this.send(MsgType.TradeCaptureReportRequestAck, TradeFactory.tradeCaptureReportRequestAck(tcr, TradeRequestStatus.Completed))\r\n // start sending the odd 'live' trade\r\n switch (tcr.SubscriptionRequestType) {\r\n case SubscriptionRequestType.SnapshotAndUpdates: {\r\n this.timerHandle = setInterval(() => {\r\n if (Math.random() < 0.4) {\r\n const tc: ITradeCaptureReport = this.tradeFactory.singleTradeCaptureReport()\r\n this.send(MsgType.TradeCaptureReport, tc)\r\n }\r\n }, 5000)\r\n break\r\n }\r\n }\r\n }\r\n}\r\n"]}
|
|
File without changes
|
|
File without changes
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"trade-factory.js","sourceRoot":"","sources":["../../../../src/sample/tcp/
|
|
1
|
+
{"version":3,"file":"trade-factory.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/trade-factory.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n OrdStatus,\r\n SubscriptionRequestType,\r\n TradeReportType,\r\n TradeRequestResult,\r\n TradeRequestStatus,\r\n TradeRequestType,\r\n TrdType,\r\n ITradeCaptureReportRequestAck,\r\n ITradeCaptureReport,\r\n ITradeCaptureReportRequest\r\n} from '../../../types/FIX4.4/repo'\r\n\r\nimport { TradeReportTransType } from '../../../types/FIXML50SP2'\r\n\r\nexport class TradeFactory {\r\n private nextTradeId: number = 100000\r\n private nextExecId: number = 600000\r\n private readonly securities: string[] =\r\n [\r\n 'Gold',\r\n 'Silver',\r\n 'Platinum',\r\n 'Magnesium',\r\n 'Steel'\r\n ]\r\n\r\n public static tradeCaptureReportRequestAck (tcr: ITradeCaptureReportRequest, status: TradeRequestStatus): ITradeCaptureReportRequestAck {\r\n // send back an ack.\r\n return {\r\n TradeRequestID: tcr.TradeRequestID,\r\n TradeRequestType: tcr.TradeRequestType,\r\n TradeRequestStatus: status,\r\n TradeRequestResult: TradeRequestResult.Successful\r\n } as ITradeCaptureReportRequestAck\r\n }\r\n\r\n public static tradeCaptureReportRequest (requestId: string, tradeDate: Date): ITradeCaptureReportRequest {\r\n return {\r\n TradeRequestID: 'all-trades',\r\n TradeRequestType: TradeRequestType.AllTrades,\r\n SubscriptionRequestType: SubscriptionRequestType.SnapshotAndUpdates,\r\n TrdCapDtGrp: [\r\n {\r\n TradeDate: tradeDate\r\n }\r\n ]\r\n } as ITradeCaptureReportRequest\r\n }\r\n\r\n private static getRandomInt (min: number, max: number) {\r\n min = Math.ceil(min)\r\n max = Math.floor(max)\r\n return Math.floor(Math.random() * (max - min)) + min\r\n }\r\n\r\n public batchOfTradeCaptureReport (toMake?: number): ITradeCaptureReport[] {\r\n if (!toMake) {\r\n toMake = TradeFactory.getRandomInt(4, 8)\r\n }\r\n const arr: ITradeCaptureReport[] = []\r\n for (let i: number = 0; i < toMake; ++i) {\r\n const tc: ITradeCaptureReport = this.singleTradeCaptureReport()\r\n arr.push(tc)\r\n }\r\n return arr\r\n }\r\n\r\n public singleTradeCaptureReport (): ITradeCaptureReport {\r\n const tradeReportId = this.nextTradeId++\r\n const qty: number = TradeFactory.getRandomInt(100, 200)\r\n const price: number = Math.round(Math.random() * 100 * 100) / 100\r\n const instrument: number = TradeFactory.getRandomInt(0, this.securities.length - 1)\r\n const securities = this.securities\r\n const execId = this.nextExecId++\r\n return {\r\n TradeReportID: tradeReportId.toString(),\r\n TradeReportTransType: TradeReportTransType.New,\r\n TradeReportType: TradeReportType.Submit,\r\n TrdType: TrdType.RegularTrade,\r\n TransactTime: new Date(),\r\n ExecID: execId.toString(),\r\n PreviouslyReported: false,\r\n OrdStatus: OrdStatus.Filled,\r\n Instrument: {\r\n SecurityID: `${securities[instrument]}.INC`,\r\n Symbol: `${securities[instrument]}`\r\n },\r\n TradeDate: new Date(),\r\n LastQty: qty,\r\n LastPx: price\r\n\r\n } as ITradeCaptureReport\r\n }\r\n}\r\n"]}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
1
|
import { IFixMsgStore } from './fix-msg-store';
|
|
2
2
|
import { IFixMsgStoreRecord } from './fix-msg-store-record';
|
|
3
3
|
import { IJsFixConfig } from '../config';
|
|
4
|
+
import { AsciiParser } from '../buffer';
|
|
4
5
|
export declare class FixMsgAsciiStoreResend {
|
|
5
6
|
readonly store: IFixMsgStore;
|
|
6
7
|
readonly config: IJsFixConfig;
|
|
8
|
+
parser: AsciiParser;
|
|
7
9
|
constructor(store: IFixMsgStore, config: IJsFixConfig);
|
|
8
|
-
getResendRequest(startSeq: number, endSeq: number): IFixMsgStoreRecord[]
|
|
10
|
+
getResendRequest(startSeq: number, endSeq: number): Promise<IFixMsgStoreRecord[]>;
|
|
11
|
+
private inflateRange;
|
|
9
12
|
gap(beginGap: number, seqNum: number, arr: IFixMsgStoreRecord[]): void;
|
|
10
|
-
|
|
13
|
+
inflate(record: IFixMsgStoreRecord): void;
|
|
14
|
+
sequenceResetGap(startGap: number, newSeq: number): IFixMsgStoreRecord;
|
|
11
15
|
}
|