node-cqrs 1.0.0-rc.9 → 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 -123
  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 -131
  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 -173
  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
package/README.md CHANGED
@@ -1,188 +1,504 @@
1
1
  node-cqrs
2
2
  =========
3
3
 
4
- [![NPM Version](https://img.shields.io/npm/v/node-cqrs.svg)](https://www.npmjs.com/package/node-cqrs)
5
- [![Audit Status](https://github.com/snatalenko/node-cqrs/actions/workflows/audit.yml/badge.svg)](https://github.com/snatalenko/node-cqrs/actions/workflows/audit.yml)
6
- [![Tests Status](https://github.com/snatalenko/node-cqrs/actions/workflows/tests.yml/badge.svg)](https://github.com/snatalenko/node-cqrs/actions/workflows/tests.yml)
7
- [![Coverage Status](https://coveralls.io/repos/github/snatalenko/node-cqrs/badge.svg?branch=master)](https://coveralls.io/github/snatalenko/node-cqrs?branch=master)
8
- [![NPM Downloads](https://img.shields.io/npm/dm/node-cqrs.svg)](https://www.npmjs.com/package/node-cqrs)
4
+ [![Version](https://img.shields.io/npm/v/node-cqrs.svg)](https://www.npmjs.com/package/node-cqrs)
5
+ [![Coverage](https://coveralls.io/repos/github/snatalenko/node-cqrs/badge.svg)](https://coveralls.io/github/snatalenko/node-cqrs)
6
+ [![Downloads](https://img.shields.io/npm/dm/node-cqrs.svg)](https://www.npmjs.com/package/node-cqrs)
7
+ [![Stars](https://img.shields.io/github/stars/snatalenko/node-cqrs?style=flat&color=yellow)](https://github.com/snatalenko/node-cqrs)
8
+ [![Forks](https://img.shields.io/github/forks/snatalenko/node-cqrs?style=flat&color=yellow)](https://github.com/snatalenko/node-cqrs)
9
+ [![License](https://img.shields.io/github/license/snatalenko/node-cqrs.svg)](https://github.com/snatalenko/node-cqrs)
10
+ [![Tests/Audit](https://github.com/snatalenko/node-cqrs/actions/workflows/ci.yml/badge.svg)](https://github.com/snatalenko/node-cqrs/actions/workflows/ci.yml)
11
+
12
+ Infrastructure-agnostic building blocks for CQRS/ES, inspired by Lokad.CQRS.
13
+
14
+ CQRS/ES can be simple in a single process - minimal code, no framework:
15
+ [examples/user-domain/framework-free](examples/user-domain/framework-free/index.ts).
16
+ This library handles the "boring but hard" parts required in distributed environments:
17
+
18
+ - safer async command + event handling (per-aggregate FIFO, shared restore, fewer footguns)
19
+ - restart-safe projections/views (catch-up with checkpoints, readiness gates, locking)
20
+ - snapshots for fast rehydrate (automatic snapshot events + restore)
21
+ - pluggable dispatch pipeline (encode/persist/fan-out; order is explicit)
22
+ - conflict-safe writes (optimistic concurrency + retry with clean rehydrate)
23
+ - routed pipelines with backpressure (named pipelines + concurrency limits)
24
+ - competing-consumer delivery (named queues when supported)
25
+ - selective restore with correct versioning (filter + tail to keep versions right)
26
+ - sagas with built-in correlation (event-id origins + sagaOrigins propagation)
27
+
28
+ Built around ES6/TypeScript classes and dependency injection - swap implementations without patching the library.
29
+
30
+ ## Table of Contents
31
+
32
+ - [Overview](#overview)
33
+ - [Installation](#installation)
34
+ - [ContainerBuilder](#containerbuilder)
35
+ - [Commands](#commands)
36
+ - [Aggregates (write model)](#aggregates-write-model)
37
+ - [AbstractAggregate](#abstractaggregate)
38
+ - [Aggregate State](#aggregate-state)
39
+ - [External Dependencies](#external-dependencies)
40
+ - [Projections and Views (read model)](#projections-and-views-read-model)
41
+ - [AbstractProjection](#abstractprojection)
42
+ - [View restoring on start](#view-restoring-on-start)
43
+ - [Accessing views](#accessing-views)
44
+ - [Sagas](#sagas)
45
+ - [Infrastructure modules](#infrastructure-modules)
46
+ - [In-memory](#in-memory)
47
+ - [SQLite](#sqlite)
48
+ - [RabbitMQ](#rabbitmq)
49
+ - [Workers](#workers)
50
+ - [Examples](#examples)
51
+
9
52
 
10
53
  ## Overview
11
54
 
12
- The package provides building blocks for making a CQRS-ES application. It was inspired by Lokad.CQRS, but not tied to a specific storage implementation or infrastructure. It favors ES6 classes and dependency injection, so any components can be modified or replaced with your own implementations without hacks to the package codebase.
55
+ ![Overview](docs/images/node-cqrs-flow.svg)
56
+
57
+
58
+ Commands and events are loosely typed objects implementing the [`IMessage`](src/interfaces/IMessage.ts) interface:
59
+
60
+ ```ts
61
+ interface IMessage<TPayload = any> {
62
+ type: string;
63
+
64
+ aggregateId?: string | number;
65
+ aggregateVersion?: number;
66
+ sagaOrigins?: Record<string, string>;
67
+
68
+ payload: TPayload;
69
+ context?: any;
70
+ }
71
+ ```
72
+
73
+ Domain logic lives in three building blocks:
74
+
75
+ - **[Aggregates](#aggregates-write-model)** - handle commands and emit events
76
+ - **[Projections](#projections-and-views-read-model)** - consume events and update views
77
+ - **[Sagas](#sagas)** - manage processes by reacting to events and enqueueing follow-up commands
78
+
79
+ Message delivery is handled by the following components, in order:
80
+
81
+ - **[Command Bus](src/in-memory/InMemoryMessageBus.ts)** - routes commands to handlers
82
+ - **[Aggregate Command Handler](src/AggregateCommandHandler.ts)** - restores aggregate state and executes commands
83
+ - **[Event Store](src/EventStore.ts)** — runs the event dispatch pipeline (e.g. encoding, persistence), then publishes events to the event bus for delivery to all subscribers
84
+ - **[Saga Event Handler](src/SagaEventHandler.ts)** - restores saga state and applies events
85
+
86
+ > `src/`, `tests/`, and `examples/` are good entry points - the codebase is intentionally small and readable.
87
+
13
88
 
14
- [Documentation at node-cqrs.org](https://www.node-cqrs.org)
89
+ ## Installation
15
90
 
91
+ ```bash
92
+ npm install node-cqrs
93
+ ```
94
+
95
+ Node.js 16+ and browsers are supported.
96
+
97
+ Optional peer dependencies:
98
+
99
+ | Module | Packages |
100
+ |--------|----------|
101
+ | SQLite | `better-sqlite3`, `md5` |
102
+ | RabbitMQ | `amqplib` |
103
+ | Worker threads | `comlink` |
16
104
 
17
- Your app is expected to operate with loosely typed commands and events that match the following interface:
105
+
106
+ ## ContainerBuilder
107
+
108
+ Wire buses, the event store, and your domain components with dependency injection:
18
109
 
19
110
  ```ts
20
- declare interface IMessage {
21
- type: string,
111
+ const builder = new ContainerBuilder();
22
112
 
23
- aggregateId?: string|number,
24
- aggregateVersion?: number,
113
+ builder.register(InMemoryEventStorage); // implements IEventStorageReader, IDispatchPipelineProcessor, and IIdentifierProvider
114
+ builder.registerAggregate(UserAggregate);
115
+ builder.registerProjection(UsersProjection, 'usersView');
116
+ builder.registerSaga(WelcomeEmailSaga);
25
117
 
26
- sagaId?: string|number,
27
- sagaVersion?: number,
118
+ const { commandBus, eventStore, usersView } = builder.container();
119
+ ```
28
120
 
29
- payload?: any,
30
- context?: any
31
- }
121
+ <details>
122
+ <summary>Manual setup (without DI container)</summary>
123
+
124
+ ```ts
125
+ const commandBus = new InMemoryMessageBus();
126
+ const eventBus = new InMemoryMessageBus();
127
+ const eventStorage = new InMemoryEventStorage();
128
+ const eventStore = new EventStore({
129
+ eventStorageReader: eventStorage,
130
+ identifierProvider: eventStorage,
131
+ eventDispatchPipeline: [eventStorage],
132
+ eventBus
133
+ });
134
+
135
+ const aggregateCommandHandler = new AggregateCommandHandler({ eventStore, aggregateType: UserAggregate });
136
+ aggregateCommandHandler.subscribe(commandBus);
137
+
138
+ const projection = new UsersProjection();
139
+ projection.subscribe(eventStore);
140
+ projection.restore(eventStore);
141
+ const users = projection.view;
142
+ ```
143
+
144
+ </details>
145
+
146
+
147
+ ## Commands
148
+
149
+ Commands represent intent. Send them via `commandBus`:
150
+
151
+ ```ts
152
+ commandBus.send('signupUser', undefined, { payload: { profile, password } });
153
+ // or
154
+ commandBus.send({ type: 'signupUser', payload: { profile, password } });
32
155
  ```
33
156
 
34
- Domain business logic should be placed in Aggregate, Saga and Projection classes:
157
+ Commands are handled by [Aggregates](#aggregates-write-model) and may also be enqueued by [Sagas](#sagas).
35
158
 
36
- - [Aggregates](entities/Aggregate/README.MD) handle commands and emit events
37
- - [Sagas](entities/Saga/README.MD) handle events and enqueue commands
38
- - [Projections](entities/Projection/README.md) listen to events and update views
39
159
 
160
+ ## Aggregates (write model)
40
161
 
41
- Message delivery is being handled by the following services (in order of appearance):
162
+ Aggregates handle commands, validate business rules, and emit events.
163
+ Minimal contract ([IAggregate](src/interfaces/IAggregate.ts)):
42
164
 
43
- - **Command Bus** delivers commands to command handlers
44
- - [Aggregate Command Handler](middleware/AggregateCommandHandler.md) restores an aggregate state, executes a command
45
- - **Event Store** persists events and deliver them to event handlers (saga event handlers, projections or any other custom services)
46
- - **Saga Event Handler** restores saga state and applies event
165
+ ```ts
166
+ interface IAggregate {
167
+
168
+ /**
169
+ * Applies a single event to update the aggregate's internal state.
170
+ *
171
+ * This method is used primarily when rehydrating the aggregate
172
+ * from the persisted sequence of events
173
+ *
174
+ * @param event - The event to be applied
175
+ */
176
+ mutate(event: IEvent): void;
177
+
178
+ /**
179
+ * Processes a command by executing the aggregate's business logic,
180
+ * resulting in new events that capture the state changes.
181
+ * It serves as the primary entry point for invoking aggregate behavior
182
+ *
183
+ * @param command - The command to be processed
184
+ * @returns A set of events produced by the command
185
+ */
186
+ handle(command: ICommand): IEventSet | Promise<IEventSet>;
187
+ }
188
+ ```
47
189
 
190
+ ### AbstractAggregate
48
191
 
49
- From a high level, this is how the command/event flow looks like:
192
+ The recommended base class. Public method names are matched to command types - `createUser()` handles `createUser`:
50
193
 
51
- ![Overview](docs/images/node-cqrs-components.png)
194
+ ```ts
195
+ class UserAggregate extends AbstractAggregate<void> {
196
+ createUser(payload: CreateUserCommandPayload) {
197
+ this.emit('userCreated', { username: payload.username });
198
+ }
199
+ }
200
+ ```
52
201
 
202
+ Override `static get handles()` to declare command types explicitly.
53
203
 
54
- ## Getting Started
204
+ ### Aggregate State
55
205
 
56
- You can find sample code of a User domain in the **/examples** folder.
206
+ Keep state separate from command handlers - derive it by projecting the aggregate's own events:
57
207
 
208
+ ```ts
209
+ class UserAggregateState {
210
+ passwordHash: string;
58
211
 
59
- ### Your App → Command → Aggregate
212
+ passwordChanged(event: IEvent<PasswordChangedEventPayload>) {
213
+ this.passwordHash = event.payload.passwordHash;
214
+ }
215
+ }
60
216
 
61
- Describe an aggregate that handles a command:
217
+ class UserAggregate extends AbstractAggregate<UserAggregateState> {
218
+ protected readonly state = new UserAggregateState();
62
219
 
63
- ```js
64
- const { AbstractAggregate } = require('node-cqrs');
220
+ changePassword(payload: ChangePasswordCommandPayload) {
221
+ if (md5(payload.oldPassword) !== this.state.passwordHash)
222
+ throw new Error('Invalid password');
65
223
 
66
- class UserAggregate extends AbstractAggregate {
67
- static get handles() {
68
- return ['createUser'];
69
- }
70
-
71
- createUser(commandPayload) {
72
- // ...
73
- }
224
+ this.emit('passwordChanged', { passwordHash: md5(payload.newPassword) });
225
+ }
74
226
  }
75
227
  ```
76
228
 
77
- Then register aggregate in the [DI container](middleware/DIContainer.md).
78
- All the wiring can be done manually, without a DI container (you can find it in samples), but with container it’s just easier:
229
+ State **must not throw** - all validation belongs in the aggregate command handler.
79
230
 
80
- ```js
81
- const { ContainerBuilder, InMemoryEventStorage } = require('node-cqrs');
231
+ ### External Dependencies
82
232
 
83
- const builder = new ContainerBuilder();
84
- builder.register(InMemoryEventStorage).as('storage');
233
+ Constructor arguments are injected automatically by the DI container:
234
+
235
+ ```ts
236
+ class UserAggregate extends AbstractAggregate {
237
+ constructor({ id, authService }) {
238
+ super({ id });
239
+ this._authService = authService;
240
+ }
241
+
242
+ async signupUser(payload) {
243
+ await this._authService.registerUser(payload);
244
+ }
245
+ }
246
+
247
+ builder.register(AuthService).as('authService');
85
248
  builder.registerAggregate(UserAggregate);
249
+ ```
250
+
86
251
 
87
- const container = builder.container();
252
+ ## Projections and Views (read model)
253
+
254
+ Projections listen to events and update views.
255
+ Minimal contract ([IProjection](src/interfaces/IProjection.ts)):
256
+
257
+ ```ts
258
+ interface IProjection<TView> extends IObserver {
259
+ readonly view: TView;
260
+
261
+ /** Subscribe to new events */
262
+ subscribe(eventStore: IObservable): Promise<void> | void;
263
+
264
+ /** Restore view state from not-yet-projected events */
265
+ restore(eventStore: IEventStorageReader): Promise<void> | void;
266
+
267
+ /** Project new event */
268
+ project(event: IEvent): Promise<void> | void;
269
+ }
88
270
  ```
89
271
 
90
- Then send a command:
272
+ ### AbstractProjection
91
273
 
92
- ```js
93
- const userAggregateId = undefined;
94
- const payload = {
95
- username: 'john',
96
- password: 'test'
97
- };
274
+ Same name-matching rule as AbstractAggregate - `userCreated()` handles the `userCreated` event:
98
275
 
99
- container.commandBus.send('createUser', userAggregateId, { payload });
276
+ ```ts
277
+ class UsersProjection extends AbstractProjection<Map<string, { username: string }>> {
278
+ constructor() {
279
+ super();
280
+ this.view = new Map();
281
+ }
282
+
283
+ userCreated(event: IEvent<UserCreatedEventPayload>) {
284
+ this.view.set(event.aggregateId as string, { username: event.payload.username });
285
+ }
286
+ }
100
287
  ```
101
288
 
102
- Behind the scene, an AggregateCommandHandler will catch the command,
103
- try to load an aggregate event stream and project it to aggregate state,
104
- then it will pass the command payload to the `createUser` handler we’ve defined earlier.
289
+ Override `static get handles()` to declare event types explicitly.
105
290
 
106
- The `createUser` implementation can look like this:
291
+ ### View restoring on start
107
292
 
108
- ```js
109
- createUser(commandPayload) {
110
- const { username, password } = commandPayload;
293
+ For persistent views and safe restarts, implement [IViewLocker](src/interfaces/IViewLocker.ts) and [IEventLocker](src/interfaces/IEventLocker.ts) on the projection `view` to enable catch-up and last-processed checkpoints.
294
+
295
+ ### Accessing views
296
+
297
+ ```ts
298
+ interface IMyContainer extends IContainer { // optional interface for container typing
299
+ usersView: UsersView;
300
+ }
111
301
 
112
- this.emit('userCreated', {
113
- username,
114
- passwordHash: md5Hash(password)
115
- });
116
- }
302
+ const builder = new ContainerBuilder<IMyContainer>();
303
+ builder.registerProjection(UsersProjection, 'usersView');
304
+
305
+ const { usersView } = builder.container();
117
306
  ```
118
307
 
119
- Once the above method is executed, the emitted userCreated event will be persisted and delivered to event handlers (sagas, projections or any other custom event receptors).
308
+ For projections that manage and need to expose multiple views:
120
309
 
310
+ ```ts
311
+ builder.registerProjection(UsersProjection).as('usersProjection');
312
+ builder.register(c => c.usersProjection.users).as('usersView');
313
+ builder.register(c => c.usersProjection.connections).as('connectionsView');
314
+ ```
121
315
 
122
- ### Aggregate → Event → Projection → View
123
316
 
124
- Now it’s time to work on a read model. We’ll need a projection that will handle our events. Projection must implement 2 methods: `subscribe(eventStore)` and `project(event)` .
125
- To make it easier, you can extend an `AbstractProjection`:
317
+ ## Sagas
126
318
 
127
- ```js
128
- const { AbstractProjection } = require('node-cqrs');
129
-
130
- class UsersProjection extends AbstractProjection {
131
- static get handles() {
132
- return ['userCreated'];
133
- }
134
-
135
- userCreated(event) {
136
- // ...
137
- }
319
+ Sagas coordinate multi-step processes by reacting to events and enqueueing follow-up commands.
320
+
321
+ ```ts
322
+ class WelcomeEmailSaga extends AbstractSaga {
323
+ userSignedUp(event) {
324
+ this.enqueue('sendWelcomeEmail', undefined, { email: event.payload.email });
325
+ }
138
326
  }
327
+
328
+ builder.register(EventIdAugmentor).as('eventIdAugmenter'); // required: adds event.id
329
+ builder.registerSaga(WelcomeEmailSaga);
139
330
  ```
140
331
 
141
- By default, projection uses async `InMemoryView` for inner view, but we’ll use `Map` to make it more familiar:
332
+ - Handler methods are named after event types (`userSignedUp` handles `userSignedUp`)
333
+ - `this.enqueue(commandType, aggregateId, payload)` produces commands
334
+ - `EventIdAugmentor` must be in the dispatch pipeline - starter events use `event.id` as the saga origin
335
+ - `static sagaDescriptor` (optional) - stable key for `message.sagaOrigins`, defaults to class name
142
336
 
143
- ```js
144
- class UsersProjection extends AbstractProjection {
145
- get view() {
146
- return this._view || (this._view = new Map());
147
- }
337
+ `handle(event)` runs the handler before `mutate(event)`, so handlers always see the previous state.
148
338
 
149
- // ...
150
- }
339
+ Saga context is tracked in `message.sagaOrigins[sagaDescriptor]`, storing the starter event id. A saga starts when `sagaOrigins[sagaDescriptor]` is absent and continues when it is present. A single event type can start multiple saga types.
340
+
341
+ <details>
342
+ <summary><strong>Optional: explicit startsWith/handles</strong></summary>
343
+
344
+ By default, the saga starts on any handled event that does not have `sagaOrigins[sagaDescriptor]` and continues when it does.
345
+
346
+ For strict, explicit routing:
347
+ - `static startsWith`: event types allowed to start a saga
348
+ - `static handles`: additional event types to subscribe to
349
+ </details>
350
+
351
+ <details>
352
+ <summary><strong>Manual wiring (without DI container)</strong></summary>
353
+
354
+ ```ts
355
+ const commandBus = new InMemoryMessageBus();
356
+ const eventBus = new InMemoryMessageBus();
357
+ const eventStorage = new InMemoryEventStorage();
358
+ const eventStore = new EventStore({
359
+ eventStorageReader: eventStorage,
360
+ identifierProvider: eventStorage,
361
+ eventDispatchPipeline: [
362
+ new EventIdAugmentor({ identifierProvider: eventStorage }),
363
+ eventStorage
364
+ ],
365
+ eventBus
366
+ });
367
+
368
+ SignupAggregate.register(eventStore, commandBus);
369
+ WelcomeEmailSaga.register(eventStore, commandBus);
151
370
  ```
152
371
 
153
- With `Map` view, our event handler can look this way:
372
+ </details>
154
373
 
155
- ```js
156
- class UsersProjection extends AbstractProjection {
157
- // ...
158
-
159
- userCreated(event) {
160
- this.view.set(event.aggregateId, {
161
- username: event.payload.username
162
- });
163
- }
374
+ Minimal contract ([ISaga](src/interfaces/ISaga.ts)):
375
+
376
+ ```ts
377
+ interface ISaga {
378
+
379
+ /**
380
+ * Apply a historical event to restore saga state.
381
+ */
382
+ mutate(event: IEvent): unknown | Promise<unknown>;
383
+
384
+ /**
385
+ * Process an incoming event.
386
+ *
387
+ * @returns Commands produced by the saga in response to the event
388
+ */
389
+ handle(event: IEvent): ReadonlyArray<ICommand> | Promise<ReadonlyArray<ICommand>>;
164
390
  }
165
391
  ```
166
392
 
167
- Once the projection is ready, it can be registered in the DI container:
393
+
394
+ ## Infrastructure modules
395
+
396
+ | Module | Import | Use case |
397
+ |--------|--------|----------|
398
+ | In-memory | `node-cqrs` | Tests and local development |
399
+ | SQLite | `node-cqrs/sqlite` | Persistent views with catch-up |
400
+ | RabbitMQ | `node-cqrs/rabbitmq` | Cross-process event distribution |
401
+ | Workers | `node-cqrs/workers` | CPU-heavy projections in worker threads |
402
+
403
+ ### In-memory
404
+
405
+ - [InMemoryEventStorage](src/in-memory/InMemoryEventStorage.ts) - event storage + identifier provider
406
+ - [InMemoryMessageBus](src/in-memory/InMemoryMessageBus.ts) - event/command bus
407
+ - [InMemoryView](src/in-memory/InMemoryView.ts) - in-memory view with locking support
408
+
409
+ ### SQLite
410
+
411
+ ```ts
412
+ import { AbstractSqliteView, SqliteObjectView } from 'node-cqrs/sqlite';
413
+ ```
414
+
415
+ - [AbstractSqliteView](src/sqlite/AbstractSqliteView.ts) - SQLite view with restore locking and checkpoint tracking
416
+ - [SqliteObjectView](src/sqlite/SqliteObjectView.ts) - SQLite-backed object view
417
+
418
+ ### RabbitMQ
419
+
420
+ ```ts
421
+ import { RabbitMqEventBus, RabbitMqCommandBus, RabbitMqGateway } from 'node-cqrs/rabbitmq';
422
+ ```
423
+
424
+ - [RabbitMqGateway](src/rabbitmq/RabbitMqGateway.ts) - publish/subscribe gateway with durable and transient queue support
425
+ - [RabbitMqEventBus](src/rabbitmq/RabbitMqEventBus.ts) - RabbitMQ-backed `IEventBus` (fanout delivery to all subscribers)
426
+ - [RabbitMqCommandBus](src/rabbitmq/RabbitMqCommandBus.ts) - RabbitMQ-backed `ICommandBus` (point-to-point delivery via durable queue)
427
+
428
+ ### Workers
429
+
430
+ ```ts
431
+ import { AbstractWorkerProjection } from 'node-cqrs/workers';
432
+ ```
433
+
434
+ Workers are an execution mode for projections.
435
+
436
+ You still define one projection class, but it runs as:
437
+ 1. A real projection inside a worker thread (handles events, mutates the view).
438
+ 2. A proxy projection in the main thread (forwards calls to the worker and exposes the remote view).
439
+
440
+ This lets you keep your projection code unchanged while moving heavy work off the main thread.
441
+
442
+ Quickstart:
443
+ 1. Create your projection by extending `AbstractWorkerProjection`.
444
+ 2. In the worker module, call `YourProjection.createInstanceInWorkerThread()`.
445
+ 3. In your app container, register `YourProjection.workerProxyFactory` and use it like a normal projection.
446
+
447
+ Worker module example (CJS):
168
448
 
169
449
  ```js
170
- builder.registerProjection(UsersProjection, 'users');
450
+ const { AbstractWorkerProjection } = require('node-cqrs/workers');
451
+
452
+ class CounterView {
453
+ counter = 0;
454
+ increment() { this.counter += 1; }
455
+ getCounter() { return this.counter; }
456
+ }
457
+
458
+ class CounterProjection extends AbstractWorkerProjection {
459
+ static get workerModulePath() {
460
+ return __filename;
461
+ }
462
+
463
+ constructor() {
464
+ super({ view: new CounterView() });
465
+ }
466
+
467
+ somethingHappened() {
468
+ this.view.increment();
469
+ }
470
+ }
471
+
472
+ CounterProjection.createInstanceInWorkerThread();
473
+ module.exports = CounterProjection;
171
474
  ```
172
475
 
173
- And accessed from anywhere in your app:
476
+ Main thread usage (DI):
174
477
 
175
478
  ```js
176
- container.users
177
- // Map { 1 => { username: 'John' } }
479
+ const CounterProjection = require('./CounterProjection.cjs');
480
+ const { ContainerBuilder } = require('node-cqrs');
481
+
482
+ const builder = new ContainerBuilder();
483
+ builder.registerProjection(CounterProjection.workerProxyFactory, 'counterView');
484
+
485
+ const { eventStore, counterView } = builder.container();
486
+ await eventStore.dispatch([{ id: '1', type: 'somethingHappened', payload: {} }]);
487
+ const counter = await counterView.getCounter();
178
488
  ```
179
489
 
180
- ## Contribution
490
+ `workerModulePath` should point to executable JavaScript (`__filename` in CJS, `fileURLToPath(import.meta.url)` in ESM).
491
+ If you need a custom proxy projection, you can still use `workerProxyFactory(...)` directly (advanced usage).
492
+
181
493
 
182
- * [editorconfig](http://editorconfig.org)
183
- * [eslint](http://eslint.org)
184
- * `npm test -- --watch`
494
+ ## Examples
185
495
 
186
- ## License
496
+ - [examples/user-domain/framework-free](examples/user-domain/framework-free/index.ts) - minimal, no-framework CQRS/ES in one file
497
+ - [examples/user-domain/ts](examples/user-domain/ts) - TypeScript with DI container
498
+ - [examples/user-domain/cjs](examples/user-domain/cjs) - CommonJS
499
+ - [examples/sagas/simple](examples/sagas/simple/index.ts) - simple saga
500
+ - [examples/sagas/overlaps](examples/sagas/overlaps/index.ts) - overlapping sagas, multi-step flow
501
+ - [examples/browser](examples/browser) - browser smoke test
502
+ - [examples/workers/worker-projection](examples/workers/worker-projection) - worker thread projection
187
503
 
188
- * [MIT License](https://github.com/snatalenko/node-cqrs/blob/master/LICENSE)
504
+ TS examples can be run with NodeJS 24+ without transpiling.