New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

@eventual/core

Package Overview
Dependencies
Maintainers
2
Versions
164
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@eventual/core - npm Package Compare versions

Comparing version 0.28.2 to 0.28.3

4

lib/cjs/internal/calls/calls.d.ts

@@ -8,4 +8,4 @@ import { ActivityCall } from "./activity-call.js";

import { RegisterSignalHandlerCall } from "./signal-handler-call.js";
import { WorkflowCall } from "./workflow-call.js";
export type EventualCall = ActivityCall | AwaitTimerCall | ConditionCall | ExpectSignalCall | PublishEventsCall | SendSignalCall | RegisterSignalHandlerCall | WorkflowCall;
import { ChildWorkflowCall } from "./workflow-call.js";
export type EventualCall = ActivityCall | AwaitTimerCall | ConditionCall | ExpectSignalCall | PublishEventsCall | SendSignalCall | RegisterSignalHandlerCall | ChildWorkflowCall;
export declare enum EventualCallKind {

@@ -12,0 +12,0 @@ ActivityCall = 0,

@@ -29,2 +29,2 @@ "use strict";

exports.isEventualCallOfKind = isEventualCallOfKind;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvaW50ZXJuYWwvY2FsbHMvY2FsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBbUJBLElBQVksZ0JBU1g7QUFURCxXQUFZLGdCQUFnQjtJQUMxQix1RUFBZ0IsQ0FBQTtJQUNoQiwyRUFBa0IsQ0FBQTtJQUNsQix5RUFBaUIsQ0FBQTtJQUNqQiwrRUFBb0IsQ0FBQTtJQUNwQixpRkFBcUIsQ0FBQTtJQUNyQixpR0FBNkIsQ0FBQTtJQUM3QiwyRUFBa0IsQ0FBQTtJQUNsQix1RUFBZ0IsQ0FBQTtBQUNsQixDQUFDLEVBVFcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFTM0I7QUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFRL0UsU0FBZ0Isa0JBQWtCLENBQ2hDLElBQWtDLEVBQ2xDLENBQXFDO0lBRXBDLENBQU8sQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUNwQyxPQUFPLENBQU0sQ0FBQztBQUNoQixDQUFDO0FBTkQsZ0RBTUM7QUFFRCxTQUFnQixjQUFjLENBQUMsQ0FBTTtJQUNuQyxPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLElBQUksa0JBQWtCLElBQUksQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFGRCx3Q0FFQztBQUVELFNBQWdCLG9CQUFvQixDQUNsQyxJQUFrQyxFQUNsQyxDQUFNO0lBRU4sT0FBTyxjQUFjLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLGtCQUFrQixDQUFDLEtBQUssSUFBSSxDQUFDO0FBQzdELENBQUM7QUFMRCxvREFLQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2aXR5Q2FsbCB9IGZyb20gXCIuL2FjdGl2aXR5LWNhbGwuanNcIjtcbmltcG9ydCB7IEF3YWl0VGltZXJDYWxsIH0gZnJvbSBcIi4vYXdhaXQtdGltZS1jYWxsLmpzXCI7XG5pbXBvcnQgeyBDb25kaXRpb25DYWxsIH0gZnJvbSBcIi4vY29uZGl0aW9uLWNhbGwuanNcIjtcbmltcG9ydCB7IEV4cGVjdFNpZ25hbENhbGwgfSBmcm9tIFwiLi9leHBlY3Qtc2lnbmFsLWNhbGwuanNcIjtcbmltcG9ydCB7IFB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vcHVibGlzaC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5pbXBvcnQgeyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIH0gZnJvbSBcIi4vc2lnbmFsLWhhbmRsZXItY2FsbC5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dDYWxsIH0gZnJvbSBcIi4vd29ya2Zsb3ctY2FsbC5qc1wiO1xuXG5leHBvcnQgdHlwZSBFdmVudHVhbENhbGwgPVxuICB8IEFjdGl2aXR5Q2FsbFxuICB8IEF3YWl0VGltZXJDYWxsXG4gIHwgQ29uZGl0aW9uQ2FsbFxuICB8IEV4cGVjdFNpZ25hbENhbGxcbiAgfCBQdWJsaXNoRXZlbnRzQ2FsbFxuICB8IFNlbmRTaWduYWxDYWxsXG4gIHwgUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbFxuICB8IFdvcmtmbG93Q2FsbDtcblxuZXhwb3J0IGVudW0gRXZlbnR1YWxDYWxsS2luZCB7XG4gIEFjdGl2aXR5Q2FsbCA9IDAsXG4gIEF3YWl0VGltZXJDYWxsID0gMSxcbiAgQ29uZGl0aW9uQ2FsbCA9IDIsXG4gIEV4cGVjdFNpZ25hbENhbGwgPSAzLFxuICBQdWJsaXNoRXZlbnRzQ2FsbCA9IDQsXG4gIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwgPSA1LFxuICBTZW5kU2lnbmFsQ2FsbCA9IDYsXG4gIFdvcmtmbG93Q2FsbCA9IDcsXG59XG5cbmNvbnN0IEV2ZW50dWFsQ2FsbFN5bWJvbCA9IC8qIEBfX1BVUkVfXyAqLyBTeW1ib2wuZm9yKFwiZXZlbnR1YWw6RXZlbnR1YWxDYWxsXCIpO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50dWFsQ2FsbEJhc2U8XG4gIEtpbmQgZXh0ZW5kcyBFdmVudHVhbENhbGxbdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbF1cbj4ge1xuICBbRXZlbnR1YWxDYWxsU3ltYm9sXTogS2luZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUV2ZW50dWFsQ2FsbDxFIGV4dGVuZHMgRXZlbnR1YWxDYWxsPihcbiAga2luZDogRVt0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sXSxcbiAgZTogT21pdDxFLCB0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sPlxuKTogRSB7XG4gIChlIGFzIEUpW0V2ZW50dWFsQ2FsbFN5bWJvbF0gPSBraW5kO1xuICByZXR1cm4gZSBhcyBFO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNFdmVudHVhbENhbGwoYTogYW55KTogYSBpcyBFdmVudHVhbENhbGwge1xuICByZXR1cm4gYSAmJiB0eXBlb2YgYSA9PT0gXCJvYmplY3RcIiAmJiBFdmVudHVhbENhbGxTeW1ib2wgaW4gYTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXZlbnR1YWxDYWxsT2ZLaW5kPEUgZXh0ZW5kcyBFdmVudHVhbENhbGw+KFxuICBraW5kOiBFW3R5cGVvZiBFdmVudHVhbENhbGxTeW1ib2xdLFxuICBhOiBhbnlcbik6IGEgaXMgRSB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbChhKSAmJiBhW0V2ZW50dWFsQ2FsbFN5bWJvbF0gPT09IGtpbmQ7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvaW50ZXJuYWwvY2FsbHMvY2FsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBbUJBLElBQVksZ0JBU1g7QUFURCxXQUFZLGdCQUFnQjtJQUMxQix1RUFBZ0IsQ0FBQTtJQUNoQiwyRUFBa0IsQ0FBQTtJQUNsQix5RUFBaUIsQ0FBQTtJQUNqQiwrRUFBb0IsQ0FBQTtJQUNwQixpRkFBcUIsQ0FBQTtJQUNyQixpR0FBNkIsQ0FBQTtJQUM3QiwyRUFBa0IsQ0FBQTtJQUNsQix1RUFBZ0IsQ0FBQTtBQUNsQixDQUFDLEVBVFcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFTM0I7QUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFRL0UsU0FBZ0Isa0JBQWtCLENBQ2hDLElBQWtDLEVBQ2xDLENBQXFDO0lBRXBDLENBQU8sQ0FBQyxrQkFBa0IsQ0FBQyxHQUFHLElBQUksQ0FBQztJQUNwQyxPQUFPLENBQU0sQ0FBQztBQUNoQixDQUFDO0FBTkQsZ0RBTUM7QUFFRCxTQUFnQixjQUFjLENBQUMsQ0FBTTtJQUNuQyxPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLElBQUksa0JBQWtCLElBQUksQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFGRCx3Q0FFQztBQUVELFNBQWdCLG9CQUFvQixDQUNsQyxJQUFrQyxFQUNsQyxDQUFNO0lBRU4sT0FBTyxjQUFjLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLGtCQUFrQixDQUFDLEtBQUssSUFBSSxDQUFDO0FBQzdELENBQUM7QUFMRCxvREFLQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2aXR5Q2FsbCB9IGZyb20gXCIuL2FjdGl2aXR5LWNhbGwuanNcIjtcbmltcG9ydCB7IEF3YWl0VGltZXJDYWxsIH0gZnJvbSBcIi4vYXdhaXQtdGltZS1jYWxsLmpzXCI7XG5pbXBvcnQgeyBDb25kaXRpb25DYWxsIH0gZnJvbSBcIi4vY29uZGl0aW9uLWNhbGwuanNcIjtcbmltcG9ydCB7IEV4cGVjdFNpZ25hbENhbGwgfSBmcm9tIFwiLi9leHBlY3Qtc2lnbmFsLWNhbGwuanNcIjtcbmltcG9ydCB7IFB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vcHVibGlzaC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5pbXBvcnQgeyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIH0gZnJvbSBcIi4vc2lnbmFsLWhhbmRsZXItY2FsbC5qc1wiO1xuaW1wb3J0IHsgQ2hpbGRXb3JrZmxvd0NhbGwgfSBmcm9tIFwiLi93b3JrZmxvdy1jYWxsLmpzXCI7XG5cbmV4cG9ydCB0eXBlIEV2ZW50dWFsQ2FsbCA9XG4gIHwgQWN0aXZpdHlDYWxsXG4gIHwgQXdhaXRUaW1lckNhbGxcbiAgfCBDb25kaXRpb25DYWxsXG4gIHwgRXhwZWN0U2lnbmFsQ2FsbFxuICB8IFB1Ymxpc2hFdmVudHNDYWxsXG4gIHwgU2VuZFNpZ25hbENhbGxcbiAgfCBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsXG4gIHwgQ2hpbGRXb3JrZmxvd0NhbGw7XG5cbmV4cG9ydCBlbnVtIEV2ZW50dWFsQ2FsbEtpbmQge1xuICBBY3Rpdml0eUNhbGwgPSAwLFxuICBBd2FpdFRpbWVyQ2FsbCA9IDEsXG4gIENvbmRpdGlvbkNhbGwgPSAyLFxuICBFeHBlY3RTaWduYWxDYWxsID0gMyxcbiAgUHVibGlzaEV2ZW50c0NhbGwgPSA0LFxuICBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsID0gNSxcbiAgU2VuZFNpZ25hbENhbGwgPSA2LFxuICBXb3JrZmxvd0NhbGwgPSA3LFxufVxuXG5jb25zdCBFdmVudHVhbENhbGxTeW1ib2wgPSAvKiBAX19QVVJFX18gKi8gU3ltYm9sLmZvcihcImV2ZW50dWFsOkV2ZW50dWFsQ2FsbFwiKTtcblxuZXhwb3J0IGludGVyZmFjZSBFdmVudHVhbENhbGxCYXNlPFxuICBLaW5kIGV4dGVuZHMgRXZlbnR1YWxDYWxsW3R5cGVvZiBFdmVudHVhbENhbGxTeW1ib2xdXG4+IHtcbiAgW0V2ZW50dWFsQ2FsbFN5bWJvbF06IEtpbmQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFdmVudHVhbENhbGw8RSBleHRlbmRzIEV2ZW50dWFsQ2FsbD4oXG4gIGtpbmQ6IEVbdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbF0sXG4gIGU6IE9taXQ8RSwgdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbD5cbik6IEUge1xuICAoZSBhcyBFKVtFdmVudHVhbENhbGxTeW1ib2xdID0ga2luZDtcbiAgcmV0dXJuIGUgYXMgRTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXZlbnR1YWxDYWxsKGE6IGFueSk6IGEgaXMgRXZlbnR1YWxDYWxsIHtcbiAgcmV0dXJuIGEgJiYgdHlwZW9mIGEgPT09IFwib2JqZWN0XCIgJiYgRXZlbnR1YWxDYWxsU3ltYm9sIGluIGE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0V2ZW50dWFsQ2FsbE9mS2luZDxFIGV4dGVuZHMgRXZlbnR1YWxDYWxsPihcbiAga2luZDogRVt0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sXSxcbiAgYTogYW55XG4pOiBhIGlzIEUge1xuICByZXR1cm4gaXNFdmVudHVhbENhbGwoYSkgJiYgYVtFdmVudHVhbENhbGxTeW1ib2xdID09PSBraW5kO1xufVxuIl19

@@ -5,7 +5,7 @@ import { ChildExecution } from "../../execution.js";

import { EventualCall, EventualCallBase, EventualCallKind } from "./calls.js";
export declare function isWorkflowCall(a: EventualCall): a is WorkflowCall;
export declare function isChildWorkflowCall(a: EventualCall): a is ChildWorkflowCall;
/**
* An {@link Eventual} representing an awaited call to a {@link Workflow}.
*/
export interface WorkflowCall extends EventualCallBase<EventualCallKind.WorkflowCall> {
export interface ChildWorkflowCall extends EventualCallBase<EventualCallKind.WorkflowCall> {
name: string;

@@ -21,5 +21,5 @@ input?: any;

*/
timeout: Promise<any>;
timeout?: Promise<any>;
}
export declare function createWorkflowCall<T>(name: string, input?: any, opts?: WorkflowExecutionOptions, timeout?: Promise<any>): EventualPromise<T> & ChildExecution;
export declare function createChildWorkflowCall<T>(name: string, input?: any, opts?: WorkflowExecutionOptions, timeout?: Promise<any>): EventualPromise<T> & ChildExecution;
//# sourceMappingURL=workflow-call.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.createWorkflowCall = exports.isWorkflowCall = void 0;
exports.createChildWorkflowCall = exports.isChildWorkflowCall = void 0;
const eventual_hook_js_1 = require("../eventual-hook.js");

@@ -8,7 +8,7 @@ const signal_js_1 = require("../signal.js");

const send_signal_call_js_1 = require("./send-signal-call.js");
function isWorkflowCall(a) {
function isChildWorkflowCall(a) {
return (0, calls_js_1.isEventualCallOfKind)(calls_js_1.EventualCallKind.WorkflowCall, a);
}
exports.isWorkflowCall = isWorkflowCall;
function createWorkflowCall(name, input, opts, timeout) {
exports.isChildWorkflowCall = isChildWorkflowCall;
function createChildWorkflowCall(name, input, opts, timeout) {
const hook = (0, eventual_hook_js_1.getWorkflowHook)();

@@ -33,3 +33,3 @@ const eventual = hook.registerEventualCall((0, calls_js_1.createEventualCall)(calls_js_1.EventualCallKind.WorkflowCall, {

}
exports.createWorkflowCall = createWorkflowCall;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLDBEQUk2QjtBQUM3Qiw0Q0FBZ0Q7QUFDaEQseUNBTW9CO0FBQ3BCLCtEQUE2RDtBQUU3RCxTQUFnQixjQUFjLENBQUMsQ0FBZTtJQUM1QyxPQUFPLElBQUEsK0JBQW9CLEVBQUMsMkJBQWdCLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ2hFLENBQUM7QUFGRCx3Q0FFQztBQW9CRCxTQUFnQixrQkFBa0IsQ0FDaEMsSUFBWSxFQUNaLEtBQVcsRUFDWCxJQUErQixFQUMvQixPQUFzQjtJQUV0QixNQUFNLElBQUksR0FBRyxJQUFBLGtDQUFlLEdBQUUsQ0FBQztJQUMvQixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsb0JBQW9CLENBQ3hDLElBQUEsNkJBQWtCLEVBQUMsMkJBQWdCLENBQUMsWUFBWSxFQUFFO1FBQ2hELEtBQUs7UUFDTCxJQUFJO1FBQ0osSUFBSTtRQUNKLE9BQU87S0FDUixDQUFDLENBQ29DLENBQUM7SUFFekMsb0ZBQW9GO0lBQ3BGLGtEQUFrRDtJQUNsRCxRQUFRLENBQUMsVUFBVSxHQUFHLFVBQVUsTUFBTSxFQUFFLE9BQVE7UUFDOUMsTUFBTSxRQUFRLEdBQUcsT0FBTyxNQUFNLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDakUsT0FBTyxJQUFBLDBDQUFvQixFQUN6QjtZQUNFLElBQUksRUFBRSw0QkFBZ0IsQ0FBQyxjQUFjO1lBQ3JDLEdBQUcsRUFBRSxRQUFRLENBQUMsd0NBQXFCLENBQUU7WUFDckMsWUFBWSxFQUFFLElBQUk7U0FDbkIsRUFDRCxRQUFRLEVBQ1IsT0FBTyxDQUNVLENBQUM7SUFDdEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQztBQWhDRCxnREFnQ0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGlsZEV4ZWN1dGlvbiB9IGZyb20gXCIuLi8uLi9leGVjdXRpb24uanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnMgfSBmcm9tIFwiLi4vLi4vd29ya2Zsb3cuanNcIjtcbmltcG9ydCB7XG4gIEV2ZW50dWFsUHJvbWlzZSxcbiAgRXZlbnR1YWxQcm9taXNlU3ltYm9sLFxuICBnZXRXb3JrZmxvd0hvb2ssXG59IGZyb20gXCIuLi9ldmVudHVhbC1ob29rLmpzXCI7XG5pbXBvcnQgeyBTaWduYWxUYXJnZXRUeXBlIH0gZnJvbSBcIi4uL3NpZ25hbC5qc1wiO1xuaW1wb3J0IHtcbiAgY3JlYXRlRXZlbnR1YWxDYWxsLFxuICBFdmVudHVhbENhbGwsXG4gIEV2ZW50dWFsQ2FsbEJhc2UsXG4gIEV2ZW50dWFsQ2FsbEtpbmQsXG4gIGlzRXZlbnR1YWxDYWxsT2ZLaW5kLFxufSBmcm9tIFwiLi9jYWxscy5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1dvcmtmbG93Q2FsbChhOiBFdmVudHVhbENhbGwpOiBhIGlzIFdvcmtmbG93Q2FsbCB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbE9mS2luZChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXb3JrZmxvd0NhbGxcbiAgZXh0ZW5kcyBFdmVudHVhbENhbGxCYXNlPEV2ZW50dWFsQ2FsbEtpbmQuV29ya2Zsb3dDYWxsPiB7XG4gIG5hbWU6IHN0cmluZztcbiAgaW5wdXQ/OiBhbnk7XG4gIG9wdHM/OiBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnM7XG4gIC8qKlxuICAgKiBBbiBFdmVudHVhbC9Qcm9taXNlIHRoYXQgZGV0ZXJtaW5lcyB3aGVuIGEgY2hpbGQgd29ya2Zsb3cgc2hvdWxkIHRpbWVvdXQuXG4gICAqXG4gICAqIFRoaXMgdGltZW91dCBpcyBzZXBhcmF0ZSBmcm9tIHRoZSB0aW1lb3V0IHBhc3NlZCB0byB0aGUgd29ya2Zsb3cgKG9wdHMudGltZW91dCksIHdoaWNoIGNhbiBvbmx5IGJlIGEgcmVsYXRpdmUgZHVyYXRpb24uXG4gICAqXG4gICAqIFRPRE86IHN1cHBvcnQgY2FuY2VsbGF0aW9uIG9mIGNoaWxkIHdvcmtmbG93LlxuICAgKi9cbiAgdGltZW91dDogUHJvbWlzZTxhbnk+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV29ya2Zsb3dDYWxsPFQ+KFxuICBuYW1lOiBzdHJpbmcsXG4gIGlucHV0PzogYW55LFxuICBvcHRzPzogV29ya2Zsb3dFeGVjdXRpb25PcHRpb25zLFxuICB0aW1lb3V0PzogUHJvbWlzZTxhbnk+XG4pOiBFdmVudHVhbFByb21pc2U8VD4gJiBDaGlsZEV4ZWN1dGlvbiB7XG4gIGNvbnN0IGhvb2sgPSBnZXRXb3JrZmxvd0hvb2soKTtcbiAgY29uc3QgZXZlbnR1YWwgPSBob29rLnJlZ2lzdGVyRXZlbnR1YWxDYWxsKFxuICAgIGNyZWF0ZUV2ZW50dWFsQ2FsbChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwge1xuICAgICAgaW5wdXQsXG4gICAgICBuYW1lLFxuICAgICAgb3B0cyxcbiAgICAgIHRpbWVvdXQsXG4gICAgfSlcbiAgKSBhcyBFdmVudHVhbFByb21pc2U8VD4gJiBDaGlsZEV4ZWN1dGlvbjtcblxuICAvLyBjcmVhdGUgYSByZWZlcmVuY2UgdG8gdGhlIGNoaWxkIHdvcmtmbG93IHN0YXJ0ZWQgYXQgYSBzZXF1ZW5jZSBpbiB0aGlzIGV4ZWN1dGlvbi5cbiAgLy8gdGhpcyByZWZlcmVuY2Ugd2lsbCBiZSByZXNvbHZlZCBieSB0aGUgcnVudGltZS5cbiAgZXZlbnR1YWwuc2VuZFNpZ25hbCA9IGZ1bmN0aW9uIChzaWduYWwsIHBheWxvYWQ/KSB7XG4gICAgY29uc3Qgc2lnbmFsSWQgPSB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkO1xuICAgIHJldHVybiBjcmVhdGVTZW5kU2lnbmFsQ2FsbChcbiAgICAgIHtcbiAgICAgICAgdHlwZTogU2lnbmFsVGFyZ2V0VHlwZS5DaGlsZEV4ZWN1dGlvbixcbiAgICAgICAgc2VxOiBldmVudHVhbFtFdmVudHVhbFByb21pc2VTeW1ib2xdISxcbiAgICAgICAgd29ya2Zsb3dOYW1lOiBuYW1lLFxuICAgICAgfSxcbiAgICAgIHNpZ25hbElkLFxuICAgICAgcGF5bG9hZFxuICAgICkgYXMgdW5rbm93biBhcyBhbnk7XG4gIH07XG5cbiAgcmV0dXJuIGV2ZW50dWFsO1xufVxuIl19
exports.createChildWorkflowCall = createChildWorkflowCall;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUVBLDBEQUk2QjtBQUM3Qiw0Q0FBZ0Q7QUFDaEQseUNBTW9CO0FBQ3BCLCtEQUE2RDtBQUU3RCxTQUFnQixtQkFBbUIsQ0FBQyxDQUFlO0lBQ2pELE9BQU8sSUFBQSwrQkFBb0IsRUFBQywyQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDaEUsQ0FBQztBQUZELGtEQUVDO0FBb0JELFNBQWdCLHVCQUF1QixDQUNyQyxJQUFZLEVBQ1osS0FBVyxFQUNYLElBQStCLEVBQy9CLE9BQXNCO0lBRXRCLE1BQU0sSUFBSSxHQUFHLElBQUEsa0NBQWUsR0FBRSxDQUFDO0lBQy9CLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FDeEMsSUFBQSw2QkFBa0IsRUFBQywyQkFBZ0IsQ0FBQyxZQUFZLEVBQUU7UUFDaEQsS0FBSztRQUNMLElBQUk7UUFDSixJQUFJO1FBQ0osT0FBTztLQUNSLENBQUMsQ0FDb0MsQ0FBQztJQUV6QyxvRkFBb0Y7SUFDcEYsa0RBQWtEO0lBQ2xELFFBQVEsQ0FBQyxVQUFVLEdBQUcsVUFBVSxNQUFNLEVBQUUsT0FBUTtRQUM5QyxNQUFNLFFBQVEsR0FBRyxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUNqRSxPQUFPLElBQUEsMENBQW9CLEVBQ3pCO1lBQ0UsSUFBSSxFQUFFLDRCQUFnQixDQUFDLGNBQWM7WUFDckMsR0FBRyxFQUFFLFFBQVEsQ0FBQyx3Q0FBcUIsQ0FBRTtZQUNyQyxZQUFZLEVBQUUsSUFBSTtTQUNuQixFQUNELFFBQVEsRUFDUixPQUFPLENBQ1UsQ0FBQztJQUN0QixDQUFDLENBQUM7SUFFRixPQUFPLFFBQVEsQ0FBQztBQUNsQixDQUFDO0FBaENELDBEQWdDQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoaWxkRXhlY3V0aW9uIH0gZnJvbSBcIi4uLy4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3csIFdvcmtmbG93RXhlY3V0aW9uT3B0aW9ucyB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHtcbiAgRXZlbnR1YWxQcm9taXNlLFxuICBFdmVudHVhbFByb21pc2VTeW1ib2wsXG4gIGdldFdvcmtmbG93SG9vayxcbn0gZnJvbSBcIi4uL2V2ZW50dWFsLWhvb2suanNcIjtcbmltcG9ydCB7IFNpZ25hbFRhcmdldFR5cGUgfSBmcm9tIFwiLi4vc2lnbmFsLmpzXCI7XG5pbXBvcnQge1xuICBjcmVhdGVFdmVudHVhbENhbGwsXG4gIEV2ZW50dWFsQ2FsbCxcbiAgRXZlbnR1YWxDYWxsQmFzZSxcbiAgRXZlbnR1YWxDYWxsS2luZCxcbiAgaXNFdmVudHVhbENhbGxPZktpbmQsXG59IGZyb20gXCIuL2NhbGxzLmpzXCI7XG5pbXBvcnQgeyBjcmVhdGVTZW5kU2lnbmFsQ2FsbCB9IGZyb20gXCIuL3NlbmQtc2lnbmFsLWNhbGwuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2hpbGRXb3JrZmxvd0NhbGwoYTogRXZlbnR1YWxDYWxsKTogYSBpcyBDaGlsZFdvcmtmbG93Q2FsbCB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbE9mS2luZChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDaGlsZFdvcmtmbG93Q2FsbFxuICBleHRlbmRzIEV2ZW50dWFsQ2FsbEJhc2U8RXZlbnR1YWxDYWxsS2luZC5Xb3JrZmxvd0NhbGw+IHtcbiAgbmFtZTogc3RyaW5nO1xuICBpbnB1dD86IGFueTtcbiAgb3B0cz86IFdvcmtmbG93RXhlY3V0aW9uT3B0aW9ucztcbiAgLyoqXG4gICAqIEFuIEV2ZW50dWFsL1Byb21pc2UgdGhhdCBkZXRlcm1pbmVzIHdoZW4gYSBjaGlsZCB3b3JrZmxvdyBzaG91bGQgdGltZW91dC5cbiAgICpcbiAgICogVGhpcyB0aW1lb3V0IGlzIHNlcGFyYXRlIGZyb20gdGhlIHRpbWVvdXQgcGFzc2VkIHRvIHRoZSB3b3JrZmxvdyAob3B0cy50aW1lb3V0KSwgd2hpY2ggY2FuIG9ubHkgYmUgYSByZWxhdGl2ZSBkdXJhdGlvbi5cbiAgICpcbiAgICogVE9ETzogc3VwcG9ydCBjYW5jZWxsYXRpb24gb2YgY2hpbGQgd29ya2Zsb3cuXG4gICAqL1xuICB0aW1lb3V0PzogUHJvbWlzZTxhbnk+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQ2hpbGRXb3JrZmxvd0NhbGw8VD4oXG4gIG5hbWU6IHN0cmluZyxcbiAgaW5wdXQ/OiBhbnksXG4gIG9wdHM/OiBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnMsXG4gIHRpbWVvdXQ/OiBQcm9taXNlPGFueT5cbik6IEV2ZW50dWFsUHJvbWlzZTxUPiAmIENoaWxkRXhlY3V0aW9uIHtcbiAgY29uc3QgaG9vayA9IGdldFdvcmtmbG93SG9vaygpO1xuICBjb25zdCBldmVudHVhbCA9IGhvb2sucmVnaXN0ZXJFdmVudHVhbENhbGwoXG4gICAgY3JlYXRlRXZlbnR1YWxDYWxsKEV2ZW50dWFsQ2FsbEtpbmQuV29ya2Zsb3dDYWxsLCB7XG4gICAgICBpbnB1dCxcbiAgICAgIG5hbWUsXG4gICAgICBvcHRzLFxuICAgICAgdGltZW91dCxcbiAgICB9KVxuICApIGFzIEV2ZW50dWFsUHJvbWlzZTxUPiAmIENoaWxkRXhlY3V0aW9uO1xuXG4gIC8vIGNyZWF0ZSBhIHJlZmVyZW5jZSB0byB0aGUgY2hpbGQgd29ya2Zsb3cgc3RhcnRlZCBhdCBhIHNlcXVlbmNlIGluIHRoaXMgZXhlY3V0aW9uLlxuICAvLyB0aGlzIHJlZmVyZW5jZSB3aWxsIGJlIHJlc29sdmVkIGJ5IHRoZSBydW50aW1lLlxuICBldmVudHVhbC5zZW5kU2lnbmFsID0gZnVuY3Rpb24gKHNpZ25hbCwgcGF5bG9hZD8pIHtcbiAgICBjb25zdCBzaWduYWxJZCA9IHR5cGVvZiBzaWduYWwgPT09IFwic3RyaW5nXCIgPyBzaWduYWwgOiBzaWduYWwuaWQ7XG4gICAgcmV0dXJuIGNyZWF0ZVNlbmRTaWduYWxDYWxsKFxuICAgICAge1xuICAgICAgICB0eXBlOiBTaWduYWxUYXJnZXRUeXBlLkNoaWxkRXhlY3V0aW9uLFxuICAgICAgICBzZXE6IGV2ZW50dWFsW0V2ZW50dWFsUHJvbWlzZVN5bWJvbF0hLFxuICAgICAgICB3b3JrZmxvd05hbWU6IG5hbWUsXG4gICAgICB9LFxuICAgICAgc2lnbmFsSWQsXG4gICAgICBwYXlsb2FkXG4gICAgKSBhcyB1bmtub3duIGFzIGFueTtcbiAgfTtcblxuICByZXR1cm4gZXZlbnR1YWw7XG59XG4iXX0=

@@ -21,3 +21,3 @@ "use strict";

const timeout = options?.timeout ?? opts?.timeout;
return (0, workflow_call_js_1.createWorkflowCall)(name, input,
return (0, workflow_call_js_1.createChildWorkflowCall)(name, input,
// if the timeout is a time or a duration, from any source, send the timeout to the child execution

@@ -76,2 +76,2 @@ // to time itself out.

exports.generateSyntheticEvents = generateSyntheticEvents;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ChildExecution,\n  ExecutionHandle,\n  ExecutionID,\n} from \"./execution.js\";\nimport { createWorkflowCall } from \"./internal/calls/workflow-call.js\";\nimport { isOrchestratorWorker } from \"./internal/flags.js\";\nimport { getServiceClient, workflows } from \"./internal/global.js\";\nimport { isDurationSchedule, isTimeSchedule } from \"./internal/schedule.js\";\nimport {\n  HistoryStateEvent,\n  isTimerCompleted,\n  isTimerScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  WorkflowEventType,\n} from \"./internal/workflow-events.js\";\nimport type { DurationSchedule } from \"./schedule.js\";\nimport { Schedule } from \"./schedule.js\";\nimport type { StartExecutionRequest } from \"./service-client.js\";\n\nexport interface WorkflowHandler<Input = any, Output = any> {\n  (input: Input, context: WorkflowContext): Promise<Output>;\n}\n\n/**\n * Workflow options available when invoked by another workflow.\n */\nexport interface ChildWorkflowOptions {\n  timeout?: Promise<any> | Schedule;\n}\n\n/**\n * Options which determine how an execution operates.\n *\n * Overrides those provided by the workflow definition.\n */\nexport interface WorkflowExecutionOptions {\n  /**\n   * Number of seconds before or a time to time the workflow out at.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: Schedule;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowDefinitionOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: DurationSchedule;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\nexport type WorkflowArguments<Input = any> = [Input] extends [undefined]\n  ? [input?: Input, options?: ChildWorkflowOptions]\n  : [input: Input, options?: ChildWorkflowOptions];\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  name: string;\n\n  options?: WorkflowDefinitionOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (...args: WorkflowArguments<Input>): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n *\n * Logging using `console.info` (or similar) in a workflow will write logs to the\n * execution's log stream in the service's workflow.\n *\n * To see these logs run `eventual get logs -e <execution>` or find the log group using\n * `eventual show service`.\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowDefinitionOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [\n        opts: WorkflowDefinitionOptions,\n        definition: WorkflowHandler<Input, Output>\n      ]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((\n    input?: any,\n    options?: ChildWorkflowOptions\n  ) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    // a timeout can either by from definition or a eventual/promise or both.\n    // take the invocation time configuration first.\n    const timeout = options?.timeout ?? opts?.timeout;\n\n    return createWorkflowCall(\n      name,\n      input,\n      // if the timeout is a time or a duration, from any source, send the timeout to the child execution\n      // to time itself out.\n      {\n        timeout:\n          isDurationSchedule(timeout) || isTimeSchedule(timeout)\n            ? timeout\n            : undefined,\n      },\n      // if an eventual/promise is given, even if it is a duration or a time, timeout based on the\n      // promise resolution.\n      // TODO: support reporting cancellation to children when the parent times out?\n      timeout && \"then\" in timeout ? timeout : undefined\n    );\n  }) as any;\n\n  Object.defineProperty(workflow, \"name\", { value: name, writable: false });\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeout: input.timeout,\n      ...opts,\n    });\n  };\n\n  // @ts-ignore\n  workflow.definition = definition;\n\n  workflows().set(name, workflow);\n  return workflow;\n}\n\n/**\n * Generates synthetic events, for example, {@link TimerCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): TimerCompleted[] {\n  const unresolvedTimers: Record<number, TimerScheduled> = {};\n\n  const timerEvents = events.filter(\n    (event): event is TimerScheduled | TimerCompleted =>\n      isTimerScheduled(event) || isTimerCompleted(event)\n  );\n\n  for (const event of timerEvents) {\n    if (isTimerScheduled(event)) {\n      unresolvedTimers[event.seq] = event;\n    } else {\n      delete unresolvedTimers[event.seq];\n    }\n  }\n\n  const syntheticTimerComplete: TimerCompleted[] = Object.values(\n    unresolvedTimers\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.TimerCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies TimerCompleted)\n    );\n\n  return syntheticTimerComplete;\n}\n\n/**\n * Context values related to the current execution of the workflow.\n */\nexport interface WorkflowExecutionContext {\n  /**\n   * Computed, Unique ID of the execution.\n   */\n  id: ExecutionID;\n  /**\n   * Unique name of the execution, optionally provided in the startWorkflow call.\n   */\n  name: string;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentId?: ExecutionID;\n  /**\n   * The ISO 8601 UTC time the execution started.\n   */\n  startTime: string;\n}\n\n/**\n * Context values related to the workflow definition.\n */\nexport interface WorkflowDefinitionContext {\n  /**\n   * The name of the workflow.\n   */\n  name: string;\n}\n\n/**\n * Context values provided to each workflow execution.\n */\nexport interface WorkflowContext {\n  /**\n   * Context values related to the current execution of the workflow.\n   */\n  workflow: WorkflowDefinitionContext;\n  /**\n   * Context values related to the workflow definition.\n   */\n  execution: WorkflowExecutionContext;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import type {\n  ChildExecution,\n  ExecutionHandle,\n  ExecutionID,\n} from \"./execution.js\";\nimport { createChildWorkflowCall } from \"./internal/calls/workflow-call.js\";\nimport { isOrchestratorWorker } from \"./internal/flags.js\";\nimport { getServiceClient, workflows } from \"./internal/global.js\";\nimport { isDurationSchedule, isTimeSchedule } from \"./internal/schedule.js\";\nimport {\n  HistoryStateEvent,\n  isTimerCompleted,\n  isTimerScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  WorkflowEventType,\n} from \"./internal/workflow-events.js\";\nimport type { DurationSchedule } from \"./schedule.js\";\nimport { Schedule } from \"./schedule.js\";\nimport type { StartExecutionRequest } from \"./service-client.js\";\n\nexport interface WorkflowHandler<Input = any, Output = any> {\n  (input: Input, context: WorkflowContext): Promise<Output>;\n}\n\n/**\n * Workflow options available when invoked by another workflow.\n */\nexport interface ChildWorkflowOptions {\n  timeout?: Promise<any> | Schedule;\n}\n\n/**\n * Options which determine how an execution operates.\n *\n * Overrides those provided by the workflow definition.\n */\nexport interface WorkflowExecutionOptions {\n  /**\n   * Number of seconds before or a time to time the workflow out at.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: Schedule;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowDefinitionOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: DurationSchedule;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\nexport type WorkflowArguments<Input = any> = [Input] extends [undefined]\n  ? [input?: Input, options?: ChildWorkflowOptions]\n  : [input: Input, options?: ChildWorkflowOptions];\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  name: string;\n\n  options?: WorkflowDefinitionOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (...args: WorkflowArguments<Input>): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n *\n * Logging using `console.info` (or similar) in a workflow will write logs to the\n * execution's log stream in the service's workflow.\n *\n * To see these logs run `eventual get logs -e <execution>` or find the log group using\n * `eventual show service`.\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowDefinitionOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [\n        opts: WorkflowDefinitionOptions,\n        definition: WorkflowHandler<Input, Output>\n      ]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((\n    input?: any,\n    options?: ChildWorkflowOptions\n  ) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    // a timeout can either by from definition or a eventual/promise or both.\n    // take the invocation time configuration first.\n    const timeout = options?.timeout ?? opts?.timeout;\n\n    return createChildWorkflowCall(\n      name,\n      input,\n      // if the timeout is a time or a duration, from any source, send the timeout to the child execution\n      // to time itself out.\n      {\n        timeout:\n          isDurationSchedule(timeout) || isTimeSchedule(timeout)\n            ? timeout\n            : undefined,\n      },\n      // if an eventual/promise is given, even if it is a duration or a time, timeout based on the\n      // promise resolution.\n      // TODO: support reporting cancellation to children when the parent times out?\n      timeout && \"then\" in timeout ? timeout : undefined\n    );\n  }) as any;\n\n  Object.defineProperty(workflow, \"name\", { value: name, writable: false });\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeout: input.timeout,\n      ...opts,\n    });\n  };\n\n  // @ts-ignore\n  workflow.definition = definition;\n\n  workflows().set(name, workflow);\n  return workflow;\n}\n\n/**\n * Generates synthetic events, for example, {@link TimerCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): TimerCompleted[] {\n  const unresolvedTimers: Record<number, TimerScheduled> = {};\n\n  const timerEvents = events.filter(\n    (event): event is TimerScheduled | TimerCompleted =>\n      isTimerScheduled(event) || isTimerCompleted(event)\n  );\n\n  for (const event of timerEvents) {\n    if (isTimerScheduled(event)) {\n      unresolvedTimers[event.seq] = event;\n    } else {\n      delete unresolvedTimers[event.seq];\n    }\n  }\n\n  const syntheticTimerComplete: TimerCompleted[] = Object.values(\n    unresolvedTimers\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.TimerCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies TimerCompleted)\n    );\n\n  return syntheticTimerComplete;\n}\n\n/**\n * Context values related to the current execution of the workflow.\n */\nexport interface WorkflowExecutionContext {\n  /**\n   * Computed, Unique ID of the execution.\n   */\n  id: ExecutionID;\n  /**\n   * Unique name of the execution, optionally provided in the startWorkflow call.\n   */\n  name: string;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentId?: ExecutionID;\n  /**\n   * The ISO 8601 UTC time the execution started.\n   */\n  startTime: string;\n}\n\n/**\n * Context values related to the workflow definition.\n */\nexport interface WorkflowDefinitionContext {\n  /**\n   * The name of the workflow.\n   */\n  name: string;\n}\n\n/**\n * Context values provided to each workflow execution.\n */\nexport interface WorkflowContext {\n  /**\n   * Context values related to the current execution of the workflow.\n   */\n  workflow: WorkflowDefinitionContext;\n  /**\n   * Context values related to the workflow definition.\n   */\n  execution: WorkflowExecutionContext;\n}\n"]}

@@ -8,4 +8,4 @@ import { ActivityCall } from "./activity-call.js";

import { RegisterSignalHandlerCall } from "./signal-handler-call.js";
import { WorkflowCall } from "./workflow-call.js";
export type EventualCall = ActivityCall | AwaitTimerCall | ConditionCall | ExpectSignalCall | PublishEventsCall | SendSignalCall | RegisterSignalHandlerCall | WorkflowCall;
import { ChildWorkflowCall } from "./workflow-call.js";
export type EventualCall = ActivityCall | AwaitTimerCall | ConditionCall | ExpectSignalCall | PublishEventsCall | SendSignalCall | RegisterSignalHandlerCall | ChildWorkflowCall;
export declare enum EventualCallKind {

@@ -12,0 +12,0 @@ ActivityCall = 0,

@@ -23,2 +23,2 @@ export var EventualCallKind;

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvaW50ZXJuYWwvY2FsbHMvY2FsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBLE1BQU0sQ0FBTixJQUFZLGdCQVNYO0FBVEQsV0FBWSxnQkFBZ0I7SUFDMUIsdUVBQWdCLENBQUE7SUFDaEIsMkVBQWtCLENBQUE7SUFDbEIseUVBQWlCLENBQUE7SUFDakIsK0VBQW9CLENBQUE7SUFDcEIsaUZBQXFCLENBQUE7SUFDckIsaUdBQTZCLENBQUE7SUFDN0IsMkVBQWtCLENBQUE7SUFDbEIsdUVBQWdCLENBQUE7QUFDbEIsQ0FBQyxFQVRXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFTM0I7QUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFRL0UsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxJQUFrQyxFQUNsQyxDQUFxQztJQUVwQyxDQUFPLENBQUMsa0JBQWtCLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDcEMsT0FBTyxDQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUMsQ0FBTTtJQUNuQyxPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLElBQUksa0JBQWtCLElBQUksQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFFRCxNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLElBQWtDLEVBQ2xDLENBQU07SUFFTixPQUFPLGNBQWMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsa0JBQWtCLENBQUMsS0FBSyxJQUFJLENBQUM7QUFDN0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2aXR5Q2FsbCB9IGZyb20gXCIuL2FjdGl2aXR5LWNhbGwuanNcIjtcbmltcG9ydCB7IEF3YWl0VGltZXJDYWxsIH0gZnJvbSBcIi4vYXdhaXQtdGltZS1jYWxsLmpzXCI7XG5pbXBvcnQgeyBDb25kaXRpb25DYWxsIH0gZnJvbSBcIi4vY29uZGl0aW9uLWNhbGwuanNcIjtcbmltcG9ydCB7IEV4cGVjdFNpZ25hbENhbGwgfSBmcm9tIFwiLi9leHBlY3Qtc2lnbmFsLWNhbGwuanNcIjtcbmltcG9ydCB7IFB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vcHVibGlzaC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5pbXBvcnQgeyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIH0gZnJvbSBcIi4vc2lnbmFsLWhhbmRsZXItY2FsbC5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dDYWxsIH0gZnJvbSBcIi4vd29ya2Zsb3ctY2FsbC5qc1wiO1xuXG5leHBvcnQgdHlwZSBFdmVudHVhbENhbGwgPVxuICB8IEFjdGl2aXR5Q2FsbFxuICB8IEF3YWl0VGltZXJDYWxsXG4gIHwgQ29uZGl0aW9uQ2FsbFxuICB8IEV4cGVjdFNpZ25hbENhbGxcbiAgfCBQdWJsaXNoRXZlbnRzQ2FsbFxuICB8IFNlbmRTaWduYWxDYWxsXG4gIHwgUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbFxuICB8IFdvcmtmbG93Q2FsbDtcblxuZXhwb3J0IGVudW0gRXZlbnR1YWxDYWxsS2luZCB7XG4gIEFjdGl2aXR5Q2FsbCA9IDAsXG4gIEF3YWl0VGltZXJDYWxsID0gMSxcbiAgQ29uZGl0aW9uQ2FsbCA9IDIsXG4gIEV4cGVjdFNpZ25hbENhbGwgPSAzLFxuICBQdWJsaXNoRXZlbnRzQ2FsbCA9IDQsXG4gIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwgPSA1LFxuICBTZW5kU2lnbmFsQ2FsbCA9IDYsXG4gIFdvcmtmbG93Q2FsbCA9IDcsXG59XG5cbmNvbnN0IEV2ZW50dWFsQ2FsbFN5bWJvbCA9IC8qIEBfX1BVUkVfXyAqLyBTeW1ib2wuZm9yKFwiZXZlbnR1YWw6RXZlbnR1YWxDYWxsXCIpO1xuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50dWFsQ2FsbEJhc2U8XG4gIEtpbmQgZXh0ZW5kcyBFdmVudHVhbENhbGxbdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbF1cbj4ge1xuICBbRXZlbnR1YWxDYWxsU3ltYm9sXTogS2luZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUV2ZW50dWFsQ2FsbDxFIGV4dGVuZHMgRXZlbnR1YWxDYWxsPihcbiAga2luZDogRVt0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sXSxcbiAgZTogT21pdDxFLCB0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sPlxuKTogRSB7XG4gIChlIGFzIEUpW0V2ZW50dWFsQ2FsbFN5bWJvbF0gPSBraW5kO1xuICByZXR1cm4gZSBhcyBFO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNFdmVudHVhbENhbGwoYTogYW55KTogYSBpcyBFdmVudHVhbENhbGwge1xuICByZXR1cm4gYSAmJiB0eXBlb2YgYSA9PT0gXCJvYmplY3RcIiAmJiBFdmVudHVhbENhbGxTeW1ib2wgaW4gYTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXZlbnR1YWxDYWxsT2ZLaW5kPEUgZXh0ZW5kcyBFdmVudHVhbENhbGw+KFxuICBraW5kOiBFW3R5cGVvZiBFdmVudHVhbENhbGxTeW1ib2xdLFxuICBhOiBhbnlcbik6IGEgaXMgRSB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbChhKSAmJiBhW0V2ZW50dWFsQ2FsbFN5bWJvbF0gPT09IGtpbmQ7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvaW50ZXJuYWwvY2FsbHMvY2FsbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBbUJBLE1BQU0sQ0FBTixJQUFZLGdCQVNYO0FBVEQsV0FBWSxnQkFBZ0I7SUFDMUIsdUVBQWdCLENBQUE7SUFDaEIsMkVBQWtCLENBQUE7SUFDbEIseUVBQWlCLENBQUE7SUFDakIsK0VBQW9CLENBQUE7SUFDcEIsaUZBQXFCLENBQUE7SUFDckIsaUdBQTZCLENBQUE7SUFDN0IsMkVBQWtCLENBQUE7SUFDbEIsdUVBQWdCLENBQUE7QUFDbEIsQ0FBQyxFQVRXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFTM0I7QUFFRCxNQUFNLGtCQUFrQixHQUFHLGVBQWUsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLHVCQUF1QixDQUFDLENBQUM7QUFRL0UsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxJQUFrQyxFQUNsQyxDQUFxQztJQUVwQyxDQUFPLENBQUMsa0JBQWtCLENBQUMsR0FBRyxJQUFJLENBQUM7SUFDcEMsT0FBTyxDQUFNLENBQUM7QUFDaEIsQ0FBQztBQUVELE1BQU0sVUFBVSxjQUFjLENBQUMsQ0FBTTtJQUNuQyxPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLElBQUksa0JBQWtCLElBQUksQ0FBQyxDQUFDO0FBQy9ELENBQUM7QUFFRCxNQUFNLFVBQVUsb0JBQW9CLENBQ2xDLElBQWtDLEVBQ2xDLENBQU07SUFFTixPQUFPLGNBQWMsQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsa0JBQWtCLENBQUMsS0FBSyxJQUFJLENBQUM7QUFDN0QsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFjdGl2aXR5Q2FsbCB9IGZyb20gXCIuL2FjdGl2aXR5LWNhbGwuanNcIjtcbmltcG9ydCB7IEF3YWl0VGltZXJDYWxsIH0gZnJvbSBcIi4vYXdhaXQtdGltZS1jYWxsLmpzXCI7XG5pbXBvcnQgeyBDb25kaXRpb25DYWxsIH0gZnJvbSBcIi4vY29uZGl0aW9uLWNhbGwuanNcIjtcbmltcG9ydCB7IEV4cGVjdFNpZ25hbENhbGwgfSBmcm9tIFwiLi9leHBlY3Qtc2lnbmFsLWNhbGwuanNcIjtcbmltcG9ydCB7IFB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vcHVibGlzaC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5pbXBvcnQgeyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIH0gZnJvbSBcIi4vc2lnbmFsLWhhbmRsZXItY2FsbC5qc1wiO1xuaW1wb3J0IHsgQ2hpbGRXb3JrZmxvd0NhbGwgfSBmcm9tIFwiLi93b3JrZmxvdy1jYWxsLmpzXCI7XG5cbmV4cG9ydCB0eXBlIEV2ZW50dWFsQ2FsbCA9XG4gIHwgQWN0aXZpdHlDYWxsXG4gIHwgQXdhaXRUaW1lckNhbGxcbiAgfCBDb25kaXRpb25DYWxsXG4gIHwgRXhwZWN0U2lnbmFsQ2FsbFxuICB8IFB1Ymxpc2hFdmVudHNDYWxsXG4gIHwgU2VuZFNpZ25hbENhbGxcbiAgfCBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsXG4gIHwgQ2hpbGRXb3JrZmxvd0NhbGw7XG5cbmV4cG9ydCBlbnVtIEV2ZW50dWFsQ2FsbEtpbmQge1xuICBBY3Rpdml0eUNhbGwgPSAwLFxuICBBd2FpdFRpbWVyQ2FsbCA9IDEsXG4gIENvbmRpdGlvbkNhbGwgPSAyLFxuICBFeHBlY3RTaWduYWxDYWxsID0gMyxcbiAgUHVibGlzaEV2ZW50c0NhbGwgPSA0LFxuICBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsID0gNSxcbiAgU2VuZFNpZ25hbENhbGwgPSA2LFxuICBXb3JrZmxvd0NhbGwgPSA3LFxufVxuXG5jb25zdCBFdmVudHVhbENhbGxTeW1ib2wgPSAvKiBAX19QVVJFX18gKi8gU3ltYm9sLmZvcihcImV2ZW50dWFsOkV2ZW50dWFsQ2FsbFwiKTtcblxuZXhwb3J0IGludGVyZmFjZSBFdmVudHVhbENhbGxCYXNlPFxuICBLaW5kIGV4dGVuZHMgRXZlbnR1YWxDYWxsW3R5cGVvZiBFdmVudHVhbENhbGxTeW1ib2xdXG4+IHtcbiAgW0V2ZW50dWFsQ2FsbFN5bWJvbF06IEtpbmQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFdmVudHVhbENhbGw8RSBleHRlbmRzIEV2ZW50dWFsQ2FsbD4oXG4gIGtpbmQ6IEVbdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbF0sXG4gIGU6IE9taXQ8RSwgdHlwZW9mIEV2ZW50dWFsQ2FsbFN5bWJvbD5cbik6IEUge1xuICAoZSBhcyBFKVtFdmVudHVhbENhbGxTeW1ib2xdID0ga2luZDtcbiAgcmV0dXJuIGUgYXMgRTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXZlbnR1YWxDYWxsKGE6IGFueSk6IGEgaXMgRXZlbnR1YWxDYWxsIHtcbiAgcmV0dXJuIGEgJiYgdHlwZW9mIGEgPT09IFwib2JqZWN0XCIgJiYgRXZlbnR1YWxDYWxsU3ltYm9sIGluIGE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0V2ZW50dWFsQ2FsbE9mS2luZDxFIGV4dGVuZHMgRXZlbnR1YWxDYWxsPihcbiAga2luZDogRVt0eXBlb2YgRXZlbnR1YWxDYWxsU3ltYm9sXSxcbiAgYTogYW55XG4pOiBhIGlzIEUge1xuICByZXR1cm4gaXNFdmVudHVhbENhbGwoYSkgJiYgYVtFdmVudHVhbENhbGxTeW1ib2xdID09PSBraW5kO1xufVxuIl19

@@ -5,7 +5,7 @@ import { ChildExecution } from "../../execution.js";

import { EventualCall, EventualCallBase, EventualCallKind } from "./calls.js";
export declare function isWorkflowCall(a: EventualCall): a is WorkflowCall;
export declare function isChildWorkflowCall(a: EventualCall): a is ChildWorkflowCall;
/**
* An {@link Eventual} representing an awaited call to a {@link Workflow}.
*/
export interface WorkflowCall extends EventualCallBase<EventualCallKind.WorkflowCall> {
export interface ChildWorkflowCall extends EventualCallBase<EventualCallKind.WorkflowCall> {
name: string;

@@ -21,5 +21,5 @@ input?: any;

*/
timeout: Promise<any>;
timeout?: Promise<any>;
}
export declare function createWorkflowCall<T>(name: string, input?: any, opts?: WorkflowExecutionOptions, timeout?: Promise<any>): EventualPromise<T> & ChildExecution;
export declare function createChildWorkflowCall<T>(name: string, input?: any, opts?: WorkflowExecutionOptions, timeout?: Promise<any>): EventualPromise<T> & ChildExecution;
//# sourceMappingURL=workflow-call.d.ts.map

@@ -5,6 +5,6 @@ import { EventualPromiseSymbol, getWorkflowHook, } from "../eventual-hook.js";

import { createSendSignalCall } from "./send-signal-call.js";
export function isWorkflowCall(a) {
export function isChildWorkflowCall(a) {
return isEventualCallOfKind(EventualCallKind.WorkflowCall, a);
}
export function createWorkflowCall(name, input, opts, timeout) {
export function createChildWorkflowCall(name, input, opts, timeout) {
const hook = getWorkflowHook();

@@ -29,2 +29,2 @@ const eventual = hook.registerEventualCall(createEventualCall(EventualCallKind.WorkflowCall, {

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFFTCxxQkFBcUIsRUFDckIsZUFBZSxHQUNoQixNQUFNLHFCQUFxQixDQUFDO0FBQzdCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNoRCxPQUFPLEVBQ0wsa0JBQWtCLEVBR2xCLGdCQUFnQixFQUNoQixvQkFBb0IsR0FDckIsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFN0QsTUFBTSxVQUFVLGNBQWMsQ0FBQyxDQUFlO0lBQzVDLE9BQU8sb0JBQW9CLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ2hFLENBQUM7QUFvQkQsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxJQUFZLEVBQ1osS0FBVyxFQUNYLElBQStCLEVBQy9CLE9BQXNCO0lBRXRCLE1BQU0sSUFBSSxHQUFHLGVBQWUsRUFBRSxDQUFDO0lBQy9CLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxvQkFBb0IsQ0FDeEMsa0JBQWtCLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFO1FBQ2hELEtBQUs7UUFDTCxJQUFJO1FBQ0osSUFBSTtRQUNKLE9BQU87S0FDUixDQUFDLENBQ29DLENBQUM7SUFFekMsb0ZBQW9GO0lBQ3BGLGtEQUFrRDtJQUNsRCxRQUFRLENBQUMsVUFBVSxHQUFHLFVBQVUsTUFBTSxFQUFFLE9BQVE7UUFDOUMsTUFBTSxRQUFRLEdBQUcsT0FBTyxNQUFNLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7UUFDakUsT0FBTyxvQkFBb0IsQ0FDekI7WUFDRSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsY0FBYztZQUNyQyxHQUFHLEVBQUUsUUFBUSxDQUFDLHFCQUFxQixDQUFFO1lBQ3JDLFlBQVksRUFBRSxJQUFJO1NBQ25CLEVBQ0QsUUFBUSxFQUNSLE9BQU8sQ0FDVSxDQUFDO0lBQ3RCLENBQUMsQ0FBQztJQUVGLE9BQU8sUUFBUSxDQUFDO0FBQ2xCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDaGlsZEV4ZWN1dGlvbiB9IGZyb20gXCIuLi8uLi9leGVjdXRpb24uanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnMgfSBmcm9tIFwiLi4vLi4vd29ya2Zsb3cuanNcIjtcbmltcG9ydCB7XG4gIEV2ZW50dWFsUHJvbWlzZSxcbiAgRXZlbnR1YWxQcm9taXNlU3ltYm9sLFxuICBnZXRXb3JrZmxvd0hvb2ssXG59IGZyb20gXCIuLi9ldmVudHVhbC1ob29rLmpzXCI7XG5pbXBvcnQgeyBTaWduYWxUYXJnZXRUeXBlIH0gZnJvbSBcIi4uL3NpZ25hbC5qc1wiO1xuaW1wb3J0IHtcbiAgY3JlYXRlRXZlbnR1YWxDYWxsLFxuICBFdmVudHVhbENhbGwsXG4gIEV2ZW50dWFsQ2FsbEJhc2UsXG4gIEV2ZW50dWFsQ2FsbEtpbmQsXG4gIGlzRXZlbnR1YWxDYWxsT2ZLaW5kLFxufSBmcm9tIFwiLi9jYWxscy5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1dvcmtmbG93Q2FsbChhOiBFdmVudHVhbENhbGwpOiBhIGlzIFdvcmtmbG93Q2FsbCB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbE9mS2luZChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXb3JrZmxvd0NhbGxcbiAgZXh0ZW5kcyBFdmVudHVhbENhbGxCYXNlPEV2ZW50dWFsQ2FsbEtpbmQuV29ya2Zsb3dDYWxsPiB7XG4gIG5hbWU6IHN0cmluZztcbiAgaW5wdXQ/OiBhbnk7XG4gIG9wdHM/OiBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnM7XG4gIC8qKlxuICAgKiBBbiBFdmVudHVhbC9Qcm9taXNlIHRoYXQgZGV0ZXJtaW5lcyB3aGVuIGEgY2hpbGQgd29ya2Zsb3cgc2hvdWxkIHRpbWVvdXQuXG4gICAqXG4gICAqIFRoaXMgdGltZW91dCBpcyBzZXBhcmF0ZSBmcm9tIHRoZSB0aW1lb3V0IHBhc3NlZCB0byB0aGUgd29ya2Zsb3cgKG9wdHMudGltZW91dCksIHdoaWNoIGNhbiBvbmx5IGJlIGEgcmVsYXRpdmUgZHVyYXRpb24uXG4gICAqXG4gICAqIFRPRE86IHN1cHBvcnQgY2FuY2VsbGF0aW9uIG9mIGNoaWxkIHdvcmtmbG93LlxuICAgKi9cbiAgdGltZW91dDogUHJvbWlzZTxhbnk+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV29ya2Zsb3dDYWxsPFQ+KFxuICBuYW1lOiBzdHJpbmcsXG4gIGlucHV0PzogYW55LFxuICBvcHRzPzogV29ya2Zsb3dFeGVjdXRpb25PcHRpb25zLFxuICB0aW1lb3V0PzogUHJvbWlzZTxhbnk+XG4pOiBFdmVudHVhbFByb21pc2U8VD4gJiBDaGlsZEV4ZWN1dGlvbiB7XG4gIGNvbnN0IGhvb2sgPSBnZXRXb3JrZmxvd0hvb2soKTtcbiAgY29uc3QgZXZlbnR1YWwgPSBob29rLnJlZ2lzdGVyRXZlbnR1YWxDYWxsKFxuICAgIGNyZWF0ZUV2ZW50dWFsQ2FsbChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwge1xuICAgICAgaW5wdXQsXG4gICAgICBuYW1lLFxuICAgICAgb3B0cyxcbiAgICAgIHRpbWVvdXQsXG4gICAgfSlcbiAgKSBhcyBFdmVudHVhbFByb21pc2U8VD4gJiBDaGlsZEV4ZWN1dGlvbjtcblxuICAvLyBjcmVhdGUgYSByZWZlcmVuY2UgdG8gdGhlIGNoaWxkIHdvcmtmbG93IHN0YXJ0ZWQgYXQgYSBzZXF1ZW5jZSBpbiB0aGlzIGV4ZWN1dGlvbi5cbiAgLy8gdGhpcyByZWZlcmVuY2Ugd2lsbCBiZSByZXNvbHZlZCBieSB0aGUgcnVudGltZS5cbiAgZXZlbnR1YWwuc2VuZFNpZ25hbCA9IGZ1bmN0aW9uIChzaWduYWwsIHBheWxvYWQ/KSB7XG4gICAgY29uc3Qgc2lnbmFsSWQgPSB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkO1xuICAgIHJldHVybiBjcmVhdGVTZW5kU2lnbmFsQ2FsbChcbiAgICAgIHtcbiAgICAgICAgdHlwZTogU2lnbmFsVGFyZ2V0VHlwZS5DaGlsZEV4ZWN1dGlvbixcbiAgICAgICAgc2VxOiBldmVudHVhbFtFdmVudHVhbFByb21pc2VTeW1ib2xdISxcbiAgICAgICAgd29ya2Zsb3dOYW1lOiBuYW1lLFxuICAgICAgfSxcbiAgICAgIHNpZ25hbElkLFxuICAgICAgcGF5bG9hZFxuICAgICkgYXMgdW5rbm93biBhcyBhbnk7XG4gIH07XG5cbiAgcmV0dXJuIGV2ZW50dWFsO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9pbnRlcm5hbC9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVBLE9BQU8sRUFFTCxxQkFBcUIsRUFDckIsZUFBZSxHQUNoQixNQUFNLHFCQUFxQixDQUFDO0FBQzdCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUNoRCxPQUFPLEVBQ0wsa0JBQWtCLEVBR2xCLGdCQUFnQixFQUNoQixvQkFBb0IsR0FDckIsTUFBTSxZQUFZLENBQUM7QUFDcEIsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFN0QsTUFBTSxVQUFVLG1CQUFtQixDQUFDLENBQWU7SUFDakQsT0FBTyxvQkFBb0IsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDaEUsQ0FBQztBQW9CRCxNQUFNLFVBQVUsdUJBQXVCLENBQ3JDLElBQVksRUFDWixLQUFXLEVBQ1gsSUFBK0IsRUFDL0IsT0FBc0I7SUFFdEIsTUFBTSxJQUFJLEdBQUcsZUFBZSxFQUFFLENBQUM7SUFDL0IsTUFBTSxRQUFRLEdBQUcsSUFBSSxDQUFDLG9CQUFvQixDQUN4QyxrQkFBa0IsQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUU7UUFDaEQsS0FBSztRQUNMLElBQUk7UUFDSixJQUFJO1FBQ0osT0FBTztLQUNSLENBQUMsQ0FDb0MsQ0FBQztJQUV6QyxvRkFBb0Y7SUFDcEYsa0RBQWtEO0lBQ2xELFFBQVEsQ0FBQyxVQUFVLEdBQUcsVUFBVSxNQUFNLEVBQUUsT0FBUTtRQUM5QyxNQUFNLFFBQVEsR0FBRyxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUNqRSxPQUFPLG9CQUFvQixDQUN6QjtZQUNFLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxjQUFjO1lBQ3JDLEdBQUcsRUFBRSxRQUFRLENBQUMscUJBQXFCLENBQUU7WUFDckMsWUFBWSxFQUFFLElBQUk7U0FDbkIsRUFDRCxRQUFRLEVBQ1IsT0FBTyxDQUNVLENBQUM7SUFDdEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxRQUFRLENBQUM7QUFDbEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENoaWxkRXhlY3V0aW9uIH0gZnJvbSBcIi4uLy4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3csIFdvcmtmbG93RXhlY3V0aW9uT3B0aW9ucyB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHtcbiAgRXZlbnR1YWxQcm9taXNlLFxuICBFdmVudHVhbFByb21pc2VTeW1ib2wsXG4gIGdldFdvcmtmbG93SG9vayxcbn0gZnJvbSBcIi4uL2V2ZW50dWFsLWhvb2suanNcIjtcbmltcG9ydCB7IFNpZ25hbFRhcmdldFR5cGUgfSBmcm9tIFwiLi4vc2lnbmFsLmpzXCI7XG5pbXBvcnQge1xuICBjcmVhdGVFdmVudHVhbENhbGwsXG4gIEV2ZW50dWFsQ2FsbCxcbiAgRXZlbnR1YWxDYWxsQmFzZSxcbiAgRXZlbnR1YWxDYWxsS2luZCxcbiAgaXNFdmVudHVhbENhbGxPZktpbmQsXG59IGZyb20gXCIuL2NhbGxzLmpzXCI7XG5pbXBvcnQgeyBjcmVhdGVTZW5kU2lnbmFsQ2FsbCB9IGZyb20gXCIuL3NlbmQtc2lnbmFsLWNhbGwuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ2hpbGRXb3JrZmxvd0NhbGwoYTogRXZlbnR1YWxDYWxsKTogYSBpcyBDaGlsZFdvcmtmbG93Q2FsbCB7XG4gIHJldHVybiBpc0V2ZW50dWFsQ2FsbE9mS2luZChFdmVudHVhbENhbGxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDaGlsZFdvcmtmbG93Q2FsbFxuICBleHRlbmRzIEV2ZW50dWFsQ2FsbEJhc2U8RXZlbnR1YWxDYWxsS2luZC5Xb3JrZmxvd0NhbGw+IHtcbiAgbmFtZTogc3RyaW5nO1xuICBpbnB1dD86IGFueTtcbiAgb3B0cz86IFdvcmtmbG93RXhlY3V0aW9uT3B0aW9ucztcbiAgLyoqXG4gICAqIEFuIEV2ZW50dWFsL1Byb21pc2UgdGhhdCBkZXRlcm1pbmVzIHdoZW4gYSBjaGlsZCB3b3JrZmxvdyBzaG91bGQgdGltZW91dC5cbiAgICpcbiAgICogVGhpcyB0aW1lb3V0IGlzIHNlcGFyYXRlIGZyb20gdGhlIHRpbWVvdXQgcGFzc2VkIHRvIHRoZSB3b3JrZmxvdyAob3B0cy50aW1lb3V0KSwgd2hpY2ggY2FuIG9ubHkgYmUgYSByZWxhdGl2ZSBkdXJhdGlvbi5cbiAgICpcbiAgICogVE9ETzogc3VwcG9ydCBjYW5jZWxsYXRpb24gb2YgY2hpbGQgd29ya2Zsb3cuXG4gICAqL1xuICB0aW1lb3V0PzogUHJvbWlzZTxhbnk+O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlQ2hpbGRXb3JrZmxvd0NhbGw8VD4oXG4gIG5hbWU6IHN0cmluZyxcbiAgaW5wdXQ/OiBhbnksXG4gIG9wdHM/OiBXb3JrZmxvd0V4ZWN1dGlvbk9wdGlvbnMsXG4gIHRpbWVvdXQ/OiBQcm9taXNlPGFueT5cbik6IEV2ZW50dWFsUHJvbWlzZTxUPiAmIENoaWxkRXhlY3V0aW9uIHtcbiAgY29uc3QgaG9vayA9IGdldFdvcmtmbG93SG9vaygpO1xuICBjb25zdCBldmVudHVhbCA9IGhvb2sucmVnaXN0ZXJFdmVudHVhbENhbGwoXG4gICAgY3JlYXRlRXZlbnR1YWxDYWxsKEV2ZW50dWFsQ2FsbEtpbmQuV29ya2Zsb3dDYWxsLCB7XG4gICAgICBpbnB1dCxcbiAgICAgIG5hbWUsXG4gICAgICBvcHRzLFxuICAgICAgdGltZW91dCxcbiAgICB9KVxuICApIGFzIEV2ZW50dWFsUHJvbWlzZTxUPiAmIENoaWxkRXhlY3V0aW9uO1xuXG4gIC8vIGNyZWF0ZSBhIHJlZmVyZW5jZSB0byB0aGUgY2hpbGQgd29ya2Zsb3cgc3RhcnRlZCBhdCBhIHNlcXVlbmNlIGluIHRoaXMgZXhlY3V0aW9uLlxuICAvLyB0aGlzIHJlZmVyZW5jZSB3aWxsIGJlIHJlc29sdmVkIGJ5IHRoZSBydW50aW1lLlxuICBldmVudHVhbC5zZW5kU2lnbmFsID0gZnVuY3Rpb24gKHNpZ25hbCwgcGF5bG9hZD8pIHtcbiAgICBjb25zdCBzaWduYWxJZCA9IHR5cGVvZiBzaWduYWwgPT09IFwic3RyaW5nXCIgPyBzaWduYWwgOiBzaWduYWwuaWQ7XG4gICAgcmV0dXJuIGNyZWF0ZVNlbmRTaWduYWxDYWxsKFxuICAgICAge1xuICAgICAgICB0eXBlOiBTaWduYWxUYXJnZXRUeXBlLkNoaWxkRXhlY3V0aW9uLFxuICAgICAgICBzZXE6IGV2ZW50dWFsW0V2ZW50dWFsUHJvbWlzZVN5bWJvbF0hLFxuICAgICAgICB3b3JrZmxvd05hbWU6IG5hbWUsXG4gICAgICB9LFxuICAgICAgc2lnbmFsSWQsXG4gICAgICBwYXlsb2FkXG4gICAgKSBhcyB1bmtub3duIGFzIGFueTtcbiAgfTtcblxuICByZXR1cm4gZXZlbnR1YWw7XG59XG4iXX0=

@@ -1,2 +0,2 @@

import { createWorkflowCall } from "./internal/calls/workflow-call.js";
import { createChildWorkflowCall } from "./internal/calls/workflow-call.js";
import { isOrchestratorWorker } from "./internal/flags.js";

@@ -18,3 +18,3 @@ import { getServiceClient, workflows } from "./internal/global.js";

const timeout = options?.timeout ?? opts?.timeout;
return createWorkflowCall(name, input,
return createChildWorkflowCall(name, input,
// if the timeout is a time or a duration, from any source, send the timeout to the child execution

@@ -71,2 +71,2 @@ // to time itself out.

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,kBAAkB,EAAE,MAAM,mCAAmC,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC5E,OAAO,EAEL,gBAAgB,EAChB,gBAAgB,EAGhB,iBAAiB,GAClB,MAAM,+BAA+B,CAAC;AAgIvC,MAAM,UAAU,QAAQ,CACtB,IAAY,EACZ,GAAG,IAK6C;IAEhD,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3E,IAAI,SAAS,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,uBAAuB,IAAI,kBAAkB,CAAC,CAAC;KAChE;IAED,MAAM,QAAQ,GAA4B,CAAC,CACzC,KAAW,EACX,OAA8B,EAC9B,EAAE;QACF,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;SACH;QAED,yEAAyE;QACzE,gDAAgD;QAChD,MAAM,OAAO,GAAG,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,OAAO,CAAC;QAElD,OAAO,kBAAkB,CACvB,IAAI,EACJ,KAAK;QACL,mGAAmG;QACnG,sBAAsB;QACtB;YACE,OAAO,EACL,kBAAkB,CAAC,OAAO,CAAC,IAAI,cAAc,CAAC,OAAO,CAAC;gBACpD,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,SAAS;SAChB;QACD,4FAA4F;QAC5F,sBAAsB;QACtB,8EAA8E;QAC9E,OAAO,IAAI,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CACnD,CAAC;IACJ,CAAC,CAAQ,CAAC;IAEV,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;IAE1E,QAAQ,CAAC,cAAc,GAAG,KAAK,WAAW,KAAK;QAC7C,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAC;QACzC,OAAO,MAAM,aAAa,CAAC,cAAc,CAA0B;YACjE,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,GAAG,IAAI;SACR,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,aAAa;IACb,QAAQ,CAAC,UAAU,GAAG,UAAU,CAAC;IAEjC,SAAS,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAChC,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,uBAAuB,CACrC,MAA2B,EAC3B,QAAc;IAEd,MAAM,gBAAgB,GAAmC,EAAE,CAAC;IAE5D,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAC/B,CAAC,KAAK,EAA4C,EAAE,CAClD,gBAAgB,CAAC,KAAK,CAAC,IAAI,gBAAgB,CAAC,KAAK,CAAC,CACrD,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE;QAC/B,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE;YAC3B,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SACrC;aAAM;YACL,OAAO,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SACpC;KACF;IAED,MAAM,sBAAsB,GAAqB,MAAM,CAAC,MAAM,CAC5D,gBAAgB,CACjB;SACE,MAAM,CACL,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,IAAI,QAAQ,CAAC,OAAO,EAAE,CACrE;SACA,GAAG,CACF,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC;QACC,IAAI,EAAE,iBAAiB,CAAC,cAAc;QACtC,GAAG,EAAE,CAAC,CAAC,GAAG;QACV,SAAS,EAAE,QAAQ,CAAC,WAAW,EAAE;KACT,CAAC,CAC9B,CAAC;IAEJ,OAAO,sBAAsB,CAAC;AAChC,CAAC","sourcesContent":["import type {\n  ChildExecution,\n  ExecutionHandle,\n  ExecutionID,\n} from \"./execution.js\";\nimport { createWorkflowCall } from \"./internal/calls/workflow-call.js\";\nimport { isOrchestratorWorker } from \"./internal/flags.js\";\nimport { getServiceClient, workflows } from \"./internal/global.js\";\nimport { isDurationSchedule, isTimeSchedule } from \"./internal/schedule.js\";\nimport {\n  HistoryStateEvent,\n  isTimerCompleted,\n  isTimerScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  WorkflowEventType,\n} from \"./internal/workflow-events.js\";\nimport type { DurationSchedule } from \"./schedule.js\";\nimport { Schedule } from \"./schedule.js\";\nimport type { StartExecutionRequest } from \"./service-client.js\";\n\nexport interface WorkflowHandler<Input = any, Output = any> {\n  (input: Input, context: WorkflowContext): Promise<Output>;\n}\n\n/**\n * Workflow options available when invoked by another workflow.\n */\nexport interface ChildWorkflowOptions {\n  timeout?: Promise<any> | Schedule;\n}\n\n/**\n * Options which determine how an execution operates.\n *\n * Overrides those provided by the workflow definition.\n */\nexport interface WorkflowExecutionOptions {\n  /**\n   * Number of seconds before or a time to time the workflow out at.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: Schedule;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowDefinitionOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: DurationSchedule;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\nexport type WorkflowArguments<Input = any> = [Input] extends [undefined]\n  ? [input?: Input, options?: ChildWorkflowOptions]\n  : [input: Input, options?: ChildWorkflowOptions];\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  name: string;\n\n  options?: WorkflowDefinitionOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (...args: WorkflowArguments<Input>): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n *\n * Logging using `console.info` (or similar) in a workflow will write logs to the\n * execution's log stream in the service's workflow.\n *\n * To see these logs run `eventual get logs -e <execution>` or find the log group using\n * `eventual show service`.\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowDefinitionOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [\n        opts: WorkflowDefinitionOptions,\n        definition: WorkflowHandler<Input, Output>\n      ]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((\n    input?: any,\n    options?: ChildWorkflowOptions\n  ) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    // a timeout can either by from definition or a eventual/promise or both.\n    // take the invocation time configuration first.\n    const timeout = options?.timeout ?? opts?.timeout;\n\n    return createWorkflowCall(\n      name,\n      input,\n      // if the timeout is a time or a duration, from any source, send the timeout to the child execution\n      // to time itself out.\n      {\n        timeout:\n          isDurationSchedule(timeout) || isTimeSchedule(timeout)\n            ? timeout\n            : undefined,\n      },\n      // if an eventual/promise is given, even if it is a duration or a time, timeout based on the\n      // promise resolution.\n      // TODO: support reporting cancellation to children when the parent times out?\n      timeout && \"then\" in timeout ? timeout : undefined\n    );\n  }) as any;\n\n  Object.defineProperty(workflow, \"name\", { value: name, writable: false });\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeout: input.timeout,\n      ...opts,\n    });\n  };\n\n  // @ts-ignore\n  workflow.definition = definition;\n\n  workflows().set(name, workflow);\n  return workflow;\n}\n\n/**\n * Generates synthetic events, for example, {@link TimerCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): TimerCompleted[] {\n  const unresolvedTimers: Record<number, TimerScheduled> = {};\n\n  const timerEvents = events.filter(\n    (event): event is TimerScheduled | TimerCompleted =>\n      isTimerScheduled(event) || isTimerCompleted(event)\n  );\n\n  for (const event of timerEvents) {\n    if (isTimerScheduled(event)) {\n      unresolvedTimers[event.seq] = event;\n    } else {\n      delete unresolvedTimers[event.seq];\n    }\n  }\n\n  const syntheticTimerComplete: TimerCompleted[] = Object.values(\n    unresolvedTimers\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.TimerCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies TimerCompleted)\n    );\n\n  return syntheticTimerComplete;\n}\n\n/**\n * Context values related to the current execution of the workflow.\n */\nexport interface WorkflowExecutionContext {\n  /**\n   * Computed, Unique ID of the execution.\n   */\n  id: ExecutionID;\n  /**\n   * Unique name of the execution, optionally provided in the startWorkflow call.\n   */\n  name: string;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentId?: ExecutionID;\n  /**\n   * The ISO 8601 UTC time the execution started.\n   */\n  startTime: string;\n}\n\n/**\n * Context values related to the workflow definition.\n */\nexport interface WorkflowDefinitionContext {\n  /**\n   * The name of the workflow.\n   */\n  name: string;\n}\n\n/**\n * Context values provided to each workflow execution.\n */\nexport interface WorkflowContext {\n  /**\n   * Context values related to the current execution of the workflow.\n   */\n  workflow: WorkflowDefinitionContext;\n  /**\n   * Context values related to the workflow definition.\n   */\n  execution: WorkflowExecutionContext;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAC;AAC5E,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAC5E,OAAO,EAEL,gBAAgB,EAChB,gBAAgB,EAGhB,iBAAiB,GAClB,MAAM,+BAA+B,CAAC;AAgIvC,MAAM,UAAU,QAAQ,CACtB,IAAY,EACZ,GAAG,IAK6C;IAEhD,MAAM,CAAC,IAAI,EAAE,UAAU,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IAC3E,IAAI,SAAS,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACzB,MAAM,IAAI,KAAK,CAAC,uBAAuB,IAAI,kBAAkB,CAAC,CAAC;KAChE;IAED,MAAM,QAAQ,GAA4B,CAAC,CACzC,KAAW,EACX,OAA8B,EAC9B,EAAE;QACF,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;SACH;QAED,yEAAyE;QACzE,gDAAgD;QAChD,MAAM,OAAO,GAAG,OAAO,EAAE,OAAO,IAAI,IAAI,EAAE,OAAO,CAAC;QAElD,OAAO,uBAAuB,CAC5B,IAAI,EACJ,KAAK;QACL,mGAAmG;QACnG,sBAAsB;QACtB;YACE,OAAO,EACL,kBAAkB,CAAC,OAAO,CAAC,IAAI,cAAc,CAAC,OAAO,CAAC;gBACpD,CAAC,CAAC,OAAO;gBACT,CAAC,CAAC,SAAS;SAChB;QACD,4FAA4F;QAC5F,sBAAsB;QACtB,8EAA8E;QAC9E,OAAO,IAAI,MAAM,IAAI,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CACnD,CAAC;IACJ,CAAC,CAAQ,CAAC;IAEV,MAAM,CAAC,cAAc,CAAC,QAAQ,EAAE,MAAM,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,CAAC,CAAC;IAE1E,QAAQ,CAAC,cAAc,GAAG,KAAK,WAAW,KAAK;QAC7C,MAAM,aAAa,GAAG,gBAAgB,EAAE,CAAC;QACzC,OAAO,MAAM,aAAa,CAAC,cAAc,CAA0B;YACjE,QAAQ,EAAE,IAAI;YACd,aAAa,EAAE,KAAK,CAAC,aAAa;YAClC,KAAK,EAAE,KAAK,CAAC,KAAK;YAClB,OAAO,EAAE,KAAK,CAAC,OAAO;YACtB,GAAG,IAAI;SACR,CAAC,CAAC;IACL,CAAC,CAAC;IAEF,aAAa;IACb,QAAQ,CAAC,UAAU,GAAG,UAAU,CAAC;IAEjC,SAAS,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,QAAQ,CAAC,CAAC;IAChC,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,uBAAuB,CACrC,MAA2B,EAC3B,QAAc;IAEd,MAAM,gBAAgB,GAAmC,EAAE,CAAC;IAE5D,MAAM,WAAW,GAAG,MAAM,CAAC,MAAM,CAC/B,CAAC,KAAK,EAA4C,EAAE,CAClD,gBAAgB,CAAC,KAAK,CAAC,IAAI,gBAAgB,CAAC,KAAK,CAAC,CACrD,CAAC;IAEF,KAAK,MAAM,KAAK,IAAI,WAAW,EAAE;QAC/B,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE;YAC3B,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,KAAK,CAAC;SACrC;aAAM;YACL,OAAO,gBAAgB,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;SACpC;KACF;IAED,MAAM,sBAAsB,GAAqB,MAAM,CAAC,MAAM,CAC5D,gBAAgB,CACjB;SACE,MAAM,CACL,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,IAAI,QAAQ,CAAC,OAAO,EAAE,CACrE;SACA,GAAG,CACF,CAAC,CAAC,EAAE,EAAE,CACJ,CAAC;QACC,IAAI,EAAE,iBAAiB,CAAC,cAAc;QACtC,GAAG,EAAE,CAAC,CAAC,GAAG;QACV,SAAS,EAAE,QAAQ,CAAC,WAAW,EAAE;KACT,CAAC,CAC9B,CAAC;IAEJ,OAAO,sBAAsB,CAAC;AAChC,CAAC","sourcesContent":["import type {\n  ChildExecution,\n  ExecutionHandle,\n  ExecutionID,\n} from \"./execution.js\";\nimport { createChildWorkflowCall } from \"./internal/calls/workflow-call.js\";\nimport { isOrchestratorWorker } from \"./internal/flags.js\";\nimport { getServiceClient, workflows } from \"./internal/global.js\";\nimport { isDurationSchedule, isTimeSchedule } from \"./internal/schedule.js\";\nimport {\n  HistoryStateEvent,\n  isTimerCompleted,\n  isTimerScheduled,\n  TimerCompleted,\n  TimerScheduled,\n  WorkflowEventType,\n} from \"./internal/workflow-events.js\";\nimport type { DurationSchedule } from \"./schedule.js\";\nimport { Schedule } from \"./schedule.js\";\nimport type { StartExecutionRequest } from \"./service-client.js\";\n\nexport interface WorkflowHandler<Input = any, Output = any> {\n  (input: Input, context: WorkflowContext): Promise<Output>;\n}\n\n/**\n * Workflow options available when invoked by another workflow.\n */\nexport interface ChildWorkflowOptions {\n  timeout?: Promise<any> | Schedule;\n}\n\n/**\n * Options which determine how an execution operates.\n *\n * Overrides those provided by the workflow definition.\n */\nexport interface WorkflowExecutionOptions {\n  /**\n   * Number of seconds before or a time to time the workflow out at.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: Schedule;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowDefinitionOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeout?: DurationSchedule;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\nexport type WorkflowArguments<Input = any> = [Input] extends [undefined]\n  ? [input?: Input, options?: ChildWorkflowOptions]\n  : [input: Input, options?: ChildWorkflowOptions];\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  name: string;\n\n  options?: WorkflowDefinitionOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (...args: WorkflowArguments<Input>): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n *\n * Logging using `console.info` (or similar) in a workflow will write logs to the\n * execution's log stream in the service's workflow.\n *\n * To see these logs run `eventual get logs -e <execution>` or find the log group using\n * `eventual show service`.\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowDefinitionOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [\n        opts: WorkflowDefinitionOptions,\n        definition: WorkflowHandler<Input, Output>\n      ]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((\n    input?: any,\n    options?: ChildWorkflowOptions\n  ) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    // a timeout can either by from definition or a eventual/promise or both.\n    // take the invocation time configuration first.\n    const timeout = options?.timeout ?? opts?.timeout;\n\n    return createChildWorkflowCall(\n      name,\n      input,\n      // if the timeout is a time or a duration, from any source, send the timeout to the child execution\n      // to time itself out.\n      {\n        timeout:\n          isDurationSchedule(timeout) || isTimeSchedule(timeout)\n            ? timeout\n            : undefined,\n      },\n      // if an eventual/promise is given, even if it is a duration or a time, timeout based on the\n      // promise resolution.\n      // TODO: support reporting cancellation to children when the parent times out?\n      timeout && \"then\" in timeout ? timeout : undefined\n    );\n  }) as any;\n\n  Object.defineProperty(workflow, \"name\", { value: name, writable: false });\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeout: input.timeout,\n      ...opts,\n    });\n  };\n\n  // @ts-ignore\n  workflow.definition = definition;\n\n  workflows().set(name, workflow);\n  return workflow;\n}\n\n/**\n * Generates synthetic events, for example, {@link TimerCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): TimerCompleted[] {\n  const unresolvedTimers: Record<number, TimerScheduled> = {};\n\n  const timerEvents = events.filter(\n    (event): event is TimerScheduled | TimerCompleted =>\n      isTimerScheduled(event) || isTimerCompleted(event)\n  );\n\n  for (const event of timerEvents) {\n    if (isTimerScheduled(event)) {\n      unresolvedTimers[event.seq] = event;\n    } else {\n      delete unresolvedTimers[event.seq];\n    }\n  }\n\n  const syntheticTimerComplete: TimerCompleted[] = Object.values(\n    unresolvedTimers\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.TimerCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies TimerCompleted)\n    );\n\n  return syntheticTimerComplete;\n}\n\n/**\n * Context values related to the current execution of the workflow.\n */\nexport interface WorkflowExecutionContext {\n  /**\n   * Computed, Unique ID of the execution.\n   */\n  id: ExecutionID;\n  /**\n   * Unique name of the execution, optionally provided in the startWorkflow call.\n   */\n  name: string;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentId?: ExecutionID;\n  /**\n   * The ISO 8601 UTC time the execution started.\n   */\n  startTime: string;\n}\n\n/**\n * Context values related to the workflow definition.\n */\nexport interface WorkflowDefinitionContext {\n  /**\n   * The name of the workflow.\n   */\n  name: string;\n}\n\n/**\n * Context values provided to each workflow execution.\n */\nexport interface WorkflowContext {\n  /**\n   * Context values related to the current execution of the workflow.\n   */\n  workflow: WorkflowDefinitionContext;\n  /**\n   * Context values related to the workflow definition.\n   */\n  execution: WorkflowExecutionContext;\n}\n"]}
{
"name": "@eventual/core",
"version": "0.28.2",
"version": "0.28.3",
"exports": {

@@ -5,0 +5,0 @@ ".": {

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc