@volontariapp/post-processors 1.0.0-snap-856af13 → 1.0.0-snap-fb20f49

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.
Files changed (194) hide show
  1. package/dist/constants/config.default.d.ts +27 -0
  2. package/dist/constants/config.default.d.ts.map +1 -0
  3. package/dist/constants/config.default.js +29 -0
  4. package/dist/constants/config.default.js.map +1 -0
  5. package/dist/constants/index.d.ts +2 -0
  6. package/dist/constants/index.d.ts.map +1 -0
  7. package/dist/constants/index.js +2 -0
  8. package/dist/constants/index.js.map +1 -0
  9. package/dist/core/helpers/index.d.ts +3 -0
  10. package/dist/core/helpers/index.d.ts.map +1 -0
  11. package/dist/core/helpers/index.js +3 -0
  12. package/dist/core/helpers/index.js.map +1 -0
  13. package/dist/core/{redis-stream.helper.d.ts → helpers/redis-stream.helper.d.ts} +2 -2
  14. package/dist/core/helpers/redis-stream.helper.d.ts.map +1 -0
  15. package/dist/core/helpers/redis-stream.helper.js.map +1 -0
  16. package/dist/core/helpers/retry.helper.d.ts +24 -0
  17. package/dist/core/helpers/retry.helper.d.ts.map +1 -0
  18. package/dist/core/helpers/retry.helper.js +104 -0
  19. package/dist/core/helpers/retry.helper.js.map +1 -0
  20. package/dist/core/index.d.ts +7 -4
  21. package/dist/core/index.d.ts.map +1 -1
  22. package/dist/core/index.js +7 -4
  23. package/dist/core/index.js.map +1 -1
  24. package/dist/core/processors/base.post-processor.d.ts +46 -0
  25. package/dist/core/processors/base.post-processor.d.ts.map +1 -0
  26. package/dist/core/processors/base.post-processor.js +422 -0
  27. package/dist/core/processors/base.post-processor.js.map +1 -0
  28. package/dist/core/{batch.post-processor.d.ts → processors/batch.post-processor.d.ts} +3 -2
  29. package/dist/core/processors/batch.post-processor.d.ts.map +1 -0
  30. package/dist/core/{batch.post-processor.js → processors/batch.post-processor.js} +56 -5
  31. package/dist/core/processors/batch.post-processor.js.map +1 -0
  32. package/dist/core/processors/index.d.ts +4 -0
  33. package/dist/core/processors/index.d.ts.map +1 -0
  34. package/dist/core/processors/index.js +4 -0
  35. package/dist/core/processors/index.js.map +1 -0
  36. package/dist/core/{single.post-processor.d.ts → processors/single.post-processor.d.ts} +3 -1
  37. package/dist/core/processors/single.post-processor.d.ts.map +1 -0
  38. package/dist/core/processors/single.post-processor.js +120 -0
  39. package/dist/core/processors/single.post-processor.js.map +1 -0
  40. package/dist/core/validators/circuit-breaker.d.ts +27 -0
  41. package/dist/core/validators/circuit-breaker.d.ts.map +1 -0
  42. package/dist/core/validators/circuit-breaker.js +83 -0
  43. package/dist/core/validators/circuit-breaker.js.map +1 -0
  44. package/dist/core/validators/index.d.ts +2 -0
  45. package/dist/core/validators/index.d.ts.map +1 -0
  46. package/dist/core/validators/index.js +2 -0
  47. package/dist/core/validators/index.js.map +1 -0
  48. package/dist/core/validators/options-validator.d.ts +5 -0
  49. package/dist/core/validators/options-validator.d.ts.map +1 -0
  50. package/dist/core/validators/options-validator.js +90 -0
  51. package/dist/core/validators/options-validator.js.map +1 -0
  52. package/dist/enums/circuit-breaker-state.enum.d.ts +6 -0
  53. package/dist/enums/circuit-breaker-state.enum.d.ts.map +1 -0
  54. package/dist/enums/circuit-breaker-state.enum.js +7 -0
  55. package/dist/enums/circuit-breaker-state.enum.js.map +1 -0
  56. package/dist/enums/index.d.ts +2 -0
  57. package/dist/enums/index.d.ts.map +1 -0
  58. package/dist/enums/index.js +2 -0
  59. package/dist/enums/index.js.map +1 -0
  60. package/dist/index.d.ts +2 -0
  61. package/dist/index.d.ts.map +1 -1
  62. package/dist/index.js +2 -0
  63. package/dist/index.js.map +1 -1
  64. package/dist/interfaces/index.d.ts +7 -3
  65. package/dist/interfaces/index.d.ts.map +1 -1
  66. package/dist/interfaces/{batch-event-item.interface.d.ts → processors/batch-event-item.interface.d.ts} +1 -1
  67. package/dist/interfaces/processors/batch-event-item.interface.d.ts.map +1 -0
  68. package/dist/interfaces/processors/batch-event-item.interface.js.map +1 -0
  69. package/dist/interfaces/processors/normalized-post-processor-options.interface.d.ts +6 -0
  70. package/dist/interfaces/processors/normalized-post-processor-options.interface.d.ts.map +1 -0
  71. package/dist/interfaces/processors/normalized-post-processor-options.interface.js +2 -0
  72. package/dist/interfaces/processors/normalized-post-processor-options.interface.js.map +1 -0
  73. package/dist/interfaces/processors/pending-message-info.interface.d.ts.map +1 -0
  74. package/dist/interfaces/processors/pending-message-info.interface.js.map +1 -0
  75. package/dist/interfaces/processors/post-processor-options.interface.d.ts +21 -0
  76. package/dist/interfaces/processors/post-processor-options.interface.d.ts.map +1 -0
  77. package/dist/interfaces/processors/post-processor-options.interface.js.map +1 -0
  78. package/dist/interfaces/retry/retry-metadata.interface.d.ts +6 -0
  79. package/dist/interfaces/retry/retry-metadata.interface.d.ts.map +1 -0
  80. package/dist/interfaces/retry/retry-metadata.interface.js +2 -0
  81. package/dist/interfaces/retry/retry-metadata.interface.js.map +1 -0
  82. package/dist/interfaces/retry/retry-options.interface.d.ts +8 -0
  83. package/dist/interfaces/retry/retry-options.interface.d.ts.map +1 -0
  84. package/dist/interfaces/retry/retry-options.interface.js +2 -0
  85. package/dist/interfaces/retry/retry-options.interface.js.map +1 -0
  86. package/dist/interfaces/validators/circuit-breaker-config.interface.d.ts +6 -0
  87. package/dist/interfaces/validators/circuit-breaker-config.interface.d.ts.map +1 -0
  88. package/dist/interfaces/validators/circuit-breaker-config.interface.js +2 -0
  89. package/dist/interfaces/validators/circuit-breaker-config.interface.js.map +1 -0
  90. package/dist/test/data-source.d.ts.map +1 -0
  91. package/dist/test/data-source.js.map +1 -0
  92. package/dist/test/migrations/1776783577425-CreateJobsOutbox.d.ts.map +1 -0
  93. package/dist/test/migrations/1776783577425-CreateJobsOutbox.js.map +1 -0
  94. package/dist/test/migrations/1778328780881-InitialSchemaJobAudit.d.ts.map +1 -0
  95. package/dist/test/migrations/1778328780881-InitialSchemaJobAudit.js.map +1 -0
  96. package/dist/test/specs/batch-post-processor/batch-post-processor.int.spec.js +92 -4
  97. package/dist/test/specs/batch-post-processor/batch-post-processor.int.spec.js.map +1 -1
  98. package/dist/test/specs/batch-post-processor/batch-post-processor.unit.spec.js +174 -7
  99. package/dist/test/specs/batch-post-processor/batch-post-processor.unit.spec.js.map +1 -1
  100. package/dist/test/specs/helpers/redis-stream-helper.int.spec.d.ts +2 -0
  101. package/dist/test/specs/helpers/redis-stream-helper.int.spec.d.ts.map +1 -0
  102. package/dist/test/specs/helpers/redis-stream-helper.int.spec.js +56 -0
  103. package/dist/test/specs/helpers/redis-stream-helper.int.spec.js.map +1 -0
  104. package/dist/test/specs/helpers/redis-stream-helper.unit.spec.d.ts +2 -0
  105. package/dist/test/specs/helpers/redis-stream-helper.unit.spec.d.ts.map +1 -0
  106. package/dist/test/specs/helpers/redis-stream-helper.unit.spec.js +102 -0
  107. package/dist/test/specs/helpers/redis-stream-helper.unit.spec.js.map +1 -0
  108. package/dist/test/specs/helpers/retry-helper.int.spec.d.ts +2 -0
  109. package/dist/test/specs/helpers/retry-helper.int.spec.d.ts.map +1 -0
  110. package/dist/test/specs/helpers/retry-helper.int.spec.js +101 -0
  111. package/dist/test/specs/helpers/retry-helper.int.spec.js.map +1 -0
  112. package/dist/test/specs/helpers/retry-helper.unit.spec.d.ts +2 -0
  113. package/dist/test/specs/helpers/retry-helper.unit.spec.d.ts.map +1 -0
  114. package/dist/test/specs/helpers/retry-helper.unit.spec.js +202 -0
  115. package/dist/test/specs/helpers/retry-helper.unit.spec.js.map +1 -0
  116. package/dist/test/specs/integration/circuit-breaker.integration.spec.d.ts +2 -0
  117. package/dist/test/specs/integration/circuit-breaker.integration.spec.d.ts.map +1 -0
  118. package/dist/test/specs/integration/circuit-breaker.integration.spec.js +112 -0
  119. package/dist/test/specs/integration/circuit-breaker.integration.spec.js.map +1 -0
  120. package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.d.ts +2 -0
  121. package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.d.ts.map +1 -0
  122. package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.js +142 -0
  123. package/dist/test/specs/single-post-processor/single-post-processor-retry.int.spec.js.map +1 -0
  124. package/dist/test/specs/single-post-processor/single-post-processor.int.spec.js +49 -7
  125. package/dist/test/specs/single-post-processor/single-post-processor.int.spec.js.map +1 -1
  126. package/dist/test/specs/single-post-processor/single-post-processor.unit.spec.js +110 -22
  127. package/dist/test/specs/single-post-processor/single-post-processor.unit.spec.js.map +1 -1
  128. package/dist/test/specs/validators/options-validator.unit.spec.d.ts +2 -0
  129. package/dist/test/specs/validators/options-validator.unit.spec.d.ts.map +1 -0
  130. package/dist/test/specs/validators/options-validator.unit.spec.js +290 -0
  131. package/dist/test/specs/validators/options-validator.unit.spec.js.map +1 -0
  132. package/dist/test/utils/classes/test-batch-post-processor.class.d.ts +2 -1
  133. package/dist/test/utils/classes/test-batch-post-processor.class.d.ts.map +1 -1
  134. package/dist/test/utils/classes/test-batch-post-processor.class.js +4 -1
  135. package/dist/test/utils/classes/test-batch-post-processor.class.js.map +1 -1
  136. package/dist/test/utils/classes/test-post-processor.class.d.ts +2 -1
  137. package/dist/test/utils/classes/test-post-processor.class.d.ts.map +1 -1
  138. package/dist/test/utils/classes/test-post-processor.class.js +4 -1
  139. package/dist/test/utils/classes/test-post-processor.class.js.map +1 -1
  140. package/dist/test/utils/helpers/wait.helper.d.ts +2 -0
  141. package/dist/test/utils/helpers/wait.helper.d.ts.map +1 -0
  142. package/dist/test/utils/helpers/wait.helper.js +11 -0
  143. package/dist/test/utils/helpers/wait.helper.js.map +1 -0
  144. package/dist/test/utils/index.d.ts +1 -0
  145. package/dist/test/utils/index.d.ts.map +1 -1
  146. package/dist/test/utils/index.js +1 -0
  147. package/dist/test/utils/index.js.map +1 -1
  148. package/dist/test/utils/mocks/redis-call.mock.d.ts.map +1 -1
  149. package/dist/test/utils/mocks/redis-call.mock.js +9 -0
  150. package/dist/test/utils/mocks/redis-call.mock.js.map +1 -1
  151. package/dist/types/index.d.ts +1 -0
  152. package/dist/types/index.d.ts.map +1 -1
  153. package/dist/types/index.js +1 -1
  154. package/dist/types/index.js.map +1 -1
  155. package/dist/types/parse-event.types.d.ts +13 -0
  156. package/dist/types/parse-event.types.d.ts.map +1 -0
  157. package/dist/types/parse-event.types.js +2 -0
  158. package/dist/types/parse-event.types.js.map +1 -0
  159. package/package.json +1 -1
  160. package/dist/core/base.post-processor.d.ts +0 -27
  161. package/dist/core/base.post-processor.d.ts.map +0 -1
  162. package/dist/core/base.post-processor.js +0 -206
  163. package/dist/core/base.post-processor.js.map +0 -1
  164. package/dist/core/batch.post-processor.d.ts.map +0 -1
  165. package/dist/core/batch.post-processor.js.map +0 -1
  166. package/dist/core/redis-stream.helper.d.ts.map +0 -1
  167. package/dist/core/redis-stream.helper.js.map +0 -1
  168. package/dist/core/single.post-processor.d.ts.map +0 -1
  169. package/dist/core/single.post-processor.js +0 -58
  170. package/dist/core/single.post-processor.js.map +0 -1
  171. package/dist/data-source.d.ts.map +0 -1
  172. package/dist/data-source.js.map +0 -1
  173. package/dist/interfaces/batch-event-item.interface.d.ts.map +0 -1
  174. package/dist/interfaces/batch-event-item.interface.js.map +0 -1
  175. package/dist/interfaces/pending-message-info.interface.d.ts.map +0 -1
  176. package/dist/interfaces/pending-message-info.interface.js.map +0 -1
  177. package/dist/interfaces/post-processor-options.interface.d.ts +0 -11
  178. package/dist/interfaces/post-processor-options.interface.d.ts.map +0 -1
  179. package/dist/interfaces/post-processor-options.interface.js.map +0 -1
  180. package/dist/migrations/1776783577425-CreateJobsOutbox.d.ts.map +0 -1
  181. package/dist/migrations/1776783577425-CreateJobsOutbox.js.map +0 -1
  182. package/dist/migrations/1778328780881-InitialSchemaJobAudit.d.ts.map +0 -1
  183. package/dist/migrations/1778328780881-InitialSchemaJobAudit.js.map +0 -1
  184. /package/dist/core/{redis-stream.helper.js → helpers/redis-stream.helper.js} +0 -0
  185. /package/dist/interfaces/{batch-event-item.interface.js → processors/batch-event-item.interface.js} +0 -0
  186. /package/dist/interfaces/{pending-message-info.interface.d.ts → processors/pending-message-info.interface.d.ts} +0 -0
  187. /package/dist/interfaces/{pending-message-info.interface.js → processors/pending-message-info.interface.js} +0 -0
  188. /package/dist/interfaces/{post-processor-options.interface.js → processors/post-processor-options.interface.js} +0 -0
  189. /package/dist/{data-source.d.ts → test/data-source.d.ts} +0 -0
  190. /package/dist/{data-source.js → test/data-source.js} +0 -0
  191. /package/dist/{migrations → test/migrations}/1776783577425-CreateJobsOutbox.d.ts +0 -0
  192. /package/dist/{migrations → test/migrations}/1776783577425-CreateJobsOutbox.js +0 -0
  193. /package/dist/{migrations → test/migrations}/1778328780881-InitialSchemaJobAudit.d.ts +0 -0
  194. /package/dist/{migrations → test/migrations}/1778328780881-InitialSchemaJobAudit.js +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,2 @@
1
+ export * from './config.default.js';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export * from './config.default.js';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,qBAAqB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export * from './redis-stream.helper.js';
2
+ export * from './retry.helper.js';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -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,3 @@
1
+ export * from './redis-stream.helper.js';
2
+ export * from './retry.helper.js';
3
+ //# sourceMappingURL=index.js.map
@@ -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 '../types/index.js';
3
- import type { PendingMessageInfo } from '../interfaces/index.js';
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":"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"}
@@ -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
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC"}
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"}
@@ -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
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/core/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC;AAC7D,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AACjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,iBAAiB,EAAE,MAAM,0BAA0B,CAAC"}
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,46 @@
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
+ stop(): Promise<void>;
26
+ private setupSignalHandlers;
27
+ private cleanupSignalHandlers;
28
+ private handleShutdown;
29
+ protected abstract processEntries(entries: RedisStreamEntry[]): Promise<void>;
30
+ protected shouldProcess(_eventType: string): boolean;
31
+ protected acknowledge(messageId: string): Promise<void>;
32
+ private ensureConsumerGroup;
33
+ private runLoop;
34
+ private processNextCycle;
35
+ private buildXreadgroupArgs;
36
+ private adjustBatchSize;
37
+ private startClaimLoop;
38
+ private claimPendingMessages;
39
+ private claimMessagesList;
40
+ private startRetryLoop;
41
+ private processRetryQueue;
42
+ private startDlqSyncLoop;
43
+ private syncDlqRetention;
44
+ protected sendMessageToDlq(messageId: string, originalPayload: ParseResult, error: string): Promise<void>;
45
+ }
46
+ //# 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;IAOvB,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"}