@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,74 @@
1
+ import { logger } from "../logger.js";
2
+ export class InMemoryManager {
3
+ subscriptions = new Map();
4
+ cache = new Map();
5
+ cacheExpiry = new Map();
6
+ publishMessage(channel, message) {
7
+ const callbacks = this.subscriptions.get(channel);
8
+ if (!callbacks) {
9
+ return;
10
+ }
11
+ for (const callback of callbacks) {
12
+ queueMicrotask(() => callback(message));
13
+ }
14
+ }
15
+ subscribeToChannel(channel, callback) {
16
+ if (!this.subscriptions.has(channel)) {
17
+ this.subscriptions.set(channel, new Set());
18
+ }
19
+ this.subscriptions.get(channel).add(callback);
20
+ logger.debug(`Subscribed to channel "${channel}" (in-memory).`);
21
+ }
22
+ async getCache(key) {
23
+ this.evictIfExpired(key);
24
+ return this.cache.get(key) ?? null;
25
+ }
26
+ async setCacheIfNotExists(key, value, ttlSeconds) {
27
+ this.evictIfExpired(key);
28
+ if (this.cache.has(key)) {
29
+ return false;
30
+ }
31
+ this.cache.set(key, value);
32
+ this.applyTtl(key, ttlSeconds);
33
+ return true;
34
+ }
35
+ async setCache(key, value, ttlSeconds) {
36
+ this.cache.set(key, value);
37
+ this.applyTtl(key, ttlSeconds);
38
+ }
39
+ async deleteCache(key) {
40
+ this.cache.delete(key);
41
+ this.cacheExpiry.delete(key);
42
+ }
43
+ async incrementCache(key) {
44
+ this.evictIfExpired(key);
45
+ const expiresAt = this.cacheExpiry.get(key);
46
+ const current = Number(this.cache.get(key) ?? 0);
47
+ const next = current + 1;
48
+ this.cache.set(key, String(next));
49
+ if (expiresAt !== undefined) {
50
+ this.cacheExpiry.set(key, expiresAt);
51
+ }
52
+ return next;
53
+ }
54
+ async disconnect() {
55
+ this.subscriptions.clear();
56
+ this.cache.clear();
57
+ this.cacheExpiry.clear();
58
+ }
59
+ evictIfExpired(key) {
60
+ const expiresAt = this.cacheExpiry.get(key);
61
+ if (expiresAt !== undefined && Date.now() >= expiresAt) {
62
+ this.cache.delete(key);
63
+ this.cacheExpiry.delete(key);
64
+ }
65
+ }
66
+ applyTtl(key, ttlSeconds) {
67
+ if (ttlSeconds && ttlSeconds > 0) {
68
+ this.cacheExpiry.set(key, Date.now() + ttlSeconds * 1000);
69
+ return;
70
+ }
71
+ this.cacheExpiry.delete(key);
72
+ }
73
+ }
74
+ //# sourceMappingURL=in-memory.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"in-memory.js","sourceRoot":"","sources":["../../src/transport/in-memory.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ export type { TransportManager } from "./transport.js";
2
+ export { RedisManager } from "./redis.js";
3
+ export { InMemoryManager } from "./in-memory.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/transport/index.ts"],"names":[],"mappings":"AAAA,YAAY,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { RedisManager } from "./redis.js";
2
+ export { InMemoryManager } from "./in-memory.js";
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/transport/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,YAAY,EAAE,MAAM,YAAY,CAAC;AAC1C,OAAO,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC"}
@@ -4,13 +4,23 @@ export declare class RedisManager implements TransportManager {
4
4
  private subscriber;
5
5
  private cacheClient;
6
6
  private channelCallbacks;
7
+ private pendingSubscriptions;
8
+ private flushScheduled;
9
+ private recentMessages;
10
+ private static readonly DEDUP_WINDOW_MS;
11
+ private static readonly MAX_RECENT_MESSAGES;
7
12
  constructor(redisUrl: string);
8
13
  publishMessage(channel: string, message: string): void;
9
14
  subscribeToChannel(channel: string, callback: (message: string) => void): void;
15
+ private flushSubscriptions;
10
16
  getCache(key: string): Promise<string | null>;
17
+ setCacheIfNotExists(key: string, value: string, ttlSeconds?: number): Promise<boolean>;
11
18
  setCache(key: string, value: string, ttlSeconds?: number): Promise<void>;
12
19
  deleteCache(key: string): Promise<void>;
13
20
  incrementCache(key: string): Promise<number>;
14
21
  disconnect(): Promise<void>;
22
+ private static readonly REQUEST_ID_RE;
23
+ private extractRequestId;
24
+ private evictStaleMessages;
15
25
  }
16
26
  //# sourceMappingURL=redis.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redis.d.ts","sourceRoot":"","sources":["../../src/transport/redis.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AAEvD,qBAAa,YAAa,YAAW,gBAAgB;IACnD,OAAO,CAAC,SAAS,CAAQ;IACzB,OAAO,CAAC,UAAU,CAAQ;IAC1B,OAAO,CAAC,WAAW,CAAQ;IAC3B,OAAO,CAAC,gBAAgB,CACZ;IACZ,OAAO,CAAC,oBAAoB,CAAgB;IAC5C,OAAO,CAAC,cAAc,CAAS;IAC/B,OAAO,CAAC,cAAc,CAA6B;IACnD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAS;IAChD,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,mBAAmB,CAAU;gBAEzC,QAAQ,EAAE,MAAM;IA2B5B,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAItD,kBAAkB,CAChB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAClC,IAAI;IAkBP,OAAO,CAAC,kBAAkB;IAiBpB,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAI7C,mBAAmB,CACvB,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,OAAO,CAAC;IAOb,QAAQ,CACZ,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,IAAI,CAAC;IAQV,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIvC,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAI5C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC;IAMjC,OAAO,CAAC,MAAM,CAAC,QAAQ,CAAC,aAAa,CAA2B;IAEhE,OAAO,CAAC,gBAAgB;IAKxB,OAAO,CAAC,kBAAkB;CAS3B"}
@@ -0,0 +1,110 @@
1
+ import { Redis } from "ioredis";
2
+ import { logger } from "../logger.js";
3
+ export class RedisManager {
4
+ publisher;
5
+ subscriber;
6
+ cacheClient;
7
+ channelCallbacks = new Map();
8
+ pendingSubscriptions = [];
9
+ flushScheduled = false;
10
+ recentMessages = new Map();
11
+ static DEDUP_WINDOW_MS = 5_000;
12
+ static MAX_RECENT_MESSAGES = 10_000;
13
+ constructor(redisUrl) {
14
+ this.publisher = new Redis(redisUrl);
15
+ this.subscriber = new Redis(redisUrl);
16
+ this.cacheClient = new Redis(redisUrl);
17
+ this.subscriber.on("message", (channel, message) => {
18
+ const requestId = this.extractRequestId(message);
19
+ const dedupeKey = requestId ? `${channel}\0${requestId}` : `${channel}\0${message}`;
20
+ const now = Date.now();
21
+ if (this.recentMessages.has(dedupeKey)) {
22
+ return;
23
+ }
24
+ this.recentMessages.set(dedupeKey, now);
25
+ this.evictStaleMessages(now);
26
+ const callbacks = this.channelCallbacks.get(channel);
27
+ if (callbacks) {
28
+ logger.debug(`[RedisManager] message on "${channel}" → ${callbacks.size} callback(s)`);
29
+ for (const callback of callbacks) {
30
+ callback(message);
31
+ }
32
+ }
33
+ });
34
+ }
35
+ publishMessage(channel, message) {
36
+ this.publisher.publish(channel, message);
37
+ }
38
+ subscribeToChannel(channel, callback) {
39
+ const isNewChannel = !this.channelCallbacks.has(channel);
40
+ if (isNewChannel) {
41
+ this.channelCallbacks.set(channel, new Set());
42
+ }
43
+ this.channelCallbacks.get(channel).add(callback);
44
+ logger.debug(`[RedisManager] subscribeToChannel("${channel}") → now ${this.channelCallbacks.get(channel).size} callback(s)`);
45
+ if (isNewChannel) {
46
+ this.pendingSubscriptions.push(channel);
47
+ if (!this.flushScheduled) {
48
+ this.flushScheduled = true;
49
+ queueMicrotask(() => this.flushSubscriptions());
50
+ }
51
+ }
52
+ }
53
+ flushSubscriptions() {
54
+ this.flushScheduled = false;
55
+ const channels = this.pendingSubscriptions.splice(0);
56
+ if (channels.length === 0)
57
+ return;
58
+ this.subscriber
59
+ .subscribe(...channels)
60
+ .then((count) => {
61
+ logger.debug(`Subscribed to ${count} channel(s): ${channels.join(", ")}`);
62
+ })
63
+ .catch((err) => {
64
+ logger.error(`Failed to subscribe to channels:`, err);
65
+ });
66
+ }
67
+ async getCache(key) {
68
+ return await this.cacheClient.get(key);
69
+ }
70
+ async setCacheIfNotExists(key, value, ttlSeconds) {
71
+ const result = ttlSeconds
72
+ ? await this.cacheClient.set(key, value, "EX", ttlSeconds, "NX")
73
+ : await this.cacheClient.set(key, value, "NX");
74
+ return result === "OK";
75
+ }
76
+ async setCache(key, value, ttlSeconds) {
77
+ if (ttlSeconds) {
78
+ await this.cacheClient.set(key, value, "EX", ttlSeconds);
79
+ }
80
+ else {
81
+ await this.cacheClient.set(key, value);
82
+ }
83
+ }
84
+ async deleteCache(key) {
85
+ await this.cacheClient.del(key);
86
+ }
87
+ async incrementCache(key) {
88
+ return await this.cacheClient.incr(key);
89
+ }
90
+ async disconnect() {
91
+ await this.publisher.quit();
92
+ await this.subscriber.quit();
93
+ await this.cacheClient.quit();
94
+ }
95
+ static REQUEST_ID_RE = /"requestId":"([^"]+)"/;
96
+ extractRequestId(message) {
97
+ const match = RedisManager.REQUEST_ID_RE.exec(message);
98
+ return match?.[1] ?? null;
99
+ }
100
+ evictStaleMessages(now) {
101
+ if (this.recentMessages.size <= RedisManager.MAX_RECENT_MESSAGES)
102
+ return;
103
+ for (const [key, timestamp] of this.recentMessages) {
104
+ if (now - timestamp > RedisManager.DEDUP_WINDOW_MS) {
105
+ this.recentMessages.delete(key);
106
+ }
107
+ }
108
+ }
109
+ }
110
+ //# sourceMappingURL=redis.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"redis.js","sourceRoot":"","sources":["../../src/transport/redis.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,7 @@
1
1
  export interface TransportManager {
2
2
  publishMessage(channel: string, message: string): void;
3
3
  subscribeToChannel(channel: string, callback: (message: string) => void): void;
4
+ setCacheIfNotExists(key: string, value: string, ttlSeconds?: number): Promise<boolean>;
4
5
  getCache(key: string): Promise<string | null>;
5
6
  setCache(key: string, value: string, ttlSeconds?: number): Promise<void>;
6
7
  deleteCache(key: string): Promise<void>;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"transport.d.ts","sourceRoot":"","sources":["../../src/transport/transport.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,gBAAgB;IAC/B,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CAAC;IACvD,kBAAkB,CAChB,OAAO,EAAE,MAAM,EACf,QAAQ,EAAE,CAAC,OAAO,EAAE,MAAM,KAAK,IAAI,GAClC,IAAI,CAAC;IACR,mBAAmB,CACjB,GAAG,EAAE,MAAM,EACX,KAAK,EAAE,MAAM,EACb,UAAU,CAAC,EAAE,MAAM,GAClB,OAAO,CAAC,OAAO,CAAC,CAAC;IACpB,QAAQ,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC;IAC9C,QAAQ,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACzE,WAAW,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IACxC,cAAc,CAAC,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;IAC7C,UAAU,IAAI,OAAO,CAAC,IAAI,CAAC,CAAC;CAC7B"}
@@ -1 +1 @@
1
- {"version":3,"file":"transport.js","sourceRoot":"","sources":["../src/transport.ts"],"names":[],"mappings":""}
1
+ {"version":3,"file":"transport.js","sourceRoot":"","sources":["../../src/transport/transport.ts"],"names":[],"mappings":""}
package/dist/types.d.ts CHANGED
@@ -8,7 +8,7 @@ export type SynkroEvent = {
8
8
  };
9
9
  export type SynkroWorkflowStep = {
10
10
  type: string;
11
- handler: HandlerFunction;
11
+ handler?: HandlerFunction;
12
12
  retry?: RetryConfig;
13
13
  onSuccess?: string;
14
14
  onFailure?: string;
@@ -26,6 +26,7 @@ export type SynkroOptions = {
26
26
  debug?: boolean;
27
27
  events?: SynkroEvent[];
28
28
  workflows?: SynkroWorkflow[];
29
+ handlers?: object[];
29
30
  };
30
31
  export type PublishFunction = (event: string, payload?: unknown, requestId?: string) => Promise<string>;
31
32
  export type HandlerCtx = {
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,SAAS,EAAE,OAAO,GAAG,WAAW,CAAC;IACjC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC;CAC9B,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,CAC5B,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,EACjB,SAAS,CAAC,EAAE,MAAM,KACf,OAAO,CAAC,MAAM,CAAC,CAAC;AAErB,MAAM,MAAM,UAAU,GAAG;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,eAAe,CAAC;IACzB,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CACrD,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAExE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,gBAAgB,EAAE,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,SAAS,EAAE,YAAY,EAAE,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,WAAW,GAAG;IACxB,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,EAAE,eAAe,CAAC;IACzB,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,IAAI,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,cAAc,GAAG;IAC3B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,kBAAkB,EAAE,CAAC;IAC5B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,aAAa,GAAG;IAC1B,SAAS,EAAE,OAAO,GAAG,WAAW,CAAC;IACjC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,MAAM,CAAC,EAAE,WAAW,EAAE,CAAC;IACvB,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC;IAC7B,QAAQ,CAAC,EAAE,MAAM,EAAE,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,CAC5B,KAAK,EAAE,MAAM,EACb,OAAO,CAAC,EAAE,OAAO,EACjB,SAAS,CAAC,EAAE,MAAM,KACf,OAAO,CAAC,MAAM,CAAC,CAAC;AAErB,MAAM,MAAM,UAAU,GAAG;IACvB,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,EAAE,eAAe,CAAC;IACzB,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,KAAK,IAAI,CAAC;CACrD,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE,UAAU,KAAK,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;AAExE,MAAM,MAAM,SAAS,GAAG;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,WAAW,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG;IAC7B,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,WAAW,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,gBAAgB,EAAE,CAAC;IAC1B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG;IAChC,MAAM,EAAE,SAAS,EAAE,CAAC;IACpB,SAAS,EAAE,YAAY,EAAE,CAAC;CAC3B,CAAC;AAEF,MAAM,MAAM,YAAY,GAAG;IACzB,IAAI,EAAE,MAAM,CAAC;IACb,QAAQ,EAAE,MAAM,CAAC;IACjB,SAAS,EAAE,MAAM,CAAC;IAClB,MAAM,EAAE,MAAM,CAAC;CAChB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { WorkflowRegistry } from "./workflow-registry.js";
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/workflows/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { WorkflowRegistry } from "./workflow-registry.js";
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/workflows/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,wBAAwB,CAAC"}
@@ -1,6 +1,6 @@
1
- import type { HandlerRegistry } from "./handler-registry.js";
2
- import type { TransportManager } from "./transport.js";
3
- import type { SynkroWorkflow, WorkflowInfo } from "./types.js";
1
+ import type { HandlerRegistry } from "../handlers/handler-registry.js";
2
+ import type { TransportManager } from "../transport/transport.js";
3
+ import type { HandlerFunction, SynkroWorkflow, WorkflowInfo } from "../types.js";
4
4
  export declare class WorkflowRegistry {
5
5
  private redis;
6
6
  private handlerRegistry;
@@ -8,9 +8,12 @@ export declare class WorkflowRegistry {
8
8
  private branchTargets;
9
9
  private eventToWorkflows;
10
10
  private processingLocks;
11
+ private lockQueues;
11
12
  constructor(redis: TransportManager, handlerRegistry: HandlerRegistry);
13
+ private withLock;
12
14
  getRegisteredWorkflows(): WorkflowInfo[];
13
15
  registerWorkflows(workflows: SynkroWorkflow[]): void;
16
+ registerStepHandler(workflowName: string, stepType: string, handler: HandlerFunction): void;
14
17
  hasWorkflow(name: string): boolean;
15
18
  startWorkflow(workflowName: string, requestId: string, payload: unknown): Promise<void>;
16
19
  private subscribeToWorkflowEvents;
@@ -22,6 +25,9 @@ export declare class WorkflowRegistry {
22
25
  private findStepIndex;
23
26
  private stepChannel;
24
27
  private stateKey;
28
+ private withStepTransitionClaim;
29
+ private distributedLockKey;
30
+ private dedupeKey;
25
31
  private saveState;
26
32
  private getState;
27
33
  }
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-registry.d.ts","sourceRoot":"","sources":["../../src/workflows/workflow-registry.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,iCAAiC,CAAC;AACvE,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAWjF,qBAAa,gBAAgB;IAWzB,OAAO,CAAC,KAAK;IACb,OAAO,CAAC,eAAe;IAXzB,OAAO,CAAC,SAAS,CAAqC;IACtD,OAAO,CAAC,aAAa,CAAkC;IACvD,OAAO,CAAC,gBAAgB,CAGpB;IACJ,OAAO,CAAC,eAAe,CAAqB;IAC5C,OAAO,CAAC,UAAU,CAAoC;gBAG5C,KAAK,EAAE,gBAAgB,EACvB,eAAe,EAAE,eAAe;YAG5B,QAAQ;IAqBtB,sBAAsB,IAAI,YAAY,EAAE;IAexC,iBAAiB,CAAC,SAAS,EAAE,cAAc,EAAE,GAAG,IAAI;IAiCpD,mBAAmB,CACjB,YAAY,EAAE,MAAM,EACpB,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE,eAAe,GACvB,IAAI;IAaP,WAAW,CAAC,IAAI,EAAE,MAAM,GAAG,OAAO;IAI5B,aAAa,CACjB,YAAY,EAAE,MAAM,EACpB,SAAS,EAAE,MAAM,EACjB,OAAO,EAAE,OAAO,GACf,OAAO,CAAC,IAAI,CAAC;IAwBhB,OAAO,CAAC,yBAAyB;YA2BnB,oBAAoB;YA6DpB,iBAAiB;YAgDjB,WAAW;YAsBX,oBAAoB;IAgClC,OAAO,CAAC,YAAY;IAUpB,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,WAAW;IAInB,OAAO,CAAC,QAAQ;YAIF,uBAAuB;IA+CrC,OAAO,CAAC,kBAAkB;IAI1B,OAAO,CAAC,SAAS;YAIH,SAAS;YAWT,QAAQ;CAKvB"}
@@ -1,4 +1,6 @@
1
- import { logger } from "./logger.js";
1
+ import { logger } from "../logger.js";
2
+ const PROCESSING_LOCK_TTL_SECONDS = 300;
3
+ const DEDUPE_TTL_SECONDS = 86400;
2
4
  export class WorkflowRegistry {
3
5
  redis;
4
6
  handlerRegistry;
@@ -6,10 +8,29 @@ export class WorkflowRegistry {
6
8
  branchTargets = new Map();
7
9
  eventToWorkflows = new Map();
8
10
  processingLocks = new Set();
11
+ lockQueues = new Map();
9
12
  constructor(redis, handlerRegistry) {
10
13
  this.redis = redis;
11
14
  this.handlerRegistry = handlerRegistry;
12
15
  }
16
+ async withLock(lockKey, fn) {
17
+ const prev = this.lockQueues.get(lockKey) ?? Promise.resolve();
18
+ let resolve;
19
+ const current = new Promise((r) => {
20
+ resolve = r;
21
+ });
22
+ this.lockQueues.set(lockKey, current);
23
+ try {
24
+ await prev;
25
+ await fn();
26
+ }
27
+ finally {
28
+ if (this.lockQueues.get(lockKey) === current) {
29
+ this.lockQueues.delete(lockKey);
30
+ }
31
+ resolve();
32
+ }
33
+ }
13
34
  getRegisteredWorkflows() {
14
35
  return Array.from(this.workflows.values()).map((w) => ({
15
36
  name: w.name,
@@ -43,12 +64,23 @@ export class WorkflowRegistry {
43
64
  }
44
65
  this.eventToWorkflows.get(key).push({ workflow, stepIndex: i });
45
66
  const channel = this.stepChannel(workflow.name, step.type);
46
- this.handlerRegistry.register(channel, step.handler, step.retry);
67
+ if (step.handler) {
68
+ this.handlerRegistry.register(channel, step.handler, step.retry);
69
+ }
47
70
  }
48
71
  this.subscribeToWorkflowEvents(workflow);
49
72
  logger.debug(`[WorkflowRegistry] - Workflow "${workflow.name}" registered with ${workflow.steps.length} steps`);
50
73
  }
51
74
  }
75
+ registerStepHandler(workflowName, stepType, handler) {
76
+ const workflow = this.workflows.get(workflowName);
77
+ if (!workflow) {
78
+ logger.warn(`[WorkflowRegistry] - Workflow "${workflowName}" not found for step handler "${stepType}"`);
79
+ return;
80
+ }
81
+ const channel = this.stepChannel(workflowName, stepType);
82
+ this.handlerRegistry.register(channel, handler);
83
+ }
52
84
  hasWorkflow(name) {
53
85
  return this.workflows.has(name);
54
86
  }
@@ -73,27 +105,25 @@ export class WorkflowRegistry {
73
105
  const step = workflow.steps[i];
74
106
  const channel = this.stepChannel(workflow.name, step.type);
75
107
  this.redis.subscribeToChannel(`event:${channel}:completed`, (message) => {
76
- this.handleStepCompletion(workflow, i, message);
108
+ const { requestId } = JSON.parse(message);
109
+ void this.withLock(`${requestId}:${workflow.name}`, () => this.handleStepCompletion(workflow, i, message));
77
110
  });
78
111
  this.redis.subscribeToChannel(`event:${channel}:failed`, (message) => {
79
- this.handleStepFailure(workflow, i, message);
112
+ const { requestId } = JSON.parse(message);
113
+ void this.withLock(`${requestId}:${workflow.name}`, () => this.handleStepFailure(workflow, i, message));
80
114
  });
81
115
  }
82
116
  }
83
117
  async handleStepCompletion(workflow, stepIndex, message) {
84
118
  const { requestId, payload } = JSON.parse(message);
85
119
  const lockKey = `${requestId}:${workflow.name}:completion:${stepIndex}`;
86
- if (this.processingLocks.has(lockKey)) {
87
- return;
88
- }
89
- this.processingLocks.add(lockKey);
90
- try {
91
- const state = await this.getState(requestId);
92
- if (!state || state.workflowName !== workflow.name) {
120
+ await this.withStepTransitionClaim(lockKey, async () => {
121
+ const state = await this.getState(requestId, workflow.name);
122
+ if (!state || state.workflowName !== workflow.name || state.status !== "running") {
93
123
  return;
94
124
  }
95
125
  if (state.currentStep !== stepIndex) {
96
- logger.warn(`[WorkflowRegistry] - Step mismatch for "${workflow.name}" (requestId: ${requestId}): expected step ${state.currentStep}, got ${stepIndex}`);
126
+ logger.debug(`[WorkflowRegistry] - Ignoring stale completion for "${workflow.name}" (requestId: ${requestId}): expected step ${state.currentStep}, got ${stepIndex}`);
97
127
  return;
98
128
  }
99
129
  const currentStep = workflow.steps[stepIndex];
@@ -117,25 +147,18 @@ export class WorkflowRegistry {
117
147
  return;
118
148
  }
119
149
  await this.routeToStep(workflow, requestId, nextStepIndex, payload);
120
- }
121
- finally {
122
- this.processingLocks.delete(lockKey);
123
- }
150
+ });
124
151
  }
125
152
  async handleStepFailure(workflow, stepIndex, message) {
126
153
  const { requestId, payload } = JSON.parse(message);
127
154
  const lockKey = `${requestId}:${workflow.name}:failure:${stepIndex}`;
128
- if (this.processingLocks.has(lockKey)) {
129
- return;
130
- }
131
- this.processingLocks.add(lockKey);
132
- try {
133
- const state = await this.getState(requestId);
134
- if (!state || state.workflowName !== workflow.name) {
155
+ await this.withStepTransitionClaim(lockKey, async () => {
156
+ const state = await this.getState(requestId, workflow.name);
157
+ if (!state || state.workflowName !== workflow.name || state.status !== "running") {
135
158
  return;
136
159
  }
137
160
  if (state.currentStep !== stepIndex) {
138
- logger.warn(`[WorkflowRegistry] - Step mismatch for "${workflow.name}" (requestId: ${requestId}): expected step ${state.currentStep}, got ${stepIndex}`);
161
+ logger.debug(`[WorkflowRegistry] - Ignoring stale failure for "${workflow.name}" (requestId: ${requestId}): expected step ${state.currentStep}, got ${stepIndex}`);
139
162
  return;
140
163
  }
141
164
  const currentStep = workflow.steps[stepIndex];
@@ -153,10 +176,7 @@ export class WorkflowRegistry {
153
176
  await this.saveState(requestId, state);
154
177
  logger.error(`[WorkflowRegistry] - Workflow "${workflow.name}" failed at step "${currentStep.type}" (requestId: ${requestId})`);
155
178
  await this.triggerNextWorkflows(workflow, "failed", requestId, payload);
156
- }
157
- finally {
158
- this.processingLocks.delete(lockKey);
159
- }
179
+ });
160
180
  }
161
181
  async routeToStep(workflow, requestId, targetIndex, payload) {
162
182
  const state = {
@@ -206,14 +226,52 @@ export class WorkflowRegistry {
206
226
  stepChannel(workflowName, stepType) {
207
227
  return `workflow:${workflowName}:${stepType}`;
208
228
  }
209
- stateKey(requestId) {
210
- return `workflow:state:${requestId}`;
229
+ stateKey(requestId, workflowName) {
230
+ return `workflow:state:${requestId}:${workflowName}`;
231
+ }
232
+ async withStepTransitionClaim(lockKey, fn) {
233
+ if (this.processingLocks.has(lockKey)) {
234
+ return;
235
+ }
236
+ const dedupeKey = this.dedupeKey(lockKey);
237
+ const alreadyProcessed = await this.redis.getCache(dedupeKey);
238
+ if (alreadyProcessed === "1") {
239
+ logger.debug(`[WorkflowRegistry] - Duplicate transition ignored (${lockKey})`);
240
+ return;
241
+ }
242
+ this.processingLocks.add(lockKey);
243
+ const distributedLockKey = this.distributedLockKey(lockKey);
244
+ let distributedLockAcquired = false;
245
+ let completed = false;
246
+ try {
247
+ distributedLockAcquired = await this.redis.setCacheIfNotExists(distributedLockKey, "1", PROCESSING_LOCK_TTL_SECONDS);
248
+ if (!distributedLockAcquired) {
249
+ return;
250
+ }
251
+ await fn();
252
+ completed = true;
253
+ }
254
+ finally {
255
+ this.processingLocks.delete(lockKey);
256
+ if (completed) {
257
+ await this.redis.setCache(dedupeKey, "1", DEDUPE_TTL_SECONDS);
258
+ }
259
+ if (distributedLockAcquired) {
260
+ await this.redis.deleteCache(distributedLockKey);
261
+ }
262
+ }
263
+ }
264
+ distributedLockKey(lockKey) {
265
+ return `synkro:lock:workflow:${lockKey}`;
266
+ }
267
+ dedupeKey(lockKey) {
268
+ return `synkro:dedupe:workflow:${lockKey}`;
211
269
  }
212
270
  async saveState(requestId, state) {
213
- await this.redis.setCache(this.stateKey(requestId), JSON.stringify(state), 86400);
271
+ await this.redis.setCache(this.stateKey(requestId, state.workflowName), JSON.stringify(state), 86400);
214
272
  }
215
- async getState(requestId) {
216
- const raw = await this.redis.getCache(this.stateKey(requestId));
273
+ async getState(requestId, workflowName) {
274
+ const raw = await this.redis.getCache(this.stateKey(requestId, workflowName));
217
275
  if (!raw)
218
276
  return null;
219
277
  return JSON.parse(raw);
@@ -0,0 +1 @@
1
+ {"version":3,"file":"workflow-registry.js","sourceRoot":"","sources":["../../src/workflows/workflow-registry.ts"],"names":[],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@synkro/core",
3
- "version": "0.7.1",
3
+ "version": "0.9.0",
4
4
  "description": "Lightweight workflow and state machine orchestrator powered by Redis. Define event-driven workflows via configuration or code.",
5
5
  "main": "dist/index.js",
6
6
  "types": "dist/index.d.ts",
@@ -1 +0,0 @@
1
- {"version":3,"file":"handler-registry.d.ts","sourceRoot":"","sources":["../src/handler-registry.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AACvD,OAAO,KAAK,EACV,SAAS,EACT,YAAY,EAEZ,eAAe,EACf,eAAe,EACf,WAAW,EACZ,MAAM,YAAY,CAAC;AAOpB,qBAAa,eAAe;IAMd,OAAO,CAAC,KAAK;IALzB,OAAO,CAAC,QAAQ,CAAmC;IACnD,OAAO,CAAC,eAAe,CAAqB;IAE5C,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;IASlC,QAAQ,CACN,SAAS,EAAE,MAAM,EACjB,SAAS,EAAE,eAAe,EAC1B,KAAK,CAAC,EAAE,WAAW,GAClB,IAAI;YAWO,aAAa;CA+E5B"}