@schorts/shared-kernel 8.11.0 → 9.0.0-beta.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.
Files changed (210) hide show
  1. package/README.md +0 -1
  2. package/dist/cjs/aggregates/aggregate-root.js +54 -4
  3. package/dist/cjs/aggregates/aggregate-root.js.map +1 -1
  4. package/dist/cjs/auth/exceptions/authentication-error.js +18 -0
  5. package/dist/cjs/auth/exceptions/authentication-error.js.map +1 -0
  6. package/dist/cjs/auth/exceptions/index.js +3 -1
  7. package/dist/cjs/auth/exceptions/index.js.map +1 -1
  8. package/dist/cjs/auth/index.js +0 -3
  9. package/dist/cjs/auth/index.js.map +1 -1
  10. package/dist/cjs/converters/exceptions/conversion-error.js +15 -0
  11. package/dist/cjs/converters/exceptions/conversion-error.js.map +1 -0
  12. package/dist/cjs/converters/exceptions/index.js +6 -0
  13. package/dist/cjs/converters/exceptions/index.js.map +1 -0
  14. package/dist/cjs/converters/index.js +15 -0
  15. package/dist/cjs/converters/index.js.map +1 -1
  16. package/dist/cjs/converters/remote-file-to-base64.js +109 -4
  17. package/dist/cjs/converters/remote-file-to-base64.js.map +1 -1
  18. package/dist/cjs/cqrs/command-handler.js +108 -0
  19. package/dist/cjs/cqrs/command-handler.js.map +1 -1
  20. package/dist/cjs/cqrs/command-metadata.js +3 -0
  21. package/dist/cjs/cqrs/command-metadata.js.map +1 -0
  22. package/dist/cjs/cqrs/command.js +63 -0
  23. package/dist/cjs/cqrs/command.js.map +1 -1
  24. package/dist/cjs/cqrs/exceptions/command-handler-errors.js +66 -0
  25. package/dist/cjs/cqrs/exceptions/command-handler-errors.js.map +1 -0
  26. package/dist/cjs/cqrs/exceptions/index.js +11 -1
  27. package/dist/cjs/cqrs/exceptions/index.js.map +1 -1
  28. package/dist/cjs/cqrs/exceptions/query-handler-errors.js +37 -0
  29. package/dist/cjs/cqrs/exceptions/query-handler-errors.js.map +1 -0
  30. package/dist/cjs/cqrs/in-memory/async/async-in-memory-command-bus.js +94 -1
  31. package/dist/cjs/cqrs/in-memory/async/async-in-memory-command-bus.js.map +1 -1
  32. package/dist/cjs/cqrs/in-memory/async/async-in-memory-query-bus.js +89 -3
  33. package/dist/cjs/cqrs/in-memory/async/async-in-memory-query-bus.js.map +1 -1
  34. package/dist/cjs/cqrs/in-memory/sync/sync-in-memory-command-bus.js +96 -3
  35. package/dist/cjs/cqrs/in-memory/sync/sync-in-memory-command-bus.js.map +1 -1
  36. package/dist/cjs/cqrs/in-memory/sync/sync-in-memory-query-bus.js +89 -3
  37. package/dist/cjs/cqrs/in-memory/sync/sync-in-memory-query-bus.js.map +1 -1
  38. package/dist/cjs/cqrs/index.js +9 -2
  39. package/dist/cjs/cqrs/index.js.map +1 -1
  40. package/dist/cjs/cqrs/query-handler.js +98 -0
  41. package/dist/cjs/cqrs/query-handler.js.map +1 -1
  42. package/dist/cjs/cqrs/query-metadata.js +3 -0
  43. package/dist/cjs/cqrs/query-metadata.js.map +1 -0
  44. package/dist/cjs/cqrs/query.js +63 -0
  45. package/dist/cjs/cqrs/query.js.map +1 -1
  46. package/dist/cjs/event-bus/in-memory/async/async-in-memory-event-bus.js +16 -8
  47. package/dist/cjs/event-bus/in-memory/async/async-in-memory-event-bus.js.map +1 -1
  48. package/dist/cjs/event-bus/in-memory/async/async-in-memory-event-store.js +6 -0
  49. package/dist/cjs/event-bus/in-memory/async/async-in-memory-event-store.js.map +1 -1
  50. package/dist/cjs/event-bus/in-memory/sync/sync-in-memory-event-bus.js +16 -8
  51. package/dist/cjs/event-bus/in-memory/sync/sync-in-memory-event-bus.js.map +1 -1
  52. package/dist/cjs/event-bus/in-memory/sync/sync-in-memory-event-store.js +6 -0
  53. package/dist/cjs/event-bus/in-memory/sync/sync-in-memory-event-store.js.map +1 -1
  54. package/dist/cjs/index.js +1 -0
  55. package/dist/cjs/index.js.map +1 -1
  56. package/dist/cjs/sagas/in-memory-saga-state-store.js +20 -0
  57. package/dist/cjs/sagas/in-memory-saga-state-store.js.map +1 -0
  58. package/dist/cjs/sagas/index.js +10 -0
  59. package/dist/cjs/sagas/index.js.map +1 -0
  60. package/dist/cjs/sagas/saga-manager.js +16 -0
  61. package/dist/cjs/sagas/saga-manager.js.map +1 -0
  62. package/dist/cjs/sagas/saga-state-store.js +3 -0
  63. package/dist/cjs/sagas/saga-state-store.js.map +1 -0
  64. package/dist/cjs/sagas/saga.js +88 -0
  65. package/dist/cjs/sagas/saga.js.map +1 -0
  66. package/dist/esm/aggregates/aggregate-root.js +54 -4
  67. package/dist/esm/aggregates/aggregate-root.js.map +1 -1
  68. package/dist/esm/auth/exceptions/authentication-error.js +18 -0
  69. package/dist/esm/auth/exceptions/authentication-error.js.map +1 -0
  70. package/dist/esm/auth/exceptions/index.js +3 -1
  71. package/dist/esm/auth/exceptions/index.js.map +1 -1
  72. package/dist/esm/auth/index.js +0 -3
  73. package/dist/esm/auth/index.js.map +1 -1
  74. package/dist/esm/converters/exceptions/conversion-error.js +15 -0
  75. package/dist/esm/converters/exceptions/conversion-error.js.map +1 -0
  76. package/dist/esm/converters/exceptions/index.js +6 -0
  77. package/dist/esm/converters/exceptions/index.js.map +1 -0
  78. package/dist/esm/converters/index.js +15 -0
  79. package/dist/esm/converters/index.js.map +1 -1
  80. package/dist/esm/converters/remote-file-to-base64.js +109 -4
  81. package/dist/esm/converters/remote-file-to-base64.js.map +1 -1
  82. package/dist/esm/cqrs/command-handler.js +108 -0
  83. package/dist/esm/cqrs/command-handler.js.map +1 -1
  84. package/dist/esm/cqrs/command-metadata.js +3 -0
  85. package/dist/esm/cqrs/command-metadata.js.map +1 -0
  86. package/dist/esm/cqrs/command.js +63 -0
  87. package/dist/esm/cqrs/command.js.map +1 -1
  88. package/dist/esm/cqrs/exceptions/command-handler-errors.js +66 -0
  89. package/dist/esm/cqrs/exceptions/command-handler-errors.js.map +1 -0
  90. package/dist/esm/cqrs/exceptions/index.js +11 -1
  91. package/dist/esm/cqrs/exceptions/index.js.map +1 -1
  92. package/dist/esm/cqrs/exceptions/query-handler-errors.js +37 -0
  93. package/dist/esm/cqrs/exceptions/query-handler-errors.js.map +1 -0
  94. package/dist/esm/cqrs/in-memory/async/async-in-memory-command-bus.js +94 -1
  95. package/dist/esm/cqrs/in-memory/async/async-in-memory-command-bus.js.map +1 -1
  96. package/dist/esm/cqrs/in-memory/async/async-in-memory-query-bus.js +89 -3
  97. package/dist/esm/cqrs/in-memory/async/async-in-memory-query-bus.js.map +1 -1
  98. package/dist/esm/cqrs/in-memory/sync/sync-in-memory-command-bus.js +96 -3
  99. package/dist/esm/cqrs/in-memory/sync/sync-in-memory-command-bus.js.map +1 -1
  100. package/dist/esm/cqrs/in-memory/sync/sync-in-memory-query-bus.js +89 -3
  101. package/dist/esm/cqrs/in-memory/sync/sync-in-memory-query-bus.js.map +1 -1
  102. package/dist/esm/cqrs/index.js +9 -2
  103. package/dist/esm/cqrs/index.js.map +1 -1
  104. package/dist/esm/cqrs/query-handler.js +98 -0
  105. package/dist/esm/cqrs/query-handler.js.map +1 -1
  106. package/dist/esm/cqrs/query-metadata.js +3 -0
  107. package/dist/esm/cqrs/query-metadata.js.map +1 -0
  108. package/dist/esm/cqrs/query.js +63 -0
  109. package/dist/esm/cqrs/query.js.map +1 -1
  110. package/dist/esm/event-bus/in-memory/async/async-in-memory-event-bus.js +16 -8
  111. package/dist/esm/event-bus/in-memory/async/async-in-memory-event-bus.js.map +1 -1
  112. package/dist/esm/event-bus/in-memory/async/async-in-memory-event-store.js +6 -0
  113. package/dist/esm/event-bus/in-memory/async/async-in-memory-event-store.js.map +1 -1
  114. package/dist/esm/event-bus/in-memory/sync/sync-in-memory-event-bus.js +16 -8
  115. package/dist/esm/event-bus/in-memory/sync/sync-in-memory-event-bus.js.map +1 -1
  116. package/dist/esm/event-bus/in-memory/sync/sync-in-memory-event-store.js +6 -0
  117. package/dist/esm/event-bus/in-memory/sync/sync-in-memory-event-store.js.map +1 -1
  118. package/dist/esm/index.js +1 -0
  119. package/dist/esm/index.js.map +1 -1
  120. package/dist/esm/sagas/in-memory-saga-state-store.js +20 -0
  121. package/dist/esm/sagas/in-memory-saga-state-store.js.map +1 -0
  122. package/dist/esm/sagas/index.js +10 -0
  123. package/dist/esm/sagas/index.js.map +1 -0
  124. package/dist/esm/sagas/saga-manager.js +16 -0
  125. package/dist/esm/sagas/saga-manager.js.map +1 -0
  126. package/dist/esm/sagas/saga-state-store.js +3 -0
  127. package/dist/esm/sagas/saga-state-store.js.map +1 -0
  128. package/dist/esm/sagas/saga.js +88 -0
  129. package/dist/esm/sagas/saga.js.map +1 -0
  130. package/dist/types/abac/index.d.ts +1 -1
  131. package/dist/types/abac/index.d.ts.map +1 -1
  132. package/dist/types/abac/predicate.d.ts +10 -0
  133. package/dist/types/abac/predicate.d.ts.map +1 -1
  134. package/dist/types/aggregates/aggregate-root.d.ts +28 -3
  135. package/dist/types/aggregates/aggregate-root.d.ts.map +1 -1
  136. package/dist/types/auth/auth-provider.d.ts +28 -2
  137. package/dist/types/auth/auth-provider.d.ts.map +1 -1
  138. package/dist/types/auth/exceptions/authentication-error.d.ts +9 -0
  139. package/dist/types/auth/exceptions/authentication-error.d.ts.map +1 -0
  140. package/dist/types/auth/exceptions/index.d.ts +1 -0
  141. package/dist/types/auth/exceptions/index.d.ts.map +1 -1
  142. package/dist/types/auth/index.d.ts +1 -2
  143. package/dist/types/auth/index.d.ts.map +1 -1
  144. package/dist/types/converters/exceptions/conversion-error.d.ts +6 -0
  145. package/dist/types/converters/exceptions/conversion-error.d.ts.map +1 -0
  146. package/dist/types/converters/exceptions/index.d.ts +2 -0
  147. package/dist/types/converters/exceptions/index.d.ts.map +1 -0
  148. package/dist/types/converters/index.d.ts +2 -0
  149. package/dist/types/converters/index.d.ts.map +1 -1
  150. package/dist/types/converters/remote-file-to-base64.d.ts +21 -1
  151. package/dist/types/converters/remote-file-to-base64.d.ts.map +1 -1
  152. package/dist/types/cqrs/command-bus.d.ts +32 -0
  153. package/dist/types/cqrs/command-bus.d.ts.map +1 -1
  154. package/dist/types/cqrs/command-handler.d.ts +37 -1
  155. package/dist/types/cqrs/command-handler.d.ts.map +1 -1
  156. package/dist/types/cqrs/command-metadata.d.ts +27 -0
  157. package/dist/types/cqrs/command-metadata.d.ts.map +1 -0
  158. package/dist/types/cqrs/command.d.ts +16 -0
  159. package/dist/types/cqrs/command.d.ts.map +1 -1
  160. package/dist/types/cqrs/exceptions/command-handler-errors.d.ts +27 -0
  161. package/dist/types/cqrs/exceptions/command-handler-errors.d.ts.map +1 -0
  162. package/dist/types/cqrs/exceptions/index.d.ts +2 -0
  163. package/dist/types/cqrs/exceptions/index.d.ts.map +1 -1
  164. package/dist/types/cqrs/exceptions/query-handler-errors.d.ts +16 -0
  165. package/dist/types/cqrs/exceptions/query-handler-errors.d.ts.map +1 -0
  166. package/dist/types/cqrs/in-memory/async/async-in-memory-command-bus.d.ts +12 -1
  167. package/dist/types/cqrs/in-memory/async/async-in-memory-command-bus.d.ts.map +1 -1
  168. package/dist/types/cqrs/in-memory/async/async-in-memory-query-bus.d.ts +12 -1
  169. package/dist/types/cqrs/in-memory/async/async-in-memory-query-bus.d.ts.map +1 -1
  170. package/dist/types/cqrs/in-memory/sync/sync-in-memory-command-bus.d.ts +12 -1
  171. package/dist/types/cqrs/in-memory/sync/sync-in-memory-command-bus.d.ts.map +1 -1
  172. package/dist/types/cqrs/in-memory/sync/sync-in-memory-query-bus.d.ts +12 -1
  173. package/dist/types/cqrs/in-memory/sync/sync-in-memory-query-bus.d.ts.map +1 -1
  174. package/dist/types/cqrs/index.d.ts +14 -6
  175. package/dist/types/cqrs/index.d.ts.map +1 -1
  176. package/dist/types/cqrs/query-bus.d.ts +29 -0
  177. package/dist/types/cqrs/query-bus.d.ts.map +1 -1
  178. package/dist/types/cqrs/query-handler.d.ts +36 -1
  179. package/dist/types/cqrs/query-handler.d.ts.map +1 -1
  180. package/dist/types/cqrs/query-metadata.d.ts +27 -0
  181. package/dist/types/cqrs/query-metadata.d.ts.map +1 -0
  182. package/dist/types/cqrs/query.d.ts +16 -0
  183. package/dist/types/cqrs/query.d.ts.map +1 -1
  184. package/dist/types/event-bus/event-store.d.ts +1 -0
  185. package/dist/types/event-bus/event-store.d.ts.map +1 -1
  186. package/dist/types/event-bus/in-memory/async/async-in-memory-event-bus.d.ts.map +1 -1
  187. package/dist/types/event-bus/in-memory/async/async-in-memory-event-store.d.ts +2 -0
  188. package/dist/types/event-bus/in-memory/async/async-in-memory-event-store.d.ts.map +1 -1
  189. package/dist/types/event-bus/in-memory/sync/sync-in-memory-event-bus.d.ts.map +1 -1
  190. package/dist/types/event-bus/in-memory/sync/sync-in-memory-event-store.d.ts +2 -0
  191. package/dist/types/event-bus/in-memory/sync/sync-in-memory-event-store.d.ts.map +1 -1
  192. package/dist/types/index.d.ts +1 -0
  193. package/dist/types/index.d.ts.map +1 -1
  194. package/dist/types/sagas/in-memory-saga-state-store.d.ts +12 -0
  195. package/dist/types/sagas/in-memory-saga-state-store.d.ts.map +1 -0
  196. package/dist/types/sagas/index.d.ts +6 -0
  197. package/dist/types/sagas/index.d.ts.map +1 -0
  198. package/dist/types/sagas/saga-manager.d.ts +8 -0
  199. package/dist/types/sagas/saga-manager.d.ts.map +1 -0
  200. package/dist/types/sagas/saga-state-store.d.ts +18 -0
  201. package/dist/types/sagas/saga-state-store.d.ts.map +1 -0
  202. package/dist/types/sagas/saga.d.ts +31 -0
  203. package/dist/types/sagas/saga.d.ts.map +1 -0
  204. package/package.json +6 -1
  205. package/dist/cjs/auth/require-auth.decorator.js +0 -36
  206. package/dist/cjs/auth/require-auth.decorator.js.map +0 -1
  207. package/dist/esm/auth/require-auth.decorator.js +0 -36
  208. package/dist/esm/auth/require-auth.decorator.js.map +0 -1
  209. package/dist/types/auth/require-auth.decorator.d.ts +0 -7
  210. package/dist/types/auth/require-auth.decorator.d.ts.map +0 -1
@@ -1,3 +1,101 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractQueryHandler = void 0;
4
+ const exceptions_1 = require("./exceptions");
5
+ class AbstractQueryHandler {
6
+ options;
7
+ constructor(options = {}) {
8
+ this.options = {
9
+ cache: false,
10
+ cacheTtl: 5 * 60 * 1000,
11
+ logging: false,
12
+ metrics: false,
13
+ ...options,
14
+ };
15
+ }
16
+ async handle(query, context) {
17
+ const startTime = new Date();
18
+ const correlationId = query.getMetadata().correlationId;
19
+ const handlerContext = {
20
+ metadata: query.getMetadata.bind(query),
21
+ options: this.options,
22
+ startTime,
23
+ correlationId,
24
+ ...context,
25
+ };
26
+ try {
27
+ await this.validate(query);
28
+ await this.authorize(query);
29
+ if (this.options.cache) {
30
+ const cacheKey = this.getCacheKey?.(query);
31
+ if (cacheKey) {
32
+ // TODO: Implement cache lookup
33
+ }
34
+ }
35
+ const result = await this.execute(query, handlerContext);
36
+ if (this.options.cache && this.shouldCache?.(query, result)) {
37
+ const cacheKey = this.getCacheKey?.(query);
38
+ if (cacheKey) {
39
+ // TODO: Implement cache storage
40
+ }
41
+ }
42
+ if (this.options.logging) {
43
+ this.logQuery(query, result, startTime);
44
+ }
45
+ return result;
46
+ }
47
+ catch (error) {
48
+ if (this.options.logging) {
49
+ this.logError(query, error, startTime);
50
+ }
51
+ if (error instanceof exceptions_1.QueryValidationError ||
52
+ error instanceof exceptions_1.QueryAuthorizationError ||
53
+ error instanceof exceptions_1.QueryExecutionError) {
54
+ throw error;
55
+ }
56
+ throw new exceptions_1.QueryExecutionError(`Query execution failed: ${error instanceof Error ? error.message : String(error)}`, "QUERY_EXECUTION_FAILED", { originalError: error });
57
+ }
58
+ }
59
+ getOptions() {
60
+ return this.options;
61
+ }
62
+ async validate(_) { }
63
+ async authorize(_) { }
64
+ getCacheKey(query) {
65
+ return `${query.getType()}:${JSON.stringify(query.toPrimitives?.() ?? {})}`;
66
+ }
67
+ shouldCache(_, __) {
68
+ return true;
69
+ }
70
+ logQuery(query, result, startTime) {
71
+ const duration = Date.now() - startTime.getTime();
72
+ console.log(`[QueryHandler] ${query.getType()} completed in ${duration}ms`, {
73
+ correlationId: query.getMetadata().correlationId,
74
+ userId: query.getMetadata().userId,
75
+ resultSize: this.getResultSize(result),
76
+ });
77
+ }
78
+ logError(query, error, startTime) {
79
+ const duration = Date.now() - startTime.getTime();
80
+ console.error(`[QueryHandler] ${query.getType()} failed after ${duration}ms`, {
81
+ correlationId: query.getMetadata().correlationId,
82
+ userId: query.getMetadata().userId,
83
+ error: error instanceof Error ? error.message : String(error),
84
+ });
85
+ }
86
+ getResultSize(result) {
87
+ try {
88
+ const size = JSON.stringify(result).length;
89
+ if (size < 1024)
90
+ return `${size} bytes`;
91
+ if (size < 1024 * 1024)
92
+ return `${Math.round(size / 1024)} KB`;
93
+ return `${Math.round(size / (1024 * 1024))} MB`;
94
+ }
95
+ catch {
96
+ return "unknown";
97
+ }
98
+ }
99
+ }
100
+ exports.AbstractQueryHandler = AbstractQueryHandler;
3
101
  //# sourceMappingURL=query-handler.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"query-handler.js","sourceRoot":"","sources":["../../../src/cqrs/query-handler.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"query-handler.js","sourceRoot":"","sources":["../../../src/cqrs/query-handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=query-metadata.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"query-metadata.js","sourceRoot":"","sources":["../../../src/cqrs/query-metadata.ts"],"names":[],"mappings":""}
@@ -1,3 +1,66 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AbstractQuery = void 0;
4
+ class AbstractQuery {
5
+ metadata;
6
+ constructor(correlationId, customMetadata) {
7
+ const generateId = () => `${Date.now()}-${Math.random().toString(36).substr(2, 9)}`;
8
+ this.metadata = {
9
+ id: customMetadata?.id ?? generateId(),
10
+ createdAt: customMetadata?.createdAt ?? new Date(),
11
+ correlationId: customMetadata?.correlationId ?? correlationId,
12
+ causationId: customMetadata?.causationId,
13
+ requestId: customMetadata?.requestId,
14
+ version: customMetadata?.version ?? 1,
15
+ userId: customMetadata?.userId,
16
+ tenantId: customMetadata?.tenantId,
17
+ headers: customMetadata?.headers,
18
+ context: customMetadata?.context,
19
+ };
20
+ }
21
+ getMetadata() {
22
+ return this.metadata;
23
+ }
24
+ toPrimitives() {
25
+ return {
26
+ id: this.metadata.id,
27
+ type: this.getType(),
28
+ created_at: this.metadata.createdAt.toISOString(),
29
+ correlation_id: this.metadata.correlationId,
30
+ causation_id: this.metadata.causationId,
31
+ request_id: this.metadata.requestId,
32
+ version: this.metadata.version,
33
+ user_id: this.metadata.userId,
34
+ tenant_id: this.metadata.tenantId,
35
+ payload: {},
36
+ headers: this.metadata.headers,
37
+ context: this.metadata.context,
38
+ };
39
+ }
40
+ setCorrelationId(correlationId) {
41
+ this.metadata.correlationId = correlationId;
42
+ }
43
+ setCausationId(causationId) {
44
+ this.metadata.causationId = causationId;
45
+ }
46
+ setUserId(userId) {
47
+ this.metadata.userId = userId;
48
+ }
49
+ setTenantId(tenantId) {
50
+ this.metadata.tenantId = tenantId;
51
+ }
52
+ addHeaders(headers) {
53
+ this.metadata.headers = {
54
+ ...(this.metadata.headers ?? {}),
55
+ ...headers,
56
+ };
57
+ }
58
+ addContext(key, value) {
59
+ this.metadata.context = {
60
+ ...(this.metadata.context ?? {}),
61
+ [key]: value,
62
+ };
63
+ }
64
+ }
65
+ exports.AbstractQuery = AbstractQuery;
3
66
  //# sourceMappingURL=query.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/cqrs/query.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"query.js","sourceRoot":"","sources":["../../../src/cqrs/query.ts"],"names":[],"mappings":";;;AAUA,MAAsB,aAAa;IACd,QAAQ,CAAgB;IAE3C,YAAY,aAAqB,EAAE,cAAuC;QACxE,MAAM,UAAU,GAAG,GAAG,EAAE,CACtB,GAAG,IAAI,CAAC,GAAG,EAAE,IAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC;QAE7D,IAAI,CAAC,QAAQ,GAAG;YACd,EAAE,EAAE,cAAc,EAAE,EAAE,IAAI,UAAU,EAAE;YACtC,SAAS,EAAE,cAAc,EAAE,SAAS,IAAI,IAAI,IAAI,EAAE;YAClD,aAAa,EACX,cAAc,EAAE,aAAa,IAAI,aAAa;YAChD,WAAW,EAAE,cAAc,EAAE,WAAW;YACxC,SAAS,EAAE,cAAc,EAAE,SAAS;YACpC,OAAO,EAAE,cAAc,EAAE,OAAO,IAAI,CAAC;YACrC,MAAM,EAAE,cAAc,EAAE,MAAM;YAC9B,QAAQ,EAAE,cAAc,EAAE,QAAQ;YAClC,OAAO,EAAE,cAAc,EAAE,OAAO;YAChC,OAAO,EAAE,cAAc,EAAE,OAAO;SACjC,CAAC;IACJ,CAAC;IAID,WAAW;QACT,OAAO,IAAI,CAAC,QAAQ,CAAC;IACvB,CAAC;IAED,YAAY;QACV,OAAO;YACL,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE;YACpB,IAAI,EAAE,IAAI,CAAC,OAAO,EAAE;YACpB,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,WAAW,EAAE;YACjD,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,aAAa;YAC3C,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,WAAW;YACvC,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,SAAS;YACnC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO;YAC9B,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM;YAC7B,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ;YACjC,OAAO,EAAE,EAAE;YACX,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO;YAC9B,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,OAAO;SAC/B,CAAC;IACJ,CAAC;IAED,gBAAgB,CAAC,aAAqB;QACnC,IAAI,CAAC,QAAgB,CAAC,aAAa,GAAG,aAAa,CAAC;IACvD,CAAC;IAED,cAAc,CAAC,WAAmB;QAC/B,IAAI,CAAC,QAAgB,CAAC,WAAW,GAAG,WAAW,CAAC;IACnD,CAAC;IAED,SAAS,CAAC,MAAc;QACrB,IAAI,CAAC,QAAgB,CAAC,MAAM,GAAG,MAAM,CAAC;IACzC,CAAC;IAED,WAAW,CAAC,QAAgB;QACzB,IAAI,CAAC,QAAgB,CAAC,QAAQ,GAAG,QAAQ,CAAC;IAC7C,CAAC;IAED,UAAU,CAAC,OAA+B;QACxC,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG;YACtB,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC;YAChC,GAAG,OAAO;SACX,CAAC;IACJ,CAAC;IAED,UAAU,CAAC,GAAW,EAAE,KAAU;QAChC,IAAI,CAAC,QAAQ,CAAC,OAAO,GAAG;YACtB,GAAG,CAAC,IAAI,CAAC,QAAQ,CAAC,OAAO,IAAI,EAAE,CAAC;YAChC,CAAC,GAAG,CAAC,EAAE,KAAK;SACb,CAAC;IACJ,CAAC;CACF;AA1ED,sCA0EC"}
@@ -28,28 +28,36 @@ class AsyncInMemoryEventBus {
28
28
  const eventName = event.getEventName();
29
29
  const subs = this.subscribers.get(eventName) ?? [];
30
30
  const primitives = event.toPrimitives();
31
- event.ack = () => this.store.delete(event.id);
32
- event.requeue = (error) => {
33
- event.ack?.();
34
- if (event.meta.retries < this.maxRetries) {
31
+ if (await this.store.isProcessed(event.id)) {
32
+ return;
33
+ }
34
+ const retrySubscriber = async (failedEvent, subscriber, error) => {
35
+ failedEvent.ack?.();
36
+ if (failedEvent.meta.retries < this.maxRetries) {
35
37
  const updatedPrimitives = {
36
38
  ...primitives,
37
- meta: { ...primitives.meta, retries: event.meta.retries + 1 },
39
+ meta: { ...failedEvent.meta, retries: failedEvent.meta.retries + 1 },
38
40
  };
39
41
  this.store.requeue(updatedPrimitives);
40
- this.publish(domain_events_1.DomainEventRegistry.create(updatedPrimitives));
42
+ const retryEvent = domain_events_1.DomainEventRegistry.create(updatedPrimitives);
43
+ await executeSubscriber(subscriber, retryEvent);
41
44
  }
42
45
  else if (this.deadLetterStore) {
43
46
  const reason = error ? error.message : `Exceeded max retries (${this.maxRetries})`;
44
47
  this.deadLetterStore.add(primitives, reason);
45
48
  }
46
49
  };
50
+ const executeSubscriber = async (subscriber, currentEvent) => {
51
+ currentEvent.ack = () => this.store.delete(currentEvent.id);
52
+ currentEvent.requeue = (error) => retrySubscriber(currentEvent, subscriber, error);
53
+ await subscriber.handle(currentEvent);
54
+ };
47
55
  for (const sub of subs) {
48
56
  try {
49
- await sub.handle(event);
57
+ await executeSubscriber(sub, event);
50
58
  }
51
59
  catch (err) {
52
- event.requeue?.(err);
60
+ await retrySubscriber(event, sub, err);
53
61
  }
54
62
  }
55
63
  }
@@ -1 +1 @@
1
- {"version":3,"file":"async-in-memory-event-bus.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/async/async-in-memory-event-bus.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"async-in-memory-event-bus.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/async/async-in-memory-event-bus.ts"],"names":[],"mappings":";;;AAAA,0DAA0E;AAC1E,+EAAwE;AAMxE,MAAa,qBAAqB;IACf,WAAW,GAAG,IAAI,GAAG,EAA6B,CAAC;IACnD,KAAK,CAAmB;IACxB,UAAU,CAAS;IACnB,eAAe,CAA8B;IAE9D,YACE,QAA0B,IAAI,qDAAuB,EAAE,EACvD,UAAU,GAAG,CAAC,EACd,eAAiC;QAEjC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QACnB,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;QAC7B,IAAI,CAAC,eAAe,GAAG,eAAe,CAAC;IACzC,CAAC;IAED,SAAS,CAA4B,SAAiB,EAAE,UAAkC;QACxF,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,EAAE,CAAC;YACrC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,EAAE,EAAE,CAAC,CAAC;QACtC,CAAC;QAED,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAE,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IACpD,CAAC;IAED,KAAK,CAAC,OAAO,CAA4B,KAAY;QACnD,MAAM,UAAU,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;QAExC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAE5B,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAEO,KAAK,CAAC,QAAQ,CAAC,KAAkB;QACvC,MAAM,SAAS,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;QACvC,MAAM,IAAI,GAAG,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACnD,MAAM,UAAU,GAAG,KAAK,CAAC,YAAY,EAAE,CAAC;QAExC,IAAI,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC;YAC3C,OAAO;QACT,CAAC;QAED,MAAM,eAAe,GAAG,KAAK,EAAE,WAAwB,EAAE,UAA2B,EAAE,KAAa,EAAE,EAAE;YACrG,WAAW,CAAC,GAAG,EAAE,EAAE,CAAC;YAEpB,IAAI,WAAW,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBAC/C,MAAM,iBAAiB,GAAG;oBACxB,GAAG,UAAU;oBACb,IAAI,EAAE,EAAE,GAAG,WAAW,CAAC,IAAI,EAAE,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,OAAO,GAAG,CAAC,EAAE;iBACrE,CAAC;gBAEF,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,iBAAiB,CAAC,CAAC;gBAEtC,MAAM,UAAU,GAAG,mCAAmB,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;gBACjE,MAAM,iBAAiB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;YAClD,CAAC;iBAAM,IAAI,IAAI,CAAC,eAAe,EAAE,CAAC;gBAChC,MAAM,MAAM,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,yBAAyB,IAAI,CAAC,UAAU,GAAG,CAAC;gBAEnF,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;YAC/C,CAAC;QACH,CAAC,CAAC;QAEF,MAAM,iBAAiB,GAAG,KAAK,EAAE,UAA2B,EAAE,YAAyB,EAAE,EAAE;YACzF,YAAY,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;YAC5D,YAAY,CAAC,OAAO,GAAG,CAAC,KAAa,EAAE,EAAE,CAAC,eAAe,CAAC,YAAY,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;YAE3F,MAAM,UAAU,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACxC,CAAC,CAAC;QAEF,KAAK,MAAM,GAAG,IAAI,IAAI,EAAE,CAAC;YACvB,IAAI,CAAC;gBACH,MAAM,iBAAiB,CAAC,GAAG,EAAE,KAAK,CAAC,CAAC;YACtC,CAAC;YAAC,OAAO,GAAG,EAAE,CAAC;gBACb,MAAM,eAAe,CAAC,KAAK,EAAE,GAAG,EAAE,GAAY,CAAC,CAAC;YAClD,CAAC;QACH,CAAC;IACH,CAAC;IAED,KAAK,CAAC,MAAM;QACV,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC;QAEtC,KAAK,MAAM,UAAU,IAAI,MAAM,EAAE,CAAC;YAChC,MAAM,KAAK,GAAG,mCAAmB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;YAErD,MAAM,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;CACF;AAtFD,sDAsFC"}
@@ -3,8 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.AsyncInMemoryEventStore = void 0;
4
4
  class AsyncInMemoryEventStore {
5
5
  events = [];
6
+ processedEventIds = new Set();
6
7
  async save(primitives) {
7
8
  this.events.push(primitives);
9
+ this.processedEventIds.add(primitives.id);
8
10
  }
9
11
  async all() {
10
12
  return [...this.events];
@@ -19,6 +21,10 @@ class AsyncInMemoryEventStore {
19
21
  }
20
22
  async clear() {
21
23
  this.events.length = 0;
24
+ this.processedEventIds.clear();
25
+ }
26
+ async isProcessed(id) {
27
+ return this.processedEventIds.has(id);
22
28
  }
23
29
  }
24
30
  exports.AsyncInMemoryEventStore = AsyncInMemoryEventStore;
@@ -1 +1 @@
1
- {"version":3,"file":"async-in-memory-event-store.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/async/async-in-memory-event-store.ts"],"names":[],"mappings":";;;AAGA,MAAa,uBAAuB;IACjB,MAAM,GAA4B,EAAE,CAAC;IAEtD,KAAK,CAAC,IAAI,CAAC,UAAiC;QAC1C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,GAAG;QACP,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAU;QACrB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAEtD,IAAI,KAAK,KAAK,CAAC,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,UAAiC;QAC7C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;IACzB,CAAC;CACF;AAxBD,0DAwBC"}
1
+ {"version":3,"file":"async-in-memory-event-store.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/async/async-in-memory-event-store.ts"],"names":[],"mappings":";;;AAGA,MAAa,uBAAuB;IACjB,MAAM,GAA4B,EAAE,CAAC;IACrC,iBAAiB,GAAG,IAAI,GAAG,EAAU,CAAC;IAEvD,KAAK,CAAC,IAAI,CAAC,UAAiC;QAC1C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,KAAK,CAAC,GAAG;QACP,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,EAAU;QACrB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAEtD,IAAI,KAAK,KAAK,CAAC,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,KAAK,CAAC,OAAO,CAAC,UAAiC;QAC7C,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,WAAW,CAAC,EAAU;QAC1B,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACxC,CAAC;CACF;AA/BD,0DA+BC"}
@@ -28,28 +28,36 @@ class SyncInMemoryEventBus {
28
28
  const eventName = event.getEventName();
29
29
  const subs = this.subscribers.get(eventName) ?? [];
30
30
  const primitives = event.toPrimitives();
31
- event.ack = () => this.store.delete(event.id);
32
- event.requeue = (error) => {
33
- event.ack?.();
34
- if (event.meta.retries < this.maxRetries) {
31
+ if (this.store.isProcessed(event.id)) {
32
+ return;
33
+ }
34
+ const retrySubscriber = (failedEvent, subscriber, error) => {
35
+ failedEvent.ack?.();
36
+ if (failedEvent.meta.retries < this.maxRetries) {
35
37
  const updatedPrimitives = {
36
38
  ...primitives,
37
- meta: { ...primitives.meta, retries: event.meta.retries + 1 },
39
+ meta: { ...failedEvent.meta, retries: failedEvent.meta.retries + 1 },
38
40
  };
39
41
  this.store.requeue(updatedPrimitives);
40
- this.publish(domain_events_1.DomainEventRegistry.create(updatedPrimitives));
42
+ const retryEvent = domain_events_1.DomainEventRegistry.create(updatedPrimitives);
43
+ executeSubscriber(subscriber, retryEvent);
41
44
  }
42
45
  else if (this.deadLetterStore) {
43
46
  const reason = error ? error.message : `Exceeded max retries (${this.maxRetries})`;
44
47
  this.deadLetterStore.add(primitives, reason);
45
48
  }
46
49
  };
50
+ const executeSubscriber = (subscriber, currentEvent) => {
51
+ currentEvent.ack = () => this.store.delete(currentEvent.id);
52
+ currentEvent.requeue = (error) => retrySubscriber(currentEvent, subscriber, error);
53
+ subscriber.handle(currentEvent);
54
+ };
47
55
  for (const sub of subs) {
48
56
  try {
49
- sub.handle(event);
57
+ executeSubscriber(sub, event);
50
58
  }
51
59
  catch (err) {
52
- event.requeue?.(err);
60
+ retrySubscriber(event, sub, err);
53
61
  }
54
62
  }
55
63
  }
@@ -1 +1 @@
1
- {"version":3,"file":"sync-in-memory-event-bus.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/sync/sync-in-memory-event-bus.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"sync-in-memory-event-bus.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/sync/sync-in-memory-event-bus.ts"],"names":[],"mappings":"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"}
@@ -3,8 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
3
3
  exports.SyncInMemoryEventStore = void 0;
4
4
  class SyncInMemoryEventStore {
5
5
  events = [];
6
+ processedEventIds = new Set();
6
7
  save(primitives) {
7
8
  this.events.push(primitives);
9
+ this.processedEventIds.add(primitives.id);
8
10
  }
9
11
  all() {
10
12
  return [...this.events];
@@ -19,6 +21,10 @@ class SyncInMemoryEventStore {
19
21
  }
20
22
  clear() {
21
23
  this.events.length = 0;
24
+ this.processedEventIds.clear();
25
+ }
26
+ isProcessed(id) {
27
+ return this.processedEventIds.has(id);
22
28
  }
23
29
  }
24
30
  exports.SyncInMemoryEventStore = SyncInMemoryEventStore;
@@ -1 +1 @@
1
- {"version":3,"file":"sync-in-memory-event-store.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/sync/sync-in-memory-event-store.ts"],"names":[],"mappings":";;;AAGA,MAAa,sBAAsB;IAChB,MAAM,GAA4B,EAAE,CAAC;IAEtD,IAAI,CAAC,UAAiC;QACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,GAAG;QACD,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,EAAU;QACf,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAEtD,IAAI,KAAK,KAAK,CAAC,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,OAAO,CAAC,UAAiC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;IACzB,CAAC;CACF;AAxBD,wDAwBC"}
1
+ {"version":3,"file":"sync-in-memory-event-store.js","sourceRoot":"","sources":["../../../../../src/event-bus/in-memory/sync/sync-in-memory-event-store.ts"],"names":[],"mappings":";;;AAGA,MAAa,sBAAsB;IAChB,MAAM,GAA4B,EAAE,CAAC;IACrC,iBAAiB,GAAG,IAAI,GAAG,EAAU,CAAC;IAEvD,IAAI,CAAC,UAAiC;QACpC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7B,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,UAAU,CAAC,EAAE,CAAC,CAAC;IAC5C,CAAC;IAED,GAAG;QACD,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC;IAC1B,CAAC;IAED,MAAM,CAAC,EAAU;QACf,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QAEtD,IAAI,KAAK,KAAK,CAAC,CAAC;YAAE,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;IACjD,CAAC;IAED,OAAO,CAAC,UAAiC;QACvC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAC/B,CAAC;IAED,KAAK;QACH,IAAI,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC;QACvB,IAAI,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC;IACjC,CAAC;IAED,WAAW,CAAC,EAAU;QACpB,OAAO,IAAI,CAAC,iBAAiB,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;IACxC,CAAC;CACF;AA/BD,wDA+BC"}
package/dist/cjs/index.js CHANGED
@@ -24,6 +24,7 @@ __exportStar(require("./dao"), exports);
24
24
  __exportStar(require("./domain-events"), exports);
25
25
  __exportStar(require("./entities"), exports);
26
26
  __exportStar(require("./event-bus"), exports);
27
+ __exportStar(require("./sagas"), exports);
27
28
  __exportStar(require("./formatters"), exports);
28
29
  __exportStar(require("./http"), exports);
29
30
  __exportStar(require("./i18n"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,+CAA6B;AAC7B,yCAAuB;AACvB,+CAA6B;AAC7B,yCAAuB;AACvB,6CAA2B;AAC3B,wCAAsB;AACtB,kDAAgC;AAChC,6CAA2B;AAC3B,8CAA4B;AAC5B,+CAA6B;AAC7B,yCAAuB;AACvB,yCAAuB;AACvB,uDAAqC;AACrC,6CAA2B;AAC3B,2CAAyB;AACzB,yCAAuB;AACvB,2CAAyB;AACzB,4CAA0B;AAC1B,yCAAuB;AACvB,2CAAyB;AACzB,kDAAgC;AAChC,+CAA6B;AAC7B,0CAAwB;AACxB,iDAA+B;AAC/B,0CAAwB;AACxB,kDAAgC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,yCAAuB;AACvB,+CAA6B;AAC7B,yCAAuB;AACvB,+CAA6B;AAC7B,yCAAuB;AACvB,6CAA2B;AAC3B,wCAAsB;AACtB,kDAAgC;AAChC,6CAA2B;AAC3B,8CAA4B;AAC5B,0CAAwB;AACxB,+CAA6B;AAC7B,yCAAuB;AACvB,yCAAuB;AACvB,uDAAqC;AACrC,6CAA2B;AAC3B,2CAAyB;AACzB,yCAAuB;AACvB,2CAAyB;AACzB,4CAA0B;AAC1B,yCAAuB;AACvB,2CAAyB;AACzB,kDAAgC;AAChC,+CAA6B;AAC7B,0CAAwB;AACxB,iDAA+B;AAC/B,0CAAwB;AACxB,kDAAgC"}
@@ -0,0 +1,20 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.InMemorySagaStateStore = void 0;
4
+ class InMemorySagaStateStore {
5
+ store = new Map();
6
+ async save(sagaId, state) {
7
+ this.store.set(sagaId, state);
8
+ }
9
+ async load(sagaId) {
10
+ return this.store.get(sagaId);
11
+ }
12
+ async delete(sagaId) {
13
+ this.store.delete(sagaId);
14
+ }
15
+ async all() {
16
+ return Array.from(this.store.entries()).map(([sagaId, state]) => ({ sagaId, state }));
17
+ }
18
+ }
19
+ exports.InMemorySagaStateStore = InMemorySagaStateStore;
20
+ //# sourceMappingURL=in-memory-saga-state-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory-saga-state-store.js","sourceRoot":"","sources":["../../../src/sagas/in-memory-saga-state-store.ts"],"names":[],"mappings":";;;AAEA,MAAa,sBAAsB;IAEhB,KAAK,GAAG,IAAI,GAAG,EAAqC,CAAC;IAEtE,KAAK,CAAC,IAAI,CAAC,MAAc,EAAE,KAAgC;QACzD,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,EAAE,KAAK,CAAC,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,MAAc;QACvB,OAAO,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC;IAChC,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,MAAc;QACzB,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,GAAG;QACP,OAAO,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,MAAM,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;IACxF,CAAC;CACF;AAnBD,wDAmBC"}
@@ -0,0 +1,10 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SagaManager = exports.Saga = exports.InMemorySagaStateStore = void 0;
4
+ var in_memory_saga_state_store_1 = require("./in-memory-saga-state-store");
5
+ Object.defineProperty(exports, "InMemorySagaStateStore", { enumerable: true, get: function () { return in_memory_saga_state_store_1.InMemorySagaStateStore; } });
6
+ var saga_1 = require("./saga");
7
+ Object.defineProperty(exports, "Saga", { enumerable: true, get: function () { return saga_1.Saga; } });
8
+ var saga_manager_1 = require("./saga-manager");
9
+ Object.defineProperty(exports, "SagaManager", { enumerable: true, get: function () { return saga_manager_1.SagaManager; } });
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/sagas/index.ts"],"names":[],"mappings":";;;AAEA,2EAAsE;AAA7D,oIAAA,sBAAsB,OAAA;AAC/B,+BAA8B;AAArB,4FAAA,IAAI,OAAA;AACb,+CAA6C;AAApC,2GAAA,WAAW,OAAA"}
@@ -0,0 +1,16 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.SagaManager = void 0;
4
+ class SagaManager {
5
+ eventBus;
6
+ constructor(eventBus) {
7
+ this.eventBus = eventBus;
8
+ }
9
+ register(saga) {
10
+ for (const eventName of saga.getSubscribedEventNames()) {
11
+ this.eventBus.subscribe(eventName, saga);
12
+ }
13
+ }
14
+ }
15
+ exports.SagaManager = SagaManager;
16
+ //# sourceMappingURL=saga-manager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"saga-manager.js","sourceRoot":"","sources":["../../../src/sagas/saga-manager.ts"],"names":[],"mappings":";;;AAGA,MAAa,WAAW;IACO;IAA7B,YAA6B,QAAwB;QAAxB,aAAQ,GAAR,QAAQ,CAAgB;IAAG,CAAC;IAEzD,QAAQ,CAAsB,IAAO;QACnC,KAAK,MAAM,SAAS,IAAI,IAAI,CAAC,uBAAuB,EAAE,EAAE,CAAC;YACvD,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC3C,CAAC;IACH,CAAC;CACF;AARD,kCAQC"}
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=saga-state-store.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"saga-state-store.js","sourceRoot":"","sources":["../../../src/sagas/saga-state-store.ts"],"names":[],"mappings":""}
@@ -0,0 +1,88 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.Saga = void 0;
4
+ class Saga {
5
+ commandBus;
6
+ stateStore;
7
+ handlers = new Map();
8
+ completedSteps = [];
9
+ compensationActions = new Map();
10
+ currentState;
11
+ constructor(commandBus, stateStore) {
12
+ this.commandBus = commandBus;
13
+ this.stateStore = stateStore;
14
+ this.currentState = this.getInitialState();
15
+ this.configure();
16
+ }
17
+ on(eventName, handler) {
18
+ this.handlers.set(eventName, handler);
19
+ }
20
+ async handle(event) {
21
+ const sagaId = this.getSagaId(event);
22
+ const persisted = await this.stateStore.load(sagaId);
23
+ const state = persisted?.data ?? this.getInitialState();
24
+ const completedSteps = persisted?.completedSteps ?? [];
25
+ const processedEventIds = persisted?.processedEventIds ?? [];
26
+ const handler = this.handlers.get(event.getEventName());
27
+ if (processedEventIds.includes(event.id)) {
28
+ return;
29
+ }
30
+ if (!handler) {
31
+ return;
32
+ }
33
+ this.currentState = state;
34
+ this.completedSteps = completedSteps;
35
+ this.compensationActions.clear();
36
+ try {
37
+ await handler(event, {
38
+ state: this.currentState,
39
+ completeStep: (stepId, compensation) => this.completeStep(stepId, compensation),
40
+ dispatch: command => this.commandBus.dispatch(command),
41
+ updateState: nextState => {
42
+ this.currentState = nextState;
43
+ },
44
+ });
45
+ await this.saveState(sagaId, "pending", event.id);
46
+ }
47
+ catch (error) {
48
+ await this.rollback();
49
+ await this.saveState(sagaId, "failed", event.id);
50
+ throw error;
51
+ }
52
+ }
53
+ async completeSaga(sagaId, eventId) {
54
+ await this.saveState(sagaId, "completed", eventId);
55
+ }
56
+ completeStep(stepId, compensation) {
57
+ if (!this.completedSteps.includes(stepId)) {
58
+ this.completedSteps.push(stepId);
59
+ }
60
+ if (compensation) {
61
+ this.compensationActions.set(stepId, compensation);
62
+ }
63
+ }
64
+ async rollback() {
65
+ const compensationEntries = Array.from(this.compensationActions.entries())
66
+ .filter(([stepId]) => this.completedSteps.includes(stepId))
67
+ .reverse();
68
+ for (const [, compensation] of compensationEntries) {
69
+ await compensation();
70
+ }
71
+ }
72
+ async saveState(sagaId, status, eventId) {
73
+ const processedEventIds = eventId ? [eventId] : [];
74
+ const persisted = await this.stateStore.load(sagaId);
75
+ const allProcessedEventIds = [...(persisted?.processedEventIds ?? []), ...processedEventIds];
76
+ await this.stateStore.save(sagaId, {
77
+ status,
78
+ completedSteps: this.completedSteps,
79
+ processedEventIds: allProcessedEventIds,
80
+ data: this.currentState,
81
+ });
82
+ }
83
+ getSubscribedEventNames() {
84
+ return Array.from(this.handlers.keys());
85
+ }
86
+ }
87
+ exports.Saga = Saga;
88
+ //# sourceMappingURL=saga.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"saga.js","sourceRoot":"","sources":["../../../src/sagas/saga.ts"],"names":[],"mappings":"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"}
@@ -4,19 +4,69 @@ exports.AggregateRoot = void 0;
4
4
  class AggregateRoot {
5
5
  id;
6
6
  domainEvents = [];
7
- constructor(id) {
7
+ _version = 0;
8
+ _uncommittedChanges = false;
9
+ constructor(id, version = 0) {
8
10
  this.id = id;
11
+ this._version = version;
12
+ }
13
+ get version() {
14
+ return this._version;
15
+ }
16
+ incrementVersion() {
17
+ this._version++;
18
+ this._uncommittedChanges = true;
19
+ }
20
+ get hasUncommittedChanges() {
21
+ return this._uncommittedChanges;
22
+ }
23
+ markChangesCommitted() {
24
+ this._uncommittedChanges = false;
9
25
  }
10
26
  pullDomainEvents() {
11
- const domainEvents = [...this.domainEvents];
27
+ const domainEvents = this.domainEvents.map((event, index) => {
28
+ const sequencedEvent = Object.assign(event, {
29
+ sequenceNumber: this._version - this.domainEvents.length + index + 1,
30
+ });
31
+ return sequencedEvent;
32
+ });
12
33
  this.domainEvents = [];
13
34
  return domainEvents;
14
35
  }
15
36
  recordDomainEvent(domainEvent) {
16
37
  this.domainEvents.push(domainEvent);
38
+ this.incrementVersion();
39
+ }
40
+ equals(other) {
41
+ return this.id.equals(other.id);
42
+ }
43
+ validateInvariants() { }
44
+ validate() {
45
+ this.validateInvariants();
46
+ }
47
+ static fromPrimitives(model) {
48
+ const { id, version = 0, ...data } = model;
49
+ const instance = new this(id, version);
50
+ if (instance.restoreFromPrimitives) {
51
+ instance.restoreFromPrimitives(data);
52
+ }
53
+ return instance;
54
+ }
55
+ restoreFromPrimitives(_data) { }
56
+ toSnapshot() {
57
+ return {
58
+ id: this.id,
59
+ version: this._version,
60
+ data: this.toPrimitives(),
61
+ };
17
62
  }
18
- static fromPrimitives(_model) {
19
- throw new Error("AggregateRoot reconstruction not implemented.");
63
+ static fromSnapshot(snapshot) {
64
+ const instance = new this(snapshot.id, snapshot.version);
65
+ if (instance.restoreFromPrimitives) {
66
+ instance.restoreFromPrimitives(snapshot.data);
67
+ }
68
+ instance.markChangesCommitted();
69
+ return instance;
20
70
  }
21
71
  }
22
72
  exports.AggregateRoot = AggregateRoot;