jspurefix 1.2.0 → 2.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1116) hide show
  1. package/.travis.yml +1 -1
  2. package/README.md +48 -2
  3. package/appveyor.yml +46 -11
  4. package/data/session/certs/ca/ca.crt +33 -0
  5. package/data/session/certs/ca/ca.key +54 -0
  6. package/data/session/certs/client/client.crt +31 -0
  7. package/data/session/certs/client/client.key +51 -0
  8. package/data/session/certs/server/server.crt +31 -0
  9. package/data/session/certs/server/server.key +51 -0
  10. package/data/session/genkey.ps1 +179 -0
  11. package/dist/a-session-msg-factory.d.ts +0 -0
  12. package/dist/a-session-msg-factory.js +1 -0
  13. package/dist/a-session-msg-factory.js.map +1 -0
  14. package/dist/ascii-encoder.test.d.ts +0 -0
  15. package/dist/ascii-encoder.test.js +1 -0
  16. package/dist/ascii-encoder.test.js.map +1 -0
  17. package/dist/ascii-parser.test.d.ts +0 -0
  18. package/dist/ascii-parser.test.js +1 -0
  19. package/dist/ascii-parser.test.js.map +1 -0
  20. package/dist/ascii-segment.test.d.ts +0 -0
  21. package/dist/ascii-segment.test.js +1 -0
  22. package/dist/ascii-segment.test.js.map +1 -0
  23. package/dist/ascii-store-replay.test.d.ts +0 -0
  24. package/dist/ascii-store-replay.test.js +1 -0
  25. package/dist/ascii-store-replay.test.js.map +1 -0
  26. package/dist/ascii-tag-pos.test.d.ts +0 -0
  27. package/dist/ascii-tag-pos.test.js +1 -0
  28. package/dist/ascii-tag-pos.test.js.map +1 -0
  29. package/dist/buffer/{ascii-chars.d.ts → ascii/ascii-chars.d.ts} +0 -0
  30. package/dist/buffer/{ascii-chars.js → ascii/ascii-chars.js} +0 -0
  31. package/dist/buffer/ascii/ascii-chars.js.map +1 -0
  32. package/dist/buffer/ascii/ascii-encoder.d.ts +5 -3
  33. package/dist/buffer/ascii/ascii-encoder.js +82 -48
  34. package/dist/buffer/ascii/ascii-encoder.js.map +1 -1
  35. package/dist/buffer/ascii/ascii-parser-state.d.ts +3 -10
  36. package/dist/buffer/ascii/ascii-parser-state.js +37 -25
  37. package/dist/buffer/ascii/ascii-parser-state.js.map +1 -1
  38. package/dist/buffer/ascii/ascii-parser.d.ts +7 -7
  39. package/dist/buffer/ascii/ascii-parser.js +50 -24
  40. package/dist/buffer/ascii/ascii-parser.js.map +1 -1
  41. package/dist/buffer/ascii/ascii-segment-parser.d.ts +2 -2
  42. package/dist/buffer/ascii/ascii-segment-parser.js +34 -13
  43. package/dist/buffer/ascii/ascii-segment-parser.js.map +1 -1
  44. package/dist/buffer/ascii/ascii-view.d.ts +2 -4
  45. package/dist/buffer/ascii/ascii-view.js +11 -15
  46. package/dist/buffer/ascii/ascii-view.js.map +1 -1
  47. package/dist/buffer/ascii/index.d.ts +1 -0
  48. package/dist/buffer/ascii/index.js +1 -0
  49. package/dist/buffer/ascii/index.js.map +1 -1
  50. package/dist/buffer/ascii/parse-state.d.ts +8 -0
  51. package/dist/buffer/ascii/parse-state.js +13 -0
  52. package/dist/buffer/ascii/parse-state.js.map +1 -0
  53. package/dist/buffer/ascii/time-formatter.js +1 -1
  54. package/dist/buffer/ascii/time-formatter.js.map +1 -1
  55. package/dist/buffer/elastic-buffer.js +29 -8
  56. package/dist/buffer/elastic-buffer.js.map +1 -1
  57. package/dist/buffer/encode-proxy.d.ts +1 -1
  58. package/dist/buffer/encode-proxy.js +16 -17
  59. package/dist/buffer/encode-proxy.js.map +1 -1
  60. package/dist/buffer/fixml/fixml-encoder.d.ts +2 -1
  61. package/dist/buffer/fixml/fixml-encoder.js +43 -20
  62. package/dist/buffer/fixml/fixml-encoder.js.map +1 -1
  63. package/dist/buffer/fixml/fixml-parser.js +47 -24
  64. package/dist/buffer/fixml/fixml-parser.js.map +1 -1
  65. package/dist/buffer/fixml/fixml-view.d.ts +2 -2
  66. package/dist/buffer/fixml/fixml-view.js +13 -13
  67. package/dist/buffer/fixml/fixml-view.js.map +1 -1
  68. package/dist/buffer/fixml/populated-attributes.d.ts +5 -0
  69. package/dist/buffer/fixml/populated-attributes.js +3 -0
  70. package/dist/buffer/fixml/populated-attributes.js.map +1 -0
  71. package/dist/buffer/index.d.ts +4 -8
  72. package/dist/buffer/index.js +4 -8
  73. package/dist/buffer/index.js.map +1 -1
  74. package/dist/buffer/msg-encoder.d.ts +2 -1
  75. package/dist/buffer/msg-encoder.js.map +1 -1
  76. package/dist/buffer/msg-view.d.ts +3 -3
  77. package/dist/buffer/msg-view.js +8 -5
  78. package/dist/buffer/msg-view.js.map +1 -1
  79. package/dist/buffer/segment/segment-description.d.ts +26 -0
  80. package/dist/buffer/segment/segment-description.js +72 -0
  81. package/dist/buffer/segment/segment-description.js.map +1 -0
  82. package/dist/buffer/segment/segment-summary.d.ts +13 -0
  83. package/dist/buffer/segment/segment-summary.js +20 -0
  84. package/dist/buffer/segment/segment-summary.js.map +1 -0
  85. package/dist/buffer/segment/segment-type.d.ts +8 -0
  86. package/dist/buffer/segment/segment-type.js +13 -0
  87. package/dist/buffer/segment/segment-type.js.map +1 -0
  88. package/dist/buffer/segment-description.d.ts +2 -9
  89. package/dist/buffer/segment-description.js +5 -13
  90. package/dist/buffer/segment-description.js.map +1 -1
  91. package/dist/buffer/segment-type.d.ts +8 -0
  92. package/dist/buffer/segment-type.js +13 -0
  93. package/dist/buffer/segment-type.js.map +1 -0
  94. package/dist/buffer/structure.d.ts +3 -3
  95. package/dist/buffer/structure.js +1 -1
  96. package/dist/buffer/structure.js.map +1 -1
  97. package/dist/buffer/tag/tag-pos.d.ts +12 -0
  98. package/dist/buffer/tag/tag-pos.js +55 -0
  99. package/dist/buffer/tag/tag-pos.js.map +1 -0
  100. package/dist/buffer/tag/tag-type.d.ts +13 -0
  101. package/dist/buffer/tag/tag-type.js +18 -0
  102. package/dist/buffer/tag/tag-type.js.map +1 -0
  103. package/dist/buffer/tag/tags.d.ts +21 -0
  104. package/dist/buffer/tag/tags.js +122 -0
  105. package/dist/buffer/tag/tags.js.map +1 -0
  106. package/dist/buffer/tag-type.d.ts +13 -0
  107. package/dist/buffer/tag-type.js +18 -0
  108. package/dist/buffer/tag-type.js.map +1 -0
  109. package/dist/buffer/tags.d.ts +3 -14
  110. package/dist/buffer/tags.js +23 -36
  111. package/dist/buffer/tags.js.map +1 -1
  112. package/dist/config/get-js-fx-logger.d.ts +4 -0
  113. package/dist/config/get-js-fx-logger.js +3 -0
  114. package/dist/config/get-js-fx-logger.js.map +1 -0
  115. package/dist/config/index.d.ts +1 -0
  116. package/dist/config/index.js +1 -0
  117. package/dist/config/index.js.map +1 -1
  118. package/dist/config/js-fix-config.d.ts +4 -1
  119. package/dist/config/js-fix-config.js +3 -3
  120. package/dist/config/js-fix-config.js.map +1 -1
  121. package/dist/config/js-fix-logger.d.ts +0 -3
  122. package/dist/config/js-fix-logger.js.map +1 -1
  123. package/dist/dict-parser.js +30 -25
  124. package/dist/dict-parser.js.map +1 -1
  125. package/dist/dictionary/compiler/compiler-type.js +7 -7
  126. package/dist/dictionary/compiler/compiler-type.js.map +1 -1
  127. package/dist/dictionary/compiler/enum-compiler.d.ts +1 -0
  128. package/dist/dictionary/compiler/enum-compiler.js +11 -1
  129. package/dist/dictionary/compiler/enum-compiler.js.map +1 -1
  130. package/dist/dictionary/compiler/msg-compiler.js +8 -6
  131. package/dist/dictionary/compiler/msg-compiler.js.map +1 -1
  132. package/dist/dictionary/contained/contained-component-field.js +2 -1
  133. package/dist/dictionary/contained/contained-component-field.js.map +1 -1
  134. package/dist/dictionary/contained/contained-field-dispatch.d.ts +1 -14
  135. package/dist/dictionary/contained/contained-field-dispatch.js +4 -4
  136. package/dist/dictionary/contained/contained-field-dispatch.js.map +1 -1
  137. package/dist/dictionary/contained/contained-field-dispatcher.d.ts +14 -0
  138. package/dist/dictionary/contained/contained-field-dispatcher.js +3 -0
  139. package/dist/dictionary/contained/contained-field-dispatcher.js.map +1 -0
  140. package/dist/dictionary/contained/contained-field-set.d.ts +1 -1
  141. package/dist/dictionary/contained/contained-field-set.js +12 -11
  142. package/dist/dictionary/contained/contained-field-set.js.map +1 -1
  143. package/dist/dictionary/contained/contained-field-type.d.ts +5 -0
  144. package/dist/dictionary/contained/contained-field-type.js +10 -0
  145. package/dist/dictionary/contained/contained-field-type.js.map +1 -0
  146. package/dist/dictionary/contained/contained-field.d.ts +1 -5
  147. package/dist/dictionary/contained/contained-field.js +1 -7
  148. package/dist/dictionary/contained/contained-field.js.map +1 -1
  149. package/dist/dictionary/contained/contained-group-field.js +2 -1
  150. package/dist/dictionary/contained/contained-group-field.js.map +1 -1
  151. package/dist/dictionary/contained/contained-simple-field.js +2 -1
  152. package/dist/dictionary/contained/contained-simple-field.js.map +1 -1
  153. package/dist/dictionary/{fields-dispatch.d.ts → contained/field-dispatcher.d.ts} +3 -2
  154. package/dist/dictionary/contained/field-dispatcher.js +3 -0
  155. package/dist/dictionary/contained/field-dispatcher.js.map +1 -0
  156. package/dist/dictionary/contained/fields-dispatch.d.ts +6 -0
  157. package/dist/dictionary/contained/fields-dispatch.js +42 -0
  158. package/dist/dictionary/contained/fields-dispatch.js.map +1 -0
  159. package/dist/dictionary/contained/index.d.ts +2 -0
  160. package/dist/dictionary/contained/index.js +2 -0
  161. package/dist/dictionary/contained/index.js.map +1 -1
  162. package/dist/dictionary/contained-set-type.d.ts +5 -0
  163. package/dist/dictionary/contained-set-type.js +10 -0
  164. package/dist/dictionary/contained-set-type.js.map +1 -0
  165. package/dist/dictionary/definition/component-field-definition.js +2 -2
  166. package/dist/dictionary/definition/component-field-definition.js.map +1 -1
  167. package/dist/dictionary/definition/fix-definitions.d.ts +2 -1
  168. package/dist/dictionary/definition/fix-definitions.js.map +1 -1
  169. package/dist/dictionary/definition/group-field-definition.js +2 -2
  170. package/dist/dictionary/definition/group-field-definition.js.map +1 -1
  171. package/dist/dictionary/definition/index.d.ts +0 -1
  172. package/dist/dictionary/definition/index.js +0 -1
  173. package/dist/dictionary/definition/index.js.map +1 -1
  174. package/dist/dictionary/definition/message-definition.js +2 -2
  175. package/dist/dictionary/definition/message-definition.js.map +1 -1
  176. package/dist/dictionary/definition/simple-field-definition.d.ts +1 -1
  177. package/dist/dictionary/definition/simple-field-definition.js +5 -4
  178. package/dist/dictionary/definition/simple-field-definition.js.map +1 -1
  179. package/dist/dictionary/dict-primitive.d.ts +0 -11
  180. package/dist/dictionary/dict-primitive.js +0 -7
  181. package/dist/dictionary/dict-primitive.js.map +1 -1
  182. package/dist/dictionary/fix-definition-source.d.ts +6 -0
  183. package/dist/dictionary/fix-definition-source.js +11 -0
  184. package/dist/dictionary/fix-definition-source.js.map +1 -0
  185. package/dist/dictionary/fix-versions.d.ts +0 -9
  186. package/dist/dictionary/fix-versions.js +1 -39
  187. package/dist/dictionary/fix-versions.js.map +1 -1
  188. package/dist/dictionary/index.d.ts +1 -5
  189. package/dist/dictionary/index.js +1 -5
  190. package/dist/dictionary/index.js.map +1 -1
  191. package/dist/dictionary/parser/fix-repository/abbreviations-parser.d.ts +1 -3
  192. package/dist/dictionary/parser/fix-repository/abbreviations-parser.js +2 -3
  193. package/dist/dictionary/parser/fix-repository/abbreviations-parser.js.map +1 -1
  194. package/dist/dictionary/parser/fix-repository/base-parser.d.ts +2 -4
  195. package/dist/dictionary/parser/fix-repository/base-parser.js +1 -2
  196. package/dist/dictionary/parser/fix-repository/base-parser.js.map +1 -1
  197. package/dist/dictionary/parser/fix-repository/components-parser.d.ts +1 -3
  198. package/dist/dictionary/parser/fix-repository/components-parser.js +2 -3
  199. package/dist/dictionary/parser/fix-repository/components-parser.js.map +1 -1
  200. package/dist/dictionary/parser/fix-repository/data-types-parser.d.ts +1 -3
  201. package/dist/dictionary/parser/fix-repository/data-types-parser.js +2 -3
  202. package/dist/dictionary/parser/fix-repository/data-types-parser.js.map +1 -1
  203. package/dist/dictionary/parser/fix-repository/enums-parser.d.ts +1 -3
  204. package/dist/dictionary/parser/fix-repository/enums-parser.js +2 -3
  205. package/dist/dictionary/parser/fix-repository/enums-parser.js.map +1 -1
  206. package/dist/dictionary/parser/fix-repository/fields-parser.d.ts +1 -3
  207. package/dist/dictionary/parser/fix-repository/fields-parser.js +2 -3
  208. package/dist/dictionary/parser/fix-repository/fields-parser.js.map +1 -1
  209. package/dist/dictionary/parser/fix-repository/messages-parser.d.ts +1 -3
  210. package/dist/dictionary/parser/fix-repository/messages-parser.js +2 -3
  211. package/dist/dictionary/parser/fix-repository/messages-parser.js.map +1 -1
  212. package/dist/dictionary/parser/fix-repository/msg-contents-parser.d.ts +1 -3
  213. package/dist/dictionary/parser/fix-repository/msg-contents-parser.js +2 -3
  214. package/dist/dictionary/parser/fix-repository/msg-contents-parser.js.map +1 -1
  215. package/dist/dictionary/parser/fix-repository/repository-abbreviation.d.ts +5 -0
  216. package/dist/dictionary/parser/fix-repository/repository-abbreviation.js +3 -0
  217. package/dist/dictionary/parser/fix-repository/repository-abbreviation.js.map +1 -0
  218. package/dist/dictionary/parser/fix-repository/repository-component.d.ts +10 -0
  219. package/dist/dictionary/parser/fix-repository/repository-component.js +3 -0
  220. package/dist/dictionary/parser/fix-repository/repository-component.js.map +1 -0
  221. package/dist/dictionary/parser/fix-repository/repository-data-type.d.ts +6 -0
  222. package/dist/dictionary/parser/fix-repository/repository-data-type.js +3 -0
  223. package/dist/dictionary/parser/fix-repository/repository-data-type.js.map +1 -0
  224. package/dist/dictionary/parser/fix-repository/repository-enum.d.ts +7 -0
  225. package/dist/{standard_header.js → dictionary/parser/fix-repository/repository-enum.js} +1 -1
  226. package/dist/dictionary/parser/fix-repository/repository-enum.js.map +1 -0
  227. package/dist/dictionary/parser/fix-repository/repository-field.d.ts +11 -0
  228. package/dist/dictionary/parser/fix-repository/repository-field.js +3 -0
  229. package/dist/dictionary/parser/fix-repository/repository-field.js.map +1 -0
  230. package/dist/dictionary/parser/fix-repository/repository-message.d.ts +11 -0
  231. package/dist/dictionary/parser/fix-repository/repository-message.js +3 -0
  232. package/dist/dictionary/parser/fix-repository/repository-message.js.map +1 -0
  233. package/dist/dictionary/parser/fix-repository/repository-msg-content.d.ts +9 -0
  234. package/dist/dictionary/parser/fix-repository/repository-msg-content.js +3 -0
  235. package/dist/dictionary/parser/fix-repository/repository-msg-content.js.map +1 -0
  236. package/dist/dictionary/parser/fix-repository/repository-msg.d.ts +0 -0
  237. package/dist/dictionary/parser/fix-repository/repository-msg.js +1 -0
  238. package/dist/dictionary/parser/fix-repository/repository-msg.js.map +1 -0
  239. package/dist/dictionary/parser/fix-repository/repository-type.d.ts +0 -53
  240. package/dist/dictionary/parser/fix-repository/repository-type.js +0 -2
  241. package/dist/dictionary/parser/fix-repository/repository-type.js.map +1 -1
  242. package/dist/dictionary/parser/fix-repository/repository-xml-parser.js +10 -10
  243. package/dist/dictionary/parser/fix-repository/repository-xml-parser.js.map +1 -1
  244. package/dist/dictionary/parser/fix-repository/repository.d.ts +12 -1
  245. package/dist/dictionary/parser/fix-repository/repository.js +50 -28
  246. package/dist/dictionary/parser/fix-repository/repository.js.map +1 -1
  247. package/dist/dictionary/parser/fixml/components-parser.d.ts +1 -1
  248. package/dist/dictionary/parser/fixml/components-parser.js.map +1 -1
  249. package/dist/dictionary/parser/fixml/fields-parser.d.ts +1 -1
  250. package/dist/dictionary/parser/fixml/fields-parser.js.map +1 -1
  251. package/dist/dictionary/parser/fixml/fix-xsd-parser.js +3 -2
  252. package/dist/dictionary/parser/fixml/fix-xsd-parser.js.map +1 -1
  253. package/dist/dictionary/parser/fixml/include-graph.js.map +1 -1
  254. package/dist/dictionary/parser/fixml/xsd-parser.d.ts +1 -1
  255. package/dist/dictionary/parser/fixml/xsd-parser.js.map +1 -1
  256. package/dist/dictionary/parser/quickfix/field-definition-parser.d.ts +4 -4
  257. package/dist/dictionary/parser/quickfix/field-definition-parser.js +3 -3
  258. package/dist/dictionary/parser/quickfix/field-definition-parser.js.map +1 -1
  259. package/dist/dictionary/parser/quickfix/field-set-parser.d.ts +4 -4
  260. package/dist/dictionary/parser/quickfix/field-set-parser.js +3 -3
  261. package/dist/dictionary/parser/quickfix/field-set-parser.js.map +1 -1
  262. package/dist/dictionary/parser/quickfix/message-parser.d.ts +4 -4
  263. package/dist/dictionary/parser/quickfix/message-parser.js +3 -3
  264. package/dist/dictionary/parser/quickfix/message-parser.js.map +1 -1
  265. package/dist/dictionary/parser/quickfix/node-parser.d.ts +4 -5
  266. package/dist/dictionary/parser/quickfix/node-parser.js +4 -4
  267. package/dist/dictionary/parser/quickfix/node-parser.js.map +1 -1
  268. package/dist/dictionary/parser/quickfix/parse-state.d.ts +8 -0
  269. package/dist/dictionary/parser/quickfix/parse-state.js +13 -0
  270. package/dist/dictionary/parser/quickfix/parse-state.js.map +1 -0
  271. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.d.ts +1 -9
  272. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js +28 -35
  273. package/dist/dictionary/parser/quickfix/quick-fix-xml-file-parser.js.map +1 -1
  274. package/dist/dictionary/sax-node.d.ts +6 -0
  275. package/dist/{header.js → dictionary/sax-node.js} +1 -1
  276. package/dist/dictionary/sax-node.js.map +1 -0
  277. package/dist/dictionary/set-reduce.d.ts +5 -12
  278. package/dist/dictionary/set-reduce.js +28 -26
  279. package/dist/dictionary/set-reduce.js.map +1 -1
  280. package/dist/dictionary/type-dispatcher.d.ts +12 -0
  281. package/dist/dictionary/type-dispatcher.js +3 -0
  282. package/dist/dictionary/type-dispatcher.js.map +1 -0
  283. package/dist/dictionary/version-util.d.ts +4 -0
  284. package/dist/dictionary/version-util.js +36 -0
  285. package/dist/dictionary/version-util.js.map +1 -0
  286. package/dist/execution-report.test.d.ts +0 -0
  287. package/dist/execution-report.test.js +1 -0
  288. package/dist/execution-report.test.js.map +1 -0
  289. package/dist/experiment.d.ts +0 -0
  290. package/dist/experiment.js +1 -0
  291. package/dist/experiment.js.map +1 -0
  292. package/dist/fix-repo-dict.test.d.ts +0 -0
  293. package/dist/fix-repo-dict.test.js +1 -0
  294. package/dist/fix-repo-dict.test.js.map +1 -0
  295. package/dist/fix-session-state-args.d.ts +0 -0
  296. package/dist/fix-session-state-args.js +1 -0
  297. package/dist/fix-session-state-args.js.map +1 -0
  298. package/dist/fix-session-state.d.ts +0 -0
  299. package/dist/fix-session-state.js +1 -0
  300. package/dist/fix-session-state.js.map +1 -0
  301. package/dist/fix-session.d.ts +0 -0
  302. package/dist/fix-session.js +1 -0
  303. package/dist/fix-session.js.map +1 -0
  304. package/dist/fix.txt +1 -1
  305. package/dist/fixml-alloc-parse.test.d.ts +0 -0
  306. package/dist/fixml-alloc-parse.test.js +1 -0
  307. package/dist/fixml-alloc-parse.test.js.map +1 -0
  308. package/dist/fixml-mkt-data-fut-parse.test.d.ts +0 -0
  309. package/dist/fixml-mkt-data-fut-parse.test.js +1 -0
  310. package/dist/fixml-mkt-data-fut-parse.test.js.map +1 -0
  311. package/dist/fixml-mkt-data-settle-parse.test.d.ts +0 -0
  312. package/dist/fixml-mkt-data-settle-parse.test.js +1 -0
  313. package/dist/fixml-mkt-data-settle-parse.test.js.map +1 -0
  314. package/dist/fixml-tc-bi-lateral-parse.test.d.ts +0 -0
  315. package/dist/fixml-tc-bi-lateral-parse.test.js +1 -0
  316. package/dist/fixml-tc-bi-lateral-parse.test.js.map +1 -0
  317. package/dist/includes.test.d.ts +0 -0
  318. package/dist/includes.test.js +1 -0
  319. package/dist/includes.test.js.map +1 -0
  320. package/dist/index.d.ts +1 -0
  321. package/dist/index.js +1 -0
  322. package/dist/index.js.map +1 -1
  323. package/dist/jsfix-cmd.d.ts +5 -0
  324. package/dist/jsfix-cmd.js +28 -21
  325. package/dist/jsfix-cmd.js.map +1 -1
  326. package/dist/launcher.d.ts +0 -0
  327. package/dist/launcher.js +1 -0
  328. package/dist/launcher.js.map +1 -0
  329. package/dist/logon.test.d.ts +0 -0
  330. package/dist/logon.test.js +1 -0
  331. package/dist/logon.test.js.map +1 -0
  332. package/dist/make-fix-session.d.ts +0 -0
  333. package/dist/make-fix-session.js +1 -0
  334. package/dist/make-fix-session.js.map +1 -0
  335. package/dist/memory-store.test.d.ts +0 -0
  336. package/dist/memory-store.test.js +1 -0
  337. package/dist/memory-store.test.js.map +1 -0
  338. package/dist/object.json +473 -698
  339. package/dist/qf-full-msg.test.d.ts +0 -0
  340. package/dist/qf-full-msg.test.js +1 -0
  341. package/dist/qf-full-msg.test.js.map +1 -0
  342. package/dist/repo-full-ascii-msg.test.d.ts +0 -0
  343. package/dist/repo-full-ascii-msg.test.js +1 -0
  344. package/dist/repo-full-ascii-msg.test.js.map +1 -0
  345. package/dist/runtime/DITokens.d.ts +20 -0
  346. package/dist/runtime/DITokens.js +25 -0
  347. package/dist/runtime/DITokens.js.map +1 -0
  348. package/dist/runtime/app-launcher.d.ts +27 -0
  349. package/dist/runtime/app-launcher.js +131 -0
  350. package/dist/runtime/app-launcher.js.map +1 -0
  351. package/dist/runtime/di-tokens.d.ts +28 -0
  352. package/dist/runtime/di-tokens.js +33 -0
  353. package/dist/runtime/di-tokens.js.map +1 -0
  354. package/dist/runtime/engine-factory.d.ts +4 -0
  355. package/dist/runtime/engine-factory.js +3 -0
  356. package/dist/runtime/engine-factory.js.map +1 -0
  357. package/dist/runtime/index.d.ts +5 -0
  358. package/dist/runtime/index.js +18 -0
  359. package/dist/runtime/index.js.map +1 -0
  360. package/dist/runtime/launcher.d.ts +29 -0
  361. package/dist/runtime/launcher.js +131 -0
  362. package/dist/runtime/launcher.js.map +1 -0
  363. package/dist/runtime/make-config.d.ts +11 -0
  364. package/dist/runtime/make-config.js +57 -0
  365. package/dist/runtime/make-config.js.map +1 -0
  366. package/dist/runtime/session-container.d.ts +16 -0
  367. package/dist/runtime/session-container.js +168 -0
  368. package/dist/runtime/session-container.js.map +1 -0
  369. package/dist/runtime/session-launcher.d.ts +26 -0
  370. package/dist/runtime/session-launcher.js +131 -0
  371. package/dist/runtime/session-launcher.js.map +1 -0
  372. package/dist/sample/http/oms/app.d.ts +1 -1
  373. package/dist/sample/http/oms/app.js +16 -12
  374. package/dist/sample/http/oms/app.js.map +1 -1
  375. package/dist/sample/http/oms/http-client.js +22 -2
  376. package/dist/sample/http/oms/http-client.js.map +1 -1
  377. package/dist/sample/http/oms/http-server.js +21 -2
  378. package/dist/sample/http/oms/http-server.js.map +1 -1
  379. package/dist/sample/launcher.d.ts +21 -3
  380. package/dist/sample/launcher.js +88 -11
  381. package/dist/sample/launcher.js.map +1 -1
  382. package/dist/sample/tcp/qf-md/app.d.ts +1 -1
  383. package/dist/sample/tcp/qf-md/app.js +11 -11
  384. package/dist/sample/tcp/qf-md/app.js.map +1 -1
  385. package/dist/sample/tcp/qf-md/md-client.js +21 -2
  386. package/dist/sample/tcp/qf-md/md-client.js.map +1 -1
  387. package/dist/sample/tcp/qf-md/md-server.js +20 -2
  388. package/dist/sample/tcp/qf-md/md-server.js.map +1 -1
  389. package/dist/sample/tcp/recovering-skeleton/app.d.ts +1 -1
  390. package/dist/sample/tcp/recovering-skeleton/app.js +36 -16
  391. package/dist/sample/tcp/recovering-skeleton/app.js.map +1 -1
  392. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.d.ts +3 -1
  393. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js +30 -8
  394. package/dist/sample/tcp/recovering-skeleton/respawn-acceptor.js.map +1 -1
  395. package/dist/sample/tcp/recovering-skeleton/skeleton-client.d.ts +1 -1
  396. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js +22 -3
  397. package/dist/sample/tcp/recovering-skeleton/skeleton-client.js.map +1 -1
  398. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js +21 -2
  399. package/dist/sample/tcp/recovering-skeleton/skeleton-server.js.map +1 -1
  400. package/dist/sample/tcp/skeleton/app.d.ts +1 -1
  401. package/dist/sample/tcp/skeleton/app.js +8 -13
  402. package/dist/sample/tcp/skeleton/app.js.map +1 -1
  403. package/dist/sample/tcp/skeleton/skeleton-session.d.ts +5 -1
  404. package/dist/sample/tcp/skeleton/skeleton-session.js +45 -4
  405. package/dist/sample/tcp/skeleton/skeleton-session.js.map +1 -1
  406. package/dist/sample/tcp/tls-trade-capture/app.d.ts +1 -1
  407. package/dist/sample/tcp/tls-trade-capture/app.js +4 -24
  408. package/dist/sample/tcp/tls-trade-capture/app.js.map +1 -1
  409. package/dist/sample/tcp/trade-capture/app-launcher.d.ts +6 -0
  410. package/dist/sample/tcp/trade-capture/app-launcher.js +21 -0
  411. package/dist/sample/tcp/trade-capture/app-launcher.js.map +1 -0
  412. package/dist/sample/tcp/trade-capture/app-launher.d.ts +0 -0
  413. package/dist/sample/tcp/trade-capture/app-launher.js +1 -0
  414. package/dist/sample/tcp/trade-capture/app-launher.js.map +1 -0
  415. package/dist/sample/tcp/trade-capture/app.d.ts +1 -1
  416. package/dist/sample/tcp/trade-capture/app.js +4 -21
  417. package/dist/sample/tcp/trade-capture/app.js.map +1 -1
  418. package/dist/sample/tcp/trade-capture/jsfix.test_client.txt +11 -14
  419. package/dist/sample/tcp/trade-capture/jsfix.test_server.txt +10 -14
  420. package/dist/sample/tcp/trade-capture/trade-capture-client.d.ts +1 -0
  421. package/dist/sample/tcp/trade-capture/trade-capture-client.js +7 -3
  422. package/dist/sample/tcp/trade-capture/trade-capture-client.js.map +1 -1
  423. package/dist/sample/tcp/trade-capture/trade-capture-server.js.map +1 -1
  424. package/dist/sample/tcp/trade-capture/trade-factory.js +7 -1
  425. package/dist/sample/tcp/trade-capture/trade-factory.js.map +1 -1
  426. package/dist/segment-description.d.ts +0 -0
  427. package/dist/segment-description.js +1 -0
  428. package/dist/segment-description.js.map +1 -0
  429. package/dist/segment-summary.d.ts +0 -0
  430. package/dist/segment-summary.js +1 -0
  431. package/dist/segment-summary.js.map +1 -0
  432. package/dist/segment-type.d.ts +0 -0
  433. package/dist/segment-type.js +1 -0
  434. package/dist/segment-type.js.map +1 -0
  435. package/dist/session-description.d.ts +0 -0
  436. package/dist/session-description.js +1 -0
  437. package/dist/session-description.js.map +1 -0
  438. package/dist/session-msg-factory.d.ts +0 -0
  439. package/dist/session-msg-factory.js +1 -0
  440. package/dist/session-msg-factory.js.map +1 -0
  441. package/dist/session-state.d.ts +0 -0
  442. package/dist/session-state.js +1 -0
  443. package/dist/session-state.js.map +1 -0
  444. package/dist/session-state.test.d.ts +0 -0
  445. package/dist/session-state.test.js +1 -0
  446. package/dist/session-state.test.js.map +1 -0
  447. package/dist/session.test.d.ts +0 -0
  448. package/dist/session.test.js +1 -0
  449. package/dist/session.test.js.map +1 -0
  450. package/dist/setup.d.ts +0 -0
  451. package/dist/setup.js +1 -0
  452. package/dist/setup.js.map +1 -0
  453. package/dist/skeleton-runner.d.ts +0 -0
  454. package/dist/skeleton-runner.js +1 -0
  455. package/dist/skeleton-runner.js.map +1 -0
  456. package/dist/store/fix-msg-ascii-store-resend.d.ts +3 -2
  457. package/dist/store/fix-msg-ascii-store-resend.js +30 -21
  458. package/dist/store/fix-msg-ascii-store-resend.js.map +1 -1
  459. package/dist/store/fix-msg-memory-store.d.ts +11 -8
  460. package/dist/store/fix-msg-memory-store.js +108 -42
  461. package/dist/store/fix-msg-memory-store.js.map +1 -1
  462. package/dist/store/fix-msg-store-record.d.ts +4 -0
  463. package/dist/store/fix-msg-store-record.js +7 -0
  464. package/dist/store/fix-msg-store-record.js.map +1 -1
  465. package/dist/store/fix-msg-store-state.d.ts +6 -0
  466. package/dist/store/fix-msg-store-state.js +3 -0
  467. package/dist/store/fix-msg-store-state.js.map +1 -0
  468. package/dist/store/fix-msg-store.d.ts +8 -9
  469. package/dist/store/fix-msg-store.js.map +1 -1
  470. package/dist/structure.json +225 -485
  471. package/dist/tag-pos.d.ts +0 -0
  472. package/dist/tag-pos.js +1 -0
  473. package/dist/tag-pos.js.map +1 -0
  474. package/dist/tag-type.d.ts +0 -0
  475. package/dist/tag-type.js +1 -0
  476. package/dist/tag-type.js.map +1 -0
  477. package/dist/tags.d.ts +0 -0
  478. package/dist/tags.js +1 -0
  479. package/dist/tags.js.map +1 -0
  480. package/dist/test/ascii/ascii-encoder.test.d.ts +1 -0
  481. package/dist/test/ascii/ascii-encoder.test.js +507 -0
  482. package/dist/test/ascii/ascii-encoder.test.js.map +1 -0
  483. package/dist/test/ascii/ascii-parser.test.d.ts +1 -0
  484. package/dist/test/ascii/ascii-parser.test.js +123 -0
  485. package/dist/test/ascii/ascii-parser.test.js.map +1 -0
  486. package/dist/test/ascii/ascii-segment.test.d.ts +1 -0
  487. package/dist/test/ascii/ascii-segment.test.js +86 -0
  488. package/dist/test/ascii/ascii-segment.test.js.map +1 -0
  489. package/dist/test/ascii/ascii-store-replay.test.d.ts +1 -0
  490. package/dist/test/ascii/ascii-store-replay.test.js +92 -0
  491. package/dist/test/ascii/ascii-store-replay.test.js.map +1 -0
  492. package/dist/test/ascii/ascii-tag-pos.test.d.ts +1 -0
  493. package/dist/test/ascii/ascii-tag-pos.test.js +105 -0
  494. package/dist/test/ascii/ascii-tag-pos.test.js.map +1 -0
  495. package/dist/test/ascii/execution-report.test.d.ts +1 -0
  496. package/dist/test/ascii/execution-report.test.js +489 -0
  497. package/dist/test/ascii/execution-report.test.js.map +1 -0
  498. package/dist/test/ascii/fix-log-replay.test.d.ts +1 -0
  499. package/dist/test/{memory-store-test.js → ascii/fix-log-replay.test.js} +11 -23
  500. package/dist/test/ascii/fix-log-replay.test.js.map +1 -0
  501. package/dist/test/ascii/fix-repo-dict.test.d.ts +1 -0
  502. package/dist/test/ascii/fix-repo-dict.test.js +128 -0
  503. package/dist/test/ascii/fix-repo-dict.test.js.map +1 -0
  504. package/dist/test/ascii/includes.test.d.ts +1 -0
  505. package/dist/test/ascii/includes.test.js +43 -0
  506. package/dist/test/ascii/includes.test.js.map +1 -0
  507. package/dist/test/ascii/logon.test.d.ts +1 -0
  508. package/dist/test/ascii/logon.test.js +91 -0
  509. package/dist/test/ascii/logon.test.js.map +1 -0
  510. package/dist/test/ascii/memory-store.test.d.ts +1 -0
  511. package/dist/test/ascii/memory-store.test.js +75 -0
  512. package/dist/test/ascii/memory-store.test.js.map +1 -0
  513. package/dist/test/ascii/qf-full-msg.test.d.ts +1 -0
  514. package/dist/test/ascii/qf-full-msg.test.js +81 -0
  515. package/dist/test/ascii/qf-full-msg.test.js.map +1 -0
  516. package/dist/test/ascii/repo-full-ascii-msg.test.d.ts +1 -0
  517. package/dist/test/ascii/repo-full-ascii-msg.test.js +87 -0
  518. package/dist/test/ascii/repo-full-ascii-msg.test.js.map +1 -0
  519. package/dist/test/ascii/session-state.test.d.ts +1 -0
  520. package/dist/test/ascii/session-state.test.js +73 -0
  521. package/dist/test/ascii/session-state.test.js.map +1 -0
  522. package/dist/test/ascii/session.test.d.ts +1 -0
  523. package/dist/test/ascii/session.test.js +280 -0
  524. package/dist/test/ascii/session.test.js.map +1 -0
  525. package/dist/test/ascii/time-formatter.test.d.ts +1 -0
  526. package/dist/test/ascii/time-formatter.test.js +80 -0
  527. package/dist/test/ascii/time-formatter.test.js.map +1 -0
  528. package/dist/test/ascii/view-decode.test.d.ts +1 -0
  529. package/dist/test/ascii/view-decode.test.js +183 -0
  530. package/dist/test/ascii/view-decode.test.js.map +1 -0
  531. package/dist/test/ascii-encoder.test.d.ts +1 -0
  532. package/dist/test/{ascii-encode.test.js → ascii-encoder.test.js} +140 -48
  533. package/dist/test/ascii-encoder.test.js.map +1 -0
  534. package/dist/test/ascii-parser.test.d.ts +1 -1
  535. package/dist/test/ascii-parser.test.js +31 -48
  536. package/dist/test/ascii-parser.test.js.map +1 -1
  537. package/dist/test/ascii-segment.test.d.ts +1 -1
  538. package/dist/test/ascii-segment.test.js +19 -39
  539. package/dist/test/ascii-segment.test.js.map +1 -1
  540. package/dist/test/ascii-store-replay.test.d.ts +1 -1
  541. package/dist/test/ascii-store-replay.test.js +32 -44
  542. package/dist/test/ascii-store-replay.test.js.map +1 -1
  543. package/dist/test/ascii-tag-pos.test.d.ts +1 -1
  544. package/dist/test/ascii-tag-pos.test.js +8 -8
  545. package/dist/test/ascii-tag-pos.test.js.map +1 -1
  546. package/dist/test/elastic-buffer.test.d.ts +1 -1
  547. package/dist/test/elastic-buffer.test.js +3 -1
  548. package/dist/test/elastic-buffer.test.js.map +1 -1
  549. package/dist/test/encode-proxy.test.d.ts +1 -1
  550. package/dist/test/encode-proxy.test.js +9 -9
  551. package/dist/test/encode-proxy.test.js.map +1 -1
  552. package/dist/test/env/experiment.d.ts +23 -0
  553. package/dist/test/env/experiment.js +33 -0
  554. package/dist/test/env/experiment.js.map +1 -0
  555. package/dist/test/env/parsing-result.d.ts +10 -0
  556. package/dist/test/env/parsing-result.js +14 -0
  557. package/dist/test/env/parsing-result.js.map +1 -0
  558. package/dist/test/env/setup.d.ts +39 -0
  559. package/dist/test/env/setup.js +98 -0
  560. package/dist/test/env/setup.js.map +1 -0
  561. package/dist/test/env/skeleton-runner.d.ts +15 -0
  562. package/dist/test/env/skeleton-runner.js +108 -0
  563. package/dist/test/env/skeleton-runner.js.map +1 -0
  564. package/dist/test/env/test-recovery.d.ts +13 -0
  565. package/dist/test/env/test-recovery.js +41 -0
  566. package/dist/test/env/test-recovery.js.map +1 -0
  567. package/dist/test/env/to-views.d.ts +11 -0
  568. package/dist/test/env/to-views.js +56 -0
  569. package/dist/test/env/to-views.js.map +1 -0
  570. package/dist/test/execution-report.test.d.ts +1 -1
  571. package/dist/test/execution-report.test.js +53 -49
  572. package/dist/test/execution-report.test.js.map +1 -1
  573. package/dist/test/experiment.d.ts +23 -0
  574. package/dist/test/experiment.js +33 -0
  575. package/dist/test/experiment.js.map +1 -0
  576. package/dist/test/expieriment.d.ts +23 -0
  577. package/dist/test/expieriment.js +33 -0
  578. package/dist/test/expieriment.js.map +1 -0
  579. package/dist/test/fix-log-replay.test.d.ts +1 -1
  580. package/dist/test/fix-log-replay.test.js +7 -5
  581. package/dist/test/fix-log-replay.test.js.map +1 -1
  582. package/dist/test/fix-repo-dict.test.d.ts +1 -1
  583. package/dist/test/fix-repo-dict.test.js +6 -5
  584. package/dist/test/fix-repo-dict.test.js.map +1 -1
  585. package/dist/test/fixml/fixml-alloc-parse.test.d.ts +1 -0
  586. package/dist/test/fixml/fixml-alloc-parse.test.js +161 -0
  587. package/dist/test/fixml/fixml-alloc-parse.test.js.map +1 -0
  588. package/dist/test/fixml/fixml-mkt-data-fut-parse.test.d.ts +1 -0
  589. package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js +61 -0
  590. package/dist/test/fixml/fixml-mkt-data-fut-parse.test.js.map +1 -0
  591. package/dist/test/fixml/fixml-mkt-data-settle-parse.test.d.ts +1 -0
  592. package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js +34 -0
  593. package/dist/test/fixml/fixml-mkt-data-settle-parse.test.js.map +1 -0
  594. package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.d.ts +1 -0
  595. package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js +97 -0
  596. package/dist/test/fixml/fixml-tc-bi-lateral-parse.test.js.map +1 -0
  597. package/dist/test/fixml/repo-full-fixml-msg.test.d.ts +1 -0
  598. package/dist/test/fixml/repo-full-fixml-msg.test.js +143 -0
  599. package/dist/test/fixml/repo-full-fixml-msg.test.js.map +1 -0
  600. package/dist/test/fixml-alloc-parse.test.d.ts +1 -1
  601. package/dist/test/fixml-alloc-parse.test.js +2 -1
  602. package/dist/test/fixml-alloc-parse.test.js.map +1 -1
  603. package/dist/test/fixml-mkt-data-fut-parse.test.d.ts +1 -1
  604. package/dist/test/fixml-mkt-data-fut-parse.test.js +2 -1
  605. package/dist/test/fixml-mkt-data-fut-parse.test.js.map +1 -1
  606. package/dist/test/fixml-mkt-data-settle-parse.test.d.ts +1 -1
  607. package/dist/test/fixml-mkt-data-settle-parse.test.js +2 -1
  608. package/dist/test/fixml-mkt-data-settle-parse.test.js.map +1 -1
  609. package/dist/test/fixml-tc-bi-lateral-parse.test.d.ts +1 -1
  610. package/dist/test/fixml-tc-bi-lateral-parse.test.js +2 -1
  611. package/dist/test/fixml-tc-bi-lateral-parse.test.js.map +1 -1
  612. package/dist/test/includes.test.d.ts +1 -1
  613. package/dist/test/includes.test.js +1 -0
  614. package/dist/test/includes.test.js.map +1 -1
  615. package/dist/test/logon.test.d.ts +1 -1
  616. package/dist/test/logon.test.js +11 -11
  617. package/dist/test/logon.test.js.map +1 -1
  618. package/dist/test/memory-store.test.d.ts +1 -1
  619. package/dist/test/memory-store.test.js +35 -27
  620. package/dist/test/memory-store.test.js.map +1 -1
  621. package/dist/test/qf-full-msg.test.d.ts +1 -1
  622. package/dist/test/qf-full-msg.test.js +25 -19
  623. package/dist/test/qf-full-msg.test.js.map +1 -1
  624. package/dist/test/repo-full-ascii-msg.test.d.ts +1 -1
  625. package/dist/test/repo-full-ascii-msg.test.js +28 -22
  626. package/dist/test/repo-full-ascii-msg.test.js.map +1 -1
  627. package/dist/test/repo-full-fixml-msg.test.d.ts +1 -1
  628. package/dist/test/repo-full-fixml-msg.test.js +21 -18
  629. package/dist/test/repo-full-fixml-msg.test.js.map +1 -1
  630. package/dist/test/session-state.test.d.ts +1 -1
  631. package/dist/test/session-state.test.js +2 -1
  632. package/dist/test/session-state.test.js.map +1 -1
  633. package/dist/test/session.test.d.ts +1 -1
  634. package/dist/test/session.test.js +152 -163
  635. package/dist/test/session.test.js.map +1 -1
  636. package/dist/test/setup.d.ts +45 -0
  637. package/dist/test/setup.js +102 -0
  638. package/dist/test/setup.js.map +1 -0
  639. package/dist/test/skeleton-runner.d.ts +15 -0
  640. package/dist/test/skeleton-runner.js +108 -0
  641. package/dist/test/skeleton-runner.js.map +1 -0
  642. package/dist/test/time-formatter.test.d.ts +1 -1
  643. package/dist/test/time-formatter.test.js +3 -1
  644. package/dist/test/time-formatter.test.js.map +1 -1
  645. package/dist/test/to-views.d.ts +1 -1
  646. package/dist/test/to-views.js +5 -4
  647. package/dist/test/to-views.js.map +1 -1
  648. package/dist/test/view-decode.test.d.ts +1 -1
  649. package/dist/test/view-decode.test.js +9 -33
  650. package/dist/test/view-decode.test.js.map +1 -1
  651. package/dist/time-formatter.test.d.ts +0 -0
  652. package/dist/time-formatter.test.js +1 -0
  653. package/dist/time-formatter.test.js.map +1 -0
  654. package/dist/to-views.d.ts +0 -0
  655. package/dist/to-views.js +1 -0
  656. package/dist/to-views.js.map +1 -0
  657. package/dist/token.txt +246 -308
  658. package/dist/transport/FixEntity.d.ts +8 -0
  659. package/dist/transport/FixEntity.js +12 -0
  660. package/dist/transport/FixEntity.js.map +1 -0
  661. package/dist/transport/a-session-msg-factory.d.ts +23 -0
  662. package/dist/transport/a-session-msg-factory.js +58 -0
  663. package/dist/transport/a-session-msg-factory.js.map +1 -0
  664. package/dist/transport/ascii/ascii-msg-transmitter.js +50 -12
  665. package/dist/transport/ascii/ascii-msg-transmitter.js.map +1 -1
  666. package/dist/transport/ascii/ascii-session-msg-factory.d.ts +16 -0
  667. package/dist/transport/ascii/ascii-session-msg-factory.js +47 -0
  668. package/dist/transport/ascii/ascii-session-msg-factory.js.map +1 -0
  669. package/dist/transport/ascii/ascii-session.d.ts +10 -1
  670. package/dist/transport/ascii/ascii-session.js +98 -41
  671. package/dist/transport/ascii/ascii-session.js.map +1 -1
  672. package/dist/transport/ascii/index.d.ts +1 -1
  673. package/dist/transport/ascii/index.js +1 -1
  674. package/dist/transport/ascii/index.js.map +1 -1
  675. package/dist/transport/duplex/http-duplex.d.ts +1 -1
  676. package/dist/transport/duplex/http-duplex.js +2 -2
  677. package/dist/transport/duplex/http-duplex.js.map +1 -1
  678. package/dist/transport/duplex/tcp-duplex.js +22 -2
  679. package/dist/transport/duplex/tcp-duplex.js.map +1 -1
  680. package/dist/transport/factory/index.d.ts +1 -0
  681. package/dist/{sample/tcp/trade_capture → transport/factory}/index.js +1 -2
  682. package/dist/transport/factory/index.js.map +1 -0
  683. package/dist/transport/{msg-transport.d.ts → factory/msg-transport.d.ts} +4 -4
  684. package/dist/transport/factory/msg-transport.js +61 -0
  685. package/dist/transport/factory/msg-transport.js.map +1 -0
  686. package/dist/transport/fix-acceptor.d.ts +2 -2
  687. package/dist/transport/fix-acceptor.js.map +1 -1
  688. package/dist/transport/fix-entity.d.ts +8 -0
  689. package/dist/transport/fix-entity.js +12 -0
  690. package/dist/transport/fix-entity.js.map +1 -0
  691. package/dist/transport/fix-initiator.d.ts +2 -2
  692. package/dist/transport/fix-initiator.js.map +1 -1
  693. package/dist/transport/fix-msg-factory.d.ts +1 -1
  694. package/dist/transport/fix-msg-factory.js.map +1 -1
  695. package/dist/transport/fix-session-state-args.d.ts +8 -0
  696. package/dist/transport/fix-session-state-args.js +3 -0
  697. package/dist/transport/fix-session-state-args.js.map +1 -0
  698. package/dist/transport/fix-session-state.d.ts +8 -38
  699. package/dist/transport/fix-session-state.js +26 -56
  700. package/dist/transport/fix-session-state.js.map +1 -1
  701. package/dist/transport/fix-session.d.ts +9 -2
  702. package/dist/transport/fix-session.js +115 -59
  703. package/dist/transport/fix-session.js.map +1 -1
  704. package/dist/transport/fixml/fixml-msg-transmitter.js +23 -5
  705. package/dist/transport/fixml/fixml-msg-transmitter.js.map +1 -1
  706. package/dist/transport/fixml/fixml-session-msg-factory.d.ts +13 -0
  707. package/dist/transport/fixml/fixml-session-msg-factory.js +68 -0
  708. package/dist/transport/fixml/fixml-session-msg-factory.js.map +1 -0
  709. package/dist/transport/fixml/fixml-session.d.ts +1 -1
  710. package/dist/transport/fixml/fixml-session.js +3 -3
  711. package/dist/transport/fixml/fixml-session.js.map +1 -1
  712. package/dist/transport/fixml/index.d.ts +1 -2
  713. package/dist/transport/fixml/index.js +1 -2
  714. package/dist/transport/fixml/index.js.map +1 -1
  715. package/dist/transport/http/html-options.d.ts +8 -0
  716. package/dist/{hop_no_hops.js → transport/http/html-options.js} +1 -1
  717. package/dist/transport/http/html-options.js.map +1 -0
  718. package/dist/transport/http/html-route.d.ts +5 -0
  719. package/dist/{hop.js → transport/http/html-route.js} +1 -1
  720. package/dist/transport/http/html-route.js.map +1 -0
  721. package/dist/transport/http/http-acceptor-listener.d.ts +7 -0
  722. package/dist/transport/http/http-acceptor-listener.js +68 -0
  723. package/dist/transport/http/http-acceptor-listener.js.map +1 -0
  724. package/dist/transport/http/http-acceptor.js +31 -11
  725. package/dist/transport/http/http-acceptor.js.map +1 -1
  726. package/dist/transport/http/http-adapter.d.ts +7 -0
  727. package/dist/{trailer.js → transport/http/http-adapter.js} +1 -1
  728. package/dist/transport/http/http-adapter.js.map +1 -0
  729. package/dist/transport/http/http-initiator.d.ts +9 -3
  730. package/dist/transport/http/http-initiator.js +57 -26
  731. package/dist/transport/http/http-initiator.js.map +1 -1
  732. package/dist/transport/http/http-json-sample-adapter.d.ts +2 -1
  733. package/dist/transport/http/http-json-sample-adapter.js +21 -2
  734. package/dist/transport/http/http-json-sample-adapter.js.map +1 -1
  735. package/dist/transport/http/http-transaction.d.ts +1 -1
  736. package/dist/transport/http/http-transaction.js.map +1 -1
  737. package/dist/transport/http/http-transport-description.d.ts +8 -0
  738. package/dist/transport/http/http-transport-description.js +3 -0
  739. package/dist/transport/http/http-transport-description.js.map +1 -0
  740. package/dist/transport/http/index.d.ts +1 -0
  741. package/dist/transport/http/index.js +1 -0
  742. package/dist/transport/http/index.js.map +1 -1
  743. package/dist/transport/index.d.ts +11 -10
  744. package/dist/transport/index.js +11 -10
  745. package/dist/transport/index.js.map +1 -1
  746. package/dist/transport/{make-fixl-session.d.ts → make-fix-session.d.ts} +0 -0
  747. package/dist/transport/make-fix-session.js +3 -0
  748. package/dist/transport/make-fix-session.js.map +1 -0
  749. package/dist/transport/msg-application.d.ts +12 -0
  750. package/dist/transport/msg-application.js +3 -0
  751. package/dist/transport/msg-application.js.map +1 -0
  752. package/dist/transport/msg-transmitter.d.ts +5 -5
  753. package/dist/transport/msg-transmitter.js +2 -3
  754. package/dist/transport/msg-transmitter.js.map +1 -1
  755. package/dist/transport/session/a-session-msg-factory.d.ts +23 -0
  756. package/dist/transport/session/a-session-msg-factory.js +58 -0
  757. package/dist/transport/session/a-session-msg-factory.js.map +1 -0
  758. package/dist/transport/session/fix-session-state-args.d.ts +8 -0
  759. package/dist/transport/session/fix-session-state-args.js +3 -0
  760. package/dist/transport/session/fix-session-state-args.js.map +1 -0
  761. package/dist/transport/session/fix-session-state.d.ts +32 -0
  762. package/dist/transport/session/fix-session-state.js +133 -0
  763. package/dist/transport/session/fix-session-state.js.map +1 -0
  764. package/dist/transport/session/fix-session.d.ts +50 -0
  765. package/dist/transport/session/fix-session.js +291 -0
  766. package/dist/transport/session/fix-session.js.map +1 -0
  767. package/dist/transport/session/make-fix-session.d.ts +5 -0
  768. package/dist/transport/session/make-fix-session.js +3 -0
  769. package/dist/transport/session/make-fix-session.js.map +1 -0
  770. package/dist/transport/session/session-description.d.ts +17 -0
  771. package/dist/transport/session/session-description.js +3 -0
  772. package/dist/transport/session/session-description.js.map +1 -0
  773. package/dist/transport/session/session-msg-factory.d.ts +15 -0
  774. package/dist/transport/session/session-msg-factory.js +3 -0
  775. package/dist/transport/session/session-msg-factory.js.map +1 -0
  776. package/dist/transport/session/session-state.d.ts +25 -0
  777. package/dist/transport/session/session-state.js +30 -0
  778. package/dist/transport/session/session-state.js.map +1 -0
  779. package/dist/transport/session-description.d.ts +1 -48
  780. package/dist/transport/session-description.js.map +1 -1
  781. package/dist/transport/session-msg-factory.d.ts +7 -20
  782. package/dist/transport/session-msg-factory.js +0 -150
  783. package/dist/transport/session-msg-factory.js.map +1 -1
  784. package/dist/transport/session-state.d.ts +25 -0
  785. package/dist/transport/session-state.js +30 -0
  786. package/dist/transport/session-state.js.map +1 -0
  787. package/dist/transport/tcp/index.d.ts +3 -2
  788. package/dist/transport/tcp/index.js +3 -2
  789. package/dist/transport/tcp/index.js.map +1 -1
  790. package/dist/transport/tcp/recovering-tcp-initiator.d.ts +7 -9
  791. package/dist/transport/tcp/recovering-tcp-initiator.js +41 -16
  792. package/dist/transport/tcp/recovering-tcp-initiator.js.map +1 -1
  793. package/dist/transport/tcp/tcp-acceptor-listener.d.ts +7 -0
  794. package/dist/transport/tcp/tcp-acceptor-listener.js +70 -0
  795. package/dist/transport/tcp/tcp-acceptor-listener.js.map +1 -0
  796. package/dist/transport/tcp/tcp-acceptor.d.ts +7 -0
  797. package/dist/transport/tcp/tcp-acceptor.js +79 -43
  798. package/dist/transport/tcp/tcp-acceptor.js.map +1 -1
  799. package/dist/transport/tcp/tcp-initiator-connector.d.ts +10 -0
  800. package/dist/transport/tcp/tcp-initiator-connector.js +97 -0
  801. package/dist/transport/tcp/tcp-initiator-connector.js.map +1 -0
  802. package/dist/transport/tcp/tcp-initiator.d.ts +4 -2
  803. package/dist/transport/tcp/tcp-initiator.js +82 -36
  804. package/dist/transport/tcp/tcp-initiator.js.map +1 -1
  805. package/dist/transport/tcp/tcp-transport-description.d.ts +6 -0
  806. package/dist/transport/tcp/tcp-transport-description.js +3 -0
  807. package/dist/transport/tcp/tcp-transport-description.js.map +1 -0
  808. package/dist/transport/tcp/tls-options-factory.d.ts +9 -0
  809. package/dist/transport/tcp/tls-options-factory.js +53 -0
  810. package/dist/transport/tcp/tls-options-factory.js.map +1 -0
  811. package/dist/transport/tcp/tls-options.d.ts +10 -5
  812. package/dist/transport/tcp/tls-options.js +0 -49
  813. package/dist/transport/tcp/tls-options.js.map +1 -1
  814. package/dist/transport/tick-action.d.ts +8 -0
  815. package/dist/transport/tick-action.js +13 -0
  816. package/dist/transport/tick-action.js.map +1 -0
  817. package/dist/types/FIX4.4/repo/enum/all-enum.js.map +1 -1
  818. package/dist/util/buffer-helper.js +1 -1
  819. package/dist/util/buffer-helper.js.map +1 -1
  820. package/dist/util/definition-factory.d.ts +10 -0
  821. package/dist/util/definition-factory.js +56 -0
  822. package/dist/util/definition-factory.js.map +1 -0
  823. package/dist/util/dictionary-path.d.ts +4 -0
  824. package/dist/util/dictionary-path.js +3 -0
  825. package/dist/util/dictionary-path.js.map +1 -0
  826. package/dist/util/index.d.ts +1 -1
  827. package/dist/util/index.js +1 -1
  828. package/dist/util/index.js.map +1 -1
  829. package/dist/util/json-helper.d.ts +3 -1
  830. package/dist/util/json-helper.js +13 -12
  831. package/dist/util/json-helper.js.map +1 -1
  832. package/dist/util/message-generator.d.ts +1 -1
  833. package/dist/util/message-generator.js +16 -15
  834. package/dist/util/message-generator.js.map +1 -1
  835. package/dist/util/replay.d.ts +6 -3
  836. package/dist/util/replay.js +24 -26
  837. package/dist/util/replay.js.map +1 -1
  838. package/package.json +27 -20
  839. package/script/build.cmd +1 -0
  840. package/script/build.sh +2 -0
  841. package/script/genkey.ps1 +179 -179
  842. package/script/test.cmd +3 -0
  843. package/src/buffer/{ascii-chars.ts → ascii/ascii-chars.ts} +0 -0
  844. package/src/buffer/ascii/ascii-encoder.ts +80 -38
  845. package/src/buffer/ascii/ascii-parser-state.ts +7 -12
  846. package/src/buffer/ascii/ascii-parser.ts +23 -16
  847. package/src/buffer/ascii/ascii-segment-parser.ts +14 -8
  848. package/src/buffer/ascii/ascii-view.ts +4 -9
  849. package/src/buffer/ascii/index.ts +1 -0
  850. package/src/buffer/ascii/parse-state.ts +8 -0
  851. package/src/buffer/ascii/time-formatter.ts +3 -3
  852. package/src/buffer/elastic-buffer.ts +7 -2
  853. package/src/buffer/encode-proxy.ts +10 -5
  854. package/src/buffer/fixml/fixml-encoder.ts +15 -11
  855. package/src/buffer/fixml/fixml-parser.ts +16 -6
  856. package/src/buffer/fixml/fixml-view.ts +4 -4
  857. package/src/buffer/fixml/populated-attributes.ts +6 -0
  858. package/src/buffer/index.ts +4 -8
  859. package/src/buffer/msg-encoder.ts +2 -1
  860. package/src/buffer/msg-view.ts +13 -6
  861. package/src/buffer/{segment-description.ts → segment/segment-description.ts} +4 -11
  862. package/src/buffer/{segment-summary.ts → segment/segment-summary.ts} +0 -0
  863. package/src/buffer/segment/segment-type.ts +8 -0
  864. package/src/buffer/structure.ts +3 -3
  865. package/src/buffer/{tag-pos.ts → tag/tag-pos.ts} +0 -0
  866. package/src/buffer/tag/tag-type.ts +13 -0
  867. package/src/buffer/{tags.ts → tag/tags.ts} +4 -16
  868. package/src/config/get-js-fx-logger.ts +4 -0
  869. package/src/config/index.ts +1 -0
  870. package/src/config/js-fix-config.ts +5 -2
  871. package/src/config/js-fix-logger.ts +0 -3
  872. package/src/dictionary/compiler/compiler-type.ts +3 -3
  873. package/src/dictionary/compiler/enum-compiler.ts +12 -1
  874. package/src/dictionary/compiler/msg-compiler.ts +8 -7
  875. package/src/dictionary/contained/contained-component-field.ts +2 -1
  876. package/src/dictionary/contained/contained-field-dispatch.ts +3 -7
  877. package/src/dictionary/contained/contained-field-dispatcher.ts +9 -0
  878. package/src/dictionary/contained/contained-field-set.ts +5 -3
  879. package/src/dictionary/contained/contained-field-type.ts +5 -0
  880. package/src/dictionary/contained/contained-field.ts +1 -6
  881. package/src/dictionary/contained/contained-group-field.ts +2 -1
  882. package/src/dictionary/contained/contained-simple-field.ts +2 -1
  883. package/src/dictionary/contained/field-dispatcher.ts +9 -0
  884. package/src/dictionary/contained/fields-dispatch.ts +46 -0
  885. package/src/dictionary/contained/index.ts +2 -0
  886. package/src/dictionary/contained-set-type.ts +5 -0
  887. package/src/dictionary/definition/component-field-definition.ts +1 -1
  888. package/src/dictionary/definition/fix-definitions.ts +2 -1
  889. package/src/dictionary/definition/group-field-definition.ts +1 -1
  890. package/src/dictionary/definition/index.ts +0 -1
  891. package/src/dictionary/definition/message-definition.ts +1 -1
  892. package/src/dictionary/definition/simple-field-definition.ts +3 -1
  893. package/src/dictionary/dict-primitive.ts +0 -13
  894. package/src/dictionary/fix-definition-source.ts +6 -0
  895. package/src/dictionary/fix-versions.ts +0 -32
  896. package/src/dictionary/index.ts +1 -5
  897. package/src/dictionary/parser/fix-repository/abbreviations-parser.ts +2 -3
  898. package/src/dictionary/parser/fix-repository/base-parser.ts +2 -3
  899. package/src/dictionary/parser/fix-repository/components-parser.ts +2 -3
  900. package/src/dictionary/parser/fix-repository/data-types-parser.ts +2 -3
  901. package/src/dictionary/parser/fix-repository/enums-parser.ts +2 -3
  902. package/src/dictionary/parser/fix-repository/fields-parser.ts +2 -3
  903. package/src/dictionary/parser/fix-repository/messages-parser.ts +2 -3
  904. package/src/dictionary/parser/fix-repository/msg-contents-parser.ts +2 -3
  905. package/src/dictionary/parser/fix-repository/repository-abbreviation.ts +6 -0
  906. package/src/dictionary/parser/fix-repository/repository-component.ts +11 -0
  907. package/src/dictionary/parser/fix-repository/repository-data-type.ts +7 -0
  908. package/src/dictionary/parser/fix-repository/repository-enum.ts +8 -0
  909. package/src/dictionary/parser/fix-repository/repository-field.ts +12 -0
  910. package/src/dictionary/parser/fix-repository/repository-message.ts +12 -0
  911. package/src/dictionary/parser/fix-repository/repository-msg-content.ts +10 -0
  912. package/src/dictionary/parser/fix-repository/repository-type.ts +0 -59
  913. package/src/dictionary/parser/fix-repository/repository-xml-parser.ts +10 -9
  914. package/src/dictionary/parser/fix-repository/repository.ts +69 -38
  915. package/src/dictionary/parser/fixml/components-parser.ts +6 -3
  916. package/src/dictionary/parser/fixml/fields-parser.ts +1 -1
  917. package/src/dictionary/parser/fixml/fix-xsd-parser.ts +2 -1
  918. package/src/dictionary/parser/fixml/include-graph.ts +2 -1
  919. package/src/dictionary/parser/fixml/xsd-parser.ts +2 -1
  920. package/src/dictionary/parser/quickfix/field-definition-parser.ts +4 -5
  921. package/src/dictionary/parser/quickfix/field-set-parser.ts +4 -5
  922. package/src/dictionary/parser/quickfix/message-parser.ts +4 -5
  923. package/src/dictionary/parser/quickfix/node-parser.ts +3 -6
  924. package/src/dictionary/parser/quickfix/parse-state.ts +8 -0
  925. package/src/dictionary/parser/quickfix/quick-fix-xml-file-parser.ts +9 -15
  926. package/src/dictionary/sax-node.ts +7 -0
  927. package/src/dictionary/set-reduce.ts +30 -31
  928. package/src/dictionary/type-dispatcher.ts +7 -0
  929. package/src/dictionary/version-util.ts +25 -0
  930. package/src/index.ts +1 -0
  931. package/src/jsfix-cmd.ts +31 -16
  932. package/src/runtime/di-tokens.ts +48 -0
  933. package/src/runtime/engine-factory.ts +5 -0
  934. package/src/runtime/index.ts +5 -0
  935. package/src/runtime/make-config.ts +35 -0
  936. package/src/runtime/session-container.ts +180 -0
  937. package/src/runtime/session-launcher.ts +127 -0
  938. package/src/sample/http/oms/app.ts +20 -12
  939. package/src/sample/http/oms/http-client.ts +5 -2
  940. package/src/sample/http/oms/http-server.ts +5 -1
  941. package/src/sample/tcp/qf-md/app.ts +12 -12
  942. package/src/sample/tcp/qf-md/md-client.ts +4 -1
  943. package/src/sample/tcp/qf-md/md-server.ts +3 -1
  944. package/src/sample/tcp/recovering-skeleton/app.ts +37 -15
  945. package/src/sample/tcp/recovering-skeleton/respawn-acceptor.ts +16 -9
  946. package/src/sample/tcp/recovering-skeleton/skeleton-client.ts +4 -2
  947. package/src/sample/tcp/recovering-skeleton/skeleton-server.ts +4 -2
  948. package/src/sample/tcp/skeleton/app.ts +10 -15
  949. package/src/sample/tcp/skeleton/skeleton-session.ts +29 -3
  950. package/src/sample/tcp/tls-trade-capture/app.ts +8 -31
  951. package/src/sample/tcp/trade-capture/app-launcher.ts +22 -0
  952. package/src/sample/tcp/trade-capture/app.ts +3 -26
  953. package/src/sample/tcp/trade-capture/trade-capture-client.ts +10 -4
  954. package/src/sample/tcp/trade-capture/trade-capture-server.ts +2 -1
  955. package/src/sample/tcp/trade-capture/trade-factory.ts +7 -1
  956. package/src/store/fix-msg-ascii-store-resend.ts +38 -26
  957. package/src/store/fix-msg-memory-store.ts +105 -42
  958. package/src/store/fix-msg-store-record.ts +11 -0
  959. package/src/store/fix-msg-store-state.ts +6 -0
  960. package/src/store/fix-msg-store.ts +8 -13
  961. package/src/transport/ascii/ascii-msg-transmitter.ts +23 -13
  962. package/src/transport/ascii/ascii-session-msg-factory.ts +62 -0
  963. package/src/transport/ascii/ascii-session.ts +102 -34
  964. package/src/transport/ascii/index.ts +1 -1
  965. package/src/transport/duplex/http-duplex.ts +3 -3
  966. package/src/transport/duplex/tcp-duplex.ts +4 -1
  967. package/src/transport/factory/index.ts +1 -0
  968. package/src/transport/factory/msg-transport.ts +55 -0
  969. package/src/transport/fix-acceptor.ts +2 -2
  970. package/src/transport/fix-entity.ts +9 -0
  971. package/src/transport/fix-initiator.ts +2 -2
  972. package/src/transport/fixml/fixml-msg-transmitter.ts +8 -4
  973. package/src/transport/fixml/fixml-session-msg-factory.ts +76 -0
  974. package/src/transport/fixml/fixml-session.ts +2 -2
  975. package/src/transport/fixml/index.ts +1 -2
  976. package/src/transport/http/html-options.ts +8 -0
  977. package/src/transport/http/html-route.ts +6 -0
  978. package/src/transport/http/http-acceptor-listener.ts +42 -0
  979. package/src/transport/http/http-acceptor.ts +12 -8
  980. package/src/transport/http/http-adapter.ts +7 -0
  981. package/src/transport/http/http-initiator.ts +40 -25
  982. package/src/transport/http/http-json-sample-adapter.ts +7 -2
  983. package/src/transport/http/http-transaction.ts +1 -1
  984. package/src/transport/http/http-transport-description.ts +9 -0
  985. package/src/transport/http/index.ts +1 -0
  986. package/src/transport/index.ts +11 -10
  987. package/src/transport/msg-application.ts +13 -0
  988. package/src/transport/msg-transmitter.ts +5 -5
  989. package/src/transport/session/a-session-msg-factory.ts +81 -0
  990. package/src/transport/session/fix-session-state-args.ts +9 -0
  991. package/src/transport/{fix-session-state.ts → session/fix-session-state.ts} +23 -43
  992. package/src/transport/{fix-session.ts → session/fix-session.ts} +111 -46
  993. package/src/transport/{make-fixl-session.ts → session/make-fix-session.ts} +1 -1
  994. package/src/transport/session/session-description.ts +18 -0
  995. package/src/transport/{fix-msg-factory.ts → session/session-msg-factory.ts} +2 -2
  996. package/src/transport/session/session-state.ts +25 -0
  997. package/src/transport/tcp/index.ts +3 -2
  998. package/src/transport/tcp/recovering-tcp-initiator.ts +24 -13
  999. package/src/transport/tcp/tcp-acceptor-listener.ts +45 -0
  1000. package/src/transport/tcp/tcp-acceptor.ts +65 -40
  1001. package/src/transport/tcp/tcp-initiator-connector.ts +71 -0
  1002. package/src/transport/tcp/tcp-initiator.ts +71 -42
  1003. package/src/transport/tcp/tcp-transport-description.ts +7 -0
  1004. package/src/transport/tcp/tls-options-factory.ts +55 -0
  1005. package/src/transport/tcp/tls-options.ts +9 -51
  1006. package/src/transport/tick-action.ts +8 -0
  1007. package/src/types/FIX4.4/repo/enum/all-enum.ts +0 -1
  1008. package/src/util/definition-factory.ts +47 -0
  1009. package/src/util/dictionary-path.ts +4 -0
  1010. package/src/util/index.ts +1 -1
  1011. package/src/util/json-helper.ts +14 -4
  1012. package/src/util/message-generator.ts +6 -3
  1013. package/src/util/replay.ts +26 -21
  1014. package/tsconfig.json +2 -0
  1015. package/dist/buffer/ascii-chars.js.map +0 -1
  1016. package/dist/dictionary/fields-dispatch.js +0 -40
  1017. package/dist/dictionary/fields-dispatch.js.map +0 -1
  1018. package/dist/header.d.ts +0 -31
  1019. package/dist/header.js.map +0 -1
  1020. package/dist/hop.d.ts +0 -4
  1021. package/dist/hop.js.map +0 -1
  1022. package/dist/hop_no_hops.d.ts +0 -5
  1023. package/dist/hop_no_hops.js.map +0 -1
  1024. package/dist/sample/http/oms/jsfix.test_http-client.txt +0 -170
  1025. package/dist/sample/http/oms/jsfix.test_http-server.txt +0 -170
  1026. package/dist/sample/tcp/qf-md/jsfix.test_client.txt +0 -18
  1027. package/dist/sample/tcp/qf-md/jsfix.test_server.txt +0 -17
  1028. package/dist/sample/tcp/recovering-skeleton/jsfix.test_client.txt +0 -96
  1029. package/dist/sample/tcp/recovering-skeleton/jsfix.test_server.txt +0 -93
  1030. package/dist/sample/tcp/recovering-skeleton/skeleton-session.d.ts +0 -17
  1031. package/dist/sample/tcp/recovering-skeleton/skeleton-session.js +0 -70
  1032. package/dist/sample/tcp/recovering-skeleton/skeleton-session.js.map +0 -1
  1033. package/dist/sample/tcp/skeleton/jsfix.test_client.txt +0 -6
  1034. package/dist/sample/tcp/skeleton/jsfix.test_server.txt +0 -6
  1035. package/dist/sample/tcp/tls-trade-capture/jsfix.test_client.txt +0 -1871
  1036. package/dist/sample/tcp/tls-trade-capture/jsfix.test_server.txt +0 -3059
  1037. package/dist/sample/tcp/trade_capture/app.d.ts +0 -1
  1038. package/dist/sample/tcp/trade_capture/app.js +0 -24
  1039. package/dist/sample/tcp/trade_capture/app.js.map +0 -1
  1040. package/dist/sample/tcp/trade_capture/index.d.ts +0 -2
  1041. package/dist/sample/tcp/trade_capture/index.js.map +0 -1
  1042. package/dist/sample/tcp/trade_capture/jsfix.test_client.txt +0 -193
  1043. package/dist/sample/tcp/trade_capture/jsfix.test_server.txt +0 -193
  1044. package/dist/sample/tcp/trade_capture/trade-capture-client.d.ts +0 -16
  1045. package/dist/sample/tcp/trade_capture/trade-capture-client.js +0 -57
  1046. package/dist/sample/tcp/trade_capture/trade-capture-client.js.map +0 -1
  1047. package/dist/sample/tcp/trade_capture/trade-capture-server.d.ts +0 -18
  1048. package/dist/sample/tcp/trade_capture/trade-capture-server.js +0 -72
  1049. package/dist/sample/tcp/trade_capture/trade-capture-server.js.map +0 -1
  1050. package/dist/sample/tcp/trade_capture/trade-factory.d.ts +0 -11
  1051. package/dist/sample/tcp/trade_capture/trade-factory.js +0 -81
  1052. package/dist/sample/tcp/trade_capture/trade-factory.js.map +0 -1
  1053. package/dist/standard_header.d.ts +0 -31
  1054. package/dist/standard_header.js.map +0 -1
  1055. package/dist/standard_trailer.d.ts +0 -6
  1056. package/dist/standard_trailer.js +0 -3
  1057. package/dist/standard_trailer.js.map +0 -1
  1058. package/dist/store/fix-msg-ascii-store-recovery.d.ts +0 -12
  1059. package/dist/store/fix-msg-ascii-store-recovery.js +0 -60
  1060. package/dist/store/fix-msg-ascii-store-recovery.js.map +0 -1
  1061. package/dist/store/fix-resend-record.d.ts +0 -12
  1062. package/dist/store/fix-resend-record.js +0 -12
  1063. package/dist/store/fix-resend-record.js.map +0 -1
  1064. package/dist/test/ascii-encode.test.d.ts +0 -1
  1065. package/dist/test/ascii-encode.test.js.map +0 -1
  1066. package/dist/test/ascii-store-recovery.test.d.ts +0 -1
  1067. package/dist/test/ascii-store-recovery.test.js +0 -50
  1068. package/dist/test/ascii-store-recovery.test.js.map +0 -1
  1069. package/dist/test/memory-store-test.d.ts +0 -1
  1070. package/dist/test/memory-store-test.js.map +0 -1
  1071. package/dist/trailer.d.ts +0 -6
  1072. package/dist/trailer.js.map +0 -1
  1073. package/dist/transport/fixml/acceptor.d.ts +0 -3
  1074. package/dist/transport/fixml/acceptor.js +0 -38
  1075. package/dist/transport/fixml/acceptor.js.map +0 -1
  1076. package/dist/transport/make-config.d.ts +0 -4
  1077. package/dist/transport/make-config.js +0 -31
  1078. package/dist/transport/make-config.js.map +0 -1
  1079. package/dist/transport/make-fixl-session.js +0 -3
  1080. package/dist/transport/make-fixl-session.js.map +0 -1
  1081. package/dist/transport/msg-store.d.ts +0 -2
  1082. package/dist/transport/msg-store.js +0 -3
  1083. package/dist/transport/msg-store.js.map +0 -1
  1084. package/dist/transport/msg-transport.js +0 -57
  1085. package/dist/transport/msg-transport.js.map +0 -1
  1086. package/dist/transport/tcp/acceptor.d.ts +0 -3
  1087. package/dist/transport/tcp/acceptor.js +0 -40
  1088. package/dist/transport/tcp/acceptor.js.map +0 -1
  1089. package/dist/transport/tcp/initiator.d.ts +0 -3
  1090. package/dist/transport/tcp/initiator.js +0 -67
  1091. package/dist/transport/tcp/initiator.js.map +0 -1
  1092. package/dist/transport/tcp/recovering-initiator.d.ts +0 -17
  1093. package/dist/transport/tcp/recovering-initiator.js +0 -30
  1094. package/dist/transport/tcp/recovering-initiator.js.map +0 -1
  1095. package/dist/transport/tcp/recovering_initiator.d.ts +0 -12
  1096. package/dist/transport/tcp/recovering_initiator.js +0 -25
  1097. package/dist/transport/tcp/recovering_initiator.js.map +0 -1
  1098. package/dist/types/FIX4.4/quickfix/set/header.d.ts +0 -31
  1099. package/dist/types/FIX4.4/quickfix/set/header.js +0 -3
  1100. package/dist/types/FIX4.4/quickfix/set/header.js.map +0 -1
  1101. package/dist/types/FIX4.4/quickfix/set/trailer.d.ts +0 -6
  1102. package/dist/types/FIX4.4/quickfix/set/trailer.js +0 -3
  1103. package/dist/types/FIX4.4/quickfix/set/trailer.js.map +0 -1
  1104. package/dist/util/dictionary-definitions.d.ts +0 -8
  1105. package/dist/util/dictionary-definitions.js +0 -51
  1106. package/dist/util/dictionary-definitions.js.map +0 -1
  1107. package/src/dictionary/fields-dispatch.ts +0 -45
  1108. package/src/sample/launcher.ts +0 -46
  1109. package/src/transport/fixml/acceptor.ts +0 -29
  1110. package/src/transport/make-config.ts +0 -19
  1111. package/src/transport/msg-transport.ts +0 -67
  1112. package/src/transport/session-description.ts +0 -70
  1113. package/src/transport/session-msg-factory.ts +0 -195
  1114. package/src/transport/tcp/acceptor.ts +0 -31
  1115. package/src/transport/tcp/initiator.ts +0 -59
  1116. package/src/util/dictionary-definitions.ts +0 -41
@@ -1,50 +1,13 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.FixSessionState = exports.TickAction = exports.SessionState = void 0;
3
+ exports.FixSessionState = void 0;
4
4
  const buffer_1 = require("../buffer");
5
5
  const moment = require("moment");
6
- var SessionState;
7
- (function (SessionState) {
8
- SessionState[SessionState["DisconnectedNoConnectionToday"] = 1] = "DisconnectedNoConnectionToday";
9
- SessionState[SessionState["DisconnectedConnectionToday"] = 2] = "DisconnectedConnectionToday";
10
- SessionState[SessionState["DetectBrokenNetworkConnection"] = 3] = "DetectBrokenNetworkConnection";
11
- SessionState[SessionState["AwaitingConnection"] = 4] = "AwaitingConnection";
12
- SessionState[SessionState["InitiateConnection"] = 5] = "InitiateConnection";
13
- SessionState[SessionState["NetworkConnectionEstablished"] = 6] = "NetworkConnectionEstablished";
14
- SessionState[SessionState["InitiationLogonSent"] = 7] = "InitiationLogonSent";
15
- SessionState[SessionState["InitiationLogonReceived"] = 8] = "InitiationLogonReceived";
16
- SessionState[SessionState["InitiationLogonResponse"] = 9] = "InitiationLogonResponse";
17
- SessionState[SessionState["HandleResendRequest"] = 10] = "HandleResendRequest";
18
- SessionState[SessionState["ReceiveMsgSeqNumTooHigh"] = 11] = "ReceiveMsgSeqNumTooHigh";
19
- SessionState[SessionState["AwaitingProcessingResponseToResendRequest"] = 12] = "AwaitingProcessingResponseToResendRequest";
20
- SessionState[SessionState["NoMessagesReceivedInInterval"] = 13] = "NoMessagesReceivedInInterval";
21
- SessionState[SessionState["AwaitingProcessingResponseToTestRequest"] = 14] = "AwaitingProcessingResponseToTestRequest";
22
- SessionState[SessionState["ReceiveLogout"] = 15] = "ReceiveLogout";
23
- SessionState[SessionState["InitiateLogout"] = 16] = "InitiateLogout";
24
- SessionState[SessionState["ActiveNormalSession"] = 17] = "ActiveNormalSession";
25
- SessionState[SessionState["WaitingForALogon"] = 18] = "WaitingForALogon";
26
- SessionState[SessionState["PeerLogonRejected"] = 20] = "PeerLogonRejected";
27
- SessionState[SessionState["WaitingLogoutConfirm"] = 21] = "WaitingLogoutConfirm";
28
- SessionState[SessionState["ConfirmingLogout"] = 22] = "ConfirmingLogout";
29
- SessionState[SessionState["Stopped"] = 23] = "Stopped";
30
- SessionState[SessionState["Idle"] = 24] = "Idle";
31
- })(SessionState = exports.SessionState || (exports.SessionState = {}));
32
- var TickAction;
33
- (function (TickAction) {
34
- TickAction[TickAction["Nothing"] = 1] = "Nothing";
35
- TickAction[TickAction["Heartbeat"] = 2] = "Heartbeat";
36
- TickAction[TickAction["TestRequest"] = 3] = "TestRequest";
37
- TickAction[TickAction["TerminateOnError"] = 4] = "TerminateOnError";
38
- TickAction[TickAction["WaitLogoutConfirmExpired"] = 5] = "WaitLogoutConfirmExpired";
39
- TickAction[TickAction["Stop"] = 6] = "Stop";
40
- })(TickAction = exports.TickAction || (exports.TickAction = {}));
6
+ const tick_action_1 = require("./tick-action");
7
+ const session_state_1 = require("./session-state");
41
8
  class FixSessionState {
42
- constructor(heartBeat, state = SessionState.Idle, waitLogoutConfirmSeconds = 5, stopSeconds = 2) {
43
- this.heartBeat = heartBeat;
44
- this.state = state;
45
- this.waitLogoutConfirmSeconds = waitLogoutConfirmSeconds;
46
- this.stopSeconds = stopSeconds;
47
- this.nextTickAction = TickAction.Nothing;
9
+ constructor({ heartBeat, state = session_state_1.SessionState.Idle, waitLogoutConfirmSeconds = 5, stopSeconds = 2, lastPeerMsgSeqNum = 0 }) {
10
+ this.nextTickAction = tick_action_1.TickAction.Nothing;
48
11
  this.lastReceivedAt = null;
49
12
  this.LastSentAt = null;
50
13
  this.lastTestRequestAt = null;
@@ -53,10 +16,14 @@ class FixSessionState {
53
16
  this.compId = '';
54
17
  this.peerCompId = '';
55
18
  this.peerHeartBeatSecs = 0;
56
- this.lastPeerMsgSeqNum = 0;
57
19
  this.secondsSinceLogoutSent = -1;
58
20
  this.secondsSinceSent = -1;
59
21
  this.secondsSinceReceive = -1;
22
+ this.heartBeat = heartBeat;
23
+ this.state = state;
24
+ this.waitLogoutConfirmSeconds = waitLogoutConfirmSeconds;
25
+ this.stopSeconds = stopSeconds;
26
+ this.lastPeerMsgSeqNum = lastPeerMsgSeqNum;
60
27
  }
61
28
  reset(resetSeqNo) {
62
29
  this.lastReceivedAt = null;
@@ -67,6 +34,7 @@ class FixSessionState {
67
34
  this.secondsSinceReceive = -1;
68
35
  this.peerHeartBeatSecs = 0;
69
36
  this.logoutSentAt = null;
37
+ this.nextTickAction = tick_action_1.TickAction.Nothing;
70
38
  if (resetSeqNo) {
71
39
  this.lastPeerMsgSeqNum = 0;
72
40
  }
@@ -81,8 +49,8 @@ class FixSessionState {
81
49
  const buffer = new buffer_1.ElasticBuffer(1024);
82
50
  buffer.writeString(`compId = ${this.compId}, `);
83
51
  buffer.writeString(`heartBeat = ${this.heartBeat}, `);
84
- buffer.writeString(`state = ${SessionState[this.state]} (${this.state}), `);
85
- buffer.writeString(`nextTickAction = ${this.nextTickAction}, `);
52
+ buffer.writeString(`state = ${session_state_1.SessionState[this.state]} (${this.state}), `);
53
+ buffer.writeString(`nextTickAction = ${tick_action_1.TickAction[this.nextTickAction]} (${this.nextTickAction}), `);
86
54
  buffer.writeString(`now = ${FixSessionState.dateAsString(this.now)}, `);
87
55
  buffer.writeString(`timeToDie = ${this.timeToDie()}, `);
88
56
  buffer.writeString(`timeToHeartbeat = ${this.timeToHeartbeat()}, `);
@@ -104,31 +72,33 @@ class FixSessionState {
104
72
  this.now = now;
105
73
  this.calcState();
106
74
  switch (this.state) {
107
- case SessionState.PeerLogonRejected: {
75
+ case session_state_1.SessionState.PeerLogonRejected: {
108
76
  if (this.secondsSinceSent >= this.stopSeconds) {
109
- this.nextTickAction = TickAction.Stop;
77
+ this.nextTickAction = tick_action_1.TickAction.Stop;
110
78
  }
111
79
  break;
112
80
  }
113
- case SessionState.WaitingLogoutConfirm:
114
- case SessionState.ConfirmingLogout: {
81
+ case session_state_1.SessionState.WaitingLogoutConfirm:
82
+ case session_state_1.SessionState.ConfirmingLogout: {
115
83
  if (this.timeToDie()) {
116
- this.nextTickAction = TickAction.Stop;
84
+ this.nextTickAction = tick_action_1.TickAction.Stop;
117
85
  }
118
86
  break;
119
87
  }
120
- case SessionState.InitiationLogonReceived:
121
- case SessionState.InitiationLogonResponse: {
88
+ case session_state_1.SessionState.ActiveNormalSession:
89
+ case session_state_1.SessionState.AwaitingProcessingResponseToTestRequest:
90
+ case session_state_1.SessionState.InitiationLogonReceived:
91
+ case session_state_1.SessionState.InitiationLogonResponse: {
122
92
  if (this.timeToHeartbeat()) {
123
- this.nextTickAction = TickAction.Heartbeat;
93
+ this.nextTickAction = tick_action_1.TickAction.Heartbeat;
124
94
  }
125
95
  else {
126
96
  if (this.timeToTerminate()) {
127
- this.nextTickAction = TickAction.TerminateOnError;
97
+ this.nextTickAction = tick_action_1.TickAction.TerminateOnError;
128
98
  }
129
99
  else if (this.timeToTestRequest()) {
130
100
  if (!this.lastTestRequestAt) {
131
- this.nextTickAction = TickAction.TestRequest;
101
+ this.nextTickAction = tick_action_1.TickAction.TestRequest;
132
102
  this.lastTestRequestAt = this.now;
133
103
  }
134
104
  }
@@ -153,7 +123,7 @@ class FixSessionState {
153
123
  }
154
124
  calcState() {
155
125
  const time = this.now.getTime();
156
- this.nextTickAction = TickAction.Nothing;
126
+ this.nextTickAction = tick_action_1.TickAction.Nothing;
157
127
  this.secondsSinceLogoutSent = this.logoutSentAt ? (time - this.logoutSentAt.getTime()) / 1000 : -1;
158
128
  this.secondsSinceSent = (time - this.LastSentAt.getTime()) / 1000;
159
129
  this.secondsSinceReceive = (time - this.lastReceivedAt.getTime()) / 1000;
@@ -1 +1 @@
1
- {"version":3,"file":"fix-session-state.js","sourceRoot":"","sources":["../../src/transport/fix-session-state.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElasticBuffer } from '../buffer'\r\nimport moment = require('moment')\r\n\r\nexport enum SessionState {\r\n DisconnectedNoConnectionToday = 1,\r\n DisconnectedConnectionToday = 2,\r\n DetectBrokenNetworkConnection = 3,\r\n AwaitingConnection = 4,\r\n InitiateConnection = 5,\r\n NetworkConnectionEstablished = 6,\r\n InitiationLogonSent = 7,\r\n InitiationLogonReceived = 8,\r\n InitiationLogonResponse = 9,\r\n HandleResendRequest = 10,\r\n ReceiveMsgSeqNumTooHigh = 11,\r\n AwaitingProcessingResponseToResendRequest = 12,\r\n NoMessagesReceivedInInterval = 13,\r\n AwaitingProcessingResponseToTestRequest = 14,\r\n ReceiveLogout = 15,\r\n InitiateLogout = 16,\r\n ActiveNormalSession = 17,\r\n WaitingForALogon = 18,\r\n PeerLogonRejected = 20,\r\n WaitingLogoutConfirm = 21,\r\n ConfirmingLogout = 22,\r\n Stopped = 23,\r\n Idle = 24\r\n}\r\n\r\nexport enum TickAction {\r\n Nothing = 1,\r\n Heartbeat = 2,\r\n TestRequest = 3,\r\n TerminateOnError = 4,\r\n WaitLogoutConfirmExpired = 5,\r\n Stop = 6\r\n}\r\n\r\nexport class FixSessionState {\r\n public nextTickAction: TickAction = TickAction.Nothing\r\n\r\n public lastReceivedAt: Date = null\r\n public LastSentAt: Date = null\r\n public lastTestRequestAt: Date = null\r\n public logoutSentAt: Date = null\r\n public now: Date = new Date()\r\n public compId: string = ''\r\n public peerCompId: string = ''\r\n public peerHeartBeatSecs: number = 0\r\n public lastPeerMsgSeqNum: number = 0\r\n\r\n private secondsSinceLogoutSent: number = -1\r\n private secondsSinceSent: number = -1\r\n private secondsSinceReceive: number = -1\r\n\r\n public reset (resetSeqNo: boolean): void {\r\n this.lastReceivedAt = null\r\n this.LastSentAt = null\r\n this.lastTestRequestAt = null\r\n this.secondsSinceLogoutSent = -1\r\n this.secondsSinceSent = -1\r\n this.secondsSinceReceive = -1\r\n this.peerHeartBeatSecs = 0\r\n this.logoutSentAt = null\r\n if (resetSeqNo) {\r\n this.lastPeerMsgSeqNum = 0\r\n }\r\n }\r\n\r\n public constructor (public readonly heartBeat: number,\r\n public state: SessionState = SessionState.Idle,\r\n public readonly waitLogoutConfirmSeconds: number = 5,\r\n public readonly stopSeconds: number = 2) {\r\n\r\n }\r\n\r\n private static dateAsString (d: Date) {\r\n if (!d) {\r\n return 'null'\r\n }\r\n return moment(d).format('HH:mm:ss.SSS')\r\n }\r\n\r\n public toString (): string {\r\n\r\n const buffer = new ElasticBuffer(1024)\r\n\r\n buffer.writeString(`compId = ${this.compId}, `)\r\n buffer.writeString(`heartBeat = ${this.heartBeat}, `)\r\n buffer.writeString(`state = ${SessionState[this.state]} (${this.state}), `)\r\n buffer.writeString(`nextTickAction = ${this.nextTickAction}, `)\r\n buffer.writeString(`now = ${FixSessionState.dateAsString(this.now)}, `)\r\n buffer.writeString(`timeToDie = ${this.timeToDie()}, `)\r\n buffer.writeString(`timeToHeartbeat = ${this.timeToHeartbeat()}, `)\r\n buffer.writeString(`timeToTerminate = ${this.timeToTerminate()}, `)\r\n buffer.writeString(`timeToTestRequest = ${this.timeToTestRequest()}, `)\r\n buffer.writeString(`lastReceivedAt = ${FixSessionState.dateAsString(this.lastReceivedAt)}, `)\r\n buffer.writeString(`LastSentAt = ${FixSessionState.dateAsString(this.LastSentAt)}, `)\r\n buffer.writeString(`lastTestRequestAt = ${FixSessionState.dateAsString(this.lastTestRequestAt)}, `)\r\n buffer.writeString(`logoutSentAt = ${FixSessionState.dateAsString(this.logoutSentAt)}, `)\r\n buffer.writeString(`peerHeartBeatSecs = ${this.peerHeartBeatSecs}, `)\r\n buffer.writeString(`peerCompId = ${this.peerCompId}, `)\r\n buffer.writeString(`lastPeerMsgSeqNum = ${this.lastPeerMsgSeqNum}, `)\r\n buffer.writeString(`secondsSinceLogoutSent = ${this.secondsSinceLogoutSent}, `)\r\n buffer.writeString(`secondsSinceSent = ${this.secondsSinceSent}, `)\r\n buffer.writeString(`secondsSinceReceive = ${this.secondsSinceReceive}`)\r\n\r\n return buffer.toString()\r\n }\r\n\r\n public calcAction (now: Date): TickAction {\r\n this.now = now\r\n this.calcState()\r\n\r\n switch (this.state) {\r\n\r\n case SessionState.PeerLogonRejected: {\r\n if (this.secondsSinceSent >= this.stopSeconds) {\r\n this.nextTickAction = TickAction.Stop\r\n }\r\n break\r\n }\r\n\r\n case SessionState.WaitingLogoutConfirm:\r\n case SessionState.ConfirmingLogout: {\r\n if (this.timeToDie()) {\r\n this.nextTickAction = TickAction.Stop\r\n }\r\n break\r\n }\r\n\r\n case SessionState.InitiationLogonReceived:\r\n case SessionState.InitiationLogonResponse : {\r\n if (this.timeToHeartbeat()) {\r\n // have not sent anything for heartbeat period so let other side know still alive.\r\n this.nextTickAction = TickAction.Heartbeat\r\n } else {\r\n // console.log(`${application.name}: secondsSinceSent = ${secondsSinceSent} secondsSinceReceive = ${secondsSinceReceive}`)\r\n if (this.timeToTerminate()) {\r\n this.nextTickAction = TickAction.TerminateOnError\r\n } else if (this.timeToTestRequest()) {\r\n if (!this.lastTestRequestAt) {\r\n // not received anything from peer\r\n this.nextTickAction = TickAction.TestRequest\r\n this.lastTestRequestAt = this.now\r\n }\r\n }\r\n }\r\n break\r\n }\r\n }\r\n\r\n return this.nextTickAction\r\n }\r\n\r\n public timeToDie (): boolean {\r\n return this.secondsSinceLogoutSent > this.waitLogoutConfirmSeconds ||\r\n this.secondsSinceLogoutSent > this.stopSeconds\r\n }\r\n\r\n public timeToHeartbeat (): boolean {\r\n return this.secondsSinceSent >= this.heartBeat\r\n }\r\n\r\n public timeToTerminate (): boolean {\r\n return this.secondsSinceReceive >= 2.5 * this.peerHeartBeatSecs\r\n }\r\n\r\n public timeToTestRequest (): boolean {\r\n return this.secondsSinceReceive >= 1.5 * this.peerHeartBeatSecs\r\n }\r\n\r\n private calcState (): void {\r\n const time = this.now.getTime()\r\n this.nextTickAction = TickAction.Nothing\r\n this.secondsSinceLogoutSent = this.logoutSentAt ? (time - this.logoutSentAt.getTime()) / 1000 : -1\r\n this.secondsSinceSent = (time - this.LastSentAt.getTime()) / 1000\r\n this.secondsSinceReceive = (time - this.lastReceivedAt.getTime()) / 1000\r\n }\r\n}\r\n"]}
1
+ {"version":3,"file":"fix-session-state.js","sourceRoot":"","sources":["../../src/transport/fix-session-state.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElasticBuffer } from '../buffer'\r\nimport moment = require('moment')\r\nimport { TickAction } from './tick-action'\r\nimport { IFixSessionStateArgs } from './fix-session-state-args'\r\nimport { SessionState } from './session-state'\r\n\r\nexport class FixSessionState {\r\n public nextTickAction: TickAction = TickAction.Nothing\r\n\r\n public lastReceivedAt: Date = null\r\n public LastSentAt: Date = null\r\n public lastTestRequestAt: Date = null\r\n public logoutSentAt: Date = null\r\n public now: Date = new Date()\r\n public compId: string = ''\r\n public peerCompId: string = ''\r\n public peerHeartBeatSecs: number = 0\r\n public lastPeerMsgSeqNum: number\r\n public readonly heartBeat: number\r\n public state: SessionState\r\n public readonly waitLogoutConfirmSeconds: number\r\n public readonly stopSeconds: number\r\n\r\n private secondsSinceLogoutSent: number = -1\r\n private secondsSinceSent: number = -1\r\n private secondsSinceReceive: number = -1\r\n\r\n public reset (resetSeqNo: boolean): void {\r\n this.lastReceivedAt = null\r\n this.LastSentAt = null\r\n this.lastTestRequestAt = null\r\n this.secondsSinceLogoutSent = -1\r\n this.secondsSinceSent = -1\r\n this.secondsSinceReceive = -1\r\n this.peerHeartBeatSecs = 0\r\n this.logoutSentAt = null\r\n this.nextTickAction = TickAction.Nothing\r\n if (resetSeqNo) {\r\n this.lastPeerMsgSeqNum = 0\r\n }\r\n }\r\n\r\n public constructor ({ heartBeat,\r\n state = SessionState.Idle,\r\n waitLogoutConfirmSeconds = 5,\r\n stopSeconds = 2,\r\n lastPeerMsgSeqNum = 0 }: IFixSessionStateArgs) {\r\n this.heartBeat = heartBeat\r\n this.state = state\r\n this.waitLogoutConfirmSeconds = waitLogoutConfirmSeconds\r\n this.stopSeconds = stopSeconds\r\n this.lastPeerMsgSeqNum = lastPeerMsgSeqNum\r\n }\r\n\r\n private static dateAsString (d: Date) {\r\n if (!d) {\r\n return 'null'\r\n }\r\n return moment(d).format('HH:mm:ss.SSS')\r\n }\r\n\r\n public toString (): string {\r\n\r\n const buffer = new ElasticBuffer(1024)\r\n\r\n buffer.writeString(`compId = ${this.compId}, `)\r\n buffer.writeString(`heartBeat = ${this.heartBeat}, `)\r\n buffer.writeString(`state = ${SessionState[this.state]} (${this.state}), `)\r\n buffer.writeString(`nextTickAction = ${TickAction[this.nextTickAction]} (${this.nextTickAction}), `)\r\n buffer.writeString(`now = ${FixSessionState.dateAsString(this.now)}, `)\r\n buffer.writeString(`timeToDie = ${this.timeToDie()}, `)\r\n buffer.writeString(`timeToHeartbeat = ${this.timeToHeartbeat()}, `)\r\n buffer.writeString(`timeToTerminate = ${this.timeToTerminate()}, `)\r\n buffer.writeString(`timeToTestRequest = ${this.timeToTestRequest()}, `)\r\n buffer.writeString(`lastReceivedAt = ${FixSessionState.dateAsString(this.lastReceivedAt)}, `)\r\n buffer.writeString(`LastSentAt = ${FixSessionState.dateAsString(this.LastSentAt)}, `)\r\n buffer.writeString(`lastTestRequestAt = ${FixSessionState.dateAsString(this.lastTestRequestAt)}, `)\r\n buffer.writeString(`logoutSentAt = ${FixSessionState.dateAsString(this.logoutSentAt)}, `)\r\n buffer.writeString(`peerHeartBeatSecs = ${this.peerHeartBeatSecs}, `)\r\n buffer.writeString(`peerCompId = ${this.peerCompId}, `)\r\n buffer.writeString(`lastPeerMsgSeqNum = ${this.lastPeerMsgSeqNum}, `)\r\n buffer.writeString(`secondsSinceLogoutSent = ${this.secondsSinceLogoutSent}, `)\r\n buffer.writeString(`secondsSinceSent = ${this.secondsSinceSent}, `)\r\n buffer.writeString(`secondsSinceReceive = ${this.secondsSinceReceive}`)\r\n\r\n return buffer.toString()\r\n }\r\n\r\n public calcAction (now: Date): TickAction {\r\n this.now = now\r\n this.calcState()\r\n\r\n switch (this.state) {\r\n\r\n case SessionState.PeerLogonRejected: {\r\n if (this.secondsSinceSent >= this.stopSeconds) {\r\n this.nextTickAction = TickAction.Stop\r\n }\r\n break\r\n }\r\n\r\n case SessionState.WaitingLogoutConfirm:\r\n case SessionState.ConfirmingLogout: {\r\n if (this.timeToDie()) {\r\n this.nextTickAction = TickAction.Stop\r\n }\r\n break\r\n }\r\n\r\n case SessionState.ActiveNormalSession:\r\n case SessionState.AwaitingProcessingResponseToTestRequest:\r\n case SessionState.InitiationLogonReceived:\r\n case SessionState.InitiationLogonResponse : {\r\n if (this.timeToHeartbeat()) {\r\n // have not sent anything for heartbeat period so let other side know still alive.\r\n this.nextTickAction = TickAction.Heartbeat\r\n } else {\r\n // console.log(`${application.name}: secondsSinceSent = ${secondsSinceSent} secondsSinceReceive = ${secondsSinceReceive}`)\r\n if (this.timeToTerminate()) {\r\n this.nextTickAction = TickAction.TerminateOnError\r\n } else if (this.timeToTestRequest()) {\r\n if (!this.lastTestRequestAt) {\r\n // not received anything from peer\r\n this.nextTickAction = TickAction.TestRequest\r\n this.lastTestRequestAt = this.now\r\n }\r\n }\r\n }\r\n break\r\n }\r\n }\r\n\r\n return this.nextTickAction\r\n }\r\n\r\n public timeToDie (): boolean {\r\n return this.secondsSinceLogoutSent > this.waitLogoutConfirmSeconds ||\r\n this.secondsSinceLogoutSent > this.stopSeconds\r\n }\r\n\r\n public timeToHeartbeat (): boolean {\r\n return this.secondsSinceSent >= this.heartBeat\r\n }\r\n\r\n public timeToTerminate (): boolean {\r\n return this.secondsSinceReceive >= 2.5 * this.peerHeartBeatSecs\r\n }\r\n\r\n public timeToTestRequest (): boolean {\r\n return this.secondsSinceReceive >= 1.5 * this.peerHeartBeatSecs\r\n }\r\n\r\n private calcState (): void {\r\n const time = this.now.getTime()\r\n this.nextTickAction = TickAction.Nothing\r\n this.secondsSinceLogoutSent = this.logoutSentAt ? (time - this.logoutSentAt.getTime()) / 1000 : -1\r\n this.secondsSinceSent = (time - this.LastSentAt.getTime()) / 1000\r\n this.secondsSinceReceive = (time - this.lastReceivedAt.getTime()) / 1000\r\n }\r\n}\r\n"]}
@@ -1,10 +1,11 @@
1
1
  /// <reference types="node" />
2
2
  import { MsgView } from '../buffer';
3
3
  import { IJsFixConfig, IJsFixLogger } from '../config';
4
- import { FixSessionState, SessionState } from './fix-session-state';
5
- import { MsgTransport } from './msg-transport';
4
+ import { FixSessionState } from './fix-session-state';
5
+ import { MsgTransport } from './factory';
6
6
  import { ILooseObject } from '../collections/collection';
7
7
  import * as events from 'events';
8
+ import { SessionState } from './session-state';
8
9
  export declare abstract class FixSession extends events.EventEmitter {
9
10
  readonly config: IJsFixConfig;
10
11
  logReceivedMsgs: boolean;
@@ -23,12 +24,18 @@ export declare abstract class FixSession extends events.EventEmitter {
23
24
  protected constructor(config: IJsFixConfig);
24
25
  setState(state: SessionState): void;
25
26
  getState(): SessionState;
27
+ sendLogon(): void;
28
+ private waitPromise;
26
29
  run(transport: MsgTransport): Promise<number>;
30
+ protected expectedState(): boolean;
27
31
  protected subscribe(): void;
32
+ protected validStateApplicationMsg(): boolean;
33
+ protected stateString(): string;
28
34
  protected checkForwardMsg(msgType: string, view: MsgView): void;
29
35
  protected terminate(error: Error): void;
30
36
  protected peerLogout(view: MsgView): void;
31
37
  protected send(msgType: string, obj: ILooseObject): void;
38
+ protected sendLogout(msg: string): void;
32
39
  protected sessionLogout(): void;
33
40
  done(): void;
34
41
  reset(): void;
@@ -1,10 +1,11 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.FixSession = void 0;
4
- const buffer_1 = require("../buffer");
5
4
  const fix_session_state_1 = require("./fix-session-state");
6
5
  const types_1 = require("../types");
7
6
  const events = require("events");
7
+ const session_state_1 = require("./session-state");
8
+ const segment_type_1 = require("../buffer/segment/segment-type");
8
9
  class FixSession extends events.EventEmitter {
9
10
  constructor(config) {
10
11
  super();
@@ -16,7 +17,8 @@ class FixSession extends events.EventEmitter {
16
17
  this.checkMsgIntegrity = false;
17
18
  const description = config.description;
18
19
  this.me = description.application.name;
19
- this.sessionState = new fix_session_state_1.FixSessionState(description.HeartBtInt, config.description.LastReceivedSeqNum);
20
+ this.sessionState = new fix_session_state_1.FixSessionState({ heartBeat: config.description.HeartBtInt,
21
+ lastPeerMsgSeqNum: config.description.LastReceivedSeqNum });
20
22
  this.sessionLogger = config.logFactory.logger(`${this.me}:FixSession`);
21
23
  this.initiator = description.application.type === 'initiator';
22
24
  this.acceptor = !this.initiator;
@@ -28,29 +30,27 @@ class FixSession extends events.EventEmitter {
28
30
  return;
29
31
  const logger = this.sessionLogger;
30
32
  const prevState = this.sessionState.state;
31
- logger.info(`current state ${fix_session_state_1.SessionState[prevState]} (${prevState}) moves to ${fix_session_state_1.SessionState[state]} (${state})`);
33
+ const msg = `current state ${session_state_1.SessionState[prevState]} (${prevState}) moves to ${session_state_1.SessionState[state]} (${state})`;
34
+ logger.info(msg);
32
35
  this.sessionState.state = state;
33
36
  }
34
37
  getState() {
35
38
  return this.sessionState.state;
36
39
  }
37
- run(transport) {
40
+ sendLogon() {
41
+ this.send(this.requestLogonType, this.config.factory.logon());
42
+ }
43
+ waitPromise() {
38
44
  const logger = this.sessionLogger;
39
- if (this.transport) {
40
- logger.info('reset from previous transport.');
41
- this.reset();
42
- }
43
- this.transport = transport;
44
- this.subscribe();
45
45
  return new Promise((accept, reject) => {
46
46
  if (this.initiator) {
47
- logger.debug('initiator sending logon');
48
- this.send(this.requestLogonType, this.config.factory.logon());
49
- this.setState(fix_session_state_1.SessionState.InitiationLogonSent);
47
+ logger.debug(`initiator sending logon state = ${this.stateString()}`);
48
+ this.sendLogon();
49
+ this.setState(session_state_1.SessionState.InitiationLogonSent);
50
50
  }
51
51
  else {
52
- logger.debug('acceptor waits for logon');
53
- this.setState(fix_session_state_1.SessionState.WaitingForALogon);
52
+ logger.debug(`acceptor waits for logon state = ${this.stateString()}`);
53
+ this.setState(session_state_1.SessionState.WaitingForALogon);
54
54
  }
55
55
  this.on('error', (e) => {
56
56
  logger.error(e);
@@ -61,6 +61,30 @@ class FixSession extends events.EventEmitter {
61
61
  });
62
62
  });
63
63
  }
64
+ run(transport) {
65
+ const logger = this.sessionLogger;
66
+ if (this.transport) {
67
+ logger.info(`reset from previous transport. state ${this.stateString()}`);
68
+ this.reset();
69
+ }
70
+ this.transport = transport;
71
+ this.subscribe();
72
+ return this.waitPromise();
73
+ }
74
+ expectedState() {
75
+ switch (this.sessionState.state) {
76
+ case session_state_1.SessionState.ActiveNormalSession:
77
+ case session_state_1.SessionState.ReceiveLogout:
78
+ case session_state_1.SessionState.Stopped:
79
+ case session_state_1.SessionState.ConfirmingLogout:
80
+ case session_state_1.SessionState.HandleResendRequest:
81
+ case session_state_1.SessionState.AwaitingProcessingResponseToTestRequest:
82
+ case session_state_1.SessionState.AwaitingProcessingResponseToResendRequest:
83
+ return true;
84
+ default:
85
+ return false;
86
+ }
87
+ }
64
88
  subscribe() {
65
89
  const transport = this.transport;
66
90
  const logger = this.sessionLogger;
@@ -68,7 +92,7 @@ class FixSession extends events.EventEmitter {
68
92
  const tx = transport.transmitter;
69
93
  rx.on('msg', (msgType, view) => {
70
94
  if (this.logReceivedMsgs) {
71
- const name = view.segment.type !== buffer_1.SegmentType.Unknown ? view.segment.set.name : 'unknown';
95
+ const name = view.segment.type !== segment_type_1.SegmentType.Unknown ? view.segment.set.name : 'unknown';
72
96
  logger.info(`${msgType}: ${name}`);
73
97
  logger.info(`${view.toString()}`);
74
98
  }
@@ -90,22 +114,15 @@ class FixSession extends events.EventEmitter {
90
114
  });
91
115
  rx.on('end', () => {
92
116
  logger.info(`rx end received sessionState = [${this.sessionState.toString()}]`);
93
- switch (this.sessionState.state) {
94
- case fix_session_state_1.SessionState.ReceiveLogout:
95
- case fix_session_state_1.SessionState.Stopped:
96
- case fix_session_state_1.SessionState.ConfirmingLogout:
97
- {
98
- logger.info(`rx graceful end state = ${fix_session_state_1.SessionState[this.sessionState.state]}`);
99
- this.done();
100
- }
101
- break;
102
- default:
103
- {
104
- const e = new Error(`unexpected state - transport failed? = ${fix_session_state_1.SessionState[this.sessionState.state]}`);
105
- logger.info(`rx error ${e.message}`);
106
- this.terminate(e);
107
- }
108
- break;
117
+ const expectedState = this.expectedState();
118
+ if (expectedState) {
119
+ logger.info(`rx graceful end state = ${this.stateString()}`);
120
+ this.done();
121
+ }
122
+ else {
123
+ const e = new Error(`unexpected state - transport failed? = ${this.stateString()}`);
124
+ logger.info(`rx error ${e.message}`);
125
+ this.terminate(e);
109
126
  }
110
127
  });
111
128
  rx.on('decoded', (msgType, data, ptr) => {
@@ -121,38 +138,65 @@ class FixSession extends events.EventEmitter {
121
138
  this.onEncoded(msgType, data);
122
139
  });
123
140
  }
141
+ validStateApplicationMsg() {
142
+ switch (this.sessionState.state) {
143
+ case session_state_1.SessionState.Idle:
144
+ case session_state_1.SessionState.InitiateConnection:
145
+ case session_state_1.SessionState.InitiationLogonSent:
146
+ case session_state_1.SessionState.WaitingForALogon:
147
+ case session_state_1.SessionState.HandleResendRequest:
148
+ case session_state_1.SessionState.AwaitingProcessingResponseToTestRequest:
149
+ case session_state_1.SessionState.AwaitingProcessingResponseToResendRequest:
150
+ return false;
151
+ default:
152
+ return true;
153
+ }
154
+ }
155
+ stateString() {
156
+ return session_state_1.SessionState[this.sessionState.state];
157
+ }
124
158
  checkForwardMsg(msgType, view) {
125
159
  this.sessionLogger.info(`forwarding msgType = '${msgType}' to application`);
160
+ this.setState(session_state_1.SessionState.ActiveNormalSession);
126
161
  this.onApplicationMsg(msgType, view);
127
162
  }
128
163
  terminate(error) {
164
+ if (this.sessionState.state === session_state_1.SessionState.Stopped)
165
+ return;
129
166
  this.sessionLogger.error(error);
130
- clearInterval(this.timer);
131
- this.transport.end();
167
+ if (this.timer) {
168
+ clearInterval(this.timer);
169
+ }
170
+ if (this.transport) {
171
+ this.transport.end();
172
+ }
132
173
  this.transport = null;
133
- this.sessionState.state = fix_session_state_1.SessionState.Stopped;
174
+ this.setState(session_state_1.SessionState.Stopped);
134
175
  this.emit('error', error);
135
176
  }
136
177
  peerLogout(view) {
137
178
  const msg = view.getString(types_1.MsgTag.Text);
138
- switch (this.sessionState.state) {
139
- case fix_session_state_1.SessionState.WaitingLogoutConfirm: {
179
+ const state = this.sessionState.state;
180
+ switch (state) {
181
+ case session_state_1.SessionState.WaitingLogoutConfirm: {
140
182
  this.sessionLogger.info(`peer confirms logout Text = '${msg}'`);
141
183
  this.stop();
142
184
  break;
143
185
  }
144
- case fix_session_state_1.SessionState.InitiationLogonResponse:
145
- case fix_session_state_1.SessionState.InitiationLogonReceived: {
146
- this.setState(fix_session_state_1.SessionState.ConfirmingLogout);
186
+ case session_state_1.SessionState.InitiationLogonResponse:
187
+ case session_state_1.SessionState.ActiveNormalSession:
188
+ case session_state_1.SessionState.InitiationLogonReceived: {
189
+ this.setState(session_state_1.SessionState.ConfirmingLogout);
147
190
  this.sessionLogger.info(`peer initiates logout Text = '${msg}'`);
148
191
  this.sessionLogout();
149
192
  }
150
193
  }
151
194
  }
152
195
  send(msgType, obj) {
153
- switch (this.sessionState.state) {
154
- case fix_session_state_1.SessionState.Stopped: {
155
- this.sessionLogger.warning(`can't send in stopped state`);
196
+ const state = this.sessionState.state;
197
+ switch (state) {
198
+ case session_state_1.SessionState.Stopped: {
199
+ this.sessionLogger.warning(`can't send in state ${this.stateString()}`);
156
200
  break;
157
201
  }
158
202
  default: {
@@ -162,27 +206,32 @@ class FixSession extends events.EventEmitter {
162
206
  }
163
207
  }
164
208
  }
209
+ sendLogout(msg) {
210
+ const factory = this.config.factory;
211
+ this.sessionLogger.info(`sending logout with ${msg}`);
212
+ this.send(this.requestLogoutType, factory.logout(this.requestLogoutType, msg));
213
+ }
165
214
  sessionLogout() {
166
215
  const sessionState = this.sessionState;
167
216
  if (sessionState.logoutSentAt) {
168
217
  return;
169
218
  }
170
- const factory = this.config.factory;
171
219
  switch (sessionState.state) {
172
- case fix_session_state_1.SessionState.InitiationLogonResponse:
173
- case fix_session_state_1.SessionState.InitiationLogonReceived: {
174
- this.setState(fix_session_state_1.SessionState.WaitingLogoutConfirm);
220
+ case session_state_1.SessionState.ActiveNormalSession:
221
+ case session_state_1.SessionState.InitiationLogonResponse:
222
+ case session_state_1.SessionState.InitiationLogonReceived: {
223
+ this.setState(session_state_1.SessionState.WaitingLogoutConfirm);
175
224
  sessionState.logoutSentAt = new Date();
176
225
  const msg = `${this.me} initiate logout`;
177
226
  this.sessionLogger.info(msg);
178
- this.send(this.requestLogoutType, factory.logout(this.requestLogoutType, msg));
227
+ this.sendLogout(msg);
179
228
  break;
180
229
  }
181
- case fix_session_state_1.SessionState.ConfirmingLogout: {
230
+ case session_state_1.SessionState.ConfirmingLogout: {
182
231
  sessionState.logoutSentAt = new Date();
183
232
  const msg = `${this.me} confirming logout`;
184
233
  this.sessionLogger.info(msg);
185
- this.send(this.respondLogoutType, factory.logout(this.respondLogoutType, msg));
234
+ this.sendLogout(msg);
186
235
  break;
187
236
  }
188
237
  default: {
@@ -192,12 +241,13 @@ class FixSession extends events.EventEmitter {
192
241
  }
193
242
  done() {
194
243
  switch (this.sessionState.state) {
195
- case fix_session_state_1.SessionState.InitiationLogonResponse:
196
- case fix_session_state_1.SessionState.InitiationLogonReceived: {
244
+ case session_state_1.SessionState.InitiationLogonResponse:
245
+ case session_state_1.SessionState.ActiveNormalSession:
246
+ case session_state_1.SessionState.InitiationLogonReceived: {
197
247
  this.sessionLogout();
198
248
  break;
199
249
  }
200
- case fix_session_state_1.SessionState.Stopped:
250
+ case session_state_1.SessionState.Stopped:
201
251
  this.sessionLogger.info(`done. session is now stopped`);
202
252
  break;
203
253
  default: {
@@ -205,18 +255,24 @@ class FixSession extends events.EventEmitter {
205
255
  break;
206
256
  }
207
257
  }
208
- this.sessionLogger.info(`done. check logout sequence`);
258
+ this.sessionLogger.info(`done. check logout sequence state ${this.stateString()}`);
209
259
  }
210
260
  reset() {
261
+ if (this.timer) {
262
+ clearInterval(this.timer);
263
+ }
211
264
  this.transport = null;
212
- this.sessionState.reset(true);
213
- this.setState(fix_session_state_1.SessionState.NetworkConnectionEstablished);
265
+ const resetSeqNum = this.config.description.ResetSeqNumFlag || true;
266
+ this.sessionState.reset(resetSeqNum);
267
+ this.setState(session_state_1.SessionState.NetworkConnectionEstablished);
214
268
  }
215
269
  stop(error = null) {
216
- if (this.sessionState.state === fix_session_state_1.SessionState.Stopped) {
270
+ if (this.sessionState.state === session_state_1.SessionState.Stopped) {
217
271
  return;
218
272
  }
219
- clearInterval(this.timer);
273
+ if (this.timer) {
274
+ clearInterval(this.timer);
275
+ }
220
276
  this.sessionLogger.info(`stop: kill transport`);
221
277
  this.transport.end();
222
278
  if (error) {
@@ -226,7 +282,7 @@ class FixSession extends events.EventEmitter {
226
282
  else {
227
283
  this.emit('done');
228
284
  }
229
- this.setState(fix_session_state_1.SessionState.Stopped);
285
+ this.setState(session_state_1.SessionState.Stopped);
230
286
  this.onStopped(error);
231
287
  this.transport = null;
232
288
  }
@@ -1 +1 @@
1
- {"version":3,"file":"fix-session.js","sourceRoot":"","sources":["../../src/transport/fix-session.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElasticBuffer, MsgView, SegmentType } from '../buffer'\r\nimport { IJsFixConfig, IJsFixLogger } from '../config'\r\nimport { FixSessionState, SessionState } from './fix-session-state'\r\nimport { MsgTransport } from './msg-transport'\r\nimport { MsgTag } from '../types'\r\nimport { ILooseObject } from '../collections/collection'\r\n\r\nimport * as events from 'events'\r\n\r\nexport abstract class FixSession extends events.EventEmitter {\r\n public logReceivedMsgs: boolean = false\r\n protected timer: NodeJS.Timer = null\r\n protected transport: MsgTransport = null\r\n public manageSession: boolean = true\r\n public checkMsgIntegrity: boolean = false\r\n protected readonly me: string\r\n protected readonly initiator: boolean\r\n protected readonly acceptor: boolean\r\n protected readonly sessionState: FixSessionState\r\n // protected readonly emitter: events.EventEmitter\r\n protected readonly sessionLogger: IJsFixLogger\r\n protected requestLogoutType: string\r\n protected respondLogoutType: string\r\n protected requestLogonType: string\r\n\r\n protected constructor (public readonly config: IJsFixConfig) {\r\n super()\r\n const description = config.description\r\n this.me = description.application.name\r\n this.sessionState = new FixSessionState(description.HeartBtInt, config.description.LastReceivedSeqNum)\r\n this.sessionLogger = config.logFactory.logger(`${this.me}:FixSession`)\r\n this.initiator = description.application.type === 'initiator'\r\n this.acceptor = !this.initiator\r\n this.checkMsgIntegrity = this.acceptor\r\n this.sessionState.compId = description.SenderCompId\r\n }\r\n\r\n public setState (state: SessionState) {\r\n if (state === this.sessionState.state) return\r\n const logger = this.sessionLogger\r\n const prevState = this.sessionState.state\r\n logger.info(`current state ${SessionState[prevState]} (${prevState}) moves to ${SessionState[state]} (${state})`)\r\n this.sessionState.state = state\r\n }\r\n\r\n public getState (): SessionState {\r\n return this.sessionState.state\r\n }\r\n\r\n public run (transport: MsgTransport): Promise<number> {\r\n const logger = this.sessionLogger\r\n if (this.transport) {\r\n logger.info('reset from previous transport.')\r\n this.reset()\r\n }\r\n this.transport = transport\r\n this.subscribe()\r\n return new Promise<any>((accept, reject) => {\r\n if (this.initiator) {\r\n logger.debug('initiator sending logon')\r\n this.send(this.requestLogonType, this.config.factory.logon())\r\n this.setState(SessionState.InitiationLogonSent)\r\n } else {\r\n logger.debug('acceptor waits for logon')\r\n this.setState(SessionState.WaitingForALogon)\r\n }\r\n\r\n this.on('error', (e: Error) => {\r\n logger.error(e)\r\n reject(e)\r\n })\r\n this.on('done', () => {\r\n accept(this.transport.id)\r\n })\r\n })\r\n }\r\n\r\n protected subscribe () {\r\n\r\n const transport = this.transport\r\n const logger = this.sessionLogger\r\n\r\n const rx = transport.receiver\r\n const tx = transport.transmitter\r\n\r\n rx.on('msg', (msgType: string, view: MsgView) => {\r\n if (this.logReceivedMsgs) {\r\n const name = view.segment.type !== SegmentType.Unknown ? view.segment.set.name : 'unknown'\r\n logger.info(`${msgType}: ${name}`)\r\n logger.info(`${view.toString()}`)\r\n }\r\n this.sessionState.lastReceivedAt = new Date()\r\n if (this.manageSession) {\r\n this.onMsg(msgType, view)\r\n } else {\r\n this.checkForwardMsg(msgType, view)\r\n }\r\n })\r\n\r\n rx.on('error', (e: Error) => {\r\n logger.warning(`rx error event: ${e.message} ${e.stack || ''}`)\r\n this.terminate(e)\r\n })\r\n\r\n rx.on('done', () => {\r\n logger.info('rx done received')\r\n this.done()\r\n })\r\n\r\n rx.on('end', () => {\r\n logger.info(`rx end received sessionState = [${this.sessionState.toString()}]`)\r\n switch (this.sessionState.state) {\r\n case SessionState.ReceiveLogout:\r\n case SessionState.Stopped:\r\n case SessionState.ConfirmingLogout: {\r\n logger.info(`rx graceful end state = ${SessionState[this.sessionState.state]}`)\r\n this.done()\r\n }\r\n break\r\n\r\n default: {\r\n const e = new Error(`unexpected state - transport failed? = ${SessionState[this.sessionState.state]}`)\r\n logger.info(`rx error ${e.message}`)\r\n this.terminate(e)\r\n }\r\n break\r\n }\r\n })\r\n\r\n rx.on('decoded', (msgType: string, data: ElasticBuffer, ptr: number) => {\r\n logger.debug(`rx: [${msgType}] ${ptr} bytes`)\r\n this.onDecoded(msgType, data.toString(ptr))\r\n })\r\n\r\n tx.on('error', (e: Error) => {\r\n logger.warning(`tx error event: ${e.message} ${e.stack || ''}`)\r\n this.terminate(e)\r\n })\r\n\r\n tx.on('encoded', (msgType: string, data: string) => {\r\n logger.debug(`tx: [${msgType}] ${data.length} bytes`)\r\n this.onEncoded(msgType, data)\r\n })\r\n }\r\n\r\n protected checkForwardMsg (msgType: string, view: MsgView): void {\r\n this.sessionLogger.info(`forwarding msgType = '${msgType}' to application`)\r\n this.onApplicationMsg(msgType, view)\r\n }\r\n\r\n protected terminate (error: Error): void {\r\n this.sessionLogger.error(error)\r\n clearInterval(this.timer)\r\n this.transport.end()\r\n this.transport = null\r\n this.sessionState.state = SessionState.Stopped\r\n this.emit('error', error)\r\n }\r\n\r\n protected peerLogout (view: MsgView) {\r\n const msg = view.getString(MsgTag.Text)\r\n switch (this.sessionState.state) {\r\n case SessionState.WaitingLogoutConfirm: {\r\n this.sessionLogger.info(`peer confirms logout Text = '${msg}'`)\r\n this.stop()\r\n break\r\n }\r\n\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.InitiationLogonReceived: {\r\n this.setState(SessionState.ConfirmingLogout)\r\n this.sessionLogger.info(`peer initiates logout Text = '${msg}'`)\r\n this.sessionLogout()\r\n }\r\n }\r\n }\r\n\r\n protected send (msgType: string, obj: ILooseObject) {\r\n switch (this.sessionState.state) {\r\n case SessionState.Stopped: {\r\n this.sessionLogger.warning(`can't send in stopped state`)\r\n break\r\n }\r\n\r\n default: {\r\n this.sessionState.LastSentAt = new Date()\r\n this.transport.transmitter.send(msgType, obj)\r\n break\r\n }\r\n }\r\n }\r\n\r\n protected sessionLogout (): void {\r\n const sessionState = this.sessionState\r\n if (sessionState.logoutSentAt) {\r\n return\r\n }\r\n const factory = this.config.factory\r\n switch (sessionState.state) {\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.InitiationLogonReceived: {\r\n // this instance initiates logout\r\n this.setState(SessionState.WaitingLogoutConfirm)\r\n sessionState.logoutSentAt = new Date()\r\n const msg = `${this.me} initiate logout`\r\n this.sessionLogger.info(msg)\r\n this.send(this.requestLogoutType, factory.logout(this.requestLogoutType,msg))\r\n break\r\n }\r\n\r\n case SessionState.ConfirmingLogout: {\r\n // this instance responds to logout\r\n sessionState.logoutSentAt = new Date()\r\n const msg = `${this.me} confirming logout`\r\n this.sessionLogger.info(msg)\r\n this.send(this.respondLogoutType, factory.logout(this.respondLogoutType,msg))\r\n break\r\n }\r\n\r\n default: {\r\n this.sessionLogger.info(`sessionLogout ignored as in state ${sessionState.state}`)\r\n }\r\n }\r\n }\r\n\r\n public done (): void {\r\n switch (this.sessionState.state) {\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.InitiationLogonReceived: {\r\n this.sessionLogout()\r\n break\r\n }\r\n\r\n case SessionState.Stopped:\r\n this.sessionLogger.info(`done. session is now stopped`)\r\n break\r\n\r\n default: {\r\n this.stop()\r\n break\r\n }\r\n }\r\n this.sessionLogger.info(`done. check logout sequence`)\r\n }\r\n\r\n public reset (): void {\r\n this.transport = null\r\n this.sessionState.reset(true) // from header def ... eventually\r\n this.setState(SessionState.NetworkConnectionEstablished)\r\n }\r\n\r\n protected stop (error: Error = null): void {\r\n if (this.sessionState.state === SessionState.Stopped) {\r\n return\r\n }\r\n clearInterval(this.timer)\r\n this.sessionLogger.info(`stop: kill transport`)\r\n this.transport.end()\r\n if (error) {\r\n this.sessionLogger.info(`stop: emit error ${error.message}`)\r\n this.emit('error', error)\r\n } else {\r\n this.emit('done')\r\n }\r\n\r\n this.setState(SessionState.Stopped)\r\n this.onStopped(error)\r\n this.transport = null\r\n }\r\n\r\n protected abstract onMsg (msgType: string, view: MsgView): void\r\n // application responsible for writing its own log\r\n protected abstract onDecoded (msgType: string, txt: string): void\r\n protected abstract onEncoded (msgType: string, txt: string): void\r\n // an application level message to be handled by implementation, unless\r\n // manageSession = false in which case all messages will be forwarded\r\n protected abstract onApplicationMsg (msgType: string, view: MsgView): void\r\n // inform application peer has logged in - provide login message\r\n protected abstract onReady (view: MsgView): void\r\n // inform application this session has now ended - either from logout or connection dropped\r\n protected abstract onStopped (error?: Error): void\r\n // does the application accept the inbound logon request\r\n protected abstract onLogon (view: MsgView, user: string, password: string): boolean\r\n}\r\n"]}
1
+ {"version":3,"file":"fix-session.js","sourceRoot":"","sources":["../../src/transport/fix-session.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElasticBuffer, MsgView } from '../buffer'\r\nimport { IJsFixConfig, IJsFixLogger } from '../config'\r\nimport { FixSessionState } from './fix-session-state'\r\nimport { MsgTransport } from './factory'\r\nimport { MsgTag } from '../types'\r\nimport { ILooseObject } from '../collections/collection'\r\n\r\nimport * as events from 'events'\r\nimport { SessionState } from './session-state'\r\nimport { SegmentType } from '../buffer/segment/segment-type'\r\n\r\nexport abstract class FixSession extends events.EventEmitter {\r\n public logReceivedMsgs: boolean = false\r\n protected timer: NodeJS.Timer = null\r\n protected transport: MsgTransport = null\r\n public manageSession: boolean = true\r\n public checkMsgIntegrity: boolean = false\r\n protected readonly me: string\r\n protected readonly initiator: boolean\r\n protected readonly acceptor: boolean\r\n protected readonly sessionState: FixSessionState\r\n protected readonly sessionLogger: IJsFixLogger\r\n protected requestLogoutType: string\r\n protected respondLogoutType: string\r\n protected requestLogonType: string\r\n\r\n protected constructor (public readonly config: IJsFixConfig) {\r\n super()\r\n const description = config.description\r\n this.me = description.application.name\r\n this.sessionState = new FixSessionState(\r\n { heartBeat: config.description.HeartBtInt,\r\n lastPeerMsgSeqNum: config.description.LastReceivedSeqNum})\r\n this.sessionLogger = config.logFactory.logger(`${this.me}:FixSession`)\r\n this.initiator = description.application.type === 'initiator'\r\n this.acceptor = !this.initiator\r\n this.checkMsgIntegrity = this.acceptor\r\n this.sessionState.compId = description.SenderCompId\r\n }\r\n\r\n public setState (state: SessionState) {\r\n if (state === this.sessionState.state) return\r\n const logger = this.sessionLogger\r\n const prevState = this.sessionState.state\r\n const msg = `current state ${SessionState[prevState]} (${prevState}) moves to ${SessionState[state]} (${state})`\r\n logger.info(msg)\r\n this.sessionState.state = state\r\n }\r\n\r\n public getState (): SessionState {\r\n return this.sessionState.state\r\n }\r\n\r\n public sendLogon () {\r\n this.send(this.requestLogonType, this.config.factory.logon())\r\n }\r\n\r\n private waitPromise (): Promise<any> {\r\n const logger = this.sessionLogger\r\n return new Promise<any>((accept, reject) => {\r\n if (this.initiator) {\r\n logger.debug(`initiator sending logon state = ${this.stateString()}`)\r\n this.sendLogon()\r\n this.setState(SessionState.InitiationLogonSent)\r\n } else {\r\n logger.debug(`acceptor waits for logon state = ${this.stateString()}`)\r\n this.setState(SessionState.WaitingForALogon)\r\n }\r\n\r\n this.on('error', (e: Error) => {\r\n logger.error(e)\r\n reject(e)\r\n })\r\n\r\n this.on('done', () => {\r\n accept(this.transport.id)\r\n })\r\n })\r\n }\r\n\r\n public run (transport: MsgTransport): Promise<number> {\r\n const logger = this.sessionLogger\r\n if (this.transport) {\r\n logger.info(`reset from previous transport. state ${this.stateString()}`)\r\n this.reset()\r\n }\r\n this.transport = transport\r\n this.subscribe()\r\n return this.waitPromise()\r\n }\r\n\r\n protected expectedState (): boolean {\r\n switch (this.sessionState.state) {\r\n case SessionState.ActiveNormalSession:\r\n case SessionState.ReceiveLogout:\r\n case SessionState.Stopped:\r\n case SessionState.ConfirmingLogout:\r\n case SessionState.HandleResendRequest:\r\n case SessionState.AwaitingProcessingResponseToTestRequest:\r\n case SessionState.AwaitingProcessingResponseToResendRequest:\r\n return true\r\n\r\n default:\r\n return false\r\n }\r\n }\r\n\r\n protected subscribe () {\r\n\r\n const transport = this.transport\r\n const logger = this.sessionLogger\r\n\r\n const rx = transport.receiver\r\n const tx = transport.transmitter\r\n\r\n rx.on('msg', (msgType: string, view: MsgView) => {\r\n if (this.logReceivedMsgs) {\r\n const name = view.segment.type !== SegmentType.Unknown ? view.segment.set.name : 'unknown'\r\n logger.info(`${msgType}: ${name}`)\r\n logger.info(`${view.toString()}`)\r\n }\r\n this.sessionState.lastReceivedAt = new Date()\r\n if (this.manageSession) {\r\n this.onMsg(msgType, view)\r\n } else {\r\n this.checkForwardMsg(msgType, view)\r\n }\r\n })\r\n\r\n rx.on('error', (e: Error) => {\r\n logger.warning(`rx error event: ${e.message} ${e.stack || ''}`)\r\n this.terminate(e)\r\n })\r\n\r\n rx.on('done', () => {\r\n logger.info('rx done received')\r\n this.done()\r\n })\r\n\r\n rx.on('end', () => {\r\n logger.info(`rx end received sessionState = [${this.sessionState.toString()}]`)\r\n const expectedState = this.expectedState()\r\n if (expectedState) {\r\n logger.info(`rx graceful end state = ${this.stateString()}`)\r\n this.done()\r\n } else {\r\n const e = new Error(`unexpected state - transport failed? = ${this.stateString()}`)\r\n logger.info(`rx error ${e.message}`)\r\n this.terminate(e)\r\n }\r\n })\r\n\r\n rx.on('decoded', (msgType: string, data: ElasticBuffer, ptr: number) => {\r\n logger.debug(`rx: [${msgType}] ${ptr} bytes`)\r\n this.onDecoded(msgType, data.toString(ptr))\r\n })\r\n\r\n tx.on('error', (e: Error) => {\r\n logger.warning(`tx error event: ${e.message} ${e.stack || ''}`)\r\n this.terminate(e)\r\n })\r\n\r\n tx.on('encoded', (msgType: string, data: string) => {\r\n logger.debug(`tx: [${msgType}] ${data.length} bytes`)\r\n this.onEncoded(msgType, data)\r\n })\r\n }\r\n\r\n protected validStateApplicationMsg (): boolean {\r\n switch (this.sessionState.state) {\r\n case SessionState.Idle:\r\n case SessionState.InitiateConnection:\r\n case SessionState.InitiationLogonSent:\r\n case SessionState.WaitingForALogon:\r\n case SessionState.HandleResendRequest:\r\n case SessionState.AwaitingProcessingResponseToTestRequest:\r\n case SessionState.AwaitingProcessingResponseToResendRequest:\r\n return false\r\n default:\r\n return true\r\n }\r\n }\r\n\r\n protected stateString (): string {\r\n return SessionState[this.sessionState.state]\r\n }\r\n\r\n protected checkForwardMsg (msgType: string, view: MsgView): void {\r\n this.sessionLogger.info(`forwarding msgType = '${msgType}' to application`)\r\n this.setState(SessionState.ActiveNormalSession)\r\n this.onApplicationMsg(msgType, view)\r\n }\r\n\r\n protected terminate (error: Error): void {\r\n if (this.sessionState.state === SessionState.Stopped) return\r\n this.sessionLogger.error(error)\r\n if (this.timer) {\r\n clearInterval(this.timer)\r\n }\r\n if (this.transport) {\r\n this.transport.end()\r\n }\r\n this.transport = null\r\n this.setState(SessionState.Stopped)\r\n this.emit('error', error)\r\n }\r\n\r\n protected peerLogout (view: MsgView) {\r\n const msg = view.getString(MsgTag.Text)\r\n const state = this.sessionState.state\r\n switch (state) {\r\n case SessionState.WaitingLogoutConfirm: {\r\n this.sessionLogger.info(`peer confirms logout Text = '${msg}'`)\r\n this.stop()\r\n break\r\n }\r\n\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.ActiveNormalSession:\r\n case SessionState.InitiationLogonReceived: {\r\n this.setState(SessionState.ConfirmingLogout)\r\n this.sessionLogger.info(`peer initiates logout Text = '${msg}'`)\r\n this.sessionLogout()\r\n }\r\n }\r\n }\r\n\r\n protected send (msgType: string, obj: ILooseObject) {\r\n const state = this.sessionState.state\r\n switch (state) {\r\n case SessionState.Stopped: {\r\n this.sessionLogger.warning(`can't send in state ${this.stateString()}`)\r\n break\r\n }\r\n\r\n default: {\r\n this.sessionState.LastSentAt = new Date()\r\n this.transport.transmitter.send(msgType, obj)\r\n break\r\n }\r\n }\r\n }\r\n\r\n protected sendLogout (msg: string) {\r\n const factory = this.config.factory\r\n this.sessionLogger.info(`sending logout with ${msg}`)\r\n this.send(this.requestLogoutType, factory.logout(this.requestLogoutType, msg))\r\n }\r\n\r\n protected sessionLogout (): void {\r\n const sessionState = this.sessionState\r\n if (sessionState.logoutSentAt) {\r\n return\r\n }\r\n\r\n switch (sessionState.state) {\r\n case SessionState.ActiveNormalSession:\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.InitiationLogonReceived: {\r\n // this instance initiates logout\r\n this.setState(SessionState.WaitingLogoutConfirm)\r\n sessionState.logoutSentAt = new Date()\r\n const msg = `${this.me} initiate logout`\r\n this.sessionLogger.info(msg)\r\n this.sendLogout(msg)\r\n break\r\n }\r\n\r\n case SessionState.ConfirmingLogout: {\r\n // this instance responds to logout\r\n sessionState.logoutSentAt = new Date()\r\n const msg = `${this.me} confirming logout`\r\n this.sessionLogger.info(msg)\r\n this.sendLogout(msg)\r\n break\r\n }\r\n\r\n default: {\r\n this.sessionLogger.info(`sessionLogout ignored as in state ${sessionState.state}`)\r\n }\r\n }\r\n }\r\n\r\n public done (): void {\r\n switch (this.sessionState.state) {\r\n case SessionState.InitiationLogonResponse:\r\n case SessionState.ActiveNormalSession:\r\n case SessionState.InitiationLogonReceived: {\r\n this.sessionLogout()\r\n break\r\n }\r\n\r\n case SessionState.Stopped:\r\n this.sessionLogger.info(`done. session is now stopped`)\r\n break\r\n\r\n default: {\r\n this.stop()\r\n break\r\n }\r\n }\r\n this.sessionLogger.info(`done. check logout sequence state ${this.stateString()}`)\r\n }\r\n\r\n public reset (): void {\r\n if (this.timer) {\r\n clearInterval(this.timer)\r\n }\r\n this.transport = null\r\n const resetSeqNum = this.config.description.ResetSeqNumFlag || true\r\n this.sessionState.reset(resetSeqNum) // from header def ... eventually\r\n this.setState(SessionState.NetworkConnectionEstablished)\r\n }\r\n\r\n protected stop (error: Error = null): void {\r\n if (this.sessionState.state === SessionState.Stopped) {\r\n return\r\n }\r\n if (this.timer) {\r\n clearInterval(this.timer)\r\n }\r\n this.sessionLogger.info(`stop: kill transport`)\r\n this.transport.end()\r\n if (error) {\r\n this.sessionLogger.info(`stop: emit error ${error.message}`)\r\n this.emit('error', error)\r\n } else {\r\n this.emit('done')\r\n }\r\n\r\n this.setState(SessionState.Stopped)\r\n this.onStopped(error)\r\n this.transport = null\r\n }\r\n\r\n protected abstract onMsg (msgType: string, view: MsgView): void\r\n // application responsible for writing its own log\r\n protected abstract onDecoded (msgType: string, txt: string): void\r\n protected abstract onEncoded (msgType: string, txt: string): void\r\n // an application level message to be handled by implementation, unless\r\n // manageSession = false in which case all messages will be forwarded\r\n protected abstract onApplicationMsg (msgType: string, view: MsgView): void\r\n // inform application peer has logged in - provide login message\r\n protected abstract onReady (view: MsgView): void\r\n // inform application this session has now ended - either from logout or connection dropped\r\n protected abstract onStopped (error?: Error): void\r\n // does the application accept the inbound logon request\r\n protected abstract onLogon (view: MsgView, user: string, password: string): boolean\r\n}\r\n"]}