@workflow/core 4.1.0-beta.52 → 4.1.0-beta.54
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/class-serialization.d.ts +5 -4
- package/dist/class-serialization.d.ts.map +1 -1
- package/dist/class-serialization.js +7 -16
- package/dist/events-consumer.d.ts.map +1 -1
- package/dist/events-consumer.js +1 -9
- package/dist/logger.d.ts.map +1 -1
- package/dist/logger.js +10 -1
- package/dist/observability.d.ts.map +1 -1
- package/dist/observability.js +6 -5
- package/dist/private.d.ts +3 -1
- package/dist/private.d.ts.map +1 -1
- package/dist/private.js +4 -2
- package/dist/runtime/helpers.d.ts +9 -1
- package/dist/runtime/helpers.d.ts.map +1 -1
- package/dist/runtime/helpers.js +64 -24
- package/dist/runtime/resume-hook.d.ts.map +1 -1
- package/dist/runtime/resume-hook.js +4 -3
- package/dist/runtime/runs.d.ts +49 -0
- package/dist/runtime/runs.d.ts.map +1 -0
- package/dist/runtime/runs.js +156 -0
- package/dist/runtime/start.d.ts.map +1 -1
- package/dist/runtime/start.js +18 -11
- package/dist/runtime/step-handler.d.ts.map +1 -1
- package/dist/runtime/step-handler.js +230 -119
- package/dist/runtime/suspension-handler.d.ts.map +1 -1
- package/dist/runtime/suspension-handler.js +39 -5
- package/dist/runtime.d.ts +2 -1
- package/dist/runtime.d.ts.map +1 -1
- package/dist/runtime.js +153 -129
- package/dist/serialization.d.ts +7 -11
- package/dist/serialization.d.ts.map +1 -1
- package/dist/serialization.js +150 -63
- package/dist/telemetry/semantic-conventions.d.ts +81 -5
- package/dist/telemetry/semantic-conventions.d.ts.map +1 -1
- package/dist/telemetry/semantic-conventions.js +56 -8
- package/dist/telemetry.d.ts +25 -0
- package/dist/telemetry.d.ts.map +1 -1
- package/dist/telemetry.js +48 -2
- package/dist/version.d.ts +1 -1
- package/dist/version.js +1 -1
- package/dist/workflow.js +3 -3
- package/package.json +39 -10
- package/runtime.d.ts +1 -0
- package/runtime.js +1 -0
|
@@ -1,10 +1,25 @@
|
|
|
1
1
|
import { waitUntil } from '@vercel/functions';
|
|
2
2
|
import { WorkflowAPIError } from '@workflow/errors';
|
|
3
3
|
import { SPEC_VERSION_CURRENT, } from '@workflow/world';
|
|
4
|
+
import { runtimeLogger } from '../logger.js';
|
|
4
5
|
import { dehydrateStepArguments } from '../serialization.js';
|
|
5
6
|
import * as Attribute from '../telemetry/semantic-conventions.js';
|
|
6
7
|
import { serializeTraceCarrier } from '../telemetry.js';
|
|
7
8
|
import { queueMessage } from './helpers.js';
|
|
9
|
+
/**
|
|
10
|
+
* Extracts W3C trace context headers from a trace carrier for HTTP propagation.
|
|
11
|
+
* Returns an object with `traceparent` and optionally `tracestate` headers.
|
|
12
|
+
*/
|
|
13
|
+
function extractTraceHeaders(traceCarrier) {
|
|
14
|
+
const headers = {};
|
|
15
|
+
if (traceCarrier.traceparent) {
|
|
16
|
+
headers.traceparent = traceCarrier.traceparent;
|
|
17
|
+
}
|
|
18
|
+
if (traceCarrier.tracestate) {
|
|
19
|
+
headers.tracestate = traceCarrier.tracestate;
|
|
20
|
+
}
|
|
21
|
+
return headers;
|
|
22
|
+
}
|
|
8
23
|
/**
|
|
9
24
|
* Handles a workflow suspension by processing all pending operations (hooks, steps, waits).
|
|
10
25
|
* Uses an event-sourced architecture where entities (steps, hooks) are created atomically
|
|
@@ -53,7 +68,10 @@ export async function handleSuspension({ suspension, world, runId, workflowName,
|
|
|
53
68
|
catch (err) {
|
|
54
69
|
if (WorkflowAPIError.is(err)) {
|
|
55
70
|
if (err.status === 410) {
|
|
56
|
-
|
|
71
|
+
runtimeLogger.info('Workflow run already completed, skipping hook', {
|
|
72
|
+
workflowRunId: runId,
|
|
73
|
+
message: err.message,
|
|
74
|
+
});
|
|
57
75
|
}
|
|
58
76
|
else {
|
|
59
77
|
throw err;
|
|
@@ -97,7 +115,11 @@ export async function handleSuspension({ suspension, world, runId, workflowName,
|
|
|
97
115
|
}
|
|
98
116
|
catch (err) {
|
|
99
117
|
if (WorkflowAPIError.is(err) && err.status === 409) {
|
|
100
|
-
|
|
118
|
+
runtimeLogger.info('Step already exists, continuing', {
|
|
119
|
+
workflowRunId: runId,
|
|
120
|
+
correlationId: queueItem.correlationId,
|
|
121
|
+
message: err.message,
|
|
122
|
+
});
|
|
101
123
|
}
|
|
102
124
|
else {
|
|
103
125
|
throw err;
|
|
@@ -105,15 +127,23 @@ export async function handleSuspension({ suspension, world, runId, workflowName,
|
|
|
105
127
|
}
|
|
106
128
|
}
|
|
107
129
|
// Queue step execution message
|
|
130
|
+
// Serialize trace context once and include in both payload and headers
|
|
131
|
+
// Payload: for manual context restoration in step handler
|
|
132
|
+
// Headers: for automatic trace propagation by Vercel's infrastructure
|
|
133
|
+
const traceCarrier = await serializeTraceCarrier();
|
|
108
134
|
await queueMessage(world, `__wkf_step_${queueItem.stepName}`, {
|
|
109
135
|
workflowName,
|
|
110
136
|
workflowRunId: runId,
|
|
111
137
|
workflowStartedAt,
|
|
112
138
|
stepId: queueItem.correlationId,
|
|
113
|
-
traceCarrier
|
|
139
|
+
traceCarrier,
|
|
114
140
|
requestedAt: new Date(),
|
|
115
141
|
}, {
|
|
116
142
|
idempotencyKey: queueItem.correlationId,
|
|
143
|
+
headers: {
|
|
144
|
+
'x-workflow-run-id': runId,
|
|
145
|
+
...extractTraceHeaders(traceCarrier),
|
|
146
|
+
},
|
|
117
147
|
});
|
|
118
148
|
})());
|
|
119
149
|
}
|
|
@@ -134,7 +164,11 @@ export async function handleSuspension({ suspension, world, runId, workflowName,
|
|
|
134
164
|
}
|
|
135
165
|
catch (err) {
|
|
136
166
|
if (WorkflowAPIError.is(err) && err.status === 409) {
|
|
137
|
-
|
|
167
|
+
runtimeLogger.info('Wait already exists, continuing', {
|
|
168
|
+
workflowRunId: runId,
|
|
169
|
+
correlationId: queueItem.correlationId,
|
|
170
|
+
message: err.message,
|
|
171
|
+
});
|
|
138
172
|
}
|
|
139
173
|
else {
|
|
140
174
|
throw err;
|
|
@@ -179,4 +213,4 @@ export async function handleSuspension({ suspension, world, runId, workflowName,
|
|
|
179
213
|
}
|
|
180
214
|
return {};
|
|
181
215
|
}
|
|
182
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
216
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"suspension-handler.js","sourceRoot":"","sources":["../../src/runtime/suspension-handler.ts"],"names":[],"mappings":"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"}
|
package/dist/runtime.d.ts
CHANGED
|
@@ -3,10 +3,11 @@ export type { Event, WorkflowRun };
|
|
|
3
3
|
export { WorkflowSuspension } from './global.js';
|
|
4
4
|
export { type HealthCheckEndpoint, type HealthCheckOptions, type HealthCheckResult, healthCheck, } from './runtime/helpers.js';
|
|
5
5
|
export { getHookByToken, resumeHook, resumeWebhook, } from './runtime/resume-hook.js';
|
|
6
|
+
export { getRun, Run, type WorkflowReadableStreamOptions, } from './runtime/run.js';
|
|
7
|
+
export { cancelRun, listStreams, readStream, recreateRunFromExisting, reenqueueRun, type ReadStreamOptions, type RecreateRunOptions, type StopSleepOptions, type StopSleepResult, wakeUpRun, } from './runtime/runs.js';
|
|
6
8
|
export { type StartOptions, start } from './runtime/start.js';
|
|
7
9
|
export { stepEntrypoint } from './runtime/step-handler.js';
|
|
8
10
|
export { createWorld, getWorld, getWorldHandlers, setWorld, } from './runtime/world.js';
|
|
9
|
-
export { getRun, Run, type WorkflowReadableStreamOptions, } from './runtime/run.js';
|
|
10
11
|
/**
|
|
11
12
|
* Function that creates a single route which handles any workflow execution
|
|
12
13
|
* request and routes to the appropriate workflow function.
|
package/dist/runtime.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,KAAK,EAGV,KAAK,WAAW,EACjB,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"runtime.d.ts","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"AAEA,OAAO,EACL,KAAK,KAAK,EAGV,KAAK,WAAW,EACjB,MAAM,iBAAiB,CAAC;AAwBzB,YAAY,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC;AACnC,OAAO,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,EACL,KAAK,mBAAmB,EACxB,KAAK,kBAAkB,EACvB,KAAK,iBAAiB,EACtB,WAAW,GACZ,MAAM,sBAAsB,CAAC;AAC9B,OAAO,EACL,cAAc,EACd,UAAU,EACV,aAAa,GACd,MAAM,0BAA0B,CAAC;AAClC,OAAO,EACL,MAAM,EACN,GAAG,EACH,KAAK,6BAA6B,GACnC,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EACL,SAAS,EACT,WAAW,EACX,UAAU,EACV,uBAAuB,EACvB,YAAY,EACZ,KAAK,iBAAiB,EACtB,KAAK,kBAAkB,EACvB,KAAK,gBAAgB,EACrB,KAAK,eAAe,EACpB,SAAS,GACV,MAAM,mBAAmB,CAAC;AAC3B,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,EAAE,MAAM,oBAAoB,CAAC;AAC9D,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAC3D,OAAO,EACL,WAAW,EACX,QAAQ,EACR,gBAAgB,EAChB,QAAQ,GACT,MAAM,oBAAoB,CAAC;AAE5B;;;;;;;GAOG;AACH,wBAAgB,kBAAkB,CAChC,YAAY,EAAE,MAAM,GACnB,CAAC,GAAG,EAAE,OAAO,KAAK,OAAO,CAAC,QAAQ,CAAC,CA+PrC;AAID,wBAAgB,OAAO,SAAK"}
|
package/dist/runtime.js
CHANGED
|
@@ -8,17 +8,18 @@ import { handleSuspension } from './runtime/suspension-handler.js';
|
|
|
8
8
|
import { getWorld, getWorldHandlers } from './runtime/world.js';
|
|
9
9
|
import { remapErrorStack } from './source-map.js';
|
|
10
10
|
import * as Attribute from './telemetry/semantic-conventions.js';
|
|
11
|
-
import { linkToCurrentContext, trace, withTraceContext } from './telemetry.js';
|
|
11
|
+
import { linkToCurrentContext, trace, withTraceContext, withWorkflowBaggage, } from './telemetry.js';
|
|
12
12
|
import { getErrorName, getErrorStack } from './types.js';
|
|
13
13
|
import { buildWorkflowSuspensionMessage } from './util.js';
|
|
14
14
|
import { runWorkflow } from './workflow.js';
|
|
15
15
|
export { WorkflowSuspension } from './global.js';
|
|
16
16
|
export { healthCheck, } from './runtime/helpers.js';
|
|
17
17
|
export { getHookByToken, resumeHook, resumeWebhook, } from './runtime/resume-hook.js';
|
|
18
|
+
export { getRun, Run, } from './runtime/run.js';
|
|
19
|
+
export { cancelRun, listStreams, readStream, recreateRunFromExisting, reenqueueRun, wakeUpRun, } from './runtime/runs.js';
|
|
18
20
|
export { start } from './runtime/start.js';
|
|
19
21
|
export { stepEntrypoint } from './runtime/step-handler.js';
|
|
20
22
|
export { createWorld, getWorld, getWorldHandlers, setWorld, } from './runtime/world.js';
|
|
21
|
-
export { getRun, Run, } from './runtime/run.js';
|
|
22
23
|
/**
|
|
23
24
|
* Function that creates a single route which handles any workflow execution
|
|
24
25
|
* request and routes to the appropriate workflow function.
|
|
@@ -42,153 +43,176 @@ export function workflowEntrypoint(workflowCode) {
|
|
|
42
43
|
// Extract the workflow name from the topic name
|
|
43
44
|
const workflowName = metadata.queueName.slice('__wkf_workflow_'.length);
|
|
44
45
|
const spanLinks = await linkToCurrentContext();
|
|
45
|
-
// Invoke user workflow within the propagated trace context
|
|
46
|
+
// Invoke user workflow within the propagated trace context and baggage
|
|
46
47
|
return await withTraceContext(traceContext, async () => {
|
|
47
|
-
|
|
48
|
-
return
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
...Attribute.WorkflowOperation('execute'),
|
|
52
|
-
...Attribute.QueueName(metadata.queueName),
|
|
53
|
-
...Attribute.QueueMessageId(metadata.messageId),
|
|
54
|
-
...getQueueOverhead({ requestedAt }),
|
|
55
|
-
});
|
|
56
|
-
// TODO: validate `workflowName` exists before consuming message?
|
|
57
|
-
span?.setAttributes({
|
|
58
|
-
...Attribute.WorkflowRunId(runId),
|
|
59
|
-
...Attribute.WorkflowTracePropagated(!!traceContext),
|
|
60
|
-
});
|
|
61
|
-
let workflowStartedAt = -1;
|
|
62
|
-
try {
|
|
63
|
-
let workflowRun = await world.runs.get(runId);
|
|
64
|
-
if (workflowRun.status === 'pending') {
|
|
65
|
-
// Transition run to 'running' via event (event-sourced architecture)
|
|
66
|
-
const result = await world.events.create(runId, {
|
|
67
|
-
eventType: 'run_started',
|
|
68
|
-
specVersion: SPEC_VERSION_CURRENT,
|
|
69
|
-
});
|
|
70
|
-
// Use the run entity from the event response (no extra get call needed)
|
|
71
|
-
if (!result.run) {
|
|
72
|
-
throw new WorkflowRuntimeError(`Event creation for 'run_started' did not return the run entity for run \"${runId}\"`);
|
|
73
|
-
}
|
|
74
|
-
workflowRun = result.run;
|
|
75
|
-
}
|
|
76
|
-
// At this point, the workflow is "running" and `startedAt` should
|
|
77
|
-
// definitely be set.
|
|
78
|
-
if (!workflowRun.startedAt) {
|
|
79
|
-
throw new WorkflowRuntimeError(`Workflow run "${runId}" has no "startedAt" timestamp`);
|
|
80
|
-
}
|
|
81
|
-
workflowStartedAt = +workflowRun.startedAt;
|
|
48
|
+
// Set workflow context as baggage for automatic propagation
|
|
49
|
+
return await withWorkflowBaggage({ workflowRunId: runId, workflowName }, async () => {
|
|
50
|
+
const world = getWorld();
|
|
51
|
+
return trace(`WORKFLOW ${workflowName}`, { links: spanLinks }, async (span) => {
|
|
82
52
|
span?.setAttributes({
|
|
83
|
-
...Attribute.
|
|
84
|
-
...Attribute.
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
// TODO: furthermore, there should be a timeout or a way to force cancel SIGKILL
|
|
92
|
-
// so that we actually exit here without replaying the workflow at all, in the case
|
|
93
|
-
// the replaying the workflow is itself failing.
|
|
94
|
-
return;
|
|
95
|
-
}
|
|
96
|
-
// Load all events into memory before running
|
|
97
|
-
const events = await getAllWorkflowRunEvents(workflowRun.runId);
|
|
98
|
-
// Check for any elapsed waits and create wait_completed events
|
|
99
|
-
const now = Date.now();
|
|
100
|
-
// Pre-compute completed correlation IDs for O(n) lookup instead of O(n²)
|
|
101
|
-
const completedWaitIds = new Set(events
|
|
102
|
-
.filter((e) => e.eventType === 'wait_completed')
|
|
103
|
-
.map((e) => e.correlationId));
|
|
104
|
-
// Collect all waits that need completion
|
|
105
|
-
const waitsToComplete = events
|
|
106
|
-
.filter((e) => e.eventType === 'wait_created' &&
|
|
107
|
-
e.correlationId !== undefined &&
|
|
108
|
-
!completedWaitIds.has(e.correlationId) &&
|
|
109
|
-
now >= e.eventData.resumeAt.getTime())
|
|
110
|
-
.map((e) => ({
|
|
111
|
-
eventType: 'wait_completed',
|
|
112
|
-
specVersion: SPEC_VERSION_CURRENT,
|
|
113
|
-
correlationId: e.correlationId,
|
|
114
|
-
}));
|
|
115
|
-
// Create all wait_completed events
|
|
116
|
-
for (const waitEvent of waitsToComplete) {
|
|
117
|
-
const result = await world.events.create(runId, waitEvent);
|
|
118
|
-
// Add the event to the events array so the workflow can see it
|
|
119
|
-
events.push(result.event);
|
|
120
|
-
}
|
|
121
|
-
const result = await runWorkflow(workflowCode, workflowRun, events);
|
|
122
|
-
// Complete the workflow run via event (event-sourced architecture)
|
|
123
|
-
await world.events.create(runId, {
|
|
124
|
-
eventType: 'run_completed',
|
|
125
|
-
specVersion: SPEC_VERSION_CURRENT,
|
|
126
|
-
eventData: {
|
|
127
|
-
output: result,
|
|
128
|
-
},
|
|
53
|
+
...Attribute.WorkflowName(workflowName),
|
|
54
|
+
...Attribute.WorkflowOperation('execute'),
|
|
55
|
+
// Standard OTEL messaging conventions
|
|
56
|
+
...Attribute.MessagingSystem('vercel-queue'),
|
|
57
|
+
...Attribute.MessagingDestinationName(metadata.queueName),
|
|
58
|
+
...Attribute.MessagingMessageId(metadata.messageId),
|
|
59
|
+
...Attribute.MessagingOperationType('process'),
|
|
60
|
+
...getQueueOverhead({ requestedAt }),
|
|
129
61
|
});
|
|
62
|
+
// TODO: validate `workflowName` exists before consuming message?
|
|
130
63
|
span?.setAttributes({
|
|
131
|
-
...Attribute.
|
|
132
|
-
...Attribute.
|
|
64
|
+
...Attribute.WorkflowRunId(runId),
|
|
65
|
+
...Attribute.WorkflowTracePropagated(!!traceContext),
|
|
133
66
|
});
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
67
|
+
let workflowStartedAt = -1;
|
|
68
|
+
try {
|
|
69
|
+
let workflowRun = await world.runs.get(runId);
|
|
70
|
+
if (workflowRun.status === 'pending') {
|
|
71
|
+
// Transition run to 'running' via event (event-sourced architecture)
|
|
72
|
+
const result = await world.events.create(runId, {
|
|
73
|
+
eventType: 'run_started',
|
|
74
|
+
specVersion: SPEC_VERSION_CURRENT,
|
|
75
|
+
});
|
|
76
|
+
// Use the run entity from the event response (no extra get call needed)
|
|
77
|
+
if (!result.run) {
|
|
78
|
+
throw new WorkflowRuntimeError(`Event creation for 'run_started' did not return the run entity for run "${runId}"`);
|
|
79
|
+
}
|
|
80
|
+
workflowRun = result.run;
|
|
140
81
|
}
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
runId
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
82
|
+
// At this point, the workflow is "running" and `startedAt` should
|
|
83
|
+
// definitely be set.
|
|
84
|
+
if (!workflowRun.startedAt) {
|
|
85
|
+
throw new WorkflowRuntimeError(`Workflow run "${runId}" has no "startedAt" timestamp`);
|
|
86
|
+
}
|
|
87
|
+
workflowStartedAt = +workflowRun.startedAt;
|
|
88
|
+
span?.setAttributes({
|
|
89
|
+
...Attribute.WorkflowRunStatus(workflowRun.status),
|
|
90
|
+
...Attribute.WorkflowStartedAt(workflowStartedAt),
|
|
148
91
|
});
|
|
149
|
-
if (
|
|
150
|
-
|
|
92
|
+
if (workflowRun.status !== 'running') {
|
|
93
|
+
// Workflow has already completed or failed, so we can skip it
|
|
94
|
+
runtimeLogger.info('Workflow already completed or failed, skipping', {
|
|
95
|
+
workflowRunId: runId,
|
|
96
|
+
status: workflowRun.status,
|
|
97
|
+
});
|
|
98
|
+
// TODO: for `cancel`, we actually want to propagate a WorkflowCancelled event
|
|
99
|
+
// inside the workflow context so the user can gracefully exit. this is SIGTERM
|
|
100
|
+
// TODO: furthermore, there should be a timeout or a way to force cancel SIGKILL
|
|
101
|
+
// so that we actually exit here without replaying the workflow at all, in the case
|
|
102
|
+
// the replaying the workflow is itself failing.
|
|
103
|
+
return;
|
|
151
104
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
//
|
|
155
|
-
|
|
156
|
-
//
|
|
157
|
-
const
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
//
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
105
|
+
// Load all events into memory before running
|
|
106
|
+
const events = await getAllWorkflowRunEvents(workflowRun.runId);
|
|
107
|
+
// Check for any elapsed waits and create wait_completed events
|
|
108
|
+
const now = Date.now();
|
|
109
|
+
// Pre-compute completed correlation IDs for O(n) lookup instead of O(n²)
|
|
110
|
+
const completedWaitIds = new Set(events
|
|
111
|
+
.filter((e) => e.eventType === 'wait_completed')
|
|
112
|
+
.map((e) => e.correlationId));
|
|
113
|
+
// Collect all waits that need completion
|
|
114
|
+
const waitsToComplete = events
|
|
115
|
+
.filter((e) => e.eventType === 'wait_created' &&
|
|
116
|
+
e.correlationId !== undefined &&
|
|
117
|
+
!completedWaitIds.has(e.correlationId) &&
|
|
118
|
+
now >= e.eventData.resumeAt.getTime())
|
|
119
|
+
.map((e) => ({
|
|
120
|
+
eventType: 'wait_completed',
|
|
121
|
+
specVersion: SPEC_VERSION_CURRENT,
|
|
122
|
+
correlationId: e.correlationId,
|
|
123
|
+
}));
|
|
124
|
+
// Create all wait_completed events
|
|
125
|
+
for (const waitEvent of waitsToComplete) {
|
|
126
|
+
const result = await world.events.create(runId, waitEvent);
|
|
127
|
+
// Add the event to the events array so the workflow can see it
|
|
128
|
+
events.push(result.event);
|
|
165
129
|
}
|
|
166
|
-
|
|
167
|
-
|
|
130
|
+
const result = await trace('workflow.replay', {}, async (replaySpan) => {
|
|
131
|
+
replaySpan?.setAttributes({
|
|
132
|
+
...Attribute.WorkflowEventsCount(events.length),
|
|
133
|
+
});
|
|
134
|
+
return await runWorkflow(workflowCode, workflowRun, events);
|
|
135
|
+
});
|
|
136
|
+
// Complete the workflow run via event (event-sourced architecture)
|
|
168
137
|
await world.events.create(runId, {
|
|
169
|
-
eventType: '
|
|
138
|
+
eventType: 'run_completed',
|
|
170
139
|
specVersion: SPEC_VERSION_CURRENT,
|
|
171
140
|
eventData: {
|
|
172
|
-
|
|
173
|
-
message: errorMessage,
|
|
174
|
-
stack: errorStack,
|
|
175
|
-
},
|
|
176
|
-
// TODO: include error codes when we define them
|
|
141
|
+
output: result,
|
|
177
142
|
},
|
|
178
143
|
});
|
|
179
144
|
span?.setAttributes({
|
|
180
|
-
...Attribute.WorkflowRunStatus('
|
|
181
|
-
...Attribute.
|
|
182
|
-
...Attribute.WorkflowErrorMessage(String(err)),
|
|
145
|
+
...Attribute.WorkflowRunStatus('completed'),
|
|
146
|
+
...Attribute.WorkflowEventsCount(events.length),
|
|
183
147
|
});
|
|
184
148
|
}
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
149
|
+
catch (err) {
|
|
150
|
+
if (WorkflowSuspension.is(err)) {
|
|
151
|
+
const suspensionMessage = buildWorkflowSuspensionMessage(runId, err.stepCount, err.hookCount, err.waitCount);
|
|
152
|
+
if (suspensionMessage) {
|
|
153
|
+
runtimeLogger.debug(suspensionMessage);
|
|
154
|
+
}
|
|
155
|
+
const result = await handleSuspension({
|
|
156
|
+
suspension: err,
|
|
157
|
+
world,
|
|
158
|
+
runId,
|
|
159
|
+
workflowName,
|
|
160
|
+
workflowStartedAt,
|
|
161
|
+
span,
|
|
162
|
+
});
|
|
163
|
+
if (result.timeoutSeconds !== undefined) {
|
|
164
|
+
return { timeoutSeconds: result.timeoutSeconds };
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
else {
|
|
168
|
+
// NOTE: this error could be an error thrown in user code, or could also be a WorkflowRuntimeError
|
|
169
|
+
// (for instance when the event log is corrupted, this is thrown by the event consumer). We could
|
|
170
|
+
// specially handle these if needed.
|
|
171
|
+
// Record exception for OTEL error tracking
|
|
172
|
+
if (err instanceof Error) {
|
|
173
|
+
span?.recordException?.(err);
|
|
174
|
+
}
|
|
175
|
+
const errorName = getErrorName(err);
|
|
176
|
+
const errorMessage = err instanceof Error ? err.message : String(err);
|
|
177
|
+
let errorStack = getErrorStack(err);
|
|
178
|
+
// Remap error stack using source maps to show original source locations
|
|
179
|
+
if (errorStack) {
|
|
180
|
+
const parsedName = parseWorkflowName(workflowName);
|
|
181
|
+
const filename = parsedName?.moduleSpecifier || workflowName;
|
|
182
|
+
errorStack = remapErrorStack(errorStack, filename, workflowCode);
|
|
183
|
+
}
|
|
184
|
+
runtimeLogger.error('Error while running workflow', {
|
|
185
|
+
workflowRunId: runId,
|
|
186
|
+
errorName,
|
|
187
|
+
errorStack,
|
|
188
|
+
});
|
|
189
|
+
// Fail the workflow run via event (event-sourced architecture)
|
|
190
|
+
await world.events.create(runId, {
|
|
191
|
+
eventType: 'run_failed',
|
|
192
|
+
specVersion: SPEC_VERSION_CURRENT,
|
|
193
|
+
eventData: {
|
|
194
|
+
error: {
|
|
195
|
+
message: errorMessage,
|
|
196
|
+
stack: errorStack,
|
|
197
|
+
},
|
|
198
|
+
// TODO: include error codes when we define them
|
|
199
|
+
},
|
|
200
|
+
});
|
|
201
|
+
span?.setAttributes({
|
|
202
|
+
...Attribute.WorkflowRunStatus('failed'),
|
|
203
|
+
...Attribute.WorkflowErrorName(errorName),
|
|
204
|
+
...Attribute.WorkflowErrorMessage(String(err)),
|
|
205
|
+
...Attribute.ErrorType(errorName),
|
|
206
|
+
});
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
}); // End trace
|
|
210
|
+
}); // End withWorkflowBaggage
|
|
211
|
+
}); // End withTraceContext
|
|
188
212
|
});
|
|
189
213
|
return withHealthCheck(handler);
|
|
190
214
|
}
|
|
191
215
|
// this is a no-op placeholder as the client is
|
|
192
216
|
// expecting this to be present but we aren't actually using it
|
|
193
217
|
export function runStep() { }
|
|
194
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
218
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runtime.js","sourceRoot":"","sources":["../src/runtime.ts"],"names":[],"mappings":"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"}
|
package/dist/serialization.d.ts
CHANGED
|
@@ -41,7 +41,7 @@ export declare class WorkflowServerReadableStream extends ReadableStream<Uint8Ar
|
|
|
41
41
|
constructor(name: string, startIndex?: number);
|
|
42
42
|
}
|
|
43
43
|
export declare class WorkflowServerWritableStream extends WritableStream<Uint8Array> {
|
|
44
|
-
constructor(name: string, runId: string
|
|
44
|
+
constructor(name: string, runId: string);
|
|
45
45
|
}
|
|
46
46
|
export interface SerializableSpecial {
|
|
47
47
|
ArrayBuffer: string;
|
|
@@ -125,7 +125,7 @@ type Revivers = {
|
|
|
125
125
|
* @param ops
|
|
126
126
|
* @returns
|
|
127
127
|
*/
|
|
128
|
-
export declare function getExternalReducers(global: Record<string, any> | undefined, ops: Promise<void>[], runId: string
|
|
128
|
+
export declare function getExternalReducers(global: Record<string, any> | undefined, ops: Promise<void>[], runId: string): Reducers;
|
|
129
129
|
/**
|
|
130
130
|
* Reducers for serialization boundary from within the workflow execution
|
|
131
131
|
* environment, passing return value to the client side and into step arguments.
|
|
@@ -160,10 +160,6 @@ export declare function getCommonRevivers(global?: Record<string, any>): {
|
|
|
160
160
|
data: unknown;
|
|
161
161
|
}) => any;
|
|
162
162
|
readonly Set: (value: any[]) => any;
|
|
163
|
-
readonly StepFunction: (value: {
|
|
164
|
-
stepId: string;
|
|
165
|
-
closureVars?: Record<string, any>;
|
|
166
|
-
}) => any;
|
|
167
163
|
readonly URL: (value: string) => any;
|
|
168
164
|
readonly URLSearchParams: (value: string) => any;
|
|
169
165
|
readonly Uint8Array: (value: string) => any;
|
|
@@ -179,7 +175,7 @@ export declare function getCommonRevivers(global?: Record<string, any>): {
|
|
|
179
175
|
* @param ops
|
|
180
176
|
* @param runId
|
|
181
177
|
*/
|
|
182
|
-
export declare function getExternalRevivers(global: Record<string, any> | undefined, ops: Promise<void>[], runId: string
|
|
178
|
+
export declare function getExternalRevivers(global: Record<string, any> | undefined, ops: Promise<void>[], runId: string): Revivers;
|
|
183
179
|
/**
|
|
184
180
|
* Revivers for deserialization boundary from within the workflow execution
|
|
185
181
|
* environment, receiving arguments from the client side, and return values
|
|
@@ -199,7 +195,7 @@ export declare function getWorkflowRevivers(global?: Record<string, any>): Reviv
|
|
|
199
195
|
* @param runId
|
|
200
196
|
* @returns The dehydrated value as binary data (Uint8Array) with format prefix
|
|
201
197
|
*/
|
|
202
|
-
export declare function dehydrateWorkflowArguments(value: unknown, ops: Promise<void>[], runId: string
|
|
198
|
+
export declare function dehydrateWorkflowArguments(value: unknown, ops: Promise<void>[], runId: string, global?: Record<string, any>, v1Compat?: boolean): Uint8Array | unknown;
|
|
203
199
|
/**
|
|
204
200
|
* Called from workflow execution environment to hydrate the workflow
|
|
205
201
|
* arguments from the database at the start of workflow execution.
|
|
@@ -231,7 +227,7 @@ export declare function dehydrateWorkflowReturnValue(value: unknown, global?: Re
|
|
|
231
227
|
* @param runId
|
|
232
228
|
* @returns The hydrated return value, ready to be consumed by the client
|
|
233
229
|
*/
|
|
234
|
-
export declare function hydrateWorkflowReturnValue(value: Uint8Array | unknown, ops: Promise<void>[], runId: string
|
|
230
|
+
export declare function hydrateWorkflowReturnValue(value: Uint8Array | unknown, ops: Promise<void>[], runId: string, global?: Record<string, any>, extraRevivers?: Record<string, (value: any) => any>): any;
|
|
235
231
|
/**
|
|
236
232
|
* Called from the workflow handler when a step is being created.
|
|
237
233
|
* Dehydrates values from within the workflow execution environment
|
|
@@ -253,7 +249,7 @@ export declare function dehydrateStepArguments(value: unknown, global: Record<st
|
|
|
253
249
|
* @param runId
|
|
254
250
|
* @returns The hydrated value, ready to be consumed by the step user-code function
|
|
255
251
|
*/
|
|
256
|
-
export declare function hydrateStepArguments(value: Uint8Array | unknown, ops: Promise<any>[], runId: string
|
|
252
|
+
export declare function hydrateStepArguments(value: Uint8Array | unknown, ops: Promise<any>[], runId: string, global?: Record<string, any>, extraRevivers?: Record<string, (value: any) => any>): any;
|
|
257
253
|
/**
|
|
258
254
|
* Called from the step handler when a step has completed.
|
|
259
255
|
* Dehydrates values from within the step execution environment
|
|
@@ -265,7 +261,7 @@ export declare function hydrateStepArguments(value: Uint8Array | unknown, ops: P
|
|
|
265
261
|
* @param runId
|
|
266
262
|
* @returns The dehydrated value as binary data (Uint8Array) with format prefix
|
|
267
263
|
*/
|
|
268
|
-
export declare function dehydrateStepReturnValue(value: unknown, ops: Promise<any>[], runId: string
|
|
264
|
+
export declare function dehydrateStepReturnValue(value: unknown, ops: Promise<any>[], runId: string, global?: Record<string, any>, v1Compat?: boolean): Uint8Array | unknown;
|
|
269
265
|
/**
|
|
270
266
|
* Called from the workflow handler when replaying the event log of a `step_completed` event.
|
|
271
267
|
* Hydrates the return value of a step from the database.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"serialization.d.ts","sourceRoot":"","sources":["../src/serialization.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"serialization.d.ts","sourceRoot":"","sources":["../src/serialization.ts"],"names":[],"mappings":"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"}
|