@synkro/core 0.7.1 → 0.9.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 (66) hide show
  1. package/dist/handlers/decorators.d.ts +14 -0
  2. package/dist/handlers/decorators.d.ts.map +1 -0
  3. package/dist/handlers/decorators.js +29 -0
  4. package/dist/handlers/decorators.js.map +1 -0
  5. package/dist/handlers/handler-discovery.d.ts +14 -0
  6. package/dist/handlers/handler-discovery.d.ts.map +1 -0
  7. package/dist/handlers/handler-discovery.js +38 -0
  8. package/dist/handlers/handler-discovery.js.map +1 -0
  9. package/dist/{handler-registry.d.ts → handlers/handler-registry.d.ts} +6 -2
  10. package/dist/handlers/handler-registry.d.ts.map +1 -0
  11. package/dist/handlers/handler-registry.js +141 -0
  12. package/dist/handlers/handler-registry.js.map +1 -0
  13. package/dist/handlers/index.d.ts +4 -0
  14. package/dist/handlers/index.d.ts.map +1 -0
  15. package/dist/handlers/index.js +4 -0
  16. package/dist/handlers/index.js.map +1 -0
  17. package/dist/index.d.ts +3 -14
  18. package/dist/index.d.ts.map +1 -1
  19. package/dist/index.js +2 -64
  20. package/dist/index.js.map +1 -1
  21. package/dist/logger.d.ts.map +1 -1
  22. package/dist/logger.js +1 -3
  23. package/dist/logger.js.map +1 -1
  24. package/dist/synkro.d.ts +16 -0
  25. package/dist/synkro.d.ts.map +1 -0
  26. package/dist/synkro.js +100 -0
  27. package/dist/synkro.js.map +1 -0
  28. package/dist/{in-memory.d.ts → transport/in-memory.d.ts} +5 -1
  29. package/dist/transport/in-memory.d.ts.map +1 -0
  30. package/dist/transport/in-memory.js +74 -0
  31. package/dist/transport/in-memory.js.map +1 -0
  32. package/dist/transport/index.d.ts +4 -0
  33. package/dist/transport/index.d.ts.map +1 -0
  34. package/dist/transport/index.js +3 -0
  35. package/dist/transport/index.js.map +1 -0
  36. package/dist/{redis.d.ts → transport/redis.d.ts} +10 -0
  37. package/dist/transport/redis.d.ts.map +1 -0
  38. package/dist/transport/redis.js +110 -0
  39. package/dist/transport/redis.js.map +1 -0
  40. package/dist/{transport.d.ts → transport/transport.d.ts} +1 -0
  41. package/dist/transport/transport.d.ts.map +1 -0
  42. package/dist/{transport.js.map → transport/transport.js.map} +1 -1
  43. package/dist/types.d.ts +2 -1
  44. package/dist/types.d.ts.map +1 -1
  45. package/dist/workflows/index.d.ts +2 -0
  46. package/dist/workflows/index.d.ts.map +1 -0
  47. package/dist/workflows/index.js +2 -0
  48. package/dist/workflows/index.js.map +1 -0
  49. package/dist/{workflow-registry.d.ts → workflows/workflow-registry.d.ts} +9 -3
  50. package/dist/workflows/workflow-registry.d.ts.map +1 -0
  51. package/dist/{workflow-registry.js → workflows/workflow-registry.js} +91 -33
  52. package/dist/workflows/workflow-registry.js.map +1 -0
  53. package/package.json +1 -1
  54. package/dist/handler-registry.d.ts.map +0 -1
  55. package/dist/handler-registry.js +0 -105
  56. package/dist/handler-registry.js.map +0 -1
  57. package/dist/in-memory.d.ts.map +0 -1
  58. package/dist/in-memory.js +0 -41
  59. package/dist/in-memory.js.map +0 -1
  60. package/dist/redis.d.ts.map +0 -1
  61. package/dist/redis.js +0 -56
  62. package/dist/redis.js.map +0 -1
  63. package/dist/transport.d.ts.map +0 -1
  64. package/dist/workflow-registry.d.ts.map +0 -1
  65. package/dist/workflow-registry.js.map +0 -1
  66. /package/dist/{transport.js → transport/transport.js} +0 -0
@@ -0,0 +1,14 @@
1
+ import type { RetryConfig } from "../types.js";
2
+ export declare const ON_EVENT_META: unique symbol;
3
+ export declare const ON_WORKFLOW_STEP_META: unique symbol;
4
+ export type OnEventMetadata = {
5
+ eventType: string;
6
+ retry?: RetryConfig;
7
+ };
8
+ export type OnWorkflowStepMetadata = {
9
+ workflowName: string;
10
+ stepType: string;
11
+ };
12
+ export declare function OnEvent(eventType: string, retry?: RetryConfig): <T extends Function>(target: T, _context: ClassMethodDecoratorContext) => T;
13
+ export declare function OnWorkflowStep(workflowName: string, stepType: string): <T extends Function>(target: T, _context: ClassMethodDecoratorContext) => T;
14
+ //# sourceMappingURL=decorators.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decorators.d.ts","sourceRoot":"","sources":["../../src/handlers/decorators.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAE/C,eAAO,MAAM,aAAa,eAAgC,CAAC;AAC3D,eAAO,MAAM,qBAAqB,eAAwC,CAAC;AAE3E,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,EAAE,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,sBAAsB,GAAG;IACnC,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;CAClB,CAAC;AAEF,wBAAgB,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,WAAW,IAE3C,CAAC,SAAS,QAAQ,EACjC,QAAQ,CAAC,EACT,UAAU,2BAA2B,KACpC,CAAC,CAYL;AAED,wBAAgB,cAAc,CAAC,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,IAElD,CAAC,SAAS,QAAQ,EACjC,QAAQ,CAAC,EACT,UAAU,2BAA2B,KACpC,CAAC,CAQL"}
@@ -0,0 +1,29 @@
1
+ export const ON_EVENT_META = Symbol.for("synkro:on-event");
2
+ export const ON_WORKFLOW_STEP_META = Symbol.for("synkro:on-workflow-step");
3
+ export function OnEvent(eventType, retry) {
4
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type
5
+ return function (target, _context) {
6
+ const metadata = { eventType };
7
+ if (retry !== undefined) {
8
+ metadata.retry = retry;
9
+ }
10
+ Object.defineProperty(target, ON_EVENT_META, {
11
+ value: metadata,
12
+ enumerable: false,
13
+ configurable: true,
14
+ });
15
+ return target;
16
+ };
17
+ }
18
+ export function OnWorkflowStep(workflowName, stepType) {
19
+ // eslint-disable-next-line @typescript-eslint/no-unsafe-function-type
20
+ return function (target, _context) {
21
+ Object.defineProperty(target, ON_WORKFLOW_STEP_META, {
22
+ value: { workflowName, stepType },
23
+ enumerable: false,
24
+ configurable: true,
25
+ });
26
+ return target;
27
+ };
28
+ }
29
+ //# sourceMappingURL=decorators.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decorators.js","sourceRoot":"","sources":["../../src/handlers/decorators.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,aAAa,GAAG,MAAM,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;AAC3D,MAAM,CAAC,MAAM,qBAAqB,GAAG,MAAM,CAAC,GAAG,CAAC,yBAAyB,CAAC,CAAC;AAY3E,MAAM,UAAU,OAAO,CAAC,SAAiB,EAAE,KAAmB;IAC5D,sEAAsE;IACtE,OAAO,UACL,MAAS,EACT,QAAqC;QAErC,MAAM,QAAQ,GAAoB,EAAE,SAAS,EAAE,CAAC;QAChD,IAAI,KAAK,KAAK,SAAS,EAAE,CAAC;YACxB,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;QACzB,CAAC;QACD,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,aAAa,EAAE;YAC3C,KAAK,EAAE,QAAQ;YACf,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,cAAc,CAAC,YAAoB,EAAE,QAAgB;IACnE,sEAAsE;IACtE,OAAO,UACL,MAAS,EACT,QAAqC;QAErC,MAAM,CAAC,cAAc,CAAC,MAAM,EAAE,qBAAqB,EAAE;YACnD,KAAK,EAAE,EAAE,YAAY,EAAE,QAAQ,EAAmC;YAClE,UAAU,EAAE,KAAK;YACjB,YAAY,EAAE,IAAI;SACnB,CAAC,CAAC;QACH,OAAO,MAAM,CAAC;IAChB,CAAC,CAAC;AACJ,CAAC"}
@@ -0,0 +1,14 @@
1
+ import type { HandlerFunction, RetryConfig } from "../types.js";
2
+ export type DiscoveredEventHandler = {
3
+ eventType: string;
4
+ handler: HandlerFunction;
5
+ retry?: RetryConfig;
6
+ };
7
+ export type DiscoveredWorkflowStepHandler = {
8
+ workflowName: string;
9
+ stepType: string;
10
+ handler: HandlerFunction;
11
+ };
12
+ export declare function discoverEventHandlers(instance: object): DiscoveredEventHandler[];
13
+ export declare function discoverWorkflowStepHandlers(instance: object): DiscoveredWorkflowStepHandler[];
14
+ //# sourceMappingURL=handler-discovery.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handler-discovery.d.ts","sourceRoot":"","sources":["../../src/handlers/handler-discovery.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,aAAa,CAAC;AAEhE,MAAM,MAAM,sBAAsB,GAAG;IACnC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,6BAA6B,GAAG;IAC1C,YAAY,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,MAAM,CAAC;IACjB,OAAO,EAAE,eAAe,CAAC;CAC1B,CAAC;AASF,wBAAgB,qBAAqB,CACnC,QAAQ,EAAE,MAAM,GACf,sBAAsB,EAAE,CAoB1B;AAED,wBAAgB,4BAA4B,CAC1C,QAAQ,EAAE,MAAM,GACf,6BAA6B,EAAE,CAsBjC"}
@@ -0,0 +1,38 @@
1
+ import { ON_EVENT_META, ON_WORKFLOW_STEP_META, } from "./decorators.js";
2
+ function getDecoratedMethods(instance) {
3
+ const proto = Object.getPrototypeOf(instance);
4
+ return Object.getOwnPropertyNames(proto).filter((name) => name !== "constructor" && typeof proto[name] === "function");
5
+ }
6
+ export function discoverEventHandlers(instance) {
7
+ const handlers = [];
8
+ const proto = Object.getPrototypeOf(instance);
9
+ for (const name of getDecoratedMethods(instance)) {
10
+ const method = proto[name];
11
+ const metadata = method[ON_EVENT_META];
12
+ if (!metadata)
13
+ continue;
14
+ handlers.push({
15
+ eventType: metadata.eventType,
16
+ handler: method.bind(instance),
17
+ ...(metadata.retry !== undefined && { retry: metadata.retry }),
18
+ });
19
+ }
20
+ return handlers;
21
+ }
22
+ export function discoverWorkflowStepHandlers(instance) {
23
+ const handlers = [];
24
+ const proto = Object.getPrototypeOf(instance);
25
+ for (const name of getDecoratedMethods(instance)) {
26
+ const method = proto[name];
27
+ const metadata = method[ON_WORKFLOW_STEP_META];
28
+ if (!metadata)
29
+ continue;
30
+ handlers.push({
31
+ workflowName: metadata.workflowName,
32
+ stepType: metadata.stepType,
33
+ handler: method.bind(instance),
34
+ });
35
+ }
36
+ return handlers;
37
+ }
38
+ //# sourceMappingURL=handler-discovery.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handler-discovery.js","sourceRoot":"","sources":["../../src/handlers/handler-discovery.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,aAAa,EACb,qBAAqB,GAGtB,MAAM,iBAAiB,CAAC;AAezB,SAAS,mBAAmB,CAAC,QAAgB;IAC3C,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAA4B,CAAC;IACzE,OAAO,MAAM,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC,MAAM,CAC7C,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,KAAK,aAAa,IAAI,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,UAAU,CACtE,CAAC;AACJ,CAAC;AAED,MAAM,UAAU,qBAAqB,CACnC,QAAgB;IAEhB,MAAM,QAAQ,GAA6B,EAAE,CAAC;IAC9C,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAG3C,CAAC;IAEF,KAAK,MAAM,IAAI,IAAI,mBAAmB,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjD,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QACvC,IAAI,CAAC,QAAQ;YAAE,SAAS;QAExB,QAAQ,CAAC,IAAI,CAAC;YACZ,SAAS,EAAE,QAAQ,CAAC,SAAS;YAC7B,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAoB;YACjD,GAAG,CAAC,QAAQ,CAAC,KAAK,KAAK,SAAS,IAAI,EAAE,KAAK,EAAE,QAAQ,CAAC,KAAK,EAAE,CAAC;SAC/D,CAAC,CAAC;IACL,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,QAAgB;IAEhB,MAAM,QAAQ,GAAoC,EAAE,CAAC;IACrD,MAAM,KAAK,GAAG,MAAM,CAAC,cAAc,CAAC,QAAQ,CAK3C,CAAC;IAEF,KAAK,MAAM,IAAI,IAAI,mBAAmB,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjD,MAAM,MAAM,GAAG,KAAK,CAAC,IAAI,CAAE,CAAC;QAC5B,MAAM,QAAQ,GAAG,MAAM,CAAC,qBAAqB,CAAC,CAAC;QAC/C,IAAI,CAAC,QAAQ;YAAE,SAAS;QAExB,QAAQ,CAAC,IAAI,CAAC;YACZ,YAAY,EAAE,QAAQ,CAAC,YAAY;YACnC,QAAQ,EAAE,QAAQ,CAAC,QAAQ;YAC3B,OAAO,EAAE,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAoB;SAClD,CAAC,CAAC;IACL,CAAC;IAED,OAAO,QAAQ,CAAC;AAClB,CAAC"}
@@ -1,9 +1,10 @@
1
- import type { TransportManager } from "./transport.js";
2
- import type { EventInfo, EventMetrics, HandlerFunction, PublishFunction, RetryConfig } from "./types.js";
1
+ import type { TransportManager } from "../transport/transport.js";
2
+ import type { EventInfo, EventMetrics, HandlerFunction, PublishFunction, RetryConfig } from "../types.js";
3
3
  export declare class HandlerRegistry {
4
4
  private redis;
5
5
  private handlers;
6
6
  private processingLocks;
7
+ private subscribedChannels;
7
8
  private publishFn;
8
9
  constructor(redis: TransportManager);
9
10
  setPublishFn(fn: PublishFunction): void;
@@ -11,5 +12,8 @@ export declare class HandlerRegistry {
11
12
  getRegisteredEvents(): EventInfo[];
12
13
  register(eventType: string, handlerFn: HandlerFunction, retry?: RetryConfig): void;
13
14
  private handleMessage;
15
+ private distributedLockKey;
16
+ private dedupeKey;
17
+ private executeHandler;
14
18
  }
15
19
  //# sourceMappingURL=handler-registry.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handler-registry.d.ts","sourceRoot":"","sources":["../../src/handlers/handler-registry.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,KAAK,EACV,SAAS,EACT,YAAY,EAEZ,eAAe,EACf,eAAe,EACf,WAAW,EACZ,MAAM,aAAa,CAAC;AAUrB,qBAAa,eAAe;IAOd,OAAO,CAAC,KAAK;IANzB,OAAO,CAAC,QAAQ,CAAwC;IACxD,OAAO,CAAC,eAAe,CAAqB;IAC5C,OAAO,CAAC,kBAAkB,CAAqB;IAE/C,OAAO,CAAC,SAAS,CAAgC;gBAE7B,KAAK,EAAE,gBAAgB;IAE3C,YAAY,CAAC,EAAE,EAAE,eAAe,GAAG,IAAI;IAIjC,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAc/D,mBAAmB,IAAI,SAAS,EAAE;IAWlC,QAAQ,CACN,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,eAAe,EAC1B,KAAK,CAAC,EAAE,WAAW,GAClB,IAAI;YAiBO,aAAa;IAuF3B,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,SAAS;YAIH,cAAc;CAqC7B"}
@@ -0,0 +1,141 @@
1
+ import { logger } from "../logger.js";
2
+ const PROCESSING_LOCK_TTL_SECONDS = 300;
3
+ const DEDUPE_TTL_SECONDS = 86400;
4
+ export class HandlerRegistry {
5
+ redis;
6
+ handlers = new Map();
7
+ processingLocks = new Set();
8
+ subscribedChannels = new Set();
9
+ publishFn = null;
10
+ constructor(redis) {
11
+ this.redis = redis;
12
+ }
13
+ setPublishFn(fn) {
14
+ this.publishFn = fn;
15
+ }
16
+ async getEventMetrics(eventType) {
17
+ const [received, completed, failed] = await Promise.all([
18
+ this.redis.getCache(`synkro:metrics:${eventType}:received`),
19
+ this.redis.getCache(`synkro:metrics:${eventType}:completed`),
20
+ this.redis.getCache(`synkro:metrics:${eventType}:failed`),
21
+ ]);
22
+ return {
23
+ type: eventType,
24
+ received: Number(received ?? 0),
25
+ completed: Number(completed ?? 0),
26
+ failed: Number(failed ?? 0),
27
+ };
28
+ }
29
+ getRegisteredEvents() {
30
+ return Array.from(this.handlers.entries())
31
+ .filter(([type]) => !type.startsWith("workflow:"))
32
+ .flatMap(([type, entries]) => Array.from(entries).map((entry) => ({
33
+ type,
34
+ ...(entry.retry && { retry: entry.retry }),
35
+ })));
36
+ }
37
+ register(eventType, handlerFn, retry) {
38
+ if (!this.handlers.has(eventType)) {
39
+ this.handlers.set(eventType, new Set());
40
+ }
41
+ this.handlers.get(eventType).add({
42
+ handler: handlerFn,
43
+ ...(retry && { retry }),
44
+ });
45
+ if (!this.subscribedChannels.has(eventType)) {
46
+ this.subscribedChannels.add(eventType);
47
+ this.redis.subscribeToChannel(eventType, (message) => {
48
+ void this.handleMessage(eventType, message);
49
+ });
50
+ }
51
+ }
52
+ async handleMessage(eventType, message) {
53
+ const entries = this.handlers.get(eventType);
54
+ if (!entries || entries.size === 0) {
55
+ return;
56
+ }
57
+ const event = JSON.parse(message);
58
+ const localLockKey = `${event.requestId}:${eventType}`;
59
+ if (this.processingLocks.has(localLockKey)) {
60
+ return;
61
+ }
62
+ const dedupeKey = this.dedupeKey(localLockKey);
63
+ const alreadyProcessed = await this.redis.getCache(dedupeKey);
64
+ if (alreadyProcessed === "1") {
65
+ logger.debug(`[HandlerRegistry] duplicate message ignored for "${eventType}" (requestId: ${event.requestId})`);
66
+ return;
67
+ }
68
+ this.processingLocks.add(localLockKey);
69
+ const distributedLockKey = this.distributedLockKey(localLockKey);
70
+ let distributedLockAcquired = false;
71
+ const trackMetrics = !eventType.startsWith("workflow:");
72
+ try {
73
+ distributedLockAcquired = await this.redis.setCacheIfNotExists(distributedLockKey, "1", PROCESSING_LOCK_TTL_SECONDS);
74
+ if (!distributedLockAcquired) {
75
+ logger.debug(`[HandlerRegistry] in-flight message ignored for "${eventType}" (requestId: ${event.requestId})`);
76
+ return;
77
+ }
78
+ logger.debug(`[HandlerRegistry] handleMessage("${eventType}") entries=${entries.size}`);
79
+ if (trackMetrics) {
80
+ await this.redis.incrementCache(`synkro:metrics:${eventType}:received`);
81
+ }
82
+ const results = await Promise.allSettled(Array.from(entries).map((entry) => this.executeHandler(eventType, entry, event)));
83
+ const allSucceeded = results.every((r) => r.status === "fulfilled");
84
+ if (trackMetrics) {
85
+ if (allSucceeded) {
86
+ await this.redis.incrementCache(`synkro:metrics:${eventType}:completed`);
87
+ }
88
+ else {
89
+ await this.redis.incrementCache(`synkro:metrics:${eventType}:failed`);
90
+ }
91
+ }
92
+ this.redis.publishMessage(`event:${eventType}:${allSucceeded ? "completed" : "failed"}`, JSON.stringify({
93
+ requestId: event.requestId,
94
+ payload: event.payload,
95
+ }));
96
+ await this.redis.setCache(dedupeKey, "1", DEDUPE_TTL_SECONDS);
97
+ }
98
+ finally {
99
+ this.processingLocks.delete(localLockKey);
100
+ if (distributedLockAcquired) {
101
+ await this.redis.deleteCache(distributedLockKey);
102
+ }
103
+ }
104
+ }
105
+ distributedLockKey(lockKey) {
106
+ return `synkro:lock:handler:${lockKey}`;
107
+ }
108
+ dedupeKey(lockKey) {
109
+ return `synkro:dedupe:handler:${lockKey}`;
110
+ }
111
+ async executeHandler(eventType, entry, event) {
112
+ const maxRetries = entry.retry?.maxRetries ?? 0;
113
+ const ctx = {
114
+ requestId: event.requestId,
115
+ payload: event.payload,
116
+ publish: this.publishFn,
117
+ setPayload(data) {
118
+ ctx.payload =
119
+ typeof ctx.payload === "object" && ctx.payload !== null
120
+ ? { ...ctx.payload, ...data }
121
+ : data;
122
+ },
123
+ };
124
+ for (let attempt = 0; attempt <= maxRetries; attempt++) {
125
+ try {
126
+ await entry.handler(ctx);
127
+ return;
128
+ }
129
+ catch (error) {
130
+ if (attempt < maxRetries) {
131
+ logger.warn(`[HandlerRegistry] - Handler "${eventType}" failed (attempt ${attempt + 1}/${maxRetries + 1}), retrying...`);
132
+ }
133
+ else {
134
+ logger.error(`[HandlerRegistry] - Handler "${eventType}" failed after ${maxRetries + 1} attempt(s): ${error}`);
135
+ throw error;
136
+ }
137
+ }
138
+ }
139
+ }
140
+ }
141
+ //# sourceMappingURL=handler-registry.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handler-registry.js","sourceRoot":"","sources":["../../src/handlers/handler-registry.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export { OnEvent, OnWorkflowStep } from "./decorators.js";
2
+ export { discoverEventHandlers, discoverWorkflowStepHandlers, } from "./handler-discovery.js";
3
+ export { HandlerRegistry } from "./handler-registry.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EACL,qBAAqB,EACrB,4BAA4B,GAC7B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { OnEvent, OnWorkflowStep } from "./decorators.js";
2
+ export { discoverEventHandlers, discoverWorkflowStepHandlers, } from "./handler-discovery.js";
3
+ export { HandlerRegistry } from "./handler-registry.js";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/handlers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EACL,qBAAqB,EACrB,4BAA4B,GAC7B,MAAM,wBAAwB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC"}
package/dist/index.d.ts CHANGED
@@ -1,16 +1,5 @@
1
- import type { EventMetrics, HandlerFunction, RetryConfig, SynkroIntrospection, SynkroOptions } from "./types.js";
2
- export declare class Synkro {
3
- private transport;
4
- private handlerRegistry;
5
- private workflowRegistry;
6
- private constructor();
7
- static start(options: SynkroOptions): Promise<Synkro>;
8
- on(eventType: string, handler: HandlerFunction, retry?: RetryConfig): void;
9
- publish(event: string, payload?: unknown, requestId?: string): Promise<string>;
10
- getEventMetrics(eventType: string): Promise<EventMetrics>;
11
- introspect(): SynkroIntrospection;
12
- stop(): Promise<void>;
13
- }
14
- export type { TransportManager } from "./transport.js";
1
+ export { Synkro } from "./synkro.js";
2
+ export { OnEvent, OnWorkflowStep } from "./handlers/index.js";
3
+ export type { TransportManager } from "./transport/index.js";
15
4
  export type { EventInfo, EventMetrics, HandlerCtx, HandlerFunction, PublishFunction, RetryConfig, SynkroEvent, SynkroIntrospection, SynkroOptions, SynkroWorkflow, SynkroWorkflowStep, WorkflowInfo, WorkflowStepInfo, } from "./types.js";
16
5
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAQA,OAAO,KAAK,EACV,YAAY,EACZ,eAAe,EACf,WAAW,EACX,mBAAmB,EACnB,aAAa,EACd,MAAM,YAAY,CAAC;AAGpB,qBAAa,MAAM;IACjB,OAAO,CAAC,SAAS,CAAmB;IACpC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,gBAAgB,CAAmB;IAE3C,OAAO;WAOM,KAAK,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;IA4B3D,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,EAAE,KAAK,CAAC,EAAE,WAAW,GAAG,IAAI;IAIpE,OAAO,CACX,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,EACjB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,MAAM,CAAC;IAeZ,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAI/D,UAAU,IAAI,mBAAmB;IAO3B,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;CAG5B;AAED,YAAY,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACvD,YAAY,EACV,SAAS,EACT,YAAY,EACZ,UAAU,EACV,eAAe,EACf,eAAe,EACf,WAAW,EACX,WAAW,EACX,mBAAmB,EACnB,aAAa,EACb,cAAc,EACd,kBAAkB,EAClB,YAAY,EACZ,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC;AAC9D,YAAY,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAC7D,YAAY,EACV,SAAS,EACT,YAAY,EACZ,UAAU,EACV,eAAe,EACf,eAAe,EACf,WAAW,EACX,WAAW,EACX,mBAAmB,EACnB,aAAa,EACb,cAAc,EACd,kBAAkB,EAClB,YAAY,EACZ,gBAAgB,GACjB,MAAM,YAAY,CAAC"}
package/dist/index.js CHANGED
@@ -1,65 +1,3 @@
1
- import { randomUUID } from "node:crypto";
2
- import { HandlerRegistry } from "./handler-registry.js";
3
- import { InMemoryManager } from "./in-memory.js";
4
- import { setDebug } from "./logger.js";
5
- import { RedisManager } from "./redis.js";
6
- import { WorkflowRegistry } from "./workflow-registry.js";
7
- export class Synkro {
8
- transport;
9
- handlerRegistry;
10
- workflowRegistry;
11
- constructor(transport) {
12
- this.transport = transport;
13
- this.handlerRegistry = new HandlerRegistry(transport);
14
- this.workflowRegistry = new WorkflowRegistry(transport, this.handlerRegistry);
15
- this.handlerRegistry.setPublishFn(this.publish.bind(this));
16
- }
17
- static async start(options) {
18
- setDebug(options.debug ?? false);
19
- let transport;
20
- if (options.transport === "in-memory") {
21
- transport = new InMemoryManager();
22
- }
23
- else {
24
- if (!options.connectionUrl) {
25
- throw new Error("connectionUrl is required when using Redis transport");
26
- }
27
- transport = new RedisManager(options.connectionUrl);
28
- }
29
- const instance = new Synkro(transport);
30
- if (options.events) {
31
- for (const event of options.events) {
32
- instance.on(event.type, event.handler, event.retry);
33
- }
34
- }
35
- if (options.workflows) {
36
- instance.workflowRegistry.registerWorkflows(options.workflows);
37
- }
38
- return instance;
39
- }
40
- on(eventType, handler, retry) {
41
- this.handlerRegistry.register(eventType, handler, retry);
42
- }
43
- async publish(event, payload, requestId) {
44
- requestId = requestId ?? randomUUID();
45
- if (this.workflowRegistry.hasWorkflow(event)) {
46
- await this.workflowRegistry.startWorkflow(event, requestId, payload);
47
- return requestId;
48
- }
49
- this.transport.publishMessage(event, JSON.stringify({ requestId, payload }));
50
- return requestId;
51
- }
52
- async getEventMetrics(eventType) {
53
- return this.handlerRegistry.getEventMetrics(eventType);
54
- }
55
- introspect() {
56
- return {
57
- events: this.handlerRegistry.getRegisteredEvents(),
58
- workflows: this.workflowRegistry.getRegisteredWorkflows(),
59
- };
60
- }
61
- async stop() {
62
- await this.transport.disconnect();
63
- }
64
- }
1
+ export { Synkro } from "./synkro.js";
2
+ export { OnEvent, OnWorkflowStep } from "./handlers/index.js";
65
3
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AAEzC,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AACjD,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AACvC,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC;AAW1D,MAAM,OAAO,MAAM;IACT,SAAS,CAAmB;IAC5B,eAAe,CAAkB;IACjC,gBAAgB,CAAmB;IAE3C,YAAoB,SAA2B;QAC7C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC;QAC3B,IAAI,CAAC,eAAe,GAAG,IAAI,eAAe,CAAC,SAAS,CAAC,CAAC;QACtD,IAAI,CAAC,gBAAgB,GAAG,IAAI,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,eAAe,CAAC,CAAC;QAC9E,IAAI,CAAC,eAAe,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;IAC7D,CAAC;IAED,MAAM,CAAC,KAAK,CAAC,KAAK,CAAC,OAAsB;QACvC,QAAQ,CAAC,OAAO,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC;QAEjC,IAAI,SAA2B,CAAC;QAChC,IAAI,OAAO,CAAC,SAAS,KAAK,WAAW,EAAE,CAAC;YACtC,SAAS,GAAG,IAAI,eAAe,EAAE,CAAC;QACpC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC;gBAC3B,MAAM,IAAI,KAAK,CAAC,sDAAsD,CAAC,CAAC;YAC1E,CAAC;YACD,SAAS,GAAG,IAAI,YAAY,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACtD,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,MAAM,CAAC,SAAS,CAAC,CAAC;QAEvC,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;YACnB,KAAK,MAAM,KAAK,IAAI,OAAO,CAAC,MAAM,EAAE,CAAC;gBACnC,QAAQ,CAAC,EAAE,CAAC,KAAK,CAAC,IAAI,EAAE,KAAK,CAAC,OAAO,EAAE,KAAK,CAAC,KAAK,CAAC,CAAC;YACtD,CAAC;QACH,CAAC;QAED,IAAI,OAAO,CAAC,SAAS,EAAE,CAAC;YACtB,QAAQ,CAAC,gBAAgB,CAAC,iBAAiB,CAAC,OAAO,CAAC,SAAS,CAAC,CAAC;QACjE,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,EAAE,CAAC,SAAiB,EAAE,OAAwB,EAAE,KAAmB;QACjE,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,SAAS,EAAE,OAAO,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAED,KAAK,CAAC,OAAO,CACX,KAAa,EACb,OAAiB,EACjB,SAAkB;QAElB,SAAS,GAAG,SAAS,IAAI,UAAU,EAAE,CAAC;QAEtC,IAAI,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,CAAC;YAC7C,MAAM,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,KAAK,EAAE,SAAS,EAAE,OAAO,CAAC,CAAC;YACrE,OAAO,SAAS,CAAC;QACnB,CAAC;QAED,IAAI,CAAC,SAAS,CAAC,cAAc,CAC3B,KAAK,EACL,IAAI,CAAC,SAAS,CAAC,EAAE,SAAS,EAAE,OAAO,EAAE,CAAC,CACvC,CAAC;QACF,OAAO,SAAS,CAAC;IACnB,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,SAAiB;QACrC,OAAO,IAAI,CAAC,eAAe,CAAC,eAAe,CAAC,SAAS,CAAC,CAAC;IACzD,CAAC;IAED,UAAU;QACR,OAAO;YACL,MAAM,EAAE,IAAI,CAAC,eAAe,CAAC,mBAAmB,EAAE;YAClD,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE;SAC1D,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,IAAI;QACR,MAAM,IAAI,CAAC,SAAS,CAAC,UAAU,EAAE,CAAC;IACpC,CAAC;CACF"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AACrC,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,qBAAqB,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAEA,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAE/C;AAED,eAAO,MAAM,MAAM;mBACF,OAAO,EAAE,GAAG,IAAI;kBAKjB,OAAO,EAAE,GAAG,IAAI;mBAKf,OAAO,EAAE,GAAG,IAAI;CAGhC,CAAC"}
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAEA,wBAAgB,QAAQ,CAAC,OAAO,EAAE,OAAO,GAAG,IAAI,CAE/C;AAED,eAAO,MAAM,MAAM;mBACF,OAAO,EAAE,GAAG,IAAI;kBAKjB,OAAO,EAAE,GAAG,IAAI;mBAGf,OAAO,EAAE,GAAG,IAAI;CAGhC,CAAC"}
package/dist/logger.js CHANGED
@@ -9,9 +9,7 @@ export const logger = {
9
9
  }
10
10
  },
11
11
  warn(...args) {
12
- if (debugEnabled) {
13
- console.warn(...args);
14
- }
12
+ console.warn(...args);
15
13
  },
16
14
  error(...args) {
17
15
  console.error(...args);
@@ -1 +1 @@
1
- {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,IAAI,YAAY,GAAG,KAAK,CAAC;AAEzB,MAAM,UAAU,QAAQ,CAAC,OAAgB;IACvC,YAAY,GAAG,OAAO,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,KAAK,CAAC,GAAG,IAAe;QACtB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IACD,IAAI,CAAC,GAAG,IAAe;QACrB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;QACxB,CAAC;IACH,CAAC;IACD,KAAK,CAAC,GAAG,IAAe;QACtB,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;IACzB,CAAC;CACF,CAAC"}
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AAAA,IAAI,YAAY,GAAG,KAAK,CAAC;AAEzB,MAAM,UAAU,QAAQ,CAAC,OAAgB;IACvC,YAAY,GAAG,OAAO,CAAC;AACzB,CAAC;AAED,MAAM,CAAC,MAAM,MAAM,GAAG;IACpB,KAAK,CAAC,GAAG,IAAe;QACtB,IAAI,YAAY,EAAE,CAAC;YACjB,OAAO,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,CAAC;QACvB,CAAC;IACH,CAAC;IACD,IAAI,CAAC,GAAG,IAAe;QACrB,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,CAAC;IACxB,CAAC;IACD,KAAK,CAAC,GAAG,IAAe;QACtB,OAAO,CAAC,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;IACzB,CAAC;CACF,CAAC"}
@@ -0,0 +1,16 @@
1
+ import type { EventMetrics, HandlerFunction, RetryConfig, SynkroIntrospection, SynkroOptions } from "./types.js";
2
+ export declare class Synkro {
3
+ private transport;
4
+ private handlerRegistry;
5
+ private workflowRegistry;
6
+ private constructor();
7
+ static start(options: SynkroOptions): Promise<Synkro>;
8
+ register(...instances: object[]): void;
9
+ on(eventType: string, handler: HandlerFunction, retry?: RetryConfig): void;
10
+ publish(event: string, payload?: unknown, requestId?: string): Promise<string>;
11
+ getEventMetrics(eventType: string): Promise<EventMetrics>;
12
+ introspect(): SynkroIntrospection;
13
+ stop(): Promise<void>;
14
+ private patchWorkflowHandlers;
15
+ }
16
+ //# sourceMappingURL=synkro.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"synkro.d.ts","sourceRoot":"","sources":["../src/synkro.ts"],"names":[],"mappings":"AAWA,OAAO,KAAK,EACV,YAAY,EACZ,eAAe,EACf,WAAW,EACX,mBAAmB,EACnB,aAAa,EAEd,MAAM,YAAY,CAAC;AAGpB,qBAAa,MAAM;IACjB,OAAO,CAAC,SAAS,CAAmB;IACpC,OAAO,CAAC,eAAe,CAAkB;IACzC,OAAO,CAAC,gBAAgB,CAAmB;IAE3C,OAAO;WAOM,KAAK,CAAC,OAAO,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC;IAwC3D,QAAQ,CAAC,GAAG,SAAS,EAAE,MAAM,EAAE,GAAG,IAAI;IAYtC,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,eAAe,EAAE,KAAK,CAAC,EAAE,WAAW,GAAG,IAAI;IAIpE,OAAO,CACX,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,EACjB,SAAS,CAAC,EAAE,MAAM,GACjB,OAAO,CAAC,MAAM,CAAC;IAeZ,eAAe,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC,YAAY,CAAC;IAI/D,UAAU,IAAI,mBAAmB;IAO3B,IAAI,IAAI,OAAO,CAAC,IAAI,CAAC;IAI3B,OAAO,CAAC,qBAAqB;CA4B9B"}
package/dist/synkro.js ADDED
@@ -0,0 +1,100 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { HandlerRegistry, discoverEventHandlers, discoverWorkflowStepHandlers, } from "./handlers/index.js";
3
+ import { InMemoryManager, RedisManager } from "./transport/index.js";
4
+ import { setDebug } from "./logger.js";
5
+ import { WorkflowRegistry } from "./workflows/index.js";
6
+ export class Synkro {
7
+ transport;
8
+ handlerRegistry;
9
+ workflowRegistry;
10
+ constructor(transport) {
11
+ this.transport = transport;
12
+ this.handlerRegistry = new HandlerRegistry(transport);
13
+ this.workflowRegistry = new WorkflowRegistry(transport, this.handlerRegistry);
14
+ this.handlerRegistry.setPublishFn(this.publish.bind(this));
15
+ }
16
+ static async start(options) {
17
+ setDebug(options.debug ?? false);
18
+ let transport;
19
+ if (options.transport === "in-memory") {
20
+ transport = new InMemoryManager();
21
+ }
22
+ else {
23
+ if (!options.connectionUrl) {
24
+ throw new Error("connectionUrl is required when using Redis transport");
25
+ }
26
+ transport = new RedisManager(options.connectionUrl);
27
+ }
28
+ const instance = new Synkro(transport);
29
+ // Patch decorated workflow step handlers before registering workflows
30
+ const workflows = options.workflows
31
+ ? instance.patchWorkflowHandlers(options.workflows, options.handlers ?? [])
32
+ : [];
33
+ if (options.events) {
34
+ for (const event of options.events) {
35
+ instance.on(event.type, event.handler, event.retry);
36
+ }
37
+ }
38
+ if (workflows.length > 0) {
39
+ instance.workflowRegistry.registerWorkflows(workflows);
40
+ }
41
+ // Register decorated event handlers
42
+ for (const handlerInstance of options.handlers ?? []) {
43
+ for (const { eventType, handler, retry } of discoverEventHandlers(handlerInstance)) {
44
+ instance.on(eventType, handler, retry);
45
+ }
46
+ }
47
+ return instance;
48
+ }
49
+ register(...instances) {
50
+ for (const instance of instances) {
51
+ for (const { eventType, handler, retry } of discoverEventHandlers(instance)) {
52
+ this.on(eventType, handler, retry);
53
+ }
54
+ for (const { workflowName, stepType, handler } of discoverWorkflowStepHandlers(instance)) {
55
+ this.workflowRegistry.registerStepHandler(workflowName, stepType, handler);
56
+ }
57
+ }
58
+ }
59
+ on(eventType, handler, retry) {
60
+ this.handlerRegistry.register(eventType, handler, retry);
61
+ }
62
+ async publish(event, payload, requestId) {
63
+ requestId = requestId ?? randomUUID();
64
+ if (this.workflowRegistry.hasWorkflow(event)) {
65
+ await this.workflowRegistry.startWorkflow(event, requestId, payload);
66
+ return requestId;
67
+ }
68
+ this.transport.publishMessage(event, JSON.stringify({ requestId, payload }));
69
+ return requestId;
70
+ }
71
+ async getEventMetrics(eventType) {
72
+ return this.handlerRegistry.getEventMetrics(eventType);
73
+ }
74
+ introspect() {
75
+ return {
76
+ events: this.handlerRegistry.getRegisteredEvents(),
77
+ workflows: this.workflowRegistry.getRegisteredWorkflows(),
78
+ };
79
+ }
80
+ async stop() {
81
+ await this.transport.disconnect();
82
+ }
83
+ patchWorkflowHandlers(workflows, handlerInstances) {
84
+ // Collect all decorated workflow step handlers
85
+ const stepHandlers = handlerInstances.flatMap((instance) => discoverWorkflowStepHandlers(instance));
86
+ return workflows.map((w) => ({
87
+ ...w,
88
+ steps: w.steps.map((s) => {
89
+ if (s.handler)
90
+ return s;
91
+ const discovered = stepHandlers.find((h) => h.workflowName === w.name && h.stepType === s.type);
92
+ if (!discovered) {
93
+ throw new Error(`Workflow "${w.name}" step "${s.type}" has no handler. Provide an inline handler or use the @OnWorkflowStep decorator.`);
94
+ }
95
+ return { ...s, handler: discovered.handler };
96
+ }),
97
+ }));
98
+ }
99
+ }
100
+ //# sourceMappingURL=synkro.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"synkro.js","sourceRoot":"","sources":["../src/synkro.ts"],"names":[],"mappings":"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"}
@@ -2,12 +2,16 @@ import type { TransportManager } from "./transport.js";
2
2
  export declare class InMemoryManager implements TransportManager {
3
3
  private subscriptions;
4
4
  private cache;
5
+ private cacheExpiry;
5
6
  publishMessage(channel: string, message: string): void;
6
7
  subscribeToChannel(channel: string, callback: (message: string) => void): void;
7
8
  getCache(key: string): Promise<string | null>;
8
- setCache(key: string, value: string, _ttlSeconds?: number): Promise<void>;
9
+ setCacheIfNotExists(key: string, value: string, ttlSeconds?: number): Promise<boolean>;
10
+ setCache(key: string, value: string, ttlSeconds?: number): Promise<void>;
9
11
  deleteCache(key: string): Promise<void>;
10
12
  incrementCache(key: string): Promise<number>;
11
13
  disconnect(): Promise<void>;
14
+ private evictIfExpired;
15
+ private applyTtl;
12
16
  }
13
17
  //# sourceMappingURL=in-memory.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.d.ts","sourceRoot":"","sources":["../../src/transport/in-memory.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD,qBAAa,eAAgB,YAAW,gBAAgB;IACtD,OAAO,CAAC,aAAa,CAAqD;IAC1E,OAAO,CAAC,KAAK,CAA6B;IAC1C,OAAO,CAAC,WAAW,CAA6B;IAEhD,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAWtD,kBAAkB,CAChB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAClC,IAAI;IAQD,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAK7C,mBAAmB,CACvB,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,OAAO,CAAC;IAWb,QAAQ,CACZ,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,IAAI,CAAC;IAKV,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAKvC,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAY5C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAMjC,OAAO,CAAC,cAAc;IAQtB,OAAO,CAAC,QAAQ;CAQjB"}