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
@@ -1,473 +0,0 @@
1
- import { Channel, ChannelModel, ConfirmChannel, ConsumeMessage } from 'amqplib';
2
- import { IContainer, ILogger, IMessage, isMessage } from '../interfaces';
3
- import * as Event from '../Event';
4
- import { delay } from '../utils';
5
- import { HANDLER_PROCESS_TIMEOUT } from './constants';
6
- import { TerminationHandler } from './TerminationHandler';
7
-
8
- /** Generate a short pseudo-unique identifier using a truncated timestamp and random component */
9
- const getRandomAppId = () =>
10
- `${Date.now().toString(36).slice(-4)}.${Math.random().toString(36).slice(2, 6)}`.toUpperCase();
11
-
12
- type MessageHandler = (m: IMessage) => Promise<unknown> | unknown;
13
-
14
- /**
15
- * Represents a subscription to events from a RabbitMQ exchange.
16
- */
17
- type Subscription = {
18
-
19
- /** Name of the exchange to subscribe to */
20
- exchange: string;
21
-
22
- /** Optional durable queue name; if omitted, an exclusive temporary queue is used */
23
- queueName?: string;
24
-
25
- /** Specific event type (routing key) for filtering, defaults to all if omitted */
26
- eventType?: string;
27
-
28
- /** Callback function to process received messages */
29
- handler: MessageHandler;
30
-
31
- /** If true, messages originating from this instance are ignored */
32
- ignoreOwn?: boolean;
33
-
34
- /** Optional limit for concurrent message handling */
35
- concurrentLimit?: number;
36
- };
37
-
38
- const isSystemQueue = (queueName: string) => queueName.startsWith('amq.');
39
-
40
- /**
41
- * RabbitMqGateway implements the IObservable interface using RabbitMQ.
42
- *
43
- * It uses a fanout exchange to broadcast messages to all connected subscribers.
44
- * The `on` and `off` methods allow you to register and remove handlers for specific event types.
45
- * The `queue(name)` method creates or returns a durable queue with the given name, ensuring that
46
- * all messages delivered to the fanout exchange are also routed to this queue.
47
- */
48
- export class RabbitMqGateway {
49
-
50
- #connectionFactory: () => Promise<ChannelModel>;
51
- #appId: string;
52
- #logger: ILogger | undefined;
53
-
54
- #connecting = false;
55
- #connection: ChannelModel | undefined;
56
- #pubChannel: ConfirmChannel | undefined;
57
- #exclusiveQueueName: string | undefined;
58
- #queueChannels = new Map<string, Channel>();
59
- #queueConsumers = new Map<string, { channel: Channel, consumerTag: string }>();
60
-
61
- #subscriptions: Array<Subscription & { queueGivenName: string }> = [];
62
- #handlers: Map<string, Map<string, Set<MessageHandler>>> = new Map();
63
-
64
- /** Handles termination signals for graceful shutdown */
65
- #terminationHandler: TerminationHandler | undefined;
66
-
67
- get connection() {
68
- return this.#connection;
69
- }
70
-
71
- constructor(o: Partial<Pick<IContainer, 'logger' | 'process'>> & {
72
- rabbitMqConnectionFactory?: () => Promise<ChannelModel>
73
- }) {
74
- if (!o.rabbitMqConnectionFactory)
75
- throw new TypeError('rabbitMqConnectionFactory argument required');
76
-
77
- this.#connectionFactory = o.rabbitMqConnectionFactory;
78
- this.#appId = getRandomAppId();
79
- this.#logger = o.logger && 'child' in o.logger ?
80
- o.logger.child({ service: new.target.name }) :
81
- o.logger;
82
-
83
- if (o.process)
84
- this.#terminationHandler = new TerminationHandler(o.process, () => this.#stopConsuming());
85
- }
86
-
87
- /**
88
- * Establishes a connection to RabbitMQ.
89
- * If a connection attempt is already in progress, it waits for it to complete.
90
- * If the connection is lost, it attempts to reconnect automatically.
91
- * Upon successful connection, it restores any previously active subscriptions.
92
- *
93
- * This method is called automatically by other methods if a connection is required but not yet established.
94
- *
95
- * @returns A promise that resolves with the ChannelModel representing the established connection.
96
- */
97
- async connect(): Promise<ChannelModel> {
98
- while (this.#connecting)
99
- await delay(1_000);
100
-
101
- this.#connecting = true;
102
-
103
- while (!this.#connection) {
104
- try {
105
- this.#connection = await this.#connectionFactory();
106
- this.#connection.on('error', err => this.#onConnectionError(err));
107
- this.#connection.on('close', () => this.#onConnectionClosed());
108
- this.#logger?.info(`${this.#appId}: Connection established`);
109
-
110
- this.#handlers.clear();
111
- const subscriptionsToRestore = this.#subscriptions.splice(0);
112
- for (const subscription of subscriptionsToRestore)
113
- await this.subscribe(subscription);
114
- }
115
- catch (err: any) {
116
- this.#logger?.warn(`${this.#appId}: Connection attempt failed: ${err.message}`);
117
- await delay(5_000);
118
- }
119
- }
120
-
121
- this.#connecting = false;
122
-
123
- return this.#connection;
124
- }
125
-
126
- async disconnect() {
127
- try {
128
- this.#logger?.debug(`${this.#appId}: Disconnecting from RabbitMQ...`);
129
-
130
- await this.#stopConsuming();
131
- await this.#connection?.close();
132
- if (this.#connection) // clean up in case 'close' event was not triggered
133
- this.#onConnectionClosed();
134
-
135
- this.#logger?.debug(`${this.#appId}: Disconnected from RabbitMQ`);
136
- }
137
- catch (err: any) {
138
- this.#logger?.error(`${this.#appId}: Failed to disconnect from RabbitMQ: ${err.message}`, {
139
- stack: err.stack
140
- });
141
- }
142
- }
143
-
144
- async #stopConsuming() {
145
- this.#logger?.info(`${this.#appId}: Stopping all consumers...`);
146
-
147
- const cancellations = [...this.#queueConsumers.entries()].map(async ([queueName, { channel, consumerTag }]) => {
148
- this.#logger?.debug(`${this.#appId}: Cancelling consumer "${consumerTag}" for queue "${queueName}"`);
149
- try {
150
- await channel.cancel(consumerTag);
151
- this.#logger?.debug(`${this.#appId}: Consumer "${consumerTag}" on queue "${queueName}" cancelled successfully`);
152
- this.#queueConsumers.delete(queueName);
153
- }
154
- catch (err: any) {
155
- this.#logger?.error(`${this.#appId}: Failed to cancel consumer "${consumerTag}" for queue "${queueName}": ${err.message}`);
156
- }
157
- });
158
-
159
- await Promise.all(cancellations);
160
- this.#logger?.info(`${this.#appId}: All consumers stopped.`);
161
- }
162
-
163
- #onConnectionError(err: Error) {
164
- this.#logger?.warn(`${this.#appId}: Connection error: ${err.message}`);
165
- }
166
-
167
- #onConnectionClosed() {
168
- this.#logger?.warn('Connection closed');
169
- this.#connection = undefined;
170
- this.#pubChannel = undefined;
171
- this.#exclusiveQueueName = undefined;
172
- this.#queueChannels.clear();
173
- this.#queueConsumers.clear();
174
- }
175
-
176
- #getHandlers(queueGivenName: string = '', eventType: string = '*') {
177
- return this.#subscriptions.filter(s =>
178
- s.queueGivenName === queueGivenName
179
- && (
180
- !s.eventType
181
- || s.eventType === '*'
182
- || s.eventType === eventType
183
- )
184
- );
185
- }
186
-
187
- async subscribeToQueue(exchange: string, queueName: string, handler: MessageHandler) {
188
- return this.subscribe({ exchange, queueName, handler });
189
- }
190
-
191
- /**
192
- * Subscribes to a non-durable, exclusive queue without requiring acknowledgments.
193
- * The queue is deleted when the connection closes.
194
- * Messages are considered "delivered" upon receipt.
195
- * Failed message processing does not result in redelivery or dead-lettering.
196
- */
197
- async subscribeToFanout(exchange: string, handler: MessageHandler) {
198
- return this.subscribe({ exchange, handler, ignoreOwn: true });
199
- }
200
-
201
- /**
202
- * Subscribes to events from a specified exchange.
203
- *
204
- * This method sets up the necessary RabbitMQ topology (exchange, queue, bindings) based on the provided details.
205
- * If a `queueName` is provided, it asserts a durable queue with a dead-letter queue for failed messages.
206
- * If `queueName` is omitted, it uses or creates a temporary, exclusive queue for the connection.
207
- * Then it starts consuming messages from the queue with the specified concurrency limit, if specified.
208
- *
209
- * @param subscription - The subscription details.
210
- * @param subscription.exchange - The name of the exchange to subscribe to.
211
- * @param subscription.queueName - Optional. The name of the durable queue. If omitted, an exclusive queue is used.
212
- * @param subscription.eventType - The routing key or pattern to bind the queue with.
213
- * @param subscription.concurrentLimit - Optional. The maximum number of concurrent messages to process.
214
- * @returns A promise that resolves when the subscription is successfully set up.
215
- */
216
- async subscribe(subscription: Subscription) {
217
- const subscriptionExists = !!this.#findSubscription(subscription);
218
- if (subscriptionExists)
219
- throw new Error('Subscription already exists');
220
-
221
- const {
222
- exchange,
223
- queueName,
224
- eventType,
225
- concurrentLimit
226
- } = subscription;
227
-
228
- const channel = await this.#assertChannel(queueName);
229
-
230
- let queueGivenName = queueName;
231
- if (!queueGivenName) {
232
- // Handle temporary (exclusive) queue case
233
- if (!this.#exclusiveQueueName) {
234
- // Assert temporary "exclusive" queue that will be destroyed on connection termination
235
- this.#exclusiveQueueName = await this.#assetQueue(channel, exchange, '', eventType, {
236
- exclusive: true,
237
- durable: false
238
- });
239
- }
240
- else {
241
- // If exclusive queue already exists, ensure it is bound with the current event type
242
- await this.#assertBinding(channel, exchange, this.#exclusiveQueueName, eventType);
243
- }
244
- queueGivenName = this.#exclusiveQueueName;
245
- }
246
- else {
247
- // Handle durable queue case
248
- const deadLetterExchangeName = `${exchange}.failed`;
249
-
250
- // Assert dead letter queue for rejected or timed out messages
251
- await this.#assetQueue(channel, deadLetterExchangeName, `${queueGivenName}.failed`);
252
-
253
- // Assert durable queue that will survive broker restart
254
- await this.#assetQueue(channel, exchange, queueGivenName, eventType, { deadLetterExchangeName });
255
- }
256
-
257
- await this.#assertConsumer(queueGivenName, channel, concurrentLimit);
258
-
259
- this.#subscriptions.push({ ...subscription, queueGivenName });
260
- }
261
-
262
- #findSubscription(subscription: Pick<Subscription, 'exchange' | 'queueName' | 'eventType' | 'handler'>) {
263
- return this.#subscriptions.find(s =>
264
- s.exchange === subscription.exchange &&
265
- s.queueName === subscription.queueName &&
266
- s.eventType === subscription.eventType &&
267
- s.handler === subscription.handler);
268
- }
269
-
270
- async unsubscribe(subscription: Pick<Subscription, 'exchange' | 'queueName' | 'eventType' | 'handler'>) {
271
- const subscriptionToRemove = this.#findSubscription(subscription);
272
- if (!subscriptionToRemove)
273
- throw new Error('Such subscription does not exist');
274
-
275
- this.#subscriptions = this.#subscriptions.filter(s => s !== subscriptionToRemove);
276
-
277
- await this.#tryDropConsumer(subscriptionToRemove.queueGivenName);
278
- }
279
-
280
- async #assertConnection() {
281
- return this.#connection ?? this.connect();
282
- }
283
-
284
- /** Get existing or open a new channel for a given queue name */
285
- async #assertChannel(queueName: string = ''): Promise<Channel> {
286
- const connection = await this.#assertConnection();
287
- let channel = this.#queueChannels.get(queueName);
288
- if (!channel) {
289
- channel = await connection.createChannel();
290
- this.#queueChannels.set(queueName, channel);
291
- }
292
- return channel;
293
- }
294
-
295
- /**
296
- * Ensure queue, exchange, and binding exist
297
- */
298
- async #assetQueue(channel: Channel, exchange: string, queueName: string, eventType?: string, options?: {
299
-
300
- /** The queue will survive a broker restart */
301
- durable?: boolean,
302
-
303
- /** Used by only one connection and the queue will be deleted when that connection closes */
304
- exclusive?: boolean,
305
-
306
- /** Exchange where rejected or timed out messages will be delivered */
307
- deadLetterExchangeName?: string,
308
- }) {
309
- const {
310
- durable = true,
311
- exclusive = false,
312
- deadLetterExchangeName
313
- } = options ?? {};
314
-
315
- await channel.assertExchange(exchange, 'topic', { durable: true });
316
- const { queue: queueGivenName } = await channel.assertQueue(queueName, {
317
- exclusive,
318
- durable,
319
- ...deadLetterExchangeName && {
320
- arguments: {
321
- 'x-dead-letter-exchange': deadLetterExchangeName
322
- }
323
- }
324
- });
325
-
326
- await this.#assertBinding(channel, exchange, queueGivenName, eventType);
327
-
328
- return queueGivenName;
329
- }
330
-
331
- async #assertBinding(channel: Channel, exchange: string, queueGivenName: string, eventType?: string) {
332
- if (!eventType || eventType === '*')
333
- eventType = '#';
334
-
335
- await channel.bindQueue(queueGivenName, exchange, eventType);
336
-
337
- this.#logger?.debug(`${this.#appId}: Queue "${queueGivenName}" bound to exchange "${exchange}" with pattern "${eventType}"`);
338
- }
339
-
340
- async #assertConsumer(queueGivenName: string, channel: Channel, concurrentLimit?: number) {
341
- if (this.#queueConsumers.has(queueGivenName))
342
- return;
343
-
344
- if (concurrentLimit)
345
- await channel.prefetch(concurrentLimit);
346
-
347
- const c = await channel.consume(queueGivenName, async (msg: ConsumeMessage | null) => {
348
- if (!msg)
349
- return;
350
-
351
- const { consumerTag, routingKey } = msg.fields ?? {};
352
- const { messageId, correlationId, appId } = msg.properties ?? {};
353
-
354
- // Keep the process alive while waiting for the handler to finish
355
- const keepAliveTimeout = setTimeout(() => {
356
- this.#logger?.warn(`${this.#appId}: Message processing timed out`, {
357
- queueName: queueGivenName,
358
- consumerTag,
359
- routingKey,
360
- messageId
361
- });
362
- channel.nack(msg, false, false);
363
- }, HANDLER_PROCESS_TIMEOUT);
364
-
365
- try {
366
-
367
- this.#logger?.debug(`${this.#appId}: Message received`, {
368
- queueName: queueGivenName,
369
- consumerTag,
370
- routingKey,
371
- messageId,
372
- correlationId,
373
- appId
374
- });
375
-
376
- const jsonContent = msg.content.toString();
377
- const message: IMessage = JSON.parse(jsonContent);
378
-
379
- const handlers = this.#getHandlers(queueGivenName, message.type);
380
- if (!handlers.length && !isSystemQueue(queueGivenName))
381
- throw new Error(`Message from queue "${queueGivenName}" was delivered to a consumer that does not handle type "${message.type}"`);
382
-
383
- for (const { handler, ignoreOwn } of handlers) {
384
- if (ignoreOwn && appId === this.#appId)
385
- continue;
386
-
387
- await handler(message);
388
- }
389
-
390
- channel?.ack(msg);
391
- }
392
- catch (err: any) {
393
- this.#logger?.error(`${this.#appId}: Message processing failed: ${err.message}`);
394
-
395
- // Redirect message to dead letter queue, if `{ noAck: true }` was not set on consumption
396
- channel?.nack(msg, false, false);
397
- }
398
- finally {
399
- clearTimeout(keepAliveTimeout);
400
- }
401
- });
402
-
403
- this.#logger?.debug(`${this.#appId}: Consumer "${c.consumerTag}" registered on queue "${queueGivenName}"`);
404
-
405
- this.#queueConsumers.set(queueGivenName, {
406
- channel,
407
- consumerTag: c.consumerTag
408
- });
409
-
410
- this.#terminationHandler?.on();
411
- }
412
-
413
- async #tryDropConsumer(queueGivenName: string) {
414
- const queueStillUsed = this.#subscriptions.some(s => s.queueGivenName === queueGivenName);
415
- if (queueStillUsed)
416
- return;
417
-
418
- const consumer = this.#queueConsumers.get(queueGivenName);
419
- if (!consumer)
420
- return;
421
-
422
- this.#queueConsumers.delete(queueGivenName);
423
- await consumer.channel.cancel(consumer.consumerTag);
424
-
425
- // If no consumers are active anymore, disable the termination handler
426
- if (!this.#queueConsumers.size)
427
- this.#terminationHandler?.off();
428
- }
429
-
430
- /**
431
- * Publishes an event to the fanout exchange.
432
- * The event will be delivered to all subscribers, except this instance's own consumer.
433
- */
434
- async publish(exchange: string, message: IMessage): Promise<void> {
435
- if (typeof exchange !== 'string' || !exchange.length)
436
- throw new TypeError('exchange argument must be a non-empty String');
437
- if (!isMessage(message))
438
- throw new TypeError('valid message argument is required');
439
-
440
- if (!this.#pubChannel) {
441
- const connection = await this.#assertConnection();
442
- this.#pubChannel = await connection.createConfirmChannel();
443
-
444
- await this.#pubChannel.assertExchange(exchange, 'topic', { durable: true });
445
- }
446
-
447
- const content = Buffer.from(JSON.stringify(message), 'utf8');
448
- const properties = {
449
- contentType: 'application/json',
450
- contentEncoding: 'utf8',
451
- persistent: true,
452
- timestamp: message.context?.ts ?? Date.now(),
453
- appId: this.#appId,
454
- type: message.type,
455
- messageId: 'id' in message && typeof message.id === 'string' ?
456
- message.id :
457
- undefined,
458
- correlationId: message.sagaId?.toString()
459
- };
460
-
461
- return new Promise<void>((resolve, reject) => {
462
- if (!this.#pubChannel)
463
- throw new Error(`${this.#appId}: No channel available for publishing`);
464
-
465
- this.#logger?.debug(`${this.#appId}: Publishing message "${Event.describe(message)}" to exchange "${exchange}"`);
466
-
467
- const published = this.#pubChannel.publish(exchange, message.type, content, properties, err =>
468
- (err ? reject(err) : resolve()));
469
- if (!published)
470
- throw new Error(`${this.#appId}: Failed to send event ${Event.describe(message)}, channel buffer is full`);
471
- });
472
- }
473
- }
@@ -1,31 +0,0 @@
1
- /**
2
- * Handles graceful termination of a Node.js process.
3
- * Listens for SIGINT and executes a cleanup routine before allowing the process to exit.
4
- */
5
- export class TerminationHandler {
6
-
7
- #process: NodeJS.Process;
8
- #cleanupHandler: () => Promise<void>;
9
- #terminationHandler: () => Promise<void>;
10
-
11
- constructor(process: NodeJS.Process, cleanupHandler: () => Promise<void>) {
12
- this.#process = process;
13
- this.#cleanupHandler = cleanupHandler;
14
- this.#terminationHandler = this.#onProcessTermination.bind(this);
15
- }
16
-
17
- on() {
18
- this.#process.once('SIGINT', this.#terminationHandler);
19
- this.#process.once('SIGTERM', this.#terminationHandler);
20
- }
21
-
22
- off() {
23
- this.#process.off('SIGINT', this.#terminationHandler);
24
- this.#process.off('SIGTERM', this.#terminationHandler);
25
- }
26
-
27
- async #onProcessTermination() {
28
- this.off();
29
- await this.#cleanupHandler();
30
- }
31
- }
@@ -1,2 +0,0 @@
1
- export const DEFAULT_EXCHANGE = 'node-cqrs.events';
2
- export const HANDLER_PROCESS_TIMEOUT = 60 * 60 * 1000; // 1 hour
@@ -1,3 +0,0 @@
1
- export * from './RabbitMqEventBus';
2
- export * from './RabbitMqEventInjector';
3
- export * from './RabbitMqGateway';
@@ -1,58 +0,0 @@
1
- import { IContainer } from '../interfaces';
2
- import { Lock } from '../utils';
3
- import { Database } from 'better-sqlite3';
4
-
5
- /**
6
- * Abstract base class for accessing a SQLite database.
7
- *
8
- * Manages the database connection lifecycle, ensuring initialization via `assertDb`.
9
- * Supports providing a database instance directly or a factory function for lazy initialization.
10
- *
11
- * Subclasses must implement the `initialize` method for specific setup tasks.
12
- */
13
- export abstract class AbstractSqliteAccessor {
14
-
15
- protected db: Database | undefined;
16
- #dbFactory: (() => Promise<Database> | Database) | undefined;
17
- #initLocker = new Lock();
18
- #initialized = false;
19
-
20
- constructor(c: Partial<Pick<IContainer, 'viewModelSqliteDb' | 'viewModelSqliteDbFactory'>>) {
21
- if (!c.viewModelSqliteDb && !c.viewModelSqliteDbFactory)
22
- throw new TypeError('either viewModelSqliteDb or viewModelSqliteDbFactory argument required');
23
-
24
- this.db = c.viewModelSqliteDb;
25
- this.#dbFactory = c.viewModelSqliteDbFactory;
26
- }
27
-
28
- protected abstract initialize(db: Database): Promise<void> | void;
29
-
30
- /**
31
- * Ensures that the database connection is initialized.
32
- * Uses a lock to prevent race conditions during concurrent initialization attempts.
33
- * If the database is not already initialized, it creates the database connection
34
- * using the provided factory and calls the `initialize` method.
35
- *
36
- * This method is idempotent and safe to call multiple times.
37
- */
38
- async assertConnection() {
39
- if (this.#initialized)
40
- return;
41
-
42
- try {
43
- this.#initLocker.acquire();
44
- if (this.#initialized)
45
- return;
46
-
47
- if (!this.db)
48
- this.db = await this.#dbFactory!();
49
-
50
- await this.initialize(this.db);
51
-
52
- this.#initialized = true;
53
- }
54
- finally {
55
- this.#initLocker.release();
56
- }
57
- }
58
- }
@@ -1,31 +0,0 @@
1
- import { AbstractProjection } from '../AbstractProjection';
2
- import { IContainer } from '../interfaces';
3
- import { SqliteObjectView } from './SqliteObjectView';
4
-
5
- export abstract class AbstractSqliteObjectProjection<T> extends AbstractProjection<SqliteObjectView<T>> {
6
-
7
- static get tableName(): string {
8
- throw new Error('tableName is not defined');
9
- }
10
-
11
- static get schemaVersion(): string {
12
- throw new Error('schemaVersion is not defined');
13
- }
14
-
15
- constructor({ viewModelSqliteDb, viewModelSqliteDbFactory, logger }: Pick<IContainer,
16
- 'viewModelSqliteDbFactory' |
17
- 'viewModelSqliteDb' |
18
- 'logger'
19
- >) {
20
- super({ logger });
21
-
22
- this.view = new SqliteObjectView({
23
- schemaVersion: new.target.schemaVersion,
24
- projectionName: new.target.name,
25
- viewModelSqliteDb,
26
- viewModelSqliteDbFactory,
27
- tableNamePrefix: new.target.tableName,
28
- logger
29
- });
30
- }
31
- }
@@ -1,53 +0,0 @@
1
- import { IContainer, IEvent, IEventLocker, ILogger, IViewLocker } from '../interfaces';
2
- import { SqliteViewLocker, SqliteViewLockerParams } from './SqliteViewLocker';
3
- import { SqliteEventLocker, SqliteEventLockerParams } from './SqliteEventLocker';
4
- import { AbstractSqliteAccessor } from './AbstractSqliteAccessor';
5
-
6
- export abstract class AbstractSqliteView extends AbstractSqliteAccessor implements IViewLocker, IEventLocker {
7
-
8
- protected readonly schemaVersion: string;
9
- protected readonly viewLocker: SqliteViewLocker;
10
- protected readonly eventLocker: SqliteEventLocker;
11
- protected logger: ILogger | undefined;
12
-
13
- get ready(): boolean {
14
- return this.viewLocker.ready;
15
- }
16
-
17
- constructor(options: Partial<Pick<IContainer, 'viewModelSqliteDb' | 'viewModelSqliteDbFactory' | 'logger'>>
18
- & SqliteEventLockerParams
19
- & SqliteViewLockerParams) {
20
- super(options);
21
-
22
- this.schemaVersion = options.schemaVersion;
23
- this.viewLocker = new SqliteViewLocker(options);
24
- this.eventLocker = new SqliteEventLocker(options);
25
- this.logger = options.logger && 'child' in options.logger ?
26
- options.logger.child({ serviceName: new.target.name }) :
27
- options.logger;
28
- }
29
-
30
- async lock() {
31
- return this.viewLocker.lock();
32
- }
33
-
34
- unlock(): void {
35
- this.viewLocker.unlock();
36
- }
37
-
38
- once(event: 'ready') {
39
- return this.viewLocker.once(event);
40
- }
41
-
42
- getLastEvent() {
43
- return this.eventLocker.getLastEvent();
44
- }
45
-
46
- tryMarkAsProjecting(event: IEvent<any>) {
47
- return this.eventLocker.tryMarkAsProjecting(event);
48
- }
49
-
50
- markAsProjected(event: IEvent<any>) {
51
- return this.eventLocker.markAsProjected(event);
52
- }
53
- }
@@ -1,8 +0,0 @@
1
- import { Database } from 'better-sqlite3';
2
-
3
- declare module '../interfaces/IContainer' {
4
- interface IContainer {
5
- viewModelSqliteDbFactory?: () => Promise<Database> | Database;
6
- viewModelSqliteDb?: Database;
7
- }
8
- }