@prodforcode/event-forge-core 1.1.0 → 1.2.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/dist/config/inbox.config.d.ts +0 -3
- package/dist/config/inbox.config.d.ts.map +1 -1
- package/dist/config/inbox.config.js +0 -3
- package/dist/config/inbox.config.js.map +1 -1
- package/dist/config/outbox.config.d.ts +1 -0
- package/dist/config/outbox.config.d.ts.map +1 -1
- package/dist/config/outbox.config.js +2 -1
- package/dist/config/outbox.config.js.map +1 -1
- package/dist/interfaces/inbox-repository.interface.d.ts +0 -1
- package/dist/interfaces/inbox-repository.interface.d.ts.map +1 -1
- package/dist/interfaces/outbox-repository.interface.d.ts +1 -0
- package/dist/interfaces/outbox-repository.interface.d.ts.map +1 -1
- package/dist/services/inbox.service.d.ts +1 -8
- package/dist/services/inbox.service.d.ts.map +1 -1
- package/dist/services/inbox.service.js +0 -43
- package/dist/services/inbox.service.js.map +1 -1
- package/dist/services/outbox.service.d.ts +8 -1
- package/dist/services/outbox.service.d.ts.map +1 -1
- package/dist/services/outbox.service.js +59 -13
- package/dist/services/outbox.service.js.map +1 -1
- package/package.json +1 -1
|
@@ -3,11 +3,8 @@ export interface InboxConfig {
|
|
|
3
3
|
retentionDays?: number;
|
|
4
4
|
enableRetry?: boolean;
|
|
5
5
|
maxRetries?: number;
|
|
6
|
-
retryPollingInterval?: number;
|
|
7
6
|
backoffBaseSeconds?: number;
|
|
8
7
|
maxBackoffSeconds?: number;
|
|
9
|
-
retryBatchSize?: number;
|
|
10
|
-
retryWorkerId?: string;
|
|
11
8
|
}
|
|
12
9
|
export declare const DEFAULT_INBOX_CONFIG: Required<InboxConfig>;
|
|
13
10
|
//# sourceMappingURL=inbox.config.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox.config.d.ts","sourceRoot":"","sources":["../../src/config/inbox.config.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,WAAW;IAE1B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,aAAa,CAAC,EAAE,MAAM,CAAC;IAGvB,WAAW,CAAC,EAAE,OAAO,CAAC;IAGtB,UAAU,CAAC,EAAE,MAAM,CAAC;IAGpB,
|
|
1
|
+
{"version":3,"file":"inbox.config.d.ts","sourceRoot":"","sources":["../../src/config/inbox.config.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,WAAW;IAE1B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,aAAa,CAAC,EAAE,MAAM,CAAC;IAGvB,WAAW,CAAC,EAAE,OAAO,CAAC;IAGtB,UAAU,CAAC,EAAE,MAAM,CAAC;IAGpB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,iBAAiB,CAAC,EAAE,MAAM,CAAC;CAC5B;AAKD,eAAO,MAAM,oBAAoB,EAAE,QAAQ,CAAC,WAAW,CAOtD,CAAC"}
|
|
@@ -6,10 +6,7 @@ exports.DEFAULT_INBOX_CONFIG = {
|
|
|
6
6
|
retentionDays: 7,
|
|
7
7
|
enableRetry: false,
|
|
8
8
|
maxRetries: 3,
|
|
9
|
-
retryPollingInterval: 5000,
|
|
10
9
|
backoffBaseSeconds: 5,
|
|
11
10
|
maxBackoffSeconds: 3600,
|
|
12
|
-
retryBatchSize: 10,
|
|
13
|
-
retryWorkerId: `${process.env.HOSTNAME || 'unknown'}-${process.pid}`,
|
|
14
11
|
};
|
|
15
12
|
//# sourceMappingURL=inbox.config.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox.config.js","sourceRoot":"","sources":["../../src/config/inbox.config.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"inbox.config.js","sourceRoot":"","sources":["../../src/config/inbox.config.ts"],"names":[],"mappings":";;;AA0Ba,QAAA,oBAAoB,GAA0B;IACzD,eAAe,EAAE,QAAQ;IACzB,aAAa,EAAE,CAAC;IAChB,WAAW,EAAE,KAAK;IAClB,UAAU,EAAE,CAAC;IACb,kBAAkB,EAAE,CAAC;IACrB,iBAAiB,EAAE,IAAI;CACxB,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox.config.d.ts","sourceRoot":"","sources":["../../src/config/outbox.config.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,YAAY;IAE3B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,SAAS,CAAC,EAAE,MAAM,CAAC;IAGnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAGpB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAG3B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,aAAa,CAAC,EAAE,MAAM,CAAC;IAGvB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAG9B,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAKD,eAAO,MAAM,qBAAqB,EAAE,QAAQ,CAAC,YAAY,
|
|
1
|
+
{"version":3,"file":"outbox.config.d.ts","sourceRoot":"","sources":["../../src/config/outbox.config.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,YAAY;IAE3B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAG3B,SAAS,CAAC,EAAE,MAAM,CAAC;IAGnB,UAAU,CAAC,EAAE,MAAM,CAAC;IAGpB,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAG3B,eAAe,CAAC,EAAE,MAAM,CAAC;IAGzB,aAAa,CAAC,EAAE,MAAM,CAAC;IAGvB,mBAAmB,CAAC,EAAE,OAAO,CAAC;IAG9B,QAAQ,CAAC,EAAE,MAAM,CAAC;CACnB;AAKD,eAAO,MAAM,qBAAqB,EAAE,QAAQ,CAAC,YAAY,CAYxD,CAAC"}
|
|
@@ -2,7 +2,8 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.DEFAULT_OUTBOX_CONFIG = void 0;
|
|
4
4
|
exports.DEFAULT_OUTBOX_CONFIG = {
|
|
5
|
-
pollingInterval:
|
|
5
|
+
pollingInterval: 300000,
|
|
6
|
+
safetyNetInterval: 300000,
|
|
6
7
|
batchSize: 10,
|
|
7
8
|
maxRetries: 3,
|
|
8
9
|
lockTimeoutSeconds: 300,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox.config.js","sourceRoot":"","sources":["../../src/config/outbox.config.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"outbox.config.js","sourceRoot":"","sources":["../../src/config/outbox.config.ts"],"names":[],"mappings":";;;AAyCa,QAAA,qBAAqB,GAA2B;IAC3D,eAAe,EAAE,MAAM;IACvB,iBAAiB,EAAE,MAAM;IACzB,SAAS,EAAE,EAAE;IACb,UAAU,EAAE,CAAC;IACb,kBAAkB,EAAE,GAAG;IACvB,kBAAkB,EAAE,CAAC;IACrB,iBAAiB,EAAE,IAAI;IACvB,eAAe,EAAE,QAAQ;IACzB,aAAa,EAAE,CAAC;IAChB,mBAAmB,EAAE,IAAI;IACzB,QAAQ,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,SAAS,IAAI,OAAO,CAAC,GAAG,EAAE;CAChE,CAAC"}
|
|
@@ -10,7 +10,6 @@ export interface IInboxRepository {
|
|
|
10
10
|
markProcessing(id: string): Promise<void>;
|
|
11
11
|
markProcessed(id: string): Promise<void>;
|
|
12
12
|
markFailed(id: string, error: string, permanent?: boolean, scheduledAt?: Date): Promise<void>;
|
|
13
|
-
findRetryable(limit: number): Promise<InboxMessage[]>;
|
|
14
13
|
deleteOlderThan(date: Date): Promise<number>;
|
|
15
14
|
}
|
|
16
15
|
//# sourceMappingURL=inbox-repository.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox-repository.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/inbox-repository.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAKzD,MAAM,WAAW,wBAAwB;IAEvC,OAAO,EAAE,YAAY,CAAC;IAGtB,WAAW,EAAE,OAAO,CAAC;CACtB;AAMD,MAAM,WAAW,gBAAgB;IAM/B,MAAM,CAAC,GAAG,EAAE,qBAAqB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC;IAQtE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAM5D,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAM1C,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IASzC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAO9F,
|
|
1
|
+
{"version":3,"file":"inbox-repository.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/inbox-repository.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAKzD,MAAM,WAAW,wBAAwB;IAEvC,OAAO,EAAE,YAAY,CAAC;IAGtB,WAAW,EAAE,OAAO,CAAC;CACtB;AAMD,MAAM,WAAW,gBAAgB;IAM/B,MAAM,CAAC,GAAG,EAAE,qBAAqB,GAAG,OAAO,CAAC,wBAAwB,CAAC,CAAC;IAQtE,MAAM,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAM5D,cAAc,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAM1C,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IASzC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAO9F,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC9C"}
|
|
@@ -8,6 +8,7 @@ export interface IOutboxRepository {
|
|
|
8
8
|
releaseLock(id: string): Promise<void>;
|
|
9
9
|
releaseStaleLocks(olderThan: Date): Promise<number>;
|
|
10
10
|
deleteOlderThan(date: Date): Promise<number>;
|
|
11
|
+
findAndLockById(id: string, lockerId: string): Promise<OutboxMessage | null>;
|
|
11
12
|
withTransaction<T>(operation: (context: unknown) => Promise<T>): Promise<T>;
|
|
12
13
|
}
|
|
13
14
|
//# sourceMappingURL=outbox-repository.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox-repository.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/outbox-repository.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAM3D,MAAM,WAAW,iBAAiB;IAOhC,MAAM,CAAC,GAAG,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IAS1F,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IAM/E,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IASzC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAM9F,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAOvC,iBAAiB,CAAC,SAAS,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAOpD,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"outbox-repository.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/outbox-repository.interface.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,sBAAsB,EAAE,MAAM,6BAA6B,CAAC;AACrE,OAAO,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAM3D,MAAM,WAAW,iBAAiB;IAOhC,MAAM,CAAC,GAAG,EAAE,sBAAsB,EAAE,kBAAkB,CAAC,EAAE,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC,CAAC;IAS1F,mBAAmB,CAAC,KAAK,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IAM/E,aAAa,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IASzC,UAAU,CAAC,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,OAAO,EAAE,WAAW,CAAC,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAM9F,WAAW,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAOvC,iBAAiB,CAAC,SAAS,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAOpD,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAS7C,eAAe,CAAC,EAAE,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC,CAAC;IAO7E,eAAe,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CAC7E"}
|
|
@@ -8,17 +8,13 @@ export declare enum InboxEvents {
|
|
|
8
8
|
MESSAGE_RECEIVED = "inbox:message:received",
|
|
9
9
|
MESSAGE_DUPLICATE = "inbox:message:duplicate",
|
|
10
10
|
MESSAGE_PROCESSED = "inbox:message:processed",
|
|
11
|
-
MESSAGE_FAILED = "inbox:message:failed"
|
|
12
|
-
RETRY_POLLING_STARTED = "inbox:retry:polling:started",
|
|
13
|
-
RETRY_POLLING_STOPPED = "inbox:retry:polling:stopped"
|
|
11
|
+
MESSAGE_FAILED = "inbox:message:failed"
|
|
14
12
|
}
|
|
15
13
|
export declare class InboxService extends EventEmitter {
|
|
16
14
|
private readonly repository;
|
|
17
15
|
private readonly config;
|
|
18
16
|
private readonly handlers;
|
|
19
17
|
private cleanupTimer?;
|
|
20
|
-
private retryPollingTimer?;
|
|
21
|
-
private isProcessingRetries;
|
|
22
18
|
constructor(repository: IInboxRepository, config?: InboxConfig);
|
|
23
19
|
registerHandler(eventType: string, handler: MessageHandler): void;
|
|
24
20
|
unregisterHandler(eventType: string, handler: MessageHandler): void;
|
|
@@ -26,9 +22,6 @@ export declare class InboxService extends EventEmitter {
|
|
|
26
22
|
processMessage(message: InboxMessage): Promise<void>;
|
|
27
23
|
private handleProcessingError;
|
|
28
24
|
private calculateBackoff;
|
|
29
|
-
startRetryPolling(): void;
|
|
30
|
-
stopRetryPolling(): void;
|
|
31
|
-
private pollAndRetry;
|
|
32
25
|
startCleanup(): void;
|
|
33
26
|
stopCleanup(): void;
|
|
34
27
|
private cleanup;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox.service.d.ts","sourceRoot":"","sources":["../../src/services/inbox.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAwB,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAG3E,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0CAA0C,CAAC;AAK5E,MAAM,MAAM,cAAc,GAAG,CAC3B,OAAO,EAAE,YAAY,KAClB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;AAK1B,oBAAY,WAAW;IACrB,gBAAgB,2BAA2B;IAC3C,iBAAiB,4BAA4B;IAC7C,iBAAiB,4BAA4B;IAC7C,cAAc,yBAAyB;
|
|
1
|
+
{"version":3,"file":"inbox.service.d.ts","sourceRoot":"","sources":["../../src/services/inbox.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAwB,WAAW,EAAE,MAAM,wBAAwB,CAAC;AAG3E,OAAO,EAAE,qBAAqB,EAAE,MAAM,wCAAwC,CAAC;AAC/E,OAAO,EAAE,YAAY,EAAE,MAAM,uCAAuC,CAAC;AACrE,OAAO,EAAE,gBAAgB,EAAE,MAAM,0CAA0C,CAAC;AAK5E,MAAM,MAAM,cAAc,GAAG,CAC3B,OAAO,EAAE,YAAY,KAClB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;AAK1B,oBAAY,WAAW;IACrB,gBAAgB,2BAA2B;IAC3C,iBAAiB,4BAA4B;IAC7C,iBAAiB,4BAA4B;IAC7C,cAAc,yBAAyB;CACxC;AAOD,qBAAa,YAAa,SAAQ,YAAY;IAM1C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAL7B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwB;IAC/C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAuC;IAChE,OAAO,CAAC,YAAY,CAAC,CAAiB;gBAGnB,UAAU,EAAE,gBAAgB,EAC7C,MAAM,CAAC,EAAE,WAAW;IAStB,eAAe,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IASjE,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IAqB7D,cAAc,CAAC,GAAG,EAAE,qBAAqB,GAAG,OAAO,CAAC,IAAI,CAAC;IAkBzD,cAAc,CAAC,OAAO,EAAE,YAAY,GAAG,OAAO,CAAC,IAAI,CAAC;YAuC5C,qBAAqB;IAmCnC,OAAO,CAAC,gBAAgB;IAqBxB,YAAY,IAAI,IAAI;IAgBpB,WAAW,IAAI,IAAI;YAUL,OAAO;CAYtB"}
|
|
@@ -11,16 +11,12 @@ var InboxEvents;
|
|
|
11
11
|
InboxEvents["MESSAGE_DUPLICATE"] = "inbox:message:duplicate";
|
|
12
12
|
InboxEvents["MESSAGE_PROCESSED"] = "inbox:message:processed";
|
|
13
13
|
InboxEvents["MESSAGE_FAILED"] = "inbox:message:failed";
|
|
14
|
-
InboxEvents["RETRY_POLLING_STARTED"] = "inbox:retry:polling:started";
|
|
15
|
-
InboxEvents["RETRY_POLLING_STOPPED"] = "inbox:retry:polling:stopped";
|
|
16
14
|
})(InboxEvents || (exports.InboxEvents = InboxEvents = {}));
|
|
17
15
|
class InboxService extends events_1.EventEmitter {
|
|
18
16
|
repository;
|
|
19
17
|
config;
|
|
20
18
|
handlers = new Map();
|
|
21
19
|
cleanupTimer;
|
|
22
|
-
retryPollingTimer;
|
|
23
|
-
isProcessingRetries = false;
|
|
24
20
|
constructor(repository, config) {
|
|
25
21
|
super();
|
|
26
22
|
this.repository = repository;
|
|
@@ -103,45 +99,6 @@ class InboxService extends events_1.EventEmitter {
|
|
|
103
99
|
const finalDelay = cappedDelay + jitter;
|
|
104
100
|
return Math.max(0, finalDelay * 1000);
|
|
105
101
|
}
|
|
106
|
-
startRetryPolling() {
|
|
107
|
-
if (!this.config.enableRetry) {
|
|
108
|
-
return;
|
|
109
|
-
}
|
|
110
|
-
if (this.retryPollingTimer) {
|
|
111
|
-
return;
|
|
112
|
-
}
|
|
113
|
-
this.emit(InboxEvents.RETRY_POLLING_STARTED);
|
|
114
|
-
this.retryPollingTimer = setInterval(() => {
|
|
115
|
-
void this.pollAndRetry();
|
|
116
|
-
}, this.config.retryPollingInterval);
|
|
117
|
-
void this.pollAndRetry();
|
|
118
|
-
}
|
|
119
|
-
stopRetryPolling() {
|
|
120
|
-
if (this.retryPollingTimer) {
|
|
121
|
-
clearInterval(this.retryPollingTimer);
|
|
122
|
-
this.retryPollingTimer = undefined;
|
|
123
|
-
this.emit(InboxEvents.RETRY_POLLING_STOPPED);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
async pollAndRetry() {
|
|
127
|
-
if (this.isProcessingRetries) {
|
|
128
|
-
return;
|
|
129
|
-
}
|
|
130
|
-
this.isProcessingRetries = true;
|
|
131
|
-
try {
|
|
132
|
-
const messages = await this.repository.findRetryable(this.config.retryBatchSize);
|
|
133
|
-
if (!messages || messages.length === 0) {
|
|
134
|
-
return;
|
|
135
|
-
}
|
|
136
|
-
await Promise.allSettled(messages.map((message) => this.processMessage(message)));
|
|
137
|
-
}
|
|
138
|
-
catch (error) {
|
|
139
|
-
this.emit('error', error);
|
|
140
|
-
}
|
|
141
|
-
finally {
|
|
142
|
-
this.isProcessingRetries = false;
|
|
143
|
-
}
|
|
144
|
-
}
|
|
145
102
|
startCleanup() {
|
|
146
103
|
if (this.cleanupTimer) {
|
|
147
104
|
return;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox.service.js","sourceRoot":"","sources":["../../src/services/inbox.service.ts"],"names":[],"mappings":";;;AAAA,mCAAsC;AAEtC,yDAA2E;AAC3E,+EAA0E;AAC1E,iEAA6D;AAe7D,IAAY,
|
|
1
|
+
{"version":3,"file":"inbox.service.js","sourceRoot":"","sources":["../../src/services/inbox.service.ts"],"names":[],"mappings":"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"}
|
|
@@ -8,6 +8,8 @@ export declare enum OutboxEvents {
|
|
|
8
8
|
MESSAGE_CREATED = "outbox:message:created",
|
|
9
9
|
MESSAGE_PUBLISHED = "outbox:message:published",
|
|
10
10
|
MESSAGE_FAILED = "outbox:message:failed",
|
|
11
|
+
PROCESSOR_STARTED = "outbox:processor:started",
|
|
12
|
+
PROCESSOR_STOPPED = "outbox:processor:stopped",
|
|
11
13
|
POLLING_STARTED = "outbox:polling:started",
|
|
12
14
|
POLLING_STOPPED = "outbox:polling:stopped"
|
|
13
15
|
}
|
|
@@ -15,14 +17,19 @@ export declare class OutboxService extends EventEmitter {
|
|
|
15
17
|
private readonly repository;
|
|
16
18
|
private readonly publisher;
|
|
17
19
|
private readonly config;
|
|
18
|
-
private
|
|
20
|
+
private safetyNetTimer?;
|
|
19
21
|
private cleanupTimer?;
|
|
20
22
|
private isProcessing;
|
|
23
|
+
private retryTimers;
|
|
24
|
+
private messageCreatedHandler?;
|
|
21
25
|
constructor(repository: IOutboxRepository, publisher: IMessagePublisher, config?: OutboxConfig);
|
|
22
26
|
createMessage(dto: CreateOutboxMessageDto, transactionContext?: unknown): Promise<OutboxMessage>;
|
|
23
27
|
withTransaction<T>(operation: (context: unknown) => Promise<T>): Promise<T>;
|
|
28
|
+
startProcessor(): void;
|
|
29
|
+
stopProcessor(): void;
|
|
24
30
|
startPolling(): void;
|
|
25
31
|
stopPolling(): void;
|
|
32
|
+
processMessageById(id: string): Promise<void>;
|
|
26
33
|
processMessage(_messageId: string): Promise<void>;
|
|
27
34
|
private pollAndProcess;
|
|
28
35
|
private publishMessage;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox.service.d.ts","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAyB,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAE9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAK9E,oBAAY,YAAY;IACtB,eAAe,2BAA2B;IAC1C,iBAAiB,6BAA6B;IAC9C,cAAc,0BAA0B;IACxC,eAAe,2BAA2B;
|
|
1
|
+
{"version":3,"file":"outbox.service.d.ts","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,QAAQ,CAAC;AAEtC,OAAO,EAAyB,YAAY,EAAE,MAAM,yBAAyB,CAAC;AAE9E,OAAO,EAAE,sBAAsB,EAAE,MAAM,yCAAyC,CAAC;AACjF,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAC9E,OAAO,EAAE,aAAa,EAAE,MAAM,wCAAwC,CAAC;AACvE,OAAO,EAAE,iBAAiB,EAAE,MAAM,2CAA2C,CAAC;AAK9E,oBAAY,YAAY;IACtB,eAAe,2BAA2B;IAC1C,iBAAiB,6BAA6B;IAC9C,cAAc,0BAA0B;IACxC,iBAAiB,6BAA6B;IAC9C,iBAAiB,6BAA6B;IAE9C,eAAe,2BAA2B;IAE1C,eAAe,2BAA2B;CAC3C;AAMD,qBAAa,aAAc,SAAQ,YAAY;IAS3C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAT5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyB;IAChD,OAAO,CAAC,cAAc,CAAC,CAAiB;IACxC,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,YAAY,CAAS;IAC7B,OAAO,CAAC,WAAW,CAAqC;IACxD,OAAO,CAAC,qBAAqB,CAAC,CAAuB;gBAGlC,UAAU,EAAE,iBAAiB,EAC7B,SAAS,EAAE,iBAAiB,EAC7C,MAAM,CAAC,EAAE,YAAY;IAcjB,aAAa,CACjB,GAAG,EAAE,sBAAsB,EAC3B,kBAAkB,CAAC,EAAE,OAAO,GAC3B,OAAO,CAAC,aAAa,CAAC;IAoBnB,eAAe,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC;IASjF,cAAc,IAAI,IAAI;IAyBtB,aAAa,IAAI,IAAI;IA8BrB,YAAY,IAAI,IAAI;IAOpB,WAAW,IAAI,IAAI;IAOb,kBAAkB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAc7C,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAOzC,cAAc;YAoCd,cAAc;YAiBd,kBAAkB;IAkChC,OAAO,CAAC,gBAAgB;IAqBxB,OAAO,CAAC,YAAY;YAYN,OAAO;CAatB"}
|
|
@@ -9,6 +9,8 @@ var OutboxEvents;
|
|
|
9
9
|
OutboxEvents["MESSAGE_CREATED"] = "outbox:message:created";
|
|
10
10
|
OutboxEvents["MESSAGE_PUBLISHED"] = "outbox:message:published";
|
|
11
11
|
OutboxEvents["MESSAGE_FAILED"] = "outbox:message:failed";
|
|
12
|
+
OutboxEvents["PROCESSOR_STARTED"] = "outbox:processor:started";
|
|
13
|
+
OutboxEvents["PROCESSOR_STOPPED"] = "outbox:processor:stopped";
|
|
12
14
|
OutboxEvents["POLLING_STARTED"] = "outbox:polling:started";
|
|
13
15
|
OutboxEvents["POLLING_STOPPED"] = "outbox:polling:stopped";
|
|
14
16
|
})(OutboxEvents || (exports.OutboxEvents = OutboxEvents = {}));
|
|
@@ -16,14 +18,20 @@ class OutboxService extends events_1.EventEmitter {
|
|
|
16
18
|
repository;
|
|
17
19
|
publisher;
|
|
18
20
|
config;
|
|
19
|
-
|
|
21
|
+
safetyNetTimer;
|
|
20
22
|
cleanupTimer;
|
|
21
23
|
isProcessing = false;
|
|
24
|
+
retryTimers = new Map();
|
|
25
|
+
messageCreatedHandler;
|
|
22
26
|
constructor(repository, publisher, config) {
|
|
23
27
|
super();
|
|
24
28
|
this.repository = repository;
|
|
25
29
|
this.publisher = publisher;
|
|
26
|
-
this.config = {
|
|
30
|
+
this.config = {
|
|
31
|
+
...outbox_config_1.DEFAULT_OUTBOX_CONFIG,
|
|
32
|
+
...config,
|
|
33
|
+
safetyNetInterval: config?.safetyNetInterval ?? config?.pollingInterval ?? outbox_config_1.DEFAULT_OUTBOX_CONFIG.safetyNetInterval,
|
|
34
|
+
};
|
|
27
35
|
}
|
|
28
36
|
async createMessage(dto, transactionContext) {
|
|
29
37
|
const message = await this.repository.create({
|
|
@@ -38,27 +46,57 @@ class OutboxService extends events_1.EventEmitter {
|
|
|
38
46
|
async withTransaction(operation) {
|
|
39
47
|
return this.repository.withTransaction(operation);
|
|
40
48
|
}
|
|
41
|
-
|
|
42
|
-
if (this.
|
|
49
|
+
startProcessor() {
|
|
50
|
+
if (this.safetyNetTimer) {
|
|
43
51
|
return;
|
|
44
52
|
}
|
|
45
|
-
this.
|
|
46
|
-
|
|
53
|
+
this.messageCreatedHandler = (id) => {
|
|
54
|
+
void this.processMessageById(id);
|
|
55
|
+
};
|
|
56
|
+
this.on(OutboxEvents.MESSAGE_CREATED, this.messageCreatedHandler);
|
|
57
|
+
this.safetyNetTimer = setInterval(() => {
|
|
47
58
|
void this.pollAndProcess();
|
|
48
|
-
}, this.config.
|
|
49
|
-
void this.pollAndProcess();
|
|
59
|
+
}, this.config.safetyNetInterval);
|
|
50
60
|
this.startCleanup();
|
|
61
|
+
this.emit(OutboxEvents.PROCESSOR_STARTED);
|
|
62
|
+
this.emit(OutboxEvents.POLLING_STARTED);
|
|
51
63
|
}
|
|
52
|
-
|
|
53
|
-
if (this.
|
|
54
|
-
clearInterval(this.
|
|
55
|
-
this.
|
|
56
|
-
this.emit(OutboxEvents.POLLING_STOPPED);
|
|
64
|
+
stopProcessor() {
|
|
65
|
+
if (this.safetyNetTimer) {
|
|
66
|
+
clearInterval(this.safetyNetTimer);
|
|
67
|
+
this.safetyNetTimer = undefined;
|
|
57
68
|
}
|
|
58
69
|
if (this.cleanupTimer) {
|
|
59
70
|
clearInterval(this.cleanupTimer);
|
|
60
71
|
this.cleanupTimer = undefined;
|
|
61
72
|
}
|
|
73
|
+
for (const timer of this.retryTimers.values()) {
|
|
74
|
+
clearTimeout(timer);
|
|
75
|
+
}
|
|
76
|
+
this.retryTimers.clear();
|
|
77
|
+
if (this.messageCreatedHandler) {
|
|
78
|
+
this.off(OutboxEvents.MESSAGE_CREATED, this.messageCreatedHandler);
|
|
79
|
+
this.messageCreatedHandler = undefined;
|
|
80
|
+
}
|
|
81
|
+
this.emit(OutboxEvents.PROCESSOR_STOPPED);
|
|
82
|
+
this.emit(OutboxEvents.POLLING_STOPPED);
|
|
83
|
+
}
|
|
84
|
+
startPolling() {
|
|
85
|
+
this.startProcessor();
|
|
86
|
+
}
|
|
87
|
+
stopPolling() {
|
|
88
|
+
this.stopProcessor();
|
|
89
|
+
}
|
|
90
|
+
async processMessageById(id) {
|
|
91
|
+
try {
|
|
92
|
+
const message = await this.repository.findAndLockById(id, this.config.workerId);
|
|
93
|
+
if (!message)
|
|
94
|
+
return;
|
|
95
|
+
await this.publishMessage(message);
|
|
96
|
+
}
|
|
97
|
+
catch (error) {
|
|
98
|
+
this.emit('error', error);
|
|
99
|
+
}
|
|
62
100
|
}
|
|
63
101
|
async processMessage(_messageId) {
|
|
64
102
|
await this.pollAndProcess();
|
|
@@ -106,6 +144,14 @@ class OutboxService extends events_1.EventEmitter {
|
|
|
106
144
|
const scheduledAt = new Date(Date.now() + backoffDelay);
|
|
107
145
|
await this.repository.markFailed(message.id, errorMessage, false, scheduledAt);
|
|
108
146
|
this.emit(OutboxEvents.MESSAGE_FAILED, { message, error, permanent: false });
|
|
147
|
+
const existingTimer = this.retryTimers.get(message.id);
|
|
148
|
+
if (existingTimer)
|
|
149
|
+
clearTimeout(existingTimer);
|
|
150
|
+
const timer = setTimeout(() => {
|
|
151
|
+
this.retryTimers.delete(message.id);
|
|
152
|
+
void this.processMessageById(message.id);
|
|
153
|
+
}, backoffDelay);
|
|
154
|
+
this.retryTimers.set(message.id, timer);
|
|
109
155
|
}
|
|
110
156
|
calculateBackoff(retryCount) {
|
|
111
157
|
const baseDelaySeconds = this.config.backoffBaseSeconds;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox.service.js","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":";;;AAAA,mCAAsC;AAEtC,2DAA8E;AAC9E,iEAA6D;AAS7D,IAAY,
|
|
1
|
+
{"version":3,"file":"outbox.service.js","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":"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"}
|