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.
- package/CHANGELOG.md +245 -123
- package/LICENSE +202 -21
- package/NOTICE +15 -0
- package/README.md +429 -113
- package/dist/cjs/AbstractAggregate.js +193 -0
- package/dist/cjs/AbstractAggregate.js.map +1 -0
- package/dist/cjs/AbstractProjection.js +165 -0
- package/dist/cjs/AbstractProjection.js.map +1 -0
- package/dist/cjs/AbstractSaga.js +109 -0
- package/dist/cjs/AbstractSaga.js.map +1 -0
- package/dist/cjs/AggregateCommandHandler.js +182 -0
- package/dist/cjs/AggregateCommandHandler.js.map +1 -0
- package/dist/cjs/CommandBus.js +9 -0
- package/dist/cjs/CommandBus.js.map +1 -0
- package/dist/cjs/CqrsContainerBuilder.js +97 -0
- package/dist/cjs/CqrsContainerBuilder.js.map +1 -0
- package/dist/cjs/Event.js +19 -0
- package/dist/cjs/Event.js.map +1 -0
- package/dist/cjs/EventDispatchPipeline.js +83 -0
- package/dist/cjs/EventDispatchPipeline.js.map +1 -0
- package/dist/cjs/EventDispatcher.js +93 -0
- package/dist/cjs/EventDispatcher.js.map +1 -0
- package/dist/cjs/EventIdAugmentor.js +30 -0
- package/dist/cjs/EventIdAugmentor.js.map +1 -0
- package/dist/cjs/EventStore.js +106 -0
- package/dist/cjs/EventStore.js.map +1 -0
- package/dist/cjs/SagaEventHandler.js +153 -0
- package/dist/cjs/SagaEventHandler.js.map +1 -0
- package/dist/cjs/errors/ConcurrencyError.js +21 -0
- package/dist/cjs/errors/ConcurrencyError.js.map +1 -0
- package/dist/cjs/errors/index.js +18 -0
- package/dist/cjs/errors/index.js.map +1 -0
- package/dist/cjs/in-memory/InMemoryEventStorage.js +106 -0
- package/dist/cjs/in-memory/InMemoryEventStorage.js.map +1 -0
- package/dist/cjs/in-memory/InMemoryLock.js +44 -0
- package/dist/cjs/in-memory/InMemoryLock.js.map +1 -0
- package/dist/cjs/in-memory/InMemoryMessageBus.js +93 -0
- package/dist/cjs/in-memory/InMemoryMessageBus.js.map +1 -0
- package/dist/cjs/in-memory/InMemorySnapshotStorage.js +101 -0
- package/dist/cjs/in-memory/InMemorySnapshotStorage.js.map +1 -0
- package/dist/cjs/in-memory/InMemoryView.js +154 -0
- package/dist/cjs/in-memory/InMemoryView.js.map +1 -0
- package/dist/cjs/in-memory/index.js +22 -0
- package/dist/cjs/in-memory/index.js.map +1 -0
- package/dist/cjs/in-memory/utils/index.js +18 -0
- package/dist/cjs/in-memory/utils/index.js.map +1 -0
- package/dist/cjs/in-memory/utils/nextCycle.js +9 -0
- package/dist/cjs/in-memory/utils/nextCycle.js.map +1 -0
- package/dist/cjs/index.js +58 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/cjs/interfaces/IAggregate.js.map +1 -0
- package/dist/cjs/interfaces/IAggregateSnapshotStorage.js +13 -0
- package/dist/cjs/interfaces/IAggregateSnapshotStorage.js.map +1 -0
- package/dist/cjs/interfaces/ICommand.js.map +1 -0
- package/dist/cjs/interfaces/ICommandBus.js.map +1 -0
- package/dist/cjs/interfaces/IContainer.js.map +1 -0
- package/dist/cjs/interfaces/IDispatchPipelineProcessor.js +9 -0
- package/dist/cjs/interfaces/IDispatchPipelineProcessor.js.map +1 -0
- package/dist/cjs/interfaces/IEvent.js +10 -0
- package/dist/cjs/interfaces/IEvent.js.map +1 -0
- package/dist/cjs/interfaces/IEventBus.js +9 -0
- package/dist/cjs/interfaces/IEventBus.js.map +1 -0
- package/dist/cjs/interfaces/IEventDispatcher.js.map +1 -0
- package/dist/cjs/interfaces/IEventLocker.js +15 -0
- package/dist/cjs/interfaces/IEventLocker.js.map +1 -0
- package/dist/cjs/interfaces/IEventReceptor.js.map +1 -0
- package/dist/cjs/interfaces/IEventSet.js +8 -0
- package/dist/cjs/interfaces/IEventSet.js.map +1 -0
- package/dist/cjs/interfaces/IEventStorageReader.js +13 -0
- package/dist/cjs/interfaces/IEventStorageReader.js.map +1 -0
- package/dist/cjs/interfaces/IEventStore.js.map +1 -0
- package/dist/cjs/interfaces/IEventStream.js.map +1 -0
- package/dist/cjs/interfaces/IIdentifierProvider.js +9 -0
- package/dist/cjs/interfaces/IIdentifierProvider.js.map +1 -0
- package/dist/cjs/interfaces/ILocker.js +9 -0
- package/dist/cjs/interfaces/ILocker.js.map +1 -0
- package/dist/cjs/interfaces/ILogger.js.map +1 -0
- package/dist/cjs/interfaces/IMessage.js +10 -0
- package/dist/cjs/interfaces/IMessage.js.map +1 -0
- package/dist/cjs/interfaces/IMutableState.js +3 -0
- package/dist/cjs/interfaces/IMutableState.js.map +1 -0
- package/dist/cjs/interfaces/IObjectStorage.js.map +1 -0
- package/dist/cjs/interfaces/IObservable.js +11 -0
- package/dist/cjs/interfaces/IObservable.js.map +1 -0
- package/dist/cjs/interfaces/IObservableQueueProvider.js +9 -0
- package/dist/cjs/interfaces/IObservableQueueProvider.js.map +1 -0
- package/dist/cjs/interfaces/IObserver.js.map +1 -0
- package/dist/cjs/interfaces/IProjection.js.map +1 -0
- package/dist/cjs/interfaces/ISaga.js.map +1 -0
- package/dist/cjs/interfaces/ISnapshotEvent.js +10 -0
- package/dist/cjs/interfaces/ISnapshotEvent.js.map +1 -0
- package/dist/cjs/interfaces/IViewLocker.js +21 -0
- package/dist/cjs/interfaces/IViewLocker.js.map +1 -0
- package/dist/cjs/interfaces/Identifier.js.map +1 -0
- package/dist/cjs/interfaces/index.js +46 -0
- package/dist/cjs/interfaces/index.js.map +1 -0
- package/dist/cjs/interfaces/isObject.js.map +1 -0
- package/dist/cjs/package.json +3 -0
- package/dist/cjs/rabbitmq/IContainer.js.map +1 -0
- package/dist/cjs/rabbitmq/RabbitMqCommandBus.js +84 -0
- package/dist/cjs/rabbitmq/RabbitMqCommandBus.js.map +1 -0
- package/dist/cjs/rabbitmq/RabbitMqEventBus.js +121 -0
- package/dist/cjs/rabbitmq/RabbitMqEventBus.js.map +1 -0
- package/dist/cjs/rabbitmq/RabbitMqGateway.js +578 -0
- package/dist/cjs/rabbitmq/RabbitMqGateway.js.map +1 -0
- package/dist/cjs/rabbitmq/index.js +21 -0
- package/dist/cjs/rabbitmq/index.js.map +1 -0
- package/dist/cjs/rabbitmq/utils/index.js +19 -0
- package/dist/cjs/rabbitmq/utils/index.js.map +1 -0
- package/dist/cjs/rabbitmq/utils/registerExitCleanup.js +28 -0
- package/dist/cjs/rabbitmq/utils/registerExitCleanup.js.map +1 -0
- package/dist/cjs/rabbitmq/utils/resolveProvider.js +9 -0
- package/dist/cjs/rabbitmq/utils/resolveProvider.js.map +1 -0
- package/dist/cjs/sqlite/AbstractSqliteAccessor.js +50 -0
- package/dist/cjs/sqlite/AbstractSqliteAccessor.js.map +1 -0
- package/dist/cjs/sqlite/AbstractSqliteObjectProjection.js +26 -0
- package/dist/cjs/sqlite/AbstractSqliteObjectProjection.js.map +1 -0
- package/dist/cjs/sqlite/AbstractSqliteView.js +50 -0
- package/dist/cjs/sqlite/AbstractSqliteView.js.map +1 -0
- package/dist/cjs/sqlite/IContainer.js.map +1 -0
- package/dist/cjs/sqlite/SqliteEventLocker.js +93 -0
- package/dist/cjs/sqlite/SqliteEventLocker.js.map +1 -0
- package/dist/cjs/sqlite/SqliteObjectStorage.js +114 -0
- package/dist/cjs/sqlite/SqliteObjectStorage.js.map +1 -0
- package/dist/cjs/sqlite/SqliteObjectView.js +48 -0
- package/dist/cjs/sqlite/SqliteObjectView.js.map +1 -0
- package/dist/cjs/sqlite/SqliteProjectionDataParams.js.map +1 -0
- package/dist/cjs/sqlite/SqliteViewLocker.js +119 -0
- package/dist/cjs/sqlite/SqliteViewLocker.js.map +1 -0
- package/dist/cjs/sqlite/index.js +26 -0
- package/dist/cjs/sqlite/index.js.map +1 -0
- package/dist/cjs/sqlite/queries/eventLockTableInit.js +15 -0
- package/dist/cjs/sqlite/queries/eventLockTableInit.js.map +1 -0
- package/dist/cjs/sqlite/queries/index.js +19 -0
- package/dist/cjs/sqlite/queries/index.js.map +1 -0
- package/dist/cjs/sqlite/queries/viewLockTableInit.js.map +1 -0
- package/dist/cjs/sqlite/utils/getEventId.js +14 -0
- package/dist/cjs/sqlite/utils/getEventId.js.map +1 -0
- package/dist/cjs/sqlite/utils/guid.js.map +1 -0
- package/dist/cjs/sqlite/utils/index.js +19 -0
- package/dist/cjs/sqlite/utils/index.js.map +1 -0
- package/dist/cjs/utils/Deferred.js.map +1 -0
- package/dist/cjs/utils/Lock.js +102 -0
- package/dist/cjs/utils/Lock.js.map +1 -0
- package/dist/cjs/utils/MapAssertable.js +30 -0
- package/dist/cjs/utils/MapAssertable.js.map +1 -0
- package/dist/cjs/utils/assert.js +88 -0
- package/dist/cjs/utils/assert.js.map +1 -0
- package/dist/cjs/utils/clone.js +13 -0
- package/dist/cjs/utils/clone.js.map +1 -0
- package/dist/cjs/utils/extractErrorDetails.js +37 -0
- package/dist/cjs/utils/extractErrorDetails.js.map +1 -0
- package/dist/cjs/utils/getClassName.js.map +1 -0
- package/dist/cjs/utils/getHandler.js +18 -0
- package/dist/cjs/utils/getHandler.js.map +1 -0
- package/dist/cjs/utils/getMessageHandlerNames.js +30 -0
- package/dist/cjs/utils/getMessageHandlerNames.js.map +1 -0
- package/dist/cjs/utils/index.js +31 -0
- package/dist/cjs/utils/index.js.map +1 -0
- package/dist/cjs/utils/isClass.js.map +1 -0
- package/dist/cjs/utils/sagaId.js +23 -0
- package/dist/cjs/utils/sagaId.js.map +1 -0
- package/dist/cjs/utils/setupOneTimeEmitterSubscription.js +45 -0
- package/dist/cjs/utils/setupOneTimeEmitterSubscription.js.map +1 -0
- package/dist/cjs/utils/subscribe.js +43 -0
- package/dist/cjs/utils/subscribe.js.map +1 -0
- package/dist/cjs/utils/validateHandlers.js +21 -0
- package/dist/cjs/utils/validateHandlers.js.map +1 -0
- package/dist/cjs/workers/AbstractWorkerProjection.js +56 -0
- package/dist/cjs/workers/AbstractWorkerProjection.js.map +1 -0
- package/dist/cjs/workers/WorkerProxyProjection.js +142 -0
- package/dist/cjs/workers/WorkerProxyProjection.js.map +1 -0
- package/dist/cjs/workers/index.js +20 -0
- package/dist/cjs/workers/index.js.map +1 -0
- package/dist/cjs/workers/interfaces/IProxyProjection.js +3 -0
- package/dist/cjs/workers/interfaces/IProxyProjection.js.map +1 -0
- package/dist/cjs/workers/interfaces/IWorkerProjection.js +3 -0
- package/dist/cjs/workers/interfaces/IWorkerProjection.js.map +1 -0
- package/dist/cjs/workers/interfaces/index.js +3 -0
- package/dist/cjs/workers/interfaces/index.js.map +1 -0
- package/dist/cjs/workers/protocol.js +16 -0
- package/dist/cjs/workers/protocol.js.map +1 -0
- package/dist/cjs/workers/utils/ProjectionView.js +3 -0
- package/dist/cjs/workers/utils/ProjectionView.js.map +1 -0
- package/dist/cjs/workers/utils/createWorker.js +87 -0
- package/dist/cjs/workers/utils/createWorker.js.map +1 -0
- package/dist/cjs/workers/utils/createWorkerInstance.js +59 -0
- package/dist/cjs/workers/utils/createWorkerInstance.js.map +1 -0
- package/dist/cjs/workers/utils/index.js +21 -0
- package/dist/cjs/workers/utils/index.js.map +1 -0
- package/dist/cjs/workers/utils/nodeEndpoint.js +8 -0
- package/dist/cjs/workers/utils/nodeEndpoint.js.map +1 -0
- package/dist/cjs/workers/utils/workerProxyFactory.js +21 -0
- package/dist/cjs/workers/utils/workerProxyFactory.js.map +1 -0
- package/dist/esm/AbstractAggregate.js +189 -0
- package/dist/esm/AbstractAggregate.js.map +1 -0
- package/dist/esm/AbstractProjection.js +161 -0
- package/dist/esm/AbstractProjection.js.map +1 -0
- package/dist/esm/AbstractSaga.js +105 -0
- package/dist/esm/AbstractSaga.js.map +1 -0
- package/dist/esm/AggregateCommandHandler.js +178 -0
- package/dist/esm/AggregateCommandHandler.js.map +1 -0
- package/dist/esm/CommandBus.js +5 -0
- package/dist/esm/CommandBus.js.map +1 -0
- package/dist/esm/CqrsContainerBuilder.js +93 -0
- package/dist/esm/CqrsContainerBuilder.js.map +1 -0
- package/dist/esm/Event.js +15 -0
- package/dist/esm/Event.js.map +1 -0
- package/dist/esm/EventDispatchPipeline.js +79 -0
- package/dist/esm/EventDispatchPipeline.js.map +1 -0
- package/dist/esm/EventDispatcher.js +89 -0
- package/dist/esm/EventDispatcher.js.map +1 -0
- package/dist/esm/EventIdAugmentor.js +26 -0
- package/dist/esm/EventIdAugmentor.js.map +1 -0
- package/dist/esm/EventStore.js +102 -0
- package/dist/esm/EventStore.js.map +1 -0
- package/dist/esm/SagaEventHandler.js +116 -0
- package/dist/esm/SagaEventHandler.js.map +1 -0
- package/dist/esm/errors/ConcurrencyError.js +17 -0
- package/dist/esm/errors/ConcurrencyError.js.map +1 -0
- package/dist/esm/errors/index.js +2 -0
- package/dist/esm/errors/index.js.map +1 -0
- package/dist/esm/in-memory/InMemoryEventStorage.js +102 -0
- package/dist/esm/in-memory/InMemoryEventStorage.js.map +1 -0
- package/dist/esm/in-memory/InMemoryLock.js +40 -0
- package/dist/esm/in-memory/InMemoryLock.js.map +1 -0
- package/dist/esm/in-memory/InMemoryMessageBus.js +89 -0
- package/dist/esm/in-memory/InMemoryMessageBus.js.map +1 -0
- package/dist/esm/in-memory/InMemorySnapshotStorage.js +64 -0
- package/dist/esm/in-memory/InMemorySnapshotStorage.js.map +1 -0
- package/dist/esm/in-memory/InMemoryView.js +150 -0
- package/dist/esm/in-memory/InMemoryView.js.map +1 -0
- package/dist/esm/in-memory/index.js +6 -0
- package/dist/esm/in-memory/index.js.map +1 -0
- package/dist/esm/in-memory/utils/index.js +2 -0
- package/dist/esm/in-memory/utils/index.js.map +1 -0
- package/dist/esm/in-memory/utils/nextCycle.js +5 -0
- package/dist/esm/in-memory/utils/nextCycle.js.map +1 -0
- package/dist/esm/index.js +16 -0
- package/dist/esm/index.js.map +1 -0
- package/dist/esm/interfaces/IAggregate.js +2 -0
- package/dist/esm/interfaces/IAggregate.js.map +1 -0
- package/dist/esm/interfaces/IAggregateSnapshotStorage.js +9 -0
- package/dist/esm/interfaces/IAggregateSnapshotStorage.js.map +1 -0
- package/dist/esm/interfaces/ICommand.js +2 -0
- package/dist/esm/interfaces/ICommand.js.map +1 -0
- package/dist/esm/interfaces/ICommandBus.js +2 -0
- package/dist/esm/interfaces/ICommandBus.js.map +1 -0
- package/dist/esm/interfaces/IContainer.js +2 -0
- package/dist/esm/interfaces/IContainer.js.map +1 -0
- package/dist/esm/interfaces/IDispatchPipelineProcessor.js +5 -0
- package/dist/esm/interfaces/IDispatchPipelineProcessor.js.map +1 -0
- package/dist/esm/interfaces/IEvent.js +6 -0
- package/dist/esm/interfaces/IEvent.js.map +1 -0
- package/dist/esm/interfaces/IEventBus.js +5 -0
- package/dist/esm/interfaces/IEventBus.js.map +1 -0
- package/dist/esm/interfaces/IEventDispatcher.js +2 -0
- package/dist/esm/interfaces/IEventDispatcher.js.map +1 -0
- package/dist/esm/interfaces/IEventLocker.js +11 -0
- package/dist/esm/interfaces/IEventLocker.js.map +1 -0
- package/dist/esm/interfaces/IEventReceptor.js +2 -0
- package/dist/esm/interfaces/IEventReceptor.js.map +1 -0
- package/dist/esm/interfaces/IEventSet.js +4 -0
- package/dist/esm/interfaces/IEventSet.js.map +1 -0
- package/dist/esm/interfaces/IEventStorageReader.js +9 -0
- package/dist/esm/interfaces/IEventStorageReader.js.map +1 -0
- package/dist/esm/interfaces/IEventStore.js +2 -0
- package/dist/esm/interfaces/IEventStore.js.map +1 -0
- package/dist/esm/interfaces/IEventStream.js +2 -0
- package/dist/esm/interfaces/IEventStream.js.map +1 -0
- package/dist/esm/interfaces/IIdentifierProvider.js +5 -0
- package/dist/esm/interfaces/IIdentifierProvider.js.map +1 -0
- package/dist/esm/interfaces/ILocker.js +5 -0
- package/dist/esm/interfaces/ILocker.js.map +1 -0
- package/dist/esm/interfaces/ILogger.js +2 -0
- package/dist/esm/interfaces/ILogger.js.map +1 -0
- package/dist/esm/interfaces/IMessage.js +6 -0
- package/dist/esm/interfaces/IMessage.js.map +1 -0
- package/dist/esm/interfaces/IMutableState.js +2 -0
- package/dist/esm/interfaces/IMutableState.js.map +1 -0
- package/dist/esm/interfaces/IObjectStorage.js +2 -0
- package/dist/esm/interfaces/IObjectStorage.js.map +1 -0
- package/dist/esm/interfaces/IObservable.js +7 -0
- package/dist/esm/interfaces/IObservable.js.map +1 -0
- package/dist/esm/interfaces/IObservableQueueProvider.js +5 -0
- package/dist/esm/interfaces/IObservableQueueProvider.js.map +1 -0
- package/dist/esm/interfaces/IObserver.js +2 -0
- package/dist/esm/interfaces/IObserver.js.map +1 -0
- package/dist/esm/interfaces/IProjection.js +2 -0
- package/dist/esm/interfaces/IProjection.js.map +1 -0
- package/dist/esm/interfaces/ISaga.js +2 -0
- package/dist/esm/interfaces/ISaga.js.map +1 -0
- package/dist/esm/interfaces/ISnapshotEvent.js +6 -0
- package/dist/esm/interfaces/ISnapshotEvent.js.map +1 -0
- package/dist/esm/interfaces/IViewLocker.js +17 -0
- package/dist/esm/interfaces/IViewLocker.js.map +1 -0
- package/dist/esm/interfaces/Identifier.js +2 -0
- package/dist/esm/interfaces/Identifier.js.map +1 -0
- package/dist/esm/interfaces/index.js +30 -0
- package/dist/esm/interfaces/index.js.map +1 -0
- package/dist/esm/interfaces/isObject.js +5 -0
- package/dist/esm/interfaces/isObject.js.map +1 -0
- package/dist/esm/rabbitmq/IContainer.js +2 -0
- package/dist/esm/rabbitmq/IContainer.js.map +1 -0
- package/dist/esm/rabbitmq/RabbitMqCommandBus.js +80 -0
- package/dist/esm/rabbitmq/RabbitMqCommandBus.js.map +1 -0
- package/dist/esm/rabbitmq/RabbitMqEventBus.js +117 -0
- package/dist/esm/rabbitmq/RabbitMqEventBus.js.map +1 -0
- package/dist/esm/rabbitmq/RabbitMqGateway.js +541 -0
- package/dist/esm/rabbitmq/RabbitMqGateway.js.map +1 -0
- package/dist/esm/rabbitmq/index.js +5 -0
- package/dist/esm/rabbitmq/index.js.map +1 -0
- package/dist/esm/rabbitmq/utils/index.js +3 -0
- package/dist/esm/rabbitmq/utils/index.js.map +1 -0
- package/dist/esm/rabbitmq/utils/registerExitCleanup.js +24 -0
- package/dist/esm/rabbitmq/utils/registerExitCleanup.js.map +1 -0
- package/dist/esm/rabbitmq/utils/resolveProvider.js +6 -0
- package/dist/esm/rabbitmq/utils/resolveProvider.js.map +1 -0
- package/dist/esm/sqlite/AbstractSqliteAccessor.js +46 -0
- package/dist/esm/sqlite/AbstractSqliteAccessor.js.map +1 -0
- package/dist/esm/sqlite/AbstractSqliteObjectProjection.js +22 -0
- package/dist/esm/sqlite/AbstractSqliteObjectProjection.js.map +1 -0
- package/dist/esm/sqlite/AbstractSqliteView.js +46 -0
- package/dist/esm/sqlite/AbstractSqliteView.js.map +1 -0
- package/dist/esm/sqlite/IContainer.js +2 -0
- package/dist/esm/sqlite/IContainer.js.map +1 -0
- package/dist/esm/sqlite/SqliteEventLocker.js +89 -0
- package/dist/esm/sqlite/SqliteEventLocker.js.map +1 -0
- package/dist/esm/sqlite/SqliteObjectStorage.js +110 -0
- package/dist/esm/sqlite/SqliteObjectStorage.js.map +1 -0
- package/dist/esm/sqlite/SqliteObjectView.js +44 -0
- package/dist/esm/sqlite/SqliteObjectView.js.map +1 -0
- package/dist/esm/sqlite/SqliteProjectionDataParams.js +2 -0
- package/dist/esm/sqlite/SqliteProjectionDataParams.js.map +1 -0
- package/dist/esm/sqlite/SqliteViewLocker.js +115 -0
- package/dist/esm/sqlite/SqliteViewLocker.js.map +1 -0
- package/dist/esm/sqlite/index.js +10 -0
- package/dist/esm/sqlite/index.js.map +1 -0
- package/dist/esm/sqlite/queries/eventLockTableInit.js +11 -0
- package/dist/esm/sqlite/queries/eventLockTableInit.js.map +1 -0
- package/dist/esm/sqlite/queries/index.js +3 -0
- package/dist/esm/sqlite/queries/index.js.map +1 -0
- package/dist/esm/sqlite/queries/viewLockTableInit.js +10 -0
- package/dist/esm/sqlite/queries/viewLockTableInit.js.map +1 -0
- package/dist/esm/sqlite/utils/getEventId.js +7 -0
- package/dist/esm/sqlite/utils/getEventId.js.map +1 -0
- package/dist/esm/sqlite/utils/guid.js +5 -0
- package/dist/esm/sqlite/utils/guid.js.map +1 -0
- package/dist/esm/sqlite/utils/index.js +3 -0
- package/dist/esm/sqlite/utils/index.js.map +1 -0
- package/dist/esm/utils/Deferred.js +34 -0
- package/dist/esm/utils/Deferred.js.map +1 -0
- package/dist/esm/utils/Lock.js +97 -0
- package/dist/esm/utils/Lock.js.map +1 -0
- package/dist/esm/utils/MapAssertable.js +26 -0
- package/dist/esm/utils/MapAssertable.js.map +1 -0
- package/dist/esm/utils/assert.js +70 -0
- package/dist/esm/utils/assert.js.map +1 -0
- package/dist/esm/utils/clone.js +10 -0
- package/dist/esm/utils/clone.js.map +1 -0
- package/dist/esm/utils/extractErrorDetails.js +33 -0
- package/dist/esm/utils/extractErrorDetails.js.map +1 -0
- package/dist/esm/utils/getClassName.js +7 -0
- package/dist/esm/utils/getClassName.js.map +1 -0
- package/dist/esm/utils/getHandler.js +15 -0
- package/dist/esm/utils/getHandler.js.map +1 -0
- package/dist/esm/utils/getMessageHandlerNames.js +27 -0
- package/dist/esm/utils/getMessageHandlerNames.js.map +1 -0
- package/dist/esm/utils/index.js +15 -0
- package/dist/esm/utils/index.js.map +1 -0
- package/dist/esm/utils/isClass.js +5 -0
- package/dist/esm/utils/isClass.js.map +1 -0
- package/dist/esm/utils/sagaId.js +18 -0
- package/dist/esm/utils/sagaId.js.map +1 -0
- package/dist/esm/utils/setupOneTimeEmitterSubscription.js +42 -0
- package/dist/esm/utils/setupOneTimeEmitterSubscription.js.map +1 -0
- package/dist/esm/utils/subscribe.js +40 -0
- package/dist/esm/utils/subscribe.js.map +1 -0
- package/dist/esm/utils/validateHandlers.js +18 -0
- package/dist/esm/utils/validateHandlers.js.map +1 -0
- package/dist/esm/workers/AbstractWorkerProjection.js +52 -0
- package/dist/esm/workers/AbstractWorkerProjection.js.map +1 -0
- package/dist/esm/workers/WorkerProxyProjection.js +105 -0
- package/dist/esm/workers/WorkerProxyProjection.js.map +1 -0
- package/dist/esm/workers/index.js +4 -0
- package/dist/esm/workers/index.js.map +1 -0
- package/dist/esm/workers/interfaces/IProxyProjection.js +2 -0
- package/dist/esm/workers/interfaces/IProxyProjection.js.map +1 -0
- package/dist/esm/workers/interfaces/IWorkerProjection.js +2 -0
- package/dist/esm/workers/interfaces/IWorkerProjection.js.map +1 -0
- package/dist/esm/workers/interfaces/index.js +2 -0
- package/dist/esm/workers/interfaces/index.js.map +1 -0
- package/dist/esm/workers/protocol.js +11 -0
- package/dist/esm/workers/protocol.js.map +1 -0
- package/dist/esm/workers/utils/ProjectionView.js +2 -0
- package/dist/esm/workers/utils/ProjectionView.js.map +1 -0
- package/dist/esm/workers/utils/createWorker.js +51 -0
- package/dist/esm/workers/utils/createWorker.js.map +1 -0
- package/dist/esm/workers/utils/createWorkerInstance.js +23 -0
- package/dist/esm/workers/utils/createWorkerInstance.js.map +1 -0
- package/dist/esm/workers/utils/index.js +5 -0
- package/dist/esm/workers/utils/index.js.map +1 -0
- package/dist/esm/workers/utils/nodeEndpoint.js +5 -0
- package/dist/esm/workers/utils/nodeEndpoint.js.map +1 -0
- package/dist/esm/workers/utils/workerProxyFactory.js +18 -0
- package/dist/esm/workers/utils/workerProxyFactory.js.map +1 -0
- package/dist/types/AbstractAggregate.d.ts +80 -0
- package/dist/types/AbstractProjection.d.ts +77 -0
- package/dist/types/AbstractSaga.d.ts +42 -0
- package/dist/types/AggregateCommandHandler.d.ts +22 -0
- package/dist/types/CommandBus.d.ts +4 -0
- package/dist/types/CqrsContainerBuilder.d.ts +21 -0
- package/dist/types/Event.d.ts +9 -0
- package/dist/types/EventDispatchPipeline.d.ts +16 -0
- package/dist/types/EventDispatcher.d.ts +39 -0
- package/dist/types/EventIdAugmentor.d.ts +12 -0
- package/dist/types/EventStore.d.ts +29 -0
- package/dist/types/SagaEventHandler.d.ts +22 -0
- package/dist/types/errors/ConcurrencyError.d.ts +9 -0
- package/dist/types/errors/index.d.ts +1 -0
- package/dist/types/in-memory/InMemoryEventStorage.d.ts +24 -0
- package/dist/types/in-memory/InMemoryLock.d.ts +23 -0
- package/dist/types/in-memory/InMemoryMessageBus.d.ts +45 -0
- package/dist/types/in-memory/InMemorySnapshotStorage.d.ts +37 -0
- package/dist/types/in-memory/InMemoryView.d.ts +53 -0
- package/dist/types/in-memory/index.d.ts +5 -0
- package/dist/types/in-memory/utils/index.d.ts +1 -0
- package/dist/types/index.d.ts +15 -0
- package/dist/types/interfaces/IAggregate.d.ts +78 -0
- package/dist/types/interfaces/IAggregateSnapshotStorage.d.ts +8 -0
- package/dist/types/interfaces/ICommand.d.ts +2 -0
- package/dist/types/interfaces/ICommandBus.d.ts +15 -0
- package/dist/types/interfaces/IContainer.d.ts +37 -0
- package/dist/types/interfaces/IDispatchPipelineProcessor.d.ts +29 -0
- package/dist/types/interfaces/IEvent.d.ts +7 -0
- package/dist/types/interfaces/IEventBus.d.ts +6 -0
- package/dist/types/interfaces/IEventDispatcher.d.ts +6 -0
- package/dist/types/interfaces/IEventLocker.d.ts +28 -0
- package/dist/types/interfaces/IEventReceptor.d.ts +5 -0
- package/dist/types/interfaces/IEventSet.d.ts +3 -0
- package/dist/types/interfaces/IEventStorageReader.d.ts +48 -0
- package/dist/types/interfaces/IEventStore.d.ts +9 -0
- package/dist/types/interfaces/IEventStream.d.ts +2 -0
- package/dist/types/interfaces/IIdentifierProvider.d.ts +10 -0
- package/dist/types/interfaces/ILocker.d.ts +8 -0
- package/dist/types/interfaces/IMessage.d.ts +23 -0
- package/dist/types/interfaces/IMutableState.d.ts +14 -0
- package/dist/types/interfaces/IObjectStorage.d.ts +8 -0
- package/dist/types/interfaces/IObservable.d.ts +15 -0
- package/dist/types/interfaces/IObservableQueueProvider.d.ts +8 -0
- package/dist/types/interfaces/IObserver.d.ts +4 -0
- package/dist/types/interfaces/IProjection.d.ts +17 -0
- package/dist/types/interfaces/ISaga.d.ts +38 -0
- package/dist/types/interfaces/ISnapshotEvent.d.ts +7 -0
- package/dist/types/interfaces/Identifier.d.ts +1 -0
- package/dist/types/interfaces/index.d.ts +29 -0
- package/dist/types/interfaces/isObject.d.ts +1 -0
- package/dist/types/rabbitmq/IContainer.d.ts +19 -0
- package/dist/types/rabbitmq/RabbitMqCommandBus.d.ts +38 -0
- package/dist/types/rabbitmq/RabbitMqEventBus.d.ts +44 -0
- package/dist/types/rabbitmq/RabbitMqGateway.d.ts +133 -0
- package/dist/types/rabbitmq/index.d.ts +4 -0
- package/dist/types/rabbitmq/utils/index.d.ts +2 -0
- package/dist/types/rabbitmq/utils/registerExitCleanup.d.ts +10 -0
- package/dist/types/rabbitmq/utils/resolveProvider.d.ts +3 -0
- package/dist/types/sqlite/AbstractSqliteAccessor.d.ts +25 -0
- package/dist/types/sqlite/AbstractSqliteObjectProjection.d.ts +8 -0
- package/dist/types/sqlite/AbstractSqliteView.d.ts +23 -0
- package/dist/types/sqlite/IContainer.d.ts +7 -0
- package/dist/types/sqlite/SqliteEventLocker.d.ts +30 -0
- package/dist/types/sqlite/SqliteObjectStorage.d.ts +17 -0
- package/dist/types/sqlite/SqliteObjectView.d.ts +19 -0
- package/dist/types/sqlite/SqliteViewLocker.d.ts +31 -0
- package/dist/types/sqlite/index.d.ts +9 -0
- package/dist/types/sqlite/queries/index.d.ts +2 -0
- package/dist/types/sqlite/utils/getEventId.d.ts +5 -0
- package/dist/types/sqlite/utils/index.d.ts +2 -0
- package/dist/types/utils/Lock.d.ts +30 -0
- package/dist/types/utils/MapAssertable.d.ts +11 -0
- package/dist/types/utils/assert.d.ts +20 -0
- package/dist/types/utils/clone.d.ts +1 -0
- package/dist/types/utils/extractErrorDetails.d.ts +8 -0
- package/dist/types/utils/getHandler.d.ts +7 -0
- package/dist/types/utils/getMessageHandlerNames.d.ts +12 -0
- package/dist/types/utils/index.d.ts +14 -0
- package/dist/types/utils/isClass.d.ts +1 -0
- package/dist/types/utils/sagaId.d.ts +6 -0
- package/dist/types/utils/setupOneTimeEmitterSubscription.d.ts +12 -0
- package/dist/types/utils/subscribe.d.ts +9 -0
- package/dist/types/workers/AbstractWorkerProjection.d.ts +25 -0
- package/dist/types/workers/WorkerProxyProjection.d.ts +25 -0
- package/dist/types/workers/index.d.ts +3 -0
- package/dist/types/workers/interfaces/IProxyProjection.d.ts +15 -0
- package/dist/types/workers/interfaces/IWorkerProjection.d.ts +19 -0
- package/dist/types/workers/interfaces/index.d.ts +2 -0
- package/dist/types/workers/protocol.d.ts +10 -0
- package/dist/types/workers/utils/ProjectionView.d.ts +2 -0
- package/dist/types/workers/utils/createWorker.d.ts +10 -0
- package/dist/types/workers/utils/createWorkerInstance.d.ts +11 -0
- package/dist/types/workers/utils/index.d.ts +5 -0
- package/dist/types/workers/utils/nodeEndpoint.d.ts +2 -0
- package/dist/types/workers/utils/workerProxyFactory.d.ts +14 -0
- package/package.json +106 -54
- package/dist/AbstractAggregate.js +0 -178
- package/dist/AbstractAggregate.js.map +0 -1
- package/dist/AbstractProjection.js +0 -138
- package/dist/AbstractProjection.js.map +0 -1
- package/dist/AbstractSaga.js +0 -99
- package/dist/AbstractSaga.js.map +0 -1
- package/dist/AggregateCommandHandler.js +0 -86
- package/dist/AggregateCommandHandler.js.map +0 -1
- package/dist/CommandBus.js +0 -74
- package/dist/CommandBus.js.map +0 -1
- package/dist/CqrsContainerBuilder.js +0 -92
- package/dist/CqrsContainerBuilder.js.map +0 -1
- package/dist/Event.js +0 -33
- package/dist/Event.js.map +0 -1
- package/dist/EventDispatcher.js +0 -131
- package/dist/EventDispatcher.js.map +0 -1
- package/dist/EventStore.js +0 -137
- package/dist/EventStore.js.map +0 -1
- package/dist/EventValidationProcessor.js +0 -29
- package/dist/EventValidationProcessor.js.map +0 -1
- package/dist/SagaEventHandler.js +0 -118
- package/dist/SagaEventHandler.js.map +0 -1
- package/dist/in-memory/InMemoryEventStorage.js +0 -73
- package/dist/in-memory/InMemoryEventStorage.js.map +0 -1
- package/dist/in-memory/InMemoryLock.js +0 -40
- package/dist/in-memory/InMemoryLock.js.map +0 -1
- package/dist/in-memory/InMemoryMessageBus.js +0 -111
- package/dist/in-memory/InMemoryMessageBus.js.map +0 -1
- package/dist/in-memory/InMemorySnapshotStorage.js +0 -70
- package/dist/in-memory/InMemorySnapshotStorage.js.map +0 -1
- package/dist/in-memory/InMemoryView.js +0 -167
- package/dist/in-memory/InMemoryView.js.map +0 -1
- package/dist/in-memory/index.js +0 -22
- package/dist/in-memory/index.js.map +0 -1
- package/dist/in-memory/utils/index.js +0 -18
- package/dist/in-memory/utils/index.js.map +0 -1
- package/dist/in-memory/utils/nextCycle.js +0 -9
- package/dist/in-memory/utils/nextCycle.js.map +0 -1
- package/dist/index.js +0 -35
- package/dist/index.js.map +0 -1
- package/dist/interfaces/IAggregate.js.map +0 -1
- package/dist/interfaces/IAggregateSnapshotStorage.js +0 -3
- package/dist/interfaces/IAggregateSnapshotStorage.js.map +0 -1
- package/dist/interfaces/ICommand.js.map +0 -1
- package/dist/interfaces/ICommandBus.js.map +0 -1
- package/dist/interfaces/IContainer.js.map +0 -1
- package/dist/interfaces/IDispatchPipelineProcessor.js +0 -9
- package/dist/interfaces/IDispatchPipelineProcessor.js.map +0 -1
- package/dist/interfaces/IEvent.js +0 -9
- package/dist/interfaces/IEvent.js.map +0 -1
- package/dist/interfaces/IEventBus.js +0 -9
- package/dist/interfaces/IEventBus.js.map +0 -1
- package/dist/interfaces/IEventDispatcher.js.map +0 -1
- package/dist/interfaces/IEventLocker.js +0 -10
- package/dist/interfaces/IEventLocker.js.map +0 -1
- package/dist/interfaces/IEventReceptor.js.map +0 -1
- package/dist/interfaces/IEventSet.js +0 -8
- package/dist/interfaces/IEventSet.js.map +0 -1
- package/dist/interfaces/IEventStorage.js +0 -13
- package/dist/interfaces/IEventStorage.js.map +0 -1
- package/dist/interfaces/IEventStore.js.map +0 -1
- package/dist/interfaces/IEventStream.js.map +0 -1
- package/dist/interfaces/IIdentifierProvider.js +0 -9
- package/dist/interfaces/IIdentifierProvider.js.map +0 -1
- package/dist/interfaces/ILogger.js.map +0 -1
- package/dist/interfaces/IMessage.js +0 -9
- package/dist/interfaces/IMessage.js.map +0 -1
- package/dist/interfaces/IMessageBus.js +0 -3
- package/dist/interfaces/IMessageBus.js.map +0 -1
- package/dist/interfaces/IObjectStorage.js.map +0 -1
- package/dist/interfaces/IObservable.js +0 -11
- package/dist/interfaces/IObservable.js.map +0 -1
- package/dist/interfaces/IObserver.js.map +0 -1
- package/dist/interfaces/IProjection.js.map +0 -1
- package/dist/interfaces/ISaga.js.map +0 -1
- package/dist/interfaces/IViewLocker.js +0 -17
- package/dist/interfaces/IViewLocker.js.map +0 -1
- package/dist/interfaces/Identifier.js.map +0 -1
- package/dist/interfaces/index.js +0 -43
- package/dist/interfaces/index.js.map +0 -1
- package/dist/interfaces/isObject.js.map +0 -1
- package/dist/rabbitmq/IContainer.js.map +0 -1
- package/dist/rabbitmq/RabbitMqEventBus.js +0 -89
- package/dist/rabbitmq/RabbitMqEventBus.js.map +0 -1
- package/dist/rabbitmq/RabbitMqEventInjector.js +0 -55
- package/dist/rabbitmq/RabbitMqEventInjector.js.map +0 -1
- package/dist/rabbitmq/RabbitMqGateway.js +0 -347
- package/dist/rabbitmq/RabbitMqGateway.js.map +0 -1
- package/dist/rabbitmq/TerminationHandler.js +0 -31
- package/dist/rabbitmq/TerminationHandler.js.map +0 -1
- package/dist/rabbitmq/constants.js +0 -6
- package/dist/rabbitmq/constants.js.map +0 -1
- package/dist/rabbitmq/index.js +0 -20
- package/dist/rabbitmq/index.js.map +0 -1
- package/dist/sqlite/AbstractSqliteAccessor.js +0 -50
- package/dist/sqlite/AbstractSqliteAccessor.js.map +0 -1
- package/dist/sqlite/AbstractSqliteObjectProjection.js +0 -26
- package/dist/sqlite/AbstractSqliteObjectProjection.js.map +0 -1
- package/dist/sqlite/AbstractSqliteView.js +0 -44
- package/dist/sqlite/AbstractSqliteView.js.map +0 -1
- package/dist/sqlite/IContainer.js.map +0 -1
- package/dist/sqlite/SqliteEventLocker.js +0 -94
- package/dist/sqlite/SqliteEventLocker.js.map +0 -1
- package/dist/sqlite/SqliteObjectStorage.js +0 -113
- package/dist/sqlite/SqliteObjectStorage.js.map +0 -1
- package/dist/sqlite/SqliteObjectView.js +0 -46
- package/dist/sqlite/SqliteObjectView.js.map +0 -1
- package/dist/sqlite/SqliteProjectionDataParams.js.map +0 -1
- package/dist/sqlite/SqliteViewLocker.js +0 -119
- package/dist/sqlite/SqliteViewLocker.js.map +0 -1
- package/dist/sqlite/index.js +0 -25
- package/dist/sqlite/index.js.map +0 -1
- package/dist/sqlite/queries/eventLockTableInit.js +0 -15
- package/dist/sqlite/queries/eventLockTableInit.js.map +0 -1
- package/dist/sqlite/queries/index.js +0 -19
- package/dist/sqlite/queries/index.js.map +0 -1
- package/dist/sqlite/queries/viewLockTableInit.js.map +0 -1
- package/dist/sqlite/utils/getEventId.js +0 -11
- package/dist/sqlite/utils/getEventId.js.map +0 -1
- package/dist/sqlite/utils/guid.js.map +0 -1
- package/dist/sqlite/utils/index.js +0 -19
- package/dist/sqlite/utils/index.js.map +0 -1
- package/dist/tsconfig.tsbuildinfo +0 -1
- package/dist/utils/Deferred.js.map +0 -1
- package/dist/utils/Lock.js +0 -50
- package/dist/utils/Lock.js.map +0 -1
- package/dist/utils/delay.js +0 -13
- package/dist/utils/delay.js.map +0 -1
- package/dist/utils/getClassName.js.map +0 -1
- package/dist/utils/getHandler.js +0 -19
- package/dist/utils/getHandler.js.map +0 -1
- package/dist/utils/getMessageHandlerNames.js +0 -34
- package/dist/utils/getMessageHandlerNames.js.map +0 -1
- package/dist/utils/index.js +0 -29
- package/dist/utils/index.js.map +0 -1
- package/dist/utils/isClass.js.map +0 -1
- package/dist/utils/iteratorToArray.js +0 -10
- package/dist/utils/iteratorToArray.js.map +0 -1
- package/dist/utils/notEmpty.js +0 -6
- package/dist/utils/notEmpty.js.map +0 -1
- package/dist/utils/setupOneTimeEmitterSubscription.js +0 -46
- package/dist/utils/setupOneTimeEmitterSubscription.js.map +0 -1
- package/dist/utils/subscribe.js +0 -51
- package/dist/utils/subscribe.js.map +0 -1
- package/dist/utils/validateHandlers.js +0 -21
- package/dist/utils/validateHandlers.js.map +0 -1
- package/eslint.config.mjs +0 -838
- package/src/AbstractAggregate.ts +0 -223
- package/src/AbstractProjection.ts +0 -209
- package/src/AbstractSaga.ts +0 -118
- package/src/AggregateCommandHandler.ts +0 -131
- package/src/CommandBus.ts +0 -100
- package/src/CqrsContainerBuilder.ts +0 -124
- package/src/Event.ts +0 -32
- package/src/EventDispatcher.ts +0 -173
- package/src/EventStore.ts +0 -205
- package/src/EventValidationProcessor.ts +0 -33
- package/src/SagaEventHandler.ts +0 -160
- package/src/in-memory/InMemoryEventStorage.ts +0 -108
- package/src/in-memory/InMemoryLock.ts +0 -43
- package/src/in-memory/InMemoryMessageBus.ts +0 -140
- package/src/in-memory/InMemorySnapshotStorage.ts +0 -89
- package/src/in-memory/InMemoryView.ts +0 -208
- package/src/in-memory/index.ts +0 -5
- package/src/in-memory/utils/index.ts +0 -1
- package/src/in-memory/utils/nextCycle.ts +0 -4
- package/src/index.ts +0 -22
- package/src/interfaces/IAggregate.ts +0 -58
- package/src/interfaces/IAggregateSnapshotStorage.ts +0 -11
- package/src/interfaces/ICommand.ts +0 -3
- package/src/interfaces/ICommandBus.ts +0 -16
- package/src/interfaces/IContainer.ts +0 -27
- package/src/interfaces/IDispatchPipelineProcessor.ts +0 -35
- package/src/interfaces/IEvent.ts +0 -13
- package/src/interfaces/IEventBus.ts +0 -11
- package/src/interfaces/IEventDispatcher.ts +0 -7
- package/src/interfaces/IEventLocker.ts +0 -34
- package/src/interfaces/IEventReceptor.ts +0 -6
- package/src/interfaces/IEventSet.ts +0 -7
- package/src/interfaces/IEventStorage.ts +0 -53
- package/src/interfaces/IEventStore.ts +0 -13
- package/src/interfaces/IEventStream.ts +0 -3
- package/src/interfaces/IIdentifierProvider.ts +0 -17
- package/src/interfaces/ILogger.ts +0 -11
- package/src/interfaces/IMessage.ts +0 -22
- package/src/interfaces/IMessageBus.ts +0 -8
- package/src/interfaces/IObjectStorage.ts +0 -13
- package/src/interfaces/IObservable.ts +0 -31
- package/src/interfaces/IObserver.ts +0 -5
- package/src/interfaces/IProjection.ts +0 -20
- package/src/interfaces/ISaga.ts +0 -38
- package/src/interfaces/IViewLocker.ts +0 -46
- package/src/interfaces/Identifier.ts +0 -1
- package/src/interfaces/index.ts +0 -26
- package/src/interfaces/isObject.ts +0 -5
- package/src/rabbitmq/IContainer.ts +0 -16
- package/src/rabbitmq/RabbitMqEventBus.ts +0 -104
- package/src/rabbitmq/RabbitMqEventInjector.ts +0 -66
- package/src/rabbitmq/RabbitMqGateway.ts +0 -473
- package/src/rabbitmq/TerminationHandler.ts +0 -31
- package/src/rabbitmq/constants.ts +0 -2
- package/src/rabbitmq/index.ts +0 -3
- package/src/sqlite/AbstractSqliteAccessor.ts +0 -58
- package/src/sqlite/AbstractSqliteObjectProjection.ts +0 -31
- package/src/sqlite/AbstractSqliteView.ts +0 -53
- package/src/sqlite/IContainer.ts +0 -8
- package/src/sqlite/SqliteEventLocker.ts +0 -137
- package/src/sqlite/SqliteObjectStorage.ts +0 -142
- package/src/sqlite/SqliteObjectView.ts +0 -58
- package/src/sqlite/SqliteProjectionDataParams.ts +0 -16
- package/src/sqlite/SqliteViewLocker.ts +0 -167
- package/src/sqlite/index.ts +0 -8
- package/src/sqlite/queries/eventLockTableInit.ts +0 -10
- package/src/sqlite/queries/index.ts +0 -2
- package/src/sqlite/queries/viewLockTableInit.ts +0 -9
- package/src/sqlite/utils/getEventId.ts +0 -8
- package/src/sqlite/utils/guid.ts +0 -4
- package/src/sqlite/utils/index.ts +0 -2
- package/src/utils/Deferred.ts +0 -41
- package/src/utils/Lock.ts +0 -53
- package/src/utils/delay.ts +0 -8
- package/src/utils/getClassName.ts +0 -6
- package/src/utils/getHandler.ts +0 -20
- package/src/utils/getMessageHandlerNames.ts +0 -38
- package/src/utils/index.ts +0 -12
- package/src/utils/isClass.ts +0 -4
- package/src/utils/iteratorToArray.ts +0 -6
- package/src/utils/notEmpty.ts +0 -1
- package/src/utils/setupOneTimeEmitterSubscription.ts +0 -59
- package/src/utils/subscribe.ts +0 -65
- package/src/utils/validateHandlers.ts +0 -20
- package/types/AbstractAggregate.d.ts +0 -57
- package/types/AbstractProjection.d.ts +0 -60
- package/types/AbstractSaga.d.ts +0 -31
- package/types/AggregateCommandHandler.d.ts +0 -20
- package/types/CommandBus.d.ts +0 -27
- package/types/CqrsContainerBuilder.d.ts +0 -21
- package/types/Event.d.ts +0 -13
- package/types/EventDispatcher.d.ts +0 -32
- package/types/EventStore.d.ts +0 -34
- package/types/EventValidationProcessor.d.ts +0 -19
- package/types/SagaEventHandler.d.ts +0 -21
- package/types/in-memory/InMemoryEventStorage.d.ts +0 -24
- package/types/in-memory/InMemoryLock.d.ts +0 -21
- package/types/in-memory/InMemoryMessageBus.d.ts +0 -42
- package/types/in-memory/InMemorySnapshotStorage.d.ts +0 -37
- package/types/in-memory/InMemoryView.d.ts +0 -53
- package/types/in-memory/index.d.ts +0 -5
- package/types/in-memory/utils/index.d.ts +0 -1
- package/types/index.d.ts +0 -14
- package/types/interfaces/IAggregate.d.ts +0 -35
- package/types/interfaces/IAggregateSnapshotStorage.d.ts +0 -7
- package/types/interfaces/ICommand.d.ts +0 -2
- package/types/interfaces/ICommandBus.d.ts +0 -14
- package/types/interfaces/IContainer.d.ts +0 -23
- package/types/interfaces/IDispatchPipelineProcessor.d.ts +0 -25
- package/types/interfaces/IEvent.d.ts +0 -6
- package/types/interfaces/IEventBus.d.ts +0 -6
- package/types/interfaces/IEventDispatcher.d.ts +0 -6
- package/types/interfaces/IEventLocker.d.ts +0 -24
- package/types/interfaces/IEventReceptor.d.ts +0 -5
- package/types/interfaces/IEventSet.d.ts +0 -3
- package/types/interfaces/IEventStorage.d.ts +0 -36
- package/types/interfaces/IEventStore.d.ts +0 -9
- package/types/interfaces/IEventStream.d.ts +0 -2
- package/types/interfaces/IIdentifierProvider.d.ts +0 -10
- package/types/interfaces/IMessage.d.ts +0 -12
- package/types/interfaces/IMessageBus.d.ts +0 -7
- package/types/interfaces/IObjectStorage.d.ts +0 -8
- package/types/interfaces/IObservable.d.ts +0 -19
- package/types/interfaces/IObserver.d.ts +0 -4
- package/types/interfaces/IProjection.d.ts +0 -17
- package/types/interfaces/ISaga.d.ts +0 -30
- package/types/interfaces/Identifier.d.ts +0 -1
- package/types/interfaces/index.d.ts +0 -26
- package/types/interfaces/isObject.d.ts +0 -1
- package/types/rabbitmq/IContainer.d.ts +0 -14
- package/types/rabbitmq/RabbitMqEventBus.d.ts +0 -41
- package/types/rabbitmq/RabbitMqEventInjector.d.ts +0 -13
- package/types/rabbitmq/RabbitMqGateway.d.ts +0 -78
- package/types/rabbitmq/TerminationHandler.d.ts +0 -10
- package/types/rabbitmq/constants.d.ts +0 -2
- package/types/rabbitmq/index.d.ts +0 -3
- package/types/sqlite/AbstractSqliteAccessor.d.ts +0 -25
- package/types/sqlite/AbstractSqliteObjectProjection.d.ts +0 -8
- package/types/sqlite/AbstractSqliteView.d.ts +0 -18
- package/types/sqlite/IContainer.d.ts +0 -7
- package/types/sqlite/SqliteEventLocker.d.ts +0 -28
- package/types/sqlite/SqliteObjectStorage.d.ts +0 -16
- package/types/sqlite/SqliteObjectView.d.ts +0 -16
- package/types/sqlite/SqliteViewLocker.d.ts +0 -30
- package/types/sqlite/index.d.ts +0 -8
- package/types/sqlite/queries/index.d.ts +0 -2
- package/types/sqlite/utils/getEventId.d.ts +0 -5
- package/types/sqlite/utils/index.d.ts +0 -2
- package/types/utils/Lock.d.ts +0 -22
- package/types/utils/delay.d.ts +0 -5
- package/types/utils/getHandler.d.ts +0 -7
- package/types/utils/getMessageHandlerNames.d.ts +0 -5
- package/types/utils/index.d.ts +0 -12
- package/types/utils/isClass.d.ts +0 -1
- package/types/utils/iteratorToArray.d.ts +0 -1
- package/types/utils/notEmpty.d.ts +0 -1
- package/types/utils/setupOneTimeEmitterSubscription.d.ts +0 -12
- package/types/utils/subscribe.d.ts +0 -13
- /package/dist/{interfaces → cjs/interfaces}/IAggregate.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/ICommand.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/ICommandBus.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IContainer.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IEventDispatcher.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IEventReceptor.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IEventStore.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IEventStream.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/ILogger.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IObjectStorage.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IObserver.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/IProjection.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/ISaga.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/Identifier.js +0 -0
- /package/dist/{interfaces → cjs/interfaces}/isObject.js +0 -0
- /package/dist/{rabbitmq → cjs/rabbitmq}/IContainer.js +0 -0
- /package/dist/{sqlite → cjs/sqlite}/IContainer.js +0 -0
- /package/dist/{sqlite → cjs/sqlite}/SqliteProjectionDataParams.js +0 -0
- /package/dist/{sqlite → cjs/sqlite}/queries/viewLockTableInit.js +0 -0
- /package/dist/{sqlite → cjs/sqlite}/utils/guid.js +0 -0
- /package/dist/{utils → cjs/utils}/Deferred.js +0 -0
- /package/dist/{utils → cjs/utils}/getClassName.js +0 -0
- /package/dist/{utils → cjs/utils}/isClass.js +0 -0
- /package/{types → dist/types}/in-memory/utils/nextCycle.d.ts +0 -0
- /package/{types → dist/types}/interfaces/ILogger.d.ts +0 -0
- /package/{types → dist/types}/interfaces/IViewLocker.d.ts +0 -0
- /package/{types → dist/types}/sqlite/SqliteProjectionDataParams.d.ts +0 -0
- /package/{types → dist/types}/sqlite/queries/eventLockTableInit.d.ts +0 -0
- /package/{types → dist/types}/sqlite/queries/viewLockTableInit.d.ts +0 -0
- /package/{types → dist/types}/sqlite/utils/guid.d.ts +0 -0
- /package/{types → dist/types}/utils/Deferred.d.ts +0 -0
- /package/{types → dist/types}/utils/getClassName.d.ts +0 -0
- /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
|
-
}
|
package/src/rabbitmq/index.ts
DELETED
|
@@ -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
|
-
}
|