node-cqrs 1.0.0-rc.8 → 1.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 (841) hide show
  1. package/CHANGELOG.md +245 -119
  2. package/LICENSE +202 -21
  3. package/NOTICE +15 -0
  4. package/README.md +429 -113
  5. package/dist/cjs/AbstractAggregate.js +193 -0
  6. package/dist/cjs/AbstractAggregate.js.map +1 -0
  7. package/dist/cjs/AbstractProjection.js +165 -0
  8. package/dist/cjs/AbstractProjection.js.map +1 -0
  9. package/dist/cjs/AbstractSaga.js +109 -0
  10. package/dist/cjs/AbstractSaga.js.map +1 -0
  11. package/dist/cjs/AggregateCommandHandler.js +182 -0
  12. package/dist/cjs/AggregateCommandHandler.js.map +1 -0
  13. package/dist/cjs/CommandBus.js +9 -0
  14. package/dist/cjs/CommandBus.js.map +1 -0
  15. package/dist/cjs/CqrsContainerBuilder.js +97 -0
  16. package/dist/cjs/CqrsContainerBuilder.js.map +1 -0
  17. package/dist/cjs/Event.js +19 -0
  18. package/dist/cjs/Event.js.map +1 -0
  19. package/dist/cjs/EventDispatchPipeline.js +83 -0
  20. package/dist/cjs/EventDispatchPipeline.js.map +1 -0
  21. package/dist/cjs/EventDispatcher.js +93 -0
  22. package/dist/cjs/EventDispatcher.js.map +1 -0
  23. package/dist/cjs/EventIdAugmentor.js +30 -0
  24. package/dist/cjs/EventIdAugmentor.js.map +1 -0
  25. package/dist/cjs/EventStore.js +106 -0
  26. package/dist/cjs/EventStore.js.map +1 -0
  27. package/dist/cjs/SagaEventHandler.js +153 -0
  28. package/dist/cjs/SagaEventHandler.js.map +1 -0
  29. package/dist/cjs/errors/ConcurrencyError.js +21 -0
  30. package/dist/cjs/errors/ConcurrencyError.js.map +1 -0
  31. package/dist/cjs/errors/index.js +18 -0
  32. package/dist/cjs/errors/index.js.map +1 -0
  33. package/dist/cjs/in-memory/InMemoryEventStorage.js +106 -0
  34. package/dist/cjs/in-memory/InMemoryEventStorage.js.map +1 -0
  35. package/dist/cjs/in-memory/InMemoryLock.js +44 -0
  36. package/dist/cjs/in-memory/InMemoryLock.js.map +1 -0
  37. package/dist/cjs/in-memory/InMemoryMessageBus.js +93 -0
  38. package/dist/cjs/in-memory/InMemoryMessageBus.js.map +1 -0
  39. package/dist/cjs/in-memory/InMemorySnapshotStorage.js +101 -0
  40. package/dist/cjs/in-memory/InMemorySnapshotStorage.js.map +1 -0
  41. package/dist/cjs/in-memory/InMemoryView.js +154 -0
  42. package/dist/cjs/in-memory/InMemoryView.js.map +1 -0
  43. package/dist/cjs/in-memory/index.js +22 -0
  44. package/dist/cjs/in-memory/index.js.map +1 -0
  45. package/dist/cjs/in-memory/utils/index.js +18 -0
  46. package/dist/cjs/in-memory/utils/index.js.map +1 -0
  47. package/dist/cjs/in-memory/utils/nextCycle.js +9 -0
  48. package/dist/cjs/in-memory/utils/nextCycle.js.map +1 -0
  49. package/dist/cjs/index.js +58 -0
  50. package/dist/cjs/index.js.map +1 -0
  51. package/dist/cjs/interfaces/IAggregate.js.map +1 -0
  52. package/dist/cjs/interfaces/IAggregateSnapshotStorage.js +13 -0
  53. package/dist/cjs/interfaces/IAggregateSnapshotStorage.js.map +1 -0
  54. package/dist/cjs/interfaces/ICommand.js.map +1 -0
  55. package/dist/cjs/interfaces/ICommandBus.js.map +1 -0
  56. package/dist/cjs/interfaces/IContainer.js.map +1 -0
  57. package/dist/cjs/interfaces/IDispatchPipelineProcessor.js +9 -0
  58. package/dist/cjs/interfaces/IDispatchPipelineProcessor.js.map +1 -0
  59. package/dist/cjs/interfaces/IEvent.js +10 -0
  60. package/dist/cjs/interfaces/IEvent.js.map +1 -0
  61. package/dist/cjs/interfaces/IEventBus.js +9 -0
  62. package/dist/cjs/interfaces/IEventBus.js.map +1 -0
  63. package/dist/cjs/interfaces/IEventDispatcher.js.map +1 -0
  64. package/dist/cjs/interfaces/IEventLocker.js +15 -0
  65. package/dist/cjs/interfaces/IEventLocker.js.map +1 -0
  66. package/dist/cjs/interfaces/IEventReceptor.js.map +1 -0
  67. package/dist/cjs/interfaces/IEventSet.js +8 -0
  68. package/dist/cjs/interfaces/IEventSet.js.map +1 -0
  69. package/dist/cjs/interfaces/IEventStorageReader.js +13 -0
  70. package/dist/cjs/interfaces/IEventStorageReader.js.map +1 -0
  71. package/dist/cjs/interfaces/IEventStore.js.map +1 -0
  72. package/dist/cjs/interfaces/IEventStream.js.map +1 -0
  73. package/dist/cjs/interfaces/IIdentifierProvider.js +9 -0
  74. package/dist/cjs/interfaces/IIdentifierProvider.js.map +1 -0
  75. package/dist/cjs/interfaces/ILocker.js +9 -0
  76. package/dist/cjs/interfaces/ILocker.js.map +1 -0
  77. package/dist/cjs/interfaces/ILogger.js.map +1 -0
  78. package/dist/cjs/interfaces/IMessage.js +10 -0
  79. package/dist/cjs/interfaces/IMessage.js.map +1 -0
  80. package/dist/cjs/interfaces/IMutableState.js +3 -0
  81. package/dist/cjs/interfaces/IMutableState.js.map +1 -0
  82. package/dist/cjs/interfaces/IObjectStorage.js.map +1 -0
  83. package/dist/cjs/interfaces/IObservable.js +11 -0
  84. package/dist/cjs/interfaces/IObservable.js.map +1 -0
  85. package/dist/cjs/interfaces/IObservableQueueProvider.js +9 -0
  86. package/dist/cjs/interfaces/IObservableQueueProvider.js.map +1 -0
  87. package/dist/cjs/interfaces/IObserver.js.map +1 -0
  88. package/dist/cjs/interfaces/IProjection.js.map +1 -0
  89. package/dist/cjs/interfaces/ISaga.js.map +1 -0
  90. package/dist/cjs/interfaces/ISnapshotEvent.js +10 -0
  91. package/dist/cjs/interfaces/ISnapshotEvent.js.map +1 -0
  92. package/dist/cjs/interfaces/IViewLocker.js +21 -0
  93. package/dist/cjs/interfaces/IViewLocker.js.map +1 -0
  94. package/dist/cjs/interfaces/Identifier.js.map +1 -0
  95. package/dist/cjs/interfaces/index.js +46 -0
  96. package/dist/cjs/interfaces/index.js.map +1 -0
  97. package/dist/cjs/interfaces/isObject.js.map +1 -0
  98. package/dist/cjs/package.json +3 -0
  99. package/dist/cjs/rabbitmq/IContainer.js.map +1 -0
  100. package/dist/cjs/rabbitmq/RabbitMqCommandBus.js +84 -0
  101. package/dist/cjs/rabbitmq/RabbitMqCommandBus.js.map +1 -0
  102. package/dist/cjs/rabbitmq/RabbitMqEventBus.js +121 -0
  103. package/dist/cjs/rabbitmq/RabbitMqEventBus.js.map +1 -0
  104. package/dist/cjs/rabbitmq/RabbitMqGateway.js +578 -0
  105. package/dist/cjs/rabbitmq/RabbitMqGateway.js.map +1 -0
  106. package/dist/cjs/rabbitmq/index.js +21 -0
  107. package/dist/cjs/rabbitmq/index.js.map +1 -0
  108. package/dist/cjs/rabbitmq/utils/index.js +19 -0
  109. package/dist/cjs/rabbitmq/utils/index.js.map +1 -0
  110. package/dist/cjs/rabbitmq/utils/registerExitCleanup.js +28 -0
  111. package/dist/cjs/rabbitmq/utils/registerExitCleanup.js.map +1 -0
  112. package/dist/cjs/rabbitmq/utils/resolveProvider.js +9 -0
  113. package/dist/cjs/rabbitmq/utils/resolveProvider.js.map +1 -0
  114. package/dist/cjs/sqlite/AbstractSqliteAccessor.js +50 -0
  115. package/dist/cjs/sqlite/AbstractSqliteAccessor.js.map +1 -0
  116. package/dist/cjs/sqlite/AbstractSqliteObjectProjection.js +26 -0
  117. package/dist/cjs/sqlite/AbstractSqliteObjectProjection.js.map +1 -0
  118. package/dist/cjs/sqlite/AbstractSqliteView.js +50 -0
  119. package/dist/cjs/sqlite/AbstractSqliteView.js.map +1 -0
  120. package/dist/cjs/sqlite/IContainer.js.map +1 -0
  121. package/dist/cjs/sqlite/SqliteEventLocker.js +93 -0
  122. package/dist/cjs/sqlite/SqliteEventLocker.js.map +1 -0
  123. package/dist/cjs/sqlite/SqliteObjectStorage.js +114 -0
  124. package/dist/cjs/sqlite/SqliteObjectStorage.js.map +1 -0
  125. package/dist/cjs/sqlite/SqliteObjectView.js +48 -0
  126. package/dist/cjs/sqlite/SqliteObjectView.js.map +1 -0
  127. package/dist/cjs/sqlite/SqliteProjectionDataParams.js.map +1 -0
  128. package/dist/cjs/sqlite/SqliteViewLocker.js +119 -0
  129. package/dist/cjs/sqlite/SqliteViewLocker.js.map +1 -0
  130. package/dist/cjs/sqlite/index.js +26 -0
  131. package/dist/cjs/sqlite/index.js.map +1 -0
  132. package/dist/cjs/sqlite/queries/eventLockTableInit.js +15 -0
  133. package/dist/cjs/sqlite/queries/eventLockTableInit.js.map +1 -0
  134. package/dist/cjs/sqlite/queries/index.js +19 -0
  135. package/dist/cjs/sqlite/queries/index.js.map +1 -0
  136. package/dist/cjs/sqlite/queries/viewLockTableInit.js.map +1 -0
  137. package/dist/cjs/sqlite/utils/getEventId.js +14 -0
  138. package/dist/cjs/sqlite/utils/getEventId.js.map +1 -0
  139. package/dist/cjs/sqlite/utils/guid.js.map +1 -0
  140. package/dist/cjs/sqlite/utils/index.js +19 -0
  141. package/dist/cjs/sqlite/utils/index.js.map +1 -0
  142. package/dist/cjs/utils/Deferred.js.map +1 -0
  143. package/dist/cjs/utils/Lock.js +102 -0
  144. package/dist/cjs/utils/Lock.js.map +1 -0
  145. package/dist/cjs/utils/MapAssertable.js +30 -0
  146. package/dist/cjs/utils/MapAssertable.js.map +1 -0
  147. package/dist/cjs/utils/assert.js +88 -0
  148. package/dist/cjs/utils/assert.js.map +1 -0
  149. package/dist/cjs/utils/clone.js +13 -0
  150. package/dist/cjs/utils/clone.js.map +1 -0
  151. package/dist/cjs/utils/extractErrorDetails.js +37 -0
  152. package/dist/cjs/utils/extractErrorDetails.js.map +1 -0
  153. package/dist/cjs/utils/getClassName.js.map +1 -0
  154. package/dist/cjs/utils/getHandler.js +18 -0
  155. package/dist/cjs/utils/getHandler.js.map +1 -0
  156. package/dist/cjs/utils/getMessageHandlerNames.js +30 -0
  157. package/dist/cjs/utils/getMessageHandlerNames.js.map +1 -0
  158. package/dist/cjs/utils/index.js +31 -0
  159. package/dist/cjs/utils/index.js.map +1 -0
  160. package/dist/cjs/utils/isClass.js.map +1 -0
  161. package/dist/cjs/utils/sagaId.js +23 -0
  162. package/dist/cjs/utils/sagaId.js.map +1 -0
  163. package/dist/cjs/utils/setupOneTimeEmitterSubscription.js +45 -0
  164. package/dist/cjs/utils/setupOneTimeEmitterSubscription.js.map +1 -0
  165. package/dist/cjs/utils/subscribe.js +43 -0
  166. package/dist/cjs/utils/subscribe.js.map +1 -0
  167. package/dist/cjs/utils/validateHandlers.js +21 -0
  168. package/dist/cjs/utils/validateHandlers.js.map +1 -0
  169. package/dist/cjs/workers/AbstractWorkerProjection.js +56 -0
  170. package/dist/cjs/workers/AbstractWorkerProjection.js.map +1 -0
  171. package/dist/cjs/workers/WorkerProxyProjection.js +142 -0
  172. package/dist/cjs/workers/WorkerProxyProjection.js.map +1 -0
  173. package/dist/cjs/workers/index.js +20 -0
  174. package/dist/cjs/workers/index.js.map +1 -0
  175. package/dist/cjs/workers/interfaces/IProxyProjection.js +3 -0
  176. package/dist/cjs/workers/interfaces/IProxyProjection.js.map +1 -0
  177. package/dist/cjs/workers/interfaces/IWorkerProjection.js +3 -0
  178. package/dist/cjs/workers/interfaces/IWorkerProjection.js.map +1 -0
  179. package/dist/cjs/workers/interfaces/index.js +3 -0
  180. package/dist/cjs/workers/interfaces/index.js.map +1 -0
  181. package/dist/cjs/workers/protocol.js +16 -0
  182. package/dist/cjs/workers/protocol.js.map +1 -0
  183. package/dist/cjs/workers/utils/ProjectionView.js +3 -0
  184. package/dist/cjs/workers/utils/ProjectionView.js.map +1 -0
  185. package/dist/cjs/workers/utils/createWorker.js +87 -0
  186. package/dist/cjs/workers/utils/createWorker.js.map +1 -0
  187. package/dist/cjs/workers/utils/createWorkerInstance.js +59 -0
  188. package/dist/cjs/workers/utils/createWorkerInstance.js.map +1 -0
  189. package/dist/cjs/workers/utils/index.js +21 -0
  190. package/dist/cjs/workers/utils/index.js.map +1 -0
  191. package/dist/cjs/workers/utils/nodeEndpoint.js +8 -0
  192. package/dist/cjs/workers/utils/nodeEndpoint.js.map +1 -0
  193. package/dist/cjs/workers/utils/workerProxyFactory.js +21 -0
  194. package/dist/cjs/workers/utils/workerProxyFactory.js.map +1 -0
  195. package/dist/esm/AbstractAggregate.js +189 -0
  196. package/dist/esm/AbstractAggregate.js.map +1 -0
  197. package/dist/esm/AbstractProjection.js +161 -0
  198. package/dist/esm/AbstractProjection.js.map +1 -0
  199. package/dist/esm/AbstractSaga.js +105 -0
  200. package/dist/esm/AbstractSaga.js.map +1 -0
  201. package/dist/esm/AggregateCommandHandler.js +178 -0
  202. package/dist/esm/AggregateCommandHandler.js.map +1 -0
  203. package/dist/esm/CommandBus.js +5 -0
  204. package/dist/esm/CommandBus.js.map +1 -0
  205. package/dist/esm/CqrsContainerBuilder.js +93 -0
  206. package/dist/esm/CqrsContainerBuilder.js.map +1 -0
  207. package/dist/esm/Event.js +15 -0
  208. package/dist/esm/Event.js.map +1 -0
  209. package/dist/esm/EventDispatchPipeline.js +79 -0
  210. package/dist/esm/EventDispatchPipeline.js.map +1 -0
  211. package/dist/esm/EventDispatcher.js +89 -0
  212. package/dist/esm/EventDispatcher.js.map +1 -0
  213. package/dist/esm/EventIdAugmentor.js +26 -0
  214. package/dist/esm/EventIdAugmentor.js.map +1 -0
  215. package/dist/esm/EventStore.js +102 -0
  216. package/dist/esm/EventStore.js.map +1 -0
  217. package/dist/esm/SagaEventHandler.js +116 -0
  218. package/dist/esm/SagaEventHandler.js.map +1 -0
  219. package/dist/esm/errors/ConcurrencyError.js +17 -0
  220. package/dist/esm/errors/ConcurrencyError.js.map +1 -0
  221. package/dist/esm/errors/index.js +2 -0
  222. package/dist/esm/errors/index.js.map +1 -0
  223. package/dist/esm/in-memory/InMemoryEventStorage.js +102 -0
  224. package/dist/esm/in-memory/InMemoryEventStorage.js.map +1 -0
  225. package/dist/esm/in-memory/InMemoryLock.js +40 -0
  226. package/dist/esm/in-memory/InMemoryLock.js.map +1 -0
  227. package/dist/esm/in-memory/InMemoryMessageBus.js +89 -0
  228. package/dist/esm/in-memory/InMemoryMessageBus.js.map +1 -0
  229. package/dist/esm/in-memory/InMemorySnapshotStorage.js +64 -0
  230. package/dist/esm/in-memory/InMemorySnapshotStorage.js.map +1 -0
  231. package/dist/esm/in-memory/InMemoryView.js +150 -0
  232. package/dist/esm/in-memory/InMemoryView.js.map +1 -0
  233. package/dist/esm/in-memory/index.js +6 -0
  234. package/dist/esm/in-memory/index.js.map +1 -0
  235. package/dist/esm/in-memory/utils/index.js +2 -0
  236. package/dist/esm/in-memory/utils/index.js.map +1 -0
  237. package/dist/esm/in-memory/utils/nextCycle.js +5 -0
  238. package/dist/esm/in-memory/utils/nextCycle.js.map +1 -0
  239. package/dist/esm/index.js +16 -0
  240. package/dist/esm/index.js.map +1 -0
  241. package/dist/esm/interfaces/IAggregate.js +2 -0
  242. package/dist/esm/interfaces/IAggregate.js.map +1 -0
  243. package/dist/esm/interfaces/IAggregateSnapshotStorage.js +9 -0
  244. package/dist/esm/interfaces/IAggregateSnapshotStorage.js.map +1 -0
  245. package/dist/esm/interfaces/ICommand.js +2 -0
  246. package/dist/esm/interfaces/ICommand.js.map +1 -0
  247. package/dist/esm/interfaces/ICommandBus.js +2 -0
  248. package/dist/esm/interfaces/ICommandBus.js.map +1 -0
  249. package/dist/esm/interfaces/IContainer.js +2 -0
  250. package/dist/esm/interfaces/IContainer.js.map +1 -0
  251. package/dist/esm/interfaces/IDispatchPipelineProcessor.js +5 -0
  252. package/dist/esm/interfaces/IDispatchPipelineProcessor.js.map +1 -0
  253. package/dist/esm/interfaces/IEvent.js +6 -0
  254. package/dist/esm/interfaces/IEvent.js.map +1 -0
  255. package/dist/esm/interfaces/IEventBus.js +5 -0
  256. package/dist/esm/interfaces/IEventBus.js.map +1 -0
  257. package/dist/esm/interfaces/IEventDispatcher.js +2 -0
  258. package/dist/esm/interfaces/IEventDispatcher.js.map +1 -0
  259. package/dist/esm/interfaces/IEventLocker.js +11 -0
  260. package/dist/esm/interfaces/IEventLocker.js.map +1 -0
  261. package/dist/esm/interfaces/IEventReceptor.js +2 -0
  262. package/dist/esm/interfaces/IEventReceptor.js.map +1 -0
  263. package/dist/esm/interfaces/IEventSet.js +4 -0
  264. package/dist/esm/interfaces/IEventSet.js.map +1 -0
  265. package/dist/esm/interfaces/IEventStorageReader.js +9 -0
  266. package/dist/esm/interfaces/IEventStorageReader.js.map +1 -0
  267. package/dist/esm/interfaces/IEventStore.js +2 -0
  268. package/dist/esm/interfaces/IEventStore.js.map +1 -0
  269. package/dist/esm/interfaces/IEventStream.js +2 -0
  270. package/dist/esm/interfaces/IEventStream.js.map +1 -0
  271. package/dist/esm/interfaces/IIdentifierProvider.js +5 -0
  272. package/dist/esm/interfaces/IIdentifierProvider.js.map +1 -0
  273. package/dist/esm/interfaces/ILocker.js +5 -0
  274. package/dist/esm/interfaces/ILocker.js.map +1 -0
  275. package/dist/esm/interfaces/ILogger.js +2 -0
  276. package/dist/esm/interfaces/ILogger.js.map +1 -0
  277. package/dist/esm/interfaces/IMessage.js +6 -0
  278. package/dist/esm/interfaces/IMessage.js.map +1 -0
  279. package/dist/esm/interfaces/IMutableState.js +2 -0
  280. package/dist/esm/interfaces/IMutableState.js.map +1 -0
  281. package/dist/esm/interfaces/IObjectStorage.js +2 -0
  282. package/dist/esm/interfaces/IObjectStorage.js.map +1 -0
  283. package/dist/esm/interfaces/IObservable.js +7 -0
  284. package/dist/esm/interfaces/IObservable.js.map +1 -0
  285. package/dist/esm/interfaces/IObservableQueueProvider.js +5 -0
  286. package/dist/esm/interfaces/IObservableQueueProvider.js.map +1 -0
  287. package/dist/esm/interfaces/IObserver.js +2 -0
  288. package/dist/esm/interfaces/IObserver.js.map +1 -0
  289. package/dist/esm/interfaces/IProjection.js +2 -0
  290. package/dist/esm/interfaces/IProjection.js.map +1 -0
  291. package/dist/esm/interfaces/ISaga.js +2 -0
  292. package/dist/esm/interfaces/ISaga.js.map +1 -0
  293. package/dist/esm/interfaces/ISnapshotEvent.js +6 -0
  294. package/dist/esm/interfaces/ISnapshotEvent.js.map +1 -0
  295. package/dist/esm/interfaces/IViewLocker.js +17 -0
  296. package/dist/esm/interfaces/IViewLocker.js.map +1 -0
  297. package/dist/esm/interfaces/Identifier.js +2 -0
  298. package/dist/esm/interfaces/Identifier.js.map +1 -0
  299. package/dist/esm/interfaces/index.js +30 -0
  300. package/dist/esm/interfaces/index.js.map +1 -0
  301. package/dist/esm/interfaces/isObject.js +5 -0
  302. package/dist/esm/interfaces/isObject.js.map +1 -0
  303. package/dist/esm/rabbitmq/IContainer.js +2 -0
  304. package/dist/esm/rabbitmq/IContainer.js.map +1 -0
  305. package/dist/esm/rabbitmq/RabbitMqCommandBus.js +80 -0
  306. package/dist/esm/rabbitmq/RabbitMqCommandBus.js.map +1 -0
  307. package/dist/esm/rabbitmq/RabbitMqEventBus.js +117 -0
  308. package/dist/esm/rabbitmq/RabbitMqEventBus.js.map +1 -0
  309. package/dist/esm/rabbitmq/RabbitMqGateway.js +541 -0
  310. package/dist/esm/rabbitmq/RabbitMqGateway.js.map +1 -0
  311. package/dist/esm/rabbitmq/index.js +5 -0
  312. package/dist/esm/rabbitmq/index.js.map +1 -0
  313. package/dist/esm/rabbitmq/utils/index.js +3 -0
  314. package/dist/esm/rabbitmq/utils/index.js.map +1 -0
  315. package/dist/esm/rabbitmq/utils/registerExitCleanup.js +24 -0
  316. package/dist/esm/rabbitmq/utils/registerExitCleanup.js.map +1 -0
  317. package/dist/esm/rabbitmq/utils/resolveProvider.js +6 -0
  318. package/dist/esm/rabbitmq/utils/resolveProvider.js.map +1 -0
  319. package/dist/esm/sqlite/AbstractSqliteAccessor.js +46 -0
  320. package/dist/esm/sqlite/AbstractSqliteAccessor.js.map +1 -0
  321. package/dist/esm/sqlite/AbstractSqliteObjectProjection.js +22 -0
  322. package/dist/esm/sqlite/AbstractSqliteObjectProjection.js.map +1 -0
  323. package/dist/esm/sqlite/AbstractSqliteView.js +46 -0
  324. package/dist/esm/sqlite/AbstractSqliteView.js.map +1 -0
  325. package/dist/esm/sqlite/IContainer.js +2 -0
  326. package/dist/esm/sqlite/IContainer.js.map +1 -0
  327. package/dist/esm/sqlite/SqliteEventLocker.js +89 -0
  328. package/dist/esm/sqlite/SqliteEventLocker.js.map +1 -0
  329. package/dist/esm/sqlite/SqliteObjectStorage.js +110 -0
  330. package/dist/esm/sqlite/SqliteObjectStorage.js.map +1 -0
  331. package/dist/esm/sqlite/SqliteObjectView.js +44 -0
  332. package/dist/esm/sqlite/SqliteObjectView.js.map +1 -0
  333. package/dist/esm/sqlite/SqliteProjectionDataParams.js +2 -0
  334. package/dist/esm/sqlite/SqliteProjectionDataParams.js.map +1 -0
  335. package/dist/esm/sqlite/SqliteViewLocker.js +115 -0
  336. package/dist/esm/sqlite/SqliteViewLocker.js.map +1 -0
  337. package/dist/esm/sqlite/index.js +10 -0
  338. package/dist/esm/sqlite/index.js.map +1 -0
  339. package/dist/esm/sqlite/queries/eventLockTableInit.js +11 -0
  340. package/dist/esm/sqlite/queries/eventLockTableInit.js.map +1 -0
  341. package/dist/esm/sqlite/queries/index.js +3 -0
  342. package/dist/esm/sqlite/queries/index.js.map +1 -0
  343. package/dist/esm/sqlite/queries/viewLockTableInit.js +10 -0
  344. package/dist/esm/sqlite/queries/viewLockTableInit.js.map +1 -0
  345. package/dist/esm/sqlite/utils/getEventId.js +7 -0
  346. package/dist/esm/sqlite/utils/getEventId.js.map +1 -0
  347. package/dist/esm/sqlite/utils/guid.js +5 -0
  348. package/dist/esm/sqlite/utils/guid.js.map +1 -0
  349. package/dist/esm/sqlite/utils/index.js +3 -0
  350. package/dist/esm/sqlite/utils/index.js.map +1 -0
  351. package/dist/esm/utils/Deferred.js +34 -0
  352. package/dist/esm/utils/Deferred.js.map +1 -0
  353. package/dist/esm/utils/Lock.js +97 -0
  354. package/dist/esm/utils/Lock.js.map +1 -0
  355. package/dist/esm/utils/MapAssertable.js +26 -0
  356. package/dist/esm/utils/MapAssertable.js.map +1 -0
  357. package/dist/esm/utils/assert.js +70 -0
  358. package/dist/esm/utils/assert.js.map +1 -0
  359. package/dist/esm/utils/clone.js +10 -0
  360. package/dist/esm/utils/clone.js.map +1 -0
  361. package/dist/esm/utils/extractErrorDetails.js +33 -0
  362. package/dist/esm/utils/extractErrorDetails.js.map +1 -0
  363. package/dist/esm/utils/getClassName.js +7 -0
  364. package/dist/esm/utils/getClassName.js.map +1 -0
  365. package/dist/esm/utils/getHandler.js +15 -0
  366. package/dist/esm/utils/getHandler.js.map +1 -0
  367. package/dist/esm/utils/getMessageHandlerNames.js +27 -0
  368. package/dist/esm/utils/getMessageHandlerNames.js.map +1 -0
  369. package/dist/esm/utils/index.js +15 -0
  370. package/dist/esm/utils/index.js.map +1 -0
  371. package/dist/esm/utils/isClass.js +5 -0
  372. package/dist/esm/utils/isClass.js.map +1 -0
  373. package/dist/esm/utils/sagaId.js +18 -0
  374. package/dist/esm/utils/sagaId.js.map +1 -0
  375. package/dist/esm/utils/setupOneTimeEmitterSubscription.js +42 -0
  376. package/dist/esm/utils/setupOneTimeEmitterSubscription.js.map +1 -0
  377. package/dist/esm/utils/subscribe.js +40 -0
  378. package/dist/esm/utils/subscribe.js.map +1 -0
  379. package/dist/esm/utils/validateHandlers.js +18 -0
  380. package/dist/esm/utils/validateHandlers.js.map +1 -0
  381. package/dist/esm/workers/AbstractWorkerProjection.js +52 -0
  382. package/dist/esm/workers/AbstractWorkerProjection.js.map +1 -0
  383. package/dist/esm/workers/WorkerProxyProjection.js +105 -0
  384. package/dist/esm/workers/WorkerProxyProjection.js.map +1 -0
  385. package/dist/esm/workers/index.js +4 -0
  386. package/dist/esm/workers/index.js.map +1 -0
  387. package/dist/esm/workers/interfaces/IProxyProjection.js +2 -0
  388. package/dist/esm/workers/interfaces/IProxyProjection.js.map +1 -0
  389. package/dist/esm/workers/interfaces/IWorkerProjection.js +2 -0
  390. package/dist/esm/workers/interfaces/IWorkerProjection.js.map +1 -0
  391. package/dist/esm/workers/interfaces/index.js +2 -0
  392. package/dist/esm/workers/interfaces/index.js.map +1 -0
  393. package/dist/esm/workers/protocol.js +11 -0
  394. package/dist/esm/workers/protocol.js.map +1 -0
  395. package/dist/esm/workers/utils/ProjectionView.js +2 -0
  396. package/dist/esm/workers/utils/ProjectionView.js.map +1 -0
  397. package/dist/esm/workers/utils/createWorker.js +51 -0
  398. package/dist/esm/workers/utils/createWorker.js.map +1 -0
  399. package/dist/esm/workers/utils/createWorkerInstance.js +23 -0
  400. package/dist/esm/workers/utils/createWorkerInstance.js.map +1 -0
  401. package/dist/esm/workers/utils/index.js +5 -0
  402. package/dist/esm/workers/utils/index.js.map +1 -0
  403. package/dist/esm/workers/utils/nodeEndpoint.js +5 -0
  404. package/dist/esm/workers/utils/nodeEndpoint.js.map +1 -0
  405. package/dist/esm/workers/utils/workerProxyFactory.js +18 -0
  406. package/dist/esm/workers/utils/workerProxyFactory.js.map +1 -0
  407. package/dist/types/AbstractAggregate.d.ts +80 -0
  408. package/dist/types/AbstractProjection.d.ts +77 -0
  409. package/dist/types/AbstractSaga.d.ts +42 -0
  410. package/dist/types/AggregateCommandHandler.d.ts +22 -0
  411. package/dist/types/CommandBus.d.ts +4 -0
  412. package/dist/types/CqrsContainerBuilder.d.ts +21 -0
  413. package/dist/types/Event.d.ts +9 -0
  414. package/dist/types/EventDispatchPipeline.d.ts +16 -0
  415. package/dist/types/EventDispatcher.d.ts +39 -0
  416. package/dist/types/EventIdAugmentor.d.ts +12 -0
  417. package/dist/types/EventStore.d.ts +29 -0
  418. package/dist/types/SagaEventHandler.d.ts +22 -0
  419. package/dist/types/errors/ConcurrencyError.d.ts +9 -0
  420. package/dist/types/errors/index.d.ts +1 -0
  421. package/dist/types/in-memory/InMemoryEventStorage.d.ts +24 -0
  422. package/dist/types/in-memory/InMemoryLock.d.ts +23 -0
  423. package/dist/types/in-memory/InMemoryMessageBus.d.ts +45 -0
  424. package/dist/types/in-memory/InMemorySnapshotStorage.d.ts +37 -0
  425. package/dist/types/in-memory/InMemoryView.d.ts +53 -0
  426. package/dist/types/in-memory/index.d.ts +5 -0
  427. package/dist/types/in-memory/utils/index.d.ts +1 -0
  428. package/dist/types/index.d.ts +15 -0
  429. package/dist/types/interfaces/IAggregate.d.ts +78 -0
  430. package/dist/types/interfaces/IAggregateSnapshotStorage.d.ts +8 -0
  431. package/dist/types/interfaces/ICommand.d.ts +2 -0
  432. package/dist/types/interfaces/ICommandBus.d.ts +15 -0
  433. package/dist/types/interfaces/IContainer.d.ts +37 -0
  434. package/dist/types/interfaces/IDispatchPipelineProcessor.d.ts +29 -0
  435. package/dist/types/interfaces/IEvent.d.ts +7 -0
  436. package/dist/types/interfaces/IEventBus.d.ts +6 -0
  437. package/dist/types/interfaces/IEventDispatcher.d.ts +6 -0
  438. package/dist/types/interfaces/IEventLocker.d.ts +28 -0
  439. package/dist/types/interfaces/IEventReceptor.d.ts +5 -0
  440. package/dist/types/interfaces/IEventSet.d.ts +3 -0
  441. package/dist/types/interfaces/IEventStorageReader.d.ts +48 -0
  442. package/dist/types/interfaces/IEventStore.d.ts +9 -0
  443. package/dist/types/interfaces/IEventStream.d.ts +2 -0
  444. package/dist/types/interfaces/IIdentifierProvider.d.ts +10 -0
  445. package/dist/types/interfaces/ILocker.d.ts +8 -0
  446. package/dist/types/interfaces/IMessage.d.ts +23 -0
  447. package/dist/types/interfaces/IMutableState.d.ts +14 -0
  448. package/dist/types/interfaces/IObjectStorage.d.ts +8 -0
  449. package/dist/types/interfaces/IObservable.d.ts +15 -0
  450. package/dist/types/interfaces/IObservableQueueProvider.d.ts +8 -0
  451. package/dist/types/interfaces/IObserver.d.ts +4 -0
  452. package/dist/types/interfaces/IProjection.d.ts +17 -0
  453. package/dist/types/interfaces/ISaga.d.ts +38 -0
  454. package/dist/types/interfaces/ISnapshotEvent.d.ts +7 -0
  455. package/dist/types/interfaces/Identifier.d.ts +1 -0
  456. package/dist/types/interfaces/index.d.ts +29 -0
  457. package/dist/types/interfaces/isObject.d.ts +1 -0
  458. package/dist/types/rabbitmq/IContainer.d.ts +19 -0
  459. package/dist/types/rabbitmq/RabbitMqCommandBus.d.ts +38 -0
  460. package/dist/types/rabbitmq/RabbitMqEventBus.d.ts +44 -0
  461. package/dist/types/rabbitmq/RabbitMqGateway.d.ts +133 -0
  462. package/dist/types/rabbitmq/index.d.ts +4 -0
  463. package/dist/types/rabbitmq/utils/index.d.ts +2 -0
  464. package/dist/types/rabbitmq/utils/registerExitCleanup.d.ts +10 -0
  465. package/dist/types/rabbitmq/utils/resolveProvider.d.ts +3 -0
  466. package/dist/types/sqlite/AbstractSqliteAccessor.d.ts +25 -0
  467. package/dist/types/sqlite/AbstractSqliteObjectProjection.d.ts +8 -0
  468. package/dist/types/sqlite/AbstractSqliteView.d.ts +23 -0
  469. package/dist/types/sqlite/IContainer.d.ts +7 -0
  470. package/dist/types/sqlite/SqliteEventLocker.d.ts +30 -0
  471. package/dist/types/sqlite/SqliteObjectStorage.d.ts +17 -0
  472. package/dist/types/sqlite/SqliteObjectView.d.ts +19 -0
  473. package/dist/types/sqlite/SqliteViewLocker.d.ts +31 -0
  474. package/dist/types/sqlite/index.d.ts +9 -0
  475. package/dist/types/sqlite/queries/index.d.ts +2 -0
  476. package/dist/types/sqlite/utils/getEventId.d.ts +5 -0
  477. package/dist/types/sqlite/utils/index.d.ts +2 -0
  478. package/dist/types/utils/Lock.d.ts +30 -0
  479. package/dist/types/utils/MapAssertable.d.ts +11 -0
  480. package/dist/types/utils/assert.d.ts +20 -0
  481. package/dist/types/utils/clone.d.ts +1 -0
  482. package/dist/types/utils/extractErrorDetails.d.ts +8 -0
  483. package/dist/types/utils/getHandler.d.ts +7 -0
  484. package/dist/types/utils/getMessageHandlerNames.d.ts +12 -0
  485. package/dist/types/utils/index.d.ts +14 -0
  486. package/dist/types/utils/isClass.d.ts +1 -0
  487. package/dist/types/utils/sagaId.d.ts +6 -0
  488. package/dist/types/utils/setupOneTimeEmitterSubscription.d.ts +12 -0
  489. package/dist/types/utils/subscribe.d.ts +9 -0
  490. package/dist/types/workers/AbstractWorkerProjection.d.ts +25 -0
  491. package/dist/types/workers/WorkerProxyProjection.d.ts +25 -0
  492. package/dist/types/workers/index.d.ts +3 -0
  493. package/dist/types/workers/interfaces/IProxyProjection.d.ts +15 -0
  494. package/dist/types/workers/interfaces/IWorkerProjection.d.ts +19 -0
  495. package/dist/types/workers/interfaces/index.d.ts +2 -0
  496. package/dist/types/workers/protocol.d.ts +10 -0
  497. package/dist/types/workers/utils/ProjectionView.d.ts +2 -0
  498. package/dist/types/workers/utils/createWorker.d.ts +10 -0
  499. package/dist/types/workers/utils/createWorkerInstance.d.ts +11 -0
  500. package/dist/types/workers/utils/index.d.ts +5 -0
  501. package/dist/types/workers/utils/nodeEndpoint.d.ts +2 -0
  502. package/dist/types/workers/utils/workerProxyFactory.d.ts +14 -0
  503. package/package.json +106 -54
  504. package/dist/AbstractAggregate.js +0 -178
  505. package/dist/AbstractAggregate.js.map +0 -1
  506. package/dist/AbstractProjection.js +0 -138
  507. package/dist/AbstractProjection.js.map +0 -1
  508. package/dist/AbstractSaga.js +0 -99
  509. package/dist/AbstractSaga.js.map +0 -1
  510. package/dist/AggregateCommandHandler.js +0 -86
  511. package/dist/AggregateCommandHandler.js.map +0 -1
  512. package/dist/CommandBus.js +0 -74
  513. package/dist/CommandBus.js.map +0 -1
  514. package/dist/CqrsContainerBuilder.js +0 -92
  515. package/dist/CqrsContainerBuilder.js.map +0 -1
  516. package/dist/Event.js +0 -33
  517. package/dist/Event.js.map +0 -1
  518. package/dist/EventDispatcher.js +0 -125
  519. package/dist/EventDispatcher.js.map +0 -1
  520. package/dist/EventStore.js +0 -137
  521. package/dist/EventStore.js.map +0 -1
  522. package/dist/EventValidationProcessor.js +0 -29
  523. package/dist/EventValidationProcessor.js.map +0 -1
  524. package/dist/SagaEventHandler.js +0 -118
  525. package/dist/SagaEventHandler.js.map +0 -1
  526. package/dist/in-memory/InMemoryEventStorage.js +0 -73
  527. package/dist/in-memory/InMemoryEventStorage.js.map +0 -1
  528. package/dist/in-memory/InMemoryLock.js +0 -40
  529. package/dist/in-memory/InMemoryLock.js.map +0 -1
  530. package/dist/in-memory/InMemoryMessageBus.js +0 -111
  531. package/dist/in-memory/InMemoryMessageBus.js.map +0 -1
  532. package/dist/in-memory/InMemorySnapshotStorage.js +0 -70
  533. package/dist/in-memory/InMemorySnapshotStorage.js.map +0 -1
  534. package/dist/in-memory/InMemoryView.js +0 -167
  535. package/dist/in-memory/InMemoryView.js.map +0 -1
  536. package/dist/in-memory/index.js +0 -22
  537. package/dist/in-memory/index.js.map +0 -1
  538. package/dist/in-memory/utils/index.js +0 -18
  539. package/dist/in-memory/utils/index.js.map +0 -1
  540. package/dist/in-memory/utils/nextCycle.js +0 -9
  541. package/dist/in-memory/utils/nextCycle.js.map +0 -1
  542. package/dist/index.js +0 -35
  543. package/dist/index.js.map +0 -1
  544. package/dist/interfaces/IAggregate.js.map +0 -1
  545. package/dist/interfaces/IAggregateSnapshotStorage.js +0 -3
  546. package/dist/interfaces/IAggregateSnapshotStorage.js.map +0 -1
  547. package/dist/interfaces/ICommand.js.map +0 -1
  548. package/dist/interfaces/ICommandBus.js.map +0 -1
  549. package/dist/interfaces/IContainer.js.map +0 -1
  550. package/dist/interfaces/IDispatchPipelineProcessor.js +0 -9
  551. package/dist/interfaces/IDispatchPipelineProcessor.js.map +0 -1
  552. package/dist/interfaces/IEvent.js +0 -9
  553. package/dist/interfaces/IEvent.js.map +0 -1
  554. package/dist/interfaces/IEventBus.js +0 -9
  555. package/dist/interfaces/IEventBus.js.map +0 -1
  556. package/dist/interfaces/IEventDispatcher.js.map +0 -1
  557. package/dist/interfaces/IEventLocker.js +0 -10
  558. package/dist/interfaces/IEventLocker.js.map +0 -1
  559. package/dist/interfaces/IEventReceptor.js.map +0 -1
  560. package/dist/interfaces/IEventSet.js +0 -8
  561. package/dist/interfaces/IEventSet.js.map +0 -1
  562. package/dist/interfaces/IEventStorage.js +0 -13
  563. package/dist/interfaces/IEventStorage.js.map +0 -1
  564. package/dist/interfaces/IEventStore.js.map +0 -1
  565. package/dist/interfaces/IEventStream.js.map +0 -1
  566. package/dist/interfaces/IIdentifierProvider.js +0 -9
  567. package/dist/interfaces/IIdentifierProvider.js.map +0 -1
  568. package/dist/interfaces/ILogger.js.map +0 -1
  569. package/dist/interfaces/IMessage.js +0 -9
  570. package/dist/interfaces/IMessage.js.map +0 -1
  571. package/dist/interfaces/IMessageBus.js +0 -3
  572. package/dist/interfaces/IMessageBus.js.map +0 -1
  573. package/dist/interfaces/IObjectStorage.js.map +0 -1
  574. package/dist/interfaces/IObservable.js +0 -11
  575. package/dist/interfaces/IObservable.js.map +0 -1
  576. package/dist/interfaces/IObserver.js.map +0 -1
  577. package/dist/interfaces/IProjection.js.map +0 -1
  578. package/dist/interfaces/ISaga.js.map +0 -1
  579. package/dist/interfaces/IViewLocker.js +0 -17
  580. package/dist/interfaces/IViewLocker.js.map +0 -1
  581. package/dist/interfaces/Identifier.js.map +0 -1
  582. package/dist/interfaces/index.js +0 -43
  583. package/dist/interfaces/index.js.map +0 -1
  584. package/dist/interfaces/isObject.js.map +0 -1
  585. package/dist/rabbitmq/IContainer.js.map +0 -1
  586. package/dist/rabbitmq/RabbitMqEventBus.js +0 -89
  587. package/dist/rabbitmq/RabbitMqEventBus.js.map +0 -1
  588. package/dist/rabbitmq/RabbitMqEventInjector.js +0 -55
  589. package/dist/rabbitmq/RabbitMqEventInjector.js.map +0 -1
  590. package/dist/rabbitmq/RabbitMqGateway.js +0 -347
  591. package/dist/rabbitmq/RabbitMqGateway.js.map +0 -1
  592. package/dist/rabbitmq/TerminationHandler.js +0 -31
  593. package/dist/rabbitmq/TerminationHandler.js.map +0 -1
  594. package/dist/rabbitmq/constants.js +0 -6
  595. package/dist/rabbitmq/constants.js.map +0 -1
  596. package/dist/rabbitmq/index.js +0 -20
  597. package/dist/rabbitmq/index.js.map +0 -1
  598. package/dist/sqlite/AbstractSqliteAccessor.js +0 -50
  599. package/dist/sqlite/AbstractSqliteAccessor.js.map +0 -1
  600. package/dist/sqlite/AbstractSqliteObjectProjection.js +0 -26
  601. package/dist/sqlite/AbstractSqliteObjectProjection.js.map +0 -1
  602. package/dist/sqlite/AbstractSqliteView.js +0 -44
  603. package/dist/sqlite/AbstractSqliteView.js.map +0 -1
  604. package/dist/sqlite/IContainer.js.map +0 -1
  605. package/dist/sqlite/SqliteEventLocker.js +0 -94
  606. package/dist/sqlite/SqliteEventLocker.js.map +0 -1
  607. package/dist/sqlite/SqliteObjectStorage.js +0 -113
  608. package/dist/sqlite/SqliteObjectStorage.js.map +0 -1
  609. package/dist/sqlite/SqliteObjectView.js +0 -46
  610. package/dist/sqlite/SqliteObjectView.js.map +0 -1
  611. package/dist/sqlite/SqliteProjectionDataParams.js.map +0 -1
  612. package/dist/sqlite/SqliteViewLocker.js +0 -119
  613. package/dist/sqlite/SqliteViewLocker.js.map +0 -1
  614. package/dist/sqlite/index.js +0 -25
  615. package/dist/sqlite/index.js.map +0 -1
  616. package/dist/sqlite/queries/eventLockTableInit.js +0 -15
  617. package/dist/sqlite/queries/eventLockTableInit.js.map +0 -1
  618. package/dist/sqlite/queries/index.js +0 -19
  619. package/dist/sqlite/queries/index.js.map +0 -1
  620. package/dist/sqlite/queries/viewLockTableInit.js.map +0 -1
  621. package/dist/sqlite/utils/getEventId.js +0 -11
  622. package/dist/sqlite/utils/getEventId.js.map +0 -1
  623. package/dist/sqlite/utils/guid.js.map +0 -1
  624. package/dist/sqlite/utils/index.js +0 -19
  625. package/dist/sqlite/utils/index.js.map +0 -1
  626. package/dist/tsconfig.tsbuildinfo +0 -1
  627. package/dist/utils/Deferred.js.map +0 -1
  628. package/dist/utils/Lock.js +0 -50
  629. package/dist/utils/Lock.js.map +0 -1
  630. package/dist/utils/delay.js +0 -13
  631. package/dist/utils/delay.js.map +0 -1
  632. package/dist/utils/getClassName.js.map +0 -1
  633. package/dist/utils/getHandler.js +0 -19
  634. package/dist/utils/getHandler.js.map +0 -1
  635. package/dist/utils/getMessageHandlerNames.js +0 -34
  636. package/dist/utils/getMessageHandlerNames.js.map +0 -1
  637. package/dist/utils/index.js +0 -29
  638. package/dist/utils/index.js.map +0 -1
  639. package/dist/utils/isClass.js.map +0 -1
  640. package/dist/utils/iteratorToArray.js +0 -10
  641. package/dist/utils/iteratorToArray.js.map +0 -1
  642. package/dist/utils/notEmpty.js +0 -6
  643. package/dist/utils/notEmpty.js.map +0 -1
  644. package/dist/utils/setupOneTimeEmitterSubscription.js +0 -46
  645. package/dist/utils/setupOneTimeEmitterSubscription.js.map +0 -1
  646. package/dist/utils/subscribe.js +0 -51
  647. package/dist/utils/subscribe.js.map +0 -1
  648. package/dist/utils/validateHandlers.js +0 -21
  649. package/dist/utils/validateHandlers.js.map +0 -1
  650. package/eslint.config.mjs +0 -838
  651. package/src/AbstractAggregate.ts +0 -223
  652. package/src/AbstractProjection.ts +0 -209
  653. package/src/AbstractSaga.ts +0 -118
  654. package/src/AggregateCommandHandler.ts +0 -131
  655. package/src/CommandBus.ts +0 -100
  656. package/src/CqrsContainerBuilder.ts +0 -124
  657. package/src/Event.ts +0 -32
  658. package/src/EventDispatcher.ts +0 -166
  659. package/src/EventStore.ts +0 -205
  660. package/src/EventValidationProcessor.ts +0 -33
  661. package/src/SagaEventHandler.ts +0 -160
  662. package/src/in-memory/InMemoryEventStorage.ts +0 -108
  663. package/src/in-memory/InMemoryLock.ts +0 -43
  664. package/src/in-memory/InMemoryMessageBus.ts +0 -140
  665. package/src/in-memory/InMemorySnapshotStorage.ts +0 -89
  666. package/src/in-memory/InMemoryView.ts +0 -208
  667. package/src/in-memory/index.ts +0 -5
  668. package/src/in-memory/utils/index.ts +0 -1
  669. package/src/in-memory/utils/nextCycle.ts +0 -4
  670. package/src/index.ts +0 -22
  671. package/src/interfaces/IAggregate.ts +0 -58
  672. package/src/interfaces/IAggregateSnapshotStorage.ts +0 -11
  673. package/src/interfaces/ICommand.ts +0 -3
  674. package/src/interfaces/ICommandBus.ts +0 -16
  675. package/src/interfaces/IContainer.ts +0 -27
  676. package/src/interfaces/IDispatchPipelineProcessor.ts +0 -35
  677. package/src/interfaces/IEvent.ts +0 -13
  678. package/src/interfaces/IEventBus.ts +0 -11
  679. package/src/interfaces/IEventDispatcher.ts +0 -7
  680. package/src/interfaces/IEventLocker.ts +0 -34
  681. package/src/interfaces/IEventReceptor.ts +0 -6
  682. package/src/interfaces/IEventSet.ts +0 -7
  683. package/src/interfaces/IEventStorage.ts +0 -53
  684. package/src/interfaces/IEventStore.ts +0 -13
  685. package/src/interfaces/IEventStream.ts +0 -3
  686. package/src/interfaces/IIdentifierProvider.ts +0 -17
  687. package/src/interfaces/ILogger.ts +0 -11
  688. package/src/interfaces/IMessage.ts +0 -22
  689. package/src/interfaces/IMessageBus.ts +0 -8
  690. package/src/interfaces/IObjectStorage.ts +0 -13
  691. package/src/interfaces/IObservable.ts +0 -31
  692. package/src/interfaces/IObserver.ts +0 -5
  693. package/src/interfaces/IProjection.ts +0 -20
  694. package/src/interfaces/ISaga.ts +0 -38
  695. package/src/interfaces/IViewLocker.ts +0 -46
  696. package/src/interfaces/Identifier.ts +0 -1
  697. package/src/interfaces/index.ts +0 -26
  698. package/src/interfaces/isObject.ts +0 -5
  699. package/src/rabbitmq/IContainer.ts +0 -16
  700. package/src/rabbitmq/RabbitMqEventBus.ts +0 -104
  701. package/src/rabbitmq/RabbitMqEventInjector.ts +0 -66
  702. package/src/rabbitmq/RabbitMqGateway.ts +0 -473
  703. package/src/rabbitmq/TerminationHandler.ts +0 -31
  704. package/src/rabbitmq/constants.ts +0 -2
  705. package/src/rabbitmq/index.ts +0 -3
  706. package/src/sqlite/AbstractSqliteAccessor.ts +0 -58
  707. package/src/sqlite/AbstractSqliteObjectProjection.ts +0 -31
  708. package/src/sqlite/AbstractSqliteView.ts +0 -53
  709. package/src/sqlite/IContainer.ts +0 -8
  710. package/src/sqlite/SqliteEventLocker.ts +0 -137
  711. package/src/sqlite/SqliteObjectStorage.ts +0 -142
  712. package/src/sqlite/SqliteObjectView.ts +0 -58
  713. package/src/sqlite/SqliteProjectionDataParams.ts +0 -16
  714. package/src/sqlite/SqliteViewLocker.ts +0 -167
  715. package/src/sqlite/index.ts +0 -8
  716. package/src/sqlite/queries/eventLockTableInit.ts +0 -10
  717. package/src/sqlite/queries/index.ts +0 -2
  718. package/src/sqlite/queries/viewLockTableInit.ts +0 -9
  719. package/src/sqlite/utils/getEventId.ts +0 -8
  720. package/src/sqlite/utils/guid.ts +0 -4
  721. package/src/sqlite/utils/index.ts +0 -2
  722. package/src/utils/Deferred.ts +0 -41
  723. package/src/utils/Lock.ts +0 -53
  724. package/src/utils/delay.ts +0 -8
  725. package/src/utils/getClassName.ts +0 -6
  726. package/src/utils/getHandler.ts +0 -20
  727. package/src/utils/getMessageHandlerNames.ts +0 -38
  728. package/src/utils/index.ts +0 -12
  729. package/src/utils/isClass.ts +0 -4
  730. package/src/utils/iteratorToArray.ts +0 -6
  731. package/src/utils/notEmpty.ts +0 -1
  732. package/src/utils/setupOneTimeEmitterSubscription.ts +0 -59
  733. package/src/utils/subscribe.ts +0 -65
  734. package/src/utils/validateHandlers.ts +0 -20
  735. package/types/AbstractAggregate.d.ts +0 -57
  736. package/types/AbstractProjection.d.ts +0 -60
  737. package/types/AbstractSaga.d.ts +0 -31
  738. package/types/AggregateCommandHandler.d.ts +0 -20
  739. package/types/CommandBus.d.ts +0 -27
  740. package/types/CqrsContainerBuilder.d.ts +0 -21
  741. package/types/Event.d.ts +0 -13
  742. package/types/EventDispatcher.d.ts +0 -32
  743. package/types/EventStore.d.ts +0 -34
  744. package/types/EventValidationProcessor.d.ts +0 -19
  745. package/types/SagaEventHandler.d.ts +0 -21
  746. package/types/in-memory/InMemoryEventStorage.d.ts +0 -24
  747. package/types/in-memory/InMemoryLock.d.ts +0 -21
  748. package/types/in-memory/InMemoryMessageBus.d.ts +0 -42
  749. package/types/in-memory/InMemorySnapshotStorage.d.ts +0 -37
  750. package/types/in-memory/InMemoryView.d.ts +0 -53
  751. package/types/in-memory/index.d.ts +0 -5
  752. package/types/in-memory/utils/index.d.ts +0 -1
  753. package/types/index.d.ts +0 -14
  754. package/types/interfaces/IAggregate.d.ts +0 -35
  755. package/types/interfaces/IAggregateSnapshotStorage.d.ts +0 -7
  756. package/types/interfaces/ICommand.d.ts +0 -2
  757. package/types/interfaces/ICommandBus.d.ts +0 -14
  758. package/types/interfaces/IContainer.d.ts +0 -23
  759. package/types/interfaces/IDispatchPipelineProcessor.d.ts +0 -25
  760. package/types/interfaces/IEvent.d.ts +0 -6
  761. package/types/interfaces/IEventBus.d.ts +0 -6
  762. package/types/interfaces/IEventDispatcher.d.ts +0 -6
  763. package/types/interfaces/IEventLocker.d.ts +0 -24
  764. package/types/interfaces/IEventReceptor.d.ts +0 -5
  765. package/types/interfaces/IEventSet.d.ts +0 -3
  766. package/types/interfaces/IEventStorage.d.ts +0 -36
  767. package/types/interfaces/IEventStore.d.ts +0 -9
  768. package/types/interfaces/IEventStream.d.ts +0 -2
  769. package/types/interfaces/IIdentifierProvider.d.ts +0 -10
  770. package/types/interfaces/IMessage.d.ts +0 -12
  771. package/types/interfaces/IMessageBus.d.ts +0 -7
  772. package/types/interfaces/IObjectStorage.d.ts +0 -8
  773. package/types/interfaces/IObservable.d.ts +0 -19
  774. package/types/interfaces/IObserver.d.ts +0 -4
  775. package/types/interfaces/IProjection.d.ts +0 -17
  776. package/types/interfaces/ISaga.d.ts +0 -30
  777. package/types/interfaces/Identifier.d.ts +0 -1
  778. package/types/interfaces/index.d.ts +0 -26
  779. package/types/interfaces/isObject.d.ts +0 -1
  780. package/types/rabbitmq/IContainer.d.ts +0 -14
  781. package/types/rabbitmq/RabbitMqEventBus.d.ts +0 -41
  782. package/types/rabbitmq/RabbitMqEventInjector.d.ts +0 -13
  783. package/types/rabbitmq/RabbitMqGateway.d.ts +0 -78
  784. package/types/rabbitmq/TerminationHandler.d.ts +0 -10
  785. package/types/rabbitmq/constants.d.ts +0 -2
  786. package/types/rabbitmq/index.d.ts +0 -3
  787. package/types/sqlite/AbstractSqliteAccessor.d.ts +0 -25
  788. package/types/sqlite/AbstractSqliteObjectProjection.d.ts +0 -8
  789. package/types/sqlite/AbstractSqliteView.d.ts +0 -18
  790. package/types/sqlite/IContainer.d.ts +0 -7
  791. package/types/sqlite/SqliteEventLocker.d.ts +0 -28
  792. package/types/sqlite/SqliteObjectStorage.d.ts +0 -16
  793. package/types/sqlite/SqliteObjectView.d.ts +0 -16
  794. package/types/sqlite/SqliteViewLocker.d.ts +0 -30
  795. package/types/sqlite/index.d.ts +0 -8
  796. package/types/sqlite/queries/index.d.ts +0 -2
  797. package/types/sqlite/utils/getEventId.d.ts +0 -5
  798. package/types/sqlite/utils/index.d.ts +0 -2
  799. package/types/utils/Lock.d.ts +0 -22
  800. package/types/utils/delay.d.ts +0 -5
  801. package/types/utils/getHandler.d.ts +0 -7
  802. package/types/utils/getMessageHandlerNames.d.ts +0 -5
  803. package/types/utils/index.d.ts +0 -12
  804. package/types/utils/isClass.d.ts +0 -1
  805. package/types/utils/iteratorToArray.d.ts +0 -1
  806. package/types/utils/notEmpty.d.ts +0 -1
  807. package/types/utils/setupOneTimeEmitterSubscription.d.ts +0 -12
  808. package/types/utils/subscribe.d.ts +0 -13
  809. /package/dist/{interfaces → cjs/interfaces}/IAggregate.js +0 -0
  810. /package/dist/{interfaces → cjs/interfaces}/ICommand.js +0 -0
  811. /package/dist/{interfaces → cjs/interfaces}/ICommandBus.js +0 -0
  812. /package/dist/{interfaces → cjs/interfaces}/IContainer.js +0 -0
  813. /package/dist/{interfaces → cjs/interfaces}/IEventDispatcher.js +0 -0
  814. /package/dist/{interfaces → cjs/interfaces}/IEventReceptor.js +0 -0
  815. /package/dist/{interfaces → cjs/interfaces}/IEventStore.js +0 -0
  816. /package/dist/{interfaces → cjs/interfaces}/IEventStream.js +0 -0
  817. /package/dist/{interfaces → cjs/interfaces}/ILogger.js +0 -0
  818. /package/dist/{interfaces → cjs/interfaces}/IObjectStorage.js +0 -0
  819. /package/dist/{interfaces → cjs/interfaces}/IObserver.js +0 -0
  820. /package/dist/{interfaces → cjs/interfaces}/IProjection.js +0 -0
  821. /package/dist/{interfaces → cjs/interfaces}/ISaga.js +0 -0
  822. /package/dist/{interfaces → cjs/interfaces}/Identifier.js +0 -0
  823. /package/dist/{interfaces → cjs/interfaces}/isObject.js +0 -0
  824. /package/dist/{rabbitmq → cjs/rabbitmq}/IContainer.js +0 -0
  825. /package/dist/{sqlite → cjs/sqlite}/IContainer.js +0 -0
  826. /package/dist/{sqlite → cjs/sqlite}/SqliteProjectionDataParams.js +0 -0
  827. /package/dist/{sqlite → cjs/sqlite}/queries/viewLockTableInit.js +0 -0
  828. /package/dist/{sqlite → cjs/sqlite}/utils/guid.js +0 -0
  829. /package/dist/{utils → cjs/utils}/Deferred.js +0 -0
  830. /package/dist/{utils → cjs/utils}/getClassName.js +0 -0
  831. /package/dist/{utils → cjs/utils}/isClass.js +0 -0
  832. /package/{types → dist/types}/in-memory/utils/nextCycle.d.ts +0 -0
  833. /package/{types → dist/types}/interfaces/ILogger.d.ts +0 -0
  834. /package/{types → dist/types}/interfaces/IViewLocker.d.ts +0 -0
  835. /package/{types → dist/types}/sqlite/SqliteProjectionDataParams.d.ts +0 -0
  836. /package/{types → dist/types}/sqlite/queries/eventLockTableInit.d.ts +0 -0
  837. /package/{types → dist/types}/sqlite/queries/viewLockTableInit.d.ts +0 -0
  838. /package/{types → dist/types}/sqlite/utils/guid.d.ts +0 -0
  839. /package/{types → dist/types}/utils/Deferred.d.ts +0 -0
  840. /package/{types → dist/types}/utils/getClassName.d.ts +0 -0
  841. /package/{types → dist/types}/utils/validateHandlers.d.ts +0 -0
@@ -1,92 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.CqrsContainerBuilder = void 0;
4
- const di0_1 = require("di0");
5
- const AggregateCommandHandler_1 = require("./AggregateCommandHandler");
6
- const CommandBus_1 = require("./CommandBus");
7
- const EventStore_1 = require("./EventStore");
8
- const SagaEventHandler_1 = require("./SagaEventHandler");
9
- const EventDispatcher_1 = require("./EventDispatcher");
10
- const in_memory_1 = require("./in-memory");
11
- const EventValidationProcessor_1 = require("./EventValidationProcessor");
12
- const utils_1 = require("./utils");
13
- class CqrsContainerBuilder extends di0_1.ContainerBuilder {
14
- constructor(options) {
15
- super(options);
16
- super.register(in_memory_1.InMemoryMessageBus).as('eventBus');
17
- super.register(EventStore_1.EventStore).as('eventStore');
18
- super.register(CommandBus_1.CommandBus).as('commandBus');
19
- super.register(EventDispatcher_1.EventDispatcher).as('eventDispatcher');
20
- super.register(in_memory_1.InMemoryEventStorage).as('eventStorageWriter');
21
- super.register(in_memory_1.InMemorySnapshotStorage).as('snapshotStorage');
22
- // Register default event dispatch pipeline:
23
- // validate events, write to event storage, write to snapshot storage.
24
- // If any of the processors is not defined, it will be skipped.
25
- super.register((container) => [
26
- new EventValidationProcessor_1.EventValidationProcessor(),
27
- container.eventStorageWriter,
28
- container.snapshotStorage
29
- ]).as('eventDispatchPipeline');
30
- }
31
- /** Register command handler, which will be subscribed to commandBus upon instance creation */
32
- registerCommandHandler(typeOrFactory) {
33
- return super.register((container) => {
34
- const handler = container.createInstance(typeOrFactory);
35
- handler.subscribe(container.commandBus);
36
- return handler;
37
- })
38
- .asSingleInstance();
39
- }
40
- /** Register event receptor, which will be subscribed to eventStore upon instance creation */
41
- registerEventReceptor(typeOrFactory) {
42
- return super.register((container) => {
43
- const receptor = container.createInstance(typeOrFactory);
44
- receptor.subscribe(container.eventStore);
45
- return receptor;
46
- })
47
- .asSingleInstance();
48
- }
49
- /**
50
- * Register projection, which will expose view and will be subscribed
51
- * to eventStore and will restore its state upon instance creation
52
- */
53
- registerProjection(ProjectionType, exposedViewAlias) {
54
- if (!(0, utils_1.isClass)(ProjectionType))
55
- throw new TypeError('ProjectionType argument must be a constructor function');
56
- const projectionFactory = (container) => {
57
- const projection = container.createInstance(ProjectionType);
58
- projection.subscribe(container.eventStore);
59
- if (exposedViewAlias)
60
- return projection.view;
61
- return projection;
62
- };
63
- const t = super.register(projectionFactory).asSingleInstance();
64
- if (exposedViewAlias)
65
- t.as(exposedViewAlias);
66
- return t;
67
- }
68
- /** Register aggregate type in the container */
69
- registerAggregate(AggregateType) {
70
- if (!(0, utils_1.isClass)(AggregateType))
71
- throw new TypeError('AggregateType argument must be a constructor function');
72
- const commandHandlerFactory = (container) => container.createInstance(AggregateCommandHandler_1.AggregateCommandHandler, {
73
- aggregateFactory: (options) => container.createInstance(AggregateType, options),
74
- handles: AggregateType.handles
75
- });
76
- return this.registerCommandHandler(commandHandlerFactory);
77
- }
78
- /** Register saga type in the container */
79
- registerSaga(SagaType) {
80
- if (!(0, utils_1.isClass)(SagaType))
81
- throw new TypeError('SagaType argument must be a constructor function');
82
- const eventReceptorFactory = (container) => container.createInstance(SagaEventHandler_1.SagaEventHandler, {
83
- sagaFactory: (options) => container.createInstance(SagaType, options),
84
- handles: SagaType.handles,
85
- startsWith: SagaType.startsWith,
86
- queueName: SagaType.name
87
- });
88
- return this.registerEventReceptor(eventReceptorFactory);
89
- }
90
- }
91
- exports.CqrsContainerBuilder = CqrsContainerBuilder;
92
- //# sourceMappingURL=CqrsContainerBuilder.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"CqrsContainerBuilder.js","sourceRoot":"","sources":["../src/CqrsContainerBuilder.ts"],"names":[],"mappings":"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"}
package/dist/Event.js DELETED
@@ -1,33 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.describe = describe;
4
- exports.describeMultiple = describeMultiple;
5
- exports.validate = validate;
6
- /**
7
- * Get text description of an event for logging purposes
8
- */
9
- function describe(event) {
10
- return `'${event.type}' of ${event.aggregateId} (v${event.aggregateVersion})`;
11
- }
12
- /**
13
- * Get text description of a set of events for logging purposes
14
- */
15
- function describeMultiple(events) {
16
- if (events.length === 1)
17
- return describe(events[0]);
18
- return `${events.length} events`;
19
- }
20
- /**
21
- * Validate event structure
22
- */
23
- function validate(event) {
24
- if (typeof event !== 'object' || !event)
25
- throw new TypeError('event must be an Object');
26
- if (typeof event.type !== 'string' || !event.type.length)
27
- throw new TypeError('event.type must be a non-empty String');
28
- if (!event.aggregateId && !event.sagaId)
29
- throw new TypeError('either event.aggregateId or event.sagaId is required');
30
- if (event.sagaId && typeof event.sagaVersion === 'undefined')
31
- throw new TypeError('event.sagaVersion is required, when event.sagaId is defined');
32
- }
33
- //# sourceMappingURL=Event.js.map
package/dist/Event.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"Event.js","sourceRoot":"","sources":["../src/Event.ts"],"names":[],"mappings":";;AAKA,4BAEC;AAKD,4CAKC;AAKD,4BASC;AA7BD;;GAEG;AACH,SAAgB,QAAQ,CAAC,KAAa;IACrC,OAAO,IAAI,KAAK,CAAC,IAAI,QAAQ,KAAK,CAAC,WAAW,MAAM,KAAK,CAAC,gBAAgB,GAAG,CAAC;AAC/E,CAAC;AAED;;GAEG;AACH,SAAgB,gBAAgB,CAAC,MAA6B;IAC7D,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;QACtB,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAE5B,OAAO,GAAG,MAAM,CAAC,MAAM,SAAS,CAAC;AAClC,CAAC;AAED;;GAEG;AACH,SAAgB,QAAQ,CAAC,KAAa;IACrC,IAAI,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,KAAK;QACtC,MAAM,IAAI,SAAS,CAAC,yBAAyB,CAAC,CAAC;IAChD,IAAI,OAAO,KAAK,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,MAAM;QACvD,MAAM,IAAI,SAAS,CAAC,uCAAuC,CAAC,CAAC;IAC9D,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,MAAM;QACtC,MAAM,IAAI,SAAS,CAAC,sDAAsD,CAAC,CAAC;IAC7E,IAAI,KAAK,CAAC,MAAM,IAAI,OAAO,KAAK,CAAC,WAAW,KAAK,WAAW;QAC3D,MAAM,IAAI,SAAS,CAAC,6DAA6D,CAAC,CAAC;AACrF,CAAC"}
@@ -1,125 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EventDispatcher = void 0;
4
- const interfaces_1 = require("./interfaces");
5
- const async_parallel_pipe_1 = require("async-parallel-pipe");
6
- const async_iterable_buffer_1 = require("async-iterable-buffer");
7
- const utils_1 = require("./utils");
8
- const in_memory_1 = require("./in-memory");
9
- class EventDispatcher {
10
- #pipelineInput = new async_iterable_buffer_1.AsyncIterableBuffer();
11
- #processors = [];
12
- #pipeline = this.#pipelineInput;
13
- /**
14
- * Event bus where dispatched messages are delivered after processing.
15
- *
16
- * If not provided in the constructor, defaults to an instance of `InMemoryMessageBus`.
17
- */
18
- eventBus;
19
- /**
20
- * Maximum number of event batches that each pipeline processor can handle in parallel.
21
- */
22
- concurrentLimit;
23
- constructor(o) {
24
- this.eventBus = o?.eventBus ?? new in_memory_1.InMemoryMessageBus();
25
- this.concurrentLimit = o?.eventDispatcherConfig?.concurrentLimit ?? 100;
26
- if (o?.eventDispatchPipeline)
27
- this.addPipelineProcessors(o.eventDispatchPipeline);
28
- }
29
- addPipelineProcessors(eventDispatchPipeline) {
30
- if (!Array.isArray(eventDispatchPipeline))
31
- throw new TypeError('eventDispatchPipeline argument must be an Array');
32
- for (const processor of eventDispatchPipeline) {
33
- if (processor)
34
- this.addPipelineProcessor(processor);
35
- }
36
- }
37
- /**
38
- * Adds a preprocessor to the event dispatch pipeline.
39
- *
40
- * Preprocessors run in order they are added but process separate batches in parallel, maintaining FIFO order.
41
- */
42
- addPipelineProcessor(preprocessor) {
43
- if (!(0, interfaces_1.isDispatchPipelineProcessor)(preprocessor))
44
- throw new TypeError(`preprocessor ${(0, utils_1.getClassName)(preprocessor)} does not implement IDispatchPipelineProcessor`);
45
- if (this.#pipelineProcessing)
46
- throw new Error('pipeline processing already started');
47
- this.#processors.push(preprocessor);
48
- // Build a processing pipeline that runs preprocessors concurrently, preserving FIFO ordering
49
- this.#pipeline = (0, async_parallel_pipe_1.parallelPipe)(this.#pipeline, this.concurrentLimit, async (envelope) => {
50
- if (envelope.error)
51
- return envelope;
52
- try {
53
- return {
54
- ...envelope,
55
- data: await preprocessor.process(envelope.data)
56
- };
57
- }
58
- catch (error) {
59
- return {
60
- ...envelope,
61
- error
62
- };
63
- }
64
- });
65
- }
66
- #pipelineProcessing = false;
67
- /**
68
- * Consume the pipeline, publish events, and resolve/reject each batch
69
- */
70
- async #startPipelineProcessing() {
71
- if (this.#pipelineProcessing) // should never happen
72
- throw new Error('pipeline processing already started');
73
- this.#pipelineProcessing = true;
74
- for await (const { error, reject, data, resolve } of this.#pipeline) {
75
- if (error) { // some of the preprocessors failed
76
- await this.#revert(data);
77
- reject(error);
78
- continue;
79
- }
80
- const events = data.map(e => e.event).filter(utils_1.notEmpty);
81
- try {
82
- for (const batch of data) {
83
- const { event, ...meta } = batch;
84
- if (event)
85
- this.eventBus.publish(event, meta);
86
- }
87
- resolve(events);
88
- }
89
- catch (publishError) {
90
- reject(publishError);
91
- }
92
- }
93
- }
94
- /**
95
- * Revert side effects made by pipeline processors in case of a batch processing failure
96
- */
97
- async #revert(batch) {
98
- for (const processor of this.#processors)
99
- await processor.revert?.(batch);
100
- }
101
- /**
102
- * Dispatch a set of events through the processing pipeline.
103
- *
104
- * Returns a promise that resolves after all events are processed and published.
105
- */
106
- async dispatch(events, meta) {
107
- if (!(0, interfaces_1.isEventSet)(events) || events.length === 0)
108
- throw new Error('dispatch requires a non-empty array of events');
109
- const { promise, resolve, reject } = Promise.withResolvers();
110
- const envelope = {
111
- data: events.map(event => ({
112
- event,
113
- ...meta
114
- })),
115
- resolve,
116
- reject
117
- };
118
- if (!this.#pipelineProcessing)
119
- this.#startPipelineProcessing();
120
- this.#pipelineInput.push(envelope);
121
- return promise;
122
- }
123
- }
124
- exports.EventDispatcher = EventDispatcher;
125
- //# sourceMappingURL=EventDispatcher.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventDispatcher.js","sourceRoot":"","sources":["../src/EventDispatcher.ts"],"names":[],"mappings":";;;AAAA,6CAUsB;AACtB,6DAAmD;AACnD,iEAA4D;AAC5D,mCAAiD;AACjD,2CAAiD;AASjD,MAAa,eAAe;IAE3B,cAAc,GAAG,IAAI,2CAAmB,EAAsB,CAAC;IAC/D,WAAW,GAAsC,EAAE,CAAC;IACpD,SAAS,GAAqF,IAAI,CAAC,cAAc,CAAC;IAElH;;;;OAIG;IACH,QAAQ,CAAY;IAEpB;;OAEG;IACH,eAAe,CAAS;IAExB,YAAY,CAIX;QACA,IAAI,CAAC,QAAQ,GAAG,CAAC,EAAE,QAAQ,IAAI,IAAI,8BAAkB,EAAE,CAAC;QACxD,IAAI,CAAC,eAAe,GAAG,CAAC,EAAE,qBAAqB,EAAE,eAAe,IAAI,GAAG,CAAC;QAExE,IAAI,CAAC,EAAE,qBAAqB;YAC3B,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC;IACtD,CAAC;IAED,qBAAqB,CAAC,qBAAmD;QACxE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,qBAAqB,CAAC;YACxC,MAAM,IAAI,SAAS,CAAC,iDAAiD,CAAC,CAAC;QAExE,KAAK,MAAM,SAAS,IAAI,qBAAqB,EAAE,CAAC;YAC/C,IAAI,SAAS;gBACZ,IAAI,CAAC,oBAAoB,CAAC,SAAS,CAAC,CAAC;QACvC,CAAC;IACF,CAAC;IAED;;;;OAIG;IACH,oBAAoB,CAAC,YAAwC;QAC5D,IAAI,CAAC,IAAA,wCAA2B,EAAC,YAAY,CAAC;YAC7C,MAAM,IAAI,SAAS,CAAC,gBAAgB,IAAA,oBAAY,EAAC,YAAY,CAAC,gDAAgD,CAAC,CAAC;QACjH,IAAI,IAAI,CAAC,mBAAmB;YAC3B,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QAExD,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAEpC,6FAA6F;QAC7F,IAAI,CAAC,SAAS,GAAG,IAAA,kCAAY,EAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,EAAE,KAAK,EAAC,QAAQ,EAAC,EAAE;YACpF,IAAI,QAAQ,CAAC,KAAK;gBACjB,OAAO,QAAQ,CAAC;YAEjB,IAAI,CAAC;gBACJ,OAAO;oBACN,GAAG,QAAQ;oBACX,IAAI,EAAE,MAAM,YAAY,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC;iBAC/C,CAAC;YACH,CAAC;YACD,OAAO,KAAU,EAAE,CAAC;gBACnB,OAAO;oBACN,GAAG,QAAQ;oBACX,KAAK;iBACL,CAAC;YACH,CAAC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,mBAAmB,GAAG,KAAK,CAAC;IAE5B;;OAEG;IACH,KAAK,CAAC,wBAAwB;QAC7B,IAAI,IAAI,CAAC,mBAAmB,EAAE,sBAAsB;YACnD,MAAM,IAAI,KAAK,CAAC,qCAAqC,CAAC,CAAC;QAExD,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;QAEhC,IAAI,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACrE,IAAI,KAAK,EAAE,CAAC,CAAC,mCAAmC;gBAC/C,MAAM,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;gBACzB,MAAM,CAAC,KAAK,CAAC,CAAC;gBACd,SAAS;YACV,CAAC;YAED,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,gBAAQ,CAAC,CAAC;YAEvD,IAAI,CAAC;gBACJ,KAAK,MAAM,KAAK,IAAI,IAAI,EAAE,CAAC;oBAC1B,MAAM,EAAE,KAAK,EAAE,GAAG,IAAI,EAAE,GAAG,KAAK,CAAC;oBACjC,IAAI,KAAK;wBACR,IAAI,CAAC,QAAQ,CAAC,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;gBACrC,CAAC;gBAED,OAAO,CAAC,MAAM,CAAC,CAAC;YACjB,CAAC;YACD,OAAO,YAAiB,EAAE,CAAC;gBAC1B,MAAM,CAAC,YAAY,CAAC,CAAC;YACtB,CAAC;QACF,CAAC;IACF,CAAC;IAED;;OAEG;IACH,KAAK,CAAC,OAAO,CAAC,KAA4B;QACzC,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,WAAW;YACvC,MAAM,SAAS,CAAC,MAAM,EAAE,CAAC,KAAK,CAAC,CAAC;IAClC,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,QAAQ,CAAC,MAAiB,EAAE,IAA0B;QAC3D,IAAI,CAAC,IAAA,uBAAU,EAAC,MAAM,CAAC,IAAI,MAAM,CAAC,MAAM,KAAK,CAAC;YAC7C,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;QAElE,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,OAAO,CAAC,aAAa,EAAa,CAAC;QACxE,MAAM,QAAQ,GAAuB;YACpC,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;gBAC1B,KAAK;gBACL,GAAG,IAAI;aACP,CAAC,CAAC;YACH,OAAO;YACP,MAAM;SACN,CAAC;QAEF,IAAI,CAAC,IAAI,CAAC,mBAAmB;YAC5B,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEjC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEnC,OAAO,OAAO,CAAC;IAChB,CAAC;CACD;AA9ID,0CA8IC"}
@@ -1,137 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EventStore = void 0;
4
- const interfaces_1 = require("./interfaces");
5
- const utils_1 = require("./utils");
6
- const EventDispatcher_1 = require("./EventDispatcher");
7
- class EventStore {
8
- #identifierProvider;
9
- #eventStorageReader;
10
- #snapshotStorage;
11
- eventBus;
12
- #eventDispatcher;
13
- #sagaStarters = new Set();
14
- #logger;
15
- constructor({ eventStorageReader, identifierProvider = (0, interfaces_1.isIdentifierProvider)(eventStorageReader) ? eventStorageReader : undefined, snapshotStorage, eventBus, eventDispatcher, logger }) {
16
- if (!eventStorageReader)
17
- throw new TypeError('eventStorageReader argument required');
18
- if (!identifierProvider)
19
- throw new TypeError('identifierProvider argument required');
20
- if (!(0, interfaces_1.isIEventStorageReader)(eventStorageReader))
21
- throw new TypeError('storage does not implement IEventStorage interface');
22
- if (eventBus && !(0, interfaces_1.isIEventBus)(eventBus))
23
- throw new TypeError('eventBus does not implement IMessageBus interface');
24
- this.#eventStorageReader = eventStorageReader;
25
- this.#identifierProvider = identifierProvider;
26
- this.#snapshotStorage = snapshotStorage;
27
- this.#eventDispatcher = eventDispatcher ?? new EventDispatcher_1.EventDispatcher({ eventBus });
28
- this.eventBus = eventBus ?? this.#eventDispatcher.eventBus;
29
- this.#logger = logger && 'child' in logger ?
30
- logger.child({ service: (0, utils_1.getClassName)(this) }) :
31
- logger;
32
- }
33
- /**
34
- * Generates and returns a new unique identifier using the configured identifier provider.
35
- *
36
- * @returns A promise resolving to a unique identifier suitable for aggregates, sagas, and events.
37
- */
38
- async getNewId() {
39
- return this.#identifierProvider.getNewId();
40
- }
41
- async *getEventsByTypes(eventTypes, options) {
42
- if (!Array.isArray(eventTypes))
43
- throw new TypeError('eventTypes argument must be an Array');
44
- this.#logger?.debug(`retrieving ${eventTypes.join(', ')} events...`);
45
- const eventsIterable = await this.#eventStorageReader.getEventsByTypes(eventTypes, options);
46
- yield* eventsIterable;
47
- this.#logger?.debug(`${eventTypes.join(', ')} events retrieved`);
48
- }
49
- /** Retrieve all events of specific Aggregate */
50
- async *getAggregateEvents(aggregateId) {
51
- if (!aggregateId)
52
- throw new TypeError('aggregateId argument required');
53
- this.#logger?.debug(`retrieving event stream for aggregate ${aggregateId}...`);
54
- const snapshot = this.#snapshotStorage ?
55
- await this.#snapshotStorage.getAggregateSnapshot(aggregateId) :
56
- undefined;
57
- if (snapshot)
58
- yield snapshot;
59
- const eventsIterable = await this.#eventStorageReader.getAggregateEvents(aggregateId, { snapshot });
60
- yield* eventsIterable;
61
- this.#logger?.debug(`all events for aggregate ${aggregateId} retrieved`);
62
- }
63
- /** Retrieve events of specific Saga */
64
- async *getSagaEvents(sagaId, filter) {
65
- if (!sagaId)
66
- throw new TypeError('sagaId argument required');
67
- if (!filter)
68
- throw new TypeError('filter argument required');
69
- if (!filter.beforeEvent)
70
- throw new TypeError('filter.beforeEvent argument required');
71
- if (filter.beforeEvent.sagaVersion === undefined)
72
- throw new TypeError('filter.beforeEvent.sagaVersion argument required');
73
- this.#logger?.debug(`retrieving event stream for saga ${sagaId}, v${filter.beforeEvent.sagaVersion}...`);
74
- const eventsIterable = await this.#eventStorageReader.getSagaEvents(sagaId, filter);
75
- yield* eventsIterable;
76
- this.#logger?.debug(`all events for saga ${sagaId} retrieved`);
77
- }
78
- /**
79
- * Register event types that start sagas.
80
- * Upon such event commit a new sagaId will be assigned
81
- */
82
- registerSagaStarters(eventTypes = []) {
83
- for (const eventType of eventTypes)
84
- this.#sagaStarters.add(eventType);
85
- }
86
- /**
87
- * Validate events, commit to storage and publish to messageBus, if needed
88
- *
89
- * @param events - a set of events to commit
90
- * @returns Signed and committed events
91
- */
92
- async dispatch(events) {
93
- if (!Array.isArray(events))
94
- throw new TypeError('events argument must be an Array');
95
- const augmentedEvents = await this.#attachSagaIdToSagaStarterEvents(events);
96
- return this.#eventDispatcher.dispatch(augmentedEvents, { origin: 'internal' });
97
- }
98
- /**
99
- * Generate and attach sagaId to events that start new sagas
100
- */
101
- async #attachSagaIdToSagaStarterEvents(events) {
102
- if (!this.#sagaStarters.size)
103
- return events;
104
- const augmentedEvents = [];
105
- for (const event of events) {
106
- if (this.#sagaStarters.has(event.type)) {
107
- if (event.sagaId)
108
- throw new Error(`Event "${event.type}" already contains sagaId. Multiple sagas with same event type are not supported`);
109
- event.sagaId = await this.getNewId();
110
- event.sagaVersion = 0;
111
- augmentedEvents.push(event);
112
- }
113
- else {
114
- augmentedEvents.push(event);
115
- }
116
- }
117
- return augmentedEvents;
118
- }
119
- on(messageType, handler) {
120
- this.eventBus.on(messageType, handler);
121
- }
122
- off(messageType, handler) {
123
- this.eventBus.off(messageType, handler);
124
- }
125
- queue(name) {
126
- if (!this.eventBus.queue)
127
- throw new Error('Injected eventBus does not support named queues');
128
- return this.eventBus.queue(name);
129
- }
130
- /** Creates one-time subscription for one or multiple events that match a filter */
131
- once(messageTypes, handler, filter) {
132
- const subscribeTo = Array.isArray(messageTypes) ? messageTypes : [messageTypes];
133
- return (0, utils_1.setupOneTimeEmitterSubscription)(this.eventBus, subscribeTo, filter, handler, this.#logger);
134
- }
135
- }
136
- exports.EventStore = EventStore;
137
- //# sourceMappingURL=EventStore.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventStore.js","sourceRoot":"","sources":["../src/EventStore.ts"],"names":[],"mappings":"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"}
@@ -1,29 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.EventValidationProcessor = void 0;
4
- const Event_1 = require("./Event");
5
- /**
6
- * Processor that validates the format of events.
7
- * Rejects the batch if any event fails validation.
8
- */
9
- class EventValidationProcessor {
10
- #validate;
11
- constructor(o) {
12
- this.#validate = o?.eventFormatValidator ?? Event_1.validate;
13
- }
14
- /**
15
- * Processes a batch of dispatch pipeline items by validating each event within the batch.
16
- * It iterates through the batch and calls the private `#validate` method for each event found.
17
- *
18
- * This method is part of the `IDispatchPipelineProcessor` interface.
19
- */
20
- async process(batch) {
21
- for (const { event } of batch) {
22
- if (event)
23
- this.#validate(event);
24
- }
25
- return batch;
26
- }
27
- }
28
- exports.EventValidationProcessor = EventValidationProcessor;
29
- //# sourceMappingURL=EventValidationProcessor.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"EventValidationProcessor.js","sourceRoot":"","sources":["../src/EventValidationProcessor.ts"],"names":[],"mappings":";;;AACA,mCAAuD;AAIvD;;;GAGG;AACH,MAAa,wBAAwB;IAEpC,SAAS,CAAiB;IAE1B,YAAY,CAEX;QACA,IAAI,CAAC,SAAS,GAAG,CAAC,EAAE,oBAAoB,IAAI,gBAAgB,CAAC;IAC9D,CAAC;IAED;;;;;OAKG;IACH,KAAK,CAAC,OAAO,CAAC,KAA4B;QACzC,KAAK,MAAM,EAAE,KAAK,EAAE,IAAI,KAAK,EAAE,CAAC;YAC/B,IAAI,KAAK;gBACR,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACxB,CAAC;QACD,OAAO,KAAK,CAAC;IACd,CAAC;CACD;AAvBD,4DAuBC"}
@@ -1,118 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.SagaEventHandler = void 0;
4
- const Event = require("./Event");
5
- const utils_1 = require("./utils");
6
- /**
7
- * Listens to Saga events,
8
- * creates new saga or restores it from event store,
9
- * applies new events
10
- * and passes command(s) to command bus
11
- */
12
- class SagaEventHandler {
13
- #eventStore;
14
- #commandBus;
15
- #queueName;
16
- #logger;
17
- #sagaFactory;
18
- #startsWith;
19
- #handles;
20
- constructor(options) {
21
- if (!options)
22
- throw new TypeError('options argument required');
23
- if (!options.eventStore)
24
- throw new TypeError('options.eventStore argument required');
25
- if (!options.commandBus)
26
- throw new TypeError('options.commandBus argument required');
27
- this.#eventStore = options.eventStore;
28
- this.#commandBus = options.commandBus;
29
- this.#queueName = options.queueName;
30
- this.#logger = options.logger && 'child' in options.logger ?
31
- options.logger.child({ service: (0, utils_1.getClassName)(this) }) :
32
- options.logger;
33
- if (options.sagaType) {
34
- const SagaType = options.sagaType;
35
- this.#sagaFactory = params => new SagaType(params);
36
- this.#startsWith = SagaType.startsWith;
37
- this.#handles = SagaType.handles;
38
- }
39
- else if (options.sagaFactory) {
40
- if (!Array.isArray(options.startsWith))
41
- throw new TypeError('options.startsWith argument must be an Array');
42
- if (!Array.isArray(options.handles))
43
- throw new TypeError('options.handles argument must be an Array');
44
- this.#sagaFactory = options.sagaFactory;
45
- this.#startsWith = options.startsWith;
46
- this.#handles = options.handles;
47
- }
48
- else {
49
- throw new Error('Either sagaType or sagaFactory is required');
50
- }
51
- this.#eventStore.registerSagaStarters(options.startsWith);
52
- }
53
- /** Overrides observer subscribe method */
54
- subscribe(eventStore) {
55
- (0, utils_1.subscribe)(eventStore, this, {
56
- messageTypes: [...this.#startsWith, ...this.#handles],
57
- masterHandler: e => this.handle(e),
58
- queueName: this.#queueName
59
- });
60
- }
61
- /** Handle saga event */
62
- async handle(event) {
63
- if (!event)
64
- throw new TypeError('event argument required');
65
- if (!event.type)
66
- throw new TypeError('event.type argument required');
67
- const isSagaStarterEvent = this.#startsWith.includes(event.type);
68
- const saga = isSagaStarterEvent ?
69
- await this.#createSaga() :
70
- await this.#restoreSaga(event);
71
- const r = saga.apply(event);
72
- if (r instanceof Promise)
73
- await r;
74
- await this.#sendCommands(saga, event);
75
- // additional commands can be added by the saga.onError handler
76
- if (saga.uncommittedMessages.length)
77
- await this.#sendCommands(saga, event);
78
- }
79
- async #sendCommands(saga, event) {
80
- const commands = saga.uncommittedMessages;
81
- saga.resetUncommittedMessages();
82
- this.#logger?.debug(`"${Event.describe(event)}" processed, ${commands.map(c => c.type).join(',') || 'no commands'} produced`);
83
- for (const command of commands) {
84
- // attach event context to produced command
85
- if (command.context === undefined && event.context !== undefined)
86
- command.context = event.context;
87
- try {
88
- await this.#commandBus.sendRaw(command);
89
- }
90
- catch (err) {
91
- if (typeof saga.onError === 'function') {
92
- // let saga to handle the error
93
- saga.onError(err, { event, command });
94
- }
95
- else {
96
- throw err;
97
- }
98
- }
99
- }
100
- }
101
- /** Start new saga */
102
- async #createSaga() {
103
- const id = await this.#eventStore.getNewId();
104
- return this.#sagaFactory.call(null, { id });
105
- }
106
- /** Restore saga from event store */
107
- async #restoreSaga(event) {
108
- if (!event.sagaId)
109
- throw new TypeError(`${Event.describe(event)} does not contain sagaId`);
110
- const eventsIterable = this.#eventStore.getSagaEvents(event.sagaId, { beforeEvent: event });
111
- const events = await (0, utils_1.iteratorToArray)(eventsIterable);
112
- const saga = this.#sagaFactory.call(null, { id: event.sagaId, events });
113
- this.#logger?.info(`Saga state restored from ${events.length} event(s)`);
114
- return saga;
115
- }
116
- }
117
- exports.SagaEventHandler = SagaEventHandler;
118
- //# sourceMappingURL=SagaEventHandler.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"SagaEventHandler.js","sourceRoot":"","sources":["../src/SagaEventHandler.ts"],"names":[],"mappings":";;;AAAA,iCAAiC;AAcjC,mCAIiB;AAEjB;;;;;GAKG;AACH,MAAa,gBAAgB;IAE5B,WAAW,CAAc;IACzB,WAAW,CAAc;IACzB,UAAU,CAAU;IACpB,OAAO,CAAW;IAClB,YAAY,CAAyB;IACrC,WAAW,CAAW;IACtB,QAAQ,CAAW;IAEnB,YAAY,OAMX;QACA,IAAI,CAAC,OAAO;YACX,MAAM,IAAI,SAAS,CAAC,2BAA2B,CAAC,CAAC;QAClD,IAAI,CAAC,OAAO,CAAC,UAAU;YACtB,MAAM,IAAI,SAAS,CAAC,sCAAsC,CAAC,CAAC;QAC7D,IAAI,CAAC,OAAO,CAAC,UAAU;YACtB,MAAM,IAAI,SAAS,CAAC,sCAAsC,CAAC,CAAC;QAE7D,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC;QACtC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,SAAS,CAAC;QACpC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAC,MAAM,IAAI,OAAO,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC;YAC3D,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,OAAO,EAAE,IAAA,oBAAY,EAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC;YACvD,OAAO,CAAC,MAAM,CAAC;QAEhB,IAAI,OAAO,CAAC,QAAQ,EAAE,CAAC;YACtB,MAAM,QAAQ,GAAG,OAAO,CAAC,QAA4B,CAAC;YAEtD,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,EAAE,CAAC,IAAI,QAAQ,CAAC,MAAM,CAAC,CAAC;YACnD,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,UAAU,CAAC;YACvC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,OAAO,CAAC;QAClC,CAAC;aACI,IAAI,OAAO,CAAC,WAAW,EAAE,CAAC;YAC9B,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC;gBACrC,MAAM,IAAI,SAAS,CAAC,8CAA8C,CAAC,CAAC;YACrE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,OAAO,CAAC;gBAClC,MAAM,IAAI,SAAS,CAAC,2CAA2C,CAAC,CAAC;YAElE,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,WAAW,CAAC;YACxC,IAAI,CAAC,WAAW,GAAG,OAAO,CAAC,UAAU,CAAC;YACtC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC,OAAO,CAAC;QACjC,CAAC;aACI,CAAC;YACL,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC,CAAC;QAC/D,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,oBAAoB,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;IAC3D,CAAC;IAED,0CAA0C;IAC1C,SAAS,CAAC,UAAuB;QAChC,IAAA,iBAAS,EAAC,UAAU,EAAE,IAAI,EAAE;YAC3B,YAAY,EAAE,CAAC,GAAG,IAAI,CAAC,WAAW,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;YACrD,aAAa,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,CAAC;YAClC,SAAS,EAAE,IAAI,CAAC,UAAU;SAC1B,CAAC,CAAC;IACJ,CAAC;IAED,wBAAwB;IACxB,KAAK,CAAC,MAAM,CAAC,KAAa;QACzB,IAAI,CAAC,KAAK;YACT,MAAM,IAAI,SAAS,CAAC,yBAAyB,CAAC,CAAC;QAChD,IAAI,CAAC,KAAK,CAAC,IAAI;YACd,MAAM,IAAI,SAAS,CAAC,8BAA8B,CAAC,CAAC;QAErD,MAAM,kBAAkB,GAAG,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;QACjE,MAAM,IAAI,GAAG,kBAAkB,CAAC,CAAC;YAChC,MAAM,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;YAC1B,MAAM,IAAI,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;QAEhC,MAAM,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QAC5B,IAAI,CAAC,YAAY,OAAO;YACvB,MAAM,CAAC,CAAC;QAET,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;QAEtC,+DAA+D;QAC/D,IAAI,IAAI,CAAC,mBAAmB,CAAC,MAAM;YAClC,MAAM,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACxC,CAAC;IAED,KAAK,CAAC,aAAa,CAAC,IAAW,EAAE,KAAkB;QAClD,MAAM,QAAQ,GAAG,IAAI,CAAC,mBAAmB,CAAC;QAC1C,IAAI,CAAC,wBAAwB,EAAE,CAAC;QAEhC,IAAI,CAAC,OAAO,EAAE,KAAK,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,gBAAgB,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,aAAa,WAAW,CAAC,CAAC;QAE9H,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;YAEhC,2CAA2C;YAC3C,IAAI,OAAO,CAAC,OAAO,KAAK,SAAS,IAAI,KAAK,CAAC,OAAO,KAAK,SAAS;gBAC/D,OAAO,CAAC,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;YAEjC,IAAI,CAAC;gBACJ,MAAM,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;YACzC,CAAC;YACD,OAAO,GAAQ,EAAE,CAAC;gBACjB,IAAI,OAAO,IAAI,CAAC,OAAO,KAAK,UAAU,EAAE,CAAC;oBACxC,+BAA+B;oBAC/B,IAAI,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,KAAK,EAAE,OAAO,EAAE,CAAC,CAAC;gBACvC,CAAC;qBACI,CAAC;oBACL,MAAM,GAAG,CAAC;gBACX,CAAC;YACF,CAAC;QACF,CAAC;IACF,CAAC;IAED,qBAAqB;IACrB,KAAK,CAAC,WAAW;QAChB,MAAM,EAAE,GAAG,MAAM,IAAI,CAAC,WAAW,CAAC,QAAQ,EAAE,CAAC;QAC7C,OAAO,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;IAC7C,CAAC;IAED,oCAAoC;IACpC,KAAK,CAAC,YAAY,CAAC,KAAa;QAC/B,IAAI,CAAC,KAAK,CAAC,MAAM;YAChB,MAAM,IAAI,SAAS,CAAC,GAAG,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,0BAA0B,CAAC,CAAC;QAEzE,MAAM,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,CAAC,CAAC;QAC5F,MAAM,MAAM,GAAG,MAAM,IAAA,uBAAe,EAAC,cAAc,CAAC,CAAC;QAErD,MAAM,IAAI,GAAG,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,KAAK,CAAC,MAAM,EAAE,MAAM,EAAE,CAAC,CAAC;QACxE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,4BAA4B,MAAM,CAAC,MAAM,WAAW,CAAC,CAAC;QAEzE,OAAO,IAAI,CAAC;IACb,CAAC;CACD;AArID,4CAqIC"}
@@ -1,73 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.InMemoryEventStorage = void 0;
4
- const utils_1 = require("./utils");
5
- /**
6
- * A simple event storage implementation intended to use for tests only.
7
- * Storage content resets on each app restart.
8
- */
9
- class InMemoryEventStorage {
10
- #nextId = 0;
11
- #events = [];
12
- getNewId() {
13
- this.#nextId += 1;
14
- return String(this.#nextId);
15
- }
16
- async commitEvents(events) {
17
- await (0, utils_1.nextCycle)();
18
- this.#events = this.#events.concat(events);
19
- await (0, utils_1.nextCycle)();
20
- return events;
21
- }
22
- async *getAggregateEvents(aggregateId, options) {
23
- await (0, utils_1.nextCycle)();
24
- const afterVersion = options?.snapshot?.aggregateVersion;
25
- const results = !afterVersion ?
26
- this.#events.filter(e => e.aggregateId === aggregateId) :
27
- this.#events.filter(e => e.aggregateId === aggregateId &&
28
- e.aggregateVersion !== undefined &&
29
- e.aggregateVersion > afterVersion);
30
- await (0, utils_1.nextCycle)();
31
- yield* results;
32
- }
33
- async *getSagaEvents(sagaId, { beforeEvent }) {
34
- await (0, utils_1.nextCycle)();
35
- const results = this.#events.filter(e => e.sagaId === sagaId &&
36
- e.sagaVersion !== undefined &&
37
- beforeEvent.sagaVersion !== undefined &&
38
- e.sagaVersion < beforeEvent.sagaVersion);
39
- await (0, utils_1.nextCycle)();
40
- yield* results;
41
- }
42
- async *getEventsByTypes(eventTypes, options) {
43
- await (0, utils_1.nextCycle)();
44
- const lastEventId = options?.afterEvent?.id;
45
- if (options?.afterEvent && !lastEventId)
46
- throw new TypeError('options.afterEvent.id is required');
47
- let offsetFound = !lastEventId;
48
- for (const event of this.#events) {
49
- if (!offsetFound)
50
- offsetFound = event.id === lastEventId;
51
- else if (!eventTypes || eventTypes.includes(event.type))
52
- yield event;
53
- }
54
- }
55
- /**
56
- * Processes a batch of dispatch pipeline items, extracts the events,
57
- * commits them to the in-memory storage, and returns the original batch.
58
- *
59
- * This method is part of the `IDispatchPipelineProcessor` interface.
60
- */
61
- async process(batch) {
62
- const events = [];
63
- for (const { event } of batch) {
64
- if (!event)
65
- throw new Error('Event batch does not contain `event`');
66
- events.push(event);
67
- }
68
- await this.commitEvents(events);
69
- return batch;
70
- }
71
- }
72
- exports.InMemoryEventStorage = InMemoryEventStorage;
73
- //# sourceMappingURL=InMemoryEventStorage.js.map