@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
|
@@ -1,15 +1,19 @@
|
|
|
1
|
-
import { OnModuleInit } from '@nestjs/common';
|
|
1
|
+
import { OnModuleInit, OnApplicationShutdown } from '@nestjs/common';
|
|
2
2
|
import { DataSource } from 'typeorm';
|
|
3
|
-
|
|
3
|
+
import { type EnvelopeConfig } from '../envelope.config';
|
|
4
|
+
export declare class OutboxDispatcherService implements OnModuleInit, OnApplicationShutdown {
|
|
4
5
|
private readonly dataSource;
|
|
5
6
|
private readonly publishFn;
|
|
7
|
+
private readonly cfg;
|
|
6
8
|
private readonly logger;
|
|
7
9
|
private intervalId?;
|
|
8
|
-
constructor(dataSource: DataSource, publishFn: (topic: string, payload: any, meta: any) => Promise<void
|
|
10
|
+
constructor(dataSource: DataSource, publishFn: (topic: string, payload: any, meta: any) => Promise<void>, cfg: EnvelopeConfig);
|
|
9
11
|
onModuleInit(): Promise<void>;
|
|
12
|
+
onApplicationShutdown(signal?: string): Promise<void>;
|
|
10
13
|
stop(): void;
|
|
11
|
-
private updateLastAttemptAt;
|
|
12
14
|
private publishMessage;
|
|
13
15
|
private dispatch;
|
|
16
|
+
private tryLockAndProcess;
|
|
17
|
+
private tryLockWithSkipLocked;
|
|
14
18
|
}
|
|
15
19
|
//# sourceMappingURL=outbox-dispatcher.service.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox-dispatcher.service.d.ts","sourceRoot":"","sources":["../../../src/envelope/services/outbox-dispatcher.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,YAAY,EAAE,MAAM,gBAAgB,CAAC;
|
|
1
|
+
{"version":3,"file":"outbox-dispatcher.service.d.ts","sourceRoot":"","sources":["../../../src/envelope/services/outbox-dispatcher.service.ts"],"names":[],"mappings":"AAEA,OAAO,EAAsB,YAAY,EAAE,qBAAqB,EAAU,MAAM,gBAAgB,CAAC;AACjG,OAAO,EAAE,UAAU,EAAE,MAAM,SAAS,CAAC;AAGrC,OAAO,EAAmB,KAAK,cAAc,EAAE,MAAM,oBAAoB,CAAC;AAY1E,qBACa,uBAAwB,YAAW,YAAY,EAAE,qBAAqB;IAK/E,OAAO,CAAC,QAAQ,CAAC,UAAU;IAK3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAE1B,OAAO,CAAC,QAAQ,CAAC,GAAG;IAXtB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAA4C;IACnE,OAAO,CAAC,UAAU,CAAC,CAAiB;gBAGjB,UAAU,EAAE,UAAU,EAKtB,SAAS,EAAE,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,KAAK,OAAO,CAAC,IAAI,CAAC,EAEpE,GAAG,EAAE,cAAc;IAOhC,YAAY,IAAI,OAAO,CAAC,IAAI,CAAC;IA0B7B,qBAAqB,CAAC,MAAM,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ3D,IAAI,IAAI,IAAI;YAQE,cAAc;YAcd,QAAQ;YAgBR,iBAAiB;YAiDjB,qBAAqB;CA6CpC"}
|
|
@@ -8,6 +8,9 @@ var __decorate = (this && this.__decorate) || function (decorators, target, key,
|
|
|
8
8
|
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
9
|
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
10
|
};
|
|
11
|
+
var __param = (this && this.__param) || function (paramIndex, decorator) {
|
|
12
|
+
return function (target, key) { decorator(target, key, paramIndex); }
|
|
13
|
+
};
|
|
11
14
|
var OutboxDispatcherService_1;
|
|
12
15
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
16
|
exports.OutboxDispatcherService = void 0;
|
|
@@ -15,18 +18,27 @@ const common_1 = require("@nestjs/common");
|
|
|
15
18
|
const typeorm_1 = require("typeorm");
|
|
16
19
|
const repositories_1 = require("../repositories");
|
|
17
20
|
const schemas_1 = require("../schemas");
|
|
21
|
+
const envelope_config_1 = require("../envelope.config");
|
|
18
22
|
let OutboxDispatcherService = OutboxDispatcherService_1 = class OutboxDispatcherService {
|
|
19
23
|
dataSource;
|
|
20
24
|
publishFn;
|
|
25
|
+
cfg;
|
|
21
26
|
logger = new common_1.Logger(OutboxDispatcherService_1.name);
|
|
22
27
|
intervalId;
|
|
23
|
-
constructor(dataSource, publishFn) {
|
|
28
|
+
constructor(dataSource, publishFn, cfg) {
|
|
24
29
|
this.dataSource = dataSource;
|
|
25
30
|
this.publishFn = publishFn;
|
|
31
|
+
this.cfg = cfg;
|
|
26
32
|
}
|
|
27
33
|
async onModuleInit() {
|
|
28
|
-
const
|
|
29
|
-
const
|
|
34
|
+
const outboxCfg = this.cfg?.outbox ?? {};
|
|
35
|
+
const enabled = outboxCfg.enabled ?? true;
|
|
36
|
+
if (!enabled) {
|
|
37
|
+
this.logger.log('Outbox dispatcher disabled by config');
|
|
38
|
+
return;
|
|
39
|
+
}
|
|
40
|
+
const intervalMs = outboxCfg.intervalMs ?? 5000;
|
|
41
|
+
const maxAttempts = outboxCfg.maxAttempts ?? 5;
|
|
30
42
|
this.intervalId = setInterval(() => {
|
|
31
43
|
this.dispatch(maxAttempts).catch((err) => {
|
|
32
44
|
this.logger.error(`Outbox dispatch error: ${err?.message || err}`);
|
|
@@ -34,6 +46,10 @@ let OutboxDispatcherService = OutboxDispatcherService_1 = class OutboxDispatcher
|
|
|
34
46
|
}, intervalMs);
|
|
35
47
|
this.logger.log(`Outbox dispatcher started (interval: ${intervalMs}ms, maxAttempts: ${maxAttempts})`);
|
|
36
48
|
}
|
|
49
|
+
async onApplicationShutdown(signal) {
|
|
50
|
+
this.logger.log(`Shutting down Outbox dispatcher (signal: ${signal})`);
|
|
51
|
+
this.stop();
|
|
52
|
+
}
|
|
37
53
|
stop() {
|
|
38
54
|
if (this.intervalId) {
|
|
39
55
|
clearInterval(this.intervalId);
|
|
@@ -41,12 +57,6 @@ let OutboxDispatcherService = OutboxDispatcherService_1 = class OutboxDispatcher
|
|
|
41
57
|
this.logger.log('Outbox dispatcher stopped');
|
|
42
58
|
}
|
|
43
59
|
}
|
|
44
|
-
async updateLastAttemptAt(messageId) {
|
|
45
|
-
const repo = this.dataSource.getRepository(schemas_1.OutboxSchema);
|
|
46
|
-
await repo.update(messageId, {
|
|
47
|
-
lastAttemptAt: new Date()
|
|
48
|
-
});
|
|
49
|
-
}
|
|
50
60
|
async publishMessage(message) {
|
|
51
61
|
try {
|
|
52
62
|
const payload = JSON.parse(message.payload);
|
|
@@ -60,27 +70,77 @@ let OutboxDispatcherService = OutboxDispatcherService_1 = class OutboxDispatcher
|
|
|
60
70
|
}
|
|
61
71
|
async dispatch(maxAttempts) {
|
|
62
72
|
const messages = await repositories_1.OutboxRepo.getPending(this.dataSource, maxAttempts);
|
|
63
|
-
if (messages.length === 0) {
|
|
64
|
-
return;
|
|
65
|
-
}
|
|
66
|
-
this.logger.debug(`Dispatching ${messages.length} outbox messages`);
|
|
67
73
|
for (const message of messages) {
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
74
|
+
await this.tryLockAndProcess(message);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
async tryLockAndProcess(message) {
|
|
78
|
+
const queryRunner = this.dataSource.createQueryRunner();
|
|
79
|
+
await queryRunner.connect();
|
|
80
|
+
await queryRunner.startTransaction();
|
|
81
|
+
try {
|
|
82
|
+
const locked = await this.tryLockWithSkipLocked(queryRunner, message.id);
|
|
83
|
+
if (!locked) {
|
|
84
|
+
await queryRunner.rollbackTransaction();
|
|
85
|
+
await queryRunner.release();
|
|
86
|
+
return;
|
|
73
87
|
}
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
88
|
+
await queryRunner.manager
|
|
89
|
+
.getRepository(schemas_1.OutboxSchema)
|
|
90
|
+
.update(message.id, { lastAttemptAt: new Date() });
|
|
91
|
+
await this.publishMessage(message);
|
|
92
|
+
await queryRunner.manager.getRepository(schemas_1.OutboxSchema).update(message.id, {
|
|
93
|
+
status: 'published',
|
|
94
|
+
publishedAt: new Date(),
|
|
95
|
+
});
|
|
96
|
+
await queryRunner.commitTransaction();
|
|
97
|
+
this.logger.debug(`Published message ${message.id}`);
|
|
98
|
+
}
|
|
99
|
+
catch (error) {
|
|
100
|
+
await queryRunner.rollbackTransaction();
|
|
101
|
+
await repositories_1.OutboxRepo.markFailed(this.dataSource, message.id, error?.message || String(error));
|
|
102
|
+
this.logger.error(`Failed to publish ${message.id}: ${error?.message || error}`);
|
|
103
|
+
}
|
|
104
|
+
finally {
|
|
105
|
+
await queryRunner.release();
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
async tryLockWithSkipLocked(queryRunner, messageId) {
|
|
109
|
+
try {
|
|
110
|
+
const dbType = this.dataSource.options.type;
|
|
111
|
+
if (dbType === 'postgres' || dbType === 'mysql' || dbType === 'mariadb') {
|
|
112
|
+
const result = await queryRunner.manager
|
|
113
|
+
.createQueryBuilder()
|
|
114
|
+
.select()
|
|
115
|
+
.from(schemas_1.OutboxSchema, 'outbox')
|
|
116
|
+
.where('id = :id', { id: messageId })
|
|
117
|
+
.andWhere('status = :status', { status: 'pending' })
|
|
118
|
+
.setLock('pessimistic_write', undefined, ['skip_locked'])
|
|
119
|
+
.getRawOne();
|
|
120
|
+
return !!result;
|
|
121
|
+
}
|
|
122
|
+
else {
|
|
123
|
+
const result = await queryRunner.manager
|
|
124
|
+
.createQueryBuilder()
|
|
125
|
+
.update(schemas_1.OutboxSchema)
|
|
126
|
+
.set({ lastAttemptAt: new Date() })
|
|
127
|
+
.where('id = :id', { id: messageId })
|
|
128
|
+
.andWhere('status = :status', { status: 'pending' })
|
|
129
|
+
.andWhere('(lastAttemptAt IS NULL OR lastAttemptAt < :threshold)', { threshold: new Date(Date.now() - 5000) })
|
|
130
|
+
.execute();
|
|
131
|
+
return (result.affected ?? 0) > 0;
|
|
77
132
|
}
|
|
78
133
|
}
|
|
134
|
+
catch (error) {
|
|
135
|
+
this.logger.error(`Error locking message ${messageId}: ${error?.message || error}`);
|
|
136
|
+
return false;
|
|
137
|
+
}
|
|
79
138
|
}
|
|
80
139
|
};
|
|
81
140
|
exports.OutboxDispatcherService = OutboxDispatcherService;
|
|
82
141
|
exports.OutboxDispatcherService = OutboxDispatcherService = OutboxDispatcherService_1 = __decorate([
|
|
83
142
|
(0, common_1.Injectable)(),
|
|
84
|
-
|
|
143
|
+
__param(2, (0, common_1.Inject)(envelope_config_1.ENVELOPE_CONFIG)),
|
|
144
|
+
__metadata("design:paramtypes", [typeorm_1.DataSource, Function, Object])
|
|
85
145
|
], OutboxDispatcherService);
|
|
86
146
|
//# sourceMappingURL=outbox-dispatcher.service.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox-dispatcher.service.js","sourceRoot":"","sources":["../../../src/envelope/services/outbox-dispatcher.service.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"outbox-dispatcher.service.js","sourceRoot":"","sources":["../../../src/envelope/services/outbox-dispatcher.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import type { DataSource, EntityManager } from "typeorm";
|
|
2
|
+
import type { TxManager } from "../service/transaction";
|
|
3
|
+
export interface WithManager<R> {
|
|
4
|
+
withManager(manager: EntityManager): R;
|
|
5
|
+
}
|
|
6
|
+
export declare class TypeormTxManager<R extends WithManager<R>> implements TxManager<R> {
|
|
7
|
+
private readonly dataSource;
|
|
8
|
+
private readonly repo;
|
|
9
|
+
constructor(dataSource: DataSource, repo: R);
|
|
10
|
+
transaction<T>(fn: (trxRepo: R) => Promise<T>, opts?: {
|
|
11
|
+
isolation?: string;
|
|
12
|
+
}): Promise<T>;
|
|
13
|
+
}
|
|
14
|
+
//# sourceMappingURL=tx-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tx-manager.d.ts","sourceRoot":"","sources":["../../src/envelope/tx-manager.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,aAAa,EAAE,MAAM,SAAS,CAAC;AACzD,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,wBAAwB,CAAC;AASxD,MAAM,WAAW,WAAW,CAAC,CAAC;IAC5B,WAAW,CAAC,OAAO,EAAE,aAAa,GAAG,CAAC,CAAC;CACxC;AAaD,qBAAa,gBAAgB,CAAC,CAAC,SAAS,WAAW,CAAC,CAAC,CAAC,CACpD,YAAW,SAAS,CAAC,CAAC,CAAC;IAGrB,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,IAAI;gBADJ,UAAU,EAAE,UAAU,EACtB,IAAI,EAAE,CAAC;IAGpB,WAAW,CAAC,CAAC,EACjB,EAAE,EAAE,CAAC,OAAO,EAAE,CAAC,KAAK,OAAO,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,EAAE;QAAE,SAAS,CAAC,EAAE,MAAM,CAAA;KAAE,GAC5B,OAAO,CAAC,CAAC,CAAC;CAYd"}
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.TypeormTxManager = void 0;
|
|
4
|
+
class TypeormTxManager {
|
|
5
|
+
dataSource;
|
|
6
|
+
repo;
|
|
7
|
+
constructor(dataSource, repo) {
|
|
8
|
+
this.dataSource = dataSource;
|
|
9
|
+
this.repo = repo;
|
|
10
|
+
}
|
|
11
|
+
async transaction(fn, opts) {
|
|
12
|
+
const iso = opts?.isolation;
|
|
13
|
+
return this.dataSource.transaction(iso ? { isolation: iso } : undefined, async (manager) => {
|
|
14
|
+
const trxRepo = this.repo.withManager(manager);
|
|
15
|
+
return fn(trxRepo);
|
|
16
|
+
});
|
|
17
|
+
}
|
|
18
|
+
}
|
|
19
|
+
exports.TypeormTxManager = TypeormTxManager;
|
|
20
|
+
//# sourceMappingURL=tx-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"tx-manager.js","sourceRoot":"","sources":["../../src/envelope/tx-manager.ts"],"names":[],"mappings":";;;AA2BA,MAAa,gBAAgB;IAIR;IACA;IAFnB,YACmB,UAAsB,EACtB,IAAO;QADP,eAAU,GAAV,UAAU,CAAY;QACtB,SAAI,GAAJ,IAAI,CAAG;IACvB,CAAC;IAEJ,KAAK,CAAC,WAAW,CACf,EAA8B,EAC9B,IAA6B;QAE7B,MAAM,GAAG,GAAG,IAAI,EAAE,SAAS,CAAC;QAE5B,OAAO,IAAI,CAAC,UAAU,CAAC,WAAW,CAEhC,GAAG,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,GAAU,EAAE,CAAC,CAAC,CAAC,SAAS,EAC3C,KAAK,EAAE,OAAO,EAAE,EAAE;YAChB,MAAM,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YAC/C,OAAO,EAAE,CAAC,OAAO,CAAC,CAAC;QACrB,CAAC,CACF,CAAC;IACJ,CAAC;CACF;AAvBD,4CAuBC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/event-bus/adapters/index.ts"],"names":[],"mappings":"AAOA,cAAc,4BAA4B,CAAC;AAG3C,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC"}
|
|
@@ -0,0 +1,20 @@
|
|
|
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("./message-broker.interface"), exports);
|
|
18
|
+
__exportStar(require("./rabbitmq.adapter"), exports);
|
|
19
|
+
__exportStar(require("./kafka.adapter"), exports);
|
|
20
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/event-bus/adapters/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAOA,6DAA2C;AAG3C,qDAAmC;AACnC,kDAAgC"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import type { MessageBrokerAdapter, BrokerConnectionConfig, MessageHandler, PublishOptions } from './message-broker.interface';
|
|
2
|
+
import type { EventMeta } from '../../envelope';
|
|
3
|
+
export declare class KafkaAdapter implements MessageBrokerAdapter {
|
|
4
|
+
private readonly logger;
|
|
5
|
+
private kafka?;
|
|
6
|
+
private producer?;
|
|
7
|
+
private consumer?;
|
|
8
|
+
private admin?;
|
|
9
|
+
private serviceName;
|
|
10
|
+
private handlers;
|
|
11
|
+
private rpcHandlers;
|
|
12
|
+
private connected;
|
|
13
|
+
connect(config: BrokerConnectionConfig): Promise<void>;
|
|
14
|
+
disconnect(): Promise<void>;
|
|
15
|
+
publish(topic: string, payload: any, meta?: EventMeta, options?: PublishOptions): Promise<void>;
|
|
16
|
+
request<T = any>(topic: string, payload: any, meta?: EventMeta, timeoutMs?: number): Promise<T>;
|
|
17
|
+
reply(replyTo: string, correlationId: string, payload: any, meta?: EventMeta): Promise<void>;
|
|
18
|
+
subscribe(topic: string, handler: MessageHandler): Promise<void>;
|
|
19
|
+
unsubscribe(topic: string): Promise<void>;
|
|
20
|
+
isConnected(): boolean;
|
|
21
|
+
createTopic(name: string, options?: {
|
|
22
|
+
numPartitions?: number;
|
|
23
|
+
replicationFactor?: number;
|
|
24
|
+
}): Promise<void>;
|
|
25
|
+
private handleMessage;
|
|
26
|
+
private encodeHeaders;
|
|
27
|
+
}
|
|
28
|
+
//# sourceMappingURL=kafka.adapter.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kafka.adapter.d.ts","sourceRoot":"","sources":["../../../src/event-bus/adapters/kafka.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;AA6BhD,qBAAa,YAAa,YAAW,oBAAoB;IACvD,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAiC;IAExD,OAAO,CAAC,KAAK,CAAC,CAAQ;IACtB,OAAO,CAAC,QAAQ,CAAC,CAAW;IAC5B,OAAO,CAAC,QAAQ,CAAC,CAAW;IAC5B,OAAO,CAAC,KAAK,CAAC,CAAQ;IACtB,OAAO,CAAC,WAAW,CAAqB;IACxC,OAAO,CAAC,QAAQ,CAAuC;IACvD,OAAO,CAAC,WAAW,CAA8C;IACjE,OAAO,CAAC,SAAS,CAAS;IAKpB,OAAO,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,IAAI,CAAC;IA4DtD,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IA2B3B,OAAO,CACX,KAAK,EAAE,MAAM,EACb,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,EAChB,OAAO,CAAC,EAAE,cAAc,GACvB,OAAO,CAAC,IAAI,CAAC;IAmCV,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;IAgEP,KAAK,CACT,OAAO,EAAE,MAAM,EACf,aAAa,EAAE,MAAM,EACrB,OAAO,EAAE,GAAG,EACZ,IAAI,CAAC,EAAE,SAAS,GACf,OAAO,CAAC,IAAI,CAAC;IA0BV,SAAS,CAAC,KAAK,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBhE,WAAW,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAU/C,WAAW,IAAI,OAAO;IAOhB,WAAW,CAAC,IAAI,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE;QAAE,aAAa,CAAC,EAAE,MAAM,CAAC;QAAC,iBAAiB,CAAC,EAAE,MAAM,CAAA;KAAE,GAAG,OAAO,CAAC,IAAI,CAAC;YA2BlG,aAAa;IAkE3B,OAAO,CAAC,aAAa;CAStB"}
|
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.KafkaAdapter = void 0;
|
|
4
|
+
const common_1 = require("@nestjs/common");
|
|
5
|
+
const kafkajs_1 = require("kafkajs");
|
|
6
|
+
const envelope_1 = require("../../envelope");
|
|
7
|
+
class KafkaAdapter {
|
|
8
|
+
logger = new common_1.Logger(KafkaAdapter.name);
|
|
9
|
+
kafka;
|
|
10
|
+
producer;
|
|
11
|
+
consumer;
|
|
12
|
+
admin;
|
|
13
|
+
serviceName = 'default-service';
|
|
14
|
+
handlers = new Map();
|
|
15
|
+
rpcHandlers = new Map();
|
|
16
|
+
connected = false;
|
|
17
|
+
async connect(config) {
|
|
18
|
+
const brokers = Array.isArray(config.url)
|
|
19
|
+
? config.url
|
|
20
|
+
: [config.url || 'localhost:9092'];
|
|
21
|
+
const clientId = config.options?.clientId ?? config.serviceName ?? 'anatix-client';
|
|
22
|
+
const groupId = config.options?.groupId ?? config.serviceName ?? 'anatix-group';
|
|
23
|
+
this.serviceName = config.serviceName ?? 'default-service';
|
|
24
|
+
try {
|
|
25
|
+
this.kafka = new kafkajs_1.Kafka({
|
|
26
|
+
clientId,
|
|
27
|
+
brokers,
|
|
28
|
+
logLevel: kafkajs_1.logLevel.ERROR,
|
|
29
|
+
...config.options?.kafkaConfig,
|
|
30
|
+
});
|
|
31
|
+
const producerConfig = {
|
|
32
|
+
allowAutoTopicCreation: config.options?.producerConfig?.allowAutoTopicCreation ?? true,
|
|
33
|
+
idempotent: config.options?.producerConfig?.idempotent ?? false,
|
|
34
|
+
transactionTimeout: config.options?.producerConfig?.transactionTimeout ?? 60000,
|
|
35
|
+
maxInFlightRequests: config.options?.producerConfig?.maxInFlightRequests,
|
|
36
|
+
retry: config.options?.producerConfig?.retry,
|
|
37
|
+
};
|
|
38
|
+
this.producer = this.kafka.producer(producerConfig);
|
|
39
|
+
await this.producer.connect();
|
|
40
|
+
this.consumer = this.kafka.consumer({
|
|
41
|
+
groupId,
|
|
42
|
+
...config.options?.consumerConfig,
|
|
43
|
+
});
|
|
44
|
+
await this.consumer.connect();
|
|
45
|
+
this.admin = this.kafka.admin();
|
|
46
|
+
await this.admin.connect();
|
|
47
|
+
await this.consumer.run({
|
|
48
|
+
eachMessage: async (payload) => this.handleMessage(payload),
|
|
49
|
+
});
|
|
50
|
+
this.connected = true;
|
|
51
|
+
this.logger.log(`Connected to Kafka: ${brokers.join(', ')} (clientId: ${clientId}, groupId: ${groupId})`);
|
|
52
|
+
}
|
|
53
|
+
catch (error) {
|
|
54
|
+
this.logger.error(`Failed to connect to Kafka: ${error?.message || error}`);
|
|
55
|
+
throw error;
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
async disconnect() {
|
|
59
|
+
try {
|
|
60
|
+
if (this.producer) {
|
|
61
|
+
await this.producer.disconnect();
|
|
62
|
+
this.producer = undefined;
|
|
63
|
+
}
|
|
64
|
+
if (this.consumer) {
|
|
65
|
+
await this.consumer.disconnect();
|
|
66
|
+
this.consumer = undefined;
|
|
67
|
+
}
|
|
68
|
+
if (this.admin) {
|
|
69
|
+
await this.admin.disconnect();
|
|
70
|
+
this.admin = undefined;
|
|
71
|
+
}
|
|
72
|
+
this.connected = false;
|
|
73
|
+
this.logger.log('Disconnected from Kafka');
|
|
74
|
+
}
|
|
75
|
+
catch (error) {
|
|
76
|
+
this.logger.error(`Error disconnecting from Kafka: ${error?.message || error}`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async publish(topic, payload, meta, options) {
|
|
80
|
+
if (!this.producer) {
|
|
81
|
+
throw new Error('Kafka adapter not connected');
|
|
82
|
+
}
|
|
83
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
84
|
+
const message = {
|
|
85
|
+
__event: topic,
|
|
86
|
+
data: payload,
|
|
87
|
+
meta: eventMeta,
|
|
88
|
+
};
|
|
89
|
+
const value = JSON.stringify(message);
|
|
90
|
+
await this.producer.send({
|
|
91
|
+
topic,
|
|
92
|
+
messages: [
|
|
93
|
+
{
|
|
94
|
+
key: options?.key,
|
|
95
|
+
value,
|
|
96
|
+
partition: options?.partition,
|
|
97
|
+
headers: options?.headers
|
|
98
|
+
? this.encodeHeaders(options.headers)
|
|
99
|
+
: undefined,
|
|
100
|
+
},
|
|
101
|
+
],
|
|
102
|
+
});
|
|
103
|
+
}
|
|
104
|
+
async request(topic, payload, meta, timeoutMs = 5000) {
|
|
105
|
+
if (!this.producer || !this.consumer) {
|
|
106
|
+
throw new Error('Kafka adapter not connected');
|
|
107
|
+
}
|
|
108
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
109
|
+
const replyTopic = `${this.serviceName}-replies`;
|
|
110
|
+
const correlationId = eventMeta.correlationId;
|
|
111
|
+
if (!this.handlers.has(replyTopic)) {
|
|
112
|
+
await this.subscribe(replyTopic, async (msg) => {
|
|
113
|
+
const handler = this.rpcHandlers.get(msg.meta?.correlationId || '');
|
|
114
|
+
if (handler) {
|
|
115
|
+
handler(msg.payload);
|
|
116
|
+
this.rpcHandlers.delete(msg.meta?.correlationId || '');
|
|
117
|
+
}
|
|
118
|
+
await msg.ack();
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
const responsePromise = new Promise((resolve, reject) => {
|
|
122
|
+
this.rpcHandlers.set(correlationId, (response) => {
|
|
123
|
+
clearTimeout(timer);
|
|
124
|
+
resolve(response);
|
|
125
|
+
});
|
|
126
|
+
const timer = setTimeout(() => {
|
|
127
|
+
this.rpcHandlers.delete(correlationId);
|
|
128
|
+
reject(new Error(`RPC timeout for topic "${topic}" (correlationId: ${correlationId})`));
|
|
129
|
+
}, timeoutMs);
|
|
130
|
+
});
|
|
131
|
+
const message = {
|
|
132
|
+
__event: topic,
|
|
133
|
+
__replyTo: replyTopic,
|
|
134
|
+
__correlationId: correlationId,
|
|
135
|
+
data: payload,
|
|
136
|
+
meta: eventMeta,
|
|
137
|
+
};
|
|
138
|
+
await this.producer.send({
|
|
139
|
+
topic,
|
|
140
|
+
messages: [
|
|
141
|
+
{
|
|
142
|
+
value: JSON.stringify(message),
|
|
143
|
+
},
|
|
144
|
+
],
|
|
145
|
+
});
|
|
146
|
+
return responsePromise;
|
|
147
|
+
}
|
|
148
|
+
async reply(replyTo, correlationId, payload, meta) {
|
|
149
|
+
if (!this.producer) {
|
|
150
|
+
throw new Error('Kafka adapter not connected');
|
|
151
|
+
}
|
|
152
|
+
const eventMeta = (0, envelope_1.ensureMeta)(meta);
|
|
153
|
+
const message = {
|
|
154
|
+
__correlationId: correlationId,
|
|
155
|
+
data: payload,
|
|
156
|
+
meta: eventMeta,
|
|
157
|
+
};
|
|
158
|
+
await this.producer.send({
|
|
159
|
+
topic: replyTo,
|
|
160
|
+
messages: [
|
|
161
|
+
{
|
|
162
|
+
value: JSON.stringify(message),
|
|
163
|
+
},
|
|
164
|
+
],
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
async subscribe(topic, handler) {
|
|
168
|
+
if (!this.consumer) {
|
|
169
|
+
throw new Error('Kafka adapter not connected');
|
|
170
|
+
}
|
|
171
|
+
if (!this.handlers.has(topic)) {
|
|
172
|
+
this.handlers.set(topic, []);
|
|
173
|
+
await this.consumer.subscribe({ topic, fromBeginning: false });
|
|
174
|
+
this.logger.log(`Subscribed to topic: ${topic}`);
|
|
175
|
+
}
|
|
176
|
+
this.handlers.get(topic).push(handler);
|
|
177
|
+
}
|
|
178
|
+
async unsubscribe(topic) {
|
|
179
|
+
if (this.handlers.has(topic)) {
|
|
180
|
+
this.handlers.delete(topic);
|
|
181
|
+
this.logger.log(`Unsubscribed from topic: ${topic}`);
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
isConnected() {
|
|
185
|
+
return this.connected;
|
|
186
|
+
}
|
|
187
|
+
async createTopic(name, options) {
|
|
188
|
+
if (!this.admin) {
|
|
189
|
+
throw new Error('Kafka adapter not connected');
|
|
190
|
+
}
|
|
191
|
+
try {
|
|
192
|
+
await this.admin.createTopics({
|
|
193
|
+
topics: [
|
|
194
|
+
{
|
|
195
|
+
topic: name,
|
|
196
|
+
numPartitions: options?.numPartitions ?? 1,
|
|
197
|
+
replicationFactor: options?.replicationFactor ?? 1,
|
|
198
|
+
},
|
|
199
|
+
],
|
|
200
|
+
});
|
|
201
|
+
this.logger.log(`Topic created: ${name}`);
|
|
202
|
+
}
|
|
203
|
+
catch (error) {
|
|
204
|
+
if (error.type !== 'TOPIC_ALREADY_EXISTS') {
|
|
205
|
+
throw error;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
async handleMessage(payload) {
|
|
210
|
+
const { topic, message: kafkaMessage } = payload;
|
|
211
|
+
if (!kafkaMessage.value) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
let content;
|
|
215
|
+
try {
|
|
216
|
+
content = JSON.parse(kafkaMessage.value.toString());
|
|
217
|
+
}
|
|
218
|
+
catch {
|
|
219
|
+
this.logger.error('Invalid JSON message; skipping');
|
|
220
|
+
return;
|
|
221
|
+
}
|
|
222
|
+
const eventTopic = content.__event || topic;
|
|
223
|
+
const handlers = this.handlers.get(topic) ?? [];
|
|
224
|
+
if (handlers.length === 0) {
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
const meta = (0, envelope_1.ensureMeta)(content?.meta);
|
|
228
|
+
const brokerMessage = {
|
|
229
|
+
topic: eventTopic,
|
|
230
|
+
payload: content?.data ?? content,
|
|
231
|
+
meta,
|
|
232
|
+
replyTo: content.__replyTo && content.__correlationId
|
|
233
|
+
? {
|
|
234
|
+
destination: String(content.__replyTo),
|
|
235
|
+
correlationId: String(content.__correlationId),
|
|
236
|
+
}
|
|
237
|
+
: undefined,
|
|
238
|
+
ack: async () => {
|
|
239
|
+
},
|
|
240
|
+
nack: async (_requeue = false) => {
|
|
241
|
+
this.logger.error(`Message processing failed for topic: ${topic}`);
|
|
242
|
+
},
|
|
243
|
+
};
|
|
244
|
+
try {
|
|
245
|
+
for (const handler of handlers) {
|
|
246
|
+
await handler(brokerMessage);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
catch (error) {
|
|
250
|
+
this.logger.error(`Handler failed for topic="${topic}" (corr=${meta.correlationId}): ${error?.message || error}`);
|
|
251
|
+
throw error;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
encodeHeaders(headers) {
|
|
255
|
+
const encoded = {};
|
|
256
|
+
for (const [key, value] of Object.entries(headers)) {
|
|
257
|
+
encoded[key] = Buffer.from(String(value));
|
|
258
|
+
}
|
|
259
|
+
return encoded;
|
|
260
|
+
}
|
|
261
|
+
}
|
|
262
|
+
exports.KafkaAdapter = KafkaAdapter;
|
|
263
|
+
//# sourceMappingURL=kafka.adapter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"kafka.adapter.js","sourceRoot":"","sources":["../../../src/event-bus/adapters/kafka.adapter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
import type { EventMeta } from '../../envelope';
|
|
2
|
+
export interface BrokerConnectionConfig {
|
|
3
|
+
url?: string | string[];
|
|
4
|
+
serviceName?: string;
|
|
5
|
+
prefetch?: number;
|
|
6
|
+
options?: Record<string, any>;
|
|
7
|
+
}
|
|
8
|
+
export interface BrokerMessage {
|
|
9
|
+
topic: string;
|
|
10
|
+
payload: any;
|
|
11
|
+
meta?: EventMeta;
|
|
12
|
+
replyTo?: {
|
|
13
|
+
destination: string;
|
|
14
|
+
correlationId: string;
|
|
15
|
+
};
|
|
16
|
+
ack: () => Promise<void>;
|
|
17
|
+
nack: (requeue?: boolean) => Promise<void>;
|
|
18
|
+
}
|
|
19
|
+
export type MessageHandler = (message: BrokerMessage) => Promise<void>;
|
|
20
|
+
export interface MessageBrokerAdapter {
|
|
21
|
+
connect(config: BrokerConnectionConfig): Promise<void>;
|
|
22
|
+
disconnect(): Promise<void>;
|
|
23
|
+
publish(topic: string, payload: any, meta?: EventMeta, options?: PublishOptions): Promise<void>;
|
|
24
|
+
request<T = any>(topic: string, payload: any, meta?: EventMeta, timeoutMs?: number): Promise<T>;
|
|
25
|
+
reply(replyTo: string, correlationId: string, payload: any, meta?: EventMeta): Promise<void>;
|
|
26
|
+
subscribe(topic: string, handler: MessageHandler): Promise<void>;
|
|
27
|
+
unsubscribe(topic: string): Promise<void>;
|
|
28
|
+
isConnected(): boolean;
|
|
29
|
+
createExchange?(name: string, type?: string): Promise<void>;
|
|
30
|
+
}
|
|
31
|
+
export interface PublishOptions {
|
|
32
|
+
persistent?: boolean;
|
|
33
|
+
headers?: Record<string, any>;
|
|
34
|
+
delay?: number;
|
|
35
|
+
ttl?: number;
|
|
36
|
+
partition?: number;
|
|
37
|
+
key?: string;
|
|
38
|
+
}
|
|
39
|
+
//# sourceMappingURL=message-broker.interface.d.ts.map
|