@taskcast/core 0.2.0 → 0.3.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.
- package/dist/config.d.ts +13 -2
- package/dist/config.d.ts.map +1 -1
- package/dist/config.js.map +1 -1
- package/dist/engine.d.ts +5 -0
- package/dist/engine.d.ts.map +1 -1
- package/dist/engine.js +10 -4
- package/dist/engine.js.map +1 -1
- package/dist/index.d.ts +2 -0
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +2 -0
- package/dist/index.js.map +1 -1
- package/dist/memory-adapters.d.ts +13 -1
- package/dist/memory-adapters.d.ts.map +1 -1
- package/dist/memory-adapters.js +85 -0
- package/dist/memory-adapters.js.map +1 -1
- package/dist/state-machine.d.ts.map +1 -1
- package/dist/state-machine.js +4 -3
- package/dist/state-machine.js.map +1 -1
- package/dist/types.d.ts +76 -2
- package/dist/types.d.ts.map +1 -1
- package/dist/worker-manager.d.ts +67 -0
- package/dist/worker-manager.d.ts.map +1 -0
- package/dist/worker-manager.js +312 -0
- package/dist/worker-manager.js.map +1 -0
- package/dist/worker-matching.d.ts +23 -0
- package/dist/worker-matching.d.ts.map +1 -0
- package/dist/worker-matching.js +50 -0
- package/dist/worker-matching.js.map +1 -0
- package/package.json +1 -1
package/dist/config.d.ts
CHANGED
|
@@ -17,11 +17,11 @@ export interface TaskcastConfig {
|
|
|
17
17
|
provider: string;
|
|
18
18
|
url?: string;
|
|
19
19
|
};
|
|
20
|
-
|
|
20
|
+
shortTermStore?: {
|
|
21
21
|
provider: string;
|
|
22
22
|
url?: string;
|
|
23
23
|
};
|
|
24
|
-
|
|
24
|
+
longTermStore?: {
|
|
25
25
|
provider: string;
|
|
26
26
|
url?: string;
|
|
27
27
|
};
|
|
@@ -49,6 +49,17 @@ export interface TaskcastConfig {
|
|
|
49
49
|
cleanup?: {
|
|
50
50
|
rules?: unknown[];
|
|
51
51
|
};
|
|
52
|
+
workers?: {
|
|
53
|
+
enabled?: boolean;
|
|
54
|
+
defaults?: {
|
|
55
|
+
assignMode?: 'external' | 'pull' | 'ws-offer' | 'ws-race';
|
|
56
|
+
heartbeatIntervalMs?: number;
|
|
57
|
+
heartbeatTimeoutMs?: number;
|
|
58
|
+
offerTimeoutMs?: number;
|
|
59
|
+
disconnectPolicy?: 'reassign' | 'mark' | 'fail';
|
|
60
|
+
disconnectGraceMs?: number;
|
|
61
|
+
};
|
|
62
|
+
};
|
|
52
63
|
}
|
|
53
64
|
export declare function interpolateEnvVars(value: string): string;
|
|
54
65
|
export declare function parseConfig(content: string, format: 'json' | 'yaml'): TaskcastConfig;
|
package/dist/config.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAEA,MAAM,WAAW,cAAc;IAC7B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,QAAQ,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAA;IAC9C,IAAI,CAAC,EAAE;QACL,IAAI,EAAE,MAAM,GAAG,KAAK,GAAG,QAAQ,CAAA;QAC/B,GAAG,CAAC,EAAE;YACJ,SAAS,CAAC,EAAE,MAAM,CAAA;YAClB,MAAM,CAAC,EAAE,MAAM,CAAA;YACf,SAAS,CAAC,EAAE,MAAM,CAAA;YAClB,aAAa,CAAC,EAAE,MAAM,CAAA;YACtB,MAAM,CAAC,EAAE,MAAM,CAAA;YACf,QAAQ,CAAC,EAAE,MAAM,CAAA;SAClB,CAAA;KACF,CAAA;IACD,QAAQ,CAAC,EAAE;QACT,SAAS,CAAC,EAAE;YAAE,QAAQ,EAAE,MAAM,CAAC;YAAC,GAAG,CAAC,EAAE,MAAM,CAAA;SAAE,CAAA;QAC9C,
|
|
1
|
+
{"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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"}
|
package/dist/config.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,IAAI,QAAQ,EAAE,MAAM,SAAS,CAAA;
|
|
1
|
+
{"version":3,"file":"config.js","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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"}
|
package/dist/engine.d.ts
CHANGED
|
@@ -7,6 +7,7 @@ interface TaskEngineOptionsCanonical extends TaskEngineOptionsBase {
|
|
|
7
7
|
shortTermStore: ShortTermStore;
|
|
8
8
|
longTermStore?: LongTermStore;
|
|
9
9
|
}
|
|
10
|
+
/** @deprecated Use shortTermStore/longTermStore instead */
|
|
10
11
|
interface TaskEngineOptionsLegacy extends TaskEngineOptionsBase {
|
|
11
12
|
shortTerm: ShortTermStore;
|
|
12
13
|
longTerm?: LongTermStore;
|
|
@@ -28,6 +29,10 @@ export interface CreateTaskInput {
|
|
|
28
29
|
webhooks?: Task['webhooks'];
|
|
29
30
|
cleanup?: Task['cleanup'];
|
|
30
31
|
authConfig?: Task['authConfig'];
|
|
32
|
+
tags?: string[];
|
|
33
|
+
assignMode?: Task['assignMode'];
|
|
34
|
+
cost?: number;
|
|
35
|
+
disconnectPolicy?: Task['disconnectPolicy'];
|
|
31
36
|
}
|
|
32
37
|
export declare class TaskEngine {
|
|
33
38
|
private shortTermStore;
|
package/dist/engine.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../src/engine.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,IAAI,EACJ,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,aAAa,EACb,iBAAiB,EAClB,MAAM,YAAY,CAAA;AAEnB,UAAU,qBAAqB;IAC7B,SAAS,EAAE,iBAAiB,CAAA;IAC5B,KAAK,CAAC,EAAE,aAAa,CAAA;CACtB;AAED,UAAU,0BAA2B,SAAQ,qBAAqB;IAChE,cAAc,EAAE,cAAc,CAAA;IAC9B,aAAa,CAAC,EAAE,aAAa,CAAA;CAC9B;AAED,UAAU,uBAAwB,SAAQ,qBAAqB;IAC7D,SAAS,EAAE,cAAc,CAAA;IACzB,QAAQ,CAAC,EAAE,aAAa,CAAA;CACzB;AAED,MAAM,MAAM,iBAAiB,GAAG,0BAA0B,GAAG,uBAAuB,CAAA;AAEpF,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC,CAAA;IACzB,IAAI,EAAE,OAAO,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,SAAS,CAAC,YAAY,CAAC,CAAA;CACrC;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAClC,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,QAAQ,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAA;IAC3B,OAAO,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAA;IACzB,UAAU,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;
|
|
1
|
+
{"version":3,"file":"engine.d.ts","sourceRoot":"","sources":["../src/engine.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,IAAI,EACJ,UAAU,EACV,SAAS,EACT,iBAAiB,EACjB,cAAc,EACd,aAAa,EACb,aAAa,EACb,iBAAiB,EAClB,MAAM,YAAY,CAAA;AAEnB,UAAU,qBAAqB;IAC7B,SAAS,EAAE,iBAAiB,CAAA;IAC5B,KAAK,CAAC,EAAE,aAAa,CAAA;CACtB;AAED,UAAU,0BAA2B,SAAQ,qBAAqB;IAChE,cAAc,EAAE,cAAc,CAAA;IAC9B,aAAa,CAAC,EAAE,aAAa,CAAA;CAC9B;AAED,2DAA2D;AAC3D,UAAU,uBAAwB,SAAQ,qBAAqB;IAC7D,SAAS,EAAE,cAAc,CAAA;IACzB,QAAQ,CAAC,EAAE,aAAa,CAAA;CACzB;AAED,MAAM,MAAM,iBAAiB,GAAG,0BAA0B,GAAG,uBAAuB,CAAA;AAEpF,MAAM,WAAW,iBAAiB;IAChC,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,SAAS,CAAC,OAAO,CAAC,CAAA;IACzB,IAAI,EAAE,OAAO,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,SAAS,CAAC,YAAY,CAAC,CAAA;CACrC;AAED,MAAM,WAAW,eAAe;IAC9B,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAClC,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,QAAQ,CAAC,EAAE,IAAI,CAAC,UAAU,CAAC,CAAA;IAC3B,OAAO,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,CAAA;IACzB,UAAU,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;IAC/B,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,CAAA;IAC/B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,gBAAgB,CAAC,EAAE,IAAI,CAAC,kBAAkB,CAAC,CAAA;CAC5C;AAED,qBAAa,UAAU;IACrB,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,aAAa,CAA2B;IAChD,OAAO,CAAC,SAAS,CAAmB;IACpC,OAAO,CAAC,KAAK,CAA2B;gBAE5B,IAAI,EAAE,iBAAiB;IAiB7B,UAAU,CAAC,KAAK,EAAE,eAAe,GAAG,OAAO,CAAC,IAAI,CAAC;IA0BjD,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;IAM7C,cAAc,CAClB,MAAM,EAAE,MAAM,EACd,EAAE,EAAE,UAAU,EACd,OAAO,CAAC,EAAE;QAAE,MAAM,CAAC,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAAC,KAAK,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAA;KAAE,GAC3D,OAAO,CAAC,IAAI,CAAC;IAyCV,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,iBAAiB,GAAG,OAAO,CAAC,SAAS,CAAC;IAU1E,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAI/E,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,IAAI,GAAG,MAAM,IAAI;YAI5D,KAAK;CA2BpB"}
|
package/dist/engine.js
CHANGED
|
@@ -7,11 +7,11 @@ export class TaskEngine {
|
|
|
7
7
|
broadcast;
|
|
8
8
|
hooks;
|
|
9
9
|
constructor(opts) {
|
|
10
|
-
if ('
|
|
11
|
-
throw new Error('Cannot specify both
|
|
10
|
+
if ('shortTerm' in opts && 'shortTermStore' in opts) {
|
|
11
|
+
throw new Error('Cannot specify both shortTerm and shortTermStore');
|
|
12
12
|
}
|
|
13
|
-
if ('
|
|
14
|
-
throw new Error('Cannot specify both
|
|
13
|
+
if ('longTerm' in opts && 'longTermStore' in opts) {
|
|
14
|
+
throw new Error('Cannot specify both longTerm and longTermStore');
|
|
15
15
|
}
|
|
16
16
|
this.shortTermStore = 'shortTermStore' in opts ? opts.shortTermStore : opts.shortTerm;
|
|
17
17
|
this.longTermStore = 'longTermStore' in opts
|
|
@@ -37,12 +37,17 @@ export class TaskEngine {
|
|
|
37
37
|
...(input.webhooks !== undefined && { webhooks: input.webhooks }),
|
|
38
38
|
...(input.cleanup !== undefined && { cleanup: input.cleanup }),
|
|
39
39
|
...(input.authConfig !== undefined && { authConfig: input.authConfig }),
|
|
40
|
+
...(input.tags !== undefined && { tags: input.tags }),
|
|
41
|
+
...(input.assignMode !== undefined && { assignMode: input.assignMode }),
|
|
42
|
+
...(input.cost !== undefined && { cost: input.cost }),
|
|
43
|
+
...(input.disconnectPolicy !== undefined && { disconnectPolicy: input.disconnectPolicy }),
|
|
40
44
|
};
|
|
41
45
|
await this.shortTermStore.saveTask(task);
|
|
42
46
|
if (this.longTermStore)
|
|
43
47
|
await this.longTermStore.saveTask(task);
|
|
44
48
|
if (task.ttl)
|
|
45
49
|
await this.shortTermStore.setTTL(task.id, task.ttl);
|
|
50
|
+
this.hooks?.onTaskCreated?.(task);
|
|
46
51
|
return task;
|
|
47
52
|
}
|
|
48
53
|
async getTask(taskId) {
|
|
@@ -84,6 +89,7 @@ export class TaskEngine {
|
|
|
84
89
|
if (to === 'timeout') {
|
|
85
90
|
this.hooks?.onTaskTimeout?.(updated);
|
|
86
91
|
}
|
|
92
|
+
this.hooks?.onTaskTransitioned?.(updated, task.status, to);
|
|
87
93
|
return updated;
|
|
88
94
|
}
|
|
89
95
|
async publishEvent(taskId, input) {
|
package/dist/engine.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../src/engine.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAA;AAC5B,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAA;AAC9D,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAA;
|
|
1
|
+
{"version":3,"file":"engine.js","sourceRoot":"","sources":["../src/engine.ts"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,oBAAoB,CAAA;AAClC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAC5B,cAAc,sBAAsB,CAAA;AACpC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,oBAAoB,CAAA;AAClC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAC5B,cAAc,sBAAsB,CAAA;AACpC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,sBAAsB,CAAA;AACpC,cAAc,qBAAqB,CAAA"}
|
package/dist/index.js
CHANGED
package/dist/index.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,oBAAoB,CAAA;AAClC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAC5B,cAAc,sBAAsB,CAAA;AACpC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,YAAY,CAAA;AAC1B,cAAc,oBAAoB,CAAA;AAClC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,cAAc,CAAA;AAC5B,cAAc,sBAAsB,CAAA;AACpC,cAAc,aAAa,CAAA;AAC3B,cAAc,aAAa,CAAA;AAC3B,cAAc,sBAAsB,CAAA;AACpC,cAAc,qBAAqB,CAAA"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import type { Task, TaskEvent, BroadcastProvider, ShortTermStore, EventQueryOptions } from './types.js';
|
|
1
|
+
import type { Task, TaskEvent, BroadcastProvider, ShortTermStore, EventQueryOptions, TaskFilter, Worker, WorkerFilter, WorkerAssignment } from './types.js';
|
|
2
2
|
export declare class MemoryBroadcastProvider implements BroadcastProvider {
|
|
3
3
|
private listeners;
|
|
4
4
|
publish(channel: string, event: TaskEvent): Promise<void>;
|
|
@@ -9,6 +9,8 @@ export declare class MemoryShortTermStore implements ShortTermStore {
|
|
|
9
9
|
private events;
|
|
10
10
|
private seriesLatest;
|
|
11
11
|
private indexCounters;
|
|
12
|
+
private workers;
|
|
13
|
+
private assignments;
|
|
12
14
|
saveTask(task: Task): Promise<void>;
|
|
13
15
|
getTask(taskId: string): Promise<Task | null>;
|
|
14
16
|
nextIndex(taskId: string): Promise<number>;
|
|
@@ -18,5 +20,15 @@ export declare class MemoryShortTermStore implements ShortTermStore {
|
|
|
18
20
|
getSeriesLatest(taskId: string, seriesId: string): Promise<TaskEvent | null>;
|
|
19
21
|
setSeriesLatest(taskId: string, seriesId: string, event: TaskEvent): Promise<void>;
|
|
20
22
|
replaceLastSeriesEvent(taskId: string, seriesId: string, event: TaskEvent): Promise<void>;
|
|
23
|
+
listTasks(filter: TaskFilter): Promise<Task[]>;
|
|
24
|
+
saveWorker(worker: Worker): Promise<void>;
|
|
25
|
+
getWorker(workerId: string): Promise<Worker | null>;
|
|
26
|
+
listWorkers(filter?: WorkerFilter): Promise<Worker[]>;
|
|
27
|
+
deleteWorker(workerId: string): Promise<void>;
|
|
28
|
+
claimTask(taskId: string, workerId: string, cost: number): Promise<boolean>;
|
|
29
|
+
addAssignment(assignment: WorkerAssignment): Promise<void>;
|
|
30
|
+
removeAssignment(taskId: string): Promise<void>;
|
|
31
|
+
getWorkerAssignments(workerId: string): Promise<WorkerAssignment[]>;
|
|
32
|
+
getTaskAssignment(taskId: string): Promise<WorkerAssignment | null>;
|
|
21
33
|
}
|
|
22
34
|
//# sourceMappingURL=memory-adapters.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memory-adapters.d.ts","sourceRoot":"","sources":["../src/memory-adapters.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"memory-adapters.d.ts","sourceRoot":"","sources":["../src/memory-adapters.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,IAAI,EACJ,SAAS,EACT,iBAAiB,EACjB,cAAc,EACd,iBAAiB,EACjB,UAAU,EACV,MAAM,EACN,YAAY,EACZ,gBAAgB,EACjB,MAAM,YAAY,CAAA;AAEnB,qBAAa,uBAAwB,YAAW,iBAAiB;IAC/D,OAAO,CAAC,SAAS,CAAqD;IAEhE,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAQ/D,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,IAAI,GAAG,MAAM,IAAI;CAS5E;AAED,qBAAa,oBAAqB,YAAW,cAAc;IACzD,OAAO,CAAC,KAAK,CAA0B;IACvC,OAAO,CAAC,MAAM,CAAiC;IAC/C,OAAO,CAAC,YAAY,CAA+B;IACnD,OAAO,CAAC,aAAa,CAA4B;IACjD,OAAO,CAAC,OAAO,CAA4B;IAC3C,OAAO,CAAC,WAAW,CAAsC;IAEnD,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC;IAInC,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC;IAI7C,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC;IAO1C,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAK5D,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IAiBzE,MAAM,CAAC,OAAO,EAAE,MAAM,EAAE,WAAW,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI3D,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;IAI5E,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAIlF,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBzF,SAAS,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC;IAkC9C,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAIzC,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC;IAInD,WAAW,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC;IAarD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAM7C,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC;IAiB3E,aAAa,CAAC,UAAU,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC;IAI1D,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAI/C,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC;IAInE,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC;CAG1E"}
|
package/dist/memory-adapters.js
CHANGED
|
@@ -23,6 +23,8 @@ export class MemoryShortTermStore {
|
|
|
23
23
|
events = new Map();
|
|
24
24
|
seriesLatest = new Map();
|
|
25
25
|
indexCounters = new Map();
|
|
26
|
+
workers = new Map();
|
|
27
|
+
assignments = new Map();
|
|
26
28
|
async saveTask(task) {
|
|
27
29
|
this.tasks.set(task.id, { ...task });
|
|
28
30
|
}
|
|
@@ -89,5 +91,88 @@ export class MemoryShortTermStore {
|
|
|
89
91
|
}
|
|
90
92
|
this.seriesLatest.set(key, { ...event });
|
|
91
93
|
}
|
|
94
|
+
// Task query
|
|
95
|
+
async listTasks(filter) {
|
|
96
|
+
let tasks = Array.from(this.tasks.values());
|
|
97
|
+
if (filter.status?.length) {
|
|
98
|
+
tasks = tasks.filter((t) => filter.status.includes(t.status));
|
|
99
|
+
}
|
|
100
|
+
if (filter.types?.length) {
|
|
101
|
+
tasks = tasks.filter((t) => t.type !== undefined && filter.types.includes(t.type));
|
|
102
|
+
}
|
|
103
|
+
if (filter.tags) {
|
|
104
|
+
const { all, any, none } = filter.tags;
|
|
105
|
+
tasks = tasks.filter((t) => {
|
|
106
|
+
const taskTags = t.tags ?? [];
|
|
107
|
+
if (all && !all.every((tag) => taskTags.includes(tag)))
|
|
108
|
+
return false;
|
|
109
|
+
if (any && !any.some((tag) => taskTags.includes(tag)))
|
|
110
|
+
return false;
|
|
111
|
+
if (none && none.some((tag) => taskTags.includes(tag)))
|
|
112
|
+
return false;
|
|
113
|
+
return true;
|
|
114
|
+
});
|
|
115
|
+
}
|
|
116
|
+
if (filter.assignMode?.length) {
|
|
117
|
+
tasks = tasks.filter((t) => t.assignMode !== undefined && filter.assignMode.includes(t.assignMode));
|
|
118
|
+
}
|
|
119
|
+
if (filter.excludeTaskIds?.length) {
|
|
120
|
+
const excluded = new Set(filter.excludeTaskIds);
|
|
121
|
+
tasks = tasks.filter((t) => !excluded.has(t.id));
|
|
122
|
+
}
|
|
123
|
+
if (filter.limit !== undefined) {
|
|
124
|
+
tasks = tasks.slice(0, filter.limit);
|
|
125
|
+
}
|
|
126
|
+
return tasks;
|
|
127
|
+
}
|
|
128
|
+
// Worker state
|
|
129
|
+
async saveWorker(worker) {
|
|
130
|
+
this.workers.set(worker.id, { ...worker });
|
|
131
|
+
}
|
|
132
|
+
async getWorker(workerId) {
|
|
133
|
+
return this.workers.get(workerId) ?? null;
|
|
134
|
+
}
|
|
135
|
+
async listWorkers(filter) {
|
|
136
|
+
let workers = Array.from(this.workers.values());
|
|
137
|
+
if (filter?.status?.length) {
|
|
138
|
+
workers = workers.filter((w) => filter.status.includes(w.status));
|
|
139
|
+
}
|
|
140
|
+
if (filter?.connectionMode?.length) {
|
|
141
|
+
workers = workers.filter((w) => filter.connectionMode.includes(w.connectionMode));
|
|
142
|
+
}
|
|
143
|
+
return workers;
|
|
144
|
+
}
|
|
145
|
+
async deleteWorker(workerId) {
|
|
146
|
+
this.workers.delete(workerId);
|
|
147
|
+
}
|
|
148
|
+
// Atomic claim — single-threaded JS makes this safe without locking.
|
|
149
|
+
// The Redis adapter uses a Lua script for the same guarantee across processes.
|
|
150
|
+
async claimTask(taskId, workerId, cost) {
|
|
151
|
+
const worker = this.workers.get(workerId);
|
|
152
|
+
if (!worker || worker.usedSlots + cost > worker.capacity)
|
|
153
|
+
return false;
|
|
154
|
+
const task = this.tasks.get(taskId);
|
|
155
|
+
if (!task || (task.status !== 'pending' && task.status !== 'assigned'))
|
|
156
|
+
return false;
|
|
157
|
+
task.status = 'assigned';
|
|
158
|
+
task.assignedWorker = workerId;
|
|
159
|
+
task.cost = cost;
|
|
160
|
+
task.updatedAt = Date.now();
|
|
161
|
+
worker.usedSlots += cost;
|
|
162
|
+
return true;
|
|
163
|
+
}
|
|
164
|
+
// Worker assignments
|
|
165
|
+
async addAssignment(assignment) {
|
|
166
|
+
this.assignments.set(assignment.taskId, { ...assignment });
|
|
167
|
+
}
|
|
168
|
+
async removeAssignment(taskId) {
|
|
169
|
+
this.assignments.delete(taskId);
|
|
170
|
+
}
|
|
171
|
+
async getWorkerAssignments(workerId) {
|
|
172
|
+
return Array.from(this.assignments.values()).filter((a) => a.workerId === workerId);
|
|
173
|
+
}
|
|
174
|
+
async getTaskAssignment(taskId) {
|
|
175
|
+
return this.assignments.get(taskId) ?? null;
|
|
176
|
+
}
|
|
92
177
|
}
|
|
93
178
|
//# sourceMappingURL=memory-adapters.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"memory-adapters.js","sourceRoot":"","sources":["../src/memory-adapters.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"memory-adapters.js","sourceRoot":"","sources":["../src/memory-adapters.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"state-machine.d.ts","sourceRoot":"","sources":["../src/state-machine.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,iBAAiB,EAAE,SAAS,UAAU,EAKzC,CAAA;AAEV,eAAO,MAAM,kBAAkB,EAAE,SAAS,UAAU,EAG1C,CAAA;
|
|
1
|
+
{"version":3,"file":"state-machine.d.ts","sourceRoot":"","sources":["../src/state-machine.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,YAAY,CAAA;AAE5C,eAAO,MAAM,iBAAiB,EAAE,SAAS,UAAU,EAKzC,CAAA;AAEV,eAAO,MAAM,kBAAkB,EAAE,SAAS,UAAU,EAG1C,CAAA;AAcV,wBAAgB,aAAa,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,GAAG,OAAO,CAIvE;AAED,wBAAgB,eAAe,CAAC,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,GAAG,UAAU,CAK5E;AAED,wBAAgB,UAAU,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAEtD;AAED,wBAAgB,WAAW,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAEvD"}
|
package/dist/state-machine.js
CHANGED
|
@@ -9,10 +9,11 @@ export const SUSPENDED_STATUSES = [
|
|
|
9
9
|
'blocked',
|
|
10
10
|
];
|
|
11
11
|
const ALLOWED_TRANSITIONS = {
|
|
12
|
-
pending: ['running', 'cancelled'],
|
|
12
|
+
pending: ['assigned', 'running', 'paused', 'cancelled'],
|
|
13
|
+
assigned: ['running', 'pending', 'paused', 'cancelled'],
|
|
13
14
|
running: ['paused', 'blocked', 'completed', 'failed', 'timeout', 'cancelled'],
|
|
14
|
-
paused: ['running', 'blocked', 'cancelled'],
|
|
15
|
-
blocked: ['running', 'paused', 'cancelled', 'failed'],
|
|
15
|
+
paused: ['running', 'assigned', 'blocked', 'cancelled'],
|
|
16
|
+
blocked: ['running', 'assigned', 'paused', 'cancelled', 'failed'],
|
|
16
17
|
completed: [],
|
|
17
18
|
failed: [],
|
|
18
19
|
timeout: [],
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"state-machine.js","sourceRoot":"","sources":["../src/state-machine.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,iBAAiB,GAA0B;IACtD,WAAW;IACX,QAAQ;IACR,SAAS;IACT,WAAW;CACH,CAAA;AAEV,MAAM,CAAC,MAAM,kBAAkB,GAA0B;IACvD,QAAQ;IACR,SAAS;CACD,CAAA;AAEV,MAAM,mBAAmB,GAAqC;IAC5D,OAAO,EAAE,CAAC,SAAS,EAAE,WAAW,CAAC;
|
|
1
|
+
{"version":3,"file":"state-machine.js","sourceRoot":"","sources":["../src/state-machine.ts"],"names":[],"mappings":"AAEA,MAAM,CAAC,MAAM,iBAAiB,GAA0B;IACtD,WAAW;IACX,QAAQ;IACR,SAAS;IACT,WAAW;CACH,CAAA;AAEV,MAAM,CAAC,MAAM,kBAAkB,GAA0B;IACvD,QAAQ;IACR,SAAS;CACD,CAAA;AAEV,MAAM,mBAAmB,GAAqC;IAC5D,OAAO,EAAE,CAAC,UAAU,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,CAAC;IACvD,QAAQ,EAAE,CAAC,SAAS,EAAE,SAAS,EAAE,QAAQ,EAAE,WAAW,CAAC;IACvD,OAAO,EAAE,CAAC,QAAQ,EAAE,SAAS,EAAE,WAAW,EAAE,QAAQ,EAAE,SAAS,EAAE,WAAW,CAAC;IAC7E,MAAM,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,SAAS,EAAE,WAAW,CAAC;IACvD,OAAO,EAAE,CAAC,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,WAAW,EAAE,QAAQ,CAAC;IACjE,SAAS,EAAE,EAAE;IACb,MAAM,EAAE,EAAE;IACV,OAAO,EAAE,EAAE;IACX,SAAS,EAAE,EAAE;CACd,CAAA;AAED,MAAM,UAAU,aAAa,CAAC,IAAgB,EAAE,EAAc;IAC5D,IAAI,IAAI,KAAK,EAAE;QAAE,OAAO,KAAK,CAAA;IAC7B,yGAAyG;IACzG,OAAO,mBAAmB,CAAC,IAAI,CAAC,EAAE,QAAQ,CAAC,EAAE,CAAC,IAAI,KAAK,CAAA;AACzD,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,IAAgB,EAAE,EAAc;IAC9D,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,EAAE,CAAC,EAAE,CAAC;QAC7B,MAAM,IAAI,KAAK,CAAC,uBAAuB,IAAI,MAAM,EAAE,EAAE,CAAC,CAAA;IACxD,CAAC;IACD,OAAO,EAAE,CAAA;AACX,CAAC;AAED,MAAM,UAAU,UAAU,CAAC,MAAkB;IAC3C,OAAO,iBAAiB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;AAC3C,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,MAAkB;IAC5C,OAAO,kBAAkB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;AAC5C,CAAC"}
|
package/dist/types.d.ts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type TaskStatus = 'pending' | 'running' | 'paused' | 'blocked' | 'completed' | 'failed' | 'timeout' | 'cancelled';
|
|
1
|
+
export type TaskStatus = 'pending' | 'assigned' | 'running' | 'paused' | 'blocked' | 'completed' | 'failed' | 'timeout' | 'cancelled';
|
|
2
2
|
export interface TaskError {
|
|
3
3
|
code?: string;
|
|
4
4
|
message: string;
|
|
@@ -31,7 +31,7 @@ export interface RetryConfig {
|
|
|
31
31
|
}
|
|
32
32
|
export type SeriesMode = 'keep-all' | 'accumulate' | 'latest';
|
|
33
33
|
export type Level = 'debug' | 'info' | 'warn' | 'error';
|
|
34
|
-
export type PermissionScope = 'task:create' | 'task:manage' | 'event:publish' | 'event:subscribe' | 'event:history' | 'webhook:create' | '*';
|
|
34
|
+
export type PermissionScope = 'task:create' | 'task:manage' | 'event:publish' | 'event:subscribe' | 'event:history' | 'webhook:create' | 'worker:connect' | 'worker:manage' | '*';
|
|
35
35
|
export interface CleanupRule {
|
|
36
36
|
name?: string;
|
|
37
37
|
match?: {
|
|
@@ -49,6 +49,45 @@ export interface CleanupRule {
|
|
|
49
49
|
seriesMode?: SeriesMode[];
|
|
50
50
|
};
|
|
51
51
|
}
|
|
52
|
+
export type AssignMode = 'external' | 'pull' | 'ws-offer' | 'ws-race';
|
|
53
|
+
export type DisconnectPolicy = 'reassign' | 'mark' | 'fail';
|
|
54
|
+
export type WorkerStatus = 'idle' | 'busy' | 'draining' | 'offline';
|
|
55
|
+
export interface TagMatcher {
|
|
56
|
+
all?: string[];
|
|
57
|
+
any?: string[];
|
|
58
|
+
none?: string[];
|
|
59
|
+
}
|
|
60
|
+
export interface WorkerMatchRule {
|
|
61
|
+
taskTypes?: string[];
|
|
62
|
+
tags?: TagMatcher;
|
|
63
|
+
}
|
|
64
|
+
export interface Worker {
|
|
65
|
+
id: string;
|
|
66
|
+
status: WorkerStatus;
|
|
67
|
+
matchRule: WorkerMatchRule;
|
|
68
|
+
capacity: number;
|
|
69
|
+
usedSlots: number;
|
|
70
|
+
weight: number;
|
|
71
|
+
connectionMode: 'pull' | 'websocket';
|
|
72
|
+
connectedAt: number;
|
|
73
|
+
lastHeartbeatAt: number;
|
|
74
|
+
metadata?: Record<string, unknown>;
|
|
75
|
+
}
|
|
76
|
+
export type WorkerAssignmentStatus = 'offered' | 'assigned' | 'running';
|
|
77
|
+
export interface WorkerAssignment {
|
|
78
|
+
taskId: string;
|
|
79
|
+
workerId: string;
|
|
80
|
+
cost: number;
|
|
81
|
+
assignedAt: number;
|
|
82
|
+
status: WorkerAssignmentStatus;
|
|
83
|
+
}
|
|
84
|
+
export interface WorkerAuditEvent {
|
|
85
|
+
id: string;
|
|
86
|
+
workerId: string;
|
|
87
|
+
timestamp: number;
|
|
88
|
+
action: 'connected' | 'disconnected' | 'updated' | 'task_assigned' | 'task_declined' | 'task_reclaimed' | 'draining' | 'heartbeat_timeout' | 'pull_request';
|
|
89
|
+
data?: Record<string, unknown>;
|
|
90
|
+
}
|
|
52
91
|
export interface Task {
|
|
53
92
|
id: string;
|
|
54
93
|
type?: string;
|
|
@@ -66,6 +105,11 @@ export interface Task {
|
|
|
66
105
|
cleanup?: {
|
|
67
106
|
rules: CleanupRule[];
|
|
68
107
|
};
|
|
108
|
+
tags?: string[];
|
|
109
|
+
assignMode?: AssignMode;
|
|
110
|
+
cost?: number;
|
|
111
|
+
assignedWorker?: string;
|
|
112
|
+
disconnectPolicy?: DisconnectPolicy;
|
|
69
113
|
}
|
|
70
114
|
export interface TaskEvent {
|
|
71
115
|
id: string;
|
|
@@ -121,12 +165,36 @@ export interface ShortTermStore {
|
|
|
121
165
|
getSeriesLatest(taskId: string, seriesId: string): Promise<TaskEvent | null>;
|
|
122
166
|
setSeriesLatest(taskId: string, seriesId: string, event: TaskEvent): Promise<void>;
|
|
123
167
|
replaceLastSeriesEvent(taskId: string, seriesId: string, event: TaskEvent): Promise<void>;
|
|
168
|
+
listTasks(filter: TaskFilter): Promise<Task[]>;
|
|
169
|
+
saveWorker(worker: Worker): Promise<void>;
|
|
170
|
+
getWorker(workerId: string): Promise<Worker | null>;
|
|
171
|
+
listWorkers(filter?: WorkerFilter): Promise<Worker[]>;
|
|
172
|
+
deleteWorker(workerId: string): Promise<void>;
|
|
173
|
+
claimTask(taskId: string, workerId: string, cost: number): Promise<boolean>;
|
|
174
|
+
addAssignment(assignment: WorkerAssignment): Promise<void>;
|
|
175
|
+
removeAssignment(taskId: string): Promise<void>;
|
|
176
|
+
getWorkerAssignments(workerId: string): Promise<WorkerAssignment[]>;
|
|
177
|
+
getTaskAssignment(taskId: string): Promise<WorkerAssignment | null>;
|
|
124
178
|
}
|
|
125
179
|
export interface LongTermStore {
|
|
126
180
|
saveTask(task: Task): Promise<void>;
|
|
127
181
|
getTask(taskId: string): Promise<Task | null>;
|
|
128
182
|
saveEvent(event: TaskEvent): Promise<void>;
|
|
129
183
|
getEvents(taskId: string, opts?: EventQueryOptions): Promise<TaskEvent[]>;
|
|
184
|
+
saveWorkerEvent(event: WorkerAuditEvent): Promise<void>;
|
|
185
|
+
getWorkerEvents(workerId: string, opts?: EventQueryOptions): Promise<WorkerAuditEvent[]>;
|
|
186
|
+
}
|
|
187
|
+
export interface TaskFilter {
|
|
188
|
+
status?: TaskStatus[];
|
|
189
|
+
types?: string[];
|
|
190
|
+
tags?: TagMatcher;
|
|
191
|
+
assignMode?: AssignMode[];
|
|
192
|
+
excludeTaskIds?: string[];
|
|
193
|
+
limit?: number;
|
|
194
|
+
}
|
|
195
|
+
export interface WorkerFilter {
|
|
196
|
+
status?: WorkerStatus[];
|
|
197
|
+
connectionMode?: ('pull' | 'websocket')[];
|
|
130
198
|
}
|
|
131
199
|
export interface ErrorContext {
|
|
132
200
|
operation: string;
|
|
@@ -140,5 +208,11 @@ export interface TaskcastHooks {
|
|
|
140
208
|
onWebhookFailed?(config: WebhookConfig, err: unknown): void;
|
|
141
209
|
onSSEConnect?(taskId: string, clientId: string): void;
|
|
142
210
|
onSSEDisconnect?(taskId: string, clientId: string, duration: number): void;
|
|
211
|
+
onTaskCreated?(task: Task): void;
|
|
212
|
+
onTaskTransitioned?(task: Task, from: TaskStatus, to: TaskStatus): void;
|
|
213
|
+
onWorkerConnected?(worker: Worker): void;
|
|
214
|
+
onWorkerDisconnected?(worker: Worker, reason: string): void;
|
|
215
|
+
onTaskAssigned?(task: Task, worker: Worker): void;
|
|
216
|
+
onTaskDeclined?(task: Task, worker: Worker, blacklisted: boolean): void;
|
|
143
217
|
}
|
|
144
218
|
//# sourceMappingURL=types.d.ts.map
|
package/dist/types.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"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
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../src/types.ts"],"names":[],"mappings":"AAEA,MAAM,MAAM,UAAU,GAClB,SAAS,GACT,UAAU,GACV,SAAS,GACT,QAAQ,GACR,SAAS,GACT,WAAW,GACX,QAAQ,GACR,SAAS,GACT,WAAW,CAAA;AAEf,MAAM,WAAW,SAAS;IACxB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAClC;AAED,MAAM,WAAW,cAAc;IAC7B,KAAK,EAAE,KAAK,CAAC;QACX,KAAK,EAAE;YAAE,KAAK,EAAE,eAAe,EAAE,CAAA;SAAE,CAAA;QACnC,OAAO,EAAE;YACP,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;YAChC,GAAG,CAAC,EAAE,MAAM,EAAE,CAAA;SACf,CAAA;KACF,CAAC,CAAA;CACH;AAED,MAAM,WAAW,aAAa;IAC5B,GAAG,EAAE,MAAM,CAAA;IACX,MAAM,CAAC,EAAE,eAAe,CAAA;IACxB,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,KAAK,CAAC,EAAE,WAAW,CAAA;CACpB;AAED,MAAM,WAAW,WAAW;IAC1B,OAAO,EAAE,MAAM,CAAA;IACf,OAAO,EAAE,OAAO,GAAG,aAAa,GAAG,QAAQ,CAAA;IAC3C,cAAc,EAAE,MAAM,CAAA;IACtB,UAAU,EAAE,MAAM,CAAA;IAClB,SAAS,EAAE,MAAM,CAAA;CAClB;AAED,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,YAAY,GAAG,QAAQ,CAAA;AAE7D,MAAM,MAAM,KAAK,GAAG,OAAO,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,CAAA;AAEvD,MAAM,MAAM,eAAe,GACvB,aAAa,GACb,aAAa,GACb,eAAe,GACf,iBAAiB,GACjB,eAAe,GACf,gBAAgB,GAChB,gBAAgB,GAChB,eAAe,GACf,GAAG,CAAA;AAEP,MAAM,WAAW,WAAW;IAC1B,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,KAAK,CAAC,EAAE;QACN,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;QACpB,MAAM,CAAC,EAAE,UAAU,EAAE,CAAA;KACtB,CAAA;IACD,OAAO,EAAE;QACP,OAAO,CAAC,EAAE,MAAM,CAAA;KACjB,CAAA;IACD,MAAM,EAAE,KAAK,GAAG,QAAQ,GAAG,MAAM,CAAA;IACjC,WAAW,CAAC,EAAE;QACZ,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;QAChB,MAAM,CAAC,EAAE,KAAK,EAAE,CAAA;QAChB,WAAW,CAAC,EAAE,MAAM,CAAA;QACpB,UAAU,CAAC,EAAE,UAAU,EAAE,CAAA;KAC1B,CAAA;CACF;AAID,MAAM,MAAM,UAAU,GAAG,UAAU,GAAG,MAAM,GAAG,UAAU,GAAG,SAAS,CAAA;AAErE,MAAM,MAAM,gBAAgB,GAAG,UAAU,GAAG,MAAM,GAAG,MAAM,CAAA;AAE3D,MAAM,MAAM,YAAY,GAAG,MAAM,GAAG,MAAM,GAAG,UAAU,GAAG,SAAS,CAAA;AAEnE,MAAM,WAAW,UAAU;IACzB,GAAG,CAAC,EAAE,MAAM,EAAE,CAAA;IACd,GAAG,CAAC,EAAE,MAAM,EAAE,CAAA;IACd,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;CAChB;AAED,MAAM,WAAW,eAAe;IAC9B,SAAS,CAAC,EAAE,MAAM,EAAE,CAAA;IACpB,IAAI,CAAC,EAAE,UAAU,CAAA;CAClB;AAED,MAAM,WAAW,MAAM;IACrB,EAAE,EAAE,MAAM,CAAA;IACV,MAAM,EAAE,YAAY,CAAA;IACpB,SAAS,EAAE,eAAe,CAAA;IAC1B,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,EAAE,MAAM,CAAA;IACd,cAAc,EAAE,MAAM,GAAG,WAAW,CAAA;IACpC,WAAW,EAAE,MAAM,CAAA;IACnB,eAAe,EAAE,MAAM,CAAA;IACvB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CACnC;AAED,MAAM,MAAM,sBAAsB,GAAG,SAAS,GAAG,UAAU,GAAG,SAAS,CAAA;AAEvE,MAAM,WAAW,gBAAgB;IAC/B,MAAM,EAAE,MAAM,CAAA;IACd,QAAQ,EAAE,MAAM,CAAA;IAChB,IAAI,EAAE,MAAM,CAAA;IACZ,UAAU,EAAE,MAAM,CAAA;IAClB,MAAM,EAAE,sBAAsB,CAAA;CAC/B;AAED,MAAM,WAAW,gBAAgB;IAC/B,EAAE,EAAE,MAAM,CAAA;IACV,QAAQ,EAAE,MAAM,CAAA;IAChB,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,EACF,WAAW,GACX,cAAc,GACd,SAAS,GACT,eAAe,GACf,eAAe,GACf,gBAAgB,GAChB,UAAU,GACV,mBAAmB,GACnB,cAAc,CAAA;IAClB,IAAI,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;CAC/B;AAED,MAAM,WAAW,IAAI;IACnB,EAAE,EAAE,MAAM,CAAA;IACV,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,EAAE,UAAU,CAAA;IAClB,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC,MAAM,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAChC,KAAK,CAAC,EAAE,SAAS,CAAA;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,CAAA;IAClC,SAAS,EAAE,MAAM,CAAA;IACjB,SAAS,EAAE,MAAM,CAAA;IACjB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,GAAG,CAAC,EAAE,MAAM,CAAA;IACZ,UAAU,CAAC,EAAE,cAAc,CAAA;IAC3B,QAAQ,CAAC,EAAE,aAAa,EAAE,CAAA;IAC1B,OAAO,CAAC,EAAE;QAAE,KAAK,EAAE,WAAW,EAAE,CAAA;KAAE,CAAA;IAClC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAA;IACf,UAAU,CAAC,EAAE,UAAU,CAAA;IACvB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,gBAAgB,CAAC,EAAE,gBAAgB,CAAA;CACpC;AAID,MAAM,WAAW,SAAS;IACxB,EAAE,EAAE,MAAM,CAAA;IACV,MAAM,EAAE,MAAM,CAAA;IACd,KAAK,EAAE,MAAM,CAAA;IACb,SAAS,EAAE,MAAM,CAAA;IACjB,IAAI,EAAE,MAAM,CAAA;IACZ,KAAK,EAAE,KAAK,CAAA;IACZ,IAAI,EAAE,OAAO,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,UAAU,CAAA;CACxB;AAED,MAAM,WAAW,WAAW;IAC1B,aAAa,EAAE,MAAM,CAAA;IACrB,QAAQ,EAAE,MAAM,CAAA;IAChB,OAAO,EAAE,MAAM,CAAA;IACf,MAAM,EAAE,MAAM,CAAA;IACd,IAAI,EAAE,MAAM,CAAA;IACZ,SAAS,EAAE,MAAM,CAAA;IACjB,KAAK,EAAE,KAAK,CAAA;IACZ,IAAI,EAAE,OAAO,CAAA;IACb,QAAQ,CAAC,EAAE,MAAM,CAAA;IACjB,UAAU,CAAC,EAAE,UAAU,CAAA;CACxB;AAID,MAAM,WAAW,WAAW;IAC1B,EAAE,CAAC,EAAE,MAAM,CAAA;IACX,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,SAAS,CAAC,EAAE,MAAM,CAAA;CACnB;AAED,MAAM,WAAW,eAAe;IAC9B,KAAK,CAAC,EAAE,WAAW,CAAA;IACnB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,MAAM,CAAC,EAAE,KAAK,EAAE,CAAA;IAChB,aAAa,CAAC,EAAE,OAAO,CAAA;IACvB,IAAI,CAAC,EAAE,OAAO,CAAA;CACf;AAED,MAAM,WAAW,iBAAiB;IAChC,KAAK,CAAC,EAAE,WAAW,CAAA;IACnB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAID,MAAM,WAAW,iBAAiB;IAChC,OAAO,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACzD,SAAS,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,CAAC,KAAK,EAAE,SAAS,KAAK,IAAI,GAAG,MAAM,IAAI,CAAA;CAC5E;AAED,MAAM,WAAW,cAAc;IAC7B,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACnC,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAA;IAC7C,4DAA4D;IAC5D,SAAS,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;IAC1C,WAAW,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC5D,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC,CAAA;IACzE,MAAM,CAAC,MAAM,EAAE,MAAM,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACzD,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,CAAA;IAC5E,eAAe,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAClF,sBAAsB,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAGzF,SAAS,CAAC,MAAM,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,EAAE,CAAC,CAAA;IAG9C,UAAU,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACzC,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IACnD,WAAW,CAAC,MAAM,CAAC,EAAE,YAAY,GAAG,OAAO,CAAC,MAAM,EAAE,CAAC,CAAA;IACrD,YAAY,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAG7C,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAA;IAG3E,aAAa,CAAC,UAAU,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC1D,gBAAgB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC/C,oBAAoB,CAAC,QAAQ,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAA;IACnE,iBAAiB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,gBAAgB,GAAG,IAAI,CAAC,CAAA;CACpE;AAED,MAAM,WAAW,aAAa;IAC5B,QAAQ,CAAC,IAAI,EAAE,IAAI,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACnC,OAAO,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,GAAG,IAAI,CAAC,CAAA;IAC7C,SAAS,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IAC1C,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC,CAAA;IACzE,eAAe,CAAC,KAAK,EAAE,gBAAgB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAA;IACvD,eAAe,CAAC,QAAQ,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,iBAAiB,GAAG,OAAO,CAAC,gBAAgB,EAAE,CAAC,CAAA;CACzF;AAED,MAAM,WAAW,UAAU;IACzB,MAAM,CAAC,EAAE,UAAU,EAAE,CAAA;IACrB,KAAK,CAAC,EAAE,MAAM,EAAE,CAAA;IAChB,IAAI,CAAC,EAAE,UAAU,CAAA;IACjB,UAAU,CAAC,EAAE,UAAU,EAAE,CAAA;IACzB,cAAc,CAAC,EAAE,MAAM,EAAE,CAAA;IACzB,KAAK,CAAC,EAAE,MAAM,CAAA;CACf;AAED,MAAM,WAAW,YAAY;IAC3B,MAAM,CAAC,EAAE,YAAY,EAAE,CAAA;IACvB,cAAc,CAAC,EAAE,CAAC,MAAM,GAAG,WAAW,CAAC,EAAE,CAAA;CAC1C;AAID,MAAM,WAAW,YAAY;IAC3B,SAAS,EAAE,MAAM,CAAA;IACjB,MAAM,CAAC,EAAE,MAAM,CAAA;CAChB;AAED,MAAM,WAAW,aAAa;IAC5B,YAAY,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI,CAAA;IACjD,aAAa,CAAC,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,CAAA;IAChC,gBAAgB,CAAC,CAAC,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,YAAY,GAAG,IAAI,CAAA;IAC5D,cAAc,CAAC,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACvD,eAAe,CAAC,CAAC,MAAM,EAAE,aAAa,EAAE,GAAG,EAAE,OAAO,GAAG,IAAI,CAAA;IAC3D,YAAY,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IACrD,eAAe,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAA;IAC1E,aAAa,CAAC,CAAC,IAAI,EAAE,IAAI,GAAG,IAAI,CAAA;IAChC,kBAAkB,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,UAAU,EAAE,EAAE,EAAE,UAAU,GAAG,IAAI,CAAA;IACvE,iBAAiB,CAAC,CAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACxC,oBAAoB,CAAC,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IAC3D,cAAc,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAAA;IACjD,cAAc,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,WAAW,EAAE,OAAO,GAAG,IAAI,CAAA;CACxE"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import type { Task, Worker, WorkerFilter, WorkerAssignment, BroadcastProvider, ShortTermStore, LongTermStore, TaskcastHooks, AssignMode, DisconnectPolicy, WorkerMatchRule } from './types.js';
|
|
2
|
+
import type { TaskEngine } from './engine.js';
|
|
3
|
+
export interface WorkerManagerOptions {
|
|
4
|
+
engine: TaskEngine;
|
|
5
|
+
shortTermStore: ShortTermStore;
|
|
6
|
+
broadcast: BroadcastProvider;
|
|
7
|
+
longTermStore?: LongTermStore;
|
|
8
|
+
hooks?: TaskcastHooks;
|
|
9
|
+
defaults?: WorkerManagerDefaults;
|
|
10
|
+
}
|
|
11
|
+
export interface WorkerManagerDefaults {
|
|
12
|
+
assignMode?: AssignMode;
|
|
13
|
+
heartbeatIntervalMs?: number;
|
|
14
|
+
heartbeatTimeoutMs?: number;
|
|
15
|
+
offerTimeoutMs?: number;
|
|
16
|
+
disconnectPolicy?: DisconnectPolicy;
|
|
17
|
+
disconnectGraceMs?: number;
|
|
18
|
+
}
|
|
19
|
+
export interface WorkerRegistration {
|
|
20
|
+
id?: string;
|
|
21
|
+
matchRule: WorkerMatchRule;
|
|
22
|
+
capacity: number;
|
|
23
|
+
weight?: number;
|
|
24
|
+
connectionMode: Worker['connectionMode'];
|
|
25
|
+
metadata?: Record<string, unknown>;
|
|
26
|
+
}
|
|
27
|
+
export interface WorkerUpdate {
|
|
28
|
+
weight?: number;
|
|
29
|
+
capacity?: number;
|
|
30
|
+
matchRule?: WorkerMatchRule;
|
|
31
|
+
status?: 'draining';
|
|
32
|
+
}
|
|
33
|
+
export interface DispatchResult {
|
|
34
|
+
matched: boolean;
|
|
35
|
+
workerId?: string;
|
|
36
|
+
}
|
|
37
|
+
export interface ClaimResult {
|
|
38
|
+
success: boolean;
|
|
39
|
+
reason?: string;
|
|
40
|
+
}
|
|
41
|
+
export interface DeclineOptions {
|
|
42
|
+
blacklist?: boolean;
|
|
43
|
+
}
|
|
44
|
+
export declare class WorkerManager {
|
|
45
|
+
private opts;
|
|
46
|
+
private engine;
|
|
47
|
+
private shortTermStore;
|
|
48
|
+
private longTermStore?;
|
|
49
|
+
private hooks?;
|
|
50
|
+
constructor(opts: WorkerManagerOptions);
|
|
51
|
+
get heartbeatIntervalMs(): number;
|
|
52
|
+
private emitTaskAudit;
|
|
53
|
+
private emitWorkerAudit;
|
|
54
|
+
registerWorker(config: WorkerRegistration): Promise<Worker>;
|
|
55
|
+
unregisterWorker(workerId: string): Promise<void>;
|
|
56
|
+
updateWorker(workerId: string, update: WorkerUpdate): Promise<Worker | null>;
|
|
57
|
+
heartbeat(workerId: string): Promise<void>;
|
|
58
|
+
getWorker(workerId: string): Promise<Worker | null>;
|
|
59
|
+
listWorkers(filter?: WorkerFilter): Promise<Worker[]>;
|
|
60
|
+
dispatchTask(taskId: string): Promise<DispatchResult>;
|
|
61
|
+
claimTask(taskId: string, workerId: string): Promise<ClaimResult>;
|
|
62
|
+
declineTask(taskId: string, workerId: string, opts?: DeclineOptions): Promise<void>;
|
|
63
|
+
getWorkerTasks(workerId: string): Promise<WorkerAssignment[]>;
|
|
64
|
+
waitForTask(workerId: string, signal?: AbortSignal): Promise<Task>;
|
|
65
|
+
notifyNewTask(taskId: string): Promise<void>;
|
|
66
|
+
}
|
|
67
|
+
//# sourceMappingURL=worker-manager.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-manager.d.ts","sourceRoot":"","sources":["../src/worker-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,312 @@
|
|
|
1
|
+
import { ulid } from 'ulidx';
|
|
2
|
+
import { matchesWorkerRule } from './worker-matching.js';
|
|
3
|
+
// ─── WorkerManager ──────────────────────────────────────────────────────────
|
|
4
|
+
export class WorkerManager {
|
|
5
|
+
opts;
|
|
6
|
+
engine;
|
|
7
|
+
shortTermStore;
|
|
8
|
+
longTermStore;
|
|
9
|
+
hooks;
|
|
10
|
+
constructor(opts) {
|
|
11
|
+
this.opts = opts;
|
|
12
|
+
this.engine = opts.engine;
|
|
13
|
+
this.shortTermStore = opts.shortTermStore;
|
|
14
|
+
if (opts.longTermStore)
|
|
15
|
+
this.longTermStore = opts.longTermStore;
|
|
16
|
+
if (opts.hooks)
|
|
17
|
+
this.hooks = opts.hooks;
|
|
18
|
+
}
|
|
19
|
+
get heartbeatIntervalMs() {
|
|
20
|
+
return this.opts.defaults?.heartbeatIntervalMs ?? 30_000;
|
|
21
|
+
}
|
|
22
|
+
// ─── Audit Helpers ──────────────────────────────────────────────────────
|
|
23
|
+
async emitTaskAudit(taskId, action, extra) {
|
|
24
|
+
try {
|
|
25
|
+
await this.opts.engine.publishEvent(taskId, {
|
|
26
|
+
type: 'taskcast:audit',
|
|
27
|
+
level: 'info',
|
|
28
|
+
data: { action, ...extra },
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
catch {
|
|
32
|
+
// Task may be in terminal state or not found; audit is best-effort
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
emitWorkerAudit(action, workerId, data) {
|
|
36
|
+
if (!this.opts.longTermStore)
|
|
37
|
+
return;
|
|
38
|
+
const event = {
|
|
39
|
+
id: ulid(),
|
|
40
|
+
workerId,
|
|
41
|
+
timestamp: Date.now(),
|
|
42
|
+
action,
|
|
43
|
+
...(data !== undefined && { data }),
|
|
44
|
+
};
|
|
45
|
+
this.opts.longTermStore.saveWorkerEvent(event).catch(() => { });
|
|
46
|
+
}
|
|
47
|
+
// ─── Worker Registration & Lifecycle ────────────────────────────────────
|
|
48
|
+
async registerWorker(config) {
|
|
49
|
+
const now = Date.now();
|
|
50
|
+
const worker = {
|
|
51
|
+
id: config.id ?? ulid(),
|
|
52
|
+
status: 'idle',
|
|
53
|
+
matchRule: config.matchRule,
|
|
54
|
+
capacity: config.capacity,
|
|
55
|
+
usedSlots: 0,
|
|
56
|
+
weight: config.weight ?? 50,
|
|
57
|
+
connectionMode: config.connectionMode,
|
|
58
|
+
connectedAt: now,
|
|
59
|
+
lastHeartbeatAt: now,
|
|
60
|
+
...(config.metadata !== undefined && { metadata: config.metadata }),
|
|
61
|
+
};
|
|
62
|
+
await this.shortTermStore.saveWorker(worker);
|
|
63
|
+
this.emitWorkerAudit('connected', worker.id);
|
|
64
|
+
this.hooks?.onWorkerConnected?.(worker);
|
|
65
|
+
return worker;
|
|
66
|
+
}
|
|
67
|
+
async unregisterWorker(workerId) {
|
|
68
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
69
|
+
await this.shortTermStore.deleteWorker(workerId);
|
|
70
|
+
if (worker) {
|
|
71
|
+
this.emitWorkerAudit('disconnected', workerId, { reason: 'unregistered' });
|
|
72
|
+
this.hooks?.onWorkerDisconnected?.(worker, 'unregistered');
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
async updateWorker(workerId, update) {
|
|
76
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
77
|
+
if (!worker)
|
|
78
|
+
return null;
|
|
79
|
+
if (update.weight !== undefined)
|
|
80
|
+
worker.weight = update.weight;
|
|
81
|
+
if (update.capacity !== undefined)
|
|
82
|
+
worker.capacity = update.capacity;
|
|
83
|
+
if (update.matchRule !== undefined)
|
|
84
|
+
worker.matchRule = update.matchRule;
|
|
85
|
+
if (update.status !== undefined)
|
|
86
|
+
worker.status = update.status;
|
|
87
|
+
await this.shortTermStore.saveWorker(worker);
|
|
88
|
+
return worker;
|
|
89
|
+
}
|
|
90
|
+
async heartbeat(workerId) {
|
|
91
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
92
|
+
if (!worker)
|
|
93
|
+
return;
|
|
94
|
+
worker.lastHeartbeatAt = Date.now();
|
|
95
|
+
await this.shortTermStore.saveWorker(worker);
|
|
96
|
+
}
|
|
97
|
+
async getWorker(workerId) {
|
|
98
|
+
return this.shortTermStore.getWorker(workerId);
|
|
99
|
+
}
|
|
100
|
+
async listWorkers(filter) {
|
|
101
|
+
return this.shortTermStore.listWorkers(filter);
|
|
102
|
+
}
|
|
103
|
+
// ─── Task Dispatch ─────────────────────────────────────────────────────
|
|
104
|
+
async dispatchTask(taskId) {
|
|
105
|
+
const task = await this.engine.getTask(taskId);
|
|
106
|
+
if (!task || task.status !== 'pending') {
|
|
107
|
+
return { matched: false };
|
|
108
|
+
}
|
|
109
|
+
const blacklist = task.metadata?._blacklistedWorkers ?? [];
|
|
110
|
+
const workers = await this.shortTermStore.listWorkers({ status: ['idle', 'busy'] });
|
|
111
|
+
const taskCost = task.cost ?? 1;
|
|
112
|
+
const candidates = workers.filter((w) => {
|
|
113
|
+
if (blacklist.includes(w.id))
|
|
114
|
+
return false;
|
|
115
|
+
if (w.usedSlots + taskCost > w.capacity)
|
|
116
|
+
return false;
|
|
117
|
+
if (!matchesWorkerRule(task, w.matchRule))
|
|
118
|
+
return false;
|
|
119
|
+
return true;
|
|
120
|
+
});
|
|
121
|
+
if (candidates.length === 0) {
|
|
122
|
+
return { matched: false };
|
|
123
|
+
}
|
|
124
|
+
// Sort: weight desc → available slots desc → connectedAt asc
|
|
125
|
+
candidates.sort((a, b) => {
|
|
126
|
+
if (b.weight !== a.weight)
|
|
127
|
+
return b.weight - a.weight;
|
|
128
|
+
const aAvailable = a.capacity - a.usedSlots;
|
|
129
|
+
const bAvailable = b.capacity - b.usedSlots;
|
|
130
|
+
if (bAvailable !== aAvailable)
|
|
131
|
+
return bAvailable - aAvailable;
|
|
132
|
+
return a.connectedAt - b.connectedAt;
|
|
133
|
+
});
|
|
134
|
+
return { matched: true, workerId: candidates[0].id };
|
|
135
|
+
}
|
|
136
|
+
// ─── Task Claim ────────────────────────────────────────────────────────
|
|
137
|
+
async claimTask(taskId, workerId) {
|
|
138
|
+
const task = await this.engine.getTask(taskId);
|
|
139
|
+
if (!task) {
|
|
140
|
+
return { success: false, reason: 'Task not found' };
|
|
141
|
+
}
|
|
142
|
+
if (task.status !== 'pending') {
|
|
143
|
+
return { success: false, reason: `Task is not pending (status: ${task.status})` };
|
|
144
|
+
}
|
|
145
|
+
const cost = task.cost ?? 1;
|
|
146
|
+
const claimed = await this.shortTermStore.claimTask(taskId, workerId, cost);
|
|
147
|
+
if (!claimed) {
|
|
148
|
+
return { success: false, reason: 'Claim failed (concurrent modification)' };
|
|
149
|
+
}
|
|
150
|
+
// claimTask atomically sets status to 'assigned' and assignedWorker on the
|
|
151
|
+
// store. Re-read to get the authoritative state, then persist to longTermStore.
|
|
152
|
+
const updatedTask = (await this.shortTermStore.getTask(taskId));
|
|
153
|
+
if (this.longTermStore)
|
|
154
|
+
await this.longTermStore.saveTask(updatedTask);
|
|
155
|
+
// Emit audit events for the claim
|
|
156
|
+
this.emitWorkerAudit('task_assigned', workerId, { taskId });
|
|
157
|
+
await this.emitTaskAudit(taskId, 'assigned', { workerId });
|
|
158
|
+
// Create assignment record
|
|
159
|
+
const assignment = {
|
|
160
|
+
taskId,
|
|
161
|
+
workerId,
|
|
162
|
+
cost,
|
|
163
|
+
assignedAt: Date.now(),
|
|
164
|
+
status: 'assigned',
|
|
165
|
+
};
|
|
166
|
+
await this.shortTermStore.addAssignment(assignment);
|
|
167
|
+
// Update worker status (usedSlots already updated by claimTask)
|
|
168
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
169
|
+
if (worker) {
|
|
170
|
+
worker.status = worker.usedSlots >= worker.capacity ? 'busy' : 'idle';
|
|
171
|
+
await this.shortTermStore.saveWorker(worker);
|
|
172
|
+
this.hooks?.onTaskAssigned?.(updatedTask, worker);
|
|
173
|
+
}
|
|
174
|
+
return { success: true };
|
|
175
|
+
}
|
|
176
|
+
// ─── Task Decline ──────────────────────────────────────────────────────
|
|
177
|
+
async declineTask(taskId, workerId, opts) {
|
|
178
|
+
const assignment = await this.shortTermStore.getTaskAssignment(taskId);
|
|
179
|
+
if (!assignment || assignment.workerId !== workerId)
|
|
180
|
+
return;
|
|
181
|
+
// Remove assignment
|
|
182
|
+
await this.shortTermStore.removeAssignment(taskId);
|
|
183
|
+
// Restore worker capacity
|
|
184
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
185
|
+
if (worker) {
|
|
186
|
+
worker.usedSlots = Math.max(0, worker.usedSlots - assignment.cost);
|
|
187
|
+
worker.status = 'idle';
|
|
188
|
+
await this.shortTermStore.saveWorker(worker);
|
|
189
|
+
}
|
|
190
|
+
// Transition task back to pending
|
|
191
|
+
await this.engine.transitionTask(taskId, 'pending');
|
|
192
|
+
// Emit audit events for the decline
|
|
193
|
+
const blacklisted = opts?.blacklist ?? false;
|
|
194
|
+
this.emitWorkerAudit('task_declined', workerId, { taskId });
|
|
195
|
+
await this.emitTaskAudit(taskId, 'declined', { workerId, blacklisted });
|
|
196
|
+
// Clear assignedWorker
|
|
197
|
+
const task = await this.engine.getTask(taskId);
|
|
198
|
+
if (task) {
|
|
199
|
+
delete task.assignedWorker;
|
|
200
|
+
// Add to blacklist if requested
|
|
201
|
+
if (opts?.blacklist) {
|
|
202
|
+
const metadata = task.metadata ?? {};
|
|
203
|
+
const existing = metadata._blacklistedWorkers ?? [];
|
|
204
|
+
metadata._blacklistedWorkers = [...existing, workerId];
|
|
205
|
+
task.metadata = metadata;
|
|
206
|
+
}
|
|
207
|
+
await this.shortTermStore.saveTask(task);
|
|
208
|
+
if (this.longTermStore)
|
|
209
|
+
await this.longTermStore.saveTask(task);
|
|
210
|
+
if (worker) {
|
|
211
|
+
this.hooks?.onTaskDeclined?.(task, worker, blacklisted);
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
// ─── Worker Tasks ──────────────────────────────────────────────────────
|
|
216
|
+
async getWorkerTasks(workerId) {
|
|
217
|
+
return this.shortTermStore.getWorkerAssignments(workerId);
|
|
218
|
+
}
|
|
219
|
+
// ─── Pull Mode (Long-Poll) ─────────────────────────────────────────────
|
|
220
|
+
async waitForTask(workerId, signal) {
|
|
221
|
+
const worker = await this.shortTermStore.getWorker(workerId);
|
|
222
|
+
if (!worker)
|
|
223
|
+
throw new Error(`Worker not found: ${workerId}`);
|
|
224
|
+
// Check if already aborted
|
|
225
|
+
if (signal?.aborted) {
|
|
226
|
+
throw new Error('aborted');
|
|
227
|
+
}
|
|
228
|
+
// Check existing pending pull tasks
|
|
229
|
+
const pendingTasks = await this.shortTermStore.listTasks({ status: ['pending'], assignMode: ['pull'] });
|
|
230
|
+
const blacklist = new Set();
|
|
231
|
+
for (const task of pendingTasks) {
|
|
232
|
+
const taskBlacklist = task.metadata?._blacklistedWorkers ?? [];
|
|
233
|
+
if (taskBlacklist.includes(workerId))
|
|
234
|
+
continue;
|
|
235
|
+
if (!matchesWorkerRule(task, worker.matchRule))
|
|
236
|
+
continue;
|
|
237
|
+
const taskCost = task.cost ?? 1;
|
|
238
|
+
if (worker.usedSlots + taskCost > worker.capacity)
|
|
239
|
+
continue;
|
|
240
|
+
const result = await this.claimTask(task.id, workerId);
|
|
241
|
+
if (result.success) {
|
|
242
|
+
this.emitWorkerAudit('pull_request', workerId, { matched: true, taskId: task.id });
|
|
243
|
+
const claimed = await this.engine.getTask(task.id);
|
|
244
|
+
return claimed;
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
// Wait for a new task notification via broadcast
|
|
248
|
+
return new Promise((resolve, reject) => {
|
|
249
|
+
let unsubscribe;
|
|
250
|
+
const cleanup = () => {
|
|
251
|
+
unsubscribe?.();
|
|
252
|
+
signal?.removeEventListener('abort', onAbort);
|
|
253
|
+
};
|
|
254
|
+
const onAbort = () => {
|
|
255
|
+
cleanup();
|
|
256
|
+
this.emitWorkerAudit('pull_request', workerId, { matched: false });
|
|
257
|
+
reject(new Error('aborted'));
|
|
258
|
+
};
|
|
259
|
+
if (signal) {
|
|
260
|
+
signal.addEventListener('abort', onAbort);
|
|
261
|
+
}
|
|
262
|
+
unsubscribe = this.opts.broadcast.subscribe('taskcast:worker:new-task', async (event) => {
|
|
263
|
+
const taskId = event.data;
|
|
264
|
+
try {
|
|
265
|
+
// Re-fetch the worker to get current state
|
|
266
|
+
const currentWorker = await this.shortTermStore.getWorker(workerId);
|
|
267
|
+
if (!currentWorker) {
|
|
268
|
+
cleanup();
|
|
269
|
+
reject(new Error(`Worker not found: ${workerId}`));
|
|
270
|
+
return;
|
|
271
|
+
}
|
|
272
|
+
const task = await this.engine.getTask(taskId);
|
|
273
|
+
if (!task || task.status !== 'pending')
|
|
274
|
+
return;
|
|
275
|
+
if (task.assignMode !== 'pull')
|
|
276
|
+
return;
|
|
277
|
+
const taskBlacklist = task.metadata?._blacklistedWorkers ?? [];
|
|
278
|
+
if (taskBlacklist.includes(workerId))
|
|
279
|
+
return;
|
|
280
|
+
if (!matchesWorkerRule(task, currentWorker.matchRule))
|
|
281
|
+
return;
|
|
282
|
+
const taskCost = task.cost ?? 1;
|
|
283
|
+
if (currentWorker.usedSlots + taskCost > currentWorker.capacity)
|
|
284
|
+
return;
|
|
285
|
+
const result = await this.claimTask(taskId, workerId);
|
|
286
|
+
if (result.success) {
|
|
287
|
+
cleanup();
|
|
288
|
+
this.emitWorkerAudit('pull_request', workerId, { matched: true, taskId });
|
|
289
|
+
const claimed = await this.engine.getTask(taskId);
|
|
290
|
+
resolve(claimed);
|
|
291
|
+
}
|
|
292
|
+
}
|
|
293
|
+
catch {
|
|
294
|
+
// Ignore errors from individual task checks
|
|
295
|
+
}
|
|
296
|
+
});
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
async notifyNewTask(taskId) {
|
|
300
|
+
const event = {
|
|
301
|
+
id: ulid(),
|
|
302
|
+
taskId: 'system',
|
|
303
|
+
index: 0,
|
|
304
|
+
timestamp: Date.now(),
|
|
305
|
+
type: 'taskcast:worker:new-task',
|
|
306
|
+
level: 'info',
|
|
307
|
+
data: taskId,
|
|
308
|
+
};
|
|
309
|
+
await this.opts.broadcast.publish('taskcast:worker:new-task', event);
|
|
310
|
+
}
|
|
311
|
+
}
|
|
312
|
+
//# sourceMappingURL=worker-manager.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-manager.js","sourceRoot":"","sources":["../src/worker-manager.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import type { Task, TagMatcher, WorkerMatchRule } from './types.js';
|
|
2
|
+
/**
|
|
3
|
+
* Checks if a set of task tags matches a TagMatcher.
|
|
4
|
+
*
|
|
5
|
+
* - `all`: every tag in `all` must exist in taskTags
|
|
6
|
+
* - `any`: at least one tag in `any` must exist in taskTags
|
|
7
|
+
* - `none`: none of the tags in `none` may exist in taskTags
|
|
8
|
+
* - Empty/undefined matcher matches everything
|
|
9
|
+
* - Undefined taskTags treated as empty array
|
|
10
|
+
* - Empty arrays in matcher fields are vacuous true
|
|
11
|
+
*/
|
|
12
|
+
export declare function matchesTag(taskTags: string[] | undefined, matcher: TagMatcher): boolean;
|
|
13
|
+
/**
|
|
14
|
+
* Checks if a task matches a WorkerMatchRule.
|
|
15
|
+
*
|
|
16
|
+
* - If rule has `taskTypes`: task.type must match using wildcard matching
|
|
17
|
+
* - If rule has `tags`: use matchesTag
|
|
18
|
+
* - Both conditions are AND'd
|
|
19
|
+
* - Empty/no rule matches everything
|
|
20
|
+
* - Task with no `type` does not match if rule has `taskTypes`
|
|
21
|
+
*/
|
|
22
|
+
export declare function matchesWorkerRule(task: Task, rule: WorkerMatchRule): boolean;
|
|
23
|
+
//# sourceMappingURL=worker-matching.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-matching.d.ts","sourceRoot":"","sources":["../src/worker-matching.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,UAAU,EAAE,eAAe,EAAE,MAAM,YAAY,CAAA;AAGnE;;;;;;;;;GASG;AACH,wBAAgB,UAAU,CAAC,QAAQ,EAAE,MAAM,EAAE,GAAG,SAAS,EAAE,OAAO,EAAE,UAAU,GAAG,OAAO,CAgBvF;AAED;;;;;;;;GAQG;AACH,wBAAgB,iBAAiB,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,eAAe,GAAG,OAAO,CAW5E"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { matchesType } from './filter.js';
|
|
2
|
+
/**
|
|
3
|
+
* Checks if a set of task tags matches a TagMatcher.
|
|
4
|
+
*
|
|
5
|
+
* - `all`: every tag in `all` must exist in taskTags
|
|
6
|
+
* - `any`: at least one tag in `any` must exist in taskTags
|
|
7
|
+
* - `none`: none of the tags in `none` may exist in taskTags
|
|
8
|
+
* - Empty/undefined matcher matches everything
|
|
9
|
+
* - Undefined taskTags treated as empty array
|
|
10
|
+
* - Empty arrays in matcher fields are vacuous true
|
|
11
|
+
*/
|
|
12
|
+
export function matchesTag(taskTags, matcher) {
|
|
13
|
+
const tags = taskTags ?? [];
|
|
14
|
+
if (matcher.all !== undefined && matcher.all.length > 0) {
|
|
15
|
+
if (!matcher.all.every((tag) => tags.includes(tag)))
|
|
16
|
+
return false;
|
|
17
|
+
}
|
|
18
|
+
if (matcher.any !== undefined && matcher.any.length > 0) {
|
|
19
|
+
if (!matcher.any.some((tag) => tags.includes(tag)))
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (matcher.none !== undefined && matcher.none.length > 0) {
|
|
23
|
+
if (matcher.none.some((tag) => tags.includes(tag)))
|
|
24
|
+
return false;
|
|
25
|
+
}
|
|
26
|
+
return true;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Checks if a task matches a WorkerMatchRule.
|
|
30
|
+
*
|
|
31
|
+
* - If rule has `taskTypes`: task.type must match using wildcard matching
|
|
32
|
+
* - If rule has `tags`: use matchesTag
|
|
33
|
+
* - Both conditions are AND'd
|
|
34
|
+
* - Empty/no rule matches everything
|
|
35
|
+
* - Task with no `type` does not match if rule has `taskTypes`
|
|
36
|
+
*/
|
|
37
|
+
export function matchesWorkerRule(task, rule) {
|
|
38
|
+
if (rule.taskTypes !== undefined && rule.taskTypes.length > 0) {
|
|
39
|
+
if (task.type === undefined)
|
|
40
|
+
return false;
|
|
41
|
+
if (!matchesType(task.type, rule.taskTypes))
|
|
42
|
+
return false;
|
|
43
|
+
}
|
|
44
|
+
if (rule.tags !== undefined) {
|
|
45
|
+
if (!matchesTag(task.tags, rule.tags))
|
|
46
|
+
return false;
|
|
47
|
+
}
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
//# sourceMappingURL=worker-matching.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"worker-matching.js","sourceRoot":"","sources":["../src/worker-matching.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,aAAa,CAAA;AAEzC;;;;;;;;;GASG;AACH,MAAM,UAAU,UAAU,CAAC,QAA8B,EAAE,OAAmB;IAC5E,MAAM,IAAI,GAAG,QAAQ,IAAI,EAAE,CAAA;IAE3B,IAAI,OAAO,CAAC,GAAG,KAAK,SAAS,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAAE,OAAO,KAAK,CAAA;IACnE,CAAC;IAED,IAAI,OAAO,CAAC,GAAG,KAAK,SAAS,IAAI,OAAO,CAAC,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QACxD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAAE,OAAO,KAAK,CAAA;IAClE,CAAC;IAED,IAAI,OAAO,CAAC,IAAI,KAAK,SAAS,IAAI,OAAO,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1D,IAAI,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAAE,OAAO,KAAK,CAAA;IAClE,CAAC;IAED,OAAO,IAAI,CAAA;AACb,CAAC;AAED;;;;;;;;GAQG;AACH,MAAM,UAAU,iBAAiB,CAAC,IAAU,EAAE,IAAqB;IACjE,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC9D,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS;YAAE,OAAO,KAAK,CAAA;QACzC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC;YAAE,OAAO,KAAK,CAAA;IAC3D,CAAC;IAED,IAAI,IAAI,CAAC,IAAI,KAAK,SAAS,EAAE,CAAC;QAC5B,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC;YAAE,OAAO,KAAK,CAAA;IACrD,CAAC;IAED,OAAO,IAAI,CAAA;AACb,CAAC"}
|