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,160 +0,0 @@
1
- import * as Event from './Event';
2
- import {
3
- ICommandBus,
4
- IContainer,
5
- IEvent,
6
- IEventReceptor,
7
- IEventStore,
8
- ILogger,
9
- IObservable,
10
- ISaga,
11
- ISagaConstructor,
12
- ISagaFactory
13
- } from './interfaces';
14
-
15
- import {
16
- subscribe,
17
- getClassName,
18
- iteratorToArray
19
- } from './utils';
20
-
21
- /**
22
- * Listens to Saga events,
23
- * creates new saga or restores it from event store,
24
- * applies new events
25
- * and passes command(s) to command bus
26
- */
27
- export class SagaEventHandler implements IEventReceptor {
28
-
29
- #eventStore: IEventStore;
30
- #commandBus: ICommandBus;
31
- #queueName?: string;
32
- #logger?: ILogger;
33
- #sagaFactory: (params: any) => ISaga;
34
- #startsWith: string[];
35
- #handles: string[];
36
-
37
- constructor(options: Pick<IContainer, 'eventStore' | 'commandBus' | 'logger'> & {
38
- sagaType?: ISagaConstructor,
39
- sagaFactory?: ISagaFactory,
40
- queueName?: string,
41
- startsWith?: string[],
42
- handles?: string[]
43
- }) {
44
- if (!options)
45
- throw new TypeError('options argument required');
46
- if (!options.eventStore)
47
- throw new TypeError('options.eventStore argument required');
48
- if (!options.commandBus)
49
- throw new TypeError('options.commandBus argument required');
50
-
51
- this.#eventStore = options.eventStore;
52
- this.#commandBus = options.commandBus;
53
- this.#queueName = options.queueName;
54
- this.#logger = options.logger && 'child' in options.logger ?
55
- options.logger.child({ service: getClassName(this) }) :
56
- options.logger;
57
-
58
- if (options.sagaType) {
59
- const SagaType = options.sagaType as ISagaConstructor;
60
-
61
- this.#sagaFactory = params => new SagaType(params);
62
- this.#startsWith = SagaType.startsWith;
63
- this.#handles = SagaType.handles;
64
- }
65
- else if (options.sagaFactory) {
66
- if (!Array.isArray(options.startsWith))
67
- throw new TypeError('options.startsWith argument must be an Array');
68
- if (!Array.isArray(options.handles))
69
- throw new TypeError('options.handles argument must be an Array');
70
-
71
- this.#sagaFactory = options.sagaFactory;
72
- this.#startsWith = options.startsWith;
73
- this.#handles = options.handles;
74
- }
75
- else {
76
- throw new Error('Either sagaType or sagaFactory is required');
77
- }
78
-
79
- this.#eventStore.registerSagaStarters(options.startsWith);
80
- }
81
-
82
- /** Overrides observer subscribe method */
83
- subscribe(eventStore: IObservable) {
84
- subscribe(eventStore, this, {
85
- messageTypes: [...this.#startsWith, ...this.#handles],
86
- masterHandler: e => this.handle(e),
87
- queueName: this.#queueName
88
- });
89
- }
90
-
91
- /** Handle saga event */
92
- async handle(event: IEvent): Promise<void> {
93
- if (!event)
94
- throw new TypeError('event argument required');
95
- if (!event.type)
96
- throw new TypeError('event.type argument required');
97
-
98
- const isSagaStarterEvent = this.#startsWith.includes(event.type);
99
- const saga = isSagaStarterEvent ?
100
- await this.#createSaga() :
101
- await this.#restoreSaga(event);
102
-
103
- const r = saga.apply(event);
104
- if (r instanceof Promise)
105
- await r;
106
-
107
- await this.#sendCommands(saga, event);
108
-
109
- // additional commands can be added by the saga.onError handler
110
- if (saga.uncommittedMessages.length)
111
- await this.#sendCommands(saga, event);
112
- }
113
-
114
- async #sendCommands(saga: ISaga, event: IEvent<any>) {
115
- const commands = saga.uncommittedMessages;
116
- saga.resetUncommittedMessages();
117
-
118
- this.#logger?.debug(`"${Event.describe(event)}" processed, ${commands.map(c => c.type).join(',') || 'no commands'} produced`);
119
-
120
- for (const command of commands) {
121
-
122
- // attach event context to produced command
123
- if (command.context === undefined && event.context !== undefined)
124
- command.context = event.context;
125
-
126
- try {
127
- await this.#commandBus.sendRaw(command);
128
- }
129
- catch (err: any) {
130
- if (typeof saga.onError === 'function') {
131
- // let saga to handle the error
132
- saga.onError(err, { event, command });
133
- }
134
- else {
135
- throw err;
136
- }
137
- }
138
- }
139
- }
140
-
141
- /** Start new saga */
142
- async #createSaga(): Promise<ISaga> {
143
- const id = await this.#eventStore.getNewId();
144
- return this.#sagaFactory.call(null, { id });
145
- }
146
-
147
- /** Restore saga from event store */
148
- async #restoreSaga(event: IEvent): Promise<ISaga> {
149
- if (!event.sagaId)
150
- throw new TypeError(`${Event.describe(event)} does not contain sagaId`);
151
-
152
- const eventsIterable = this.#eventStore.getSagaEvents(event.sagaId, { beforeEvent: event });
153
- const events = await iteratorToArray(eventsIterable);
154
-
155
- const saga = this.#sagaFactory.call(null, { id: event.sagaId, events });
156
- this.#logger?.info(`Saga state restored from ${events.length} event(s)`);
157
-
158
- return saga;
159
- }
160
- }
@@ -1,108 +0,0 @@
1
- import {
2
- IIdentifierProvider,
3
- IEvent,
4
- IEventSet,
5
- EventQueryAfter,
6
- IEventStorageReader,
7
- IEventStream,
8
- IEventStorageWriter,
9
- Identifier,
10
- IDispatchPipelineProcessor,
11
- DispatchPipelineBatch
12
- } from '../interfaces';
13
- import { nextCycle } from './utils';
14
-
15
- /**
16
- * A simple event storage implementation intended to use for tests only.
17
- * Storage content resets on each app restart.
18
- */
19
- export class InMemoryEventStorage implements
20
- IEventStorageReader,
21
- IEventStorageWriter,
22
- IIdentifierProvider,
23
- IDispatchPipelineProcessor {
24
-
25
- #nextId: number = 0;
26
- #events: IEventSet = [];
27
-
28
- getNewId(): string {
29
- this.#nextId += 1;
30
- return String(this.#nextId);
31
- }
32
-
33
- async commitEvents(events: IEventSet): Promise<IEventSet> {
34
- await nextCycle();
35
-
36
- this.#events = this.#events.concat(events);
37
-
38
- await nextCycle();
39
-
40
- return events;
41
- }
42
-
43
- async* getAggregateEvents(aggregateId: Identifier, options?: { snapshot: IEvent }): IEventStream {
44
- await nextCycle();
45
-
46
- const afterVersion = options?.snapshot?.aggregateVersion;
47
- const results = !afterVersion ?
48
- this.#events.filter(e => e.aggregateId === aggregateId) :
49
- this.#events.filter(e =>
50
- e.aggregateId === aggregateId &&
51
- e.aggregateVersion !== undefined &&
52
- e.aggregateVersion > afterVersion);
53
-
54
- await nextCycle();
55
-
56
- yield* results;
57
- }
58
-
59
- async* getSagaEvents(sagaId: Identifier, { beforeEvent }: { beforeEvent: IEvent }): IEventStream {
60
- await nextCycle();
61
-
62
- const results = this.#events.filter(e =>
63
- e.sagaId === sagaId &&
64
- e.sagaVersion !== undefined &&
65
- beforeEvent.sagaVersion !== undefined &&
66
- e.sagaVersion < beforeEvent.sagaVersion);
67
-
68
- await nextCycle();
69
-
70
- yield* results;
71
- }
72
-
73
- async* getEventsByTypes(eventTypes: Readonly<string[]>, options?: EventQueryAfter): IEventStream {
74
- await nextCycle();
75
-
76
- const lastEventId = options?.afterEvent?.id;
77
- if (options?.afterEvent && !lastEventId)
78
- throw new TypeError('options.afterEvent.id is required');
79
-
80
- let offsetFound = !lastEventId;
81
- for (const event of this.#events) {
82
- if (!offsetFound)
83
- offsetFound = event.id === lastEventId;
84
- else if (!eventTypes || eventTypes.includes(event.type))
85
- yield event;
86
- }
87
- }
88
-
89
- /**
90
- * Processes a batch of dispatch pipeline items, extracts the events,
91
- * commits them to the in-memory storage, and returns the original batch.
92
- *
93
- * This method is part of the `IDispatchPipelineProcessor` interface.
94
- */
95
- async process(batch: DispatchPipelineBatch): Promise<DispatchPipelineBatch> {
96
- const events: IEvent[] = [];
97
- for (const { event } of batch) {
98
- if (!event)
99
- throw new Error('Event batch does not contain `event`');
100
-
101
- events.push(event);
102
- }
103
-
104
- await this.commitEvents(events);
105
-
106
- return batch;
107
- }
108
- }
@@ -1,43 +0,0 @@
1
- import { Deferred } from '../utils';
2
-
3
- export class InMemoryLock {
4
-
5
- #lockMarker: Deferred<void> | undefined;
6
-
7
- /**
8
- * Indicates if lock is acquired
9
- */
10
- get locked(): boolean {
11
- return !!this.#lockMarker;
12
- }
13
-
14
- /**
15
- * Acquire the lock on the current instance.
16
- * Resolves when the lock is successfully acquired
17
- */
18
- async lock(): Promise<void> {
19
- while (this.locked)
20
- await this.once('unlocked');
21
-
22
- this.#lockMarker = new Deferred();
23
- }
24
-
25
- /**
26
- * Release the lock acquired earlier
27
- */
28
- async unlock(): Promise<void> {
29
- this.#lockMarker?.resolve();
30
- this.#lockMarker = undefined;
31
- }
32
-
33
- /**
34
- * Wait until the lock is released.
35
- * Resolves immediately if the lock is not acquired
36
- */
37
- once(event: 'unlocked'): Promise<void> {
38
- if (event !== 'unlocked')
39
- throw new TypeError(`Unexpected event type: ${event}`);
40
-
41
- return this.#lockMarker?.promise ?? Promise.resolve();
42
- }
43
- }
@@ -1,140 +0,0 @@
1
- import {
2
- DispatchPipelineBatch,
3
- ICommand,
4
- IDispatchPipelineProcessor,
5
- IEvent,
6
- IMessageBus,
7
- IMessageHandler,
8
- IObservable
9
- } from '../interfaces';
10
-
11
- /**
12
- * Default implementation of the message bus.
13
- * Keeps all subscriptions and messages in memory.
14
- */
15
- export class InMemoryMessageBus implements IMessageBus, IDispatchPipelineProcessor {
16
-
17
- protected handlers: Map<string, Set<IMessageHandler>> = new Map();
18
- protected uniqueEventHandlers: boolean;
19
- protected queueName: string | undefined;
20
- protected queues: Map<string, IMessageBus> = new Map();
21
-
22
- constructor({ queueName, uniqueEventHandlers = !!queueName }: {
23
- queueName?: string,
24
- uniqueEventHandlers?: boolean
25
- } = {}) {
26
- this.queueName = queueName;
27
- this.uniqueEventHandlers = uniqueEventHandlers;
28
- }
29
-
30
- /**
31
- * Subscribe to message type
32
- */
33
- on(messageType: string, handler: IMessageHandler) {
34
- if (typeof messageType !== 'string' || !messageType.length)
35
- throw new TypeError('messageType argument must be a non-empty String');
36
- if (typeof handler !== 'function')
37
- throw new TypeError('handler argument must be a Function');
38
- if (arguments.length !== 2)
39
- throw new TypeError(`2 arguments are expected, but ${arguments.length} received`);
40
-
41
- // Events published to a named queue must be consumed only once.
42
- // For example, for sending a welcome email, NotificationReceptor will subscribe to "notifications:userCreated".
43
- // Since we use an in-memory bus, there is no need to track message handling by multiple distributed
44
- // subscribers, and we only need to make sure that no more than 1 such subscriber will be created
45
- if (!this.handlers.has(messageType))
46
- this.handlers.set(messageType, new Set());
47
- else if (this.uniqueEventHandlers)
48
- throw new Error(`"${messageType}" handler is already set up on the "${this.queueName}" queue`);
49
-
50
- this.handlers.get(messageType)?.add(handler);
51
- }
52
-
53
- /**
54
- * Get or create a named queue.
55
- * Named queues support only one handler per event type.
56
- */
57
- queue(queueName: string): IObservable {
58
- let queue = this.queues.get(queueName);
59
- if (!queue) {
60
- queue = new InMemoryMessageBus({ queueName, uniqueEventHandlers: true });
61
- this.queues.set(queueName, queue);
62
- }
63
-
64
- return queue;
65
- }
66
-
67
- /**
68
- * Remove subscription
69
- */
70
- off(messageType: string, handler: IMessageHandler) {
71
- if (typeof messageType !== 'string' || !messageType.length)
72
- throw new TypeError('messageType argument must be a non-empty String');
73
- if (typeof handler !== 'function')
74
- throw new TypeError('handler argument must be a Function');
75
- if (arguments.length !== 2)
76
- throw new TypeError(`2 arguments are expected, but ${arguments.length} received`);
77
- if (!this.handlers.has(messageType))
78
- throw new Error(`No ${messageType} subscribers found`);
79
-
80
- this.handlers.get(messageType)?.delete(handler);
81
- }
82
-
83
- /**
84
- * Send command to exactly 1 command handler
85
- */
86
- async send(command: ICommand): Promise<any> {
87
- if (typeof command !== 'object' || !command)
88
- throw new TypeError('command argument must be an Object');
89
- if (typeof command.type !== 'string' || !command.type.length)
90
- throw new TypeError('command.type argument must be a non-empty String');
91
-
92
- const handlers = this.handlers.get(command.type);
93
- if (!handlers || !handlers.size)
94
- throw new Error(`No '${command.type}' subscribers found`);
95
- if (handlers.size > 1)
96
- throw new Error(`More than one '${command.type}' subscriber found`);
97
-
98
- const commandHandler = handlers.values().next().value;
99
-
100
- return commandHandler!(command);
101
- }
102
-
103
- /**
104
- * Publish event to all subscribers (if any)
105
- */
106
- async publish(event: IEvent, meta?: Record<string, any>): Promise<any> {
107
- if (typeof event !== 'object' || !event)
108
- throw new TypeError('event argument must be an Object');
109
- if (typeof event.type !== 'string' || !event.type.length)
110
- throw new TypeError('event.type argument must be a non-empty String');
111
-
112
- const handlers = [
113
- ...this.handlers.get(event.type) || [],
114
- ...Array.from(this.queues.values()).map(namedQueue =>
115
- (e: IEvent, m?: Record<string, any>) => namedQueue.publish(e, m))
116
- ];
117
-
118
- return Promise.all(handlers.map(handler => handler(event, meta)));
119
- }
120
-
121
- /**
122
- * Processes a batch of events and publishes them to the fanout exchange.
123
- *
124
- * This method is part of the `IDispatchPipelineProcessor` interface.
125
- */
126
- async process(batch: DispatchPipelineBatch): Promise<DispatchPipelineBatch> {
127
- for (const { event, origin } of batch) {
128
- // Skip publishing if the event was dispatched from external source
129
- if (origin === 'external')
130
- continue;
131
-
132
- if (!event)
133
- throw new Error('Event batch does not contain `event`');
134
-
135
- await this.publish(event);
136
- }
137
-
138
- return batch;
139
- }
140
- }
@@ -1,89 +0,0 @@
1
- import {
2
- DispatchPipelineBatch,
3
- IAggregateSnapshotStorage,
4
- IContainer,
5
- Identifier,
6
- IDispatchPipelineProcessor,
7
- IEvent,
8
- ILogger
9
- } from '../interfaces';
10
- import * as Event from '../Event';
11
-
12
- const SNAPSHOT_EVENT_TYPE = 'snapshot';
13
- const isSnapshotEvent = (event?: IEvent): event is IEvent & { type: 'snapshot' } =>
14
- (!!event && event.type === SNAPSHOT_EVENT_TYPE);
15
-
16
- /**
17
- * In-memory storage for aggregate snapshots.
18
- * Storage content resets on app restart
19
- */
20
- export class InMemorySnapshotStorage implements IAggregateSnapshotStorage, IDispatchPipelineProcessor {
21
-
22
- #snapshots: Map<Identifier, IEvent> = new Map();
23
- #logger: ILogger | undefined;
24
-
25
- constructor(c?: Partial<Pick<IContainer, 'logger'>>) {
26
- this.#logger = c?.logger && 'child' in c?.logger ?
27
- c?.logger.child({ service: new.target.name }) :
28
- c?.logger;
29
- }
30
-
31
- /**
32
- * Get latest aggregate snapshot
33
- */
34
- async getAggregateSnapshot(aggregateId: string): Promise<IEvent | undefined> {
35
- return this.#snapshots.get(aggregateId);
36
- }
37
-
38
- /**
39
- * Save new aggregate snapshot
40
- */
41
- async saveAggregateSnapshot(snapshotEvent: IEvent) {
42
- if (!snapshotEvent.aggregateId)
43
- throw new TypeError('event.aggregateId is required');
44
-
45
- this.#logger?.debug(`Persisting ${Event.describe(snapshotEvent)}`);
46
-
47
- this.#snapshots.set(snapshotEvent.aggregateId, snapshotEvent);
48
- }
49
-
50
- /**
51
- * Delete aggregate snapshot
52
- */
53
- deleteAggregateSnapshot<TState>(snapshotEvent: IEvent<TState>): Promise<void> | void {
54
- if (!snapshotEvent.aggregateId)
55
- throw new TypeError('snapshotEvent.aggregateId argument required');
56
-
57
- this.#logger?.debug(`Removing ${Event.describe(snapshotEvent)}`);
58
-
59
- this.#snapshots.delete(snapshotEvent.aggregateId);
60
- }
61
-
62
- /**
63
- * Processes a batch of events, saves any snapshot events found, and returns the batch
64
- * without the snapshot events.
65
- *
66
- * This method is part of the `IDispatchPipelineProcessor` interface.
67
- */
68
- async process(batch: DispatchPipelineBatch): Promise<DispatchPipelineBatch> {
69
- const snapshotEvents = batch.map(e => e.event).filter(isSnapshotEvent);
70
- for (const event of snapshotEvents)
71
- await this.saveAggregateSnapshot(event);
72
-
73
- return batch.filter(e => !isSnapshotEvent(e.event));
74
- }
75
-
76
- /**
77
- * Reverts the snapshots associated with the events in the given batch.
78
- * It filters the batch for snapshot events and deletes the corresponding aggregate snapshots.
79
- *
80
- * This method is part of the `IDispatchPipelineProcessor` interface.
81
- *
82
- * @param batch The batch of events to revert snapshots for.
83
- */
84
- async revert(batch: DispatchPipelineBatch): Promise<void> {
85
- const snapshotEvents = batch.map(e => e.event).filter(isSnapshotEvent);
86
- for (const snapshotEvent of snapshotEvents)
87
- await this.deleteAggregateSnapshot(snapshotEvent);
88
- }
89
- }