@prodforcode/event-forge-core 1.0.4 → 1.1.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 +7 -0
- package/dist/config/inbox.config.d.ts.map +1 -1
- package/dist/config/inbox.config.js +7 -0
- package/dist/config/inbox.config.js.map +1 -1
- package/dist/config/outbox.config.js +1 -1
- package/dist/interfaces/create-inbox-message.dto.d.ts +1 -0
- package/dist/interfaces/create-inbox-message.dto.d.ts.map +1 -1
- package/dist/interfaces/inbox-message.interface.d.ts +5 -1
- package/dist/interfaces/inbox-message.interface.d.ts.map +1 -1
- package/dist/interfaces/inbox-message.interface.js +1 -0
- package/dist/interfaces/inbox-message.interface.js.map +1 -1
- package/dist/interfaces/inbox-repository.interface.d.ts +2 -1
- package/dist/interfaces/inbox-repository.interface.d.ts.map +1 -1
- package/dist/interfaces/outbox-repository.interface.d.ts +1 -1
- package/dist/interfaces/outbox-repository.interface.d.ts.map +1 -1
- package/dist/services/inbox.service.d.ts +9 -1
- package/dist/services/inbox.service.d.ts.map +1 -1
- package/dist/services/inbox.service.js +67 -4
- package/dist/services/inbox.service.js.map +1 -1
- package/dist/services/outbox.service.d.ts +1 -0
- package/dist/services/outbox.service.d.ts.map +1 -1
- package/dist/services/outbox.service.js +12 -1
- package/dist/services/outbox.service.js.map +1 -1
- package/package.json +1 -1
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
export interface InboxConfig {
|
|
2
2
|
cleanupInterval?: number;
|
|
3
3
|
retentionDays?: number;
|
|
4
|
+
enableRetry?: boolean;
|
|
5
|
+
maxRetries?: number;
|
|
6
|
+
retryPollingInterval?: number;
|
|
7
|
+
backoffBaseSeconds?: number;
|
|
8
|
+
maxBackoffSeconds?: number;
|
|
9
|
+
retryBatchSize?: number;
|
|
10
|
+
retryWorkerId?: string;
|
|
4
11
|
}
|
|
5
12
|
export declare const DEFAULT_INBOX_CONFIG: Required<InboxConfig>;
|
|
6
13
|
//# 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;CACxB;AAKD,eAAO,MAAM,oBAAoB,EAAE,QAAQ,CAAC,WAAW,
|
|
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,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAG9B,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAG5B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAG3B,cAAc,CAAC,EAAE,MAAM,CAAC;IAGxB,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAKD,eAAO,MAAM,oBAAoB,EAAE,QAAQ,CAAC,WAAW,CAUtD,CAAC"}
|
|
@@ -4,5 +4,12 @@ exports.DEFAULT_INBOX_CONFIG = void 0;
|
|
|
4
4
|
exports.DEFAULT_INBOX_CONFIG = {
|
|
5
5
|
cleanupInterval: 86400000,
|
|
6
6
|
retentionDays: 7,
|
|
7
|
+
enableRetry: false,
|
|
8
|
+
maxRetries: 3,
|
|
9
|
+
retryPollingInterval: 5000,
|
|
10
|
+
backoffBaseSeconds: 5,
|
|
11
|
+
maxBackoffSeconds: 3600,
|
|
12
|
+
retryBatchSize: 10,
|
|
13
|
+
retryWorkerId: `${process.env.HOSTNAME || 'unknown'}-${process.pid}`,
|
|
7
14
|
};
|
|
8
15
|
//# 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":";;;AAmCa,QAAA,oBAAoB,GAA0B;IACzD,eAAe,EAAE,QAAQ;IACzB,aAAa,EAAE,CAAC;IAChB,WAAW,EAAE,KAAK;IAClB,UAAU,EAAE,CAAC;IACb,oBAAoB,EAAE,IAAI;IAC1B,kBAAkB,EAAE,CAAC;IACrB,iBAAiB,EAAE,IAAI;IACvB,cAAc,EAAE,EAAE;IAClB,aAAa,EAAE,GAAG,OAAO,CAAC,GAAG,CAAC,QAAQ,IAAI,SAAS,IAAI,OAAO,CAAC,GAAG,EAAE;CACrE,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"create-inbox-message.dto.d.ts","sourceRoot":"","sources":["../../src/interfaces/create-inbox-message.dto.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,qBAAqB;IAEpC,SAAS,EAAE,MAAM,CAAC;IAGlB,MAAM,EAAE,MAAM,CAAC;IAGf,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;
|
|
1
|
+
{"version":3,"file":"create-inbox-message.dto.d.ts","sourceRoot":"","sources":["../../src/interfaces/create-inbox-message.dto.ts"],"names":[],"mappings":"AAGA,MAAM,WAAW,qBAAqB;IAEpC,SAAS,EAAE,MAAM,CAAC;IAGlB,MAAM,EAAE,MAAM,CAAC;IAGf,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAGjC,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB"}
|
|
@@ -7,12 +7,16 @@ export interface InboxMessage {
|
|
|
7
7
|
status: InboxMessageStatus;
|
|
8
8
|
processedAt?: Date;
|
|
9
9
|
errorMessage?: string;
|
|
10
|
+
retryCount: number;
|
|
11
|
+
maxRetries: number;
|
|
12
|
+
scheduledAt?: Date;
|
|
10
13
|
createdAt: Date;
|
|
11
14
|
}
|
|
12
15
|
export declare enum InboxMessageStatus {
|
|
13
16
|
RECEIVED = "received",
|
|
14
17
|
PROCESSING = "processing",
|
|
15
18
|
PROCESSED = "processed",
|
|
16
|
-
FAILED = "failed"
|
|
19
|
+
FAILED = "failed",
|
|
20
|
+
PERMANENTLY_FAILED = "permanently_failed"
|
|
17
21
|
}
|
|
18
22
|
//# sourceMappingURL=inbox-message.interface.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox-message.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/inbox-message.interface.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAE3B,EAAE,EAAE,MAAM,CAAC;IAGX,SAAS,EAAE,MAAM,CAAC;IAGlB,MAAM,EAAE,MAAM,CAAC;IAGf,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAGjC,MAAM,EAAE,kBAAkB,CAAC;IAG3B,WAAW,CAAC,EAAE,IAAI,CAAC;IAGnB,YAAY,CAAC,EAAE,MAAM,CAAC;IAGtB,SAAS,EAAE,IAAI,CAAC;CACjB;AAKD,oBAAY,kBAAkB;IAC5B,QAAQ,aAAa;IACrB,UAAU,eAAe;IACzB,SAAS,cAAc;IACvB,MAAM,WAAW;
|
|
1
|
+
{"version":3,"file":"inbox-message.interface.d.ts","sourceRoot":"","sources":["../../src/interfaces/inbox-message.interface.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,YAAY;IAE3B,EAAE,EAAE,MAAM,CAAC;IAGX,SAAS,EAAE,MAAM,CAAC;IAGlB,MAAM,EAAE,MAAM,CAAC;IAGf,SAAS,EAAE,MAAM,CAAC;IAGlB,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAC;IAGjC,MAAM,EAAE,kBAAkB,CAAC;IAG3B,WAAW,CAAC,EAAE,IAAI,CAAC;IAGnB,YAAY,CAAC,EAAE,MAAM,CAAC;IAGtB,UAAU,EAAE,MAAM,CAAC;IAGnB,UAAU,EAAE,MAAM,CAAC;IAGnB,WAAW,CAAC,EAAE,IAAI,CAAC;IAGnB,SAAS,EAAE,IAAI,CAAC;CACjB;AAKD,oBAAY,kBAAkB;IAC5B,QAAQ,aAAa;IACrB,UAAU,eAAe;IACzB,SAAS,cAAc;IACvB,MAAM,WAAW;IACjB,kBAAkB,uBAAuB;CAC1C"}
|
|
@@ -7,5 +7,6 @@ var InboxMessageStatus;
|
|
|
7
7
|
InboxMessageStatus["PROCESSING"] = "processing";
|
|
8
8
|
InboxMessageStatus["PROCESSED"] = "processed";
|
|
9
9
|
InboxMessageStatus["FAILED"] = "failed";
|
|
10
|
+
InboxMessageStatus["PERMANENTLY_FAILED"] = "permanently_failed";
|
|
10
11
|
})(InboxMessageStatus || (exports.InboxMessageStatus = InboxMessageStatus = {}));
|
|
11
12
|
//# sourceMappingURL=inbox-message.interface.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"inbox-message.interface.js","sourceRoot":"","sources":["../../src/interfaces/inbox-message.interface.ts"],"names":[],"mappings":";;;
|
|
1
|
+
{"version":3,"file":"inbox-message.interface.js","sourceRoot":"","sources":["../../src/interfaces/inbox-message.interface.ts"],"names":[],"mappings":";;;AA6CA,IAAY,kBAMX;AAND,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,+CAAyB,CAAA;IACzB,6CAAuB,CAAA;IACvB,uCAAiB,CAAA;IACjB,+DAAyC,CAAA;AAC3C,CAAC,EANW,kBAAkB,kCAAlB,kBAAkB,QAM7B"}
|
|
@@ -9,7 +9,8 @@ export interface IInboxRepository {
|
|
|
9
9
|
exists(messageId: string, source: string): Promise<boolean>;
|
|
10
10
|
markProcessing(id: string): Promise<void>;
|
|
11
11
|
markProcessed(id: string): Promise<void>;
|
|
12
|
-
markFailed(id: string, error: string): Promise<void>;
|
|
12
|
+
markFailed(id: string, error: string, permanent?: boolean, scheduledAt?: Date): Promise<void>;
|
|
13
|
+
findRetryable(limit: number): Promise<InboxMessage[]>;
|
|
13
14
|
deleteOlderThan(date: Date): Promise<number>;
|
|
14
15
|
}
|
|
15
16
|
//# 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;
|
|
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,aAAa,CAAC,KAAK,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,EAAE,CAAC,CAAC;IAOtD,eAAe,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;CAC9C"}
|
|
@@ -4,7 +4,7 @@ export interface IOutboxRepository {
|
|
|
4
4
|
create(dto: CreateOutboxMessageDto, transactionContext?: unknown): Promise<OutboxMessage>;
|
|
5
5
|
fetchAndLockPending(limit: number, lockerId: string): Promise<OutboxMessage[]>;
|
|
6
6
|
markPublished(id: string): Promise<void>;
|
|
7
|
-
markFailed(id: string, error: string, permanent?: boolean): Promise<void>;
|
|
7
|
+
markFailed(id: string, error: string, permanent?: boolean, scheduledAt?: Date): Promise<void>;
|
|
8
8
|
releaseLock(id: string): Promise<void>;
|
|
9
9
|
releaseStaleLocks(olderThan: Date): Promise<number>;
|
|
10
10
|
deleteOlderThan(date: Date): Promise<number>;
|
|
@@ -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;
|
|
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;IAO7C,eAAe,CAAC,CAAC,EAAE,SAAS,EAAE,CAAC,OAAO,EAAE,OAAO,KAAK,OAAO,CAAC,CAAC,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;CAC7E"}
|
|
@@ -8,19 +8,27 @@ 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"
|
|
11
|
+
MESSAGE_FAILED = "inbox:message:failed",
|
|
12
|
+
RETRY_POLLING_STARTED = "inbox:retry:polling:started",
|
|
13
|
+
RETRY_POLLING_STOPPED = "inbox:retry:polling:stopped"
|
|
12
14
|
}
|
|
13
15
|
export declare class InboxService extends EventEmitter {
|
|
14
16
|
private readonly repository;
|
|
15
17
|
private readonly config;
|
|
16
18
|
private readonly handlers;
|
|
17
19
|
private cleanupTimer?;
|
|
20
|
+
private retryPollingTimer?;
|
|
21
|
+
private isProcessingRetries;
|
|
18
22
|
constructor(repository: IInboxRepository, config?: InboxConfig);
|
|
19
23
|
registerHandler(eventType: string, handler: MessageHandler): void;
|
|
20
24
|
unregisterHandler(eventType: string, handler: MessageHandler): void;
|
|
21
25
|
receiveMessage(dto: CreateInboxMessageDto): Promise<void>;
|
|
22
26
|
processMessage(message: InboxMessage): Promise<void>;
|
|
23
27
|
private handleProcessingError;
|
|
28
|
+
private calculateBackoff;
|
|
29
|
+
startRetryPolling(): void;
|
|
30
|
+
stopRetryPolling(): void;
|
|
31
|
+
private pollAndRetry;
|
|
24
32
|
startCleanup(): void;
|
|
25
33
|
stopCleanup(): void;
|
|
26
34
|
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;IACvC,qBAAqB,gCAAgC;IACrD,qBAAqB,gCAAgC;CACtD;AAMD,qBAAa,YAAa,SAAQ,YAAY;IAQ1C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAP7B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAwB;IAC/C,OAAO,CAAC,QAAQ,CAAC,QAAQ,CAAuC;IAChE,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,iBAAiB,CAAC,CAAiB;IAC3C,OAAO,CAAC,mBAAmB,CAAS;gBAGjB,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;IAsBxB,iBAAiB,IAAI,IAAI;IAqBzB,gBAAgB,IAAI,IAAI;YAWV,YAAY;IA4B1B,YAAY,IAAI,IAAI;IAgBpB,WAAW,IAAI,IAAI;YAUL,OAAO;CAYtB"}
|
|
@@ -11,12 +11,16 @@ 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";
|
|
14
16
|
})(InboxEvents || (exports.InboxEvents = InboxEvents = {}));
|
|
15
17
|
class InboxService extends events_1.EventEmitter {
|
|
16
18
|
repository;
|
|
17
19
|
config;
|
|
18
20
|
handlers = new Map();
|
|
19
21
|
cleanupTimer;
|
|
22
|
+
retryPollingTimer;
|
|
23
|
+
isProcessingRetries = false;
|
|
20
24
|
constructor(repository, config) {
|
|
21
25
|
super();
|
|
22
26
|
this.repository = repository;
|
|
@@ -72,13 +76,72 @@ class InboxService extends events_1.EventEmitter {
|
|
|
72
76
|
}
|
|
73
77
|
async handleProcessingError(message, error) {
|
|
74
78
|
const errorMessage = error instanceof Error ? error.message : String(error);
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
+
const isPermanent = error instanceof processing_error_1.ProcessingError;
|
|
80
|
+
if (message.retryCount >= message.maxRetries || isPermanent) {
|
|
81
|
+
await this.repository.markFailed(message.id, errorMessage, true);
|
|
82
|
+
this.emit(InboxEvents.MESSAGE_FAILED, { message, error, permanent: true });
|
|
83
|
+
if (isPermanent) {
|
|
84
|
+
throw error;
|
|
85
|
+
}
|
|
86
|
+
throw new Error(`Failed to process inbox message ${message.id} after ${message.maxRetries} retries: ${errorMessage}`);
|
|
87
|
+
}
|
|
88
|
+
let scheduledAt;
|
|
89
|
+
if (this.config.enableRetry) {
|
|
90
|
+
const backoffDelay = this.calculateBackoff(message.retryCount);
|
|
91
|
+
scheduledAt = new Date(Date.now() + backoffDelay);
|
|
79
92
|
}
|
|
93
|
+
await this.repository.markFailed(message.id, errorMessage, false, scheduledAt);
|
|
94
|
+
this.emit(InboxEvents.MESSAGE_FAILED, { message, error, permanent: false });
|
|
80
95
|
throw new Error(`Failed to process inbox message ${message.id}: ${errorMessage}`);
|
|
81
96
|
}
|
|
97
|
+
calculateBackoff(retryCount) {
|
|
98
|
+
const baseDelaySeconds = this.config.backoffBaseSeconds;
|
|
99
|
+
const maxDelaySeconds = this.config.maxBackoffSeconds;
|
|
100
|
+
const exponentialDelay = baseDelaySeconds * Math.pow(2, retryCount);
|
|
101
|
+
const cappedDelay = Math.min(exponentialDelay, maxDelaySeconds);
|
|
102
|
+
const jitter = cappedDelay * 0.1 * (Math.random() * 2 - 1);
|
|
103
|
+
const finalDelay = cappedDelay + jitter;
|
|
104
|
+
return Math.max(0, finalDelay * 1000);
|
|
105
|
+
}
|
|
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
|
+
}
|
|
82
145
|
startCleanup() {
|
|
83
146
|
if (this.cleanupTimer) {
|
|
84
147
|
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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"}
|
|
@@ -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;IAC1C,eAAe,2BAA2B;CAC3C;AAMD,qBAAa,aAAc,SAAQ,YAAY;IAO3C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAP5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyB;IAChD,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,YAAY,CAAS;gBAGV,UAAU,EAAE,iBAAiB,EAC7B,SAAS,EAAE,iBAAiB,EAC7C,MAAM,CAAC,EAAE,YAAY;IAUjB,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;IAOjF,YAAY,IAAI,IAAI;IAoBpB,WAAW,IAAI,IAAI;IAgBb,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YASzC,cAAc;YAoCd,cAAc;YAiBd,kBAAkB;
|
|
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;IAC1C,eAAe,2BAA2B;CAC3C;AAMD,qBAAa,aAAc,SAAQ,YAAY;IAO3C,OAAO,CAAC,QAAQ,CAAC,UAAU;IAC3B,OAAO,CAAC,QAAQ,CAAC,SAAS;IAP5B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAyB;IAChD,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,YAAY,CAAC,CAAiB;IACtC,OAAO,CAAC,YAAY,CAAS;gBAGV,UAAU,EAAE,iBAAiB,EAC7B,SAAS,EAAE,iBAAiB,EAC7C,MAAM,CAAC,EAAE,YAAY;IAUjB,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;IAOjF,YAAY,IAAI,IAAI;IAoBpB,WAAW,IAAI,IAAI;IAgBb,cAAc,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YASzC,cAAc;YAoCd,cAAc;YAiBd,kBAAkB;IAwBhC,OAAO,CAAC,gBAAgB;IAqBxB,OAAO,CAAC,YAAY;YAYN,OAAO;CAatB"}
|
|
@@ -102,9 +102,20 @@ class OutboxService extends events_1.EventEmitter {
|
|
|
102
102
|
this.emit(OutboxEvents.MESSAGE_FAILED, { message, error, permanent: true });
|
|
103
103
|
return;
|
|
104
104
|
}
|
|
105
|
-
|
|
105
|
+
const backoffDelay = this.calculateBackoff(message.retryCount);
|
|
106
|
+
const scheduledAt = new Date(Date.now() + backoffDelay);
|
|
107
|
+
await this.repository.markFailed(message.id, errorMessage, false, scheduledAt);
|
|
106
108
|
this.emit(OutboxEvents.MESSAGE_FAILED, { message, error, permanent: false });
|
|
107
109
|
}
|
|
110
|
+
calculateBackoff(retryCount) {
|
|
111
|
+
const baseDelaySeconds = this.config.backoffBaseSeconds;
|
|
112
|
+
const maxDelaySeconds = this.config.maxBackoffSeconds;
|
|
113
|
+
const exponentialDelay = baseDelaySeconds * Math.pow(2, retryCount);
|
|
114
|
+
const cappedDelay = Math.min(exponentialDelay, maxDelaySeconds);
|
|
115
|
+
const jitter = cappedDelay * 0.1 * (Math.random() * 2 - 1);
|
|
116
|
+
const finalDelay = cappedDelay + jitter;
|
|
117
|
+
return Math.max(0, finalDelay * 1000);
|
|
118
|
+
}
|
|
108
119
|
startCleanup() {
|
|
109
120
|
this.cleanupTimer = setInterval(() => {
|
|
110
121
|
void this.cleanup();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"outbox.service.js","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"outbox.service.js","sourceRoot":"","sources":["../../src/services/outbox.service.ts"],"names":[],"mappings":"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"}
|