convex-effect-workflows 0.1.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/README.md +107 -0
- package/dist/client/ConvexCtx.d.ts +12 -0
- package/dist/client/ConvexCtx.d.ts.map +1 -0
- package/dist/client/ConvexCtx.js +6 -0
- package/dist/client/ConvexCtx.js.map +1 -0
- package/dist/client/ConvexLogger.d.ts +7 -0
- package/dist/client/ConvexLogger.d.ts.map +1 -0
- package/dist/client/ConvexLogger.js +39 -0
- package/dist/client/ConvexLogger.js.map +1 -0
- package/dist/client/ConvexTracer.d.ts +7 -0
- package/dist/client/ConvexTracer.d.ts.map +1 -0
- package/dist/client/ConvexTracer.js +60 -0
- package/dist/client/ConvexTracer.js.map +1 -0
- package/dist/client/ConvexWorkflowEngine.d.ts +308 -0
- package/dist/client/ConvexWorkflowEngine.d.ts.map +1 -0
- package/dist/client/ConvexWorkflowEngine.js +88 -0
- package/dist/client/ConvexWorkflowEngine.js.map +1 -0
- package/dist/client/activityWorker.d.ts +23 -0
- package/dist/client/activityWorker.d.ts.map +1 -0
- package/dist/client/activityWorker.js +41 -0
- package/dist/client/activityWorker.js.map +1 -0
- package/dist/client/boundaries.d.ts +27 -0
- package/dist/client/boundaries.d.ts.map +1 -0
- package/dist/client/boundaries.js +17 -0
- package/dist/client/boundaries.js.map +1 -0
- package/dist/client/encoded.d.ts +22 -0
- package/dist/client/encoded.d.ts.map +1 -0
- package/dist/client/encoded.js +276 -0
- package/dist/client/encoded.js.map +1 -0
- package/dist/client/index.d.ts +13 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +11 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/registry.d.ts +17 -0
- package/dist/client/registry.d.ts.map +1 -0
- package/dist/client/registry.js +21 -0
- package/dist/client/registry.js.map +1 -0
- package/dist/client/runner.d.ts +27 -0
- package/dist/client/runner.d.ts.map +1 -0
- package/dist/client/runner.js +90 -0
- package/dist/client/runner.js.map +1 -0
- package/dist/client/runtime.d.ts +10 -0
- package/dist/client/runtime.d.ts.map +1 -0
- package/dist/client/runtime.js +15 -0
- package/dist/client/runtime.js.map +1 -0
- package/dist/component/_generated/api.d.ts +148 -0
- package/dist/component/_generated/api.d.ts.map +1 -0
- package/dist/component/_generated/api.js +31 -0
- package/dist/component/_generated/api.js.map +1 -0
- package/dist/component/_generated/component.d.ts +921 -0
- package/dist/component/_generated/component.d.ts.map +1 -0
- package/dist/component/_generated/component.js +11 -0
- package/dist/component/_generated/component.js.map +1 -0
- package/dist/component/_generated/dataModel.d.ts +46 -0
- package/dist/component/_generated/dataModel.d.ts.map +1 -0
- package/dist/component/_generated/dataModel.js +11 -0
- package/dist/component/_generated/dataModel.js.map +1 -0
- package/dist/component/_generated/server.d.ts +121 -0
- package/dist/component/_generated/server.d.ts.map +1 -0
- package/dist/component/_generated/server.js +78 -0
- package/dist/component/_generated/server.js.map +1 -0
- package/dist/component/activityCompletions.d.ts +27 -0
- package/dist/component/activityCompletions.d.ts.map +1 -0
- package/dist/component/activityCompletions.js +70 -0
- package/dist/component/activityCompletions.js.map +1 -0
- package/dist/component/boundaries.d.ts +20 -0
- package/dist/component/boundaries.d.ts.map +1 -0
- package/dist/component/boundaries.js +17 -0
- package/dist/component/boundaries.js.map +1 -0
- package/dist/component/cleanup.d.ts +11 -0
- package/dist/component/cleanup.d.ts.map +1 -0
- package/dist/component/cleanup.js +163 -0
- package/dist/component/cleanup.js.map +1 -0
- package/dist/component/clocks.d.ts +12 -0
- package/dist/component/clocks.d.ts.map +1 -0
- package/dist/component/clocks.js +26 -0
- package/dist/component/clocks.js.map +1 -0
- package/dist/component/config.d.ts +25 -0
- package/dist/component/config.d.ts.map +1 -0
- package/dist/component/config.js +110 -0
- package/dist/component/config.js.map +1 -0
- package/dist/component/convex.config.d.ts +3 -0
- package/dist/component/convex.config.d.ts.map +1 -0
- package/dist/component/convex.config.js +6 -0
- package/dist/component/convex.config.js.map +1 -0
- package/dist/component/dashboard.d.ts +268 -0
- package/dist/component/dashboard.d.ts.map +1 -0
- package/dist/component/dashboard.js +622 -0
- package/dist/component/dashboard.js.map +1 -0
- package/dist/component/deferreds.d.ts +31 -0
- package/dist/component/deferreds.d.ts.map +1 -0
- package/dist/component/deferreds.js +138 -0
- package/dist/component/deferreds.js.map +1 -0
- package/dist/component/executions.d.ts +77 -0
- package/dist/component/executions.d.ts.map +1 -0
- package/dist/component/executions.js +186 -0
- package/dist/component/executions.js.map +1 -0
- package/dist/component/journalSteps.d.ts +261 -0
- package/dist/component/journalSteps.d.ts.map +1 -0
- package/dist/component/journalSteps.js +203 -0
- package/dist/component/journalSteps.js.map +1 -0
- package/dist/component/logs.d.ts +68 -0
- package/dist/component/logs.d.ts.map +1 -0
- package/dist/component/logs.js +123 -0
- package/dist/component/logs.js.map +1 -0
- package/dist/component/onComplete.d.ts +31 -0
- package/dist/component/onComplete.d.ts.map +1 -0
- package/dist/component/onComplete.js +146 -0
- package/dist/component/onComplete.js.map +1 -0
- package/dist/component/payloads.d.ts +26 -0
- package/dist/component/payloads.d.ts.map +1 -0
- package/dist/component/payloads.js +57 -0
- package/dist/component/payloads.js.map +1 -0
- package/dist/component/queries.d.ts +2 -0
- package/dist/component/queries.d.ts.map +1 -0
- package/dist/component/queries.js +2 -0
- package/dist/component/queries.js.map +1 -0
- package/dist/component/runner.d.ts +31 -0
- package/dist/component/runner.d.ts.map +1 -0
- package/dist/component/runner.js +87 -0
- package/dist/component/runner.js.map +1 -0
- package/dist/component/schema.d.ts +282 -0
- package/dist/component/schema.d.ts.map +1 -0
- package/dist/component/schema.js +119 -0
- package/dist/component/schema.js.map +1 -0
- package/dist/component/spans.d.ts +105 -0
- package/dist/component/spans.d.ts.map +1 -0
- package/dist/component/spans.js +190 -0
- package/dist/component/spans.js.map +1 -0
- package/dist/component/utils.d.ts +15 -0
- package/dist/component/utils.d.ts.map +1 -0
- package/dist/component/utils.js +53 -0
- package/dist/component/utils.js.map +1 -0
- package/dist/shared/constants.d.ts +12 -0
- package/dist/shared/constants.d.ts.map +1 -0
- package/dist/shared/constants.js +12 -0
- package/dist/shared/constants.js.map +1 -0
- package/dist/shared/validators.d.ts +69 -0
- package/dist/shared/validators.d.ts.map +1 -0
- package/dist/shared/validators.js +30 -0
- package/dist/shared/validators.js.map +1 -0
- package/package.json +74 -0
- package/src/client/ConvexCtx.ts +21 -0
- package/src/client/ConvexLogger.ts +52 -0
- package/src/client/ConvexTracer.ts +75 -0
- package/src/client/ConvexWorkflowEngine.test.ts +124 -0
- package/src/client/ConvexWorkflowEngine.ts +209 -0
- package/src/client/activityWorker.ts +62 -0
- package/src/client/boundaries.test.ts +83 -0
- package/src/client/boundaries.ts +79 -0
- package/src/client/encoded.lifecycle.test.ts +336 -0
- package/src/client/encoded.test.ts +153 -0
- package/src/client/encoded.ts +484 -0
- package/src/client/index.ts +47 -0
- package/src/client/registry.ts +35 -0
- package/src/client/runner.ts +165 -0
- package/src/client/runtime.ts +30 -0
- package/src/component/_generated/api.ts +179 -0
- package/src/component/_generated/component.ts +1216 -0
- package/src/component/_generated/dataModel.ts +60 -0
- package/src/component/_generated/server.ts +156 -0
- package/src/component/activityCompletions.ts +73 -0
- package/src/component/boundaries.ts +55 -0
- package/src/component/cleanup.test.ts +219 -0
- package/src/component/cleanup.ts +218 -0
- package/src/component/clocks.ts +26 -0
- package/src/component/config.test.ts +159 -0
- package/src/component/config.ts +145 -0
- package/src/component/convex.config.ts +7 -0
- package/src/component/core.test.ts +829 -0
- package/src/component/dashboard.scaling.test.ts +268 -0
- package/src/component/dashboard.ts +743 -0
- package/src/component/deferreds.ts +162 -0
- package/src/component/executions.ts +225 -0
- package/src/component/journalSteps.ts +252 -0
- package/src/component/logs.ts +152 -0
- package/src/component/onComplete.ts +170 -0
- package/src/component/payloads.ts +83 -0
- package/src/component/queries.ts +8 -0
- package/src/component/runner.ts +122 -0
- package/src/component/schema.ts +155 -0
- package/src/component/setup.test.ts +15 -0
- package/src/component/spans.ts +241 -0
- package/src/component/utils.test.ts +32 -0
- package/src/component/utils.ts +73 -0
- package/src/shared/constants.test.ts +14 -0
- package/src/shared/constants.ts +15 -0
- package/src/shared/validators.ts +98 -0
- package/src/test.d.ts +8 -0
- package/src/test.ts +17 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConvexWorkflowEngine.js","sourceRoot":"","sources":["../../src/client/ConvexWorkflowEngine.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
export declare const activityWorkerArgs: {
|
|
2
|
+
workflowName: import("convex/values").VString<string, "required">;
|
|
3
|
+
activityName: import("convex/values").VString<string, "required">;
|
|
4
|
+
executionId: import("convex/values").VString<string, "required">;
|
|
5
|
+
attempt: import("convex/values").VFloat64<number, "required">;
|
|
6
|
+
};
|
|
7
|
+
export declare function runRegisteredActivity(args: {
|
|
8
|
+
workflowName: string;
|
|
9
|
+
activityName: string;
|
|
10
|
+
executionId: string;
|
|
11
|
+
attempt: number;
|
|
12
|
+
}): Promise<any>;
|
|
13
|
+
/**
|
|
14
|
+
* Create an app-local internal action worker that can execute registered activities.
|
|
15
|
+
*/
|
|
16
|
+
export declare function defineActivityWorker(): import("convex/server").RegisteredAction<"internal", {
|
|
17
|
+
executionId: string;
|
|
18
|
+
workflowName: string;
|
|
19
|
+
attempt: number;
|
|
20
|
+
activityName: string;
|
|
21
|
+
}, Promise<any>>;
|
|
22
|
+
export type ActivityWorkerReference = ReturnType<typeof defineActivityWorker>;
|
|
23
|
+
//# sourceMappingURL=activityWorker.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activityWorker.d.ts","sourceRoot":"","sources":["../../src/client/activityWorker.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,kBAAkB;;;;;CAK9B,CAAC;AAEF,wBAAsB,qBAAqB,CAAC,IAAI,EAAE;IAChD,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,WAAW,EAAE,MAAM,CAAC;IACpB,OAAO,EAAE,MAAM,CAAC;CACjB,gBA2BA;AAED;;GAEG;AACH,wBAAgB,oBAAoB;;;;;iBAOnC;AAED,MAAM,MAAM,uBAAuB,GAAG,UAAU,CAAC,OAAO,oBAAoB,CAAC,CAAC"}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
import * as Effect from "effect/Effect";
|
|
2
|
+
import * as Exit from "effect/Exit";
|
|
3
|
+
import { internalActionGeneric } from "convex/server";
|
|
4
|
+
import { v } from "convex/values";
|
|
5
|
+
import { WorkflowInstance } from "@effect/workflow/WorkflowEngine";
|
|
6
|
+
import * as Activity from "@effect/workflow/Activity";
|
|
7
|
+
import { getActivity, getWorkflow } from "./registry.js";
|
|
8
|
+
export const activityWorkerArgs = {
|
|
9
|
+
workflowName: v.string(),
|
|
10
|
+
activityName: v.string(),
|
|
11
|
+
executionId: v.string(),
|
|
12
|
+
attempt: v.number(),
|
|
13
|
+
};
|
|
14
|
+
export async function runRegisteredActivity(args) {
|
|
15
|
+
const workflowEntry = getWorkflow(args.workflowName);
|
|
16
|
+
if (!workflowEntry) {
|
|
17
|
+
throw new Error(`Workflow not registered: ${args.workflowName}`);
|
|
18
|
+
}
|
|
19
|
+
const activity = getActivity(args.activityName);
|
|
20
|
+
if (!activity) {
|
|
21
|
+
throw new Error(`Activity not registered: ${args.activityName}`);
|
|
22
|
+
}
|
|
23
|
+
const instance = WorkflowInstance.initial(workflowEntry.workflow, args.executionId);
|
|
24
|
+
const exit = await Effect.runPromiseExit(activity.executeEncoded.pipe(Effect.provideService(WorkflowInstance, instance), Effect.provideService(Activity.CurrentAttempt, args.attempt)));
|
|
25
|
+
if (Exit.isSuccess(exit)) {
|
|
26
|
+
return exit.value;
|
|
27
|
+
}
|
|
28
|
+
throw new Error(String(exit.cause));
|
|
29
|
+
}
|
|
30
|
+
/**
|
|
31
|
+
* Create an app-local internal action worker that can execute registered activities.
|
|
32
|
+
*/
|
|
33
|
+
export function defineActivityWorker() {
|
|
34
|
+
return internalActionGeneric({
|
|
35
|
+
args: activityWorkerArgs,
|
|
36
|
+
handler: async (_ctx, args) => {
|
|
37
|
+
return await runRegisteredActivity(args);
|
|
38
|
+
},
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
//# sourceMappingURL=activityWorker.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"activityWorker.js","sourceRoot":"","sources":["../../src/client/activityWorker.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAC;AACxC,OAAO,KAAK,IAAI,MAAM,aAAa,CAAC;AACpC,OAAO,EAAE,qBAAqB,EAAE,MAAM,eAAe,CAAC;AACtD,OAAO,EAAE,CAAC,EAAE,MAAM,eAAe,CAAC;AAClC,OAAO,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AACnE,OAAO,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAEzD,MAAM,CAAC,MAAM,kBAAkB,GAAG;IAChC,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE;IACxB,YAAY,EAAE,CAAC,CAAC,MAAM,EAAE;IACxB,WAAW,EAAE,CAAC,CAAC,MAAM,EAAE;IACvB,OAAO,EAAE,CAAC,CAAC,MAAM,EAAE;CACpB,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,qBAAqB,CAAC,IAK3C;IACC,MAAM,aAAa,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACrD,IAAI,CAAC,aAAa,EAAE,CAAC;QACnB,MAAM,IAAI,KAAK,CAAC,4BAA4B,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IACnE,CAAC;IACD,MAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAChD,IAAI,CAAC,QAAQ,EAAE,CAAC;QACd,MAAM,IAAI,KAAK,CAAC,4BAA4B,IAAI,CAAC,YAAY,EAAE,CAAC,CAAC;IACnE,CAAC;IAED,MAAM,QAAQ,GAAG,gBAAgB,CAAC,OAAO,CACvC,aAAa,CAAC,QAAQ,EACtB,IAAI,CAAC,WAAW,CACjB,CAAC;IAEF,MAAM,IAAI,GAAG,MAAM,MAAM,CAAC,cAAc,CACtC,QAAQ,CAAC,cAAc,CAAC,IAAI,CAC1B,MAAM,CAAC,cAAc,CAAC,gBAAgB,EAAE,QAAQ,CAAC,EACjD,MAAM,CAAC,cAAc,CAAC,QAAQ,CAAC,cAAuB,EAAE,IAAI,CAAC,OAAO,CAAC,CACtE,CACF,CAAC;IAEF,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC;QACzB,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;IAED,MAAM,IAAI,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;AACtC,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,oBAAoB;IAClC,OAAO,qBAAqB,CAAC;QAC3B,IAAI,EAAE,kBAAkB;QACxB,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE;YAC5B,OAAO,MAAM,qBAAqB,CAAC,IAAI,CAAC,CAAC;QAC3C,CAAC;KACF,CAAC,CAAC;AACL,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import type { GenericDataModel, GenericMutationCtx } from "convex/server";
|
|
2
|
+
import type { WorkpoolOptions } from "@convex-dev/workpool";
|
|
3
|
+
import type { ComponentApi } from "../component/_generated/component.js";
|
|
4
|
+
import type { RunnerArgs, RunnerHandle } from "./ConvexWorkflowEngine.js";
|
|
5
|
+
type Scheduler = Pick<GenericMutationCtx<GenericDataModel>, "scheduler">["scheduler"];
|
|
6
|
+
type MutationRun = Pick<GenericMutationCtx<GenericDataModel>, "runMutation">["runMutation"];
|
|
7
|
+
export type EnqueueActivityArgs = {
|
|
8
|
+
executionId: string;
|
|
9
|
+
generation: number;
|
|
10
|
+
workflowName: string;
|
|
11
|
+
activityName: string;
|
|
12
|
+
attempt: number;
|
|
13
|
+
stepNumber: number;
|
|
14
|
+
spanId?: string;
|
|
15
|
+
activityWorkerHandle: string;
|
|
16
|
+
workpoolOptions?: WorkpoolOptions;
|
|
17
|
+
};
|
|
18
|
+
export declare function serializeRunnerHandle(handle: RunnerHandle): string;
|
|
19
|
+
export declare function enqueueActivity(runMutation: MutationRun, component: ComponentApi, args: EnqueueActivityArgs): Promise<any>;
|
|
20
|
+
export declare function scheduleRunnerFanIn(scheduler: Scheduler, component: ComponentApi, args: RunnerArgs): Promise<import("convex/values").GenericId<"_scheduled_functions">>;
|
|
21
|
+
export declare function scheduleDeferredCompletion(scheduler: Scheduler, component: ComponentApi, runAfterMs: number, args: {
|
|
22
|
+
executionId: string;
|
|
23
|
+
deferredName: string;
|
|
24
|
+
exit: unknown;
|
|
25
|
+
}): Promise<import("convex/values").GenericId<"_scheduled_functions">>;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=boundaries.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"boundaries.d.ts","sourceRoot":"","sources":["../../src/client/boundaries.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAEV,gBAAgB,EAChB,kBAAkB,EACnB,MAAM,eAAe,CAAC;AACvB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AACzE,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAE1E,KAAK,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,gBAAgB,CAAC,EAAE,WAAW,CAAC,CAAC,WAAW,CAAC,CAAC;AAUtF,KAAK,WAAW,GAAG,IAAI,CACrB,kBAAkB,CAAC,gBAAgB,CAAC,EACpC,aAAa,CACd,CAAC,aAAa,CAAC,CAAC;AAQjB,MAAM,MAAM,mBAAmB,GAAG;IAChC,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,oBAAoB,EAAE,MAAM,CAAC;IAC7B,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,CAAC;AAEF,wBAAgB,qBAAqB,CAAC,MAAM,EAAE,YAAY,GAAG,MAAM,CAElE;AAED,wBAAgB,eAAe,CAC7B,WAAW,EAAE,WAAW,EACxB,SAAS,EAAE,YAAY,EACvB,IAAI,EAAE,mBAAmB,gBAI1B;AAED,wBAAgB,mBAAmB,CACjC,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,YAAY,EACvB,IAAI,EAAE,UAAU,sEAGjB;AAED,wBAAgB,0BAA0B,CACxC,SAAS,EAAE,SAAS,EACpB,SAAS,EAAE,YAAY,EACvB,UAAU,EAAE,MAAM,EAClB,IAAI,EAAE;IACJ,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,IAAI,EAAE,OAAO,CAAC;CACf,sEAOF"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
function asMutationRef(reference) {
|
|
2
|
+
return reference;
|
|
3
|
+
}
|
|
4
|
+
export function serializeRunnerHandle(handle) {
|
|
5
|
+
return handle;
|
|
6
|
+
}
|
|
7
|
+
export function enqueueActivity(runMutation, component, args) {
|
|
8
|
+
const reference = component.runner.enqueueActivity;
|
|
9
|
+
return runMutation(asMutationRef(reference), args);
|
|
10
|
+
}
|
|
11
|
+
export function scheduleRunnerFanIn(scheduler, component, args) {
|
|
12
|
+
return scheduler.runAfter(0, asMutationRef(component.runner.run), args);
|
|
13
|
+
}
|
|
14
|
+
export function scheduleDeferredCompletion(scheduler, component, runAfterMs, args) {
|
|
15
|
+
return scheduler.runAfter(runAfterMs, asMutationRef(component.deferreds.deferredDone), args);
|
|
16
|
+
}
|
|
17
|
+
//# sourceMappingURL=boundaries.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"boundaries.js","sourceRoot":"","sources":["../../src/client/boundaries.ts"],"names":[],"mappings":"AAeA,SAAS,aAAa,CAAC,SAAkB;IACvC,OAAO,SAAwB,CAAC;AAClC,CAAC;AAyBD,MAAM,UAAU,qBAAqB,CAAC,MAAoB;IACxD,OAAO,MAA2B,CAAC;AACrC,CAAC;AAED,MAAM,UAAU,eAAe,CAC7B,WAAwB,EACxB,SAAuB,EACvB,IAAyB;IAEzB,MAAM,SAAS,GAAI,SAA0C,CAAC,MAAM,CAAC,eAAe,CAAC;IACrF,OAAO,WAAW,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,IAAI,CAAC,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,mBAAmB,CACjC,SAAoB,EACpB,SAAuB,EACvB,IAAgB;IAEhB,OAAO,SAAS,CAAC,QAAQ,CAAC,CAAC,EAAE,aAAa,CAAC,SAAS,CAAC,MAAM,CAAC,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC;AAC1E,CAAC;AAED,MAAM,UAAU,0BAA0B,CACxC,SAAoB,EACpB,SAAuB,EACvB,UAAkB,EAClB,IAIC;IAED,OAAO,SAAS,CAAC,QAAQ,CACvB,UAAU,EACV,aAAa,CAAC,SAAS,CAAC,SAAS,CAAC,YAAY,CAAC,EAC/C,IAAI,CACL,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import * as Workflow from "@effect/workflow/Workflow";
|
|
2
|
+
import type * as Activity from "@effect/workflow/Activity";
|
|
3
|
+
import { type Encoded } from "@effect/workflow/WorkflowEngine";
|
|
4
|
+
import type { ComponentApi } from "../component/_generated/component.js";
|
|
5
|
+
import { type ConvexWorkflowCtx } from "./ConvexCtx.js";
|
|
6
|
+
export type RunnerEnqueueArgs = {
|
|
7
|
+
workflow: Workflow.Any;
|
|
8
|
+
executionId: string;
|
|
9
|
+
generation: number;
|
|
10
|
+
};
|
|
11
|
+
export type ActivityEnqueueArgs = RunnerEnqueueArgs & {
|
|
12
|
+
activity: Activity.Any;
|
|
13
|
+
stepNumber: number;
|
|
14
|
+
spanId: string;
|
|
15
|
+
attempt: number;
|
|
16
|
+
};
|
|
17
|
+
export type ConvexEncodedHooks = {
|
|
18
|
+
enqueueRunner: (ctx: ConvexWorkflowCtx, args: RunnerEnqueueArgs) => Promise<void>;
|
|
19
|
+
enqueueActivity: (ctx: ConvexWorkflowCtx, args: ActivityEnqueueArgs) => Promise<string>;
|
|
20
|
+
};
|
|
21
|
+
export declare function makeConvexEncoded(component: ComponentApi, hooks: ConvexEncodedHooks): Encoded;
|
|
22
|
+
//# sourceMappingURL=encoded.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoded.d.ts","sourceRoot":"","sources":["../../src/client/encoded.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AACtD,OAAO,KAAK,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AAE3D,OAAO,EACL,KAAK,OAAO,EAGb,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AAEzE,OAAO,EAAa,KAAK,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAqBnE,MAAM,MAAM,iBAAiB,GAAG;IAC9B,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC;IACvB,WAAW,EAAE,MAAM,CAAC;IACpB,UAAU,EAAE,MAAM,CAAC;CACpB,CAAC;AAEF,MAAM,MAAM,mBAAmB,GAAG,iBAAiB,GAAG;IACpD,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC;IACvB,UAAU,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,MAAM,CAAC;CACjB,CAAC;AAEF,MAAM,MAAM,kBAAkB,GAAG;IAC/B,aAAa,EAAE,CAAC,GAAG,EAAE,iBAAiB,EAAE,IAAI,EAAE,iBAAiB,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAClF,eAAe,EAAE,CACf,GAAG,EAAE,iBAAiB,EACtB,IAAI,EAAE,mBAAmB,KACtB,OAAO,CAAC,MAAM,CAAC,CAAC;CACtB,CAAC;AAyGF,wBAAgB,iBAAiB,CAC/B,SAAS,EAAE,YAAY,EACvB,KAAK,EAAE,kBAAkB,GACxB,OAAO,CAiUT"}
|
|
@@ -0,0 +1,276 @@
|
|
|
1
|
+
import * as Context from "effect/Context";
|
|
2
|
+
import * as Duration from "effect/Duration";
|
|
3
|
+
import * as Effect from "effect/Effect";
|
|
4
|
+
import * as Exit from "effect/Exit";
|
|
5
|
+
import * as Workflow from "@effect/workflow/Workflow";
|
|
6
|
+
import { WorkflowEngine, WorkflowInstance, } from "@effect/workflow/WorkflowEngine";
|
|
7
|
+
import { ConvexCtx } from "./ConvexCtx.js";
|
|
8
|
+
import { scheduleDeferredCompletion } from "./boundaries.js";
|
|
9
|
+
const ReplayStateTag = Context.GenericTag("convex-effect-workflows/ReplayState");
|
|
10
|
+
function signaturesMatch(a, b) {
|
|
11
|
+
return JSON.stringify(a) === JSON.stringify(b);
|
|
12
|
+
}
|
|
13
|
+
function asExecuteOptions(options) {
|
|
14
|
+
return options;
|
|
15
|
+
}
|
|
16
|
+
function asDeferredDoneOptions(options) {
|
|
17
|
+
return options;
|
|
18
|
+
}
|
|
19
|
+
function asScheduleClockOptions(options) {
|
|
20
|
+
return options;
|
|
21
|
+
}
|
|
22
|
+
function toStepResult(step) {
|
|
23
|
+
const runResult = step?.runResult;
|
|
24
|
+
if (!runResult) {
|
|
25
|
+
return new Workflow.Suspended({});
|
|
26
|
+
}
|
|
27
|
+
if (runResult.kind === "success") {
|
|
28
|
+
return new Workflow.Complete({ exit: Exit.succeed(runResult.valuePreview) });
|
|
29
|
+
}
|
|
30
|
+
if (runResult.kind === "failed") {
|
|
31
|
+
return new Workflow.Complete({ exit: Exit.fail(runResult.error) });
|
|
32
|
+
}
|
|
33
|
+
return new Workflow.Complete({ exit: Exit.fail("canceled") });
|
|
34
|
+
}
|
|
35
|
+
function toExecutionTerminal(execution) {
|
|
36
|
+
if (!execution)
|
|
37
|
+
return undefined;
|
|
38
|
+
if (execution.status === "completed") {
|
|
39
|
+
return new Workflow.Complete({ exit: Exit.succeed(execution.resultPreview) });
|
|
40
|
+
}
|
|
41
|
+
if (execution.status === "failed" || execution.status === "interrupted") {
|
|
42
|
+
return new Workflow.Complete({
|
|
43
|
+
exit: Exit.fail(execution.error ?? "Workflow failed"),
|
|
44
|
+
});
|
|
45
|
+
}
|
|
46
|
+
return undefined;
|
|
47
|
+
}
|
|
48
|
+
function readExecution(ctx, component, executionId) {
|
|
49
|
+
return ctx.runQuery(component.executions.getExecution, { executionId });
|
|
50
|
+
}
|
|
51
|
+
function readJournalSteps(ctx, component, executionId) {
|
|
52
|
+
return ctx.runQuery(component.journalSteps.loadJournalForExecution, {
|
|
53
|
+
executionId,
|
|
54
|
+
});
|
|
55
|
+
}
|
|
56
|
+
function readPayload(ctx, component, payloadId) {
|
|
57
|
+
const runQueryPayload = ctx.runQuery;
|
|
58
|
+
return runQueryPayload(component.payloads.getPayload, { payloadId });
|
|
59
|
+
}
|
|
60
|
+
export function makeConvexEncoded(component, hooks) {
|
|
61
|
+
const workflows = new Map();
|
|
62
|
+
const encoded = {
|
|
63
|
+
register: Effect.fnUntraced(function* (workflow, execute) {
|
|
64
|
+
workflows.set(workflow.name, {
|
|
65
|
+
workflow,
|
|
66
|
+
execute: execute,
|
|
67
|
+
});
|
|
68
|
+
}),
|
|
69
|
+
execute: Effect.fnUntraced(function* (workflow, options) {
|
|
70
|
+
const convex = yield* ConvexCtx;
|
|
71
|
+
const executeOptions = asExecuteOptions(options);
|
|
72
|
+
const created = yield* Effect.promise(() => convex.runMutation(component.executions.createExecution, {
|
|
73
|
+
workflowName: workflow.name,
|
|
74
|
+
executionId: executeOptions.executionId,
|
|
75
|
+
payload: executeOptions.payload,
|
|
76
|
+
parentExecutionId: executeOptions.parent?.executionId,
|
|
77
|
+
}));
|
|
78
|
+
if (executeOptions.discard) {
|
|
79
|
+
if (created.created) {
|
|
80
|
+
yield* Effect.promise(() => hooks.enqueueRunner(convex, {
|
|
81
|
+
workflow,
|
|
82
|
+
executionId: executeOptions.executionId,
|
|
83
|
+
generation: 0,
|
|
84
|
+
}));
|
|
85
|
+
}
|
|
86
|
+
return;
|
|
87
|
+
}
|
|
88
|
+
const execution = yield* Effect.promise(() => readExecution(convex, component, executeOptions.executionId));
|
|
89
|
+
if (!execution) {
|
|
90
|
+
return new Workflow.Complete({
|
|
91
|
+
exit: Exit.fail(`Execution not found: ${executeOptions.executionId}`),
|
|
92
|
+
});
|
|
93
|
+
}
|
|
94
|
+
const terminal = toExecutionTerminal(execution);
|
|
95
|
+
if (terminal) {
|
|
96
|
+
return terminal;
|
|
97
|
+
}
|
|
98
|
+
yield* Effect.promise(() => convex.runMutation(component.executions.setExecutionRunning, {
|
|
99
|
+
executionId: executeOptions.executionId,
|
|
100
|
+
generation: execution.generation,
|
|
101
|
+
}));
|
|
102
|
+
const replaySteps = yield* Effect.promise(() => readJournalSteps(convex, component, executeOptions.executionId));
|
|
103
|
+
const registered = workflows.get(workflow.name);
|
|
104
|
+
if (!registered) {
|
|
105
|
+
yield* Effect.promise(() => convex.runMutation(component.executions.completeExecution, {
|
|
106
|
+
executionId: executeOptions.executionId,
|
|
107
|
+
generation: execution.generation,
|
|
108
|
+
kind: "failure",
|
|
109
|
+
error: `Workflow not registered: ${workflow.name}`,
|
|
110
|
+
}));
|
|
111
|
+
return new Workflow.Complete({
|
|
112
|
+
exit: Exit.fail(`Workflow not registered: ${workflow.name}`),
|
|
113
|
+
});
|
|
114
|
+
}
|
|
115
|
+
const engine = yield* WorkflowEngine;
|
|
116
|
+
const instance = WorkflowInstance.initial(workflow, executeOptions.executionId);
|
|
117
|
+
let payload = execution.payloadPreview;
|
|
118
|
+
const payloadRef = execution.payloadRef;
|
|
119
|
+
if (payloadRef) {
|
|
120
|
+
const payloadDoc = yield* Effect.promise(() => readPayload(convex, component, payloadRef));
|
|
121
|
+
payload = payloadDoc?.data ?? execution.payloadPreview;
|
|
122
|
+
}
|
|
123
|
+
const replayState = { steps: replaySteps, cursor: 0 };
|
|
124
|
+
const result = yield* registered.execute(payload, executeOptions.executionId).pipe(Workflow.intoResult, Effect.provideService(ReplayStateTag, replayState), Effect.provideService(WorkflowInstance, instance), Effect.provideService(WorkflowEngine, engine));
|
|
125
|
+
if (result._tag === "Complete") {
|
|
126
|
+
yield* Exit.match(result.exit, {
|
|
127
|
+
onSuccess: (value) => Effect.promise(() => convex.runMutation(component.executions.completeExecution, {
|
|
128
|
+
executionId: executeOptions.executionId,
|
|
129
|
+
generation: execution.generation,
|
|
130
|
+
kind: "success",
|
|
131
|
+
result: value,
|
|
132
|
+
})),
|
|
133
|
+
onFailure: (cause) => Effect.promise(() => convex.runMutation(component.executions.completeExecution, {
|
|
134
|
+
executionId: executeOptions.executionId,
|
|
135
|
+
generation: execution.generation,
|
|
136
|
+
kind: "failure",
|
|
137
|
+
error: String(cause),
|
|
138
|
+
})),
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
else {
|
|
142
|
+
yield* Effect.promise(() => convex.runMutation(component.executions.setExecutionSuspended, {
|
|
143
|
+
executionId: executeOptions.executionId,
|
|
144
|
+
generation: execution.generation,
|
|
145
|
+
}));
|
|
146
|
+
}
|
|
147
|
+
return result;
|
|
148
|
+
}),
|
|
149
|
+
poll: Effect.fnUntraced(function* (_workflow, executionId) {
|
|
150
|
+
const convex = yield* ConvexCtx;
|
|
151
|
+
const execution = yield* Effect.promise(() => readExecution(convex, component, executionId));
|
|
152
|
+
return toExecutionTerminal(execution);
|
|
153
|
+
}),
|
|
154
|
+
interrupt: Effect.fnUntraced(function* (_workflow, executionId) {
|
|
155
|
+
const convex = yield* ConvexCtx;
|
|
156
|
+
yield* Effect.promise(() => convex.runMutation(component.executions.interruptExecution, {
|
|
157
|
+
executionId,
|
|
158
|
+
reason: "Interrupted",
|
|
159
|
+
}));
|
|
160
|
+
}),
|
|
161
|
+
resume: Effect.fnUntraced(function* (workflow, executionId) {
|
|
162
|
+
const convex = yield* ConvexCtx;
|
|
163
|
+
const execution = yield* Effect.promise(() => readExecution(convex, component, executionId));
|
|
164
|
+
if (!execution || execution.status === "interrupted") {
|
|
165
|
+
return;
|
|
166
|
+
}
|
|
167
|
+
yield* Effect.promise(() => hooks.enqueueRunner(convex, {
|
|
168
|
+
workflow,
|
|
169
|
+
executionId,
|
|
170
|
+
generation: execution.generation,
|
|
171
|
+
}));
|
|
172
|
+
}),
|
|
173
|
+
activityExecute: Effect.fnUntraced(function* (activity, attempt) {
|
|
174
|
+
const convex = yield* ConvexCtx;
|
|
175
|
+
const instance = yield* WorkflowInstance;
|
|
176
|
+
const replay = yield* ReplayStateTag;
|
|
177
|
+
const signature = {
|
|
178
|
+
kind: "activity",
|
|
179
|
+
opName: activity.name,
|
|
180
|
+
};
|
|
181
|
+
const replayed = replay.steps[replay.cursor];
|
|
182
|
+
if (replayed) {
|
|
183
|
+
replay.cursor += 1;
|
|
184
|
+
if (!signaturesMatch(replayed.signature, signature)) {
|
|
185
|
+
throw new Error(`Determinism mismatch at ${instance.executionId}/${replayed.stepNumber}`);
|
|
186
|
+
}
|
|
187
|
+
if (replayed.state === "completed" ||
|
|
188
|
+
replayed.state === "failed" ||
|
|
189
|
+
replayed.state === "canceled") {
|
|
190
|
+
return toStepResult(replayed);
|
|
191
|
+
}
|
|
192
|
+
return new Workflow.Suspended({});
|
|
193
|
+
}
|
|
194
|
+
const execution = yield* Effect.promise(() => readExecution(convex, component, instance.executionId));
|
|
195
|
+
if (!execution) {
|
|
196
|
+
return new Workflow.Complete({
|
|
197
|
+
exit: Exit.fail(`Execution not found: ${instance.executionId}`),
|
|
198
|
+
});
|
|
199
|
+
}
|
|
200
|
+
const stepNumber = replay.steps.length;
|
|
201
|
+
const span = yield* Effect.promise(() => convex.runMutation(component.spans.createSpan, {
|
|
202
|
+
executionId: instance.executionId,
|
|
203
|
+
traceId: execution.traceId,
|
|
204
|
+
name: activity.name,
|
|
205
|
+
kind: "activity",
|
|
206
|
+
stepNumber,
|
|
207
|
+
attempt,
|
|
208
|
+
}));
|
|
209
|
+
yield* Effect.promise(() => convex.runMutation(component.journalSteps.appendJournalStep, {
|
|
210
|
+
executionId: instance.executionId,
|
|
211
|
+
stepNumber,
|
|
212
|
+
kind: "activity",
|
|
213
|
+
name: activity.name,
|
|
214
|
+
signature,
|
|
215
|
+
attempt,
|
|
216
|
+
spanId: span.spanId,
|
|
217
|
+
input: null,
|
|
218
|
+
}));
|
|
219
|
+
const workId = yield* Effect.promise(() => hooks.enqueueActivity(convex, {
|
|
220
|
+
workflow: instance.workflow,
|
|
221
|
+
executionId: instance.executionId,
|
|
222
|
+
generation: execution.generation,
|
|
223
|
+
activity,
|
|
224
|
+
stepNumber,
|
|
225
|
+
spanId: span.spanId,
|
|
226
|
+
attempt,
|
|
227
|
+
}));
|
|
228
|
+
yield* Effect.promise(() => convex.runMutation(component.journalSteps.suspendJournalStep, {
|
|
229
|
+
executionId: instance.executionId,
|
|
230
|
+
stepNumber,
|
|
231
|
+
workId,
|
|
232
|
+
}));
|
|
233
|
+
replay.steps.push({
|
|
234
|
+
stepNumber,
|
|
235
|
+
state: "suspended",
|
|
236
|
+
signature,
|
|
237
|
+
});
|
|
238
|
+
replay.cursor += 1;
|
|
239
|
+
return new Workflow.Suspended({});
|
|
240
|
+
}),
|
|
241
|
+
deferredResult: Effect.fnUntraced(function* (deferred) {
|
|
242
|
+
const convex = yield* ConvexCtx;
|
|
243
|
+
const instance = yield* WorkflowInstance;
|
|
244
|
+
return yield* Effect.promise(() => convex.runQuery(component.deferreds.deferredResult, {
|
|
245
|
+
executionId: instance.executionId,
|
|
246
|
+
deferredName: deferred.name,
|
|
247
|
+
}));
|
|
248
|
+
}),
|
|
249
|
+
deferredDone: Effect.fnUntraced(function* (options) {
|
|
250
|
+
const convex = yield* ConvexCtx;
|
|
251
|
+
const doneOptions = asDeferredDoneOptions(options);
|
|
252
|
+
yield* Effect.promise(() => convex.runMutation(component.deferreds.deferredDone, {
|
|
253
|
+
executionId: doneOptions.executionId,
|
|
254
|
+
deferredName: doneOptions.deferredName,
|
|
255
|
+
exit: doneOptions.exit,
|
|
256
|
+
}));
|
|
257
|
+
}),
|
|
258
|
+
scheduleClock: Effect.fnUntraced(function* (_workflow, options) {
|
|
259
|
+
const convex = yield* ConvexCtx;
|
|
260
|
+
const clockOptions = asScheduleClockOptions(options);
|
|
261
|
+
const execution = yield* Effect.promise(() => readExecution(convex, component, clockOptions.executionId));
|
|
262
|
+
if (!execution) {
|
|
263
|
+
return;
|
|
264
|
+
}
|
|
265
|
+
const ms = Duration.toMillis(clockOptions.clock.duration);
|
|
266
|
+
const runAfter = Math.max(0, Math.ceil(ms));
|
|
267
|
+
yield* Effect.promise(() => scheduleDeferredCompletion(convex.scheduler, component, runAfter, {
|
|
268
|
+
executionId: clockOptions.executionId,
|
|
269
|
+
deferredName: clockOptions.clock.deferred.name,
|
|
270
|
+
exit: Exit.void,
|
|
271
|
+
}));
|
|
272
|
+
}),
|
|
273
|
+
};
|
|
274
|
+
return encoded;
|
|
275
|
+
}
|
|
276
|
+
//# sourceMappingURL=encoded.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"encoded.js","sourceRoot":"","sources":["../../src/client/encoded.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export { ConvexWorkflowEngine } from "./ConvexWorkflowEngine.js";
|
|
2
|
+
export type { MutationRunCtx, QueryRunCtx, RunnerArgs, RunnerHandle, StartWorkflowArgs, ResumeWorkflowArgs, } from "./ConvexWorkflowEngine.js";
|
|
3
|
+
export { ConvexCtx, ConvexActionCtx } from "./ConvexCtx.js";
|
|
4
|
+
export type { ConvexWorkflowCtx, ConvexWorkflowActionCtx } from "./ConvexCtx.js";
|
|
5
|
+
export { makeConvexLogger } from "./ConvexLogger.js";
|
|
6
|
+
export { makeConvexTracer } from "./ConvexTracer.js";
|
|
7
|
+
export { makeConvexEncoded, type ConvexEncodedHooks, type RunnerEnqueueArgs, type ActivityEnqueueArgs, } from "./encoded.js";
|
|
8
|
+
export { makeWorkflowEngine, provideConvexCtx, layerConvexWorkflowEngine, } from "./runtime.js";
|
|
9
|
+
export { serializeRunnerHandle, scheduleRunnerFanIn, scheduleDeferredCompletion, } from "./boundaries.js";
|
|
10
|
+
export { registerActivity, registerWorkflow, getActivity, getWorkflow } from "./registry.js";
|
|
11
|
+
export { defineActivityWorker, runRegisteredActivity, activityWorkerArgs, } from "./activityWorker.js";
|
|
12
|
+
export { defineWorkflowRunner, functionHandleForRunner, type RunnerMutationArgs, type RunnerOptions, } from "./runner.js";
|
|
13
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AACjE,YAAY,EACV,cAAc,EACd,WAAW,EACX,UAAU,EACV,YAAY,EACZ,iBAAiB,EACjB,kBAAkB,GACnB,MAAM,2BAA2B,CAAC;AAEnC,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAC5D,YAAY,EAAE,iBAAiB,EAAE,uBAAuB,EAAE,MAAM,gBAAgB,CAAC;AAEjF,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EACL,iBAAiB,EACjB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,EACtB,KAAK,mBAAmB,GACzB,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,GAC1B,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,qBAAqB,EACrB,mBAAmB,EACnB,0BAA0B,GAC3B,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7F,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,kBAAkB,GACnB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,oBAAoB,EACpB,uBAAuB,EACvB,KAAK,kBAAkB,EACvB,KAAK,aAAa,GACnB,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export { ConvexWorkflowEngine } from "./ConvexWorkflowEngine.js";
|
|
2
|
+
export { ConvexCtx, ConvexActionCtx } from "./ConvexCtx.js";
|
|
3
|
+
export { makeConvexLogger } from "./ConvexLogger.js";
|
|
4
|
+
export { makeConvexTracer } from "./ConvexTracer.js";
|
|
5
|
+
export { makeConvexEncoded, } from "./encoded.js";
|
|
6
|
+
export { makeWorkflowEngine, provideConvexCtx, layerConvexWorkflowEngine, } from "./runtime.js";
|
|
7
|
+
export { serializeRunnerHandle, scheduleRunnerFanIn, scheduleDeferredCompletion, } from "./boundaries.js";
|
|
8
|
+
export { registerActivity, registerWorkflow, getActivity, getWorkflow } from "./registry.js";
|
|
9
|
+
export { defineActivityWorker, runRegisteredActivity, activityWorkerArgs, } from "./activityWorker.js";
|
|
10
|
+
export { defineWorkflowRunner, functionHandleForRunner, } from "./runner.js";
|
|
11
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/client/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,2BAA2B,CAAC;AAUjE,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,gBAAgB,CAAC;AAG5D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAErD,OAAO,EACL,iBAAiB,GAIlB,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,kBAAkB,EAClB,gBAAgB,EAChB,yBAAyB,GAC1B,MAAM,cAAc,CAAC;AAEtB,OAAO,EACL,qBAAqB,EACrB,mBAAmB,EACnB,0BAA0B,GAC3B,MAAM,iBAAiB,CAAC;AAEzB,OAAO,EAAE,gBAAgB,EAAE,gBAAgB,EAAE,WAAW,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC7F,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,kBAAkB,GACnB,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EACL,oBAAoB,EACpB,uBAAuB,GAGxB,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import type * as Activity from "@effect/workflow/Activity";
|
|
2
|
+
import type * as Workflow from "@effect/workflow/Workflow";
|
|
3
|
+
import type * as Effect from "effect/Effect";
|
|
4
|
+
import type { WorkflowEngine, WorkflowInstance } from "@effect/workflow/WorkflowEngine";
|
|
5
|
+
export type WorkflowExecute = (payload: object, executionId: string) => Effect.Effect<unknown, unknown, WorkflowInstance | WorkflowEngine>;
|
|
6
|
+
export declare function registerWorkflow(workflow: Workflow.Any, execute: WorkflowExecute): void;
|
|
7
|
+
export declare function getWorkflow(name: string): {
|
|
8
|
+
workflow: Workflow.Any;
|
|
9
|
+
execute: WorkflowExecute;
|
|
10
|
+
} | undefined;
|
|
11
|
+
export declare function registerActivity(activity: Activity.Any): void;
|
|
12
|
+
export declare function getActivity(name: string): Activity.Any | undefined;
|
|
13
|
+
export declare function listRegistered(): {
|
|
14
|
+
workflows: string[];
|
|
15
|
+
activities: string[];
|
|
16
|
+
};
|
|
17
|
+
//# sourceMappingURL=registry.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.d.ts","sourceRoot":"","sources":["../../src/client/registry.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AAC3D,OAAO,KAAK,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AAC3D,OAAO,KAAK,KAAK,MAAM,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,EAAE,cAAc,EAAE,gBAAgB,EAAE,MAAM,iCAAiC,CAAC;AAExF,MAAM,MAAM,eAAe,GAAG,CAC5B,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,MAAM,KAChB,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,GAAG,cAAc,CAAC,CAAC;AAKxE,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,EAAE,OAAO,EAAE,eAAe,QAEhF;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM;cAPM,QAAQ,CAAC,GAAG;aAAW,eAAe;cASnF;AAED,wBAAgB,gBAAgB,CAAC,QAAQ,EAAE,QAAQ,CAAC,GAAG,QAEtD;AAED,wBAAgB,WAAW,CAAC,IAAI,EAAE,MAAM,4BAEvC;AAED,wBAAgB,cAAc;;;EAK7B"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
const workflows = new Map();
|
|
2
|
+
const activities = new Map();
|
|
3
|
+
export function registerWorkflow(workflow, execute) {
|
|
4
|
+
workflows.set(workflow.name, { workflow, execute });
|
|
5
|
+
}
|
|
6
|
+
export function getWorkflow(name) {
|
|
7
|
+
return workflows.get(name);
|
|
8
|
+
}
|
|
9
|
+
export function registerActivity(activity) {
|
|
10
|
+
activities.set(activity.name, activity);
|
|
11
|
+
}
|
|
12
|
+
export function getActivity(name) {
|
|
13
|
+
return activities.get(name);
|
|
14
|
+
}
|
|
15
|
+
export function listRegistered() {
|
|
16
|
+
return {
|
|
17
|
+
workflows: [...workflows.keys()],
|
|
18
|
+
activities: [...activities.keys()],
|
|
19
|
+
};
|
|
20
|
+
}
|
|
21
|
+
//# sourceMappingURL=registry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"registry.js","sourceRoot":"","sources":["../../src/client/registry.ts"],"names":[],"mappings":"AAUA,MAAM,SAAS,GAAG,IAAI,GAAG,EAAgE,CAAC;AAC1F,MAAM,UAAU,GAAG,IAAI,GAAG,EAAwB,CAAC;AAEnD,MAAM,UAAU,gBAAgB,CAAC,QAAsB,EAAE,OAAwB;IAC/E,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,EAAE,QAAQ,EAAE,OAAO,EAAE,CAAC,CAAC;AACtD,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,SAAS,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AAC7B,CAAC;AAED,MAAM,UAAU,gBAAgB,CAAC,QAAsB;IACrD,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,WAAW,CAAC,IAAY;IACtC,OAAO,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,cAAc;IAC5B,OAAO;QACL,SAAS,EAAE,CAAC,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC;QAChC,UAAU,EAAE,CAAC,GAAG,UAAU,CAAC,IAAI,EAAE,CAAC;KACnC,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import * as Effect from "effect/Effect";
|
|
2
|
+
import * as Workflow from "@effect/workflow/Workflow";
|
|
3
|
+
import { WorkflowEngine, type WorkflowInstance } from "@effect/workflow/WorkflowEngine";
|
|
4
|
+
import { type FunctionReference } from "convex/server";
|
|
5
|
+
import type { WorkpoolOptions } from "@convex-dev/workpool";
|
|
6
|
+
import type { ComponentApi } from "../component/_generated/component.js";
|
|
7
|
+
import type { RunnerArgs, RunnerHandle } from "./ConvexWorkflowEngine.js";
|
|
8
|
+
export type RunnerMutationArgs = RunnerArgs;
|
|
9
|
+
type MutationReference = FunctionReference<"mutation", "public"> | FunctionReference<"mutation", "internal">;
|
|
10
|
+
type ActionReference = FunctionReference<"action", "public"> | FunctionReference<"action", "internal">;
|
|
11
|
+
export type RunnerReference = MutationReference | string;
|
|
12
|
+
export type ActivityWorkerTarget = ActionReference | string;
|
|
13
|
+
export type RunnerOptions = {
|
|
14
|
+
activityWorker: ActivityWorkerTarget;
|
|
15
|
+
workpoolOptions?: WorkpoolOptions;
|
|
16
|
+
};
|
|
17
|
+
/**
|
|
18
|
+
* Define a workflow runner mutation for one workflow.
|
|
19
|
+
*
|
|
20
|
+
* The runner executes one deterministic tick by calling the encoded engine
|
|
21
|
+
* directly (not `WorkflowEngine.execute`), avoiding in-mutation suspended loops.
|
|
22
|
+
* Suspension/resume is handled via component.onComplete.
|
|
23
|
+
*/
|
|
24
|
+
export declare function defineWorkflowRunner(component: ComponentApi, workflow: Workflow.Any, execute: (payload: object, executionId: string) => Effect.Effect<unknown, unknown, WorkflowInstance | WorkflowEngine>, options: RunnerOptions): import("convex/server").RegisteredMutation<"internal", RunnerArgs, Promise<void>>;
|
|
25
|
+
export declare function functionHandleForRunner(runner: RunnerReference): Promise<RunnerHandle>;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=runner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"runner.d.ts","sourceRoot":"","sources":["../../src/client/runner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAC;AAExC,OAAO,KAAK,QAAQ,MAAM,2BAA2B,CAAC;AACtD,OAAO,EAEL,cAAc,EACd,KAAK,gBAAgB,EACtB,MAAM,iCAAiC,CAAC;AACzC,OAAO,EAIL,KAAK,iBAAiB,EACvB,MAAM,eAAe,CAAC;AAEvB,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAC5D,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,sCAAsC,CAAC;AASzE,OAAO,KAAK,EAAE,UAAU,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AAM1E,MAAM,MAAM,kBAAkB,GAAG,UAAU,CAAC;AAE5C,KAAK,iBAAiB,GAClB,iBAAiB,CAAC,UAAU,EAAE,QAAQ,CAAC,GACvC,iBAAiB,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;AAE9C,KAAK,eAAe,GAChB,iBAAiB,CAAC,QAAQ,EAAE,QAAQ,CAAC,GACrC,iBAAiB,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;AAE5C,MAAM,MAAM,eAAe,GAAG,iBAAiB,GAAG,MAAM,CAAC;AAazD,MAAM,MAAM,oBAAoB,GAAG,eAAe,GAAG,MAAM,CAAC;AAY5D,MAAM,MAAM,aAAa,GAAG;IAI1B,cAAc,EAAE,oBAAoB,CAAC;IACrC,eAAe,CAAC,EAAE,eAAe,CAAC;CACnC,CAAC;AAEF;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAClC,SAAS,EAAE,YAAY,EACvB,QAAQ,EAAE,QAAQ,CAAC,GAAG,EACtB,OAAO,EAAE,CACP,OAAO,EAAE,MAAM,EACf,WAAW,EAAE,MAAM,KAChB,MAAM,CAAC,MAAM,CAAC,OAAO,EAAE,OAAO,EAAE,gBAAgB,GAAG,cAAc,CAAC,EACvE,OAAO,EAAE,aAAa,qFAsEvB;AAED,wBAAsB,uBAAuB,CAC3C,MAAM,EAAE,eAAe,GACtB,OAAO,CAAC,YAAY,CAAC,CAEvB"}
|