@volontariapp/post-processors 1.0.0-snap-856af13 → 1.0.0-snap-678b8d1
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/constants/config.default.d.ts +27 -0
- package/dist/constants/config.default.d.ts.map +1 -0
- package/dist/constants/config.default.js +29 -0
- package/dist/constants/config.default.js.map +1 -0
- package/dist/constants/index.d.ts +2 -0
- package/dist/constants/index.d.ts.map +1 -0
- package/dist/constants/index.js +2 -0
- package/dist/constants/index.js.map +1 -0
- package/dist/core/helpers/index.d.ts +3 -0
- package/dist/core/helpers/index.d.ts.map +1 -0
- package/dist/core/helpers/index.js +3 -0
- package/dist/core/helpers/index.js.map +1 -0
- package/dist/core/{redis-stream.helper.d.ts → helpers/redis-stream.helper.d.ts} +2 -2
- package/dist/core/helpers/redis-stream.helper.d.ts.map +1 -0
- package/dist/core/helpers/redis-stream.helper.js.map +1 -0
- package/dist/core/helpers/retry.helper.d.ts +24 -0
- package/dist/core/helpers/retry.helper.d.ts.map +1 -0
- package/dist/core/helpers/retry.helper.js +104 -0
- package/dist/core/helpers/retry.helper.js.map +1 -0
- package/dist/core/index.d.ts +7 -4
- package/dist/core/index.d.ts.map +1 -1
- package/dist/core/index.js +7 -4
- package/dist/core/index.js.map +1 -1
- package/dist/core/processors/base.post-processor.d.ts +47 -0
- package/dist/core/processors/base.post-processor.d.ts.map +1 -0
- package/dist/core/processors/base.post-processor.js +425 -0
- package/dist/core/processors/base.post-processor.js.map +1 -0
- package/dist/core/{batch.post-processor.d.ts → processors/batch.post-processor.d.ts} +3 -2
- package/dist/core/processors/batch.post-processor.d.ts.map +1 -0
- package/dist/core/{batch.post-processor.js → processors/batch.post-processor.js} +56 -5
- package/dist/core/processors/batch.post-processor.js.map +1 -0
- package/dist/core/processors/index.d.ts +4 -0
- package/dist/core/processors/index.d.ts.map +1 -0
- package/dist/core/processors/index.js +4 -0
- package/dist/core/processors/index.js.map +1 -0
- package/dist/core/{single.post-processor.d.ts → processors/single.post-processor.d.ts} +3 -1
- package/dist/core/processors/single.post-processor.d.ts.map +1 -0
- package/dist/core/processors/single.post-processor.js +120 -0
- package/dist/core/processors/single.post-processor.js.map +1 -0
- package/dist/core/validators/circuit-breaker.d.ts +27 -0
- package/dist/core/validators/circuit-breaker.d.ts.map +1 -0
- package/dist/core/validators/circuit-breaker.js +83 -0
- package/dist/core/validators/circuit-breaker.js.map +1 -0
- package/dist/core/validators/index.d.ts +2 -0
- package/dist/core/validators/index.d.ts.map +1 -0
- package/dist/core/validators/index.js +2 -0
- package/dist/core/validators/index.js.map +1 -0
- package/dist/core/validators/options-validator.d.ts +5 -0
- package/dist/core/validators/options-validator.d.ts.map +1 -0
- package/dist/core/validators/options-validator.js +90 -0
- package/dist/core/validators/options-validator.js.map +1 -0
- package/dist/enums/circuit-breaker-state.enum.d.ts +6 -0
- package/dist/enums/circuit-breaker-state.enum.d.ts.map +1 -0
- package/dist/enums/circuit-breaker-state.enum.js +7 -0
- package/dist/enums/circuit-breaker-state.enum.js.map +1 -0
- package/dist/enums/index.d.ts +2 -0
- package/dist/enums/index.d.ts.map +1 -0
- package/dist/enums/index.js +2 -0
- package/dist/enums/index.js.map +1 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/interfaces/index.d.ts +7 -3
- package/dist/interfaces/index.d.ts.map +1 -1
- package/dist/interfaces/{batch-event-item.interface.d.ts → processors/batch-event-item.interface.d.ts} +1 -1
- package/dist/interfaces/processors/batch-event-item.interface.d.ts.map +1 -0
- package/dist/interfaces/processors/batch-event-item.interface.js.map +1 -0
- package/dist/interfaces/processors/normalized-post-processor-options.interface.d.ts +6 -0
- package/dist/interfaces/processors/normalized-post-processor-options.interface.d.ts.map +1 -0
- package/dist/interfaces/processors/normalized-post-processor-options.interface.js +2 -0
- package/dist/interfaces/processors/normalized-post-processor-options.interface.js.map +1 -0
- package/dist/interfaces/processors/pending-message-info.interface.d.ts.map +1 -0
- package/dist/interfaces/processors/pending-message-info.interface.js.map +1 -0
- package/dist/interfaces/processors/post-processor-options.interface.d.ts +21 -0
- package/dist/interfaces/processors/post-processor-options.interface.d.ts.map +1 -0
- package/dist/interfaces/processors/post-processor-options.interface.js.map +1 -0
- package/dist/interfaces/retry/retry-metadata.interface.d.ts +6 -0
- package/dist/interfaces/retry/retry-metadata.interface.d.ts.map +1 -0
- package/dist/interfaces/retry/retry-metadata.interface.js +2 -0
- package/dist/interfaces/retry/retry-metadata.interface.js.map +1 -0
- package/dist/interfaces/retry/retry-options.interface.d.ts +8 -0
- package/dist/interfaces/retry/retry-options.interface.d.ts.map +1 -0
- package/dist/interfaces/retry/retry-options.interface.js +2 -0
- package/dist/interfaces/retry/retry-options.interface.js.map +1 -0
- package/dist/interfaces/validators/circuit-breaker-config.interface.d.ts +6 -0
- package/dist/interfaces/validators/circuit-breaker-config.interface.d.ts.map +1 -0
- package/dist/interfaces/validators/circuit-breaker-config.interface.js +2 -0
- package/dist/interfaces/validators/circuit-breaker-config.interface.js.map +1 -0
- package/dist/test/data-source.d.ts.map +1 -0
- package/dist/test/data-source.js +25 -0
- package/dist/test/data-source.js.map +1 -0
- package/dist/test/specs/batch-post-processor/batch-post-processor.int.spec.js +92 -4
- package/dist/test/specs/batch-post-processor/batch-post-processor.int.spec.js.map +1 -1
- package/dist/test/specs/batch-post-processor/batch-post-processor.unit.spec.js +174 -7
- package/dist/test/specs/batch-post-processor/batch-post-processor.unit.spec.js.map +1 -1
- package/dist/test/specs/helpers/redis-stream-helper.int.spec.d.ts +2 -0
- package/dist/test/specs/helpers/redis-stream-helper.int.spec.d.ts.map +1 -0
- package/dist/test/specs/helpers/redis-stream-helper.int.spec.js +56 -0
- package/dist/test/specs/helpers/redis-stream-helper.int.spec.js.map +1 -0
- package/dist/test/specs/helpers/redis-stream-helper.unit.spec.d.ts +2 -0
- package/dist/test/specs/helpers/redis-stream-helper.unit.spec.d.ts.map +1 -0
- package/dist/test/specs/helpers/redis-stream-helper.unit.spec.js +102 -0
- package/dist/test/specs/helpers/redis-stream-helper.unit.spec.js.map +1 -0
- package/dist/test/specs/helpers/retry-helper.int.spec.d.ts +2 -0
- package/dist/test/specs/helpers/retry-helper.int.spec.d.ts.map +1 -0
- package/dist/test/specs/helpers/retry-helper.int.spec.js +101 -0
- package/dist/test/specs/helpers/retry-helper.int.spec.js.map +1 -0
- package/dist/test/specs/helpers/retry-helper.unit.spec.d.ts +2 -0
- package/dist/test/specs/helpers/retry-helper.unit.spec.d.ts.map +1 -0
- package/dist/test/specs/helpers/retry-helper.unit.spec.js +202 -0
- package/dist/test/specs/helpers/retry-helper.unit.spec.js.map +1 -0
- package/dist/test/specs/integration/batch-post-processor-e2e.int.spec.d.ts +2 -0
- package/dist/test/specs/integration/batch-post-processor-e2e.int.spec.d.ts.map +1 -0
- package/dist/test/specs/integration/batch-post-processor-e2e.int.spec.js +190 -0
- package/dist/test/specs/integration/batch-post-processor-e2e.int.spec.js.map +1 -0
- package/dist/test/specs/integration/circuit-breaker.integration.spec.d.ts +2 -0
- package/dist/test/specs/integration/circuit-breaker.integration.spec.d.ts.map +1 -0
- package/dist/test/specs/integration/circuit-breaker.integration.spec.js +140 -0
- package/dist/test/specs/integration/circuit-breaker.integration.spec.js.map +1 -0
- package/dist/test/specs/integration/multiple-post-processors.int.spec.d.ts +2 -0
- package/dist/test/specs/integration/multiple-post-processors.int.spec.d.ts.map +1 -0
- package/dist/test/specs/integration/multiple-post-processors.int.spec.js +247 -0
- package/dist/test/specs/integration/multiple-post-processors.int.spec.js.map +1 -0
- package/dist/test/specs/integration/single-post-processor-e2e.int.spec.d.ts +2 -0
- package/dist/test/specs/integration/single-post-processor-e2e.int.spec.d.ts.map +1 -0
- package/dist/test/specs/integration/single-post-processor-e2e.int.spec.js +288 -0
- package/dist/test/specs/integration/single-post-processor-e2e.int.spec.js.map +1 -0
- package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.d.ts +2 -0
- package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.d.ts.map +1 -0
- package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.js +142 -0
- package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.js.map +1 -0
- package/dist/test/specs/single-post-processor/single-post-processor.int.spec.js +49 -7
- package/dist/test/specs/single-post-processor/single-post-processor.int.spec.js.map +1 -1
- package/dist/test/specs/single-post-processor/single-post-processor.unit.spec.js +110 -22
- package/dist/test/specs/single-post-processor/single-post-processor.unit.spec.js.map +1 -1
- package/dist/test/specs/validators/options-validator.unit.spec.d.ts +2 -0
- package/dist/test/specs/validators/options-validator.unit.spec.d.ts.map +1 -0
- package/dist/test/specs/validators/options-validator.unit.spec.js +290 -0
- package/dist/test/specs/validators/options-validator.unit.spec.js.map +1 -0
- package/dist/test/utils/classes/e2e-batch-post-processor.class.d.ts +14 -0
- package/dist/test/utils/classes/e2e-batch-post-processor.class.d.ts.map +1 -0
- package/dist/test/utils/classes/e2e-batch-post-processor.class.js +34 -0
- package/dist/test/utils/classes/e2e-batch-post-processor.class.js.map +1 -0
- package/dist/test/utils/classes/e2e-single-post-processor.class.d.ts +16 -0
- package/dist/test/utils/classes/e2e-single-post-processor.class.d.ts.map +1 -0
- package/dist/test/utils/classes/e2e-single-post-processor.class.js +27 -0
- package/dist/test/utils/classes/e2e-single-post-processor.class.js.map +1 -0
- package/dist/test/utils/classes/test-base-post-processor.class.d.ts +23 -0
- package/dist/test/utils/classes/test-base-post-processor.class.d.ts.map +1 -0
- package/dist/test/utils/classes/test-base-post-processor.class.js +60 -0
- package/dist/test/utils/classes/test-base-post-processor.class.js.map +1 -0
- package/dist/test/utils/classes/test-batch-post-processor.class.d.ts +3 -1
- package/dist/test/utils/classes/test-batch-post-processor.class.d.ts.map +1 -1
- package/dist/test/utils/classes/test-batch-post-processor.class.js +7 -1
- package/dist/test/utils/classes/test-batch-post-processor.class.js.map +1 -1
- package/dist/test/utils/classes/test-post-processor.class.d.ts +3 -1
- package/dist/test/utils/classes/test-post-processor.class.d.ts.map +1 -1
- package/dist/test/utils/classes/test-post-processor.class.js +7 -1
- package/dist/test/utils/classes/test-post-processor.class.js.map +1 -1
- package/dist/test/utils/factories/test-event.factory.d.ts +4 -0
- package/dist/test/utils/factories/test-event.factory.d.ts.map +1 -1
- package/dist/test/utils/factories/test-event.factory.js +30 -0
- package/dist/test/utils/factories/test-event.factory.js.map +1 -1
- package/dist/test/utils/helpers/push-db-event.helper.d.ts +12 -0
- package/dist/test/utils/helpers/push-db-event.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/push-db-event.helper.js +36 -0
- package/dist/test/utils/helpers/push-db-event.helper.js.map +1 -0
- package/dist/test/utils/helpers/wait.helper.d.ts +2 -0
- package/dist/test/utils/helpers/wait.helper.d.ts.map +1 -0
- package/dist/test/utils/helpers/wait.helper.js +11 -0
- package/dist/test/utils/helpers/wait.helper.js.map +1 -0
- package/dist/test/utils/index.d.ts +5 -0
- package/dist/test/utils/index.d.ts.map +1 -1
- package/dist/test/utils/index.js +5 -0
- package/dist/test/utils/index.js.map +1 -1
- package/dist/test/utils/mocks/redis-call.mock.d.ts.map +1 -1
- package/dist/test/utils/mocks/redis-call.mock.js +9 -0
- package/dist/test/utils/mocks/redis-call.mock.js.map +1 -1
- package/dist/types/index.d.ts +1 -0
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/types/parse-event.types.d.ts +13 -0
- package/dist/types/parse-event.types.d.ts.map +1 -0
- package/dist/types/parse-event.types.js +2 -0
- package/dist/types/parse-event.types.js.map +1 -0
- package/package.json +6 -5
- package/dist/core/base.post-processor.d.ts +0 -27
- package/dist/core/base.post-processor.d.ts.map +0 -1
- package/dist/core/base.post-processor.js +0 -206
- package/dist/core/base.post-processor.js.map +0 -1
- package/dist/core/batch.post-processor.d.ts.map +0 -1
- package/dist/core/batch.post-processor.js.map +0 -1
- package/dist/core/redis-stream.helper.d.ts.map +0 -1
- package/dist/core/redis-stream.helper.js.map +0 -1
- package/dist/core/single.post-processor.d.ts.map +0 -1
- package/dist/core/single.post-processor.js +0 -58
- package/dist/core/single.post-processor.js.map +0 -1
- package/dist/data-source.d.ts.map +0 -1
- package/dist/data-source.js +0 -33
- package/dist/data-source.js.map +0 -1
- package/dist/interfaces/batch-event-item.interface.d.ts.map +0 -1
- package/dist/interfaces/batch-event-item.interface.js.map +0 -1
- package/dist/interfaces/pending-message-info.interface.d.ts.map +0 -1
- package/dist/interfaces/pending-message-info.interface.js.map +0 -1
- package/dist/interfaces/post-processor-options.interface.d.ts +0 -11
- package/dist/interfaces/post-processor-options.interface.d.ts.map +0 -1
- package/dist/interfaces/post-processor-options.interface.js.map +0 -1
- package/dist/migrations/1776783577425-CreateJobsOutbox.d.ts +0 -7
- package/dist/migrations/1776783577425-CreateJobsOutbox.d.ts.map +0 -1
- package/dist/migrations/1776783577425-CreateJobsOutbox.js +0 -25
- package/dist/migrations/1776783577425-CreateJobsOutbox.js.map +0 -1
- package/dist/migrations/1778328780881-InitialSchemaJobAudit.d.ts +0 -6
- package/dist/migrations/1778328780881-InitialSchemaJobAudit.d.ts.map +0 -1
- package/dist/migrations/1778328780881-InitialSchemaJobAudit.js +0 -93
- package/dist/migrations/1778328780881-InitialSchemaJobAudit.js.map +0 -1
- /package/dist/core/{redis-stream.helper.js → helpers/redis-stream.helper.js} +0 -0
- /package/dist/interfaces/{batch-event-item.interface.js → processors/batch-event-item.interface.js} +0 -0
- /package/dist/interfaces/{pending-message-info.interface.d.ts → processors/pending-message-info.interface.d.ts} +0 -0
- /package/dist/interfaces/{pending-message-info.interface.js → processors/pending-message-info.interface.js} +0 -0
- /package/dist/interfaces/{post-processor-options.interface.js → processors/post-processor-options.interface.js} +0 -0
- /package/dist/{data-source.d.ts → test/data-source.d.ts} +0 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { RetryOptions } from '../index.js';
|
|
2
|
+
import type { CircuitBreakerConfig } from '../interfaces/validators/circuit-breaker-config.interface.js';
|
|
3
|
+
export declare const DEFAULT_RETRY_OPTIONS: RetryOptions;
|
|
4
|
+
export declare const DEFAULT_CIRCUIT_BREAKER_CONFIG: CircuitBreakerConfig;
|
|
5
|
+
export declare const DEFAULT_DYNAMIC_BATCHING_CONFIG: {
|
|
6
|
+
enabled: boolean;
|
|
7
|
+
minBatchSize: number;
|
|
8
|
+
maxBatchSize: number;
|
|
9
|
+
targetLatencyMs: number;
|
|
10
|
+
};
|
|
11
|
+
export interface RequiredPostProcessorOptions {
|
|
12
|
+
batchSize: number;
|
|
13
|
+
blockMs: number;
|
|
14
|
+
claimIntervalMs: number;
|
|
15
|
+
claimMinIdleTimeMs: number;
|
|
16
|
+
idempotencyTtlSeconds: number;
|
|
17
|
+
circuitBreaker: CircuitBreakerConfig;
|
|
18
|
+
retry: RetryOptions;
|
|
19
|
+
dynamicBatching: {
|
|
20
|
+
enabled: boolean;
|
|
21
|
+
minBatchSize: number;
|
|
22
|
+
maxBatchSize: number;
|
|
23
|
+
targetLatencyMs: number;
|
|
24
|
+
};
|
|
25
|
+
}
|
|
26
|
+
export declare const DEFAULT_POST_PROCESSOR_CONFIG: RequiredPostProcessorOptions;
|
|
27
|
+
//# sourceMappingURL=config.default.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.default.d.ts","sourceRoot":"","sources":["../../src/constants/config.default.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,8DAA8D,CAAC;AAEzG,eAAO,MAAM,qBAAqB,EAAE,YAMnC,CAAC;AAEF,eAAO,MAAM,8BAA8B,EAAE,oBAI5C,CAAC;AAEF,eAAO,MAAM,+BAA+B;;;;;CAK3C,CAAC;AAEF,MAAM,WAAW,4BAA4B;IAC3C,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,eAAe,EAAE,MAAM,CAAC;IACxB,kBAAkB,EAAE,MAAM,CAAC;IAC3B,qBAAqB,EAAE,MAAM,CAAC;IAC9B,cAAc,EAAE,oBAAoB,CAAC;IACrC,KAAK,EAAE,YAAY,CAAC;IACpB,eAAe,EAAE;QACf,OAAO,EAAE,OAAO,CAAC;QACjB,YAAY,EAAE,MAAM,CAAC;QACrB,YAAY,EAAE,MAAM,CAAC;QACrB,eAAe,EAAE,MAAM,CAAC;KACzB,CAAC;CACH;AAED,eAAO,MAAM,6BAA6B,EAAE,4BAS3C,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
export const DEFAULT_RETRY_OPTIONS = {
|
|
2
|
+
maxRetries: 5,
|
|
3
|
+
initialDelayMs: 1000,
|
|
4
|
+
maxDelayMs: 60000,
|
|
5
|
+
backoffMultiplier: 2,
|
|
6
|
+
enableDlq: true,
|
|
7
|
+
};
|
|
8
|
+
export const DEFAULT_CIRCUIT_BREAKER_CONFIG = {
|
|
9
|
+
failureThreshold: 3,
|
|
10
|
+
resetTimeoutMs: 60000,
|
|
11
|
+
successThreshold: 1,
|
|
12
|
+
};
|
|
13
|
+
export const DEFAULT_DYNAMIC_BATCHING_CONFIG = {
|
|
14
|
+
enabled: false,
|
|
15
|
+
minBatchSize: 1,
|
|
16
|
+
maxBatchSize: 100,
|
|
17
|
+
targetLatencyMs: 1000,
|
|
18
|
+
};
|
|
19
|
+
export const DEFAULT_POST_PROCESSOR_CONFIG = {
|
|
20
|
+
batchSize: 10,
|
|
21
|
+
blockMs: 2000,
|
|
22
|
+
claimIntervalMs: 30000,
|
|
23
|
+
claimMinIdleTimeMs: 60000,
|
|
24
|
+
idempotencyTtlSeconds: 86400,
|
|
25
|
+
retry: DEFAULT_RETRY_OPTIONS,
|
|
26
|
+
circuitBreaker: DEFAULT_CIRCUIT_BREAKER_CONFIG,
|
|
27
|
+
dynamicBatching: DEFAULT_DYNAMIC_BATCHING_CONFIG,
|
|
28
|
+
};
|
|
29
|
+
//# sourceMappingURL=config.default.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"config.default.js","sourceRoot":"","sources":["../../src/constants/config.default.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,qBAAqB,GAAiB;IACjD,UAAU,EAAE,CAAC;IACb,cAAc,EAAE,IAAI;IACpB,UAAU,EAAE,KAAK;IACjB,iBAAiB,EAAE,CAAC;IACpB,SAAS,EAAE,IAAI;CAChB,CAAC;AAEF,MAAM,CAAC,MAAM,8BAA8B,GAAyB;IAClE,gBAAgB,EAAE,CAAC;IACnB,cAAc,EAAE,KAAK;IACrB,gBAAgB,EAAE,CAAC;CACpB,CAAC;AAEF,MAAM,CAAC,MAAM,+BAA+B,GAAG;IAC7C,OAAO,EAAE,KAAK;IACd,YAAY,EAAE,CAAC;IACf,YAAY,EAAE,GAAG;IACjB,eAAe,EAAE,IAAI;CACtB,CAAC;AAkBF,MAAM,CAAC,MAAM,6BAA6B,GAAiC;IACzE,SAAS,EAAE,EAAE;IACb,OAAO,EAAE,IAAI;IACb,eAAe,EAAE,KAAK;IACtB,kBAAkB,EAAE,KAAK;IACzB,qBAAqB,EAAE,KAAK;IAC5B,KAAK,EAAE,qBAAqB;IAC5B,cAAc,EAAE,8BAA8B;IAC9C,eAAe,EAAE,+BAA+B;CACjD,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/core/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/helpers/index.ts"],"names":[],"mappings":"AAAA,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import type { Redis } from 'ioredis';
|
|
2
|
-
import type { RedisStreamEntry, RedisStreamRawEntry } from '
|
|
3
|
-
import type { PendingMessageInfo } from '
|
|
2
|
+
import type { RedisStreamEntry, RedisStreamRawEntry } from '../../types/index.js';
|
|
3
|
+
import type { PendingMessageInfo } from '../../interfaces/index.js';
|
|
4
4
|
export declare class RedisStreamHelper {
|
|
5
5
|
static parseRawEntries(rawEntries: RedisStreamRawEntry[]): RedisStreamEntry[];
|
|
6
6
|
static getPendingMessages(redis: Redis, streamName: string, groupName: string, batchSize: number): Promise<PendingMessageInfo[]>;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-stream.helper.d.ts","sourceRoot":"","sources":["../../../src/core/helpers/redis-stream.helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EAAE,gBAAgB,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAClF,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAEpE,qBAAa,iBAAiB;IAI5B,MAAM,CAAC,eAAe,CAAC,UAAU,EAAE,mBAAmB,EAAE,GAAG,gBAAgB,EAAE;WAmBhE,kBAAkB,CAC7B,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,kBAAkB,EAAE,CAAC;WAuBnB,YAAY,CACvB,KAAK,EAAE,KAAK,EACZ,UAAU,EAAE,MAAM,EAClB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,EACpB,kBAAkB,EAAE,MAAM,EAC1B,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC;IAehB,MAAM,CAAC,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,MAAM;WAQzD,sBAAsB,CACjC,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,UAAU,EAAE,MAAM,GACjB,OAAO,CAAC,OAAO,CAAC;WASN,qBAAqB,CAChC,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,IAAI,CAAC;CAIjB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"redis-stream.helper.js","sourceRoot":"","sources":["../../../src/core/helpers/redis-stream.helper.ts"],"names":[],"mappings":"AAIA,MAAM,OAAO,iBAAiB;IAI5B,MAAM,CAAC,eAAe,CAAC,UAAiC;QACtD,MAAM,OAAO,GAAuB,EAAE,CAAC;QACvC,KAAK,MAAM,CAAC,EAAE,EAAE,WAAW,CAAC,IAAI,UAAU,EAAE,CAAC;YAC3C,MAAM,MAAM,GAA2B,EAAE,CAAC;YAC1C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC/C,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;gBAC3B,MAAM,GAAG,GAAG,WAAW,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC;gBAC/B,IAAI,GAAG,IAAI,GAAG,EAAE,CAAC;oBACf,MAAM,CAAC,GAAG,CAAC,GAAG,GAAG,CAAC;gBACpB,CAAC;YACH,CAAC;YACD,OAAO,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAC/B,CAAC;QACD,OAAO,OAAO,CAAC;IACjB,CAAC;IAKD,MAAM,CAAC,KAAK,CAAC,kBAAkB,CAC7B,KAAY,EACZ,UAAkB,EAClB,SAAiB,EACjB,SAAiB;QAEjB,MAAM,UAAU,GAAG,CAAC,MAAM,KAAK,CAAC,IAAI,CAClC,UAAU,EACV,UAAU,EACV,SAAS,EACT,GAAG,EACH,GAAG,EACH,SAAS,CACV,CAA8C,CAAC;QAEhD,IAAI,CAAC,UAAU;YAAE,OAAO,EAAE,CAAC;QAE3B,OAAO,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC,SAAS,EAAE,YAAY,EAAE,UAAU,EAAE,aAAa,CAAC,EAAE,EAAE,CAAC,CAAC;YAC/E,SAAS;YACT,YAAY;YACZ,UAAU,EAAE,MAAM,CAAC,UAAU,CAAC;YAC9B,aAAa,EAAE,MAAM,CAAC,aAAa,CAAC;SACrC,CAAC,CAAC,CAAC;IACN,CAAC;IAKD,MAAM,CAAC,KAAK,CAAC,YAAY,CACvB,KAAY,EACZ,UAAkB,EAClB,SAAiB,EACjB,YAAoB,EACpB,kBAA0B,EAC1B,SAAiB;QAEjB,MAAM,KAAK,CAAC,IAAI,CACd,QAAQ,EACR,UAAU,EACV,SAAS,EACT,YAAY,EACZ,kBAAkB,CAAC,QAAQ,EAAE,EAC7B,SAAS,EACT,QAAQ,CACT,CAAC;IACJ,CAAC;IAKD,MAAM,CAAC,iBAAiB,CAAC,SAAiB,EAAE,SAAiB;QAC3D,OAAO,8BAA8B,SAAS,IAAI,SAAS,EAAE,CAAC;IAChE,CAAC;IAMD,MAAM,CAAC,KAAK,CAAC,sBAAsB,CACjC,KAAY,EACZ,SAAiB,EACjB,SAAiB,EACjB,UAAkB;QAElB,MAAM,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACzD,MAAM,MAAM,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,KAAK,EAAE,GAAG,EAAE,YAAY,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;QAClF,OAAO,MAAM,KAAK,IAAI,CAAC;IACzB,CAAC;IAKD,MAAM,CAAC,KAAK,CAAC,qBAAqB,CAChC,KAAY,EACZ,SAAiB,EACjB,SAAiB;QAEjB,MAAM,GAAG,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACzD,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;IACvB,CAAC;CACF"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import type { Redis } from 'ioredis';
|
|
2
|
+
import type { RetryOptions, RetryMetadata } from '../../interfaces/index.js';
|
|
3
|
+
import type { ParseResult } from '../../index.js';
|
|
4
|
+
export declare class RetryHelper {
|
|
5
|
+
private readonly maxRetries;
|
|
6
|
+
private readonly initialDelayMs;
|
|
7
|
+
private readonly maxDelayMs;
|
|
8
|
+
private readonly backoffMultiplier;
|
|
9
|
+
private readonly enableDlq;
|
|
10
|
+
constructor(options: Required<RetryOptions>);
|
|
11
|
+
calculateDelay(attemptCount: number): number;
|
|
12
|
+
private getRetryKey;
|
|
13
|
+
private getRetryQueueKey;
|
|
14
|
+
getDlqStreamName(streamName: string): string;
|
|
15
|
+
recordRetry(redis: Redis, groupName: string, messageId: string, error: Error, ttlSeconds?: number): Promise<number>;
|
|
16
|
+
getRetryMetadata(redis: Redis, groupName: string, messageId: string): Promise<RetryMetadata | null>;
|
|
17
|
+
enqueueForRetry(redis: Redis, groupName: string, messageId: string, attemptCount: number): Promise<void>;
|
|
18
|
+
getReadyForRetry(redis: Redis, groupName: string): Promise<string[]>;
|
|
19
|
+
shouldRetry(attemptCount: number): boolean;
|
|
20
|
+
clearRetryData(redis: Redis, groupName: string, messageId: string): Promise<void>;
|
|
21
|
+
sendToDlq(redis: Redis, dlqStreamName: string, messageId: string, originalPayload: ParseResult, error: string): Promise<string>;
|
|
22
|
+
static normalizeRetryOptions(options?: RetryOptions): Required<RetryOptions>;
|
|
23
|
+
}
|
|
24
|
+
//# sourceMappingURL=retry.helper.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.helper.d.ts","sourceRoot":"","sources":["../../../src/core/helpers/retry.helper.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,2BAA2B,CAAC;AAC7E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAKlD,qBAAa,WAAW;IACtB,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAAS;IACxC,OAAO,CAAC,QAAQ,CAAC,UAAU,CAAS;IACpC,OAAO,CAAC,QAAQ,CAAC,iBAAiB,CAAS;IAC3C,OAAO,CAAC,QAAQ,CAAC,SAAS,CAAU;gBAExB,OAAO,EAAE,QAAQ,CAAC,YAAY,CAAC;IAY3C,cAAc,CAAC,YAAY,EAAE,MAAM,GAAG,MAAM;IAQ5C,OAAO,CAAC,WAAW;IAOnB,OAAO,CAAC,gBAAgB;IAOxB,gBAAgB,CAAC,UAAU,EAAE,MAAM,GAAG,MAAM;IAQtC,WAAW,CACf,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,KAAK,EACZ,UAAU,GAAE,MAAc,GACzB,OAAO,CAAC,MAAM,CAAC;IAWZ,gBAAgB,CACpB,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,GAChB,OAAO,CAAC,aAAa,GAAG,IAAI,CAAC;IAwB1B,eAAe,CACnB,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,MAAM,EACjB,YAAY,EAAE,MAAM,GACnB,OAAO,CAAC,IAAI,CAAC;IAaV,gBAAgB,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAkB1E,WAAW,CAAC,YAAY,EAAE,MAAM,GAAG,OAAO;IAOpC,cAAc,CAAC,KAAK,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAejF,SAAS,CACb,KAAK,EAAE,KAAK,EACZ,aAAa,EAAE,MAAM,EACrB,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,WAAW,EAC5B,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,MAAM,CAAC;IAuBlB,MAAM,CAAC,qBAAqB,CAAC,OAAO,CAAC,EAAE,YAAY,GAAG,QAAQ,CAAC,YAAY,CAAC;CAqB7E"}
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
export class RetryHelper {
|
|
2
|
+
maxRetries;
|
|
3
|
+
initialDelayMs;
|
|
4
|
+
maxDelayMs;
|
|
5
|
+
backoffMultiplier;
|
|
6
|
+
enableDlq;
|
|
7
|
+
constructor(options) {
|
|
8
|
+
this.maxRetries = options.maxRetries;
|
|
9
|
+
this.initialDelayMs = options.initialDelayMs;
|
|
10
|
+
this.maxDelayMs = options.maxDelayMs;
|
|
11
|
+
this.backoffMultiplier = options.backoffMultiplier;
|
|
12
|
+
this.enableDlq = options.enableDlq;
|
|
13
|
+
}
|
|
14
|
+
calculateDelay(attemptCount) {
|
|
15
|
+
const delay = this.initialDelayMs * Math.pow(this.backoffMultiplier, attemptCount);
|
|
16
|
+
return Math.min(delay, this.maxDelayMs);
|
|
17
|
+
}
|
|
18
|
+
getRetryKey(groupName, messageId) {
|
|
19
|
+
return `retry:post-processor:${groupName}:${messageId}`;
|
|
20
|
+
}
|
|
21
|
+
getRetryQueueKey(groupName) {
|
|
22
|
+
return `retry-queue:post-processor:${groupName}`;
|
|
23
|
+
}
|
|
24
|
+
getDlqStreamName(streamName) {
|
|
25
|
+
return `${streamName}-dlq`;
|
|
26
|
+
}
|
|
27
|
+
async recordRetry(redis, groupName, messageId, error, ttlSeconds = 86400) {
|
|
28
|
+
const key = this.getRetryKey(groupName, messageId);
|
|
29
|
+
const currentAttempt = await redis.incr(`${key}:attempt`);
|
|
30
|
+
await redis.set(`${key}:lastError`, error.message, 'EX', ttlSeconds);
|
|
31
|
+
await redis.expire(key, ttlSeconds);
|
|
32
|
+
return currentAttempt;
|
|
33
|
+
}
|
|
34
|
+
async getRetryMetadata(redis, groupName, messageId) {
|
|
35
|
+
const key = this.getRetryKey(groupName, messageId);
|
|
36
|
+
const attemptCountStr = await redis.get(`${key}:attempt`);
|
|
37
|
+
if (!attemptCountStr) {
|
|
38
|
+
return null;
|
|
39
|
+
}
|
|
40
|
+
const attemptCount = Number(attemptCountStr);
|
|
41
|
+
const delay = this.calculateDelay(attemptCount);
|
|
42
|
+
const nextRetryTimestamp = Date.now() + delay;
|
|
43
|
+
const lastError = (await redis.get(`${key}:lastError`)) ?? undefined;
|
|
44
|
+
return {
|
|
45
|
+
attemptCount,
|
|
46
|
+
nextRetryTimestamp,
|
|
47
|
+
lastError,
|
|
48
|
+
};
|
|
49
|
+
}
|
|
50
|
+
async enqueueForRetry(redis, groupName, messageId, attemptCount) {
|
|
51
|
+
const queueKey = this.getRetryQueueKey(groupName);
|
|
52
|
+
const delay = this.calculateDelay(attemptCount);
|
|
53
|
+
const retryTimestamp = Date.now() + delay;
|
|
54
|
+
await redis.zadd(queueKey, retryTimestamp, messageId);
|
|
55
|
+
}
|
|
56
|
+
async getReadyForRetry(redis, groupName) {
|
|
57
|
+
const queueKey = this.getRetryQueueKey(groupName);
|
|
58
|
+
const now = Date.now();
|
|
59
|
+
const readyMessages = await redis.zrangebyscore(queueKey, '-inf', now);
|
|
60
|
+
if (readyMessages.length > 0) {
|
|
61
|
+
await redis.zrem(queueKey, ...readyMessages);
|
|
62
|
+
}
|
|
63
|
+
return readyMessages;
|
|
64
|
+
}
|
|
65
|
+
shouldRetry(attemptCount) {
|
|
66
|
+
return attemptCount < this.maxRetries;
|
|
67
|
+
}
|
|
68
|
+
async clearRetryData(redis, groupName, messageId) {
|
|
69
|
+
const key = this.getRetryKey(groupName, messageId);
|
|
70
|
+
const queueKey = this.getRetryQueueKey(groupName);
|
|
71
|
+
await Promise.all([
|
|
72
|
+
redis.del(`${key}:attempt`),
|
|
73
|
+
redis.del(`${key}:lastError`),
|
|
74
|
+
redis.del(key),
|
|
75
|
+
redis.zrem(queueKey, messageId),
|
|
76
|
+
]);
|
|
77
|
+
}
|
|
78
|
+
async sendToDlq(redis, dlqStreamName, messageId, originalPayload, error) {
|
|
79
|
+
if (!this.enableDlq) {
|
|
80
|
+
return messageId;
|
|
81
|
+
}
|
|
82
|
+
return (await redis.xadd(dlqStreamName, '*', 'messageId', messageId, 'error', error, 'payload', JSON.stringify(originalPayload), 'timestamp', String(Date.now())));
|
|
83
|
+
}
|
|
84
|
+
static normalizeRetryOptions(options) {
|
|
85
|
+
const defaultOptions = {
|
|
86
|
+
maxRetries: 5,
|
|
87
|
+
initialDelayMs: 1000,
|
|
88
|
+
maxDelayMs: 60000,
|
|
89
|
+
backoffMultiplier: 2,
|
|
90
|
+
enableDlq: true,
|
|
91
|
+
};
|
|
92
|
+
if (!options) {
|
|
93
|
+
return defaultOptions;
|
|
94
|
+
}
|
|
95
|
+
return {
|
|
96
|
+
maxRetries: options.maxRetries ?? defaultOptions.maxRetries,
|
|
97
|
+
initialDelayMs: options.initialDelayMs ?? defaultOptions.initialDelayMs,
|
|
98
|
+
maxDelayMs: options.maxDelayMs ?? defaultOptions.maxDelayMs,
|
|
99
|
+
backoffMultiplier: options.backoffMultiplier ?? defaultOptions.backoffMultiplier,
|
|
100
|
+
enableDlq: options.enableDlq ?? defaultOptions.enableDlq,
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
//# sourceMappingURL=retry.helper.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"retry.helper.js","sourceRoot":"","sources":["../../../src/core/helpers/retry.helper.ts"],"names":[],"mappings":"AAOA,MAAM,OAAO,WAAW;IACL,UAAU,CAAS;IACnB,cAAc,CAAS;IACvB,UAAU,CAAS;IACnB,iBAAiB,CAAS;IAC1B,SAAS,CAAU;IAEpC,YAAY,OAA+B;QACzC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC;QAC7C,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,UAAU,CAAC;QACrC,IAAI,CAAC,iBAAiB,GAAG,OAAO,CAAC,iBAAiB,CAAC;QACnD,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAC;IACrC,CAAC;IAMD,cAAc,CAAC,YAAoB;QACjC,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,iBAAiB,EAAE,YAAY,CAAC,CAAC;QACnF,OAAO,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC1C,CAAC;IAKO,WAAW,CAAC,SAAiB,EAAE,SAAiB;QACtD,OAAO,wBAAwB,SAAS,IAAI,SAAS,EAAE,CAAC;IAC1D,CAAC;IAKO,gBAAgB,CAAC,SAAiB;QACxC,OAAO,8BAA8B,SAAS,EAAE,CAAC;IACnD,CAAC;IAKD,gBAAgB,CAAC,UAAkB;QACjC,OAAO,GAAG,UAAU,MAAM,CAAC;IAC7B,CAAC;IAMD,KAAK,CAAC,WAAW,CACf,KAAY,EACZ,SAAiB,EACjB,SAAiB,EACjB,KAAY,EACZ,aAAqB,KAAK;QAE1B,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACnD,MAAM,cAAc,GAAG,MAAM,KAAK,CAAC,IAAI,CAAC,GAAG,GAAG,UAAU,CAAC,CAAC;QAC1D,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,YAAY,EAAE,KAAK,CAAC,OAAO,EAAE,IAAI,EAAE,UAAU,CAAC,CAAC;QACrE,MAAM,KAAK,CAAC,MAAM,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;QACpC,OAAO,cAAc,CAAC;IACxB,CAAC;IAKD,KAAK,CAAC,gBAAgB,CACpB,KAAY,EACZ,SAAiB,EACjB,SAAiB;QAEjB,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACnD,MAAM,eAAe,GAAG,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,UAAU,CAAC,CAAC;QAE1D,IAAI,CAAC,eAAe,EAAE,CAAC;YACrB,OAAO,IAAI,CAAC;QACd,CAAC;QAED,MAAM,YAAY,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QAChD,MAAM,kBAAkB,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC;QAE9C,MAAM,SAAS,GAAG,CAAC,MAAM,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,YAAY,CAAC,CAAC,IAAI,SAAS,CAAC;QAErE,OAAO;YACL,YAAY;YACZ,kBAAkB;YAClB,SAAS;SACV,CAAC;IACJ,CAAC;IAKD,KAAK,CAAC,eAAe,CACnB,KAAY,EACZ,SAAiB,EACjB,SAAiB,EACjB,YAAoB;QAEpB,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAClD,MAAM,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,YAAY,CAAC,CAAC;QAChD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC;QAG1C,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,cAAc,EAAE,SAAS,CAAC,CAAC;IACxD,CAAC;IAMD,KAAK,CAAC,gBAAgB,CAAC,KAAY,EAAE,SAAiB;QACpD,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAClD,MAAM,GAAG,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC;QAGvB,MAAM,aAAa,GAAG,MAAM,KAAK,CAAC,aAAa,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,CAAC,CAAC;QAGvE,IAAI,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YAC7B,MAAM,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,aAAa,CAAC,CAAC;QAC/C,CAAC;QAED,OAAO,aAAa,CAAC;IACvB,CAAC;IAKD,WAAW,CAAC,YAAoB;QAC9B,OAAO,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC;IACxC,CAAC;IAKD,KAAK,CAAC,cAAc,CAAC,KAAY,EAAE,SAAiB,EAAE,SAAiB;QACrE,MAAM,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;QACnD,MAAM,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,CAAC;QAElD,MAAM,OAAO,CAAC,GAAG,CAAC;YAChB,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,UAAU,CAAC;YAC3B,KAAK,CAAC,GAAG,CAAC,GAAG,GAAG,YAAY,CAAC;YAC7B,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC;YACd,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,SAAS,CAAC;SAChC,CAAC,CAAC;IACL,CAAC;IAKD,KAAK,CAAC,SAAS,CACb,KAAY,EACZ,aAAqB,EACrB,SAAiB,EACjB,eAA4B,EAC5B,KAAa;QAEb,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,OAAO,SAAS,CAAC;QACnB,CAAC;QAGD,OAAO,CAAC,MAAM,KAAK,CAAC,IAAI,CACtB,aAAa,EACb,GAAG,EACH,WAAW,EACX,SAAS,EACT,OAAO,EACP,KAAK,EACL,SAAS,EACT,IAAI,CAAC,SAAS,CAAC,eAAe,CAAC,EAC/B,WAAW,EACX,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,CACnB,CAAW,CAAC;IACf,CAAC;IAKD,MAAM,CAAC,qBAAqB,CAAC,OAAsB;QACjD,MAAM,cAAc,GAA2B;YAC7C,UAAU,EAAE,CAAC;YACb,cAAc,EAAE,IAAI;YACpB,UAAU,EAAE,KAAK;YACjB,iBAAiB,EAAE,CAAC;YACpB,SAAS,EAAE,IAAI;SAChB,CAAC;QAEF,IAAI,CAAC,OAAO,EAAE,CAAC;YACb,OAAO,cAAc,CAAC;QACxB,CAAC;QAED,OAAO;YACL,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,cAAc,CAAC,UAAU;YAC3D,cAAc,EAAE,OAAO,CAAC,cAAc,IAAI,cAAc,CAAC,cAAc;YACvE,UAAU,EAAE,OAAO,CAAC,UAAU,IAAI,cAAc,CAAC,UAAU;YAC3D,iBAAiB,EAAE,OAAO,CAAC,iBAAiB,IAAI,cAAc,CAAC,iBAAiB;YAChF,SAAS,EAAE,OAAO,CAAC,SAAS,IAAI,cAAc,CAAC,SAAS;SACzD,CAAC;IACJ,CAAC;CACF"}
|
package/dist/core/index.d.ts
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
export { BasePostProcessor } from './base.post-processor.js';
|
|
2
|
-
export { SinglePostProcessor } from './single.post-processor.js';
|
|
3
|
-
export { BatchPostProcessor } from './batch.post-processor.js';
|
|
4
|
-
export { RedisStreamHelper } from './redis-stream.helper.js';
|
|
1
|
+
export { BasePostProcessor } from './processors/base.post-processor.js';
|
|
2
|
+
export { SinglePostProcessor } from './processors/single.post-processor.js';
|
|
3
|
+
export { BatchPostProcessor } from './processors/batch.post-processor.js';
|
|
4
|
+
export { RedisStreamHelper } from './helpers/redis-stream.helper.js';
|
|
5
|
+
export { RetryHelper } from './helpers/retry.helper.js';
|
|
6
|
+
export { CircuitBreaker } from './validators/circuit-breaker.js';
|
|
7
|
+
export { OptionsValidator } from './validators/options-validator.js';
|
|
5
8
|
//# sourceMappingURL=index.d.ts.map
|
package/dist/core/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC"}
|
package/dist/core/index.js
CHANGED
|
@@ -1,5 +1,8 @@
|
|
|
1
|
-
export { BasePostProcessor } from './base.post-processor.js';
|
|
2
|
-
export { SinglePostProcessor } from './single.post-processor.js';
|
|
3
|
-
export { BatchPostProcessor } from './batch.post-processor.js';
|
|
4
|
-
export { RedisStreamHelper } from './redis-stream.helper.js';
|
|
1
|
+
export { BasePostProcessor } from './processors/base.post-processor.js';
|
|
2
|
+
export { SinglePostProcessor } from './processors/single.post-processor.js';
|
|
3
|
+
export { BatchPostProcessor } from './processors/batch.post-processor.js';
|
|
4
|
+
export { RedisStreamHelper } from './helpers/redis-stream.helper.js';
|
|
5
|
+
export { RetryHelper } from './helpers/retry.helper.js';
|
|
6
|
+
export { CircuitBreaker } from './validators/circuit-breaker.js';
|
|
7
|
+
export { OptionsValidator } from './validators/options-validator.js';
|
|
5
8
|
//# sourceMappingURL=index.js.map
|
package/dist/core/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qCAAqC,CAAC;AACxE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAC;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sCAAsC,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,kCAAkC,CAAC;AACrE,OAAO,EAAE,WAAW,EAAE,MAAM,2BAA2B,CAAC;AACxD,OAAO,EAAE,cAAc,EAAE,MAAM,iCAAiC,CAAC;AACjE,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC"}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
import { Logger } from '@volontariapp/logger';
|
|
2
|
+
import type { Redis } from 'ioredis';
|
|
3
|
+
import type { PostProcessorOptions, NormalizedPostProcessorOptions } from '../../interfaces/index.js';
|
|
4
|
+
import type { ParseResult, RedisStreamEntry } from '../../types/index.js';
|
|
5
|
+
import { RetryHelper } from '../helpers/retry.helper.js';
|
|
6
|
+
import { CircuitBreaker } from '../validators/circuit-breaker.js';
|
|
7
|
+
export declare abstract class BasePostProcessor {
|
|
8
|
+
protected readonly redis: Redis;
|
|
9
|
+
protected readonly logger: Logger;
|
|
10
|
+
protected readonly options: NormalizedPostProcessorOptions;
|
|
11
|
+
protected readonly retryHelper: RetryHelper;
|
|
12
|
+
protected readonly circuitBreaker: CircuitBreaker;
|
|
13
|
+
private isRunning;
|
|
14
|
+
private readPending;
|
|
15
|
+
private claimTimeout;
|
|
16
|
+
private retryLoopTimeout;
|
|
17
|
+
private dlqSyncTimeout;
|
|
18
|
+
private loopPromise;
|
|
19
|
+
private currentBatchSize;
|
|
20
|
+
private readonly sigtermHandler;
|
|
21
|
+
private readonly sigintHandler;
|
|
22
|
+
constructor(redis: Redis, options: PostProcessorOptions);
|
|
23
|
+
start(): Promise<void>;
|
|
24
|
+
getCurrentBatchSize(): number;
|
|
25
|
+
getLogger(): Logger;
|
|
26
|
+
stop(): Promise<void>;
|
|
27
|
+
private setupSignalHandlers;
|
|
28
|
+
private cleanupSignalHandlers;
|
|
29
|
+
private handleShutdown;
|
|
30
|
+
protected abstract processEntries(entries: RedisStreamEntry[]): Promise<void>;
|
|
31
|
+
protected shouldProcess(_eventType: string): boolean;
|
|
32
|
+
protected acknowledge(messageId: string): Promise<void>;
|
|
33
|
+
private ensureConsumerGroup;
|
|
34
|
+
private runLoop;
|
|
35
|
+
private processNextCycle;
|
|
36
|
+
private buildXreadgroupArgs;
|
|
37
|
+
private adjustBatchSize;
|
|
38
|
+
private startClaimLoop;
|
|
39
|
+
private claimPendingMessages;
|
|
40
|
+
private claimMessagesList;
|
|
41
|
+
private startRetryLoop;
|
|
42
|
+
private processRetryQueue;
|
|
43
|
+
private startDlqSyncLoop;
|
|
44
|
+
private syncDlqRetention;
|
|
45
|
+
protected sendMessageToDlq(messageId: string, originalPayload: ParseResult, error: string): Promise<void>;
|
|
46
|
+
}
|
|
47
|
+
//# sourceMappingURL=base.post-processor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"base.post-processor.d.ts","sourceRoot":"","sources":["../../../src/core/processors/base.post-processor.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,sBAAsB,CAAC;AAG9C,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AACrC,OAAO,KAAK,EACV,oBAAoB,EACpB,8BAA8B,EAE/B,MAAM,2BAA2B,CAAC;AACnC,OAAO,KAAK,EAAE,WAAW,EAAE,gBAAgB,EAA0B,MAAM,sBAAsB,CAAC;AAElG,OAAO,EAAE,WAAW,EAAE,MAAM,4BAA4B,CAAC;AAGzD,OAAO,EAAE,cAAc,EAAE,MAAM,kCAAkC,CAAC;AAElE,8BAAsB,iBAAiB;IAqBnC,SAAS,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK;IApBjC,SAAS,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC;IAClC,SAAS,CAAC,QAAQ,CAAC,OAAO,EAAE,8BAA8B,CAAC;IAC3D,SAAS,CAAC,QAAQ,CAAC,WAAW,EAAE,WAAW,CAAC;IAC5C,SAAS,CAAC,QAAQ,CAAC,cAAc,EAAE,cAAc,CAAC;IAClD,OAAO,CAAC,SAAS,CAAS;IAC1B,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,YAAY,CAA+B;IACnD,OAAO,CAAC,gBAAgB,CAA+B;IACvD,OAAO,CAAC,cAAc,CAA+B;IACrD,OAAO,CAAC,WAAW,CAA8B;IACjD,OAAO,CAAC,gBAAgB,CAAS;IAEjC,OAAO,CAAC,QAAQ,CAAC,cAAc,CAE7B;IACF,OAAO,CAAC,QAAQ,CAAC,aAAa,CAE5B;gBAGmB,KAAK,EAAE,KAAK,EAC/B,OAAO,EAAE,oBAAoB;IAwCzB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAuC5B,mBAAmB,IAAI,MAAM;IAO7B,SAAS,IAAI,MAAM;IAOb,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAqC3B,OAAO,CAAC,mBAAmB;IAK3B,OAAO,CAAC,qBAAqB;YAKf,cAAc;IAY5B,SAAS,CAAC,QAAQ,CAAC,cAAc,CAAC,OAAO,EAAE,gBAAgB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC;IAM7E,SAAS,CAAC,aAAa,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO;cAOpC,WAAW,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;YAa/C,mBAAmB;YA2BnB,OAAO;YAoBP,gBAAgB;IAmD9B,OAAO,CAAC,mBAAmB;IAiB3B,OAAO,CAAC,eAAe;IAiEvB,OAAO,CAAC,cAAc;YAkBR,oBAAoB;YAqCpB,iBAAiB;IAyB/B,OAAO,CAAC,cAAc;YAkBR,iBAAiB;IA0B/B,OAAO,CAAC,gBAAgB;YAkBV,gBAAgB;cAgCd,gBAAgB,CAC9B,SAAS,EAAE,MAAM,EACjB,eAAe,EAAE,WAAW,EAC5B,KAAK,EAAE,MAAM,GACZ,OAAO,CAAC,IAAI,CAAC;CAkBjB"}
|