@quantform/core 0.6.6 → 0.7.0-beta.4

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 (521) hide show
  1. package/dist/as-readonly.d.ts +3 -0
  2. package/dist/as-readonly.d.ts.map +1 -0
  3. package/dist/as-readonly.js +8 -0
  4. package/dist/{domain → asset}/asset.d.ts +6 -1
  5. package/dist/asset/asset.d.ts.map +1 -0
  6. package/dist/{domain → asset}/asset.js +16 -7
  7. package/dist/asset/asset.spec.d.ts +2 -0
  8. package/dist/asset/asset.spec.d.ts.map +1 -0
  9. package/dist/asset/asset.spec.js +54 -0
  10. package/dist/asset/index.d.ts +2 -0
  11. package/dist/asset/index.d.ts.map +1 -0
  12. package/dist/{adapter/paper → asset}/index.js +1 -2
  13. package/dist/cli/build.js +1 -1
  14. package/dist/cli/dev.d.ts.map +1 -1
  15. package/dist/cli/dev.js +15 -11
  16. package/dist/cli/index.js +8 -8
  17. package/dist/cli/internal/workspace.js +1 -1
  18. package/dist/cli/pull.d.ts.map +1 -1
  19. package/dist/cli/pull.js +50 -20
  20. package/dist/cli/{test.d.ts → replay.d.ts} +1 -1
  21. package/dist/cli/replay.d.ts.map +1 -0
  22. package/dist/cli/{test.js → replay.js} +18 -20
  23. package/dist/cli/run.d.ts.map +1 -1
  24. package/dist/cli/run.js +16 -11
  25. package/dist/component/distinct-until-timesamp-changed.d.ts +5 -0
  26. package/dist/component/distinct-until-timesamp-changed.d.ts.map +1 -0
  27. package/dist/component/distinct-until-timesamp-changed.js +9 -0
  28. package/dist/component/error.d.ts +17 -0
  29. package/dist/component/error.d.ts.map +1 -0
  30. package/dist/component/error.js +33 -0
  31. package/dist/component/index.d.ts +8 -0
  32. package/dist/component/index.d.ts.map +1 -0
  33. package/dist/{store → component}/index.js +7 -9
  34. package/dist/{domain → component}/ohlc-operator.d.ts +1 -1
  35. package/dist/component/ohlc-operator.d.ts.map +1 -0
  36. package/dist/{domain → component}/ohlc-operator.js +4 -5
  37. package/dist/component/ohlc-operator.spec.d.ts +2 -0
  38. package/dist/component/ohlc-operator.spec.d.ts.map +1 -0
  39. package/dist/component/ohlc-operator.spec.js +110 -0
  40. package/dist/component/ohlc.d.ts.map +1 -0
  41. package/dist/component/ohlc.spec.d.ts +2 -0
  42. package/dist/component/ohlc.spec.d.ts.map +1 -0
  43. package/dist/component/ohlc.spec.js +25 -0
  44. package/dist/component/timeframe.d.ts.map +1 -0
  45. package/dist/core.d.ts +3 -0
  46. package/dist/core.d.ts.map +1 -0
  47. package/dist/core.js +15 -0
  48. package/dist/defined.d.ts +3 -0
  49. package/dist/defined.d.ts.map +1 -0
  50. package/dist/defined.js +8 -0
  51. package/dist/exclude.d.ts +3 -0
  52. package/dist/exclude.d.ts.map +1 -0
  53. package/dist/exclude.js +8 -0
  54. package/dist/index.d.ts +25 -27
  55. package/dist/index.d.ts.map +1 -1
  56. package/dist/index.js +25 -66
  57. package/dist/{domain → instrument/commission}/commission.d.ts +1 -1
  58. package/dist/instrument/commission/commission.d.ts.map +1 -0
  59. package/dist/{domain → instrument/commission}/commission.js +2 -2
  60. package/dist/instrument/commission/commission.spec.d.ts +2 -0
  61. package/dist/instrument/commission/commission.spec.d.ts.map +1 -0
  62. package/dist/instrument/commission/commission.spec.js +30 -0
  63. package/dist/instrument/index.d.ts +3 -0
  64. package/dist/instrument/index.d.ts.map +1 -0
  65. package/dist/{adapter → instrument}/index.js +2 -4
  66. package/dist/{domain → instrument}/instrument.d.ts +4 -4
  67. package/dist/instrument/instrument.d.ts.map +1 -0
  68. package/dist/{domain → instrument}/instrument.js +8 -5
  69. package/dist/instrument/instrument.spec.d.ts +2 -0
  70. package/dist/instrument/instrument.spec.d.ts.map +1 -0
  71. package/dist/instrument/instrument.spec.js +51 -0
  72. package/dist/make-test-module.d.ts +13 -0
  73. package/dist/make-test-module.d.ts.map +1 -0
  74. package/dist/make-test-module.js +46 -0
  75. package/dist/module.d.ts +57 -0
  76. package/dist/module.d.ts.map +1 -0
  77. package/dist/module.js +136 -0
  78. package/dist/module.spec.d.ts +2 -0
  79. package/dist/module.spec.d.ts.map +1 -0
  80. package/dist/module.spec.js +86 -0
  81. package/dist/not-found.d.ts +2 -0
  82. package/dist/not-found.d.ts.map +1 -0
  83. package/dist/{domain/component.js → not-found.js} +2 -0
  84. package/dist/replay/index.d.ts +7 -0
  85. package/dist/replay/index.d.ts.map +1 -0
  86. package/dist/replay/index.js +22 -0
  87. package/dist/replay/use-replay-coordinator.d.ts +10 -0
  88. package/dist/replay/use-replay-coordinator.d.ts.map +1 -0
  89. package/dist/replay/use-replay-coordinator.js +119 -0
  90. package/dist/replay/use-replay-options.d.ts +15 -0
  91. package/dist/replay/use-replay-options.d.ts.map +1 -0
  92. package/dist/replay/use-replay-options.js +20 -0
  93. package/dist/replay/use-replay-reader.d.ts +7 -0
  94. package/dist/replay/use-replay-reader.d.ts.map +1 -0
  95. package/dist/replay/use-replay-reader.js +32 -0
  96. package/dist/replay/use-replay-reader.spec.d.ts +2 -0
  97. package/dist/replay/use-replay-reader.spec.d.ts.map +1 -0
  98. package/dist/replay/use-replay-reader.spec.js +58 -0
  99. package/dist/replay/use-replay-storage.d.ts +10 -0
  100. package/dist/replay/use-replay-storage.d.ts.map +1 -0
  101. package/dist/replay/use-replay-storage.js +10 -0
  102. package/dist/replay/use-replay-writer.d.ts +6 -0
  103. package/dist/replay/use-replay-writer.d.ts.map +1 -0
  104. package/dist/replay/use-replay-writer.js +14 -0
  105. package/dist/replay/use-replay-writer.spec.d.ts +2 -0
  106. package/dist/replay/use-replay-writer.spec.d.ts.map +1 -0
  107. package/dist/replay/use-replay-writer.spec.js +53 -0
  108. package/dist/replay/use-replay.d.ts +10 -0
  109. package/dist/replay/use-replay.d.ts.map +1 -0
  110. package/dist/replay/use-replay.js +32 -0
  111. package/dist/replay/use-replay.spec.d.ts +2 -0
  112. package/dist/replay/use-replay.spec.d.ts.map +1 -0
  113. package/dist/replay/use-replay.spec.js +106 -0
  114. package/dist/replay/with-replay.d.ts +4 -0
  115. package/dist/replay/with-replay.d.ts.map +1 -0
  116. package/dist/replay/with-replay.js +8 -0
  117. package/dist/session/index.d.ts +4 -0
  118. package/dist/session/index.d.ts.map +1 -0
  119. package/dist/session/index.js +19 -0
  120. package/dist/session/use-session-object.d.ts +18 -0
  121. package/dist/session/use-session-object.d.ts.map +1 -0
  122. package/dist/session/use-session-object.js +13 -0
  123. package/dist/session/use-session-storage.d.ts +2 -0
  124. package/dist/session/use-session-storage.d.ts.map +1 -0
  125. package/dist/session/use-session-storage.js +10 -0
  126. package/dist/session/use-session.d.ts +4 -0
  127. package/dist/session/use-session.d.ts.map +1 -0
  128. package/dist/session/use-session.js +7 -0
  129. package/dist/shared/datetime.d.ts +1 -1
  130. package/dist/shared/datetime.d.ts.map +1 -1
  131. package/dist/shared/decimals.d.ts.map +1 -1
  132. package/dist/shared/decimals.js +5 -0
  133. package/dist/shared/decimals.spec.d.ts +2 -0
  134. package/dist/shared/decimals.spec.d.ts.map +1 -0
  135. package/dist/shared/decimals.spec.js +28 -0
  136. package/dist/shared/index.d.ts +3 -7
  137. package/dist/shared/index.d.ts.map +1 -1
  138. package/dist/shared/index.js +3 -7
  139. package/dist/simulator/index.d.ts +2 -0
  140. package/dist/simulator/index.d.ts.map +1 -0
  141. package/dist/{adapter/backtester → simulator}/index.js +1 -2
  142. package/dist/simulator/use-simulator.d.ts +2 -0
  143. package/dist/simulator/use-simulator.d.ts.map +1 -0
  144. package/dist/simulator/use-simulator.js +9 -0
  145. package/dist/simulator/use-simulator.spec.d.ts +2 -0
  146. package/dist/simulator/use-simulator.spec.d.ts.map +1 -0
  147. package/dist/simulator/use-simulator.spec.js +49 -0
  148. package/dist/storage/in-memory/in-memory-storage.d.ts +9 -0
  149. package/dist/storage/in-memory/in-memory-storage.d.ts.map +1 -0
  150. package/dist/storage/in-memory/in-memory-storage.factory.d.ts +6 -0
  151. package/dist/storage/in-memory/in-memory-storage.factory.d.ts.map +1 -0
  152. package/dist/storage/in-memory/in-memory-storage.factory.js +23 -0
  153. package/dist/storage/in-memory/in-memory-storage.js +72 -0
  154. package/dist/storage/in-memory/in-memory-storage.spec.d.ts +2 -0
  155. package/dist/storage/in-memory/in-memory-storage.spec.d.ts.map +1 -0
  156. package/dist/storage/in-memory/in-memory-storage.spec.js +167 -0
  157. package/dist/storage/in-memory/index.d.ts +3 -0
  158. package/dist/storage/in-memory/index.d.ts.map +1 -0
  159. package/dist/storage/in-memory/index.js +18 -0
  160. package/dist/storage/index.d.ts +3 -3
  161. package/dist/storage/index.d.ts.map +1 -1
  162. package/dist/storage/index.js +3 -3
  163. package/dist/storage/storage.d.ts +51 -61
  164. package/dist/storage/storage.d.ts.map +1 -1
  165. package/dist/storage/storage.js +20 -85
  166. package/dist/storage/use-cache.d.ts +4 -0
  167. package/dist/storage/use-cache.d.ts.map +1 -0
  168. package/dist/storage/use-cache.js +34 -0
  169. package/dist/storage/use-cache.spec.d.ts +2 -0
  170. package/dist/storage/use-cache.spec.d.ts.map +1 -0
  171. package/dist/storage/use-cache.spec.js +36 -0
  172. package/dist/storage/use-storage-factory.d.ts +10 -0
  173. package/dist/storage/use-storage-factory.d.ts.map +1 -0
  174. package/dist/storage/use-storage-factory.js +14 -0
  175. package/dist/storage/use-storage.d.ts +3 -0
  176. package/dist/storage/use-storage.d.ts.map +1 -0
  177. package/dist/storage/use-storage.js +11 -0
  178. package/dist/strat.d.ts +7 -0
  179. package/dist/strat.d.ts.map +1 -0
  180. package/dist/strat.js +7 -0
  181. package/dist/use-execution-mode.d.ts +29 -0
  182. package/dist/use-execution-mode.d.ts.map +1 -0
  183. package/dist/use-execution-mode.js +37 -0
  184. package/dist/use-hash.d.ts +5 -0
  185. package/dist/use-hash.d.ts.map +1 -0
  186. package/dist/use-hash.js +7 -0
  187. package/dist/use-hash.spec.d.ts +2 -0
  188. package/dist/use-hash.spec.d.ts.map +1 -0
  189. package/dist/use-hash.spec.js +16 -0
  190. package/dist/use-lock.d.ts +9 -0
  191. package/dist/use-lock.d.ts.map +1 -0
  192. package/dist/use-lock.js +40 -0
  193. package/dist/use-logger.d.ts +10 -0
  194. package/dist/use-logger.d.ts.map +1 -0
  195. package/dist/use-logger.js +37 -0
  196. package/dist/use-memo.d.ts +21 -0
  197. package/dist/use-memo.d.ts.map +1 -0
  198. package/dist/use-memo.js +35 -0
  199. package/dist/use-memo.spec.d.ts +2 -0
  200. package/dist/use-memo.spec.d.ts.map +1 -0
  201. package/dist/use-memo.spec.js +35 -0
  202. package/dist/use-request.d.ts +16 -0
  203. package/dist/use-request.d.ts.map +1 -0
  204. package/dist/use-request.js +27 -0
  205. package/dist/use-socket.d.ts +6 -0
  206. package/dist/use-socket.d.ts.map +1 -0
  207. package/dist/use-socket.js +52 -0
  208. package/dist/use-state.d.ts +4 -0
  209. package/dist/use-state.d.ts.map +1 -0
  210. package/dist/use-state.js +24 -0
  211. package/dist/use-state.spec.d.ts +2 -0
  212. package/dist/use-state.spec.d.ts.map +1 -0
  213. package/dist/use-state.spec.js +36 -0
  214. package/dist/use-timestamp.d.ts +2 -0
  215. package/dist/use-timestamp.d.ts.map +1 -0
  216. package/dist/use-timestamp.js +13 -0
  217. package/dist/use.d.ts +5 -0
  218. package/dist/use.d.ts.map +1 -0
  219. package/dist/use.js +20 -0
  220. package/dist/use.spec.d.ts +2 -0
  221. package/dist/use.spec.d.ts.map +1 -0
  222. package/dist/use.spec.js +47 -0
  223. package/jest.config.ts +23 -2
  224. package/package.json +14 -11
  225. package/src/as-readonly.ts +5 -0
  226. package/src/{domain → asset}/asset.spec.ts +4 -4
  227. package/src/{domain → asset}/asset.ts +17 -6
  228. package/src/asset/index.ts +1 -0
  229. package/src/cli/build.ts +1 -1
  230. package/src/cli/dev.ts +18 -13
  231. package/src/cli/index.ts +7 -7
  232. package/src/cli/internal/workspace.ts +1 -1
  233. package/src/cli/pull.ts +22 -10
  234. package/src/cli/replay.ts +31 -0
  235. package/src/cli/run.ts +17 -13
  236. package/src/component/distinct-until-timesamp-changed.ts +11 -0
  237. package/src/component/error.ts +32 -0
  238. package/src/component/index.ts +7 -0
  239. package/src/{domain → component}/ohlc-operator.spec.ts +5 -6
  240. package/src/{domain → component}/ohlc-operator.ts +2 -3
  241. package/src/{domain → component}/ohlc.spec.ts +2 -2
  242. package/src/{domain → component}/ohlc.ts +2 -2
  243. package/src/core.ts +14 -0
  244. package/src/defined.ts +6 -0
  245. package/src/exclude.ts +9 -0
  246. package/src/index.ts +27 -80
  247. package/src/{domain → instrument/commission}/commission.spec.ts +4 -3
  248. package/src/{domain → instrument/commission}/commission.ts +1 -1
  249. package/src/instrument/index.ts +2 -0
  250. package/src/{domain → instrument}/instrument.spec.ts +11 -6
  251. package/src/{domain → instrument}/instrument.ts +12 -8
  252. package/src/make-test-module.ts +46 -0
  253. package/src/module.spec.ts +74 -0
  254. package/src/module.ts +156 -0
  255. package/src/not-found.ts +1 -0
  256. package/src/replay/index.ts +6 -0
  257. package/src/replay/use-replay-coordinator.ts +142 -0
  258. package/src/replay/use-replay-options.ts +23 -0
  259. package/src/replay/use-replay-reader.spec.ts +64 -0
  260. package/src/replay/use-replay-reader.ts +23 -0
  261. package/src/replay/use-replay-storage.ts +8 -0
  262. package/src/replay/use-replay-writer.spec.ts +56 -0
  263. package/src/replay/use-replay-writer.ts +17 -0
  264. package/src/replay/use-replay.spec.ts +132 -0
  265. package/src/replay/use-replay.ts +34 -0
  266. package/src/replay/with-replay.ts +10 -0
  267. package/src/session/index.ts +3 -0
  268. package/src/session/use-session-object.ts +26 -0
  269. package/src/session/use-session-storage.ts +9 -0
  270. package/src/session/use-session.ts +5 -0
  271. package/src/shared/decimals.spec.ts +1 -1
  272. package/src/shared/decimals.ts +5 -0
  273. package/src/shared/index.ts +3 -7
  274. package/src/simulator/index.ts +1 -0
  275. package/src/simulator/use-simulator.spec.ts +54 -0
  276. package/src/simulator/use-simulator.ts +7 -0
  277. package/src/storage/in-memory/in-memory-storage.factory.ts +16 -0
  278. package/src/storage/in-memory/in-memory-storage.spec.ts +193 -0
  279. package/src/storage/in-memory/in-memory-storage.ts +80 -0
  280. package/src/storage/in-memory/index.ts +2 -0
  281. package/src/storage/index.ts +3 -3
  282. package/src/storage/storage.ts +63 -119
  283. package/src/storage/use-cache.spec.ts +31 -0
  284. package/src/storage/use-cache.ts +50 -0
  285. package/src/storage/use-storage-factory.ts +17 -0
  286. package/src/storage/use-storage.ts +11 -0
  287. package/src/strat.ts +7 -0
  288. package/src/use-execution-mode.ts +41 -0
  289. package/src/use-hash.spec.ts +16 -0
  290. package/src/use-hash.ts +5 -0
  291. package/src/use-lock.ts +52 -0
  292. package/src/use-logger.ts +47 -0
  293. package/src/use-memo.spec.ts +30 -0
  294. package/src/use-memo.ts +35 -0
  295. package/src/use-request.ts +47 -0
  296. package/src/use-socket.ts +59 -0
  297. package/src/use-state.spec.ts +31 -0
  298. package/src/use-state.ts +30 -0
  299. package/src/use-timestamp.ts +12 -0
  300. package/src/use.spec.ts +46 -0
  301. package/src/use.ts +33 -0
  302. package/tsconfig.json +7 -4
  303. package/dist/adapter/adapter-aggregate.d.ts +0 -57
  304. package/dist/adapter/adapter-aggregate.d.ts.map +0 -1
  305. package/dist/adapter/adapter-aggregate.js +0 -157
  306. package/dist/adapter/adapter.d.ts +0 -54
  307. package/dist/adapter/adapter.d.ts.map +0 -1
  308. package/dist/adapter/adapter.js +0 -20
  309. package/dist/adapter/backtester/backtester-adapter.d.ts +0 -30
  310. package/dist/adapter/backtester/backtester-adapter.d.ts.map +0 -1
  311. package/dist/adapter/backtester/backtester-adapter.js +0 -67
  312. package/dist/adapter/backtester/backtester-cursor.d.ts +0 -16
  313. package/dist/adapter/backtester/backtester-cursor.d.ts.map +0 -1
  314. package/dist/adapter/backtester/backtester-cursor.js +0 -52
  315. package/dist/adapter/backtester/backtester-streamer.d.ts +0 -50
  316. package/dist/adapter/backtester/backtester-streamer.d.ts.map +0 -1
  317. package/dist/adapter/backtester/backtester-streamer.js +0 -119
  318. package/dist/adapter/backtester/error.d.ts +0 -3
  319. package/dist/adapter/backtester/error.d.ts.map +0 -1
  320. package/dist/adapter/backtester/error.js +0 -11
  321. package/dist/adapter/backtester/index.d.ts +0 -3
  322. package/dist/adapter/backtester/index.d.ts.map +0 -1
  323. package/dist/adapter/error.d.ts +0 -4
  324. package/dist/adapter/error.d.ts.map +0 -1
  325. package/dist/adapter/error.js +0 -15
  326. package/dist/adapter/index.d.ts +0 -5
  327. package/dist/adapter/index.d.ts.map +0 -1
  328. package/dist/adapter/paper/engine/paper-engine.d.ts +0 -12
  329. package/dist/adapter/paper/engine/paper-engine.d.ts.map +0 -1
  330. package/dist/adapter/paper/engine/paper-engine.js +0 -109
  331. package/dist/adapter/paper/index.d.ts +0 -3
  332. package/dist/adapter/paper/index.d.ts.map +0 -1
  333. package/dist/adapter/paper/paper-adapter.d.ts +0 -30
  334. package/dist/adapter/paper/paper-adapter.d.ts.map +0 -1
  335. package/dist/adapter/paper/paper-adapter.js +0 -87
  336. package/dist/cli/error.d.ts +0 -2
  337. package/dist/cli/error.d.ts.map +0 -1
  338. package/dist/cli/error.js +0 -7
  339. package/dist/cli/test.d.ts.map +0 -1
  340. package/dist/domain/asset.d.ts.map +0 -1
  341. package/dist/domain/balance-operator.d.ts +0 -7
  342. package/dist/domain/balance-operator.d.ts.map +0 -1
  343. package/dist/domain/balance-operator.js +0 -9
  344. package/dist/domain/balance.d.ts +0 -47
  345. package/dist/domain/balance.d.ts.map +0 -1
  346. package/dist/domain/balance.js +0 -97
  347. package/dist/domain/commission.d.ts.map +0 -1
  348. package/dist/domain/component.d.ts +0 -6
  349. package/dist/domain/component.d.ts.map +0 -1
  350. package/dist/domain/error.d.ts +0 -7
  351. package/dist/domain/error.d.ts.map +0 -1
  352. package/dist/domain/error.js +0 -23
  353. package/dist/domain/index.d.ts +0 -22
  354. package/dist/domain/index.d.ts.map +0 -1
  355. package/dist/domain/index.js +0 -37
  356. package/dist/domain/instrument-operator.d.ts +0 -7
  357. package/dist/domain/instrument-operator.d.ts.map +0 -1
  358. package/dist/domain/instrument-operator.js +0 -13
  359. package/dist/domain/instrument.d.ts.map +0 -1
  360. package/dist/domain/ohlc-operator.d.ts.map +0 -1
  361. package/dist/domain/ohlc.d.ts.map +0 -1
  362. package/dist/domain/order-operator.d.ts +0 -8
  363. package/dist/domain/order-operator.d.ts.map +0 -1
  364. package/dist/domain/order-operator.js +0 -16
  365. package/dist/domain/order.d.ts +0 -24
  366. package/dist/domain/order.d.ts.map +0 -1
  367. package/dist/domain/order.js +0 -49
  368. package/dist/domain/orderbook-operator.d.ts +0 -7
  369. package/dist/domain/orderbook-operator.d.ts.map +0 -1
  370. package/dist/domain/orderbook-operator.js +0 -9
  371. package/dist/domain/orderbook.d.ts +0 -30
  372. package/dist/domain/orderbook.d.ts.map +0 -1
  373. package/dist/domain/orderbook.js +0 -20
  374. package/dist/domain/position-operator.d.ts +0 -13
  375. package/dist/domain/position-operator.d.ts.map +0 -1
  376. package/dist/domain/position-operator.js +0 -45
  377. package/dist/domain/position.d.ts +0 -18
  378. package/dist/domain/position.d.ts.map +0 -1
  379. package/dist/domain/position.js +0 -23
  380. package/dist/domain/session-builder.d.ts +0 -54
  381. package/dist/domain/session-builder.d.ts.map +0 -1
  382. package/dist/domain/session-builder.js +0 -106
  383. package/dist/domain/session.d.ts +0 -77
  384. package/dist/domain/session.d.ts.map +0 -1
  385. package/dist/domain/session.js +0 -162
  386. package/dist/domain/timeframe.d.ts.map +0 -1
  387. package/dist/domain/trade-operator.d.ts +0 -7
  388. package/dist/domain/trade-operator.d.ts.map +0 -1
  389. package/dist/domain/trade-operator.js +0 -9
  390. package/dist/domain/trade.d.ts +0 -16
  391. package/dist/domain/trade.d.ts.map +0 -1
  392. package/dist/domain/trade.js +0 -17
  393. package/dist/shared/collections.d.ts +0 -29
  394. package/dist/shared/collections.d.ts.map +0 -1
  395. package/dist/shared/collections.js +0 -123
  396. package/dist/shared/logger.d.ts +0 -8
  397. package/dist/shared/logger.d.ts.map +0 -1
  398. package/dist/shared/logger.js +0 -33
  399. package/dist/shared/pipe.d.ts +0 -5
  400. package/dist/shared/pipe.d.ts.map +0 -1
  401. package/dist/shared/pipe.js +0 -8
  402. package/dist/shared/policy.d.ts +0 -2
  403. package/dist/shared/policy.d.ts.map +0 -1
  404. package/dist/shared/policy.js +0 -8
  405. package/dist/storage/cache.d.ts +0 -10
  406. package/dist/storage/cache.d.ts.map +0 -1
  407. package/dist/storage/cache.js +0 -43
  408. package/dist/storage/feed.d.ts +0 -38
  409. package/dist/storage/feed.d.ts.map +0 -1
  410. package/dist/storage/feed.js +0 -108
  411. package/dist/storage/measurement.d.ts +0 -34
  412. package/dist/storage/measurement.d.ts.map +0 -1
  413. package/dist/storage/measurement.js +0 -59
  414. package/dist/store/error.d.ts +0 -9
  415. package/dist/store/error.d.ts.map +0 -1
  416. package/dist/store/error.js +0 -31
  417. package/dist/store/index.d.ts +0 -10
  418. package/dist/store/index.d.ts.map +0 -1
  419. package/dist/store/store-balance-event.d.ts +0 -46
  420. package/dist/store/store-balance-event.d.ts.map +0 -1
  421. package/dist/store/store-balance-event.js +0 -134
  422. package/dist/store/store-event.d.ts +0 -7
  423. package/dist/store/store-event.d.ts.map +0 -1
  424. package/dist/store/store-event.js +0 -2
  425. package/dist/store/store-instrument-event.d.ts +0 -22
  426. package/dist/store/store-instrument-event.d.ts.map +0 -1
  427. package/dist/store/store-instrument-event.js +0 -60
  428. package/dist/store/store-order-event.d.ts +0 -64
  429. package/dist/store/store-order-event.d.ts.map +0 -1
  430. package/dist/store/store-order-event.js +0 -185
  431. package/dist/store/store-orderbook-event.d.ts +0 -13
  432. package/dist/store/store-orderbook-event.d.ts.map +0 -1
  433. package/dist/store/store-orderbook-event.js +0 -43
  434. package/dist/store/store-position-event.d.ts +0 -22
  435. package/dist/store/store-position-event.d.ts.map +0 -1
  436. package/dist/store/store-position-event.js +0 -96
  437. package/dist/store/store-state.d.ts +0 -28
  438. package/dist/store/store-state.d.ts.map +0 -1
  439. package/dist/store/store-state.js +0 -29
  440. package/dist/store/store-trade-event.d.ts +0 -17
  441. package/dist/store/store-trade-event.d.ts.map +0 -1
  442. package/dist/store/store-trade-event.js +0 -34
  443. package/dist/store/store.d.ts +0 -15
  444. package/dist/store/store.d.ts.map +0 -1
  445. package/dist/store/store.js +0 -32
  446. package/src/adapter/adapter-aggregate.ts +0 -171
  447. package/src/adapter/adapter.ts +0 -83
  448. package/src/adapter/backtester/backtester-adapter.ts +0 -96
  449. package/src/adapter/backtester/backtester-cursor.spec.ts +0 -44
  450. package/src/adapter/backtester/backtester-cursor.ts +0 -47
  451. package/src/adapter/backtester/backtester-streamer.spec.ts +0 -60
  452. package/src/adapter/backtester/backtester-streamer.ts +0 -155
  453. package/src/adapter/backtester/error.ts +0 -7
  454. package/src/adapter/backtester/index.ts +0 -2
  455. package/src/adapter/error.ts +0 -13
  456. package/src/adapter/index.ts +0 -4
  457. package/src/adapter/paper/engine/paper-engine.spec.ts +0 -116
  458. package/src/adapter/paper/engine/paper-engine.ts +0 -151
  459. package/src/adapter/paper/index.ts +0 -2
  460. package/src/adapter/paper/paper-adapter.ts +0 -111
  461. package/src/cli/error.ts +0 -5
  462. package/src/cli/test.ts +0 -40
  463. package/src/domain/balance-operator.spec.ts +0 -26
  464. package/src/domain/balance-operator.ts +0 -15
  465. package/src/domain/balance.spec.ts +0 -116
  466. package/src/domain/balance.ts +0 -123
  467. package/src/domain/component.ts +0 -6
  468. package/src/domain/error.ts +0 -27
  469. package/src/domain/index.ts +0 -21
  470. package/src/domain/instrument-operator.spec.ts +0 -35
  471. package/src/domain/instrument-operator.ts +0 -25
  472. package/src/domain/order-operator.spec.ts +0 -85
  473. package/src/domain/order-operator.ts +0 -23
  474. package/src/domain/order.spec.ts +0 -43
  475. package/src/domain/order.ts +0 -68
  476. package/src/domain/orderbook-operator.spec.ts +0 -40
  477. package/src/domain/orderbook-operator.ts +0 -15
  478. package/src/domain/orderbook.spec.ts +0 -26
  479. package/src/domain/orderbook.ts +0 -30
  480. package/src/domain/position-operator.spec.ts +0 -64
  481. package/src/domain/position-operator.ts +0 -71
  482. package/src/domain/position.spec.ts +0 -43
  483. package/src/domain/position.ts +0 -31
  484. package/src/domain/session-builder.ts +0 -158
  485. package/src/domain/session.spec.ts +0 -33
  486. package/src/domain/session.ts +0 -256
  487. package/src/domain/trade-operator.spec.ts +0 -35
  488. package/src/domain/trade-operator.ts +0 -15
  489. package/src/domain/trade.spec.ts +0 -21
  490. package/src/domain/trade.ts +0 -20
  491. package/src/shared/collections.spec.ts +0 -34
  492. package/src/shared/collections.ts +0 -154
  493. package/src/shared/logger.ts +0 -39
  494. package/src/shared/pipe.ts +0 -12
  495. package/src/shared/policy.ts +0 -5
  496. package/src/storage/cache.spec.ts +0 -18
  497. package/src/storage/cache.ts +0 -37
  498. package/src/storage/feed.ts +0 -124
  499. package/src/storage/measurement.ts +0 -56
  500. package/src/store/error.ts +0 -36
  501. package/src/store/index.ts +0 -9
  502. package/src/store/store-balance-event.spec.ts +0 -30
  503. package/src/store/store-balance-event.ts +0 -167
  504. package/src/store/store-event.ts +0 -8
  505. package/src/store/store-instrument-event.spec.ts +0 -26
  506. package/src/store/store-instrument-event.ts +0 -83
  507. package/src/store/store-order-event.spec.ts +0 -32
  508. package/src/store/store-order-event.ts +0 -219
  509. package/src/store/store-orderbook-event.spec.ts +0 -39
  510. package/src/store/store-orderbook-event.ts +0 -56
  511. package/src/store/store-position-event.ts +0 -121
  512. package/src/store/store-state.ts +0 -48
  513. package/src/store/store-trade-event.spec.ts +0 -62
  514. package/src/store/store-trade-event.ts +0 -42
  515. package/src/store/store.spec.ts +0 -182
  516. package/src/store/store.ts +0 -37
  517. package/dist/{domain → component}/ohlc.d.ts +0 -0
  518. package/dist/{domain → component}/ohlc.js +0 -0
  519. package/dist/{domain → component}/timeframe.d.ts +0 -0
  520. package/dist/{domain → component}/timeframe.js +1 -1
  521. /package/src/{domain → component}/timeframe.ts +0 -0
@@ -2,19 +2,18 @@
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.ohlcCompleted = exports.mergeOhlc = exports.ohlc = void 0;
4
4
  const rxjs_1 = require("rxjs");
5
- const ohlc_1 = require("./ohlc");
6
- const timeframe_1 = require("./timeframe");
5
+ const component_1 = require("../component");
7
6
  function aggregate(candle, timeframe, value, timestamp) {
8
- const frame = (0, timeframe_1.tf)(timestamp, timeframe);
7
+ const frame = (0, component_1.tf)(timestamp, timeframe);
9
8
  if (!candle) {
10
- return new ohlc_1.Ohlc(frame, value, value, value, value);
9
+ return new component_1.Ohlc(frame, value, value, value, value);
11
10
  }
12
11
  if (candle.timestamp === frame) {
13
12
  candle.apply(value);
14
13
  return undefined;
15
14
  }
16
15
  else {
17
- return new ohlc_1.Ohlc(frame, candle.close, value, value, value);
16
+ return new component_1.Ohlc(frame, candle.close, value, value, value);
18
17
  }
19
18
  }
20
19
  function ohlc(timeframe, fn, candleToStartWith) {
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ohlc-operator.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ohlc-operator.spec.d.ts","sourceRoot":"","sources":["../../src/component/ohlc-operator.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,110 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const rxjs_1 = require("rxjs");
4
+ const component_1 = require("../component");
5
+ const shared_1 = require("../shared");
6
+ describe(component_1.ohlc.name, () => {
7
+ test('should aggregate and pipe ohlc updates', done => {
8
+ const input$ = (0, rxjs_1.from)([
9
+ { timestamp: 1, rate: (0, shared_1.d)(1) },
10
+ { timestamp: 2, rate: (0, shared_1.d)(2) },
11
+ { timestamp: 3, rate: (0, shared_1.d)(3) },
12
+ { timestamp: 4, rate: shared_1.d.Zero },
13
+ { timestamp: 5, rate: (0, shared_1.d)(7) },
14
+ { timestamp: 6, rate: (0, shared_1.d)(8) }
15
+ ]);
16
+ const output = [
17
+ new component_1.Ohlc(0, (0, shared_1.d)(1), (0, shared_1.d)(1), (0, shared_1.d)(1), (0, shared_1.d)(1)),
18
+ new component_1.Ohlc(0, (0, shared_1.d)(1), (0, shared_1.d)(2), (0, shared_1.d)(1), (0, shared_1.d)(2)),
19
+ new component_1.Ohlc(0, (0, shared_1.d)(1), (0, shared_1.d)(3), (0, shared_1.d)(1), (0, shared_1.d)(3)),
20
+ new component_1.Ohlc(0, (0, shared_1.d)(1), (0, shared_1.d)(3), shared_1.d.Zero, shared_1.d.Zero),
21
+ new component_1.Ohlc(5, shared_1.d.Zero, (0, shared_1.d)(7), (0, shared_1.d)(7), (0, shared_1.d)(7)),
22
+ new component_1.Ohlc(5, shared_1.d.Zero, (0, shared_1.d)(8), (0, shared_1.d)(7), (0, shared_1.d)(8))
23
+ ].reverse();
24
+ input$.pipe((0, component_1.ohlc)(5, it => it.rate)).subscribe({
25
+ next: it => {
26
+ expect(it).toEqual(output.pop());
27
+ if (output.length === 0) {
28
+ done();
29
+ }
30
+ }
31
+ });
32
+ });
33
+ });
34
+ describe(component_1.ohlcCompleted.name, () => {
35
+ test('should aggregate and pipe distinct completed ohlc', done => {
36
+ const input$ = (0, rxjs_1.from)([
37
+ { timestamp: 1, rate: (0, shared_1.d)(1) },
38
+ { timestamp: 2, rate: (0, shared_1.d)(2) },
39
+ { timestamp: 3, rate: (0, shared_1.d)(3) },
40
+ { timestamp: 4, rate: shared_1.d.Zero },
41
+ { timestamp: 5, rate: (0, shared_1.d)(7) },
42
+ { timestamp: 6, rate: (0, shared_1.d)(8) }
43
+ ]);
44
+ input$
45
+ .pipe((0, component_1.ohlc)(5, it => it.rate), (0, component_1.ohlcCompleted)())
46
+ .subscribe({
47
+ next: it => {
48
+ expect(it).toEqual(new component_1.Ohlc(0, (0, shared_1.d)(1), (0, shared_1.d)(3), shared_1.d.Zero, shared_1.d.Zero));
49
+ done();
50
+ }
51
+ });
52
+ });
53
+ });
54
+ describe(component_1.mergeOhlc.name, () => {
55
+ test('should pipe and merge ohlc from history', done => {
56
+ const history$ = (0, rxjs_1.from)([
57
+ new component_1.Ohlc(1, (0, shared_1.d)(1), (0, shared_1.d)(1.5), (0, shared_1.d)(0.5), (0, shared_1.d)(2)),
58
+ new component_1.Ohlc(2, (0, shared_1.d)(2), (0, shared_1.d)(2.5), (0, shared_1.d)(1.5), (0, shared_1.d)(3)),
59
+ new component_1.Ohlc(3, (0, shared_1.d)(3), (0, shared_1.d)(3.5), (0, shared_1.d)(2.5), (0, shared_1.d)(4))
60
+ ]);
61
+ const input$ = (0, rxjs_1.from)([
62
+ { timestamp: 3, rate: (0, shared_1.d)(5) },
63
+ { timestamp: 4, rate: (0, shared_1.d)(3) },
64
+ { timestamp: 5, rate: (0, shared_1.d)(4) }
65
+ ]);
66
+ const output = [
67
+ new component_1.Ohlc(1, (0, shared_1.d)(1), (0, shared_1.d)(1.5), (0, shared_1.d)(0.5), (0, shared_1.d)(2)),
68
+ new component_1.Ohlc(2, (0, shared_1.d)(2), (0, shared_1.d)(2.5), (0, shared_1.d)(1.5), (0, shared_1.d)(3)),
69
+ new component_1.Ohlc(3, (0, shared_1.d)(3), (0, shared_1.d)(5), (0, shared_1.d)(2.5), (0, shared_1.d)(5)),
70
+ new component_1.Ohlc(4, (0, shared_1.d)(5), (0, shared_1.d)(3), (0, shared_1.d)(3), (0, shared_1.d)(3)),
71
+ new component_1.Ohlc(5, (0, shared_1.d)(3), (0, shared_1.d)(4), (0, shared_1.d)(4), (0, shared_1.d)(4))
72
+ ].reverse();
73
+ input$.pipe((0, component_1.mergeOhlc)(1, it => it.rate, history$)).subscribe({
74
+ next: it => {
75
+ expect(it).toEqual(output.pop());
76
+ if (output.length === 0) {
77
+ done();
78
+ }
79
+ }
80
+ });
81
+ });
82
+ test('should pipe and not merge ohlc from history', done => {
83
+ const history$ = (0, rxjs_1.from)([
84
+ new component_1.Ohlc(1, (0, shared_1.d)(1), (0, shared_1.d)(1.5), (0, shared_1.d)(0.5), (0, shared_1.d)(2)),
85
+ new component_1.Ohlc(2, (0, shared_1.d)(2), (0, shared_1.d)(2.5), (0, shared_1.d)(1.5), (0, shared_1.d)(3)),
86
+ new component_1.Ohlc(3, (0, shared_1.d)(3), (0, shared_1.d)(3.5), (0, shared_1.d)(2.5), (0, shared_1.d)(4))
87
+ ]);
88
+ const input$ = (0, rxjs_1.from)([
89
+ { timestamp: 4, rate: (0, shared_1.d)(5) },
90
+ { timestamp: 5, rate: (0, shared_1.d)(3) },
91
+ { timestamp: 6, rate: (0, shared_1.d)(4) }
92
+ ]);
93
+ const output = [
94
+ new component_1.Ohlc(1, (0, shared_1.d)(1), (0, shared_1.d)(1.5), (0, shared_1.d)(0.5), (0, shared_1.d)(2)),
95
+ new component_1.Ohlc(2, (0, shared_1.d)(2), (0, shared_1.d)(2.5), (0, shared_1.d)(1.5), (0, shared_1.d)(3)),
96
+ new component_1.Ohlc(3, (0, shared_1.d)(3), (0, shared_1.d)(3.5), (0, shared_1.d)(2.5), (0, shared_1.d)(4)),
97
+ new component_1.Ohlc(4, (0, shared_1.d)(4), (0, shared_1.d)(5), (0, shared_1.d)(5), (0, shared_1.d)(5)),
98
+ new component_1.Ohlc(5, (0, shared_1.d)(5), (0, shared_1.d)(3), (0, shared_1.d)(3), (0, shared_1.d)(3)),
99
+ new component_1.Ohlc(6, (0, shared_1.d)(3), (0, shared_1.d)(4), (0, shared_1.d)(4), (0, shared_1.d)(4))
100
+ ].reverse();
101
+ input$.pipe((0, component_1.mergeOhlc)(1, it => it.rate, history$)).subscribe({
102
+ next: it => {
103
+ expect(it).toEqual(output.pop());
104
+ if (output.length === 0) {
105
+ done();
106
+ }
107
+ }
108
+ });
109
+ });
110
+ });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ohlc.d.ts","sourceRoot":"","sources":["../../src/component/ohlc.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAEjD,qBAAa,IAAI;IAEN,SAAS,EAAE,SAAS;IACpB,IAAI,EAAE,OAAO;IACb,IAAI,EAAE,OAAO;IACb,GAAG,EAAE,OAAO;IACZ,KAAK,EAAE,OAAO;IACd,MAAM,CAAC;gBALP,SAAS,EAAE,SAAS,EACpB,IAAI,EAAE,OAAO,EACb,IAAI,EAAE,OAAO,EACb,GAAG,EAAE,OAAO,EACZ,KAAK,EAAE,OAAO,EACd,MAAM,CAAC,qBAAS;IAGzB,KAAK,CAAC,KAAK,EAAE,OAAO;CAKrB"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ohlc.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ohlc.spec.d.ts","sourceRoot":"","sources":["../../src/component/ohlc.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,25 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const component_1 = require("../component");
4
+ const shared_1 = require("../shared");
5
+ describe('Ohlc', () => {
6
+ test('should construct a ohlc', () => {
7
+ const timestamp = (0, shared_1.now)();
8
+ const sut = new component_1.Ohlc(timestamp, (0, shared_1.d)(2), (0, shared_1.d)(4), (0, shared_1.d)(1), (0, shared_1.d)(3));
9
+ expect(sut.timestamp).toEqual(timestamp);
10
+ expect(sut.open).toEqual((0, shared_1.d)(2));
11
+ expect(sut.high).toEqual((0, shared_1.d)(4));
12
+ expect(sut.low).toEqual((0, shared_1.d)(1));
13
+ expect(sut.close).toEqual((0, shared_1.d)(3));
14
+ });
15
+ test('should modify a ohlc', () => {
16
+ const timestamp = (0, shared_1.now)();
17
+ const sut = new component_1.Ohlc(timestamp, (0, shared_1.d)(2), (0, shared_1.d)(4), (0, shared_1.d)(1), (0, shared_1.d)(3));
18
+ sut.apply((0, shared_1.d)(10));
19
+ expect(sut.timestamp).toEqual(timestamp);
20
+ expect(sut.open).toEqual((0, shared_1.d)(2));
21
+ expect(sut.high).toEqual((0, shared_1.d)(10));
22
+ expect(sut.low).toEqual((0, shared_1.d)(1));
23
+ expect(sut.close).toEqual((0, shared_1.d)(10));
24
+ });
25
+ });
@@ -0,0 +1 @@
1
+ {"version":3,"file":"timeframe.d.ts","sourceRoot":"","sources":["../../src/component/timeframe.ts"],"names":[],"mappings":"AAAA,qBAAa,SAAS;IACpB,MAAM,CAAC,EAAE,SAAQ;IACjB,MAAM,CAAC,EAAE,SAAqB;IAC9B,MAAM,CAAC,EAAE,SAAoB;IAC7B,MAAM,CAAC,GAAG,SAAoB;IAC9B,MAAM,CAAC,GAAG,SAAqB;IAC/B,MAAM,CAAC,EAAE,SAAqB;IAC9B,MAAM,CAAC,EAAE,SAAoB;IAC7B,MAAM,CAAC,EAAE,SAAoB;IAC7B,MAAM,CAAC,GAAG,SAAoB;IAC9B,MAAM,CAAC,EAAE,SAAqB;IAC9B,MAAM,CAAC,EAAE,SAAoB;CAC9B;AAED,wBAAgB,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM,CAE/D"}
package/dist/core.d.ts ADDED
@@ -0,0 +1,3 @@
1
+ import { Dependency } from './module';
2
+ export declare function core(): Dependency[];
3
+ //# sourceMappingURL=core.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"core.d.ts","sourceRoot":"","sources":["../src/core.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAOzC,wBAAgB,IAAI,IAAI,UAAU,EAAE,CAMnC"}
package/dist/core.js ADDED
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.core = void 0;
4
+ const use_memo_1 = require("./use-memo");
5
+ const storage_1 = require("./storage");
6
+ const use_storage_factory_1 = require("./storage/use-storage-factory");
7
+ const use_execution_mode_1 = require("./use-execution-mode");
8
+ function core() {
9
+ return [
10
+ (0, use_memo_1.memo)(),
11
+ (0, use_execution_mode_1.paperExecutionMode)({ recording: false }),
12
+ (0, use_storage_factory_1.storage)(new storage_1.InMemoryStorageFactory())
13
+ ];
14
+ }
15
+ exports.core = core;
@@ -0,0 +1,3 @@
1
+ import { Observable } from 'rxjs';
2
+ export declare function defined<T>(): (observable: Observable<T | undefined | null>) => Observable<T | null | undefined>;
3
+ //# sourceMappingURL=defined.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"defined.d.ts","sourceRoot":"","sources":["../src/defined.ts"],"names":[],"mappings":"AAAA,OAAO,EAAU,UAAU,EAAE,MAAM,MAAM,CAAC;AAE1C,wBAAgB,OAAO,CAAC,CAAC,kBACH,WAAW,CAAC,GAAG,SAAS,GAAG,IAAI,CAAC,sCAErD"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.defined = void 0;
4
+ const rxjs_1 = require("rxjs");
5
+ function defined() {
6
+ return (observable) => observable.pipe((0, rxjs_1.filter)(it => it !== undefined && it !== null));
7
+ }
8
+ exports.defined = defined;
@@ -0,0 +1,3 @@
1
+ import { Observable } from 'rxjs';
2
+ export declare function exclude<T, S extends symbol>(s: S): (observable: Observable<T | S>) => Observable<Exclude<T, S>>;
3
+ //# sourceMappingURL=exclude.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"exclude.d.ts","sourceRoot":"","sources":["../src/exclude.ts"],"names":[],"mappings":"AAAA,OAAO,EAAe,UAAU,EAAE,MAAM,MAAM,CAAC;AAE/C,wBAAgB,OAAO,CAAC,CAAC,EAAE,CAAC,SAAS,MAAM,EAAE,CAAC,EAAE,CAAC,gBAC3B,WAAW,CAAC,GAAG,CAAC,CAAC,+BAKtC"}
@@ -0,0 +1,8 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.exclude = void 0;
4
+ const rxjs_1 = require("rxjs");
5
+ function exclude(s) {
6
+ return (observable) => observable.pipe((0, rxjs_1.filter)(it => it !== s), (0, rxjs_1.map)(it => it));
7
+ }
8
+ exports.exclude = exclude;
package/dist/index.d.ts CHANGED
@@ -1,30 +1,28 @@
1
- import { Observable } from 'rxjs';
2
- import { Session, SessionBuilder, SessionFeature } from './domain';
3
- export * from './adapter';
4
- export * from './domain';
1
+ export * from './component';
5
2
  export * from './shared';
6
3
  export * from './storage';
7
- export * from './store';
8
- export declare type SessionHook = (session: Session) => Observable<any>;
9
- /**
10
- * Describes a single strategy logic
11
- */
12
- export declare let rule: (name: string | undefined, describe: SessionHook) => void;
13
- /**
14
- *
15
- */
16
- export declare let beforeAll: (describe: SessionHook) => void;
17
- /**
18
- *
19
- * @param name
20
- * @param describe
21
- */
22
- export declare function describe(name: string, describe: () => Array<SessionFeature>): void;
23
- /**
24
- *
25
- * @param name
26
- * @param builder
27
- * @returns
28
- */
29
- export declare function spawn(name: string, builder: SessionBuilder): Promise<(session: Session) => Observable<any[]>>;
4
+ export * from './module';
5
+ export * from './use-memo';
6
+ export * from './use-timestamp';
7
+ export * from './simulator';
8
+ export * from './make-test-module';
9
+ export * from './core';
10
+ export * from './use-state';
11
+ export * from './replay/use-replay-coordinator';
12
+ export * from './use-execution-mode';
13
+ export * from './storage/use-storage';
14
+ export * from './storage/use-cache';
15
+ export * from './use-logger';
16
+ export * from './replay';
17
+ export * from './replay/use-replay-coordinator';
18
+ export * from './use-socket';
19
+ export * from './use-request';
20
+ export * from './defined';
21
+ export * from './as-readonly';
22
+ export * from './use';
23
+ export * from './session';
24
+ export * from './exclude';
25
+ export * from './use-lock';
26
+ export * from './strat';
27
+ export * from './not-found';
30
28
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAsB,UAAU,EAAiB,MAAM,MAAM,CAAC;AAErE,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,UAAU,CAAC;AACnE,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC;AACzB,cAAc,UAAU,CAAC;AACzB,cAAc,WAAW,CAAC;AAC1B,cAAc,SAAS,CAAC;AAMxB,oBAAY,WAAW,GAAG,CAAC,OAAO,EAAE,OAAO,KAAK,UAAU,CAAC,GAAG,CAAC,CAAC;AAEhE;;GAEG;AACH,eAAO,IAAI,IAAI,EAAE,CAAC,IAAI,EAAE,MAAM,GAAG,SAAS,EAAE,QAAQ,EAAE,WAAW,KAAK,IAAI,CAAC;AAE3E;;GAEG;AACH,eAAO,IAAI,SAAS,EAAE,CAAC,QAAQ,EAAE,WAAW,KAAK,IAAI,CAAC;AAEtD;;;;GAIG;AACH,wBAAgB,QAAQ,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,KAAK,CAAC,cAAc,CAAC,QAE3E;AAED;;;;;GAKG;AACH,wBAAsB,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,qBAyB9C,OAAO,wBAazB"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC;AAC/B,cAAc,aAAa,CAAC;AAC5B,cAAc,cAAc,CAAC;AAC7B,cAAc,aAAa,CAAC;AAC5B,cAAc,eAAe,CAAC;AAC9B,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,uBAAuB,CAAC;AACtC,cAAc,WAAW,CAAC;AAC1B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oCAAoC,CAAC;AACnD,cAAc,yBAAyB,CAAC;AACxC,cAAc,0BAA0B,CAAC;AACzC,cAAc,wBAAwB,CAAC;AACvC,cAAc,iBAAiB,CAAC;AAChC,cAAc,aAAa,CAAC;AAC5B,cAAc,oCAAoC,CAAC;AACnD,cAAc,iBAAiB,CAAC;AAChC,cAAc,kBAAkB,CAAC;AACjC,cAAc,cAAc,CAAC;AAC7B,cAAc,kBAAkB,CAAC;AACjC,cAAc,UAAU,CAAC;AACzB,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC;AAC9B,cAAc,YAAY,CAAC;AAC3B,cAAc,gBAAgB,CAAC"}
package/dist/index.js CHANGED
@@ -13,72 +13,31 @@ var __createBinding = (this && this.__createBinding) || (Object.create ? (functi
13
13
  var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
17
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
18
- return new (P || (P = Promise))(function (resolve, reject) {
19
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
20
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
21
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
22
- step((generator = generator.apply(thisArg, _arguments || [])).next());
23
- });
24
- };
25
- var __importDefault = (this && this.__importDefault) || function (mod) {
26
- return (mod && mod.__esModule) ? mod : { "default": mod };
27
- };
28
16
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.spawn = exports.describe = exports.beforeAll = exports.rule = void 0;
30
- const chalk_1 = __importDefault(require("chalk"));
31
- const rxjs_1 = require("rxjs");
32
- __exportStar(require("./adapter"), exports);
33
- __exportStar(require("./domain"), exports);
17
+ __exportStar(require("./component"), exports);
34
18
  __exportStar(require("./shared"), exports);
35
19
  __exportStar(require("./storage"), exports);
36
- __exportStar(require("./store"), exports);
37
- const shared_1 = require("./shared");
38
- const registry = {};
39
- /**
40
- *
41
- * @param name
42
- * @param describe
43
- */
44
- function describe(name, describe) {
45
- registry[name] = describe;
46
- }
47
- exports.describe = describe;
48
- /**
49
- *
50
- * @param name
51
- * @param builder
52
- * @returns
53
- */
54
- function spawn(name, builder) {
55
- return __awaiter(this, void 0, void 0, function* () {
56
- const describe = registry[name];
57
- if (!describe) {
58
- throw new Error(`missing strategy: ${name}`);
59
- }
60
- const ruleHooks = new Array();
61
- const beforeAllHooks = new Array();
62
- exports.beforeAll = (describe) => {
63
- beforeAllHooks.push(describe);
64
- };
65
- exports.rule = (ruleName, describe) => {
66
- if (ruleName) {
67
- shared_1.Logger.info(name, `${chalk_1.default.italic(ruleName)} rule found`);
68
- }
69
- ruleHooks.push(describe);
70
- };
71
- for (const feature of describe()) {
72
- feature(builder);
73
- }
74
- return (session) => {
75
- const beforeAll$ = beforeAllHooks.map(it => it(session));
76
- const rule$ = ruleHooks.map(it => it(session));
77
- if (!beforeAll$.length) {
78
- beforeAll$.push((0, rxjs_1.of)(true));
79
- }
80
- return (0, rxjs_1.forkJoin)(beforeAll$).pipe((0, rxjs_1.switchMap)(() => (0, rxjs_1.forkJoin)(rule$)), (0, rxjs_1.finalize)(() => session.dispose()));
81
- };
82
- });
83
- }
84
- exports.spawn = spawn;
20
+ __exportStar(require("./module"), exports);
21
+ __exportStar(require("./use-memo"), exports);
22
+ __exportStar(require("./use-timestamp"), exports);
23
+ __exportStar(require("./simulator"), exports);
24
+ __exportStar(require("./make-test-module"), exports);
25
+ __exportStar(require("./core"), exports);
26
+ __exportStar(require("./use-state"), exports);
27
+ __exportStar(require("./replay/use-replay-coordinator"), exports);
28
+ __exportStar(require("./use-execution-mode"), exports);
29
+ __exportStar(require("./storage/use-storage"), exports);
30
+ __exportStar(require("./storage/use-cache"), exports);
31
+ __exportStar(require("./use-logger"), exports);
32
+ __exportStar(require("./replay"), exports);
33
+ __exportStar(require("./replay/use-replay-coordinator"), exports);
34
+ __exportStar(require("./use-socket"), exports);
35
+ __exportStar(require("./use-request"), exports);
36
+ __exportStar(require("./defined"), exports);
37
+ __exportStar(require("./as-readonly"), exports);
38
+ __exportStar(require("./use"), exports);
39
+ __exportStar(require("./session"), exports);
40
+ __exportStar(require("./exclude"), exports);
41
+ __exportStar(require("./use-lock"), exports);
42
+ __exportStar(require("./strat"), exports);
43
+ __exportStar(require("./not-found"), exports);
@@ -1,4 +1,4 @@
1
- import { decimal } from '../shared';
1
+ import { decimal } from '../../shared';
2
2
  export declare class Commission {
3
3
  readonly makerRate: decimal;
4
4
  readonly takerRate: decimal;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commission.d.ts","sourceRoot":"","sources":["../../../src/instrument/commission/commission.ts"],"names":[],"mappings":"AAAA,OAAO,EAAK,OAAO,EAAE,MAAM,aAAa,CAAC;AAEzC,qBAAa,UAAU;IAGT,QAAQ,CAAC,SAAS,EAAE,OAAO;IAAE,QAAQ,CAAC,SAAS,EAAE,OAAO;IAFpE,MAAM,CAAC,QAAQ,CAAC,IAAI,aAAyD;gBAExD,SAAS,EAAE,OAAO,EAAW,SAAS,EAAE,OAAO;IAEpE,iBAAiB,CAAC,KAAK,EAAE,OAAO;IAIhC,iBAAiB,CAAC,KAAK,EAAE,OAAO;IAIhC,aAAa,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO;IAItC,aAAa,CAAC,KAAK,EAAE,OAAO,GAAG,OAAO;CAGvC;AAED,wBAAgB,mBAAmB,CAAC,IAAI,EAAE;IAAE,KAAK,EAAE,OAAO,CAAC;IAAC,KAAK,EAAE,OAAO,CAAA;CAAE,cAE3E"}
@@ -1,7 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.commissionPercentOf = exports.Commission = void 0;
4
- const shared_1 = require("../shared");
4
+ const shared_1 = require("../../shared");
5
5
  class Commission {
6
6
  constructor(makerRate, takerRate) {
7
7
  this.makerRate = makerRate;
@@ -20,8 +20,8 @@ class Commission {
20
20
  return value.minus(this.calculateTakerFee(value));
21
21
  }
22
22
  }
23
- exports.Commission = Commission;
24
23
  Commission.Zero = commissionPercentOf({ maker: shared_1.d.Zero, taker: shared_1.d.Zero });
24
+ exports.Commission = Commission;
25
25
  function commissionPercentOf(fees) {
26
26
  return new Commission(fees.maker.div(100.0), fees.taker.div(100.0));
27
27
  }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=commission.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"commission.spec.d.ts","sourceRoot":"","sources":["../../../src/instrument/commission/commission.spec.ts"],"names":[],"mappings":""}
@@ -0,0 +1,30 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const shared_1 = require("../../shared");
4
+ const commission_1 = require("./commission");
5
+ describe(commission_1.Commission.name, () => {
6
+ test('should construct a Commission', () => {
7
+ const sut = (0, commission_1.commissionPercentOf)({
8
+ maker: (0, shared_1.d)(0.1),
9
+ taker: (0, shared_1.d)(0.2)
10
+ });
11
+ expect(sut.makerRate).toEqual((0, shared_1.d)(0.001));
12
+ expect(sut.takerRate).toEqual((0, shared_1.d)(0.002));
13
+ });
14
+ test('should calculate a maker fee', () => {
15
+ const sut = (0, commission_1.commissionPercentOf)({
16
+ maker: (0, shared_1.d)(0.1),
17
+ taker: (0, shared_1.d)(0.2)
18
+ });
19
+ expect(sut.calculateMakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(2));
20
+ expect(sut.applyMakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(1998));
21
+ });
22
+ test('should calculate a taker fee', () => {
23
+ const sut = (0, commission_1.commissionPercentOf)({
24
+ maker: (0, shared_1.d)(0.1),
25
+ taker: (0, shared_1.d)(0.2)
26
+ });
27
+ expect(sut.calculateTakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(4));
28
+ expect(sut.applyTakerFee((0, shared_1.d)(2000))).toEqual((0, shared_1.d)(1996));
29
+ });
30
+ });
@@ -0,0 +1,3 @@
1
+ export * from '../instrument/instrument';
2
+ export * from '../instrument/commission/commission';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/instrument/index.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC;AAC3C,cAAc,uCAAuC,CAAC"}
@@ -14,7 +14,5 @@ var __exportStar = (this && this.__exportStar) || function(m, exports) {
14
14
  for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
15
15
  };
16
16
  Object.defineProperty(exports, "__esModule", { value: true });
17
- __exportStar(require("./adapter"), exports);
18
- __exportStar(require("./adapter-aggregate"), exports);
19
- __exportStar(require("./backtester"), exports);
20
- __exportStar(require("./paper"), exports);
17
+ __exportStar(require("../instrument/instrument"), exports);
18
+ __exportStar(require("../instrument/commission/commission"), exports);
@@ -1,17 +1,17 @@
1
- import { Asset, AssetSelector } from './asset';
2
- import { Commission } from './commission';
3
- import { Component } from './component';
1
+ import { Asset, AssetSelector } from '../asset';
2
+ import { Commission } from './commission/commission';
4
3
  export declare const InstrumentSelectorSeparator = "-";
5
4
  export declare class InstrumentSelector {
6
5
  readonly id: string;
7
6
  readonly base: AssetSelector;
8
7
  readonly quote: AssetSelector;
9
8
  constructor(base: string, quote: string, adapter: string);
9
+ toString(): string;
10
10
  }
11
11
  /**
12
12
  * Represents trading market which is made up by two trading assets (base and quoted).
13
13
  */
14
- export declare class Instrument extends InstrumentSelector implements Component {
14
+ export declare class Instrument extends InstrumentSelector {
15
15
  timestamp: number;
16
16
  readonly base: Asset;
17
17
  readonly quote: Asset;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instrument.d.ts","sourceRoot":"","sources":["../../src/instrument/instrument.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,aAAa,EAA0B,MAAM,YAAY,CAAC;AAG1E,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAErD,eAAO,MAAM,2BAA2B,MAAM,CAAC;AAE/C,qBAAa,kBAAkB;IAC7B,QAAQ,CAAC,EAAE,EAAE,MAAM,CAAC;IACpB,QAAQ,CAAC,IAAI,EAAE,aAAa,CAAC;IAC7B,QAAQ,CAAC,KAAK,EAAE,aAAa,CAAC;gBAElB,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM;IAOxD,QAAQ;CAGT;AAED;;GAEG;AACH,qBAAa,UAAW,SAAQ,kBAAkB;IAKvC,SAAS,EAAE,MAAM;aACN,IAAI,EAAE,KAAK;aACX,KAAK,EAAE,KAAK;IAC9B,QAAQ,CAAC,GAAG,EAAE,MAAM;IACb,UAAU,EAAE,UAAU;IAR/B,QAAQ,CAAC,KAAK,EAAE,UAAU,GAAG,SAAS,CAAC;IACvC,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAa;gBAGhC,SAAS,EAAE,MAAM,EACN,IAAI,EAAE,KAAK,EACX,KAAK,EAAE,KAAK,EACrB,GAAG,EAAE,MAAM,EACb,UAAU,EAAE,UAAU;CAQhC;AAED,wBAAgB,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,kBAAkB,CAYjE"}
@@ -1,8 +1,8 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.instrumentOf = exports.Instrument = exports.InstrumentSelector = exports.InstrumentSelectorSeparator = void 0;
4
- const asset_1 = require("./asset");
5
- const error_1 = require("./error");
4
+ const asset_1 = require("../asset");
5
+ const component_1 = require("../component");
6
6
  exports.InstrumentSelectorSeparator = '-';
7
7
  class InstrumentSelector {
8
8
  constructor(base, quote, adapter) {
@@ -10,6 +10,9 @@ class InstrumentSelector {
10
10
  this.quote = new asset_1.AssetSelector(quote.toLowerCase(), adapter.toLowerCase());
11
11
  this.id = `${this.base.id}${exports.InstrumentSelectorSeparator}${this.quote.name}`;
12
12
  }
13
+ toString() {
14
+ return this.id;
15
+ }
13
16
  }
14
17
  exports.InstrumentSelector = InstrumentSelector;
15
18
  /**
@@ -25,7 +28,7 @@ class Instrument extends InstrumentSelector {
25
28
  this.commission = commission;
26
29
  this.leverage = undefined;
27
30
  if (base.adapterName != quote.adapterName) {
28
- throw (0, error_1.adapterMismatchError)();
31
+ throw new component_1.AdapterMismatchError();
29
32
  }
30
33
  }
31
34
  }
@@ -33,11 +36,11 @@ exports.Instrument = Instrument;
33
36
  function instrumentOf(selector) {
34
37
  const [adapterName, asset, ...rest] = selector.split(asset_1.AssetSelectorSeparator);
35
38
  if (!adapterName || !asset || rest.length) {
36
- throw (0, error_1.invalidInstrumentSelectorError)(selector);
39
+ throw new component_1.InvalidInstrumentSelectorError(selector);
37
40
  }
38
41
  const [baseAssetName, quoteAssetName] = asset.split(exports.InstrumentSelectorSeparator);
39
42
  if (!baseAssetName || !quoteAssetName) {
40
- throw (0, error_1.invalidInstrumentSelectorError)(selector);
43
+ throw new component_1.InvalidInstrumentSelectorError(selector);
41
44
  }
42
45
  return new InstrumentSelector(baseAssetName, quoteAssetName, adapterName);
43
46
  }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=instrument.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instrument.spec.d.ts","sourceRoot":"","sources":["../../src/instrument/instrument.spec.ts"],"names":[],"mappings":""}