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.
Files changed (602) hide show
  1. package/.travis.yml +1 -1
  2. package/README.md +48 -2
  3. package/appveyor.yml +43 -11
  4. package/data/FIX44-MD.xml +6596 -0
  5. package/data/examples/FIX.4.4/jsfix.test_client.txt +15 -13
  6. package/data/session/test-qf44-acceptor.json +21 -0
  7. package/data/session/test-qf44-initiator.json +22 -0
  8. package/dist/buffer/ascii/ascii-encoder.d.ts +9 -2
  9. package/dist/buffer/ascii/ascii-encoder.js +72 -31
  10. package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
  11. package/dist/buffer/ascii/ascii-parser.d.ts +1 -0
  12. package/dist/buffer/ascii/ascii-parser.js +7 -1
  13. package/dist/buffer/ascii/ascii-parser.js.map +1 -1
  14. package/dist/buffer/ascii/ascii-segment-parser.d.ts +0 -2
  15. package/dist/buffer/ascii/ascii-segment-parser.js +19 -25
  16. package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
  17. package/dist/buffer/ascii/ascii-view.d.ts +2 -0
  18. package/dist/buffer/ascii/ascii-view.js +4 -0
  19. package/dist/buffer/ascii/ascii-view.js.map +1 -1
  20. package/dist/buffer/ascii/time-formatter.js.map +1 -1
  21. package/dist/buffer/ascii-chars.d.ts +1 -0
  22. package/dist/buffer/ascii-chars.js +1 -0
  23. package/dist/buffer/ascii-chars.js.map +1 -1
  24. package/dist/buffer/elastic-buffer.d.ts +1 -0
  25. package/dist/buffer/elastic-buffer.js +8 -0
  26. package/dist/buffer/elastic-buffer.js.map +1 -1
  27. package/dist/buffer/encode-proxy.js.map +1 -1
  28. package/dist/buffer/fixml/fixml-encoder.d.ts +3 -0
  29. package/dist/buffer/fixml/fixml-encoder.js +6 -0
  30. package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
  31. package/dist/buffer/fixml/fixml-view.d.ts +2 -0
  32. package/dist/buffer/fixml/fixml-view.js +3 -0
  33. package/dist/buffer/fixml/fixml-view.js.map +1 -1
  34. package/dist/buffer/msg-encoder.d.ts +2 -0
  35. package/dist/buffer/msg-encoder.js.map +1 -1
  36. package/dist/buffer/msg-view.d.ts +2 -0
  37. package/dist/buffer/msg-view.js.map +1 -1
  38. package/dist/buffer/tags.js +5 -5
  39. package/dist/buffer/tags.js.map +1 -1
  40. package/dist/collections/dictionary.d.ts +1 -0
  41. package/dist/collections/dictionary.js +5 -0
  42. package/dist/collections/dictionary.js.map +1 -1
  43. package/dist/config/js-fix-config.d.ts +2 -0
  44. package/dist/config/js-fix-config.js +1 -0
  45. package/dist/config/js-fix-config.js.map +1 -1
  46. package/dist/dict-parser.js +2 -2
  47. package/dist/dict-parser.js.map +1 -1
  48. package/dist/dictionary/parser/quickfix/field-set-parser.js +11 -4
  49. package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
  50. package/dist/dictionary/parser/quickfix/message-parser.js +4 -0
  51. package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
  52. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -0
  53. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +15 -0
  54. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
  55. package/dist/jsfix-cmd.js +2 -1
  56. package/dist/jsfix-cmd.js.map +1 -1
  57. package/dist/sample/http/oms/app.js +2 -0
  58. package/dist/sample/http/oms/app.js.map +1 -1
  59. package/dist/sample/launcher.d.ts +3 -2
  60. package/dist/sample/launcher.js +12 -3
  61. package/dist/sample/launcher.js.map +1 -1
  62. package/dist/sample/tcp/{trade_capture → qf-md}/app.d.ts +0 -0
  63. package/dist/sample/tcp/qf-md/app.js +22 -0
  64. package/dist/sample/tcp/qf-md/app.js.map +1 -0
  65. package/dist/sample/tcp/qf-md/md-client.d.ts +15 -0
  66. package/dist/sample/tcp/qf-md/md-client.js +42 -0
  67. package/dist/sample/tcp/qf-md/md-client.js.map +1 -0
  68. package/dist/sample/tcp/qf-md/md-factory.d.ts +4 -0
  69. package/dist/sample/tcp/qf-md/md-factory.js +35 -0
  70. package/dist/sample/tcp/qf-md/md-factory.js.map +1 -0
  71. package/dist/sample/tcp/qf-md/md-server.d.ts +16 -0
  72. package/dist/sample/tcp/qf-md/md-server.js +44 -0
  73. package/dist/sample/tcp/qf-md/md-server.js.map +1 -0
  74. package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -0
  75. package/dist/sample/tcp/recovering-skeleton/app.js +27 -0
  76. package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -0
  77. package/dist/sample/tcp/recovering-skeleton/respawn-2.d.ts +2 -0
  78. package/dist/sample/tcp/recovering-skeleton/respawn-2.js +3 -0
  79. package/dist/sample/tcp/recovering-skeleton/respawn-2.js.map +1 -0
  80. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +7 -0
  81. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +52 -0
  82. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -0
  83. package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +16 -0
  84. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +45 -0
  85. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -0
  86. package/dist/sample/tcp/recovering-skeleton/skeleton-server.d.ts +16 -0
  87. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +52 -0
  88. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -0
  89. package/dist/sample/tcp/skeleton/app.js +2 -0
  90. package/dist/sample/tcp/skeleton/app.js.map +1 -1
  91. package/dist/sample/tcp/skeleton/skeleton-session.d.ts +5 -1
  92. package/dist/sample/tcp/skeleton/skeleton-session.js +22 -3
  93. package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
  94. package/dist/sample/tcp/tls-trade-capture/app.js +1 -1
  95. package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
  96. package/dist/sample/tcp/trade-capture/app.d.ts +1 -0
  97. package/dist/sample/tcp/{trade_capture → trade-capture}/app.js +0 -0
  98. package/dist/sample/tcp/{trade_capture → trade-capture}/app.js.map +1 -1
  99. package/dist/sample/tcp/{trade_capture → trade-capture}/index.d.ts +0 -0
  100. package/dist/sample/tcp/{trade_capture → trade-capture}/index.js +0 -0
  101. package/dist/sample/tcp/{trade_capture → trade-capture}/index.js.map +1 -1
  102. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.d.ts +1 -0
  103. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.js +8 -4
  104. package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -0
  105. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.d.ts +0 -0
  106. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.js +1 -1
  107. package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -0
  108. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.d.ts +0 -0
  109. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.js +0 -0
  110. package/dist/sample/tcp/{trade_capture → trade-capture}/trade-factory.js.map +1 -1
  111. package/dist/store/fix-msg-ascii-store-resend.d.ts +6 -2
  112. package/dist/store/fix-msg-ascii-store-resend.js +49 -22
  113. package/dist/store/fix-msg-ascii-store-resend.js.map +1 -1
  114. package/dist/store/fix-msg-memory-store.d.ts +11 -8
  115. package/dist/store/fix-msg-memory-store.js +108 -42
  116. package/dist/store/fix-msg-memory-store.js.map +1 -1
  117. package/dist/store/fix-msg-store-record.d.ts +7 -3
  118. package/dist/store/fix-msg-store-record.js +5 -1
  119. package/dist/store/fix-msg-store-record.js.map +1 -1
  120. package/dist/store/fix-msg-store.d.ts +13 -9
  121. package/dist/store/fix-msg-store.js.map +1 -1
  122. package/dist/test/ascii-encode.test.js +20 -3
  123. package/dist/test/ascii-encode.test.js.map +1 -1
  124. package/dist/test/ascii-encoder.test.d.ts +1 -0
  125. package/dist/test/ascii-encoder.test.js +505 -0
  126. package/dist/test/ascii-encoder.test.js.map +1 -0
  127. package/dist/test/ascii-parser.test.js +8 -6
  128. package/dist/test/ascii-parser.test.js.map +1 -1
  129. package/dist/test/ascii-segment.test.js +6 -5
  130. package/dist/test/ascii-segment.test.js.map +1 -1
  131. package/dist/test/ascii-store-replay.test.js +59 -44
  132. package/dist/test/ascii-store-replay.test.js.map +1 -1
  133. package/dist/test/logon.test.js +1 -1
  134. package/dist/test/logon.test.js.map +1 -1
  135. package/dist/test/memory-store.test.js +24 -19
  136. package/dist/test/memory-store.test.js.map +1 -1
  137. package/dist/test/qf-full-msg.test.js +19 -14
  138. package/dist/test/qf-full-msg.test.js.map +1 -1
  139. package/dist/test/repo-full-ascii-msg.test.js +17 -15
  140. package/dist/test/repo-full-ascii-msg.test.js.map +1 -1
  141. package/dist/test/repo-full-fixml-msg.test.js +14 -14
  142. package/dist/test/repo-full-fixml-msg.test.js.map +1 -1
  143. package/dist/test/session-state.test.js +2 -2
  144. package/dist/test/session-state.test.js.map +1 -1
  145. package/dist/test/session.test.js +263 -143
  146. package/dist/test/session.test.js.map +1 -1
  147. package/dist/test/view-decode.test.js +2 -1
  148. package/dist/test/view-decode.test.js.map +1 -1
  149. package/dist/transport/a-session-msg-factory.d.ts +23 -0
  150. package/dist/transport/a-session-msg-factory.js +58 -0
  151. package/dist/transport/a-session-msg-factory.js.map +1 -0
  152. package/dist/transport/ascii/ascii-msg-transmitter.d.ts +1 -0
  153. package/dist/transport/ascii/ascii-msg-transmitter.js +39 -8
  154. package/dist/transport/ascii/ascii-msg-transmitter.js.map +1 -1
  155. package/dist/transport/ascii/ascii-session-msg-factory.d.ts +16 -0
  156. package/dist/transport/ascii/ascii-session-msg-factory.js +47 -0
  157. package/dist/transport/ascii/ascii-session-msg-factory.js.map +1 -0
  158. package/dist/transport/ascii/ascii-session.d.ts +10 -2
  159. package/dist/transport/ascii/ascii-session.js +86 -31
  160. package/dist/transport/ascii/ascii-session.js.map +1 -1
  161. package/dist/transport/ascii/index.d.ts +1 -0
  162. package/dist/transport/ascii/index.js +1 -0
  163. package/dist/transport/ascii/index.js.map +1 -1
  164. package/dist/transport/ascii-session-msg-factory.d.ts +16 -0
  165. package/dist/transport/ascii-session-msg-factory.js +47 -0
  166. package/dist/transport/ascii-session-msg-factory.js.map +1 -0
  167. package/dist/transport/duplex/http-duplex.js +2 -2
  168. package/dist/transport/duplex/http-duplex.js.map +1 -1
  169. package/dist/transport/fix-msg-factory.d.ts +1 -1
  170. package/dist/transport/fix-msg-factory.js.map +1 -1
  171. package/dist/transport/fix-session-state.d.ts +38 -12
  172. package/dist/transport/fix-session-state.js +49 -15
  173. package/dist/transport/fix-session-state.js.map +1 -1
  174. package/dist/transport/fix-session.d.ts +13 -6
  175. package/dist/transport/fix-session.js +143 -39
  176. package/dist/transport/fix-session.js.map +1 -1
  177. package/dist/transport/fixml/fixml-session-msg-factory.d.ts +13 -0
  178. package/dist/transport/fixml/fixml-session-msg-factory.js +68 -0
  179. package/dist/transport/fixml/fixml-session-msg-factory.js.map +1 -0
  180. package/dist/transport/fixml/fixml-session.js +1 -1
  181. package/dist/transport/fixml/fixml-session.js.map +1 -1
  182. package/dist/transport/fixml/index.d.ts +2 -1
  183. package/dist/transport/fixml/index.js +2 -1
  184. package/dist/transport/fixml/index.js.map +1 -1
  185. package/dist/transport/fixml-session-msg-factory.d.ts +13 -0
  186. package/dist/transport/fixml-session-msg-factory.js +68 -0
  187. package/dist/transport/fixml-session-msg-factory.js.map +1 -0
  188. package/dist/transport/http/http-acceptor.js +8 -7
  189. package/dist/transport/http/http-acceptor.js.map +1 -1
  190. package/dist/transport/index.d.ts +1 -1
  191. package/dist/transport/index.js +1 -1
  192. package/dist/transport/index.js.map +1 -1
  193. package/dist/transport/msg-transmitter.js +4 -3
  194. package/dist/transport/msg-transmitter.js.map +1 -1
  195. package/dist/transport/msg-transport.js +3 -2
  196. package/dist/transport/msg-transport.js.map +1 -1
  197. package/dist/transport/session-description.d.ts +1 -1
  198. package/dist/transport/session-description.js.map +1 -1
  199. package/dist/transport/session-msg-factory.d.ts +2 -2
  200. package/dist/transport/session-msg-factory.js +2 -2
  201. package/dist/transport/session-msg-factory.js.map +1 -1
  202. package/dist/transport/tcp/acceptor.js +5 -3
  203. package/dist/transport/tcp/acceptor.js.map +1 -1
  204. package/dist/transport/tcp/index.d.ts +1 -0
  205. package/dist/transport/tcp/index.js +1 -0
  206. package/dist/transport/tcp/index.js.map +1 -1
  207. package/dist/transport/tcp/initiator.js +1 -0
  208. package/dist/transport/tcp/initiator.js.map +1 -1
  209. package/dist/transport/tcp/recovering-initiator.d.ts +17 -0
  210. package/dist/transport/tcp/recovering-initiator.js +30 -0
  211. package/dist/transport/tcp/recovering-initiator.js.map +1 -0
  212. package/dist/transport/tcp/recovering-tcp-initiator.d.ts +28 -0
  213. package/dist/transport/tcp/recovering-tcp-initiator.js +120 -0
  214. package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -0
  215. package/dist/transport/tcp/tcp-acceptor.d.ts +7 -0
  216. package/dist/transport/tcp/tcp-acceptor.js +43 -11
  217. package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
  218. package/dist/transport/tcp/tcp-initiator.d.ts +4 -0
  219. package/dist/transport/tcp/tcp-initiator.js +72 -35
  220. package/dist/transport/tcp/tcp-initiator.js.map +1 -1
  221. package/dist/types/FIX4.4/quickfix/advertisement.d.ts +4 -0
  222. package/dist/types/FIX4.4/quickfix/advertisement.js.map +1 -1
  223. package/dist/types/FIX4.4/quickfix/allocation_instruction.d.ts +4 -0
  224. package/dist/types/FIX4.4/quickfix/allocation_instruction.js.map +1 -1
  225. package/dist/types/FIX4.4/quickfix/allocation_instruction_ack.d.ts +4 -0
  226. package/dist/types/FIX4.4/quickfix/allocation_instruction_ack.js.map +1 -1
  227. package/dist/types/FIX4.4/quickfix/allocation_report.d.ts +4 -0
  228. package/dist/types/FIX4.4/quickfix/allocation_report.js.map +1 -1
  229. package/dist/types/FIX4.4/quickfix/allocation_report_ack.d.ts +4 -0
  230. package/dist/types/FIX4.4/quickfix/allocation_report_ack.js.map +1 -1
  231. package/dist/types/FIX4.4/quickfix/assignment_report.d.ts +4 -0
  232. package/dist/types/FIX4.4/quickfix/assignment_report.js.map +1 -1
  233. package/dist/types/FIX4.4/quickfix/bid_request.d.ts +4 -0
  234. package/dist/types/FIX4.4/quickfix/bid_request.js.map +1 -1
  235. package/dist/types/FIX4.4/quickfix/bid_response.d.ts +4 -0
  236. package/dist/types/FIX4.4/quickfix/bid_response.js.map +1 -1
  237. package/dist/types/FIX4.4/quickfix/business_message_reject.d.ts +4 -0
  238. package/dist/types/FIX4.4/quickfix/business_message_reject.js.map +1 -1
  239. package/dist/types/FIX4.4/quickfix/collateral_assignment.d.ts +4 -0
  240. package/dist/types/FIX4.4/quickfix/collateral_assignment.js.map +1 -1
  241. package/dist/types/FIX4.4/quickfix/collateral_inquiry.d.ts +4 -0
  242. package/dist/types/FIX4.4/quickfix/collateral_inquiry.js.map +1 -1
  243. package/dist/types/FIX4.4/quickfix/collateral_inquiry_ack.d.ts +4 -0
  244. package/dist/types/FIX4.4/quickfix/collateral_inquiry_ack.js.map +1 -1
  245. package/dist/types/FIX4.4/quickfix/collateral_report.d.ts +4 -0
  246. package/dist/types/FIX4.4/quickfix/collateral_report.js.map +1 -1
  247. package/dist/types/FIX4.4/quickfix/collateral_request.d.ts +4 -0
  248. package/dist/types/FIX4.4/quickfix/collateral_request.js.map +1 -1
  249. package/dist/types/FIX4.4/quickfix/collateral_response.d.ts +4 -0
  250. package/dist/types/FIX4.4/quickfix/collateral_response.js.map +1 -1
  251. package/dist/types/FIX4.4/quickfix/confirmation.d.ts +4 -0
  252. package/dist/types/FIX4.4/quickfix/confirmation.js.map +1 -1
  253. package/dist/types/FIX4.4/quickfix/confirmation_ack.d.ts +4 -0
  254. package/dist/types/FIX4.4/quickfix/confirmation_ack.js.map +1 -1
  255. package/dist/types/FIX4.4/quickfix/confirmation_request.d.ts +4 -0
  256. package/dist/types/FIX4.4/quickfix/confirmation_request.js.map +1 -1
  257. package/dist/types/FIX4.4/quickfix/cross_order_cancel_replace_request.d.ts +4 -0
  258. package/dist/types/FIX4.4/quickfix/cross_order_cancel_replace_request.js.map +1 -1
  259. package/dist/types/FIX4.4/quickfix/cross_order_cancel_request.d.ts +4 -0
  260. package/dist/types/FIX4.4/quickfix/cross_order_cancel_request.js.map +1 -1
  261. package/dist/types/FIX4.4/quickfix/derivative_security_list.d.ts +4 -0
  262. package/dist/types/FIX4.4/quickfix/derivative_security_list.js.map +1 -1
  263. package/dist/types/FIX4.4/quickfix/derivative_security_list_request.d.ts +4 -0
  264. package/dist/types/FIX4.4/quickfix/derivative_security_list_request.js.map +1 -1
  265. package/dist/types/FIX4.4/quickfix/dont_know_trade.d.ts +4 -0
  266. package/dist/types/FIX4.4/quickfix/dont_know_trade.js.map +1 -1
  267. package/dist/types/FIX4.4/quickfix/email.d.ts +4 -0
  268. package/dist/types/FIX4.4/quickfix/email.js.map +1 -1
  269. package/dist/types/FIX4.4/quickfix/execution_report.d.ts +4 -0
  270. package/dist/types/FIX4.4/quickfix/execution_report.js.map +1 -1
  271. package/dist/types/FIX4.4/quickfix/heartbeat.d.ts +4 -0
  272. package/dist/types/FIX4.4/quickfix/heartbeat.js.map +1 -1
  273. package/dist/types/FIX4.4/quickfix/index.d.ts +4 -0
  274. package/dist/types/FIX4.4/quickfix/index.js +4 -0
  275. package/dist/types/FIX4.4/quickfix/index.js.map +1 -1
  276. package/dist/types/FIX4.4/quickfix/ioi.d.ts +4 -0
  277. package/dist/types/FIX4.4/quickfix/ioi.js.map +1 -1
  278. package/dist/types/FIX4.4/quickfix/list_cancel_request.d.ts +4 -0
  279. package/dist/types/FIX4.4/quickfix/list_cancel_request.js.map +1 -1
  280. package/dist/types/FIX4.4/quickfix/list_execute.d.ts +4 -0
  281. package/dist/types/FIX4.4/quickfix/list_execute.js.map +1 -1
  282. package/dist/types/FIX4.4/quickfix/list_status.d.ts +4 -0
  283. package/dist/types/FIX4.4/quickfix/list_status.js.map +1 -1
  284. package/dist/types/FIX4.4/quickfix/list_status_request.d.ts +4 -0
  285. package/dist/types/FIX4.4/quickfix/list_status_request.js.map +1 -1
  286. package/dist/types/FIX4.4/quickfix/list_strike_price.d.ts +4 -0
  287. package/dist/types/FIX4.4/quickfix/list_strike_price.js.map +1 -1
  288. package/dist/types/FIX4.4/quickfix/logon.d.ts +4 -0
  289. package/dist/types/FIX4.4/quickfix/logon.js.map +1 -1
  290. package/dist/types/FIX4.4/quickfix/logout.d.ts +4 -0
  291. package/dist/types/FIX4.4/quickfix/logout.js.map +1 -1
  292. package/dist/types/FIX4.4/quickfix/market_data_incremental_refresh.d.ts +4 -0
  293. package/dist/types/FIX4.4/quickfix/market_data_incremental_refresh.js.map +1 -1
  294. package/dist/types/FIX4.4/quickfix/market_data_request.d.ts +4 -0
  295. package/dist/types/FIX4.4/quickfix/market_data_request.js.map +1 -1
  296. package/dist/types/FIX4.4/quickfix/market_data_request_reject.d.ts +4 -0
  297. package/dist/types/FIX4.4/quickfix/market_data_request_reject.js.map +1 -1
  298. package/dist/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.d.ts +4 -0
  299. package/dist/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.js.map +1 -1
  300. package/dist/types/FIX4.4/quickfix/mass_quote.d.ts +4 -0
  301. package/dist/types/FIX4.4/quickfix/mass_quote.js.map +1 -1
  302. package/dist/types/FIX4.4/quickfix/mass_quote_acknowledgement.d.ts +4 -0
  303. package/dist/types/FIX4.4/quickfix/mass_quote_acknowledgement.js.map +1 -1
  304. package/dist/types/FIX4.4/quickfix/multileg_order_cancel_replace.d.ts +4 -0
  305. package/dist/types/FIX4.4/quickfix/multileg_order_cancel_replace.js.map +1 -1
  306. package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_request.d.ts +4 -0
  307. package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_request.js.map +1 -1
  308. package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_response.d.ts +4 -0
  309. package/dist/types/FIX4.4/quickfix/network_counterparty_system_status_response.js.map +1 -1
  310. package/dist/types/FIX4.4/quickfix/new_order_cross.d.ts +4 -0
  311. package/dist/types/FIX4.4/quickfix/new_order_cross.js.map +1 -1
  312. package/dist/types/FIX4.4/quickfix/new_order_list.d.ts +4 -0
  313. package/dist/types/FIX4.4/quickfix/new_order_list.js.map +1 -1
  314. package/dist/types/FIX4.4/quickfix/new_order_multileg.d.ts +4 -0
  315. package/dist/types/FIX4.4/quickfix/new_order_multileg.js.map +1 -1
  316. package/dist/types/FIX4.4/quickfix/new_order_single.d.ts +4 -0
  317. package/dist/types/FIX4.4/quickfix/new_order_single.js.map +1 -1
  318. package/dist/types/FIX4.4/quickfix/news.d.ts +4 -0
  319. package/dist/types/FIX4.4/quickfix/news.js.map +1 -1
  320. package/dist/types/FIX4.4/quickfix/order_cancel_reject.d.ts +4 -0
  321. package/dist/types/FIX4.4/quickfix/order_cancel_reject.js.map +1 -1
  322. package/dist/types/FIX4.4/quickfix/order_cancel_replace_request.d.ts +4 -0
  323. package/dist/types/FIX4.4/quickfix/order_cancel_replace_request.js.map +1 -1
  324. package/dist/types/FIX4.4/quickfix/order_cancel_request.d.ts +4 -0
  325. package/dist/types/FIX4.4/quickfix/order_cancel_request.js.map +1 -1
  326. package/dist/types/FIX4.4/quickfix/order_mass_cancel_report.d.ts +4 -0
  327. package/dist/types/FIX4.4/quickfix/order_mass_cancel_report.js.map +1 -1
  328. package/dist/types/FIX4.4/quickfix/order_mass_cancel_request.d.ts +4 -0
  329. package/dist/types/FIX4.4/quickfix/order_mass_cancel_request.js.map +1 -1
  330. package/dist/types/FIX4.4/quickfix/order_mass_status_request.d.ts +4 -0
  331. package/dist/types/FIX4.4/quickfix/order_mass_status_request.js.map +1 -1
  332. package/dist/types/FIX4.4/quickfix/order_status_request.d.ts +4 -0
  333. package/dist/types/FIX4.4/quickfix/order_status_request.js.map +1 -1
  334. package/dist/types/FIX4.4/quickfix/position_maintenance_report.d.ts +4 -0
  335. package/dist/types/FIX4.4/quickfix/position_maintenance_report.js.map +1 -1
  336. package/dist/types/FIX4.4/quickfix/position_maintenance_request.d.ts +4 -0
  337. package/dist/types/FIX4.4/quickfix/position_maintenance_request.js.map +1 -1
  338. package/dist/types/FIX4.4/quickfix/position_report.d.ts +4 -0
  339. package/dist/types/FIX4.4/quickfix/position_report.js.map +1 -1
  340. package/dist/types/FIX4.4/quickfix/quote.d.ts +4 -0
  341. package/dist/types/FIX4.4/quickfix/quote.js.map +1 -1
  342. package/dist/types/FIX4.4/quickfix/quote_cancel.d.ts +4 -0
  343. package/dist/types/FIX4.4/quickfix/quote_cancel.js.map +1 -1
  344. package/dist/types/FIX4.4/quickfix/quote_request.d.ts +4 -0
  345. package/dist/types/FIX4.4/quickfix/quote_request.js.map +1 -1
  346. package/dist/types/FIX4.4/quickfix/quote_request_reject.d.ts +4 -0
  347. package/dist/types/FIX4.4/quickfix/quote_request_reject.js.map +1 -1
  348. package/dist/types/FIX4.4/quickfix/quote_response.d.ts +4 -0
  349. package/dist/types/FIX4.4/quickfix/quote_response.js.map +1 -1
  350. package/dist/types/FIX4.4/quickfix/quote_status_report.d.ts +4 -0
  351. package/dist/types/FIX4.4/quickfix/quote_status_report.js.map +1 -1
  352. package/dist/types/FIX4.4/quickfix/quote_status_request.d.ts +4 -0
  353. package/dist/types/FIX4.4/quickfix/quote_status_request.js.map +1 -1
  354. package/dist/types/FIX4.4/quickfix/registration_instructions.d.ts +4 -0
  355. package/dist/types/FIX4.4/quickfix/registration_instructions.js.map +1 -1
  356. package/dist/types/FIX4.4/quickfix/registration_instructions_response.d.ts +4 -0
  357. package/dist/types/FIX4.4/quickfix/registration_instructions_response.js.map +1 -1
  358. package/dist/types/FIX4.4/quickfix/reject.d.ts +4 -0
  359. package/dist/types/FIX4.4/quickfix/reject.js.map +1 -1
  360. package/dist/types/FIX4.4/quickfix/request_for_positions.d.ts +4 -0
  361. package/dist/types/FIX4.4/quickfix/request_for_positions.js.map +1 -1
  362. package/dist/types/FIX4.4/quickfix/request_for_positions_ack.d.ts +4 -0
  363. package/dist/types/FIX4.4/quickfix/request_for_positions_ack.js.map +1 -1
  364. package/dist/types/FIX4.4/quickfix/resend_request.d.ts +4 -0
  365. package/dist/types/FIX4.4/quickfix/resend_request.js.map +1 -1
  366. package/dist/types/FIX4.4/quickfix/rfq_request.d.ts +4 -0
  367. package/dist/types/FIX4.4/quickfix/rfq_request.js.map +1 -1
  368. package/dist/types/FIX4.4/quickfix/security_definition.d.ts +4 -0
  369. package/dist/types/FIX4.4/quickfix/security_definition.js.map +1 -1
  370. package/dist/types/FIX4.4/quickfix/security_definition_request.d.ts +4 -0
  371. package/dist/types/FIX4.4/quickfix/security_definition_request.js.map +1 -1
  372. package/dist/types/FIX4.4/quickfix/security_list.d.ts +4 -0
  373. package/dist/types/FIX4.4/quickfix/security_list.js.map +1 -1
  374. package/dist/types/FIX4.4/quickfix/security_list_request.d.ts +4 -0
  375. package/dist/types/FIX4.4/quickfix/security_list_request.js.map +1 -1
  376. package/dist/types/FIX4.4/quickfix/security_status.d.ts +4 -0
  377. package/dist/types/FIX4.4/quickfix/security_status.js.map +1 -1
  378. package/dist/types/FIX4.4/quickfix/security_status_request.d.ts +4 -0
  379. package/dist/types/FIX4.4/quickfix/security_status_request.js.map +1 -1
  380. package/dist/types/FIX4.4/quickfix/security_type_request.d.ts +4 -0
  381. package/dist/types/FIX4.4/quickfix/security_type_request.js.map +1 -1
  382. package/dist/types/FIX4.4/quickfix/security_types.d.ts +4 -0
  383. package/dist/types/FIX4.4/quickfix/security_types.js.map +1 -1
  384. package/dist/types/FIX4.4/quickfix/sequence_reset.d.ts +4 -0
  385. package/dist/types/FIX4.4/quickfix/sequence_reset.js.map +1 -1
  386. package/dist/types/FIX4.4/quickfix/set/header.d.ts +31 -0
  387. package/dist/types/FIX4.4/quickfix/set/header.js +3 -0
  388. package/dist/types/FIX4.4/quickfix/set/header.js.map +1 -0
  389. package/dist/types/FIX4.4/quickfix/set/hop.d.ts +4 -0
  390. package/dist/types/FIX4.4/quickfix/set/hop.js +3 -0
  391. package/dist/types/FIX4.4/quickfix/set/hop.js.map +1 -0
  392. package/dist/types/FIX4.4/quickfix/set/hop_no_hops.d.ts +5 -0
  393. package/dist/types/FIX4.4/quickfix/set/hop_no_hops.js +3 -0
  394. package/dist/types/FIX4.4/quickfix/set/hop_no_hops.js.map +1 -0
  395. package/dist/types/FIX4.4/quickfix/set/standard_header.d.ts +31 -0
  396. package/dist/types/FIX4.4/quickfix/set/standard_header.js +3 -0
  397. package/dist/types/FIX4.4/quickfix/set/standard_header.js.map +1 -0
  398. package/dist/types/FIX4.4/quickfix/set/standard_trailer.d.ts +6 -0
  399. package/dist/types/FIX4.4/quickfix/set/standard_trailer.js +3 -0
  400. package/dist/types/FIX4.4/quickfix/set/standard_trailer.js.map +1 -0
  401. package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +6 -0
  402. package/dist/types/FIX4.4/quickfix/set/trailer.js +3 -0
  403. package/dist/types/FIX4.4/quickfix/set/trailer.js.map +1 -0
  404. package/dist/types/FIX4.4/quickfix/settlement_instruction_request.d.ts +4 -0
  405. package/dist/types/FIX4.4/quickfix/settlement_instruction_request.js.map +1 -1
  406. package/dist/types/FIX4.4/quickfix/settlement_instructions.d.ts +4 -0
  407. package/dist/types/FIX4.4/quickfix/settlement_instructions.js.map +1 -1
  408. package/dist/types/FIX4.4/quickfix/test_request.d.ts +4 -0
  409. package/dist/types/FIX4.4/quickfix/test_request.js.map +1 -1
  410. package/dist/types/FIX4.4/quickfix/trade_capture_report.d.ts +4 -0
  411. package/dist/types/FIX4.4/quickfix/trade_capture_report.js.map +1 -1
  412. package/dist/types/FIX4.4/quickfix/trade_capture_report_ack.d.ts +4 -0
  413. package/dist/types/FIX4.4/quickfix/trade_capture_report_ack.js.map +1 -1
  414. package/dist/types/FIX4.4/quickfix/trade_capture_report_request.d.ts +4 -0
  415. package/dist/types/FIX4.4/quickfix/trade_capture_report_request.js.map +1 -1
  416. package/dist/types/FIX4.4/quickfix/trade_capture_report_request_ack.d.ts +4 -0
  417. package/dist/types/FIX4.4/quickfix/trade_capture_report_request_ack.js.map +1 -1
  418. package/dist/types/FIX4.4/quickfix/trading_session_status.d.ts +4 -0
  419. package/dist/types/FIX4.4/quickfix/trading_session_status.js.map +1 -1
  420. package/dist/types/FIX4.4/quickfix/trading_session_status_request.d.ts +4 -0
  421. package/dist/types/FIX4.4/quickfix/trading_session_status_request.js.map +1 -1
  422. package/dist/types/FIX4.4/quickfix/user_request.d.ts +4 -0
  423. package/dist/types/FIX4.4/quickfix/user_request.js.map +1 -1
  424. package/dist/types/FIX4.4/quickfix/user_response.d.ts +4 -0
  425. package/dist/types/FIX4.4/quickfix/user_response.js.map +1 -1
  426. package/dist/types/FIX4.4/quickfix/xm_lnon_fix.d.ts +4 -0
  427. package/dist/types/FIX4.4/quickfix/xm_lnon_fix.js.map +1 -1
  428. package/dist/types/FIX4.4/repo/enum/all-enum.js.map +1 -1
  429. package/package.json +25 -21
  430. package/script/build.sh +1 -0
  431. package/src/buffer/ascii/ascii-encoder.ts +110 -33
  432. package/src/buffer/ascii/ascii-parser.ts +8 -1
  433. package/src/buffer/ascii/ascii-segment-parser.ts +44 -38
  434. package/src/buffer/ascii/ascii-view.ts +5 -0
  435. package/src/buffer/ascii/time-formatter.ts +2 -2
  436. package/src/buffer/ascii-chars.ts +1 -0
  437. package/src/buffer/elastic-buffer.ts +9 -0
  438. package/src/buffer/encode-proxy.ts +2 -2
  439. package/src/buffer/fixml/fixml-encoder.ts +8 -0
  440. package/src/buffer/fixml/fixml-view.ts +5 -0
  441. package/src/buffer/msg-encoder.ts +2 -0
  442. package/src/buffer/msg-view.ts +3 -0
  443. package/src/buffer/tags.ts +1 -1
  444. package/src/collections/dictionary.ts +6 -0
  445. package/src/config/js-fix-config.ts +2 -0
  446. package/src/dictionary/parser/quickfix/field-set-parser.ts +11 -4
  447. package/src/dictionary/parser/quickfix/message-parser.ts +4 -0
  448. package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +16 -0
  449. package/src/jsfix-cmd.ts +2 -1
  450. package/src/sample/http/oms/app.ts +2 -0
  451. package/src/sample/launcher.ts +17 -7
  452. package/src/sample/tcp/qf-md/app.ts +26 -0
  453. package/src/sample/tcp/qf-md/md-client.ts +51 -0
  454. package/src/sample/tcp/qf-md/md-factory.ts +34 -0
  455. package/src/sample/tcp/qf-md/md-server.ts +56 -0
  456. package/src/sample/tcp/recovering-skeleton/app.ts +33 -0
  457. package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +41 -0
  458. package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +54 -0
  459. package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +60 -0
  460. package/src/sample/tcp/skeleton/app.ts +2 -0
  461. package/src/sample/tcp/skeleton/skeleton-session.ts +26 -4
  462. package/src/sample/tcp/tls-trade-capture/app.ts +1 -1
  463. package/src/sample/tcp/{trade_capture → trade-capture}/app.ts +0 -0
  464. package/src/sample/tcp/{trade_capture → trade-capture}/index.ts +0 -0
  465. package/src/sample/tcp/{trade_capture → trade-capture}/trade-capture-client.ts +10 -5
  466. package/src/sample/tcp/{trade_capture → trade-capture}/trade-capture-server.ts +2 -2
  467. package/src/sample/tcp/{trade_capture → trade-capture}/trade-factory.ts +0 -0
  468. package/src/store/fix-msg-ascii-store-resend.ts +87 -0
  469. package/src/store/fix-msg-memory-store.ts +171 -0
  470. package/src/store/fix-msg-store-record.ts +23 -0
  471. package/src/store/fix-msg-store.ts +23 -0
  472. package/src/store/index.ts +4 -0
  473. package/src/transport/a-session-msg-factory.ts +81 -0
  474. package/src/transport/ascii/ascii-msg-transmitter.ts +32 -11
  475. package/src/transport/ascii/ascii-session-msg-factory.ts +62 -0
  476. package/src/transport/ascii/ascii-session.ts +100 -36
  477. package/src/transport/ascii/index.ts +1 -0
  478. package/src/transport/duplex/http-duplex.ts +2 -2
  479. package/src/transport/fix-msg-factory.ts +1 -1
  480. package/src/transport/fix-session-state.ts +67 -15
  481. package/src/transport/fix-session.ts +156 -43
  482. package/src/transport/fixml/fixml-session-msg-factory.ts +76 -0
  483. package/src/transport/fixml/fixml-session.ts +1 -1
  484. package/src/transport/fixml/index.ts +2 -1
  485. package/src/transport/http/http-acceptor.ts +7 -6
  486. package/src/transport/index.ts +1 -1
  487. package/src/transport/msg-transmitter.ts +4 -3
  488. package/src/transport/msg-transport.ts +3 -2
  489. package/src/transport/session-description.ts +1 -1
  490. package/src/transport/tcp/acceptor.ts +5 -3
  491. package/src/transport/tcp/index.ts +1 -0
  492. package/src/transport/tcp/initiator.ts +1 -0
  493. package/src/transport/tcp/recovering-tcp-initiator.ts +149 -0
  494. package/src/transport/tcp/tcp-acceptor.ts +46 -11
  495. package/src/transport/tcp/tcp-initiator.ts +77 -40
  496. package/src/types/FIX4.4/quickfix/advertisement.ts +4 -0
  497. package/src/types/FIX4.4/quickfix/allocation_instruction.ts +4 -0
  498. package/src/types/FIX4.4/quickfix/allocation_instruction_ack.ts +4 -0
  499. package/src/types/FIX4.4/quickfix/allocation_report.ts +4 -0
  500. package/src/types/FIX4.4/quickfix/allocation_report_ack.ts +4 -0
  501. package/src/types/FIX4.4/quickfix/assignment_report.ts +4 -0
  502. package/src/types/FIX4.4/quickfix/bid_request.ts +4 -0
  503. package/src/types/FIX4.4/quickfix/bid_response.ts +4 -0
  504. package/src/types/FIX4.4/quickfix/business_message_reject.ts +5 -0
  505. package/src/types/FIX4.4/quickfix/collateral_assignment.ts +4 -0
  506. package/src/types/FIX4.4/quickfix/collateral_inquiry.ts +4 -0
  507. package/src/types/FIX4.4/quickfix/collateral_inquiry_ack.ts +4 -0
  508. package/src/types/FIX4.4/quickfix/collateral_report.ts +4 -0
  509. package/src/types/FIX4.4/quickfix/collateral_request.ts +4 -0
  510. package/src/types/FIX4.4/quickfix/collateral_response.ts +4 -0
  511. package/src/types/FIX4.4/quickfix/confirmation.ts +4 -0
  512. package/src/types/FIX4.4/quickfix/confirmation_ack.ts +5 -0
  513. package/src/types/FIX4.4/quickfix/confirmation_request.ts +4 -0
  514. package/src/types/FIX4.4/quickfix/cross_order_cancel_replace_request.ts +4 -0
  515. package/src/types/FIX4.4/quickfix/cross_order_cancel_request.ts +4 -0
  516. package/src/types/FIX4.4/quickfix/derivative_security_list.ts +4 -0
  517. package/src/types/FIX4.4/quickfix/derivative_security_list_request.ts +4 -0
  518. package/src/types/FIX4.4/quickfix/dont_know_trade.ts +4 -0
  519. package/src/types/FIX4.4/quickfix/email.ts +4 -0
  520. package/src/types/FIX4.4/quickfix/execution_report.ts +4 -0
  521. package/src/types/FIX4.4/quickfix/heartbeat.ts +5 -0
  522. package/src/types/FIX4.4/quickfix/index.ts +4 -0
  523. package/src/types/FIX4.4/quickfix/ioi.ts +4 -0
  524. package/src/types/FIX4.4/quickfix/list_cancel_request.ts +5 -0
  525. package/src/types/FIX4.4/quickfix/list_execute.ts +6 -1
  526. package/src/types/FIX4.4/quickfix/list_status.ts +4 -0
  527. package/src/types/FIX4.4/quickfix/list_status_request.ts +5 -0
  528. package/src/types/FIX4.4/quickfix/list_strike_price.ts +4 -0
  529. package/src/types/FIX4.4/quickfix/logon.ts +4 -0
  530. package/src/types/FIX4.4/quickfix/logout.ts +6 -1
  531. package/src/types/FIX4.4/quickfix/market_data_incremental_refresh.ts +4 -0
  532. package/src/types/FIX4.4/quickfix/market_data_request.ts +4 -0
  533. package/src/types/FIX4.4/quickfix/market_data_request_reject.ts +4 -0
  534. package/src/types/FIX4.4/quickfix/market_data_snapshot_full_refresh.ts +4 -0
  535. package/src/types/FIX4.4/quickfix/mass_quote.ts +4 -0
  536. package/src/types/FIX4.4/quickfix/mass_quote_acknowledgement.ts +4 -0
  537. package/src/types/FIX4.4/quickfix/multileg_order_cancel_replace.ts +4 -0
  538. package/src/types/FIX4.4/quickfix/network_counterparty_system_status_request.ts +4 -0
  539. package/src/types/FIX4.4/quickfix/network_counterparty_system_status_response.ts +4 -0
  540. package/src/types/FIX4.4/quickfix/new_order_cross.ts +4 -0
  541. package/src/types/FIX4.4/quickfix/new_order_list.ts +4 -0
  542. package/src/types/FIX4.4/quickfix/new_order_multileg.ts +4 -0
  543. package/src/types/FIX4.4/quickfix/new_order_single.ts +4 -0
  544. package/src/types/FIX4.4/quickfix/news.ts +4 -0
  545. package/src/types/FIX4.4/quickfix/order_cancel_reject.ts +5 -0
  546. package/src/types/FIX4.4/quickfix/order_cancel_replace_request.ts +4 -0
  547. package/src/types/FIX4.4/quickfix/order_cancel_request.ts +4 -0
  548. package/src/types/FIX4.4/quickfix/order_mass_cancel_report.ts +4 -0
  549. package/src/types/FIX4.4/quickfix/order_mass_cancel_request.ts +4 -0
  550. package/src/types/FIX4.4/quickfix/order_mass_status_request.ts +4 -0
  551. package/src/types/FIX4.4/quickfix/order_status_request.ts +4 -0
  552. package/src/types/FIX4.4/quickfix/position_maintenance_report.ts +4 -0
  553. package/src/types/FIX4.4/quickfix/position_maintenance_request.ts +4 -0
  554. package/src/types/FIX4.4/quickfix/position_report.ts +4 -0
  555. package/src/types/FIX4.4/quickfix/quote.ts +4 -0
  556. package/src/types/FIX4.4/quickfix/quote_cancel.ts +4 -0
  557. package/src/types/FIX4.4/quickfix/quote_request.ts +4 -0
  558. package/src/types/FIX4.4/quickfix/quote_request_reject.ts +4 -0
  559. package/src/types/FIX4.4/quickfix/quote_response.ts +4 -0
  560. package/src/types/FIX4.4/quickfix/quote_status_report.ts +4 -0
  561. package/src/types/FIX4.4/quickfix/quote_status_request.ts +4 -0
  562. package/src/types/FIX4.4/quickfix/registration_instructions.ts +4 -0
  563. package/src/types/FIX4.4/quickfix/registration_instructions_response.ts +4 -0
  564. package/src/types/FIX4.4/quickfix/reject.ts +6 -1
  565. package/src/types/FIX4.4/quickfix/request_for_positions.ts +4 -0
  566. package/src/types/FIX4.4/quickfix/request_for_positions_ack.ts +4 -0
  567. package/src/types/FIX4.4/quickfix/resend_request.ts +5 -0
  568. package/src/types/FIX4.4/quickfix/rfq_request.ts +4 -0
  569. package/src/types/FIX4.4/quickfix/security_definition.ts +4 -0
  570. package/src/types/FIX4.4/quickfix/security_definition_request.ts +4 -0
  571. package/src/types/FIX4.4/quickfix/security_list.ts +4 -0
  572. package/src/types/FIX4.4/quickfix/security_list_request.ts +4 -0
  573. package/src/types/FIX4.4/quickfix/security_status.ts +4 -0
  574. package/src/types/FIX4.4/quickfix/security_status_request.ts +4 -0
  575. package/src/types/FIX4.4/quickfix/security_type_request.ts +5 -0
  576. package/src/types/FIX4.4/quickfix/security_types.ts +4 -0
  577. package/src/types/FIX4.4/quickfix/sequence_reset.ts +5 -0
  578. package/src/types/FIX4.4/quickfix/set/hop.ts +5 -0
  579. package/src/types/FIX4.4/quickfix/set/hop_no_hops.ts +5 -0
  580. package/src/types/FIX4.4/quickfix/set/standard_header.ts +31 -0
  581. package/src/types/FIX4.4/quickfix/set/standard_trailer.ts +5 -0
  582. package/src/types/FIX4.4/quickfix/settlement_instruction_request.ts +4 -0
  583. package/src/types/FIX4.4/quickfix/settlement_instructions.ts +4 -0
  584. package/src/types/FIX4.4/quickfix/test_request.ts +5 -0
  585. package/src/types/FIX4.4/quickfix/trade_capture_report.ts +4 -0
  586. package/src/types/FIX4.4/quickfix/trade_capture_report_ack.ts +4 -0
  587. package/src/types/FIX4.4/quickfix/trade_capture_report_request.ts +4 -0
  588. package/src/types/FIX4.4/quickfix/trade_capture_report_request_ack.ts +4 -0
  589. package/src/types/FIX4.4/quickfix/trading_session_status.ts +5 -0
  590. package/src/types/FIX4.4/quickfix/trading_session_status_request.ts +5 -0
  591. package/src/types/FIX4.4/quickfix/user_request.ts +5 -0
  592. package/src/types/FIX4.4/quickfix/user_response.ts +5 -0
  593. package/src/types/FIX4.4/quickfix/xm_lnon_fix.ts +5 -0
  594. package/src/types/FIX4.4/repo/enum/all-enum.ts +0 -1
  595. package/dist/sample/tcp/tls-trade-capture/jsfix.test_client.txt +0 -77
  596. package/dist/sample/tcp/tls-trade-capture/jsfix.test_server.txt +0 -77
  597. package/dist/sample/tcp/trade_capture/jsfix.test_client.txt +0 -75
  598. package/dist/sample/tcp/trade_capture/jsfix.test_server.txt +0 -75
  599. package/dist/sample/tcp/trade_capture/trade-capture-client.js.map +0 -1
  600. package/dist/sample/tcp/trade_capture/trade-capture-server.js.map +0 -1
  601. package/src/transport/session-msg-factory.ts +0 -195
  602. 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,2 @@
1
+ declare class fffff {
2
+ }
@@ -0,0 +1,3 @@
1
+ class fffff {
2
+ }
3
+ //# sourceMappingURL=respawn-2.js.map
@@ -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,7 @@
1
+ import { IJsFixConfig } from '../../../config';
2
+ export declare class RespawnAcceptor {
3
+ readonly config: IJsFixConfig;
4
+ private readonly logger;
5
+ constructor(config: IJsFixConfig);
6
+ waitFor(respawns?: number): Promise<any>;
7
+ }
@@ -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"]}
@@ -17,5 +17,7 @@ class AppLauncher extends launcher_1.Launcher {
17
17
  const l = new AppLauncher();
18
18
  l.run().then(() => {
19
19
  console.log('finished.');
20
+ }).catch((e) => {
21
+ console.log(e.message);
20
22
  });
21
23
  //# sourceMappingURL=app.js.map
@@ -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(transport_1.AsciiSession.asPiped(txt));
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;AAGjD,MAAa,eAAgB,SAAQ,wBAAY;IAG/C,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,wBAAY,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAA;IAC7C,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,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,CAAA;QAClD,QAAQ,CAAC,EAAE;YACT,KAAK,WAAW,CAAC,CAAC;gBAChB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,aAAa,EAAE,CAAC,CAAA;gBACtD,UAAU,CAAC,GAAG,EAAE;oBACd,IAAI,CAAC,IAAI,EAAE,CAAA;gBACb,CAAC,EAAE,aAAa,GAAG,IAAI,CAAC,CAAA;gBACxB,MAAK;aACN;YAED,KAAK,UAAU,CAAC,CAAC;gBACf,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAA;gBAClD,MAAK;aACN;YAED,OAAO,CAAC,CAAC;gBACP,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAA;gBACxC,MAAK;aACN;SACF;IACH,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC7B,CAAC;CACF;AAhED,0CAgEC","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\n\r\nexport class SkeletonSession extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\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 // no delimiter substitution on transmit messages\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(AsciiSession.asPiped(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
+ {"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("../trade_capture");
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 '../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"]}
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 {};
@@ -1 +1 @@
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"]}
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"]}
@@ -1 +1 @@
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"]}
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(transport_1.AsciiSession.asPiped(txt));
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
- setTimeout(() => {
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"]}
@@ -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(transport_1.AsciiSession.asPiped(txt));
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"]}
@@ -1 +1 @@
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
+ {"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
- sequenceReset(newSeq: number): IFixMsgStoreRecord;
13
+ inflate(record: IFixMsgStoreRecord): void;
14
+ sequenceResetGap(startGap: number, newSeq: number): IFixMsgStoreRecord;
11
15
  }