@anatix/runtime 1.0.0 → 1.0.2
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/dist/contracts/index.d.ts +2 -0
- package/dist/contracts/index.d.ts.map +1 -0
- package/dist/{configs → contracts}/index.js +1 -2
- package/dist/contracts/index.js.map +1 -0
- package/dist/contracts/service-options.d.ts +15 -0
- package/dist/contracts/service-options.d.ts.map +1 -0
- package/dist/{configs/service-runtime.js → contracts/service-options.js} +1 -1
- package/dist/contracts/service-options.js.map +1 -0
- package/dist/decorators/filters/exception-filter.config.d.ts +7 -0
- package/dist/decorators/filters/exception-filter.config.d.ts.map +1 -0
- package/dist/decorators/filters/exception-filter.config.js +9 -0
- package/dist/decorators/filters/exception-filter.config.js.map +1 -0
- package/dist/decorators/filters/global-exception.filter.d.ts +3 -2
- package/dist/decorators/filters/global-exception.filter.d.ts.map +1 -1
- package/dist/decorators/filters/global-exception.filter.js +14 -5
- package/dist/decorators/filters/global-exception.filter.js.map +1 -1
- package/dist/decorators/filters/index.d.ts +1 -0
- package/dist/decorators/filters/index.d.ts.map +1 -1
- package/dist/decorators/filters/index.js +1 -0
- package/dist/decorators/filters/index.js.map +1 -1
- package/dist/dtos/error-response.dto.d.ts +20 -0
- package/dist/dtos/error-response.dto.d.ts.map +1 -0
- package/dist/dtos/error-response.dto.js +42 -0
- package/dist/dtos/error-response.dto.js.map +1 -0
- package/dist/dtos/index.d.ts +3 -0
- package/dist/dtos/index.d.ts.map +1 -0
- package/dist/dtos/index.js +13 -0
- package/dist/dtos/index.js.map +1 -0
- package/dist/dtos/paginated-response.dto.d.ts +16 -0
- package/dist/dtos/paginated-response.dto.d.ts.map +1 -0
- package/dist/dtos/paginated-response.dto.js +31 -0
- package/dist/dtos/paginated-response.dto.js.map +1 -0
- package/dist/envelope/envelope.config.d.ts +17 -0
- package/dist/envelope/envelope.config.d.ts.map +1 -0
- package/dist/envelope/envelope.config.js +5 -0
- package/dist/envelope/envelope.config.js.map +1 -0
- package/dist/envelope/index.d.ts +2 -0
- package/dist/envelope/index.d.ts.map +1 -1
- package/dist/envelope/index.js +2 -0
- package/dist/envelope/index.js.map +1 -1
- package/dist/envelope/repositories/outbox.repository.d.ts.map +1 -1
- package/dist/envelope/repositories/outbox.repository.js +1 -1
- package/dist/envelope/repositories/outbox.repository.js.map +1 -1
- package/dist/envelope/services/inbox-retry.service.d.ts +6 -3
- package/dist/envelope/services/inbox-retry.service.d.ts.map +1 -1
- package/dist/envelope/services/inbox-retry.service.js +20 -7
- package/dist/envelope/services/inbox-retry.service.js.map +1 -1
- package/dist/envelope/services/index.d.ts +1 -0
- package/dist/envelope/services/index.d.ts.map +1 -1
- package/dist/envelope/services/index.js +1 -0
- package/dist/envelope/services/index.js.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.d.ts +8 -4
- package/dist/envelope/services/outbox-dispatcher.service.d.ts.map +1 -1
- package/dist/envelope/services/outbox-dispatcher.service.js +82 -22
- package/dist/envelope/services/outbox-dispatcher.service.js.map +1 -1
- package/dist/envelope/tx-manager.d.ts +14 -0
- package/dist/envelope/tx-manager.d.ts.map +1 -0
- package/dist/envelope/tx-manager.js +20 -0
- package/dist/envelope/tx-manager.js.map +1 -0
- package/dist/event-bus/adapters/index.d.ts +4 -0
- package/dist/event-bus/adapters/index.d.ts.map +1 -0
- package/dist/event-bus/adapters/index.js +20 -0
- package/dist/event-bus/adapters/index.js.map +1 -0
- package/dist/event-bus/adapters/kafka.adapter.d.ts +28 -0
- package/dist/event-bus/adapters/kafka.adapter.d.ts.map +1 -0
- package/dist/event-bus/adapters/kafka.adapter.js +263 -0
- package/dist/event-bus/adapters/kafka.adapter.js.map +1 -0
- package/dist/event-bus/adapters/message-broker.interface.d.ts +39 -0
- package/dist/event-bus/adapters/message-broker.interface.d.ts.map +1 -0
- package/dist/{configs/service-repo-configs.js → event-bus/adapters/message-broker.interface.js} +1 -1
- package/dist/event-bus/adapters/message-broker.interface.js.map +1 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.d.ts +21 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.d.ts.map +1 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.js +232 -0
- package/dist/event-bus/adapters/rabbitmq.adapter.js.map +1 -0
- package/dist/event-bus/config/adapter.config.d.ts +65 -0
- package/dist/event-bus/config/adapter.config.d.ts.map +1 -0
- package/dist/event-bus/config/adapter.config.js +6 -0
- package/dist/event-bus/config/adapter.config.js.map +1 -0
- package/dist/event-bus/config/index.d.ts +2 -0
- package/dist/event-bus/config/index.d.ts.map +1 -0
- package/dist/event-bus/config/index.js +18 -0
- package/dist/event-bus/config/index.js.map +1 -0
- package/dist/event-bus/event-bus.config.d.ts +36 -0
- package/dist/event-bus/event-bus.config.d.ts.map +1 -0
- package/dist/event-bus/event-bus.config.js +17 -0
- package/dist/event-bus/event-bus.config.js.map +1 -0
- package/dist/event-bus/index.d.ts +1 -0
- package/dist/event-bus/index.d.ts.map +1 -1
- package/dist/event-bus/index.js +1 -0
- package/dist/event-bus/index.js.map +1 -1
- package/dist/event-bus/modules/event-bus.module.d.ts.map +1 -1
- package/dist/event-bus/modules/event-bus.module.js +9 -2
- package/dist/event-bus/modules/event-bus.module.js.map +1 -1
- package/dist/event-bus/services/event-bus.service.d.ts +10 -5
- package/dist/event-bus/services/event-bus.service.d.ts.map +1 -1
- package/dist/event-bus/services/event-bus.service.js +110 -185
- package/dist/event-bus/services/event-bus.service.js.map +1 -1
- package/dist/event-bus/types/event-bus-adapter.interface.d.ts +43 -0
- package/dist/event-bus/types/event-bus-adapter.interface.d.ts.map +1 -0
- package/dist/event-bus/types/event-bus-adapter.interface.js +3 -0
- package/dist/event-bus/types/event-bus-adapter.interface.js.map +1 -0
- package/dist/guards/base/index.d.ts +0 -1
- package/dist/guards/base/index.d.ts.map +1 -1
- package/dist/guards/base/index.js +0 -1
- package/dist/guards/base/index.js.map +1 -1
- package/dist/guards/base/jwt-auth.guard.d.ts +6 -1
- package/dist/guards/base/jwt-auth.guard.d.ts.map +1 -1
- package/dist/guards/base/jwt-auth.guard.js +32 -20
- package/dist/guards/base/jwt-auth.guard.js.map +1 -1
- package/dist/guards/base/permissions.guard.d.ts +1 -0
- package/dist/guards/base/permissions.guard.d.ts.map +1 -1
- package/dist/guards/base/permissions.guard.js +6 -2
- package/dist/guards/base/permissions.guard.js.map +1 -1
- package/dist/guards/types/base-roles.enum.d.ts +6 -0
- package/dist/guards/types/base-roles.enum.d.ts.map +1 -0
- package/dist/guards/types/base-roles.enum.js +10 -0
- package/dist/guards/types/base-roles.enum.js.map +1 -0
- package/dist/guards/types/index.d.ts +2 -0
- package/dist/guards/types/index.d.ts.map +1 -1
- package/dist/guards/types/index.js +2 -0
- package/dist/guards/types/index.js.map +1 -1
- package/dist/guards/types/tokens.constant.d.ts +5 -0
- package/dist/guards/types/tokens.constant.d.ts.map +1 -0
- package/dist/guards/types/tokens.constant.js +7 -0
- package/dist/guards/types/tokens.constant.js.map +1 -0
- package/dist/guards/utils/token.util.d.ts.map +1 -1
- package/dist/guards/utils/token.util.js +14 -9
- package/dist/guards/utils/token.util.js.map +1 -1
- package/dist/health/health.service.d.ts +1 -0
- package/dist/health/health.service.d.ts.map +1 -1
- package/dist/health/health.service.js +12 -3
- package/dist/health/health.service.js.map +1 -1
- package/dist/health/index.d.ts +2 -0
- package/dist/health/index.d.ts.map +1 -0
- package/dist/health/index.js +18 -0
- package/dist/health/index.js.map +1 -0
- package/dist/index.d.ts +8 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +62 -2
- package/dist/index.js.map +1 -1
- package/dist/monitoring/index.d.ts +2 -0
- package/dist/monitoring/index.d.ts.map +1 -0
- package/dist/monitoring/index.js +18 -0
- package/dist/monitoring/index.js.map +1 -0
- package/dist/proxy/config/proxy.config.d.ts +6 -2
- package/dist/proxy/config/proxy.config.d.ts.map +1 -1
- package/dist/proxy/config/proxy.config.js +6 -3
- package/dist/proxy/config/proxy.config.js.map +1 -1
- package/dist/proxy/methods/proxy-delete.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-delete.js +2 -2
- package/dist/proxy/methods/proxy-delete.js.map +1 -1
- package/dist/proxy/methods/proxy-get.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-get.js +2 -2
- package/dist/proxy/methods/proxy-get.js.map +1 -1
- package/dist/proxy/methods/proxy-patch.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-patch.js +2 -2
- package/dist/proxy/methods/proxy-patch.js.map +1 -1
- package/dist/proxy/methods/proxy-post.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-post.js +2 -2
- package/dist/proxy/methods/proxy-post.js.map +1 -1
- package/dist/proxy/methods/proxy-put.d.ts.map +1 -1
- package/dist/proxy/methods/proxy-put.js +2 -2
- package/dist/proxy/methods/proxy-put.js.map +1 -1
- package/dist/repository/bulk.d.ts +12 -0
- package/dist/repository/bulk.d.ts.map +1 -0
- package/dist/repository/bulk.js +107 -0
- package/dist/repository/bulk.js.map +1 -0
- package/dist/repository/cursor.d.ts +13 -0
- package/dist/repository/cursor.d.ts.map +1 -0
- package/dist/repository/cursor.js +73 -0
- package/dist/repository/cursor.js.map +1 -0
- package/dist/repository/index.d.ts +7 -0
- package/dist/repository/index.d.ts.map +1 -0
- package/dist/repository/index.js +25 -0
- package/dist/repository/index.js.map +1 -0
- package/dist/repository/lock.d.ts +8 -0
- package/dist/repository/lock.d.ts.map +1 -0
- package/dist/repository/lock.js +35 -0
- package/dist/repository/lock.js.map +1 -0
- package/dist/repository/retry.d.ts +7 -0
- package/dist/repository/retry.d.ts.map +1 -0
- package/dist/repository/retry.js +43 -0
- package/dist/repository/retry.js.map +1 -0
- package/dist/repository/scope.d.ts +8 -0
- package/dist/repository/scope.d.ts.map +1 -0
- package/dist/repository/scope.js +16 -0
- package/dist/repository/scope.js.map +1 -0
- package/dist/result/index.d.ts +2 -0
- package/dist/result/index.d.ts.map +1 -0
- package/dist/result/index.js +16 -0
- package/dist/result/index.js.map +1 -0
- package/dist/result/result.d.ts +26 -0
- package/dist/result/result.d.ts.map +1 -0
- package/dist/result/result.js +73 -0
- package/dist/result/result.js.map +1 -0
- package/dist/security/bcrypt.adapter.d.ts +9 -0
- package/dist/security/bcrypt.adapter.d.ts.map +1 -0
- package/dist/security/bcrypt.adapter.js +53 -0
- package/dist/security/bcrypt.adapter.js.map +1 -0
- package/dist/security/index.d.ts +2 -0
- package/dist/security/index.d.ts.map +1 -1
- package/dist/security/index.js +2 -0
- package/dist/security/index.js.map +1 -1
- package/dist/security/security.config.d.ts +6 -0
- package/dist/security/security.config.d.ts.map +1 -0
- package/dist/security/security.config.js +8 -0
- package/dist/security/security.config.js.map +1 -0
- package/dist/service/cache.d.ts +11 -0
- package/dist/service/cache.d.ts.map +1 -0
- package/dist/service/cache.js +45 -0
- package/dist/service/cache.js.map +1 -0
- package/dist/service/circuit-breaker.d.ts +19 -0
- package/dist/service/circuit-breaker.d.ts.map +1 -0
- package/dist/service/circuit-breaker.js +73 -0
- package/dist/service/circuit-breaker.js.map +1 -0
- package/dist/service/enrichment.d.ts +8 -0
- package/dist/service/enrichment.d.ts.map +1 -0
- package/dist/service/enrichment.js +40 -0
- package/dist/service/enrichment.js.map +1 -0
- package/dist/service/idempotency.d.ts +8 -0
- package/dist/service/idempotency.d.ts.map +1 -0
- package/dist/service/idempotency.js +28 -0
- package/dist/service/idempotency.js.map +1 -0
- package/dist/service/index.d.ts +10 -0
- package/dist/service/index.d.ts.map +1 -0
- package/dist/service/index.js +45 -0
- package/dist/service/index.js.map +1 -0
- package/dist/service/projection.d.ts +14 -0
- package/dist/service/projection.d.ts.map +1 -0
- package/dist/service/projection.js +59 -0
- package/dist/service/projection.js.map +1 -0
- package/dist/service/rate-limit.d.ts +10 -0
- package/dist/service/rate-limit.d.ts.map +1 -0
- package/dist/service/rate-limit.js +42 -0
- package/dist/service/rate-limit.js.map +1 -0
- package/dist/service/retry.d.ts +8 -0
- package/dist/service/retry.d.ts.map +1 -0
- package/dist/service/retry.js +62 -0
- package/dist/service/retry.js.map +1 -0
- package/dist/service/timeout.d.ts +7 -0
- package/dist/service/timeout.d.ts.map +1 -0
- package/dist/service/timeout.js +39 -0
- package/dist/service/timeout.js.map +1 -0
- package/dist/service/transaction.d.ts +12 -0
- package/dist/service/transaction.d.ts.map +1 -0
- package/dist/service/transaction.js +17 -0
- package/dist/service/transaction.js.map +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/dist/utils/retry.d.ts +7 -0
- package/dist/utils/retry.d.ts.map +1 -0
- package/dist/utils/retry.js +27 -0
- package/dist/utils/retry.js.map +1 -0
- package/package.json +52 -15
- package/dist/configs/env-validation.d.ts +0 -2
- package/dist/configs/env-validation.d.ts.map +0 -1
- package/dist/configs/env-validation.js +0 -49
- package/dist/configs/env-validation.js.map +0 -1
- package/dist/configs/index.d.ts +0 -3
- package/dist/configs/index.d.ts.map +0 -1
- package/dist/configs/index.js.map +0 -1
- package/dist/configs/service-repo-configs.d.ts +0 -13
- package/dist/configs/service-repo-configs.d.ts.map +0 -1
- package/dist/configs/service-repo-configs.js.map +0 -1
- package/dist/configs/service-runtime.d.ts +0 -19
- package/dist/configs/service-runtime.d.ts.map +0 -1
- package/dist/configs/service-runtime.js.map +0 -1
- package/dist/guards/base/roles.guard.d.ts +0 -10
- package/dist/guards/base/roles.guard.d.ts.map +0 -1
- package/dist/guards/base/roles.guard.js +0 -58
- package/dist/guards/base/roles.guard.js.map +0 -1
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-broker.interface.d.ts","sourceRoot":"","sources":["../../../src/event-bus/adapters/message-broker.interface.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAKhD,MAAM,WAAW,sBAAsB;IAErC,GAAG,CAAC,EAAE,MAAM,GAAG,MAAM,EAAE,CAAC;IAExB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CAC/B;AAKD,MAAM,WAAW,aAAa;IAE5B,KAAK,EAAE,MAAM,CAAC;IAEd,OAAO,EAAE,GAAG,CAAC;IAEb,IAAI,CAAC,EAAE,SAAS,CAAC;IAEjB,OAAO,CAAC,EAAE;QACR,WAAW,EAAE,MAAM,CAAC;QACpB,aAAa,EAAE,MAAM,CAAC;KACvB,CAAC;IAEF,GAAG,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAEzB,IAAI,EAAE,CAAC,OAAO,CAAC,EAAE,OAAO,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;CAC5C;AAKD,MAAM,MAAM,cAAc,GAAG,CAAC,OAAO,EAAE,aAAa,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;AAKvE,MAAM,WAAW,oBAAoB;IAInC,OAAO,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAKvD,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;IAU5B,OAAO,CACL,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,EAChB,OAAO,CAAC,EAAE,cAAc,GACvB,OAAO,CAAC,IAAI,CAAC,CAAC;IAWjB,OAAO,CAAC,CAAC,GAAG,GAAG,EACb,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,EAChB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,CAAC,CAAC,CAAC;IAUd,KAAK,CACH,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,GACf,OAAO,CAAC,IAAI,CAAC,CAAC;IAQjB,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAOjE,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAK1C,WAAW,IAAI,OAAO,CAAC;IAQvB,cAAc,CAAC,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7D;AAKD,MAAM,WAAW,cAAc;IAE7B,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAE9B,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,SAAS,CAAC,EAAE,MAAM,CAAC;IAEnB,GAAG,CAAC,EAAE,MAAM,CAAC;CACd"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"message-broker.interface.js","sourceRoot":"","sources":["../../../src/event-bus/adapters/message-broker.interface.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { MessageBrokerAdapter, BrokerConnectionConfig, MessageHandler, PublishOptions } from './message-broker.interface';
|
|
2
|
+
import type { EventMeta } from '../../envelope';
|
|
3
|
+
export declare class RabbitMQAdapter implements MessageBrokerAdapter {
|
|
4
|
+
private readonly logger;
|
|
5
|
+
private connection?;
|
|
6
|
+
private channel?;
|
|
7
|
+
private exchangeName;
|
|
8
|
+
private queueName;
|
|
9
|
+
private handlers;
|
|
10
|
+
connect(config: BrokerConnectionConfig): Promise<void>;
|
|
11
|
+
disconnect(): Promise<void>;
|
|
12
|
+
publish(topic: string, payload: any, meta?: EventMeta, options?: PublishOptions): Promise<void>;
|
|
13
|
+
request<T = any>(topic: string, payload: any, meta?: EventMeta, timeoutMs?: number): Promise<T>;
|
|
14
|
+
reply(replyTo: string, correlationId: string, payload: any, meta?: EventMeta): Promise<void>;
|
|
15
|
+
subscribe(topic: string, handler: MessageHandler): Promise<void>;
|
|
16
|
+
unsubscribe(topic: string): Promise<void>;
|
|
17
|
+
isConnected(): boolean;
|
|
18
|
+
createExchange(name: string, type?: string): Promise<void>;
|
|
19
|
+
private handleMessage;
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=rabbitmq.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rabbitmq.adapter.d.ts","sourceRoot":"","sources":["../../../src/event-bus/adapters/rabbitmq.adapter.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EACV,oBAAoB,EACpB,sBAAsB,EAEtB,cAAc,EACd,cAAc,EACf,MAAM,4BAA4B,CAAC;AACpC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AA4BhD,qBAAa,eAAgB,YAAW,oBAAoB;IAC1D,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoC;IAE3D,OAAO,CAAC,UAAU,CAAC,CAAe;IAClC,OAAO,CAAC,OAAO,CAAC,CAAU;IAC1B,OAAO,CAAC,YAAY,CAAsB;IAC1C,OAAO,CAAC,SAAS,CAAmB;IACpC,OAAO,CAAC,QAAQ,CAAuC;IAKjD,OAAO,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;IAiDtD,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAqB3B,OAAO,CACX,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,EAChB,OAAO,CAAC,EAAE,cAAc,GACvB,OAAO,CAAC,IAAI,CAAC;IAkCV,OAAO,CAAC,CAAC,GAAG,GAAG,EACnB,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,EAChB,SAAS,SAAO,GACf,OAAO,CAAC,CAAC,CAAC;IA4EP,KAAK,CACT,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,GACf,OAAO,CAAC,IAAI,CAAC;IAsBV,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAoBhE,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAgB/C,WAAW,IAAI,OAAO;IAOhB,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,IAAI,SAAU,GAAG,OAAO,CAAC,IAAI,CAAC;YAYnD,aAAa;CAyE5B"}
|
|
@@ -0,0 +1,232 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.RabbitMQAdapter = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const amqplib_1 = require("amqplib");
|
|
6
|
+
const envelope_1 = require("../../envelope");
|
|
7
|
+
class RabbitMQAdapter {
|
|
8
|
+
logger = new common_1.Logger(RabbitMQAdapter.name);
|
|
9
|
+
connection;
|
|
10
|
+
channel;
|
|
11
|
+
exchangeName = 'anatix-event-bus';
|
|
12
|
+
queueName = 'default-queue';
|
|
13
|
+
handlers = new Map();
|
|
14
|
+
async connect(config) {
|
|
15
|
+
const url = Array.isArray(config.url) ? config.url[0] : config.url || 'amqp://localhost';
|
|
16
|
+
const prefetch = config.prefetch ?? 1;
|
|
17
|
+
const exchangeName = config.options?.exchange ?? 'anatix-event-bus';
|
|
18
|
+
const exchangeType = config.options?.exchangeType ?? 'topic';
|
|
19
|
+
const queueName = config.serviceName ?? 'default-queue';
|
|
20
|
+
this.exchangeName = exchangeName;
|
|
21
|
+
this.queueName = queueName;
|
|
22
|
+
try {
|
|
23
|
+
this.connection = await (0, amqplib_1.connect)(url);
|
|
24
|
+
this.channel = await this.connection.createChannel();
|
|
25
|
+
await this.channel.assertExchange(this.exchangeName, exchangeType, {
|
|
26
|
+
durable: true,
|
|
27
|
+
});
|
|
28
|
+
await this.channel.assertQueue(this.queueName, {
|
|
29
|
+
durable: true,
|
|
30
|
+
});
|
|
31
|
+
await this.channel.prefetch(prefetch);
|
|
32
|
+
await this.channel.consume(this.queueName, (msg) => this.handleMessage(msg), { noAck: false });
|
|
33
|
+
this.logger.log(`Connected to RabbitMQ: ${url} (exchange: ${this.exchangeName}, queue: ${this.queueName})`);
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
this.logger.error(`Failed to connect to RabbitMQ: ${error?.message || error}`);
|
|
37
|
+
throw error;
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
async disconnect() {
|
|
41
|
+
try {
|
|
42
|
+
if (this.channel) {
|
|
43
|
+
await this.channel.close();
|
|
44
|
+
this.channel = undefined;
|
|
45
|
+
}
|
|
46
|
+
if (this.connection) {
|
|
47
|
+
await this.connection.close();
|
|
48
|
+
this.connection = undefined;
|
|
49
|
+
}
|
|
50
|
+
this.logger.log('Disconnected from RabbitMQ');
|
|
51
|
+
}
|
|
52
|
+
catch (error) {
|
|
53
|
+
this.logger.error(`Error disconnecting from RabbitMQ: ${error?.message || error}`);
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
async publish(topic, payload, meta, options) {
|
|
57
|
+
if (!this.channel) {
|
|
58
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
59
|
+
}
|
|
60
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
61
|
+
const message = {
|
|
62
|
+
__event: topic,
|
|
63
|
+
data: payload,
|
|
64
|
+
meta: eventMeta,
|
|
65
|
+
};
|
|
66
|
+
const buffer = Buffer.from(JSON.stringify(message));
|
|
67
|
+
const publishOptions = {
|
|
68
|
+
contentType: 'application/json',
|
|
69
|
+
persistent: options?.persistent ?? true,
|
|
70
|
+
};
|
|
71
|
+
if (options?.headers) {
|
|
72
|
+
publishOptions.headers = options.headers;
|
|
73
|
+
}
|
|
74
|
+
if (options?.ttl) {
|
|
75
|
+
publishOptions.expiration = String(options.ttl);
|
|
76
|
+
}
|
|
77
|
+
this.channel.publish(this.exchangeName, topic, buffer, publishOptions);
|
|
78
|
+
}
|
|
79
|
+
async request(topic, payload, meta, timeoutMs = 5000) {
|
|
80
|
+
if (!this.channel) {
|
|
81
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
82
|
+
}
|
|
83
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
84
|
+
const { queue: replyQueue } = await this.channel.assertQueue('', {
|
|
85
|
+
exclusive: true,
|
|
86
|
+
durable: false,
|
|
87
|
+
autoDelete: true,
|
|
88
|
+
});
|
|
89
|
+
return new Promise((resolve, reject) => {
|
|
90
|
+
let consumerTag = '';
|
|
91
|
+
const onReply = (msg) => {
|
|
92
|
+
if (!msg)
|
|
93
|
+
return;
|
|
94
|
+
try {
|
|
95
|
+
const content = JSON.parse(msg.content.toString());
|
|
96
|
+
if (content.__correlationId === eventMeta.correlationId) {
|
|
97
|
+
clearTimeout(timer);
|
|
98
|
+
this.channel?.cancel(consumerTag).catch(() => { });
|
|
99
|
+
resolve(content.data);
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
catch {
|
|
103
|
+
}
|
|
104
|
+
};
|
|
105
|
+
this.channel.consume(replyQueue, onReply, { noAck: true })
|
|
106
|
+
.then(({ consumerTag: tag }) => {
|
|
107
|
+
consumerTag = tag;
|
|
108
|
+
const message = {
|
|
109
|
+
__event: topic,
|
|
110
|
+
__replyTo: replyQueue,
|
|
111
|
+
__correlationId: eventMeta.correlationId,
|
|
112
|
+
data: payload,
|
|
113
|
+
meta: eventMeta,
|
|
114
|
+
};
|
|
115
|
+
this.channel.publish(this.exchangeName, topic, Buffer.from(JSON.stringify(message)), {
|
|
116
|
+
contentType: 'application/json',
|
|
117
|
+
persistent: true,
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
const timer = setTimeout(() => {
|
|
121
|
+
this.channel?.cancel(consumerTag).catch(() => { });
|
|
122
|
+
reject(new Error(`RPC timeout for topic "${topic}" (correlationId: ${eventMeta.correlationId})`));
|
|
123
|
+
}, timeoutMs);
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
async reply(replyTo, correlationId, payload, meta) {
|
|
127
|
+
if (!this.channel) {
|
|
128
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
129
|
+
}
|
|
130
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
131
|
+
const message = {
|
|
132
|
+
__correlationId: correlationId,
|
|
133
|
+
data: payload,
|
|
134
|
+
meta: eventMeta,
|
|
135
|
+
};
|
|
136
|
+
this.channel.sendToQueue(replyTo, Buffer.from(JSON.stringify(message)), {
|
|
137
|
+
contentType: 'application/json',
|
|
138
|
+
persistent: false,
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
async subscribe(topic, handler) {
|
|
142
|
+
if (!this.channel) {
|
|
143
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
144
|
+
}
|
|
145
|
+
if (!this.handlers.has(topic)) {
|
|
146
|
+
this.handlers.set(topic, []);
|
|
147
|
+
await this.channel.bindQueue(this.queueName, this.exchangeName, topic);
|
|
148
|
+
this.logger.log(`Subscribed to topic: ${topic}`);
|
|
149
|
+
}
|
|
150
|
+
this.handlers.get(topic).push(handler);
|
|
151
|
+
}
|
|
152
|
+
async unsubscribe(topic) {
|
|
153
|
+
if (!this.channel) {
|
|
154
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
155
|
+
}
|
|
156
|
+
if (this.handlers.has(topic)) {
|
|
157
|
+
await this.channel.unbindQueue(this.queueName, this.exchangeName, topic);
|
|
158
|
+
this.handlers.delete(topic);
|
|
159
|
+
this.logger.log(`Unsubscribed from topic: ${topic}`);
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
isConnected() {
|
|
163
|
+
return !!this.channel && !!this.connection;
|
|
164
|
+
}
|
|
165
|
+
async createExchange(name, type = 'topic') {
|
|
166
|
+
if (!this.channel) {
|
|
167
|
+
throw new Error('RabbitMQ adapter not connected');
|
|
168
|
+
}
|
|
169
|
+
await this.channel.assertExchange(name, type, { durable: true });
|
|
170
|
+
this.logger.log(`Exchange created: ${name} (type: ${type})`);
|
|
171
|
+
}
|
|
172
|
+
async handleMessage(msg) {
|
|
173
|
+
if (!msg || !this.channel) {
|
|
174
|
+
return;
|
|
175
|
+
}
|
|
176
|
+
let content;
|
|
177
|
+
try {
|
|
178
|
+
content = JSON.parse(msg.content.toString());
|
|
179
|
+
}
|
|
180
|
+
catch {
|
|
181
|
+
this.logger.error('Invalid JSON message; acking to avoid poison loop');
|
|
182
|
+
this.channel.ack(msg);
|
|
183
|
+
return;
|
|
184
|
+
}
|
|
185
|
+
const topic = content.__event;
|
|
186
|
+
if (!topic || typeof topic !== 'string') {
|
|
187
|
+
this.logger.warn('Message without __event topic; acking');
|
|
188
|
+
this.channel.ack(msg);
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
const handlers = this.handlers.get(topic) ?? [];
|
|
192
|
+
if (handlers.length === 0) {
|
|
193
|
+
this.channel.ack(msg);
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
const meta = (0, envelope_1.ensureMeta)(content?.meta);
|
|
197
|
+
const brokerMessage = {
|
|
198
|
+
topic,
|
|
199
|
+
payload: content?.data ?? content,
|
|
200
|
+
meta,
|
|
201
|
+
replyTo: content.__replyTo && content.__correlationId
|
|
202
|
+
? {
|
|
203
|
+
destination: String(content.__replyTo),
|
|
204
|
+
correlationId: String(content.__correlationId),
|
|
205
|
+
}
|
|
206
|
+
: undefined,
|
|
207
|
+
ack: async () => {
|
|
208
|
+
if (this.channel) {
|
|
209
|
+
this.channel.ack(msg);
|
|
210
|
+
}
|
|
211
|
+
},
|
|
212
|
+
nack: async (requeue = false) => {
|
|
213
|
+
if (this.channel) {
|
|
214
|
+
this.channel.nack(msg, false, requeue);
|
|
215
|
+
}
|
|
216
|
+
},
|
|
217
|
+
};
|
|
218
|
+
try {
|
|
219
|
+
for (const handler of handlers) {
|
|
220
|
+
await handler(brokerMessage);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
catch (error) {
|
|
224
|
+
this.logger.error(`Handler failed for topic="${topic}" (corr=${meta.correlationId}): ${error?.message || error}`);
|
|
225
|
+
if (this.channel) {
|
|
226
|
+
this.channel.nack(msg, false, false);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
}
|
|
231
|
+
exports.RabbitMQAdapter = RabbitMQAdapter;
|
|
232
|
+
//# sourceMappingURL=rabbitmq.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"rabbitmq.adapter.js","sourceRoot":"","sources":["../../../src/event-bus/adapters/rabbitmq.adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
export type EventBusAdapterType = 'rabbitmq' | 'kafka' | 'nats' | 'redis';
|
|
2
|
+
export interface BaseAdapterConfig {
|
|
3
|
+
type: EventBusAdapterType;
|
|
4
|
+
serviceName: string;
|
|
5
|
+
topicPrefix?: string;
|
|
6
|
+
}
|
|
7
|
+
export interface RabbitMQAdapterConfig extends BaseAdapterConfig {
|
|
8
|
+
type: 'rabbitmq';
|
|
9
|
+
url: string;
|
|
10
|
+
exchange: string;
|
|
11
|
+
queue: string;
|
|
12
|
+
prefetch?: number;
|
|
13
|
+
connectionOptions?: {
|
|
14
|
+
heartbeat?: number;
|
|
15
|
+
timeout?: number;
|
|
16
|
+
};
|
|
17
|
+
}
|
|
18
|
+
export interface KafkaAdapterConfig extends BaseAdapterConfig {
|
|
19
|
+
type: 'kafka';
|
|
20
|
+
brokers: string[];
|
|
21
|
+
clientId: string;
|
|
22
|
+
groupId: string;
|
|
23
|
+
consumerConfig?: {
|
|
24
|
+
sessionTimeout?: number;
|
|
25
|
+
rebalanceTimeout?: number;
|
|
26
|
+
heartbeatInterval?: number;
|
|
27
|
+
};
|
|
28
|
+
producerConfig?: {
|
|
29
|
+
acks?: 0 | 1 | -1;
|
|
30
|
+
timeout?: number;
|
|
31
|
+
compression?: 'none' | 'gzip' | 'snappy' | 'lz4' | 'zstd';
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
export interface NatsAdapterConfig extends BaseAdapterConfig {
|
|
35
|
+
type: 'nats';
|
|
36
|
+
url: string;
|
|
37
|
+
cluster?: string;
|
|
38
|
+
jetstream?: {
|
|
39
|
+
enabled: boolean;
|
|
40
|
+
stream?: string;
|
|
41
|
+
streamConfig?: {
|
|
42
|
+
retention?: 'limits' | 'interest' | 'workqueue';
|
|
43
|
+
maxMessages?: number;
|
|
44
|
+
maxBytes?: number;
|
|
45
|
+
};
|
|
46
|
+
};
|
|
47
|
+
connectionOptions?: {
|
|
48
|
+
maxReconnectAttempts?: number;
|
|
49
|
+
reconnectTimeWait?: number;
|
|
50
|
+
timeout?: number;
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
export interface RedisAdapterConfig extends BaseAdapterConfig {
|
|
54
|
+
type: 'redis';
|
|
55
|
+
url: string;
|
|
56
|
+
redisOptions?: {
|
|
57
|
+
db?: number;
|
|
58
|
+
password?: string;
|
|
59
|
+
keyPrefix?: string;
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
export type EventBusAdapterConfig = RabbitMQAdapterConfig | KafkaAdapterConfig | NatsAdapterConfig | RedisAdapterConfig;
|
|
63
|
+
export declare const EVENT_BUS_ADAPTER_CONFIG = "EVENT_BUS_ADAPTER_CONFIG";
|
|
64
|
+
export declare const EVENT_BUS_ADAPTER = "EVENT_BUS_ADAPTER";
|
|
65
|
+
//# sourceMappingURL=adapter.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.config.d.ts","sourceRoot":"","sources":["../../../src/event-bus/config/adapter.config.ts"],"names":[],"mappings":"AAKA,MAAM,MAAM,mBAAmB,GAAG,UAAU,GAAG,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC;AAK1E,MAAM,WAAW,iBAAiB;IAEhC,IAAI,EAAE,mBAAmB,CAAC;IAE1B,WAAW,EAAE,MAAM,CAAC;IAEpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAKD,MAAM,WAAW,qBAAsB,SAAQ,iBAAiB;IAC9D,IAAI,EAAE,UAAU,CAAC;IAEjB,GAAG,EAAE,MAAM,CAAC;IAEZ,QAAQ,EAAE,MAAM,CAAC;IAEjB,KAAK,EAAE,MAAM,CAAC;IAEd,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,iBAAiB,CAAC,EAAE;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC;CACH;AAKD,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,IAAI,EAAE,OAAO,CAAC;IAEd,OAAO,EAAE,MAAM,EAAE,CAAC;IAElB,QAAQ,EAAE,MAAM,CAAC;IAEjB,OAAO,EAAE,MAAM,CAAC;IAEhB,cAAc,CAAC,EAAE;QACf,cAAc,CAAC,EAAE,MAAM,CAAC;QACxB,gBAAgB,CAAC,EAAE,MAAM,CAAC;QAC1B,iBAAiB,CAAC,EAAE,MAAM,CAAC;KAC5B,CAAC;IAEF,cAAc,CAAC,EAAE;QACf,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC,CAAC;QAClB,OAAO,CAAC,EAAE,MAAM,CAAC;QACjB,WAAW,CAAC,EAAE,MAAM,GAAG,MAAM,GAAG,QAAQ,GAAG,KAAK,GAAG,MAAM,CAAC;KAC3D,CAAC;CACH;AAKD,MAAM,WAAW,iBAAkB,SAAQ,iBAAiB;IAC1D,IAAI,EAAE,MAAM,CAAC;IAEb,GAAG,EAAE,MAAM,CAAC;IAEZ,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,SAAS,CAAC,EAAE;QACV,OAAO,EAAE,OAAO,CAAC;QAEjB,MAAM,CAAC,EAAE,MAAM,CAAC;QAEhB,YAAY,CAAC,EAAE;YACb,SAAS,CAAC,EAAE,QAAQ,GAAG,UAAU,GAAG,WAAW,CAAC;YAChD,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,QAAQ,CAAC,EAAE,MAAM,CAAC;SACnB,CAAC;KACH,CAAC;IAEF,iBAAiB,CAAC,EAAE;QAClB,oBAAoB,CAAC,EAAE,MAAM,CAAC;QAC9B,iBAAiB,CAAC,EAAE,MAAM,CAAC;QAC3B,OAAO,CAAC,EAAE,MAAM,CAAC;KAClB,CAAC;CACH;AAKD,MAAM,WAAW,kBAAmB,SAAQ,iBAAiB;IAC3D,IAAI,EAAE,OAAO,CAAC;IAEd,GAAG,EAAE,MAAM,CAAC;IAEZ,YAAY,CAAC,EAAE;QACb,EAAE,CAAC,EAAE,MAAM,CAAC;QACZ,QAAQ,CAAC,EAAE,MAAM,CAAC;QAClB,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,CAAC;CACH;AAKD,MAAM,MAAM,qBAAqB,GAC7B,qBAAqB,GACrB,kBAAkB,GAClB,iBAAiB,GACjB,kBAAkB,CAAC;AAKvB,eAAO,MAAM,wBAAwB,6BAA6B,CAAC;AAKnE,eAAO,MAAM,iBAAiB,sBAAsB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.EVENT_BUS_ADAPTER = exports.EVENT_BUS_ADAPTER_CONFIG = void 0;
|
|
4
|
+
exports.EVENT_BUS_ADAPTER_CONFIG = 'EVENT_BUS_ADAPTER_CONFIG';
|
|
5
|
+
exports.EVENT_BUS_ADAPTER = 'EVENT_BUS_ADAPTER';
|
|
6
|
+
//# sourceMappingURL=adapter.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"adapter.config.js","sourceRoot":"","sources":["../../../src/event-bus/config/adapter.config.ts"],"names":[],"mappings":";;;AAwHa,QAAA,wBAAwB,GAAG,0BAA0B,CAAC;AAKtD,QAAA,iBAAiB,GAAG,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/event-bus/config/index.ts"],"names":[],"mappings":"AAEA,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./adapter.config"), exports);
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/event-bus/config/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAEA,mDAAiC"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
export type BrokerType = 'rabbitmq' | 'kafka';
|
|
2
|
+
export interface RabbitMQConfig {
|
|
3
|
+
url?: string;
|
|
4
|
+
exchange?: string;
|
|
5
|
+
exchangeType?: string;
|
|
6
|
+
prefetch?: number;
|
|
7
|
+
}
|
|
8
|
+
export interface KafkaConfig {
|
|
9
|
+
brokers?: string[];
|
|
10
|
+
clientId?: string;
|
|
11
|
+
groupId?: string;
|
|
12
|
+
kafkaConfig?: Record<string, any>;
|
|
13
|
+
producerConfig?: Record<string, any>;
|
|
14
|
+
consumerConfig?: Record<string, any>;
|
|
15
|
+
}
|
|
16
|
+
export interface EventBusConnectionConfig {
|
|
17
|
+
type?: BrokerType;
|
|
18
|
+
serviceName?: string;
|
|
19
|
+
rabbitmq?: RabbitMQConfig;
|
|
20
|
+
kafka?: KafkaConfig;
|
|
21
|
+
url?: string;
|
|
22
|
+
exchange?: string;
|
|
23
|
+
queue?: string;
|
|
24
|
+
prefetch?: number;
|
|
25
|
+
}
|
|
26
|
+
export interface EventBusCircuitBreakerConfig {
|
|
27
|
+
maxFailures?: number;
|
|
28
|
+
resetTimeoutMs?: number;
|
|
29
|
+
}
|
|
30
|
+
export interface EventBusConfig {
|
|
31
|
+
connection?: EventBusConnectionConfig;
|
|
32
|
+
circuitBreaker?: EventBusCircuitBreakerConfig;
|
|
33
|
+
}
|
|
34
|
+
export declare const EVENT_BUS_CONFIG = "EVENT_BUS_CONFIG";
|
|
35
|
+
export declare const defaultEventBusConfig: EventBusConfig;
|
|
36
|
+
//# sourceMappingURL=event-bus.config.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-bus.config.d.ts","sourceRoot":"","sources":["../../src/event-bus/event-bus.config.ts"],"names":[],"mappings":"AAKA,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,OAAO,CAAC;AAK9C,MAAM,WAAW,cAAc;IAE7B,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,YAAY,CAAC,EAAE,MAAM,CAAC;IAEtB,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAKD,MAAM,WAAW,WAAW;IAE1B,OAAO,CAAC,EAAE,MAAM,EAAE,CAAC;IAEnB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,WAAW,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAElC,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;IAErC,cAAc,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;CACtC;AAED,MAAM,WAAW,wBAAwB;IAEvC,IAAI,CAAC,EAAE,UAAU,CAAC;IAElB,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,QAAQ,CAAC,EAAE,cAAc,CAAC;IAE1B,KAAK,CAAC,EAAE,WAAW,CAAC;IAEpB,GAAG,CAAC,EAAE,MAAM,CAAC;IAEb,QAAQ,CAAC,EAAE,MAAM,CAAC;IAElB,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAED,MAAM,WAAW,4BAA4B;IAE3C,WAAW,CAAC,EAAE,MAAM,CAAC;IAErB,cAAc,CAAC,EAAE,MAAM,CAAC;CACzB;AAED,MAAM,WAAW,cAAc;IAE7B,UAAU,CAAC,EAAE,wBAAwB,CAAC;IAGtC,cAAc,CAAC,EAAE,4BAA4B,CAAC;CAC/C;AAWD,eAAO,MAAM,gBAAgB,qBAAqB,CAAC;AAKnD,eAAO,MAAM,qBAAqB,EAAE,cAWnC,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.defaultEventBusConfig = exports.EVENT_BUS_CONFIG = void 0;
|
|
4
|
+
exports.EVENT_BUS_CONFIG = 'EVENT_BUS_CONFIG';
|
|
5
|
+
exports.defaultEventBusConfig = {
|
|
6
|
+
connection: {
|
|
7
|
+
url: 'amqp://localhost',
|
|
8
|
+
exchange: 'anatix-event-bus',
|
|
9
|
+
queue: 'default-queue',
|
|
10
|
+
prefetch: 1,
|
|
11
|
+
},
|
|
12
|
+
circuitBreaker: {
|
|
13
|
+
maxFailures: 5,
|
|
14
|
+
resetTimeoutMs: 60_000,
|
|
15
|
+
},
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=event-bus.config.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event-bus.config.js","sourceRoot":"","sources":["../../src/event-bus/event-bus.config.ts"],"names":[],"mappings":";;;AAkFa,QAAA,gBAAgB,GAAG,kBAAkB,CAAC;AAKtC,QAAA,qBAAqB,GAAmB;IACnD,UAAU,EAAE;QACV,GAAG,EAAE,kBAAkB;QACvB,QAAQ,EAAE,kBAAkB;QAC5B,KAAK,EAAE,eAAe;QACtB,QAAQ,EAAE,CAAC;KACZ;IACD,cAAc,EAAE;QACd,WAAW,EAAE,CAAC;QACd,cAAc,EAAE,MAAM;KACvB;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/event-bus/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/event-bus/index.ts"],"names":[],"mappings":"AAGA,cAAc,SAAS,CAAC;AAGxB,cAAc,YAAY,CAAC;AAG3B,cAAc,WAAW,CAAC;AAG1B,cAAc,oBAAoB,CAAC"}
|
package/dist/event-bus/index.js
CHANGED
|
@@ -17,4 +17,5 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
17
17
|
__exportStar(require("./types"), exports);
|
|
18
18
|
__exportStar(require("./services"), exports);
|
|
19
19
|
__exportStar(require("./modules"), exports);
|
|
20
|
+
__exportStar(require("./event-bus.config"), exports);
|
|
20
21
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/event-bus/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/event-bus/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAGA,0CAAwB;AAGxB,6CAA2B;AAG3B,4CAA0B;AAG1B,qDAAmC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-bus.module.d.ts","sourceRoot":"","sources":["../../../src/event-bus/modules/event-bus.module.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"event-bus.module.d.ts","sourceRoot":"","sources":["../../../src/event-bus/modules/event-bus.module.ts"],"names":[],"mappings":"AAwBA,qBAUa,cAAc;CAAG"}
|
|
@@ -9,13 +9,20 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
9
9
|
exports.EventBusModule = void 0;
|
|
10
10
|
const common_1 = require("@nestjs/common");
|
|
11
11
|
const services_1 = require("../services");
|
|
12
|
+
const event_bus_config_1 = require("../event-bus.config");
|
|
12
13
|
let EventBusModule = class EventBusModule {
|
|
13
14
|
};
|
|
14
15
|
exports.EventBusModule = EventBusModule;
|
|
15
16
|
exports.EventBusModule = EventBusModule = __decorate([
|
|
16
17
|
(0, common_1.Module)({
|
|
17
|
-
providers: [
|
|
18
|
-
|
|
18
|
+
providers: [
|
|
19
|
+
services_1.EventBusService,
|
|
20
|
+
{
|
|
21
|
+
provide: event_bus_config_1.EVENT_BUS_CONFIG,
|
|
22
|
+
useValue: event_bus_config_1.defaultEventBusConfig,
|
|
23
|
+
},
|
|
24
|
+
],
|
|
25
|
+
exports: [services_1.EventBusService, event_bus_config_1.EVENT_BUS_CONFIG],
|
|
19
26
|
})
|
|
20
27
|
], EventBusModule);
|
|
21
28
|
//# sourceMappingURL=event-bus.module.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-bus.module.js","sourceRoot":"","sources":["../../../src/event-bus/modules/event-bus.module.ts"],"names":[],"mappings":";;;;;;;;;
|
|
1
|
+
{"version":3,"file":"event-bus.module.js","sourceRoot":"","sources":["../../../src/event-bus/modules/event-bus.module.ts"],"names":[],"mappings":";;;;;;;;;AACA,2CAAwC;AACxC,0CAA8C;AAC9C,0DAG6B;AA4BtB,IAAM,cAAc,GAApB,MAAM,cAAc;CAAG,CAAA;AAAjB,wCAAc;yBAAd,cAAc;IAV1B,IAAA,eAAM,EAAC;QACN,SAAS,EAAE;YACT,0BAAe;YACf;gBACE,OAAO,EAAE,mCAAgB;gBACzB,QAAQ,EAAE,wCAAqB;aAChC;SACF;QACD,OAAO,EAAE,CAAC,0BAAe,EAAE,mCAAgB,CAAC;KAC7C,CAAC;GACW,cAAc,CAAG"}
|
|
@@ -1,17 +1,20 @@
|
|
|
1
1
|
import { OnModuleDestroy, OnModuleInit } from '@nestjs/common';
|
|
2
2
|
import { DataSource } from 'typeorm';
|
|
3
|
-
import {
|
|
3
|
+
import type { EventMeta, Envelope } from '../../envelope';
|
|
4
4
|
import { LogLevel } from '../../logger';
|
|
5
5
|
import type { EnvelopeHandler, TxHandler, TxAfterHook, ReplyTransformer } from '../types';
|
|
6
|
+
import { type EventBusConfig } from '../event-bus.config';
|
|
6
7
|
export declare class EventBusService implements OnModuleInit, OnModuleDestroy {
|
|
7
8
|
private readonly logger;
|
|
8
|
-
private
|
|
9
|
-
private channel?;
|
|
9
|
+
private adapter?;
|
|
10
10
|
private subscriptions;
|
|
11
|
-
private
|
|
11
|
+
private readonly cfg;
|
|
12
|
+
constructor(cfg: EventBusConfig);
|
|
12
13
|
onModuleInit(): Promise<void>;
|
|
13
14
|
onModuleDestroy(): Promise<void>;
|
|
14
15
|
private assertReady;
|
|
16
|
+
isReady(): boolean;
|
|
17
|
+
getCircuitBreakerState(): 'OPEN' | 'HALF_OPEN' | 'CLOSED';
|
|
15
18
|
publish<T>(topic: string, data: T, meta?: Partial<EventMeta>): Promise<void>;
|
|
16
19
|
request<T, R>(topic: string, data: T, meta?: Partial<EventMeta>, timeoutMs?: number): Promise<Envelope<R>>;
|
|
17
20
|
respond<R>(to: string, correlationId: string, data: R, meta?: Partial<EventMeta>): Promise<void>;
|
|
@@ -20,6 +23,8 @@ export declare class EventBusService implements OnModuleInit, OnModuleDestroy {
|
|
|
20
23
|
emitLog(service: string, message: string, metadata: Record<string, any> | undefined, level: LogLevel, userId?: string, tag?: string, stack?: string): Promise<void>;
|
|
21
24
|
emitLogError(service: string, message: string, metadata?: Record<string, any>, userId?: string, stack?: string): Promise<void>;
|
|
22
25
|
private setup;
|
|
23
|
-
private
|
|
26
|
+
private createAdapter;
|
|
27
|
+
private buildConnectionConfig;
|
|
28
|
+
private handleBrokerMessage;
|
|
24
29
|
}
|
|
25
30
|
//# sourceMappingURL=event-bus.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"event-bus.service.d.ts","sourceRoot":"","sources":["../../../src/event-bus/services/event-bus.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"event-bus.service.d.ts","sourceRoot":"","sources":["../../../src/event-bus/services/event-bus.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAGL,eAAe,EACf,YAAY,EAEb,MAAM,gBAAgB,CAAC;AACxB,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAErC,OAAO,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,QAAQ,EAAqB,MAAM,cAAc,CAAC;AAO3D,OAAO,KAAK,EAEV,eAAe,EACf,SAAS,EACT,WAAW,EACX,gBAAgB,EACjB,MAAM,UAAU,CAAC;AAClB,OAAO,EAEL,KAAK,cAAc,EAEpB,MAAM,qBAAqB,CAAC;AAc7B,qBACa,eAAgB,YAAW,YAAY,EAAE,eAAe;IACnE,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoC;IAE3D,OAAO,CAAC,OAAO,CAAC,CAAuB;IACvC,OAAO,CAAC,aAAa,CAAwC;IAG7D,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAiB;gBAInC,GAAG,EAAE,cAAc;IAKf,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IAO7B,eAAe,IAAI,OAAO,CAAC,IAAI,CAAC;IAWtC,OAAO,CAAC,WAAW;IAWnB,OAAO,IAAI,OAAO;IAUlB,sBAAsB,IAAI,MAAM,GAAG,WAAW,GAAG,QAAQ;IAcnD,OAAO,CAAC,CAAC,EACb,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,CAAC,EACP,IAAI,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,GACxB,OAAO,CAAC,IAAI,CAAC;IAUV,OAAO,CAAC,CAAC,EAAE,CAAC,EAChB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,CAAC,EACP,IAAI,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,EACzB,SAAS,SAAO,GACf,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC;IAejB,OAAO,CAAC,CAAC,EACb,EAAE,EAAE,MAAM,EACV,aAAa,EAAE,MAAM,EACrB,IAAI,EAAE,CAAC,EACP,IAAI,CAAC,EAAE,OAAO,CAAC,SAAS,CAAC,GACxB,OAAO,CAAC,IAAI,CAAC;IAcV,EAAE,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,IAAI,CAAC;IAmBhE,eAAe,CAAC,CAAC,EAAE,CAAC,GAAG,IAAI,EAC/B,UAAU,EAAE,UAAU,EACtB,KAAK,EAAE,MAAM,EACb,IAAI,EAAE,SAAS,CAAC,CAAC,EAAE,CAAC,CAAC,EACrB,KAAK,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,EACtB,OAAO,CAAC,EAAE,gBAAgB,CAAC,CAAC,CAAC,GAC5B,OAAO,CAAC,IAAI,CAAC;IAkCV,OAAO,CACX,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,YAAK,EAClC,KAAK,EAAE,QAAQ,EACf,MAAM,SAAW,EACjB,GAAG,CAAC,EAAE,MAAM,EACZ,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC;IAcV,YAAY,CAChB,OAAO,EAAE,MAAM,EACf,OAAO,EAAE,MAAM,EACf,QAAQ,GAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAM,EAClC,MAAM,SAAW,EACjB,KAAK,CAAC,EAAE,MAAM,GACb,OAAO,CAAC,IAAI,CAAC;YAmBF,KAAK;IAwBnB,OAAO,CAAC,aAAa;IAcrB,OAAO,CAAC,qBAAqB;YAqCf,mBAAmB;CA0DlC"}
|