jspurefix 1.4.1 → 2.0.3

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 (879) hide show
  1. package/.eslintrc.js +6 -0
  2. package/appveyor.yml +4 -0
  3. package/dist/buffer/{ascii-chars.d.ts → ascii/ascii-chars.d.ts} +0 -0
  4. package/dist/buffer/{ascii-chars.js → ascii/ascii-chars.js} +0 -0
  5. package/dist/buffer/ascii/ascii-chars.js.map +1 -0
  6. package/dist/buffer/ascii/ascii-encoder.d.ts +4 -2
  7. package/dist/buffer/ascii/ascii-encoder.js +54 -32
  8. package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
  9. package/dist/buffer/ascii/ascii-parser-state.d.ts +3 -10
  10. package/dist/buffer/ascii/ascii-parser-state.js +37 -25
  11. package/dist/buffer/ascii/ascii-parser-state.js.map +1 -1
  12. package/dist/buffer/ascii/ascii-parser.d.ts +7 -7
  13. package/dist/buffer/ascii/ascii-parser.js +50 -24
  14. package/dist/buffer/ascii/ascii-parser.js.map +1 -1
  15. package/dist/buffer/ascii/ascii-segment-parser.d.ts +2 -2
  16. package/dist/buffer/ascii/ascii-segment-parser.js +34 -13
  17. package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
  18. package/dist/buffer/ascii/ascii-view.d.ts +2 -4
  19. package/dist/buffer/ascii/ascii-view.js +11 -15
  20. package/dist/buffer/ascii/ascii-view.js.map +1 -1
  21. package/dist/buffer/ascii/index.d.ts +1 -0
  22. package/dist/buffer/ascii/index.js +1 -0
  23. package/dist/buffer/ascii/index.js.map +1 -1
  24. package/dist/buffer/ascii/parse-state.d.ts +8 -0
  25. package/dist/buffer/ascii/parse-state.js +13 -0
  26. package/dist/buffer/ascii/parse-state.js.map +1 -0
  27. package/dist/buffer/ascii/time-formatter.js +1 -1
  28. package/dist/buffer/ascii/time-formatter.js.map +1 -1
  29. package/dist/buffer/elastic-buffer.js +29 -8
  30. package/dist/buffer/elastic-buffer.js.map +1 -1
  31. package/dist/buffer/encode-proxy.d.ts +1 -1
  32. package/dist/buffer/encode-proxy.js +16 -17
  33. package/dist/buffer/encode-proxy.js.map +1 -1
  34. package/dist/buffer/fixml/fixml-encoder.d.ts +2 -1
  35. package/dist/buffer/fixml/fixml-encoder.js +43 -20
  36. package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
  37. package/dist/buffer/fixml/fixml-parser.js +47 -24
  38. package/dist/buffer/fixml/fixml-parser.js.map +1 -1
  39. package/dist/buffer/fixml/fixml-view.d.ts +2 -4
  40. package/dist/buffer/fixml/fixml-view.js +13 -16
  41. package/dist/buffer/fixml/fixml-view.js.map +1 -1
  42. package/dist/buffer/fixml/populated-attributes.d.ts +5 -0
  43. package/dist/buffer/fixml/populated-attributes.js +3 -0
  44. package/dist/buffer/fixml/populated-attributes.js.map +1 -0
  45. package/dist/buffer/index.d.ts +4 -8
  46. package/dist/buffer/index.js +4 -8
  47. package/dist/buffer/index.js.map +1 -1
  48. package/dist/buffer/msg-encoder.d.ts +2 -1
  49. package/dist/buffer/msg-encoder.js.map +1 -1
  50. package/dist/buffer/msg-view.d.ts +3 -5
  51. package/dist/buffer/msg-view.js +8 -5
  52. package/dist/buffer/msg-view.js.map +1 -1
  53. package/dist/buffer/{segment-description.d.ts → segment/segment-description.d.ts} +3 -10
  54. package/dist/buffer/{segment-description.js → segment/segment-description.js} +5 -13
  55. package/dist/buffer/segment/segment-description.js.map +1 -0
  56. package/dist/buffer/{segment-summary.d.ts → segment/segment-summary.d.ts} +0 -0
  57. package/dist/buffer/{segment-summary.js → segment/segment-summary.js} +0 -0
  58. package/dist/buffer/segment/segment-summary.js.map +1 -0
  59. package/dist/buffer/segment/segment-type.d.ts +8 -0
  60. package/dist/buffer/segment/segment-type.js +13 -0
  61. package/dist/buffer/segment/segment-type.js.map +1 -0
  62. package/dist/buffer/structure.d.ts +3 -3
  63. package/dist/buffer/structure.js +1 -1
  64. package/dist/buffer/structure.js.map +1 -1
  65. package/dist/buffer/{tag-pos.d.ts → tag/tag-pos.d.ts} +0 -0
  66. package/dist/buffer/{tag-pos.js → tag/tag-pos.js} +0 -0
  67. package/dist/buffer/tag/tag-pos.js.map +1 -0
  68. package/dist/buffer/tag/tag-type.d.ts +13 -0
  69. package/dist/buffer/tag/tag-type.js +18 -0
  70. package/dist/buffer/tag/tag-type.js.map +1 -0
  71. package/dist/buffer/{tags.d.ts → tag/tags.d.ts} +3 -14
  72. package/dist/buffer/{tags.js → tag/tags.js} +24 -37
  73. package/dist/buffer/tag/tags.js.map +1 -0
  74. package/dist/config/get-js-fx-logger.d.ts +4 -0
  75. package/dist/config/get-js-fx-logger.js +3 -0
  76. package/dist/config/get-js-fx-logger.js.map +1 -0
  77. package/dist/config/index.d.ts +1 -0
  78. package/dist/config/index.js +1 -0
  79. package/dist/config/index.js.map +1 -1
  80. package/dist/config/js-fix-config.d.ts +4 -1
  81. package/dist/config/js-fix-config.js +3 -3
  82. package/dist/config/js-fix-config.js.map +1 -1
  83. package/dist/config/js-fix-logger.d.ts +0 -3
  84. package/dist/config/js-fix-logger.js.map +1 -1
  85. package/dist/dict-parser.js +28 -23
  86. package/dist/dict-parser.js.map +1 -1
  87. package/dist/dictionary/compiler/compiler-type.js +7 -7
  88. package/dist/dictionary/compiler/compiler-type.js.map +1 -1
  89. package/dist/dictionary/compiler/enum-compiler.d.ts +1 -0
  90. package/dist/dictionary/compiler/enum-compiler.js +11 -1
  91. package/dist/dictionary/compiler/enum-compiler.js.map +1 -1
  92. package/dist/dictionary/compiler/msg-compiler.js +8 -6
  93. package/dist/dictionary/compiler/msg-compiler.js.map +1 -1
  94. package/dist/dictionary/contained/contained-component-field.js +2 -1
  95. package/dist/dictionary/contained/contained-component-field.js.map +1 -1
  96. package/dist/dictionary/contained/contained-field-dispatch.d.ts +1 -14
  97. package/dist/dictionary/contained/contained-field-dispatch.js +4 -4
  98. package/dist/dictionary/contained/contained-field-dispatch.js.map +1 -1
  99. package/dist/dictionary/contained/contained-field-dispatcher.d.ts +14 -0
  100. package/dist/dictionary/contained/contained-field-dispatcher.js +3 -0
  101. package/dist/dictionary/contained/contained-field-dispatcher.js.map +1 -0
  102. package/dist/dictionary/contained/contained-field-set.d.ts +1 -1
  103. package/dist/dictionary/contained/contained-field-set.js +12 -11
  104. package/dist/dictionary/contained/contained-field-set.js.map +1 -1
  105. package/dist/dictionary/contained/contained-field-type.d.ts +5 -0
  106. package/dist/dictionary/contained/contained-field-type.js +10 -0
  107. package/dist/dictionary/contained/contained-field-type.js.map +1 -0
  108. package/dist/dictionary/contained/contained-field.d.ts +1 -5
  109. package/dist/dictionary/contained/contained-field.js +1 -7
  110. package/dist/dictionary/contained/contained-field.js.map +1 -1
  111. package/dist/dictionary/contained/contained-group-field.js +2 -1
  112. package/dist/dictionary/contained/contained-group-field.js.map +1 -1
  113. package/dist/dictionary/contained/contained-simple-field.js +2 -1
  114. package/dist/dictionary/contained/contained-simple-field.js.map +1 -1
  115. package/dist/dictionary/{fields-dispatch.d.ts → contained/field-dispatcher.d.ts} +3 -2
  116. package/dist/dictionary/contained/field-dispatcher.js +3 -0
  117. package/dist/dictionary/contained/field-dispatcher.js.map +1 -0
  118. package/dist/dictionary/contained/fields-dispatch.d.ts +6 -0
  119. package/dist/dictionary/contained/fields-dispatch.js +42 -0
  120. package/dist/dictionary/contained/fields-dispatch.js.map +1 -0
  121. package/dist/dictionary/contained/index.d.ts +2 -0
  122. package/dist/dictionary/contained/index.js +2 -0
  123. package/dist/dictionary/contained/index.js.map +1 -1
  124. package/dist/dictionary/contained-set-type.d.ts +5 -0
  125. package/dist/dictionary/contained-set-type.js +10 -0
  126. package/dist/dictionary/contained-set-type.js.map +1 -0
  127. package/dist/dictionary/definition/component-field-definition.js +2 -2
  128. package/dist/dictionary/definition/component-field-definition.js.map +1 -1
  129. package/dist/dictionary/definition/fix-definitions.d.ts +2 -1
  130. package/dist/dictionary/definition/fix-definitions.js.map +1 -1
  131. package/dist/dictionary/definition/group-field-definition.js +2 -2
  132. package/dist/dictionary/definition/group-field-definition.js.map +1 -1
  133. package/dist/dictionary/definition/index.d.ts +0 -1
  134. package/dist/dictionary/definition/index.js +0 -1
  135. package/dist/dictionary/definition/index.js.map +1 -1
  136. package/dist/dictionary/definition/message-definition.js +2 -2
  137. package/dist/dictionary/definition/message-definition.js.map +1 -1
  138. package/dist/dictionary/definition/simple-field-definition.d.ts +1 -1
  139. package/dist/dictionary/definition/simple-field-definition.js +5 -4
  140. package/dist/dictionary/definition/simple-field-definition.js.map +1 -1
  141. package/dist/dictionary/dict-primitive.d.ts +0 -11
  142. package/dist/dictionary/dict-primitive.js +0 -7
  143. package/dist/dictionary/dict-primitive.js.map +1 -1
  144. package/dist/dictionary/fix-definition-source.d.ts +6 -0
  145. package/dist/dictionary/fix-definition-source.js +11 -0
  146. package/dist/dictionary/fix-definition-source.js.map +1 -0
  147. package/dist/dictionary/fix-versions.d.ts +0 -9
  148. package/dist/dictionary/fix-versions.js +1 -39
  149. package/dist/dictionary/fix-versions.js.map +1 -1
  150. package/dist/dictionary/index.d.ts +1 -5
  151. package/dist/dictionary/index.js +1 -5
  152. package/dist/dictionary/index.js.map +1 -1
  153. package/dist/dictionary/parser/fix-repository/abbreviations-parser.d.ts +1 -3
  154. package/dist/dictionary/parser/fix-repository/abbreviations-parser.js +2 -3
  155. package/dist/dictionary/parser/fix-repository/abbreviations-parser.js.map +1 -1
  156. package/dist/dictionary/parser/fix-repository/base-parser.d.ts +2 -4
  157. package/dist/dictionary/parser/fix-repository/base-parser.js +1 -2
  158. package/dist/dictionary/parser/fix-repository/base-parser.js.map +1 -1
  159. package/dist/dictionary/parser/fix-repository/components-parser.d.ts +1 -3
  160. package/dist/dictionary/parser/fix-repository/components-parser.js +2 -3
  161. package/dist/dictionary/parser/fix-repository/components-parser.js.map +1 -1
  162. package/dist/dictionary/parser/fix-repository/data-types-parser.d.ts +1 -3
  163. package/dist/dictionary/parser/fix-repository/data-types-parser.js +2 -3
  164. package/dist/dictionary/parser/fix-repository/data-types-parser.js.map +1 -1
  165. package/dist/dictionary/parser/fix-repository/enums-parser.d.ts +1 -3
  166. package/dist/dictionary/parser/fix-repository/enums-parser.js +2 -3
  167. package/dist/dictionary/parser/fix-repository/enums-parser.js.map +1 -1
  168. package/dist/dictionary/parser/fix-repository/fields-parser.d.ts +1 -3
  169. package/dist/dictionary/parser/fix-repository/fields-parser.js +2 -3
  170. package/dist/dictionary/parser/fix-repository/fields-parser.js.map +1 -1
  171. package/dist/dictionary/parser/fix-repository/messages-parser.d.ts +1 -3
  172. package/dist/dictionary/parser/fix-repository/messages-parser.js +2 -3
  173. package/dist/dictionary/parser/fix-repository/messages-parser.js.map +1 -1
  174. package/dist/dictionary/parser/fix-repository/msg-contents-parser.d.ts +1 -3
  175. package/dist/dictionary/parser/fix-repository/msg-contents-parser.js +2 -3
  176. package/dist/dictionary/parser/fix-repository/msg-contents-parser.js.map +1 -1
  177. package/dist/dictionary/parser/fix-repository/repository-abbreviation.d.ts +5 -0
  178. package/dist/dictionary/parser/fix-repository/repository-abbreviation.js +3 -0
  179. package/dist/dictionary/parser/fix-repository/repository-abbreviation.js.map +1 -0
  180. package/dist/dictionary/parser/fix-repository/repository-component.d.ts +10 -0
  181. package/dist/dictionary/parser/fix-repository/repository-component.js +3 -0
  182. package/dist/dictionary/parser/fix-repository/repository-component.js.map +1 -0
  183. package/dist/dictionary/parser/fix-repository/repository-data-type.d.ts +6 -0
  184. package/dist/dictionary/parser/fix-repository/repository-data-type.js +3 -0
  185. package/dist/dictionary/parser/fix-repository/repository-data-type.js.map +1 -0
  186. package/dist/dictionary/parser/fix-repository/repository-enum.d.ts +7 -0
  187. package/dist/{transport/fix-msg-factory.js → dictionary/parser/fix-repository/repository-enum.js} +1 -1
  188. package/dist/dictionary/parser/fix-repository/repository-enum.js.map +1 -0
  189. package/dist/dictionary/parser/fix-repository/repository-field.d.ts +11 -0
  190. package/dist/dictionary/parser/fix-repository/repository-field.js +3 -0
  191. package/dist/dictionary/parser/fix-repository/repository-field.js.map +1 -0
  192. package/dist/dictionary/parser/fix-repository/repository-message.d.ts +11 -0
  193. package/dist/{transport/make-fixl-session.js → dictionary/parser/fix-repository/repository-message.js} +1 -1
  194. package/dist/dictionary/parser/fix-repository/repository-message.js.map +1 -0
  195. package/dist/dictionary/parser/fix-repository/repository-msg-content.d.ts +9 -0
  196. package/dist/dictionary/parser/fix-repository/repository-msg-content.js +3 -0
  197. package/dist/dictionary/parser/fix-repository/repository-msg-content.js.map +1 -0
  198. package/dist/dictionary/parser/fix-repository/repository-type.d.ts +0 -53
  199. package/dist/dictionary/parser/fix-repository/repository-type.js +0 -2
  200. package/dist/dictionary/parser/fix-repository/repository-type.js.map +1 -1
  201. package/dist/dictionary/parser/fix-repository/repository-xml-parser.js +10 -10
  202. package/dist/dictionary/parser/fix-repository/repository-xml-parser.js.map +1 -1
  203. package/dist/dictionary/parser/fix-repository/repository.d.ts +12 -1
  204. package/dist/dictionary/parser/fix-repository/repository.js +50 -28
  205. package/dist/dictionary/parser/fix-repository/repository.js.map +1 -1
  206. package/dist/dictionary/parser/fixml/components-parser.d.ts +1 -1
  207. package/dist/dictionary/parser/fixml/components-parser.js.map +1 -1
  208. package/dist/dictionary/parser/fixml/fields-parser.d.ts +1 -1
  209. package/dist/dictionary/parser/fixml/fields-parser.js.map +1 -1
  210. package/dist/dictionary/parser/fixml/fix-xsd-parser.js +3 -2
  211. package/dist/dictionary/parser/fixml/fix-xsd-parser.js.map +1 -1
  212. package/dist/dictionary/parser/fixml/include-graph.js.map +1 -1
  213. package/dist/dictionary/parser/fixml/xsd-parser.d.ts +1 -1
  214. package/dist/dictionary/parser/fixml/xsd-parser.js.map +1 -1
  215. package/dist/dictionary/parser/quickfix/field-definition-parser.d.ts +4 -4
  216. package/dist/dictionary/parser/quickfix/field-definition-parser.js +3 -3
  217. package/dist/dictionary/parser/quickfix/field-definition-parser.js.map +1 -1
  218. package/dist/dictionary/parser/quickfix/field-set-parser.d.ts +4 -4
  219. package/dist/dictionary/parser/quickfix/field-set-parser.js +3 -3
  220. package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
  221. package/dist/dictionary/parser/quickfix/message-parser.d.ts +4 -4
  222. package/dist/dictionary/parser/quickfix/message-parser.js +3 -3
  223. package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
  224. package/dist/dictionary/parser/quickfix/node-parser.d.ts +4 -5
  225. package/dist/dictionary/parser/quickfix/node-parser.js +4 -4
  226. package/dist/dictionary/parser/quickfix/node-parser.js.map +1 -1
  227. package/dist/dictionary/parser/quickfix/parse-state.d.ts +8 -0
  228. package/dist/dictionary/parser/quickfix/parse-state.js +13 -0
  229. package/dist/dictionary/parser/quickfix/parse-state.js.map +1 -0
  230. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -9
  231. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +28 -35
  232. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
  233. package/dist/dictionary/sax-node.d.ts +6 -0
  234. package/dist/{types/FIX4.4/quickfix/set/trailer.js → dictionary/sax-node.js} +1 -1
  235. package/dist/dictionary/sax-node.js.map +1 -0
  236. package/dist/dictionary/set-reduce.d.ts +5 -12
  237. package/dist/dictionary/set-reduce.js +28 -26
  238. package/dist/dictionary/set-reduce.js.map +1 -1
  239. package/dist/dictionary/type-dispatcher.d.ts +12 -0
  240. package/dist/dictionary/type-dispatcher.js +3 -0
  241. package/dist/dictionary/type-dispatcher.js.map +1 -0
  242. package/dist/dictionary/version-util.d.ts +4 -0
  243. package/dist/dictionary/version-util.js +36 -0
  244. package/dist/dictionary/version-util.js.map +1 -0
  245. package/dist/index.d.ts +1 -0
  246. package/dist/index.js +1 -0
  247. package/dist/index.js.map +1 -1
  248. package/dist/jsfix-cmd.d.ts +5 -0
  249. package/dist/jsfix-cmd.js +28 -21
  250. package/dist/jsfix-cmd.js.map +1 -1
  251. package/dist/runtime/di-tokens.d.ts +28 -0
  252. package/dist/runtime/di-tokens.js +33 -0
  253. package/dist/runtime/di-tokens.js.map +1 -0
  254. package/dist/runtime/engine-factory.d.ts +4 -0
  255. package/dist/runtime/engine-factory.js +3 -0
  256. package/dist/runtime/engine-factory.js.map +1 -0
  257. package/dist/runtime/index.d.ts +5 -0
  258. package/dist/runtime/index.js +18 -0
  259. package/dist/runtime/index.js.map +1 -0
  260. package/dist/runtime/make-config.d.ts +11 -0
  261. package/dist/runtime/make-config.js +57 -0
  262. package/dist/runtime/make-config.js.map +1 -0
  263. package/dist/runtime/session-container.d.ts +16 -0
  264. package/dist/runtime/session-container.js +168 -0
  265. package/dist/runtime/session-container.js.map +1 -0
  266. package/dist/runtime/session-launcher.d.ts +27 -0
  267. package/dist/runtime/session-launcher.js +131 -0
  268. package/dist/runtime/session-launcher.js.map +1 -0
  269. package/dist/sample/http/oms/app.d.ts +1 -1
  270. package/dist/sample/http/oms/app.js +16 -14
  271. package/dist/sample/http/oms/app.js.map +1 -1
  272. package/dist/sample/http/oms/http-client.js +22 -2
  273. package/dist/sample/http/oms/http-client.js.map +1 -1
  274. package/dist/sample/http/oms/http-server.js +21 -2
  275. package/dist/sample/http/oms/http-server.js.map +1 -1
  276. package/dist/sample/tcp/qf-md/app.d.ts +1 -1
  277. package/dist/sample/tcp/qf-md/app.js +11 -11
  278. package/dist/sample/tcp/qf-md/app.js.map +1 -1
  279. package/dist/sample/tcp/qf-md/md-client.js +21 -2
  280. package/dist/sample/tcp/qf-md/md-client.js.map +1 -1
  281. package/dist/sample/tcp/qf-md/md-server.js +20 -2
  282. package/dist/sample/tcp/qf-md/md-server.js.map +1 -1
  283. package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -1
  284. package/dist/sample/tcp/recovering-skeleton/app.js +36 -16
  285. package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -1
  286. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +3 -1
  287. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +30 -8
  288. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -1
  289. package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +1 -1
  290. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +22 -3
  291. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -1
  292. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +21 -2
  293. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -1
  294. package/dist/sample/tcp/skeleton/app.d.ts +1 -1
  295. package/dist/sample/tcp/skeleton/app.js +8 -13
  296. package/dist/sample/tcp/skeleton/app.js.map +1 -1
  297. package/dist/sample/tcp/skeleton/skeleton-session.d.ts +1 -1
  298. package/dist/sample/tcp/skeleton/skeleton-session.js +26 -4
  299. package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
  300. package/dist/sample/tcp/tls-trade-capture/app.d.ts +1 -1
  301. package/dist/sample/tcp/tls-trade-capture/app.js +4 -24
  302. package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
  303. package/dist/sample/tcp/trade-capture/app-launcher.d.ts +6 -0
  304. package/dist/sample/tcp/trade-capture/app-launcher.js +21 -0
  305. package/dist/sample/tcp/trade-capture/app-launcher.js.map +1 -0
  306. package/dist/sample/tcp/trade-capture/app.d.ts +1 -1
  307. package/dist/sample/tcp/trade-capture/app.js +4 -21
  308. package/dist/sample/tcp/trade-capture/app.js.map +1 -1
  309. package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -1
  310. package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -1
  311. package/dist/sample/tcp/trade-capture/trade-factory.js +7 -1
  312. package/dist/sample/tcp/trade-capture/trade-factory.js.map +1 -1
  313. package/dist/store/fix-msg-ascii-store-resend.d.ts +1 -1
  314. package/dist/store/fix-msg-ascii-store-resend.js +2 -1
  315. package/dist/store/fix-msg-ascii-store-resend.js.map +1 -1
  316. package/dist/store/fix-msg-memory-store.d.ts +1 -1
  317. package/dist/store/fix-msg-memory-store.js.map +1 -1
  318. package/dist/store/fix-msg-store-record.d.ts +2 -0
  319. package/dist/store/fix-msg-store-record.js +4 -0
  320. package/dist/store/fix-msg-store-record.js.map +1 -1
  321. package/dist/store/fix-msg-store-state.d.ts +6 -0
  322. package/dist/store/fix-msg-store-state.js +3 -0
  323. package/dist/store/fix-msg-store-state.js.map +1 -0
  324. package/dist/store/fix-msg-store.d.ts +1 -6
  325. package/dist/store/fix-msg-store.js.map +1 -1
  326. package/dist/test/ascii/ascii-encoder.test.d.ts +1 -0
  327. package/dist/test/{ascii-encoder.test.js → ascii/ascii-encoder.test.js} +57 -55
  328. package/dist/test/ascii/ascii-encoder.test.js.map +1 -0
  329. package/dist/test/ascii/ascii-parser.test.d.ts +1 -0
  330. package/dist/test/{ascii-parser.test.js → ascii/ascii-parser.test.js} +33 -52
  331. package/dist/test/ascii/ascii-parser.test.js.map +1 -0
  332. package/dist/test/ascii/ascii-segment.test.d.ts +1 -0
  333. package/dist/test/{ascii-segment.test.js → ascii/ascii-segment.test.js} +20 -41
  334. package/dist/test/ascii/ascii-segment.test.js.map +1 -0
  335. package/dist/test/ascii/ascii-store-replay.test.d.ts +1 -0
  336. package/dist/test/{ascii-store-replay.test.js → ascii/ascii-store-replay.test.js} +14 -43
  337. package/dist/test/ascii/ascii-store-replay.test.js.map +1 -0
  338. package/dist/test/ascii/ascii-tag-pos.test.d.ts +1 -0
  339. package/dist/test/{ascii-tag-pos.test.js → ascii/ascii-tag-pos.test.js} +10 -10
  340. package/dist/test/ascii/ascii-tag-pos.test.js.map +1 -0
  341. package/dist/test/ascii/execution-report.test.d.ts +1 -0
  342. package/dist/test/{execution-report.test.js → ascii/execution-report.test.js} +51 -52
  343. package/dist/test/ascii/execution-report.test.js.map +1 -0
  344. package/dist/test/ascii/fix-log-replay.test.d.ts +1 -0
  345. package/dist/test/{fix-log-replay.test.js → ascii/fix-log-replay.test.js} +8 -6
  346. package/dist/test/ascii/fix-log-replay.test.js.map +1 -0
  347. package/dist/test/ascii/fix-repo-dict.test.d.ts +1 -0
  348. package/dist/test/{fix-repo-dict.test.js → ascii/fix-repo-dict.test.js} +8 -7
  349. package/dist/test/ascii/fix-repo-dict.test.js.map +1 -0
  350. package/dist/test/ascii/includes.test.d.ts +1 -0
  351. package/dist/test/{includes.test.js → ascii/includes.test.js} +3 -2
  352. package/dist/test/ascii/includes.test.js.map +1 -0
  353. package/dist/test/ascii/logon.test.d.ts +1 -0
  354. package/dist/test/{logon.test.js → ascii/logon.test.js} +11 -13
  355. package/dist/test/ascii/logon.test.js.map +1 -0
  356. package/dist/test/ascii/memory-store.test.d.ts +1 -0
  357. package/dist/test/{memory-store.test.js → ascii/memory-store.test.js} +12 -12
  358. package/dist/test/ascii/memory-store.test.js.map +1 -0
  359. package/dist/test/ascii/qf-full-msg.test.d.ts +1 -0
  360. package/dist/test/{qf-full-msg.test.js → ascii/qf-full-msg.test.js} +21 -17
  361. package/dist/test/ascii/qf-full-msg.test.js.map +1 -0
  362. package/dist/test/ascii/repo-full-ascii-msg.test.d.ts +1 -0
  363. package/dist/test/{repo-full-ascii-msg.test.js → ascii/repo-full-ascii-msg.test.js} +20 -16
  364. package/dist/test/ascii/repo-full-ascii-msg.test.js.map +1 -0
  365. package/dist/test/ascii/session-state.test.d.ts +1 -0
  366. package/dist/test/{session-state.test.js → ascii/session-state.test.js} +2 -1
  367. package/dist/test/ascii/session-state.test.js.map +1 -0
  368. package/dist/test/ascii/session.test.d.ts +1 -0
  369. package/dist/test/{session.test.js → ascii/session.test.js} +14 -145
  370. package/dist/test/ascii/session.test.js.map +1 -0
  371. package/dist/test/ascii/time-formatter.test.d.ts +1 -0
  372. package/dist/test/{time-formatter.test.js → ascii/time-formatter.test.js} +4 -2
  373. package/dist/test/ascii/time-formatter.test.js.map +1 -0
  374. package/dist/test/ascii/view-decode.test.d.ts +1 -0
  375. package/dist/test/{view-decode.test.js → ascii/view-decode.test.js} +11 -36
  376. package/dist/test/ascii/view-decode.test.js.map +1 -0
  377. package/dist/test/elastic-buffer.test.d.ts +1 -1
  378. package/dist/test/elastic-buffer.test.js +3 -1
  379. package/dist/test/elastic-buffer.test.js.map +1 -1
  380. package/dist/test/encode-proxy.test.d.ts +1 -1
  381. package/dist/test/encode-proxy.test.js +9 -9
  382. package/dist/test/encode-proxy.test.js.map +1 -1
  383. package/dist/test/env/experiment.d.ts +23 -0
  384. package/dist/test/env/experiment.js +33 -0
  385. package/dist/test/env/experiment.js.map +1 -0
  386. package/dist/test/env/parsing-result.d.ts +10 -0
  387. package/dist/test/env/parsing-result.js +14 -0
  388. package/dist/test/env/parsing-result.js.map +1 -0
  389. package/dist/test/env/setup.d.ts +39 -0
  390. package/dist/test/env/setup.js +98 -0
  391. package/dist/test/env/setup.js.map +1 -0
  392. package/dist/test/env/skeleton-runner.d.ts +15 -0
  393. package/dist/test/env/skeleton-runner.js +108 -0
  394. package/dist/test/env/skeleton-runner.js.map +1 -0
  395. package/dist/test/env/test-recovery.d.ts +13 -0
  396. package/dist/test/env/test-recovery.js +41 -0
  397. package/dist/test/env/test-recovery.js.map +1 -0
  398. package/dist/test/{to-views.d.ts → env/to-views.d.ts} +2 -2
  399. package/dist/test/{to-views.js → env/to-views.js} +8 -7
  400. package/dist/test/env/to-views.js.map +1 -0
  401. package/dist/test/fixml/fixml-alloc-parse.test.d.ts +1 -0
  402. package/dist/test/{fixml-alloc-parse.test.js → fixml/fixml-alloc-parse.test.js} +2 -1
  403. package/dist/test/fixml/fixml-alloc-parse.test.js.map +1 -0
  404. package/dist/test/fixml/fixml-mkt-data-fut-parse.test.d.ts +1 -0
  405. package/dist/test/{fixml-mkt-data-fut-parse.test.js → fixml/fixml-mkt-data-fut-parse.test.js} +2 -1
  406. package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js.map +1 -0
  407. package/dist/test/fixml/fixml-mkt-data-settle-parse.test.d.ts +1 -0
  408. package/dist/test/{fixml-mkt-data-settle-parse.test.js → fixml/fixml-mkt-data-settle-parse.test.js} +2 -1
  409. package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js.map +1 -0
  410. package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.d.ts +1 -0
  411. package/dist/test/{fixml-tc-bi-lateral-parse.test.js → fixml/fixml-tc-bi-lateral-parse.test.js} +2 -1
  412. package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js.map +1 -0
  413. package/dist/test/fixml/repo-full-fixml-msg.test.d.ts +1 -0
  414. package/dist/test/{repo-full-fixml-msg.test.js → fixml/repo-full-fixml-msg.test.js} +17 -10
  415. package/dist/test/fixml/repo-full-fixml-msg.test.js.map +1 -0
  416. package/dist/transport/ascii/ascii-msg-transmitter.js +25 -6
  417. package/dist/transport/ascii/ascii-msg-transmitter.js.map +1 -1
  418. package/dist/transport/ascii/ascii-session-msg-factory.d.ts +2 -2
  419. package/dist/transport/ascii/ascii-session-msg-factory.js +1 -1
  420. package/dist/transport/ascii/ascii-session-msg-factory.js.map +1 -1
  421. package/dist/transport/ascii/ascii-session.d.ts +1 -1
  422. package/dist/transport/ascii/ascii-session.js +26 -23
  423. package/dist/transport/ascii/ascii-session.js.map +1 -1
  424. package/dist/transport/ascii/index.d.ts +0 -1
  425. package/dist/transport/ascii/index.js +0 -1
  426. package/dist/transport/ascii/index.js.map +1 -1
  427. package/dist/transport/duplex/http-duplex.d.ts +1 -1
  428. package/dist/transport/duplex/http-duplex.js.map +1 -1
  429. package/dist/transport/duplex/tcp-duplex.js +22 -2
  430. package/dist/transport/duplex/tcp-duplex.js.map +1 -1
  431. package/dist/transport/factory/index.d.ts +1 -0
  432. package/dist/transport/factory/index.js +14 -0
  433. package/dist/transport/factory/index.js.map +1 -0
  434. package/dist/transport/{msg-transport.d.ts → factory/msg-transport.d.ts} +4 -4
  435. package/dist/transport/factory/msg-transport.js +61 -0
  436. package/dist/transport/factory/msg-transport.js.map +1 -0
  437. package/dist/transport/fix-acceptor.d.ts +2 -2
  438. package/dist/transport/fix-acceptor.js.map +1 -1
  439. package/dist/transport/fix-entity.d.ts +8 -0
  440. package/dist/transport/fix-entity.js +12 -0
  441. package/dist/transport/fix-entity.js.map +1 -0
  442. package/dist/transport/fix-initiator.d.ts +2 -2
  443. package/dist/transport/fix-initiator.js.map +1 -1
  444. package/dist/transport/fixml/fixml-msg-transmitter.js +23 -5
  445. package/dist/transport/fixml/fixml-msg-transmitter.js.map +1 -1
  446. package/dist/transport/fixml/fixml-session-msg-factory.d.ts +2 -2
  447. package/dist/transport/fixml/fixml-session-msg-factory.js +1 -1
  448. package/dist/transport/fixml/fixml-session-msg-factory.js.map +1 -1
  449. package/dist/transport/fixml/fixml-session.d.ts +1 -1
  450. package/dist/transport/fixml/fixml-session.js +3 -3
  451. package/dist/transport/fixml/fixml-session.js.map +1 -1
  452. package/dist/transport/fixml/index.d.ts +0 -2
  453. package/dist/transport/fixml/index.js +0 -2
  454. package/dist/transport/fixml/index.js.map +1 -1
  455. package/dist/transport/http/html-options.d.ts +8 -0
  456. package/dist/{store/replay-record.js → transport/http/html-options.js} +1 -1
  457. package/dist/transport/http/html-options.js.map +1 -0
  458. package/dist/transport/http/html-route.d.ts +5 -0
  459. package/dist/{types/FIX4.4/quickfix/set/header.js → transport/http/html-route.js} +1 -1
  460. package/dist/transport/http/html-route.js.map +1 -0
  461. package/dist/transport/http/http-acceptor-listener.d.ts +7 -0
  462. package/dist/transport/http/http-acceptor-listener.js +68 -0
  463. package/dist/transport/http/http-acceptor-listener.js.map +1 -0
  464. package/dist/transport/http/http-acceptor.js +24 -5
  465. package/dist/transport/http/http-acceptor.js.map +1 -1
  466. package/dist/transport/http/http-adapter.d.ts +7 -0
  467. package/dist/transport/http/http-adapter.js +3 -0
  468. package/dist/transport/http/http-adapter.js.map +1 -0
  469. package/dist/transport/http/http-initiator.d.ts +9 -3
  470. package/dist/transport/http/http-initiator.js +57 -26
  471. package/dist/transport/http/http-initiator.js.map +1 -1
  472. package/dist/transport/http/http-json-sample-adapter.d.ts +2 -1
  473. package/dist/transport/http/http-json-sample-adapter.js +21 -2
  474. package/dist/transport/http/http-json-sample-adapter.js.map +1 -1
  475. package/dist/transport/http/http-transaction.d.ts +1 -1
  476. package/dist/transport/http/http-transaction.js.map +1 -1
  477. package/dist/transport/http/http-transport-description.d.ts +8 -0
  478. package/dist/transport/http/http-transport-description.js +3 -0
  479. package/dist/transport/http/http-transport-description.js.map +1 -0
  480. package/dist/transport/http/index.d.ts +1 -0
  481. package/dist/transport/http/index.js +1 -0
  482. package/dist/transport/http/index.js.map +1 -1
  483. package/dist/transport/index.d.ts +11 -10
  484. package/dist/transport/index.js +11 -10
  485. package/dist/transport/index.js.map +1 -1
  486. package/dist/transport/msg-application.d.ts +12 -0
  487. package/dist/transport/msg-application.js +3 -0
  488. package/dist/transport/msg-application.js.map +1 -0
  489. package/dist/transport/msg-transmitter.d.ts +5 -5
  490. package/dist/transport/msg-transmitter.js +2 -3
  491. package/dist/transport/msg-transmitter.js.map +1 -1
  492. package/dist/transport/{a-session-msg-factory.d.ts → session/a-session-msg-factory.d.ts} +3 -3
  493. package/dist/transport/{a-session-msg-factory.js → session/a-session-msg-factory.js} +1 -1
  494. package/dist/transport/session/a-session-msg-factory.js.map +1 -0
  495. package/dist/transport/session/fix-session-state-args.d.ts +8 -0
  496. package/dist/transport/session/fix-session-state-args.js +3 -0
  497. package/dist/transport/session/fix-session-state-args.js.map +1 -0
  498. package/dist/transport/session/fix-session-state.d.ts +32 -0
  499. package/dist/transport/{fix-session-state.js → session/fix-session-state.js} +22 -55
  500. package/dist/transport/session/fix-session-state.js.map +1 -0
  501. package/dist/transport/{fix-session.d.ts → session/fix-session.d.ts} +6 -5
  502. package/dist/transport/{fix-session.js → session/fix-session.js} +45 -43
  503. package/dist/transport/session/fix-session.js.map +1 -0
  504. package/dist/transport/{make-fixl-session.d.ts → session/make-fix-session.d.ts} +1 -1
  505. package/dist/transport/session/make-fix-session.js +3 -0
  506. package/dist/transport/session/make-fix-session.js.map +1 -0
  507. package/dist/transport/session/session-description.d.ts +17 -0
  508. package/dist/transport/{session-description.js → session/session-description.js} +0 -0
  509. package/dist/transport/session/session-description.js.map +1 -0
  510. package/dist/transport/{fix-msg-factory.d.ts → session/session-msg-factory.d.ts} +2 -2
  511. package/dist/transport/session/session-msg-factory.js +3 -0
  512. package/dist/transport/session/session-msg-factory.js.map +1 -0
  513. package/dist/transport/session/session-state.d.ts +25 -0
  514. package/dist/transport/session/session-state.js +30 -0
  515. package/dist/transport/session/session-state.js.map +1 -0
  516. package/dist/transport/tcp/index.d.ts +3 -2
  517. package/dist/transport/tcp/index.js +3 -2
  518. package/dist/transport/tcp/index.js.map +1 -1
  519. package/dist/transport/tcp/recovering-tcp-initiator.d.ts +7 -9
  520. package/dist/transport/tcp/recovering-tcp-initiator.js +41 -16
  521. package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -1
  522. package/dist/transport/tcp/tcp-acceptor-listener.d.ts +7 -0
  523. package/dist/transport/tcp/tcp-acceptor-listener.js +70 -0
  524. package/dist/transport/tcp/tcp-acceptor-listener.js.map +1 -0
  525. package/dist/transport/tcp/tcp-acceptor.js +29 -12
  526. package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
  527. package/dist/transport/tcp/tcp-initiator-connector.d.ts +10 -0
  528. package/dist/transport/tcp/tcp-initiator-connector.js +97 -0
  529. package/dist/transport/tcp/tcp-initiator-connector.js.map +1 -0
  530. package/dist/transport/tcp/tcp-initiator.d.ts +2 -2
  531. package/dist/transport/tcp/tcp-initiator.js +28 -9
  532. package/dist/transport/tcp/tcp-initiator.js.map +1 -1
  533. package/dist/transport/tcp/tcp-transport-description.d.ts +6 -0
  534. package/dist/transport/tcp/tcp-transport-description.js +3 -0
  535. package/dist/transport/tcp/tcp-transport-description.js.map +1 -0
  536. package/dist/transport/tcp/tls-options-factory.d.ts +9 -0
  537. package/dist/transport/tcp/tls-options-factory.js +53 -0
  538. package/dist/transport/tcp/tls-options-factory.js.map +1 -0
  539. package/dist/transport/tcp/tls-options.d.ts +10 -5
  540. package/dist/transport/tcp/tls-options.js +0 -49
  541. package/dist/transport/tcp/tls-options.js.map +1 -1
  542. package/dist/transport/tick-action.d.ts +8 -0
  543. package/dist/transport/tick-action.js +13 -0
  544. package/dist/transport/tick-action.js.map +1 -0
  545. package/dist/util/buffer-helper.js +1 -1
  546. package/dist/util/buffer-helper.js.map +1 -1
  547. package/dist/util/definition-factory.d.ts +10 -0
  548. package/dist/util/definition-factory.js +56 -0
  549. package/dist/util/definition-factory.js.map +1 -0
  550. package/dist/util/dictionary-path.d.ts +4 -0
  551. package/dist/util/dictionary-path.js +3 -0
  552. package/dist/util/dictionary-path.js.map +1 -0
  553. package/dist/util/index.d.ts +1 -1
  554. package/dist/util/index.js +1 -1
  555. package/dist/util/index.js.map +1 -1
  556. package/dist/util/json-helper.d.ts +3 -1
  557. package/dist/util/json-helper.js +13 -12
  558. package/dist/util/json-helper.js.map +1 -1
  559. package/dist/util/message-generator.d.ts +1 -1
  560. package/dist/util/message-generator.js +16 -15
  561. package/dist/util/message-generator.js.map +1 -1
  562. package/dist/util/replay.d.ts +6 -3
  563. package/dist/util/replay.js +24 -26
  564. package/dist/util/replay.js.map +1 -1
  565. package/package.json +18 -13
  566. package/script/build.cmd +1 -0
  567. package/script/build.sh +1 -0
  568. package/script/test.cmd +3 -0
  569. package/src/buffer/{ascii-chars.ts → ascii/ascii-chars.ts} +0 -0
  570. package/src/buffer/ascii/ascii-encoder.ts +9 -6
  571. package/src/buffer/ascii/ascii-parser-state.ts +7 -12
  572. package/src/buffer/ascii/ascii-parser.ts +23 -16
  573. package/src/buffer/ascii/ascii-segment-parser.ts +14 -8
  574. package/src/buffer/ascii/ascii-view.ts +4 -9
  575. package/src/buffer/ascii/index.ts +1 -0
  576. package/src/buffer/ascii/parse-state.ts +8 -0
  577. package/src/buffer/ascii/time-formatter.ts +1 -1
  578. package/src/buffer/elastic-buffer.ts +7 -2
  579. package/src/buffer/encode-proxy.ts +9 -4
  580. package/src/buffer/fixml/fixml-encoder.ts +15 -11
  581. package/src/buffer/fixml/fixml-parser.ts +16 -6
  582. package/src/buffer/fixml/fixml-view.ts +4 -9
  583. package/src/buffer/fixml/populated-attributes.ts +6 -0
  584. package/src/buffer/index.ts +4 -8
  585. package/src/buffer/msg-encoder.ts +2 -1
  586. package/src/buffer/msg-view.ts +13 -9
  587. package/src/buffer/{segment-description.ts → segment/segment-description.ts} +4 -11
  588. package/src/buffer/{segment-summary.ts → segment/segment-summary.ts} +0 -0
  589. package/src/buffer/segment/segment-type.ts +8 -0
  590. package/src/buffer/structure.ts +3 -3
  591. package/src/buffer/{tag-pos.ts → tag/tag-pos.ts} +0 -0
  592. package/src/buffer/tag/tag-type.ts +13 -0
  593. package/src/buffer/{tags.ts → tag/tags.ts} +4 -16
  594. package/src/config/get-js-fx-logger.ts +4 -0
  595. package/src/config/index.ts +1 -0
  596. package/src/config/js-fix-config.ts +5 -2
  597. package/src/config/js-fix-logger.ts +0 -3
  598. package/src/dictionary/compiler/compiler-type.ts +3 -3
  599. package/src/dictionary/compiler/enum-compiler.ts +12 -1
  600. package/src/dictionary/compiler/msg-compiler.ts +8 -7
  601. package/src/dictionary/contained/contained-component-field.ts +2 -1
  602. package/src/dictionary/contained/contained-field-dispatch.ts +3 -7
  603. package/src/dictionary/contained/contained-field-dispatcher.ts +9 -0
  604. package/src/dictionary/contained/contained-field-set.ts +5 -3
  605. package/src/dictionary/contained/contained-field-type.ts +5 -0
  606. package/src/dictionary/contained/contained-field.ts +1 -6
  607. package/src/dictionary/contained/contained-group-field.ts +2 -1
  608. package/src/dictionary/contained/contained-simple-field.ts +2 -1
  609. package/src/dictionary/contained/field-dispatcher.ts +9 -0
  610. package/src/dictionary/contained/fields-dispatch.ts +46 -0
  611. package/src/dictionary/contained/index.ts +2 -0
  612. package/src/dictionary/contained-set-type.ts +5 -0
  613. package/src/dictionary/definition/component-field-definition.ts +1 -1
  614. package/src/dictionary/definition/fix-definitions.ts +2 -1
  615. package/src/dictionary/definition/group-field-definition.ts +1 -1
  616. package/src/dictionary/definition/index.ts +0 -1
  617. package/src/dictionary/definition/message-definition.ts +1 -1
  618. package/src/dictionary/definition/simple-field-definition.ts +3 -1
  619. package/src/dictionary/dict-primitive.ts +0 -13
  620. package/src/dictionary/fix-definition-source.ts +6 -0
  621. package/src/dictionary/fix-versions.ts +0 -32
  622. package/src/dictionary/index.ts +1 -5
  623. package/src/dictionary/parser/fix-repository/abbreviations-parser.ts +2 -3
  624. package/src/dictionary/parser/fix-repository/base-parser.ts +2 -3
  625. package/src/dictionary/parser/fix-repository/components-parser.ts +2 -3
  626. package/src/dictionary/parser/fix-repository/data-types-parser.ts +2 -3
  627. package/src/dictionary/parser/fix-repository/enums-parser.ts +2 -3
  628. package/src/dictionary/parser/fix-repository/fields-parser.ts +2 -3
  629. package/src/dictionary/parser/fix-repository/messages-parser.ts +2 -3
  630. package/src/dictionary/parser/fix-repository/msg-contents-parser.ts +2 -3
  631. package/src/dictionary/parser/fix-repository/repository-abbreviation.ts +6 -0
  632. package/src/dictionary/parser/fix-repository/repository-component.ts +11 -0
  633. package/src/dictionary/parser/fix-repository/repository-data-type.ts +7 -0
  634. package/src/dictionary/parser/fix-repository/repository-enum.ts +8 -0
  635. package/src/dictionary/parser/fix-repository/repository-field.ts +12 -0
  636. package/src/dictionary/parser/fix-repository/repository-message.ts +12 -0
  637. package/src/dictionary/parser/fix-repository/repository-msg-content.ts +10 -0
  638. package/src/dictionary/parser/fix-repository/repository-type.ts +0 -59
  639. package/src/dictionary/parser/fix-repository/repository-xml-parser.ts +10 -9
  640. package/src/dictionary/parser/fix-repository/repository.ts +69 -38
  641. package/src/dictionary/parser/fixml/components-parser.ts +6 -3
  642. package/src/dictionary/parser/fixml/fields-parser.ts +1 -1
  643. package/src/dictionary/parser/fixml/fix-xsd-parser.ts +2 -1
  644. package/src/dictionary/parser/fixml/include-graph.ts +2 -1
  645. package/src/dictionary/parser/fixml/xsd-parser.ts +2 -1
  646. package/src/dictionary/parser/quickfix/field-definition-parser.ts +4 -5
  647. package/src/dictionary/parser/quickfix/field-set-parser.ts +4 -5
  648. package/src/dictionary/parser/quickfix/message-parser.ts +4 -5
  649. package/src/dictionary/parser/quickfix/node-parser.ts +3 -6
  650. package/src/dictionary/parser/quickfix/parse-state.ts +8 -0
  651. package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +9 -15
  652. package/src/dictionary/sax-node.ts +7 -0
  653. package/src/dictionary/set-reduce.ts +30 -31
  654. package/src/dictionary/type-dispatcher.ts +7 -0
  655. package/src/dictionary/version-util.ts +25 -0
  656. package/src/index.ts +1 -0
  657. package/src/jsfix-cmd.ts +31 -16
  658. package/src/runtime/di-tokens.ts +48 -0
  659. package/src/runtime/engine-factory.ts +5 -0
  660. package/src/runtime/index.ts +5 -0
  661. package/src/runtime/make-config.ts +35 -0
  662. package/src/runtime/session-container.ts +180 -0
  663. package/src/runtime/session-launcher.ts +127 -0
  664. package/src/sample/http/oms/app.ts +20 -14
  665. package/src/sample/http/oms/http-client.ts +5 -2
  666. package/src/sample/http/oms/http-server.ts +5 -1
  667. package/src/sample/tcp/qf-md/app.ts +12 -12
  668. package/src/sample/tcp/qf-md/md-client.ts +4 -1
  669. package/src/sample/tcp/qf-md/md-server.ts +3 -1
  670. package/src/sample/tcp/recovering-skeleton/app.ts +37 -15
  671. package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +16 -9
  672. package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +4 -2
  673. package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +4 -2
  674. package/src/sample/tcp/skeleton/app.ts +10 -15
  675. package/src/sample/tcp/skeleton/skeleton-session.ts +8 -4
  676. package/src/sample/tcp/tls-trade-capture/app.ts +8 -31
  677. package/src/sample/tcp/trade-capture/app-launcher.ts +22 -0
  678. package/src/sample/tcp/trade-capture/app.ts +3 -26
  679. package/src/sample/tcp/trade-capture/trade-capture-client.ts +2 -1
  680. package/src/sample/tcp/trade-capture/trade-capture-server.ts +2 -1
  681. package/src/sample/tcp/trade-capture/trade-factory.ts +7 -1
  682. package/src/store/fix-msg-ascii-store-resend.ts +3 -2
  683. package/src/store/fix-msg-memory-store.ts +1 -1
  684. package/src/store/fix-msg-store-record.ts +6 -0
  685. package/src/store/fix-msg-store-state.ts +6 -0
  686. package/src/store/fix-msg-store.ts +1 -7
  687. package/src/transport/ascii/ascii-msg-transmitter.ts +9 -5
  688. package/src/transport/ascii/ascii-session-msg-factory.ts +2 -2
  689. package/src/transport/ascii/ascii-session.ts +9 -6
  690. package/src/transport/ascii/index.ts +0 -1
  691. package/src/transport/duplex/http-duplex.ts +1 -1
  692. package/src/transport/duplex/tcp-duplex.ts +4 -1
  693. package/src/transport/factory/index.ts +1 -0
  694. package/src/transport/factory/msg-transport.ts +55 -0
  695. package/src/transport/fix-acceptor.ts +2 -2
  696. package/src/transport/fix-entity.ts +9 -0
  697. package/src/transport/fix-initiator.ts +2 -2
  698. package/src/transport/fixml/fixml-msg-transmitter.ts +8 -4
  699. package/src/transport/fixml/fixml-session-msg-factory.ts +2 -2
  700. package/src/transport/fixml/fixml-session.ts +2 -2
  701. package/src/transport/fixml/index.ts +0 -2
  702. package/src/transport/http/html-options.ts +8 -0
  703. package/src/transport/http/html-route.ts +6 -0
  704. package/src/transport/http/http-acceptor-listener.ts +42 -0
  705. package/src/transport/http/http-acceptor.ts +5 -2
  706. package/src/transport/http/http-adapter.ts +7 -0
  707. package/src/transport/http/http-initiator.ts +40 -25
  708. package/src/transport/http/http-json-sample-adapter.ts +7 -2
  709. package/src/transport/http/http-transaction.ts +1 -1
  710. package/src/transport/http/http-transport-description.ts +9 -0
  711. package/src/transport/http/index.ts +1 -0
  712. package/src/transport/index.ts +11 -10
  713. package/src/transport/msg-application.ts +13 -0
  714. package/src/transport/msg-transmitter.ts +5 -5
  715. package/src/transport/{a-session-msg-factory.ts → session/a-session-msg-factory.ts} +4 -4
  716. package/src/transport/session/fix-session-state-args.ts +9 -0
  717. package/src/transport/{fix-session-state.ts → session/fix-session-state.ts} +4 -44
  718. package/src/transport/{fix-session.ts → session/fix-session.ts} +10 -7
  719. package/src/transport/{make-fixl-session.ts → session/make-fix-session.ts} +1 -1
  720. package/src/transport/session/session-description.ts +18 -0
  721. package/src/transport/{fix-msg-factory.ts → session/session-msg-factory.ts} +2 -2
  722. package/src/transport/session/session-state.ts +25 -0
  723. package/src/transport/tcp/index.ts +3 -2
  724. package/src/transport/tcp/recovering-tcp-initiator.ts +24 -13
  725. package/src/transport/tcp/tcp-acceptor-listener.ts +45 -0
  726. package/src/transport/tcp/tcp-acceptor.ts +11 -10
  727. package/src/transport/tcp/tcp-initiator-connector.ts +71 -0
  728. package/src/transport/tcp/tcp-initiator.ts +10 -6
  729. package/src/transport/tcp/tcp-transport-description.ts +7 -0
  730. package/src/transport/tcp/tls-options-factory.ts +55 -0
  731. package/src/transport/tcp/tls-options.ts +9 -51
  732. package/src/transport/tick-action.ts +8 -0
  733. package/src/util/definition-factory.ts +47 -0
  734. package/src/util/dictionary-path.ts +4 -0
  735. package/src/util/index.ts +1 -1
  736. package/src/util/json-helper.ts +14 -4
  737. package/src/util/message-generator.ts +6 -3
  738. package/src/util/replay.ts +26 -21
  739. package/tsconfig.json +2 -0
  740. package/dist/buffer/ascii-chars.js.map +0 -1
  741. package/dist/buffer/segment-description.js.map +0 -1
  742. package/dist/buffer/segment-summary.js.map +0 -1
  743. package/dist/buffer/tag-pos.js.map +0 -1
  744. package/dist/buffer/tags.js.map +0 -1
  745. package/dist/dictionary/fields-dispatch.js +0 -40
  746. package/dist/dictionary/fields-dispatch.js.map +0 -1
  747. package/dist/sample/launcher.d.ts +0 -12
  748. package/dist/sample/launcher.js +0 -63
  749. package/dist/sample/launcher.js.map +0 -1
  750. package/dist/sample/tcp/recovering-skeleton/respawn-2.d.ts +0 -2
  751. package/dist/sample/tcp/recovering-skeleton/respawn-2.js +0 -3
  752. package/dist/sample/tcp/recovering-skeleton/respawn-2.js.map +0 -1
  753. package/dist/store/fix-msg-ascii-store-recovery.d.ts +0 -12
  754. package/dist/store/fix-msg-ascii-store-recovery.js +0 -60
  755. package/dist/store/fix-msg-ascii-store-recovery.js.map +0 -1
  756. package/dist/store/fix-msg-ascii-store-replay.d.ts +0 -13
  757. package/dist/store/fix-msg-ascii-store-replay.js +0 -60
  758. package/dist/store/fix-msg-ascii-store-replay.js.map +0 -1
  759. package/dist/store/fix-replay-record.d.ts +0 -12
  760. package/dist/store/fix-replay-record.js +0 -12
  761. package/dist/store/fix-replay-record.js.map +0 -1
  762. package/dist/store/fix-resend-record.d.ts +0 -12
  763. package/dist/store/fix-resend-record.js +0 -12
  764. package/dist/store/fix-resend-record.js.map +0 -1
  765. package/dist/store/replay-record.d.ts +0 -6
  766. package/dist/store/replay-record.js.map +0 -1
  767. package/dist/store/store-replay-record.d.ts +0 -12
  768. package/dist/store/store-replay-record.js +0 -12
  769. package/dist/store/store-replay-record.js.map +0 -1
  770. package/dist/tcp/tls-options.d.ts +0 -5
  771. package/dist/tcp/tls-options.js +0 -45
  772. package/dist/tcp/tls-options.js.map +0 -1
  773. package/dist/test/ascii-encode.test.d.ts +0 -1
  774. package/dist/test/ascii-encode.test.js +0 -416
  775. package/dist/test/ascii-encode.test.js.map +0 -1
  776. package/dist/test/ascii-encoder.test.d.ts +0 -1
  777. package/dist/test/ascii-encoder.test.js.map +0 -1
  778. package/dist/test/ascii-parser.test.d.ts +0 -1
  779. package/dist/test/ascii-parser.test.js.map +0 -1
  780. package/dist/test/ascii-segment.test.d.ts +0 -1
  781. package/dist/test/ascii-segment.test.js.map +0 -1
  782. package/dist/test/ascii-store-recovery.test.d.ts +0 -1
  783. package/dist/test/ascii-store-recovery.test.js +0 -50
  784. package/dist/test/ascii-store-recovery.test.js.map +0 -1
  785. package/dist/test/ascii-store-replay.test.d.ts +0 -1
  786. package/dist/test/ascii-store-replay.test.js.map +0 -1
  787. package/dist/test/ascii-tag-pos.test.d.ts +0 -1
  788. package/dist/test/ascii-tag-pos.test.js.map +0 -1
  789. package/dist/test/execution-report.test.d.ts +0 -1
  790. package/dist/test/execution-report.test.js.map +0 -1
  791. package/dist/test/fix-log-replay.test.d.ts +0 -1
  792. package/dist/test/fix-log-replay.test.js.map +0 -1
  793. package/dist/test/fix-repo-dict.test.d.ts +0 -1
  794. package/dist/test/fix-repo-dict.test.js.map +0 -1
  795. package/dist/test/fixml-alloc-parse.test.d.ts +0 -1
  796. package/dist/test/fixml-alloc-parse.test.js.map +0 -1
  797. package/dist/test/fixml-mkt-data-fut-parse.test.d.ts +0 -1
  798. package/dist/test/fixml-mkt-data-fut-parse.test.js.map +0 -1
  799. package/dist/test/fixml-mkt-data-settle-parse.test.d.ts +0 -1
  800. package/dist/test/fixml-mkt-data-settle-parse.test.js.map +0 -1
  801. package/dist/test/fixml-tc-bi-lateral-parse.test.d.ts +0 -1
  802. package/dist/test/fixml-tc-bi-lateral-parse.test.js.map +0 -1
  803. package/dist/test/includes.test.d.ts +0 -1
  804. package/dist/test/includes.test.js.map +0 -1
  805. package/dist/test/logon.test.d.ts +0 -1
  806. package/dist/test/logon.test.js.map +0 -1
  807. package/dist/test/memory-store.test.d.ts +0 -1
  808. package/dist/test/memory-store.test.js.map +0 -1
  809. package/dist/test/qf-full-msg.test.d.ts +0 -1
  810. package/dist/test/qf-full-msg.test.js.map +0 -1
  811. package/dist/test/repo-full-ascii-msg.test.d.ts +0 -1
  812. package/dist/test/repo-full-ascii-msg.test.js.map +0 -1
  813. package/dist/test/repo-full-fixml-msg.test.d.ts +0 -1
  814. package/dist/test/repo-full-fixml-msg.test.js.map +0 -1
  815. package/dist/test/session-state.test.d.ts +0 -1
  816. package/dist/test/session-state.test.js.map +0 -1
  817. package/dist/test/session.test.d.ts +0 -1
  818. package/dist/test/session.test.js.map +0 -1
  819. package/dist/test/time-formatter.test.d.ts +0 -1
  820. package/dist/test/time-formatter.test.js.map +0 -1
  821. package/dist/test/to-views.js.map +0 -1
  822. package/dist/test/view-decode.test.d.ts +0 -1
  823. package/dist/test/view-decode.test.js.map +0 -1
  824. package/dist/transport/a-session-msg-factory.js.map +0 -1
  825. package/dist/transport/ascii-session-msg-factory.d.ts +0 -16
  826. package/dist/transport/ascii-session-msg-factory.js +0 -47
  827. package/dist/transport/ascii-session-msg-factory.js.map +0 -1
  828. package/dist/transport/fix-msg-factory.js.map +0 -1
  829. package/dist/transport/fix-session-state.d.ts +0 -70
  830. package/dist/transport/fix-session-state.js.map +0 -1
  831. package/dist/transport/fix-session.js.map +0 -1
  832. package/dist/transport/fixml/acceptor.d.ts +0 -3
  833. package/dist/transport/fixml/acceptor.js +0 -38
  834. package/dist/transport/fixml/acceptor.js.map +0 -1
  835. package/dist/transport/fixml-session-msg-factory.d.ts +0 -13
  836. package/dist/transport/fixml-session-msg-factory.js +0 -68
  837. package/dist/transport/fixml-session-msg-factory.js.map +0 -1
  838. package/dist/transport/make-config.d.ts +0 -4
  839. package/dist/transport/make-config.js +0 -31
  840. package/dist/transport/make-config.js.map +0 -1
  841. package/dist/transport/make-fixl-session.js.map +0 -1
  842. package/dist/transport/msg-transport.js +0 -57
  843. package/dist/transport/msg-transport.js.map +0 -1
  844. package/dist/transport/session-description.d.ts +0 -64
  845. package/dist/transport/session-description.js.map +0 -1
  846. package/dist/transport/session-msg-factory.d.ts +0 -28
  847. package/dist/transport/session-msg-factory.js +0 -153
  848. package/dist/transport/session-msg-factory.js.map +0 -1
  849. package/dist/transport/tcp/acceptor.d.ts +0 -3
  850. package/dist/transport/tcp/acceptor.js +0 -40
  851. package/dist/transport/tcp/acceptor.js.map +0 -1
  852. package/dist/transport/tcp/initiator.d.ts +0 -3
  853. package/dist/transport/tcp/initiator.js +0 -67
  854. package/dist/transport/tcp/initiator.js.map +0 -1
  855. package/dist/transport/tcp/recovering-initiator.d.ts +0 -17
  856. package/dist/transport/tcp/recovering-initiator.js +0 -30
  857. package/dist/transport/tcp/recovering-initiator.js.map +0 -1
  858. package/dist/transport/tcp/recovering_initiator.d.ts +0 -12
  859. package/dist/transport/tcp/recovering_initiator.js +0 -25
  860. package/dist/transport/tcp/recovering_initiator.js.map +0 -1
  861. package/dist/transport/tcp/resilient-initiator.d.ts +0 -12
  862. package/dist/transport/tcp/resilient-initiator.js +0 -41
  863. package/dist/transport/tcp/resilient-initiator.js.map +0 -1
  864. package/dist/types/FIX4.4/quickfix/set/header.d.ts +0 -31
  865. package/dist/types/FIX4.4/quickfix/set/header.js.map +0 -1
  866. package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +0 -6
  867. package/dist/types/FIX4.4/quickfix/set/trailer.js.map +0 -1
  868. package/dist/util/dictionary-definitions.d.ts +0 -8
  869. package/dist/util/dictionary-definitions.js +0 -51
  870. package/dist/util/dictionary-definitions.js.map +0 -1
  871. package/src/dictionary/fields-dispatch.ts +0 -45
  872. package/src/sample/launcher.ts +0 -56
  873. package/src/transport/fixml/acceptor.ts +0 -29
  874. package/src/transport/make-config.ts +0 -19
  875. package/src/transport/msg-transport.ts +0 -67
  876. package/src/transport/session-description.ts +0 -70
  877. package/src/transport/tcp/acceptor.ts +0 -31
  878. package/src/transport/tcp/initiator.ts +0 -59
  879. package/src/util/dictionary-definitions.ts +0 -41
@@ -1 +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"]}
1
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/app.ts"],"names":[],"mappings":";;AAAA,4BAAyB;AAGzB,8CAA4D;AAC5D,uDAAkD;AAClD,gDAA+D;AAC/D,yDAAoD;AACpD,iDAAkD;AAElD,uDAAkD;AAGlD,MAAM,WAAY,SAAQ,yBAAe;IAEvC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAEkB,mBAAmB,CAAE,gBAAqC;QAC3E,MAAM,MAAM,GAAiB,gBAAgB,CAAC,OAAO,CAAe,kBAAQ,CAAC,YAAY,CAAC,CAAA;QAE1F,MAAM,CAAC,YAAY,GAAG,kBAAU,CAAC,KAAK,CAAA;QAEtC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;QACxD,IAAI,WAAW,EAAE;YACf,gBAAgB,CAAC,QAAQ,CAAa,kBAAQ,CAAC,UAAU,EAAE;gBACzD,QAAQ,EAAE,gCAAc;aACzB,CAAC,CAAA;YACF,gBAAgB,CAAC,QAAQ,CAAY,kBAAQ,CAAC,SAAS,EAAE;gBACvD,QAAQ,EAAE,4BAAsB;aACjC,CAAC,CAAA;SACH;aAAM;YACL,gBAAgB,CAAC,QAAQ,CAAY,kBAAQ,CAAC,SAAS,EAAE;gBACvD,QAAQ,EAAE,kCAAe;aAC1B,CAAC,CAAA;YACF,gBAAgB,CAAC,QAAQ,CAAa,kBAAQ,CAAC,UAAU,EAAE;gBACzD,QAAQ,EAAE,gCAAc;aACzB,CAAC,CAAA;YACF,gBAAgB,CAAC,QAAQ,CAAC,eAAe,EAAE;gBACzC,QAAQ,EAAE,EAAE;aACb,CAAC,CAAA;SACH;QACD,gBAAgB,CAAC,QAAQ,CAAC,eAAe,EAAE;YACzC,QAAQ,EAAE,EAAE;SACb,CAAC,CAAA;QACF,gBAAgB,CAAC,QAAQ,CAAC,kBAAkB,EAAE;YAC5C,QAAQ,EAAE,KAAK;SAChB,CAAC,CAAA;IACJ,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,IAAI,EAAE,CAAA","sourcesContent":["import 'reflect-metadata'\r\n\r\nimport { IJsFixConfig } from '../../../config'\r\nimport { SessionLauncher, DITokens } from '../../../runtime'\r\nimport { SkeletonClient } from './skeleton-client'\r\nimport { RecoveringTcpInitiator } from '../../../transport/tcp'\r\nimport { RespawnAcceptor } from './respawn-acceptor'\r\nimport { AsciiChars } from '../../../buffer/ascii'\r\nimport { DependencyContainer } from 'tsyringe'\r\nimport { SkeletonServer } from './skeleton-server'\r\nimport { FixSession, FixEntity } from '../../../transport'\r\n\r\nclass AppLauncher extends SessionLauncher {\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 override registerApplication (sessionContainer: DependencyContainer) {\r\n const config: IJsFixConfig = sessionContainer.resolve<IJsFixConfig>(DITokens.IJsFixConfig)\r\n // use a different log delimiter as an example\r\n config.logDelimiter = AsciiChars.Carat\r\n\r\n const isInitiator = this.isInitiator(config.description)\r\n if (isInitiator) {\r\n sessionContainer.register<FixSession>(DITokens.FixSession, {\r\n useClass: SkeletonClient\r\n })\r\n sessionContainer.register<FixEntity>(DITokens.FixEntity, {\r\n useClass: RecoveringTcpInitiator\r\n })\r\n } else {\r\n sessionContainer.register<FixEntity>(DITokens.FixEntity, {\r\n useClass: RespawnAcceptor\r\n })\r\n sessionContainer.register<FixSession>(DITokens.FixSession, {\r\n useClass: SkeletonServer\r\n })\r\n sessionContainer.register('logoutSeconds', {\r\n useValue: 45\r\n })\r\n }\r\n sessionContainer.register('logoutSeconds', {\r\n useValue: 45\r\n })\r\n sessionContainer.register('useInMemoryStore', {\r\n useValue: false\r\n })\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.exec()\r\n"]}
@@ -1,7 +1,9 @@
1
1
  import { IJsFixConfig } from '../../../config';
2
- export declare class RespawnAcceptor {
2
+ import { FixEntity } from '../../../transport';
3
+ export declare class RespawnAcceptor extends FixEntity {
3
4
  readonly config: IJsFixConfig;
4
5
  private readonly logger;
5
6
  constructor(config: IJsFixConfig);
7
+ start(): Promise<any>;
6
8
  waitFor(respawns?: number): Promise<any>;
7
9
  }
@@ -1,4 +1,16 @@
1
1
  "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
2
14
  var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
15
  function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
16
  return new (P || (P = Promise))(function (resolve, reject) {
@@ -10,25 +22,30 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
10
22
  };
11
23
  Object.defineProperty(exports, "__esModule", { value: true });
12
24
  exports.RespawnAcceptor = void 0;
25
+ const tcp_1 = require("../../../transport/tcp");
26
+ const tsyringe_1 = require("tsyringe");
13
27
  const transport_1 = require("../../../transport");
14
- const skeleton_server_1 = require("./skeleton-server");
15
- class RespawnAcceptor {
28
+ let RespawnAcceptor = class RespawnAcceptor extends transport_1.FixEntity {
16
29
  constructor(config) {
30
+ super(config);
17
31
  this.config = config;
18
32
  this.logger = config.logFactory.logger('RespawnAcceptor');
19
33
  }
34
+ start() {
35
+ return this.waitFor();
36
+ }
20
37
  waitFor(respawns = 1) {
21
38
  return __awaiter(this, void 0, void 0, function* () {
22
39
  return new Promise((resolve, reject) => __awaiter(this, void 0, void 0, function* () {
23
40
  let respawned = 0;
24
41
  while (respawned <= respawns) {
25
42
  try {
43
+ const sessionContainer = this.config.sessionContainer;
44
+ const listener = sessionContainer.resolve(tcp_1.TcpAcceptorListener);
45
+ const dropConnectionTimeout = respawned === 0 ? 5 : -1;
46
+ sessionContainer.register('dropConnectionTimeout', { useValue: dropConnectionTimeout });
26
47
  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
- });
48
+ yield listener.start();
32
49
  break;
33
50
  }
34
51
  catch (e) {
@@ -47,6 +64,11 @@ class RespawnAcceptor {
47
64
  }));
48
65
  });
49
66
  }
50
- }
67
+ };
68
+ RespawnAcceptor = __decorate([
69
+ (0, tsyringe_1.injectable)(),
70
+ __param(0, (0, tsyringe_1.inject)('IJsFixConfig')),
71
+ __metadata("design:paramtypes", [Object])
72
+ ], RespawnAcceptor);
51
73
  exports.RespawnAcceptor = RespawnAcceptor;
52
74
  //# sourceMappingURL=respawn-acceptor.js.map
@@ -1 +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"]}
1
+ {"version":3,"file":"respawn-acceptor.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/respawn-acceptor.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;AACA,gDAA4D;AAC5D,uCAA6C;AAC7C,kDAA8C;AAG9C,IAAa,eAAe,GAA5B,MAAa,eAAgB,SAAQ,qBAAS;IAG5C,YAAqD,MAAoB;QACvE,KAAK,CAAC,MAAM,CAAC,CAAA;QADsC,WAAM,GAAN,MAAM,CAAc;QAEvE,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAA;IAC3D,CAAC;IAKM,KAAK;QACV,OAAO,IAAI,CAAC,OAAO,EAAE,CAAA;IACvB,CAAC;IAEY,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,MAAM,gBAAgB,GAAG,IAAI,CAAC,MAAM,CAAC,gBAAgB,CAAA;wBACrD,MAAM,QAAQ,GAAG,gBAAgB,CAAC,OAAO,CAAsB,yBAAmB,CAAC,CAAA;wBACnF,MAAM,qBAAqB,GAAG,SAAS,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;wBACtD,gBAAgB,CAAC,QAAQ,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,qBAAqB,EAAE,CAAC,CAAA;wBACvF,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,6CAA6C,SAAS,EAAE,CAAC,CAAA;wBAC1E,MAAM,QAAQ,CAAC,KAAK,EAAE,CAAA;wBACtB,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,CAAA;AAzCY,eAAe;IAD3B,IAAA,qBAAU,GAAE;IAIG,WAAA,IAAA,iBAAM,EAAC,cAAc,CAAC,CAAA;;GAHzB,eAAe,CAyC3B;AAzCY,0CAAe","sourcesContent":["import { IJsFixConfig, IJsFixLogger } from '../../../config'\r\nimport { TcpAcceptorListener } from '../../../transport/tcp'\r\nimport { inject, injectable } from 'tsyringe'\r\nimport { FixEntity } from '../../../transport'\r\n\r\n@injectable()\r\nexport class RespawnAcceptor extends FixEntity {\r\n private readonly logger: IJsFixLogger\r\n\r\n constructor (@inject('IJsFixConfig') public readonly config: IJsFixConfig) {\r\n super(config)\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 start (): Promise<any> {\r\n return this.waitFor()\r\n }\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 const sessionContainer = this.config.sessionContainer\r\n const listener = sessionContainer.resolve<TcpAcceptorListener>(TcpAcceptorListener)\r\n const dropConnectionTimeout = respawned === 0 ? 5 : -1\r\n sessionContainer.register('dropConnectionTimeout', { useValue: dropConnectionTimeout })\r\n this.logger.info(`waitFor: waiting for acceptor respawned = ${respawned}`)\r\n await listener.start()\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"]}
@@ -6,7 +6,7 @@ export declare class SkeletonClient extends AsciiSession {
6
6
  readonly logoutSeconds: number;
7
7
  private readonly logger;
8
8
  private readonly fixLog;
9
- constructor(config: IJsFixConfig, logoutSeconds?: number);
9
+ constructor(config: IJsFixConfig, logoutSeconds: number);
10
10
  protected onApplicationMsg(msgType: string, view: MsgView): void;
11
11
  protected onDecoded(msgType: string, txt: string): void;
12
12
  protected onEncoded(msgType: string, txt: string): void;
@@ -1,9 +1,22 @@
1
1
  "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
2
14
  Object.defineProperty(exports, "__esModule", { value: true });
3
15
  exports.SkeletonClient = void 0;
4
16
  const transport_1 = require("../../../transport");
5
- class SkeletonClient extends transport_1.AsciiSession {
6
- constructor(config, logoutSeconds = 45) {
17
+ const tsyringe_1 = require("tsyringe");
18
+ let SkeletonClient = class SkeletonClient extends transport_1.AsciiSession {
19
+ constructor(config, logoutSeconds) {
7
20
  super(config);
8
21
  this.config = config;
9
22
  this.logoutSeconds = logoutSeconds;
@@ -40,6 +53,12 @@ class SkeletonClient extends transport_1.AsciiSession {
40
53
  onStopped() {
41
54
  this.logger.info('stopped');
42
55
  }
43
- }
56
+ };
57
+ SkeletonClient = __decorate([
58
+ (0, tsyringe_1.injectable)(),
59
+ __param(0, (0, tsyringe_1.inject)('IJsFixConfig')),
60
+ __param(1, (0, tsyringe_1.inject)('logoutSeconds')),
61
+ __metadata("design:paramtypes", [Object, Number])
62
+ ], SkeletonClient);
44
63
  exports.SkeletonClient = SkeletonClient;
45
64
  //# sourceMappingURL=skeleton-client.js.map
@@ -1 +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"]}
1
+ {"version":3,"file":"skeleton-client.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/skeleton-client.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,kDAAiD;AAEjD,uCAA6C;AAG7C,IAAa,cAAc,GAA3B,MAAa,cAAe,SAAQ,wBAAY;IAI9C,YAAqD,MAAoB,EACnB,aAAqB;QACzE,KAAK,CAAC,MAAM,CAAC,CAAA;QAFsC,WAAM,GAAN,MAAM,CAAc;QACnB,kBAAa,GAAb,aAAa,CAAQ;QAEzE,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,CAAA;AAjDY,cAAc;IAD1B,IAAA,qBAAU,GAAE;IAKG,WAAA,IAAA,iBAAM,EAAC,cAAc,CAAC,CAAA;IACtB,WAAA,IAAA,iBAAM,EAAC,eAAe,CAAC,CAAA;;GAL1B,cAAc,CAiD1B;AAjDY,wCAAc","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\nimport { inject, injectable } from 'tsyringe'\r\n\r\n@injectable()\r\nexport class SkeletonClient extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (@inject('IJsFixConfig') public readonly config: IJsFixConfig,\r\n @inject('logoutSeconds') public readonly logoutSeconds: 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 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"]}
@@ -1,8 +1,21 @@
1
1
  "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
2
14
  Object.defineProperty(exports, "__esModule", { value: true });
3
15
  exports.SkeletonServer = void 0;
4
16
  const transport_1 = require("../../../transport");
5
- class SkeletonServer extends transport_1.AsciiSession {
17
+ const tsyringe_1 = require("tsyringe");
18
+ let SkeletonServer = class SkeletonServer extends transport_1.AsciiSession {
6
19
  constructor(config, dropConnectionTimeout) {
7
20
  super(config);
8
21
  this.config = config;
@@ -47,6 +60,12 @@ class SkeletonServer extends transport_1.AsciiSession {
47
60
  onStopped() {
48
61
  this.logger.info('stopped');
49
62
  }
50
- }
63
+ };
64
+ SkeletonServer = __decorate([
65
+ (0, tsyringe_1.injectable)(),
66
+ __param(0, (0, tsyringe_1.inject)('IJsFixConfig')),
67
+ __param(1, (0, tsyringe_1.inject)('dropConnectionTimeout')),
68
+ __metadata("design:paramtypes", [Object, Number])
69
+ ], SkeletonServer);
51
70
  exports.SkeletonServer = SkeletonServer;
52
71
  //# sourceMappingURL=skeleton-server.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"skeleton-server.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/skeleton-server.ts"],"names":[],"mappings":";;;AACA,kDAAiD;AAGjD,MAAa,cAAe,SAAQ,wBAAY;IAI9C,YAA6B,MAAoB,EACpB,qBAA6B;QACxD,KAAK,CAAC,MAAM,CAAC,CAAA;QAFc,WAAM,GAAN,MAAM,CAAc;QACpB,0BAAqB,GAArB,qBAAqB,CAAQ;QAExD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;QAC3B,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,KAAK,CAAC,SAAS,MAAM,CAAC,WAAW,CAAC,WAAW,CAAC,IAAI,MAAM,CAAC,CAAA;QACzF,IAAI,CAAC,MAAM,GAAG,MAAM,CAAC,UAAU,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC,EAAE,EAAE,CAAC,CAAA;IACtD,CAAC;IAES,gBAAgB,CAAE,OAAe,EAAE,IAAa;QAExD,QAAQ,OAAO,EAAE;YACf,OAAO,CAAC,CAAC;gBACP,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,yBAAyB,OAAO,EAAE,CAAC,CAAA;gBACpD,MAAK;aACN;SACF;IACH,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAGS,SAAS,CAAE,OAAe,EAAE,GAAW;QAC/C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAA;IACvB,CAAC;IAES,OAAO,CAAE,IAAa,EAAE,IAAY,EAAE,QAAgB;QAC9D,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,qBAAqB,IAAI,EAAE,CAAC,CAAA;QAC7C,OAAO,IAAI,CAAA;IACb,CAAC;IAES,OAAO,CAAE,IAAa;QAC9B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAC3B,IAAI,IAAI,CAAC,qBAAqB,GAAG,CAAC,EAAE;YAClC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,uDAAuD,IAAI,CAAC,qBAAqB,EAAE,CAAC,CAAA;YACrG,UAAU,CAAC,GAAG,EAAE;gBACd,YAAY,CAAC,GAAG,EAAE;oBAChB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAA;oBAClC,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,CAAC,gBAAgB,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC,CAAA;gBACjD,CAAC,CAAC,CAAA;YACJ,CAAC,EAAE,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,CAAA;SACtC;aAAM;YACL,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,gCAAgC,CAAC,CAAA;SACnD;IACH,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;IAC7B,CAAC;CACF;AAvDD,wCAuDC","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\n\r\nexport class SkeletonServer extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (public readonly config: IJsFixConfig,\r\n public readonly dropConnectionTimeout: number) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n // dispatch messages\r\n switch (msgType) {\r\n default: {\r\n this.logger.info(`received message type ${msgType}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`peer logs in user ${user}`)\r\n return true\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('onReady')\r\n if (this.dropConnectionTimeout > 0) {\r\n this.logger.info(`acceptor is ready for requests - drop connection in ${this.dropConnectionTimeout}`)\r\n setTimeout(() => {\r\n setImmediate(() => {\r\n this.logger.info(`kill transport`)\r\n this.stop(new Error(`loss of tcp. ${this.me}`))\r\n })\r\n }, this.dropConnectionTimeout * 1000)\r\n } else {\r\n this.logger.info(`acceptor is ready for requests`)\r\n }\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"skeleton-server.js","sourceRoot":"","sources":["../../../../src/sample/tcp/recovering-skeleton/skeleton-server.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;AACA,kDAAiD;AAEjD,uCAA6C;AAG7C,IAAa,cAAc,GAA3B,MAAa,cAAe,SAAQ,wBAAY;IAI9C,YAAqD,MAAoB,EACX,qBAA6B;QACzF,KAAK,CAAC,MAAM,CAAC,CAAA;QAFsC,WAAM,GAAN,MAAM,CAAc;QACX,0BAAqB,GAArB,qBAAqB,CAAQ;QAEzF,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,CAAA;AAvDY,cAAc;IAD1B,IAAA,qBAAU,GAAE;IAKG,WAAA,IAAA,iBAAM,EAAC,cAAc,CAAC,CAAA;IACtB,WAAA,IAAA,iBAAM,EAAC,uBAAuB,CAAC,CAAA;;GALlC,cAAc,CAuD1B;AAvDY,wCAAc","sourcesContent":["import { MsgView } from '../../../buffer'\r\nimport { AsciiSession } from '../../../transport'\r\nimport { IJsFixLogger, IJsFixConfig } from '../../../config'\r\nimport { inject, injectable } from 'tsyringe'\r\n\r\n@injectable()\r\nexport class SkeletonServer extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (@inject('IJsFixConfig') public readonly config: IJsFixConfig,\r\n @inject('dropConnectionTimeout') public readonly dropConnectionTimeout: number) {\r\n super(config)\r\n this.logReceivedMsgs = true\r\n this.fixLog = config.logFactory.plain(`jsfix.${config.description.application.name}.txt`)\r\n this.logger = config.logFactory.logger(`${this.me}`)\r\n }\r\n\r\n protected onApplicationMsg (msgType: string, view: MsgView): void {\r\n // dispatch messages\r\n switch (msgType) {\r\n default: {\r\n this.logger.info(`received message type ${msgType}`)\r\n break\r\n }\r\n }\r\n }\r\n\r\n // use msgType for example to persist only trade capture messages to database\r\n protected onDecoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n // delimiter substitution now done in encoding\r\n protected onEncoded (msgType: string, txt: string): void {\r\n this.fixLog.info(txt)\r\n }\r\n\r\n protected onLogon (view: MsgView, user: string, password: string): boolean {\r\n this.logger.info(`peer logs in user ${user}`)\r\n return true\r\n }\r\n\r\n protected onReady (view: MsgView): void {\r\n this.logger.info('onReady')\r\n if (this.dropConnectionTimeout > 0) {\r\n this.logger.info(`acceptor is ready for requests - drop connection in ${this.dropConnectionTimeout}`)\r\n setTimeout(() => {\r\n setImmediate(() => {\r\n this.logger.info(`kill transport`)\r\n this.stop(new Error(`loss of tcp. ${this.me}`))\r\n })\r\n }, this.dropConnectionTimeout * 1000)\r\n } else {\r\n this.logger.info(`acceptor is ready for requests`)\r\n }\r\n }\r\n\r\n protected onStopped (): void {\r\n this.logger.info('stopped')\r\n }\r\n}\r\n"]}
@@ -1 +1 @@
1
- export {};
1
+ import 'reflect-metadata';
@@ -1,23 +1,18 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const launcher_1 = require("../../launcher");
3
+ require("reflect-metadata");
4
+ const runtime_1 = require("../../../runtime");
4
5
  const skeleton_session_1 = require("./skeleton-session");
5
- const transport_1 = require("../../../transport");
6
- class AppLauncher extends launcher_1.Launcher {
6
+ class AppLauncher extends runtime_1.SessionLauncher {
7
7
  constructor() {
8
8
  super('data/session/test-initiator.json', 'data/session/test-acceptor.json');
9
9
  }
10
- getAcceptor(config) {
11
- return transport_1.acceptor(config, c => new skeleton_session_1.SkeletonSession(c));
12
- }
13
- getInitiator(config) {
14
- return transport_1.initiator(config, c => new skeleton_session_1.SkeletonSession(c));
10
+ makeFactory(config) {
11
+ return {
12
+ makeSession: () => new skeleton_session_1.SkeletonSession(config, 45, false)
13
+ };
15
14
  }
16
15
  }
17
16
  const l = new AppLauncher();
18
- l.run().then(() => {
19
- console.log('finished.');
20
- }).catch((e) => {
21
- console.log(e.message);
22
- });
17
+ l.exec();
23
18
  //# 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,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
+ {"version":3,"file":"app.js","sourceRoot":"","sources":["../../../../src/sample/tcp/skeleton/app.ts"],"names":[],"mappings":";;AAAA,4BAAyB;AAEzB,8CAAiE;AACjE,yDAAoD;AAGpD,MAAM,WAAY,SAAQ,yBAAe;IACvC;QACE,KAAK,CACH,kCAAkC,EAClC,iCAAiC,CAAC,CAAA;IACtC,CAAC;IAEkB,WAAW,CAAE,MAAoB;QAClD,OAAO;YACL,WAAW,EAAE,GAAG,EAAE,CAAC,IAAI,kCAAe,CAAC,MAAM,EAAE,EAAE,EAAC,KAAK,CAAC;SACxC,CAAA;IACpB,CAAC;CACF;AAED,MAAM,CAAC,GAAG,IAAI,WAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,IAAI,EAAE,CAAA","sourcesContent":["import 'reflect-metadata'\r\n\r\nimport { SessionLauncher, EngineFactory } from '../../../runtime'\r\nimport { SkeletonSession } from './skeleton-session'\r\nimport { IJsFixConfig } from '../../../config'\r\n\r\nclass AppLauncher extends SessionLauncher {\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 override makeFactory (config: IJsFixConfig): EngineFactory {\r\n return {\r\n makeSession: () => new SkeletonSession(config, 45,false)\r\n } as EngineFactory\r\n }\r\n}\r\n\r\nconst l = new AppLauncher()\r\nl.exec()\r\n"]}
@@ -8,7 +8,7 @@ export declare class SkeletonSession extends AsciiSession {
8
8
  useInMemoryStore: boolean;
9
9
  private readonly logger;
10
10
  private readonly fixLog;
11
- constructor(config: IJsFixConfig, logoutSeconds?: number, useInMemoryStore?: boolean);
11
+ constructor(config: IJsFixConfig, logoutSeconds: number, useInMemoryStore: boolean);
12
12
  protected onApplicationMsg(msgType: string, view: MsgView): void;
13
13
  private dispatch;
14
14
  sendMessage(msgType: string, obj: ILooseObject): void;
@@ -1,9 +1,24 @@
1
1
  "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __param = (this && this.__param) || function (paramIndex, decorator) {
12
+ return function (target, key) { decorator(target, key, paramIndex); }
13
+ };
2
14
  Object.defineProperty(exports, "__esModule", { value: true });
3
15
  exports.SkeletonSession = void 0;
4
16
  const transport_1 = require("../../../transport");
5
- class SkeletonSession extends transport_1.AsciiSession {
6
- constructor(config, logoutSeconds = 45, useInMemoryStore = false) {
17
+ const store_1 = require("../../../store");
18
+ const tsyringe_1 = require("tsyringe");
19
+ const runtime_1 = require("../../../runtime");
20
+ let SkeletonSession = class SkeletonSession extends transport_1.AsciiSession {
21
+ constructor(config, logoutSeconds, useInMemoryStore) {
7
22
  super(config);
8
23
  this.config = config;
9
24
  this.logoutSeconds = logoutSeconds;
@@ -14,7 +29,7 @@ class SkeletonSession extends transport_1.AsciiSession {
14
29
  }
15
30
  onApplicationMsg(msgType, view) {
16
31
  if (this.useInMemoryStore) {
17
- const rec = view.toMsgStoreRecord();
32
+ const rec = store_1.FixMsgStoreRecord.toMsgStoreRecord(view);
18
33
  this.store.put(rec).then(r => {
19
34
  this.logger.info(`store state ${JSON.stringify(r, null, 4)}`);
20
35
  this.dispatch(msgType, view);
@@ -73,6 +88,13 @@ class SkeletonSession extends transport_1.AsciiSession {
73
88
  onStopped() {
74
89
  this.logger.info('stopped');
75
90
  }
76
- }
91
+ };
92
+ SkeletonSession = __decorate([
93
+ (0, tsyringe_1.injectable)(),
94
+ __param(0, (0, tsyringe_1.inject)(runtime_1.DITokens.IJsFixConfig)),
95
+ __param(1, (0, tsyringe_1.inject)('logoutSeconds')),
96
+ __param(2, (0, tsyringe_1.inject)('useInMemoryStore')),
97
+ __metadata("design:paramtypes", [Object, Number, Boolean])
98
+ ], SkeletonSession);
77
99
  exports.SkeletonSession = SkeletonSession;
78
100
  //# sourceMappingURL=skeleton-session.js.map
@@ -1 +1 @@
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
+ {"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\nimport { FixMsgStoreRecord } from '../../../store'\r\nimport { inject, injectable } from 'tsyringe'\r\nimport { DITokens } from '../../../runtime'\r\n\r\n@injectable()\r\nexport class SkeletonSession extends AsciiSession {\r\n private readonly logger: IJsFixLogger\r\n private readonly fixLog: IJsFixLogger\r\n\r\n constructor (@inject(DITokens.IJsFixConfig) public readonly config: IJsFixConfig,\r\n @inject('logoutSeconds') public readonly logoutSeconds: number,\r\n @inject('useInMemoryStore') public useInMemoryStore: boolean) {\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 = FixMsgStoreRecord.toMsgStoreRecord(view)\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 +1 @@
1
- export {};
1
+ import 'reflect-metadata';
@@ -1,27 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const trade_capture_1 = require("../trade-capture");
4
- const launcher_1 = require("../../launcher");
5
- const transport_1 = require("../../../transport");
6
- class AppLauncher extends launcher_1.Launcher {
7
- constructor() {
8
- super('data/session/test-initiator-tls.json', 'data/session/test-acceptor-tls.json');
9
- }
10
- getAcceptor(config) {
11
- return transport_1.acceptor(config, c => {
12
- return new trade_capture_1.TradeCaptureServer(c);
13
- });
14
- }
15
- getInitiator(config) {
16
- return transport_1.initiator(config, c => {
17
- return new trade_capture_1.TradeCaptureClient(c);
18
- });
19
- }
20
- }
21
- const l = new AppLauncher();
22
- l.run().then(() => {
23
- console.log('finished.');
24
- }).catch(e => {
25
- console.error(e);
26
- });
3
+ require("reflect-metadata");
4
+ const app_launcher_1 = require("../trade-capture/app-launcher");
5
+ const l = new app_launcher_1.AppLauncher('data/session/test-initiator-tls.json', 'data/session/test-acceptor-tls.json');
6
+ l.exec();
27
7
  //# sourceMappingURL=app.js.map
@@ -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,4BAAyB;AACzB,gEAA2D;AAE3D,MAAM,CAAC,GAAG,IAAI,0BAAW,CACvB,sCAAsC,EACtC,qCAAqC,CACpC,CAAA;AACH,CAAC,CAAC,IAAI,EAAE,CAAA","sourcesContent":["import 'reflect-metadata'\r\nimport { AppLauncher } from '../trade-capture/app-launcher'\r\n\r\nconst l = new AppLauncher(\r\n 'data/session/test-initiator-tls.json',\r\n 'data/session/test-acceptor-tls.json'\r\n )\r\nl.exec()\r\n"]}
@@ -0,0 +1,6 @@
1
+ import { EngineFactory, SessionLauncher } from '../../../runtime';
2
+ import { IJsFixConfig } from '../../../config';
3
+ export declare class AppLauncher extends SessionLauncher {
4
+ constructor(client?: string, server?: string);
5
+ protected makeFactory(config: IJsFixConfig): EngineFactory;
6
+ }
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AppLauncher = void 0;
4
+ const runtime_1 = require("../../../runtime");
5
+ const trade_capture_client_1 = require("./trade-capture-client");
6
+ const trade_capture_server_1 = require("./trade-capture-server");
7
+ class AppLauncher extends runtime_1.SessionLauncher {
8
+ constructor(client = 'data/session/test-initiator.json', server = 'data/session/test-acceptor.json') {
9
+ super(client, server);
10
+ }
11
+ makeFactory(config) {
12
+ const isInitiator = this.isInitiator(config.description);
13
+ return {
14
+ makeSession: () => isInitiator ?
15
+ new trade_capture_client_1.TradeCaptureClient(config) :
16
+ new trade_capture_server_1.TradeCaptureServer(config)
17
+ };
18
+ }
19
+ }
20
+ exports.AppLauncher = AppLauncher;
21
+ //# sourceMappingURL=app-launcher.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"app-launcher.js","sourceRoot":"","sources":["../../../../src/sample/tcp/trade-capture/app-launcher.ts"],"names":[],"mappings":";;;AAAA,8CAAiE;AAEjE,iEAA2D;AAC3D,iEAA2D;AAE3D,MAAa,WAAY,SAAQ,yBAAe;IAC9C,YAAoB,SAAiB,kCAAkC,EACnD,SAAiB,iCAAiC;QACpE,KAAK,CACH,MAAM,EACN,MAAM,CAAC,CAAA;IACX,CAAC;IAEkB,WAAW,CAAE,MAAoB;QAClD,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,WAAW,CAAC,CAAA;QACxD,OAAO;YACL,WAAW,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,CAAC;gBAC9B,IAAI,yCAAkB,CAAC,MAAM,CAAC,CAAC,CAAC;gBAChC,IAAI,yCAAkB,CAAC,MAAM,CAAC;SAChB,CAAA;IACpB,CAAC;CACF;AAhBD,kCAgBC","sourcesContent":["import { EngineFactory, SessionLauncher } from '../../../runtime'\r\nimport { IJsFixConfig } from '../../../config'\r\nimport { TradeCaptureClient } from './trade-capture-client'\r\nimport { TradeCaptureServer } from './trade-capture-server'\r\n\r\nexport class AppLauncher extends SessionLauncher {\r\n public constructor (client: string = 'data/session/test-initiator.json',\r\n server: string = 'data/session/test-acceptor.json') {\r\n super(\r\n client,\r\n server)\r\n }\r\n\r\n protected override makeFactory (config: IJsFixConfig): EngineFactory {\r\n const isInitiator = this.isInitiator(config.description)\r\n return {\r\n makeSession: () => isInitiator ?\r\n new TradeCaptureClient(config) :\r\n new TradeCaptureServer(config)\r\n } as EngineFactory\r\n }\r\n}\r\n"]}
@@ -1 +1 @@
1
- export {};
1
+ import 'reflect-metadata';
@@ -1,24 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- const trade_capture_client_1 = require("./trade-capture-client");
4
- const trade_capture_server_1 = require("./trade-capture-server");
5
- const launcher_1 = require("../../launcher");
6
- const transport_1 = require("../../../transport");
7
- class AppLauncher extends launcher_1.Launcher {
8
- constructor() {
9
- super('data/session/test-initiator.json', 'data/session/test-acceptor.json');
10
- }
11
- getAcceptor(config) {
12
- return transport_1.acceptor(config, c => new trade_capture_server_1.TradeCaptureServer(c));
13
- }
14
- getInitiator(config) {
15
- return transport_1.initiator(config, c => new trade_capture_client_1.TradeCaptureClient(c));
16
- }
17
- }
18
- const l = new AppLauncher();
19
- l.run().then(() => {
20
- console.log('finished.');
21
- }).catch(e => {
22
- console.error(e);
23
- });
3
+ require("reflect-metadata");
4
+ const app_launcher_1 = require("./app-launcher");
5
+ const l = new app_launcher_1.AppLauncher();
6
+ l.exec();
24
7
  //# sourceMappingURL=app.js.map
@@ -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,4BAAyB;AACzB,iDAA4C;AAE5C,MAAM,CAAC,GAAG,IAAI,0BAAW,EAAE,CAAA;AAC3B,CAAC,CAAC,IAAI,EAAE,CAAA","sourcesContent":["import 'reflect-metadata'\r\nimport { AppLauncher } from './app-launcher'\r\n\r\nconst l = new AppLauncher()\r\nl.exec()\r\n"]}
@@ -1 +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"]}
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,\r\n 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"]}
@@ -1 +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
+ {"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,\r\n 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"]}
@@ -24,13 +24,19 @@ class TradeFactory {
24
24
  };
25
25
  }
26
26
  static tradeCaptureReportRequest(requestId, tradeDate) {
27
+ const d0 = tradeDate;
28
+ const d1 = new Date(tradeDate.getTime());
29
+ d1.setDate(d1.getDate() + 1);
27
30
  return {
28
31
  TradeRequestID: 'all-trades',
29
32
  TradeRequestType: repo_1.TradeRequestType.AllTrades,
30
33
  SubscriptionRequestType: repo_1.SubscriptionRequestType.SnapshotAndUpdates,
31
34
  TrdCapDtGrp: [
32
35
  {
33
- TradeDate: tradeDate
36
+ TransactTime: d0
37
+ },
38
+ {
39
+ TransactTime: d1
34
40
  }
35
41
  ]
36
42
  };