@eventual/core
Advanced tools
Comparing version 0.2.0 to 0.3.0
@@ -21,3 +21,3 @@ import { CompleteActivityRequest } from "./runtime/clients/workflow-client.js"; | ||
} | ||
export interface ActivityFunction<Arguments extends any[], Output extends any = any> { | ||
export interface ActivityFunction<Arguments extends any[], Output = any> { | ||
(...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>; | ||
@@ -47,3 +47,3 @@ /** | ||
} | ||
export interface ActivityHandler<Arguments extends any[], Output extends any = any> { | ||
export interface ActivityHandler<Arguments extends any[], Output = any> { | ||
(...args: Arguments): Promise<Awaited<Output>> | Output | AsyncResult<Output> | Promise<AsyncResult<Awaited<Output>>>; | ||
@@ -95,4 +95,4 @@ } | ||
*/ | ||
export declare function activity<Arguments extends any[], Output extends any = any>(activityID: string, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output extends any = any>(activityID: string, opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output = any>(activityID: string, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output = any>(activityID: string, opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
/** | ||
@@ -99,0 +99,0 @@ * Retrieve an activity function that has been registered in a workflow. |
@@ -80,2 +80,2 @@ "use strict"; | ||
exports.getCallableActivityNames = getCallableActivityNames; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":";;;AAAA,+DAA8D;AAC9D,2CAIqB;AAErB,iDAA4E;AAqE5E,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;AAU3D,SAAgB,aAAa,CAAC,GAAQ;IACpC,OAAO,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,gBAAgB,CAAC;AAC7D,CAAC;AAFD,sCAEC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACI,KAAK,UAAU,WAAW,CAC/B,YAAqD;IAErD,IAAI,CAAC,IAAA,2BAAgB,GAAE,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IACD,MAAM,eAAe,GAAG,IAAA,8BAAkB,GAAE,CAAC;IAC7C,IAAI,CAAC,eAAe,EAAE;QACpB,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;KACH;IACD,MAAM,YAAY,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAClD,OAAO;QACL,CAAC,gBAAgB,CAAC,EAAE,gBAAoD;KACzE,CAAC;AACJ,CAAC;AAhBD,kCAgBC;AAwBD,SAAgB,QAAQ,CACtB,UAAkB,EAClB,GAAG,IAE8C;IAEjD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxE,IAAI,IAAyC,CAAC;IAC9C,IAAI,IAAA,+BAAoB,GAAE,EAAE;QAC1B,+FAA+F;QAC/F,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;YACnE,OAAO,IAAA,qCAAkB,EACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;QACX,CAAC,CAAwC,CAAC;KAC3C;SAAM;QACL,4DAA4D;QAC5D,yDAAyD;QACzD,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;QAC3C,4EAA4E;QAC5E,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAGpC,CAAC;KACH;IACD,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,IAAA,6BAAiB,GAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,CAAC,CAAC;IACF,OAAO,IAAI,CAAC;AACd,CAAC;AAhCD,4BAgCC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,UAAkB;IAElB,OAAO,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAyB,CAAC;AAClE,CAAC;AAJD,kDAIC;AAED,SAAgB,wBAAwB;IACtC,OAAO,MAAM,CAAC,IAAI,CAAC,IAAA,8BAAkB,GAAE,CAAC,CAAC;AAC3C,CAAC;AAFD,4DAEC","sourcesContent":["import { createActivityCall } from \"./calls/activity-call.js\";\nimport {\n  callableActivities,\n  getActivityContext,\n  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<\n  Arguments extends any[],\n  Output extends any = any\n> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n}\n\nexport interface ActivityHandler<\n  Arguments extends any[],\n  Output extends any = any\n> {\n  (...args: Arguments):\n    | Promise<Awaited<Output>>\n    | Output\n    | AsyncResult<Output>\n    | Promise<AsyncResult<Awaited<Output>>>;\n}\n\nexport type UnwrapAsync<Output> = Output extends AsyncResult<infer O>\n  ? O\n  : Output;\n\nconst AsyncTokenSymbol = Symbol.for(\"eventual:AsyncToken\");\n\n/**\n * When returned from an activity, the activity will become async,\n * allowing it to run \"forever\". The\n */\nexport interface AsyncResult<Output = any> {\n  [AsyncTokenSymbol]: typeof AsyncTokenSymbol & Output;\n}\n\nexport function isAsyncResult(obj: any): obj is AsyncResult {\n  return !!obj && obj[AsyncTokenSymbol] === AsyncTokenSymbol;\n}\n\n/**\n * When returned from an {@link activity}, tells the system to make the current\n * activity async. This allows the activity to defer sending a response from the\n * current function and instead complete the activity with {@link WorkflowClient.completeActivity}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the completeActivity function will be called later with a string result.\n *    return asyncResult<string>(async (activityToken) => {\n *       // before exiting, send the activityToken to a sqs queue to be completed later\n *       // you could invoke any service here\n *       await sqs.send(new SendMessageCommand({ ..., message: JSONl.stringify({ activityToken })));\n *    });\n * })\n * ```\n *\n * @param tokenContext is a callback which provides the activityToken. The activity token is used\n *                     to completeActivity and heartbeatActivity from outside of the\n *                     activity.\n */\nexport async function asyncResult<Output = any>(\n  tokenContext: (token: string) => Promise<void> | void\n): Promise<AsyncResult<Output>> {\n  if (!isActivityWorker()) {\n    throw new Error(\"asyncResult can only be called from within an activity.\");\n  }\n  const activityContext = getActivityContext();\n  if (!activityContext) {\n    throw new Error(\n      \"Activity context has not been set yet, asyncResult can only be used from within an activity.\"\n    );\n  }\n  await tokenContext(activityContext.activityToken);\n  return {\n    [AsyncTokenSymbol]: AsyncTokenSymbol as typeof AsyncTokenSymbol & Output,\n  };\n}\n\nexport interface ActivityContext {\n  workflowName: string;\n  executionId: string;\n  activityToken: string;\n  scheduledTime: string;\n}\n\n/**\n * Registers a function as an Activity.\n *\n * @param activityID a string that uniquely identifies the Activity within a single workflow context.\n * @param handler the function that handles the activity\n */\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  opts: ActivityOptions,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  ...args:\n    | [opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>]\n    | [handler: ActivityHandler<Arguments, Output>]\n): ActivityFunction<Arguments, Output> {\n  const [opts, handler] = args.length === 1 ? [undefined, args[0]] : args;\n  let func: ActivityFunction<Arguments, Output>;\n  if (isOrchestratorWorker()) {\n    // if we're in the orchestrator, return a command to invoke the activity in the worker function\n    func = ((...args: Parameters<ActivityFunction<Arguments, Output>>) => {\n      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    }) as ActivityFunction<Arguments, Output>;\n  } else {\n    // otherwise we must be in an activity, event or api handler\n    // register the handler to be looked up during execution.\n    callableActivities()[activityID] = handler;\n    // calling the activity from outside the orchestrator just calls the handler\n    func = ((...args) => handler(...args)) as ActivityFunction<\n      Arguments,\n      Output\n    >;\n  }\n  func.complete = async function (request) {\n    return getWorkflowClient().completeActivity(request);\n  };\n  return func;\n}\n\n/**\n * Retrieve an activity function that has been registered in a workflow.\n */\nexport function getCallableActivity(\n  activityId: string\n): ActivityHandler<any> | undefined {\n  return callableActivities()[activityId] as ActivityHandler<any>;\n}\n\nexport function getCallableActivityNames() {\n  return Object.keys(callableActivities());\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":";;;AAAA,+DAA8D;AAC9D,2CAIqB;AAErB,iDAA4E;AA+D5E,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;AAU3D,SAAgB,aAAa,CAAC,GAAQ;IACpC,OAAO,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,gBAAgB,CAAC;AAC7D,CAAC;AAFD,sCAEC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACI,KAAK,UAAU,WAAW,CAC/B,YAAqD;IAErD,IAAI,CAAC,IAAA,2BAAgB,GAAE,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IACD,MAAM,eAAe,GAAG,IAAA,8BAAkB,GAAE,CAAC;IAC7C,IAAI,CAAC,eAAe,EAAE;QACpB,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;KACH;IACD,MAAM,YAAY,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAClD,OAAO;QACL,CAAC,gBAAgB,CAAC,EAAE,gBAAoD;KACzE,CAAC;AACJ,CAAC;AAhBD,kCAgBC;AAwBD,SAAgB,QAAQ,CACtB,UAAkB,EAClB,GAAG,IAE8C;IAEjD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxE,IAAI,IAAyC,CAAC;IAC9C,IAAI,IAAA,+BAAoB,GAAE,EAAE;QAC1B,+FAA+F;QAC/F,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;YACnE,OAAO,IAAA,qCAAkB,EACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;QACX,CAAC,CAAwC,CAAC;KAC3C;SAAM;QACL,4DAA4D;QAC5D,yDAAyD;QACzD,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;QAC3C,4EAA4E;QAC5E,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAGpC,CAAC;KACH;IACD,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,IAAA,6BAAiB,GAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,CAAC,CAAC;IACF,OAAO,IAAI,CAAC;AACd,CAAC;AAhCD,4BAgCC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,UAAkB;IAElB,OAAO,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAyB,CAAC;AAClE,CAAC;AAJD,kDAIC;AAED,SAAgB,wBAAwB;IACtC,OAAO,MAAM,CAAC,IAAI,CAAC,IAAA,8BAAkB,GAAE,CAAC,CAAC;AAC3C,CAAC;AAFD,4DAEC","sourcesContent":["import { createActivityCall } from \"./calls/activity-call.js\";\nimport {\n  callableActivities,\n  getActivityContext,\n  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<Arguments extends any[], Output = any> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n}\n\nexport interface ActivityHandler<Arguments extends any[], Output = any> {\n  (...args: Arguments):\n    | Promise<Awaited<Output>>\n    | Output\n    | AsyncResult<Output>\n    | Promise<AsyncResult<Awaited<Output>>>;\n}\n\nexport type UnwrapAsync<Output> = Output extends AsyncResult<infer O>\n  ? O\n  : Output;\n\nconst AsyncTokenSymbol = Symbol.for(\"eventual:AsyncToken\");\n\n/**\n * When returned from an activity, the activity will become async,\n * allowing it to run \"forever\". The\n */\nexport interface AsyncResult<Output = any> {\n  [AsyncTokenSymbol]: typeof AsyncTokenSymbol & Output;\n}\n\nexport function isAsyncResult(obj: any): obj is AsyncResult {\n  return !!obj && obj[AsyncTokenSymbol] === AsyncTokenSymbol;\n}\n\n/**\n * When returned from an {@link activity}, tells the system to make the current\n * activity async. This allows the activity to defer sending a response from the\n * current function and instead complete the activity with {@link WorkflowClient.completeActivity}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the completeActivity function will be called later with a string result.\n *    return asyncResult<string>(async (activityToken) => {\n *       // before exiting, send the activityToken to a sqs queue to be completed later\n *       // you could invoke any service here\n *       await sqs.send(new SendMessageCommand({ ..., message: JSONl.stringify({ activityToken })));\n *    });\n * })\n * ```\n *\n * @param tokenContext is a callback which provides the activityToken. The activity token is used\n *                     to completeActivity and heartbeatActivity from outside of the\n *                     activity.\n */\nexport async function asyncResult<Output = any>(\n  tokenContext: (token: string) => Promise<void> | void\n): Promise<AsyncResult<Output>> {\n  if (!isActivityWorker()) {\n    throw new Error(\"asyncResult can only be called from within an activity.\");\n  }\n  const activityContext = getActivityContext();\n  if (!activityContext) {\n    throw new Error(\n      \"Activity context has not been set yet, asyncResult can only be used from within an activity.\"\n    );\n  }\n  await tokenContext(activityContext.activityToken);\n  return {\n    [AsyncTokenSymbol]: AsyncTokenSymbol as typeof AsyncTokenSymbol & Output,\n  };\n}\n\nexport interface ActivityContext {\n  workflowName: string;\n  executionId: string;\n  activityToken: string;\n  scheduledTime: string;\n}\n\n/**\n * Registers a function as an Activity.\n *\n * @param activityID a string that uniquely identifies the Activity within a single workflow context.\n * @param handler the function that handles the activity\n */\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  opts: ActivityOptions,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  ...args:\n    | [opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>]\n    | [handler: ActivityHandler<Arguments, Output>]\n): ActivityFunction<Arguments, Output> {\n  const [opts, handler] = args.length === 1 ? [undefined, args[0]] : args;\n  let func: ActivityFunction<Arguments, Output>;\n  if (isOrchestratorWorker()) {\n    // if we're in the orchestrator, return a command to invoke the activity in the worker function\n    func = ((...args: Parameters<ActivityFunction<Arguments, Output>>) => {\n      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    }) as ActivityFunction<Arguments, Output>;\n  } else {\n    // otherwise we must be in an activity, event or api handler\n    // register the handler to be looked up during execution.\n    callableActivities()[activityID] = handler;\n    // calling the activity from outside the orchestrator just calls the handler\n    func = ((...args) => handler(...args)) as ActivityFunction<\n      Arguments,\n      Output\n    >;\n  }\n  func.complete = async function (request) {\n    return getWorkflowClient().completeActivity(request);\n  };\n  return func;\n}\n\n/**\n * Retrieve an activity function that has been registered in a workflow.\n */\nexport function getCallableActivity(\n  activityId: string\n): ActivityHandler<any> | undefined {\n  return callableActivities()[activityId] as ActivityHandler<any>;\n}\n\nexport function getCallableActivityNames() {\n  return Object.keys(callableActivities());\n}\n"]} |
@@ -13,3 +13,3 @@ "use strict"; | ||
return (0, global_js_1.registerEventual)((0, eventual_js_1.createEventual)(eventual_js_1.EventualKind.RegisterSignalHandlerCall, { | ||
signalId: signalId, | ||
signalId, | ||
handler, | ||
@@ -22,2 +22,2 @@ dispose: function () { | ||
exports.createRegisterSignalHandlerCall = createRegisterSignalHandlerCall; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmFsLWhhbmRsZXItY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy9zaWduYWwtaGFuZGxlci1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQUt3QjtBQUV4Qiw0Q0FBZ0Q7QUFFaEQsNENBQWdEO0FBRWhELFNBQWdCLDJCQUEyQixDQUN6QyxDQUFNO0lBRU4sT0FBTyxJQUFBLDhCQUFnQixFQUFDLDBCQUFZLENBQUMseUJBQXlCLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDckUsQ0FBQztBQUpELGtFQUlDO0FBVUQsU0FBZ0IsK0JBQStCLENBQzdDLFFBQWdCLEVBQ2hCLE9BQTZDO0lBRTdDLE9BQU8sSUFBQSw0QkFBZ0IsRUFDckIsSUFBQSw0QkFBYyxFQUFDLDBCQUFZLENBQUMseUJBQXlCLEVBQUU7UUFDckQsUUFBUSxFQUFFLFFBQVE7UUFDbEIsT0FBTztRQUNQLE9BQU8sRUFBRTtZQUNQLElBQUksQ0FBQyxNQUFNLEdBQUcsa0JBQU0sQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDM0MsQ0FBQztLQUNGLENBQUMsQ0FDSCxDQUFDO0FBQ0osQ0FBQztBQWJELDBFQWFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY3JlYXRlRXZlbnR1YWwsXG4gIEV2ZW50dWFsQmFzZSxcbiAgRXZlbnR1YWxLaW5kLFxuICBpc0V2ZW50dWFsT2ZLaW5kLFxufSBmcm9tIFwiLi4vZXZlbnR1YWwuanNcIjtcbmltcG9ydCB7IFNpZ25hbHNIYW5kbGVyIH0gZnJvbSBcIi4uL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IHJlZ2lzdGVyRXZlbnR1YWwgfSBmcm9tIFwiLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBQcm9ncmFtIH0gZnJvbSBcIi4uL2ludGVycHJldC5qc1wiO1xuaW1wb3J0IHsgUmVzb2x2ZWQsIFJlc3VsdCB9IGZyb20gXCIuLi9yZXN1bHQuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbChcbiAgYTogYW55XG4pOiBhIGlzIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwge1xuICByZXR1cm4gaXNFdmVudHVhbE9mS2luZChFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwgYSk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbDxUID0gYW55PlxuICBleHRlbmRzIEV2ZW50dWFsQmFzZTxFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwgUmVzb2x2ZWQ+LFxuICAgIFNpZ25hbHNIYW5kbGVyIHtcbiAgc2VxPzogbnVtYmVyO1xuICBzaWduYWxJZDogc3RyaW5nO1xuICBoYW5kbGVyOiAoaW5wdXQ6IFQpID0+IFByb2dyYW0gfCB2b2lkO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbChcbiAgc2lnbmFsSWQ6IHN0cmluZyxcbiAgaGFuZGxlcjogUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbFtcImhhbmRsZXJcIl1cbik6IFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwge1xuICByZXR1cm4gcmVnaXN0ZXJFdmVudHVhbChcbiAgICBjcmVhdGVFdmVudHVhbChFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwge1xuICAgICAgc2lnbmFsSWQ6IHNpZ25hbElkLFxuICAgICAgaGFuZGxlcixcbiAgICAgIGRpc3Bvc2U6IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgdGhpcy5yZXN1bHQgPSBSZXN1bHQucmVzb2x2ZWQodW5kZWZpbmVkKTtcbiAgICAgIH0sXG4gICAgfSlcbiAgKTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmFsLWhhbmRsZXItY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy9zaWduYWwtaGFuZGxlci1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQUt3QjtBQUV4Qiw0Q0FBZ0Q7QUFFaEQsNENBQWdEO0FBRWhELFNBQWdCLDJCQUEyQixDQUN6QyxDQUFNO0lBRU4sT0FBTyxJQUFBLDhCQUFnQixFQUFDLDBCQUFZLENBQUMseUJBQXlCLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDckUsQ0FBQztBQUpELGtFQUlDO0FBVUQsU0FBZ0IsK0JBQStCLENBQzdDLFFBQWdCLEVBQ2hCLE9BQTZDO0lBRTdDLE9BQU8sSUFBQSw0QkFBZ0IsRUFDckIsSUFBQSw0QkFBYyxFQUFDLDBCQUFZLENBQUMseUJBQXlCLEVBQUU7UUFDckQsUUFBUTtRQUNSLE9BQU87UUFDUCxPQUFPLEVBQUU7WUFDUCxJQUFJLENBQUMsTUFBTSxHQUFHLGtCQUFNLENBQUMsUUFBUSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1FBQzNDLENBQUM7S0FDRixDQUFDLENBQ0gsQ0FBQztBQUNKLENBQUM7QUFiRCwwRUFhQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGNyZWF0ZUV2ZW50dWFsLFxuICBFdmVudHVhbEJhc2UsXG4gIEV2ZW50dWFsS2luZCxcbiAgaXNFdmVudHVhbE9mS2luZCxcbn0gZnJvbSBcIi4uL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgeyBTaWduYWxzSGFuZGxlciB9IGZyb20gXCIuLi9zaWduYWxzLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlckV2ZW50dWFsIH0gZnJvbSBcIi4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgUHJvZ3JhbSB9IGZyb20gXCIuLi9pbnRlcnByZXQuanNcIjtcbmltcG9ydCB7IFJlc29sdmVkLCBSZXN1bHQgfSBmcm9tIFwiLi4vcmVzdWx0LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1JlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwoXG4gIGE6IGFueVxuKTogYSBpcyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIHtcbiAgcmV0dXJuIGlzRXZlbnR1YWxPZktpbmQoRXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIGEpO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGw8VCA9IGFueT5cbiAgZXh0ZW5kcyBFdmVudHVhbEJhc2U8RXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIFJlc29sdmVkPixcbiAgICBTaWduYWxzSGFuZGxlciB7XG4gIHNlcT86IG51bWJlcjtcbiAgc2lnbmFsSWQ6IHN0cmluZztcbiAgaGFuZGxlcjogKGlucHV0OiBUKSA9PiBQcm9ncmFtIHwgdm9pZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwoXG4gIHNpZ25hbElkOiBzdHJpbmcsXG4gIGhhbmRsZXI6IFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGxbXCJoYW5kbGVyXCJdXG4pOiBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIHtcbiAgcmV0dXJuIHJlZ2lzdGVyRXZlbnR1YWwoXG4gICAgY3JlYXRlRXZlbnR1YWwoRXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIHtcbiAgICAgIHNpZ25hbElkLFxuICAgICAgaGFuZGxlcixcbiAgICAgIGRpc3Bvc2U6IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgdGhpcy5yZXN1bHQgPSBSZXN1bHQucmVzb2x2ZWQodW5kZWZpbmVkKTtcbiAgICAgIH0sXG4gICAgfSlcbiAgKTtcbn1cbiJdfQ== |
@@ -84,2 +84,2 @@ "use strict"; | ||
exports.SynchronousOperationError = SynchronousOperationError; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsTUFBYSxhQUFjLFNBQVEsS0FBSztJQUN0QyxZQUFZLElBQVksRUFBRSxPQUFnQjtRQUN4QyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDZixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUNuQixDQUFDO0lBQ0Q7O09BRUc7SUFDSCxNQUFNO1FBQ0osT0FBTztZQUNMLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztTQUN0QixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBZEQsc0NBY0M7QUFDRCxNQUFhLGdCQUFpQixTQUFRLGFBQWE7SUFDakQsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDckMsQ0FBQztDQUNGO0FBSkQsNENBSUM7QUFDRDs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSCxNQUFhLE9BQVEsU0FBUSxhQUFhO0lBQ3hDLFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFKRCwwQkFJQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsZ0JBQWlCLFNBQVEsT0FBTztJQUMzQyxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsa0JBQWtCLENBQUM7SUFDakMsQ0FBQztDQUNGO0FBTEQsNENBS0M7QUFDRDs7R0FFRztBQUNILE1BQWEseUJBQTBCLFNBQVEsYUFBYTtJQUMxRCxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQywyQkFBMkIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM5QyxDQUFDO0NBQ0Y7QUFKRCw4REFJQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBFdmVudHVhbEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICB9XG4gIC8qKlxuICAgKiBQcm92aWRlcyBhIHJlYXNvbmFibGUgZm9ybSB3aGVuIHJ1bm5pbmcgSlNPTi5zdHJpbmdpZnkuXG4gICAqL1xuICB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIG1lc3NhZ2U6IHRoaXMubWVzc2FnZSxcbiAgICB9O1xuICB9XG59XG5leHBvcnQgY2xhc3MgRGV0ZXJtaW5pc21FcnJvciBleHRlbmRzIEV2ZW50dWFsRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIoXCJEZXRlcm1pbmlzbUVycm9yXCIsIG1lc3NhZ2UpO1xuICB9XG59XG4vKipcbiAqIFRocm93biBmcm9tIHdpdGhpbiBhIHdvcmtmbG93IHdoZW4gYW55IHNldCB0aW1lb3V0IGV4cGlyZXMuXG4gKlxuICogYGBgdHNcbiAqIGNvbnN0IG15QWN0ID0gbmV3IGFjdGl2aXR5KFwibXlBY3RcIiwge3RpbWVvdXRTZWNvbmRzOiAxMDB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3QgdGltZSBvdXQhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IHRpbWVkIG91dCFcIjtcbiAqICAgICAgIH1cbiAqICAgICAgIHRocm93IGVycjtcbiAqICAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFRpbWVvdXQgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiVGltZW91dFwiLCBtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIFRocm93biB3aGVuIGFuIGFjdGl2aXR5IGZhaWxzIHRvIHNlbmQgaGVhcnRiZWF0cy5cbiAqXG4gKiBgYGB0c1xuICogY29uc3QgbXlBY3QgPSBuZXcgYWN0aXZpdHkoXCJteUFjdFwiLCB7aGVhcnRiZWF0U2Vjb25kczogMTB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGNvbXBsZXRlZCBzdWNjZXNzZnVsbHkhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIEhlYXJ0YmVhdFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3Qgc2VuZCBoZWFydGJlYXRzIVwiO1xuICogICAgICAgfVxuICogICAgICAgdGhyb3cgZXJyO1xuICogICAgfVxuICogfSlcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgSGVhcnRiZWF0VGltZW91dCBleHRlbmRzIFRpbWVvdXQge1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gXCJIZWFydGJlYXRUaW1lb3V0XCI7XG4gIH1cbn1cbi8qKlxuICogVGhyb3duIHdoZW4gYSBwYXJ0aWN1bGFyIGNvbnRleHQgb25seSBzdXBwb3J0IHN5bmNocm9ub3VzIG9wZXJhdGlvbnMgKGV4OiBjb25kaXRpb24gcHJlZGljYXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIFN5bmNocm9ub3VzT3BlcmF0aW9uRXJyb3IgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiU3luY2hyb25vdXNPcGVyYXRpb25FcnJvclwiLCBtZXNzYWdlKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsTUFBYSxhQUFjLFNBQVEsS0FBSztJQUN0QyxZQUFZLElBQVksRUFBRSxPQUFnQjtRQUN4QyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDZixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQztJQUNuQixDQUFDO0lBRUQ7O09BRUc7SUFDSSxNQUFNO1FBQ1gsT0FBTztZQUNMLElBQUksRUFBRSxJQUFJLENBQUMsSUFBSTtZQUNmLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztTQUN0QixDQUFDO0lBQ0osQ0FBQztDQUNGO0FBZkQsc0NBZUM7QUFDRCxNQUFhLGdCQUFpQixTQUFRLGFBQWE7SUFDakQsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsa0JBQWtCLEVBQUUsT0FBTyxDQUFDLENBQUM7SUFDckMsQ0FBQztDQUNGO0FBSkQsNENBSUM7QUFDRDs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSCxNQUFhLE9BQVEsU0FBUSxhQUFhO0lBQ3hDLFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLFNBQVMsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM1QixDQUFDO0NBQ0Y7QUFKRCwwQkFJQztBQUVEOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQWEsZ0JBQWlCLFNBQVEsT0FBTztJQUMzQyxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsa0JBQWtCLENBQUM7SUFDakMsQ0FBQztDQUNGO0FBTEQsNENBS0M7QUFDRDs7R0FFRztBQUNILE1BQWEseUJBQTBCLFNBQVEsYUFBYTtJQUMxRCxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQywyQkFBMkIsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUM5QyxDQUFDO0NBQ0Y7QUFKRCw4REFJQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBFdmVudHVhbEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb3ZpZGVzIGEgcmVhc29uYWJsZSBmb3JtIHdoZW4gcnVubmluZyBKU09OLnN0cmluZ2lmeS5cbiAgICovXG4gIHB1YmxpYyB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIG1lc3NhZ2U6IHRoaXMubWVzc2FnZSxcbiAgICB9O1xuICB9XG59XG5leHBvcnQgY2xhc3MgRGV0ZXJtaW5pc21FcnJvciBleHRlbmRzIEV2ZW50dWFsRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIoXCJEZXRlcm1pbmlzbUVycm9yXCIsIG1lc3NhZ2UpO1xuICB9XG59XG4vKipcbiAqIFRocm93biBmcm9tIHdpdGhpbiBhIHdvcmtmbG93IHdoZW4gYW55IHNldCB0aW1lb3V0IGV4cGlyZXMuXG4gKlxuICogYGBgdHNcbiAqIGNvbnN0IG15QWN0ID0gbmV3IGFjdGl2aXR5KFwibXlBY3RcIiwge3RpbWVvdXRTZWNvbmRzOiAxMDB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3QgdGltZSBvdXQhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IHRpbWVkIG91dCFcIjtcbiAqICAgICAgIH1cbiAqICAgICAgIHRocm93IGVycjtcbiAqICAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFRpbWVvdXQgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiVGltZW91dFwiLCBtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIFRocm93biB3aGVuIGFuIGFjdGl2aXR5IGZhaWxzIHRvIHNlbmQgaGVhcnRiZWF0cy5cbiAqXG4gKiBgYGB0c1xuICogY29uc3QgbXlBY3QgPSBuZXcgYWN0aXZpdHkoXCJteUFjdFwiLCB7aGVhcnRiZWF0U2Vjb25kczogMTB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGNvbXBsZXRlZCBzdWNjZXNzZnVsbHkhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIEhlYXJ0YmVhdFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3Qgc2VuZCBoZWFydGJlYXRzIVwiO1xuICogICAgICAgfVxuICogICAgICAgdGhyb3cgZXJyO1xuICogICAgfVxuICogfSlcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgSGVhcnRiZWF0VGltZW91dCBleHRlbmRzIFRpbWVvdXQge1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gXCJIZWFydGJlYXRUaW1lb3V0XCI7XG4gIH1cbn1cbi8qKlxuICogVGhyb3duIHdoZW4gYSBwYXJ0aWN1bGFyIGNvbnRleHQgb25seSBzdXBwb3J0IHN5bmNocm9ub3VzIG9wZXJhdGlvbnMgKGV4OiBjb25kaXRpb24gcHJlZGljYXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIFN5bmNocm9ub3VzT3BlcmF0aW9uRXJyb3IgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiU3luY2hyb25vdXNPcGVyYXRpb25FcnJvclwiLCBtZXNzYWdlKTtcbiAgfVxufVxuIl19 |
import { ActivityCall } from "./calls/activity-call.js"; | ||
import { AwaitAll } from "./await-all.js"; | ||
import { Chain } from "./chain.js"; | ||
import { chain, Chain } from "./chain.js"; | ||
import type { Program } from "./interpret.js"; | ||
@@ -47,3 +47,3 @@ import { Result } from "./result.js"; | ||
export declare function isCommandCall(call: Eventual): call is CommandCall; | ||
export declare namespace Eventual { | ||
export declare const Eventual: { | ||
/** | ||
@@ -54,7 +54,7 @@ * Wait for all {@link activities} to complete or until at least one throws. | ||
*/ | ||
function all<A extends Eventual[]>(activities: A): AwaitAll<EventualArrayPositional<A>>; | ||
function any<A extends Eventual[]>(activities: A): AwaitAny<EventualArrayUnion<A>>; | ||
function race<A extends Eventual[]>(activities: A): Race<EventualArrayUnion<A>>; | ||
function allSettled<A extends Eventual[]>(activities: A): AwaitAllSettled<EventualArrayPromiseResult<A>>; | ||
} | ||
all<A extends Eventual<any>[]>(activities: A): AwaitAll<EventualArrayPositional<A>>; | ||
any<A_1 extends Eventual<any>[]>(activities: A_1): AwaitAny<EventualArrayUnion<A_1>>; | ||
race<A_2 extends Eventual<any>[]>(activities: A_2): Race<EventualArrayUnion<A_2>>; | ||
allSettled<A_3 extends Eventual<any>[]>(activities: A_3): AwaitAllSettled<EventualArrayPromiseResult<A_3>>; | ||
}; | ||
export interface EventualCallCollector { | ||
@@ -70,3 +70,7 @@ pushEventual<E extends Eventual>(activity: E): E; | ||
export type EventualArrayUnion<A extends Eventual<any>[]> = A[number] extends Eventual<infer T> ? T : never; | ||
declare global { | ||
var $eventual: typeof chain; | ||
var $Eventual: typeof Eventual; | ||
} | ||
export {}; | ||
//# sourceMappingURL=eventual.d.ts.map |
@@ -61,4 +61,3 @@ "use strict"; | ||
exports.isCommandCall = isCommandCall; | ||
var Eventual; | ||
(function (Eventual) { | ||
exports.Eventual = { | ||
/** | ||
@@ -69,3 +68,3 @@ * Wait for all {@link activities} to complete or until at least one throws. | ||
*/ | ||
function all(activities) { | ||
all(activities) { | ||
if (!(0, flags_js_1.isOrchestratorWorker)()) { | ||
@@ -75,5 +74,4 @@ throw new Error("Eventual.all is only valid in a workflow"); | ||
return (0, await_all_js_1.createAwaitAll)(activities); | ||
} | ||
Eventual.all = all; | ||
function any(activities) { | ||
}, | ||
any(activities) { | ||
if (!(0, flags_js_1.isOrchestratorWorker)()) { | ||
@@ -83,5 +81,4 @@ throw new Error("Eventual.any is only valid in a workflow"); | ||
return (0, await_any_js_1.createAwaitAny)(activities); | ||
} | ||
Eventual.any = any; | ||
function race(activities) { | ||
}, | ||
race(activities) { | ||
if (!(0, flags_js_1.isOrchestratorWorker)()) { | ||
@@ -91,5 +88,4 @@ throw new Error("Eventual.race is only valid in a workflow"); | ||
return (0, race_js_1.createRace)(activities); | ||
} | ||
Eventual.race = race; | ||
function allSettled(activities) { | ||
}, | ||
allSettled(activities) { | ||
if (!(0, flags_js_1.isOrchestratorWorker)()) { | ||
@@ -99,10 +95,6 @@ throw new Error("Eventual.allSettled is only valid in a workflow"); | ||
return (0, await_all_settled_js_1.createAwaitAllSettled)(activities); | ||
} | ||
Eventual.allSettled = allSettled; | ||
})(Eventual = exports.Eventual || (exports.Eventual = {})); | ||
// the below globals are required by the transformer | ||
// @ts-ignore | ||
}, | ||
}; | ||
global.$eventual = chain_js_1.chain; | ||
// @ts-ignore | ||
global.$Eventual = Eventual; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventual.js","sourceRoot":"","sources":["../../src/eventual.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivityCall, isActivityCall } from \"./calls/activity-call.js\";\nimport { AwaitAll, createAwaitAll } from \"./await-all.js\";\nimport { chain, Chain } from \"./chain.js\";\nimport type { Program } from \"./interpret.js\";\nimport { Result } from \"./result.js\";\nimport {\n  isSleepForCall,\n  isSleepUntilCall,\n  SleepForCall,\n  SleepUntilCall,\n} from \"./calls/sleep-call.js\";\nimport {\n  isExpectSignalCall,\n  ExpectSignalCall,\n} from \"./calls/expect-signal-call.js\";\nimport {\n  isRegisterSignalHandlerCall,\n  RegisterSignalHandlerCall,\n} from \"./calls/signal-handler-call.js\";\nimport { isSendSignalCall, SendSignalCall } from \"./calls/send-signal-call.js\";\nimport { isWorkflowCall, WorkflowCall } from \"./calls/workflow-call.js\";\nimport { ConditionCall, isConditionCall } from \"./calls/condition-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { AwaitAny, createAwaitAny } from \"./await-any.js\";\nimport { AwaitAllSettled, createAwaitAllSettled } from \"./await-all-settled.js\";\nimport { createRace, Race } from \"./race.js\";\nimport {\n  isPublishEventsCall,\n  PublishEventsCall,\n} from \"./calls/send-events-call.js\";\n\nexport type AwaitedEventual<T> = T extends Promise<infer U>\n  ? Awaited<U>\n  : T extends Program<infer U>\n  ? AwaitedEventual<U>\n  : T extends Eventual<infer U>\n  ? AwaitedEventual<U>\n  : T;\n\nconst EventualSymbol = Symbol.for(\"eventual:Eventual\");\n\nexport interface EventualBase<Kind extends EventualKind, R extends Result> {\n  [EventualSymbol]: Kind;\n  result?: R;\n}\n\nexport enum EventualKind {\n  ActivityCall = 1,\n  AwaitAll = 0,\n  AwaitAllSettled = 12,\n  AwaitAny = 10,\n  Chain = 2,\n  ConditionCall = 9,\n  ExpectSignalCall = 6,\n  PublishEventsCall = 13,\n  Race = 11,\n  RegisterSignalHandlerCall = 7,\n  SendSignalCall = 8,\n  SleepForCall = 3,\n  SleepUntilCall = 4,\n  WorkflowCall = 5,\n}\n\nexport function isEventual(a: any): a is Eventual {\n  return a && typeof a === \"object\" && EventualSymbol in a;\n}\n\nexport function isEventualOfKind<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  a: any\n): a is E {\n  return isEventual(a) && a[EventualSymbol] === kind;\n}\n\nexport function createEventual<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  e: Omit<E, typeof EventualSymbol>\n): E {\n  (e as E)[EventualSymbol] = kind;\n  return e as E;\n}\n\nexport type Eventual<T = any> =\n  | AwaitAll<T extends any[] ? T : never>\n  | AwaitAllSettled<T extends any[] ? T : never>\n  | AwaitAny<T extends any[] ? T : never>\n  | Chain<T>\n  | CommandCall<T>\n  | Race<T extends any[] ? T : never>;\n\n/**\n * Calls which emit commands.\n */\nexport type CommandCall<T = any> =\n  | ActivityCall<T>\n  | ConditionCall\n  | ExpectSignalCall<T>\n  | RegisterSignalHandlerCall<T>\n  | PublishEventsCall\n  | SendSignalCall\n  | SleepForCall\n  | SleepUntilCall\n  | WorkflowCall<T>;\n\nexport function isCommandCall(call: Eventual): call is CommandCall {\n  return (\n    isActivityCall(call) ||\n    isConditionCall(call) ||\n    isExpectSignalCall(call) ||\n    isPublishEventsCall(call) ||\n    isRegisterSignalHandlerCall(call) ||\n    isSendSignalCall(call) ||\n    isSleepForCall(call) ||\n    isSleepUntilCall(call) ||\n    isWorkflowCall(call)\n  );\n}\n\nexport namespace Eventual {\n  /**\n   * Wait for all {@link activities} to complete or until at least one throws.\n   *\n   * This is the equivalent behavior to Promise.all.\n   */\n  export function all<A extends Eventual[]>(\n    activities: A\n  ): AwaitAll<EventualArrayPositional<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.all is only valid in a workflow\");\n    }\n\n    return createAwaitAll(activities) as any;\n  }\n\n  export function any<A extends Eventual[]>(\n    activities: A\n  ): AwaitAny<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.any is only valid in a workflow\");\n    }\n\n    return createAwaitAny(activities) as any;\n  }\n\n  export function race<A extends Eventual[]>(\n    activities: A\n  ): Race<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.race is only valid in a workflow\");\n    }\n\n    return createRace(activities) as any;\n  }\n\n  export function allSettled<A extends Eventual[]>(\n    activities: A\n  ): AwaitAllSettled<EventualArrayPromiseResult<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.allSettled is only valid in a workflow\");\n    }\n\n    return createAwaitAllSettled(activities) as any;\n  }\n}\n\nexport interface EventualCallCollector {\n  pushEventual<E extends Eventual>(activity: E): E;\n}\n\nexport type EventualArrayPositional<A extends Eventual[]> = {\n  [i in keyof A]: A[i] extends Eventual<infer T> ? T : A[i];\n};\n\nexport type EventualArrayPromiseResult<A extends Eventual[]> = {\n  [i in keyof A]:\n    | PromiseFulfilledResult<A[i] extends Eventual<infer T> ? T : A[i]>\n    | PromiseRejectedResult;\n};\n\nexport type EventualArrayUnion<A extends Eventual<any>[]> =\n  A[number] extends Eventual<infer T> ? T : never;\n\n// the below globals are required by the transformer\n\n// @ts-ignore\nglobal.$eventual = chain;\n// @ts-ignore\nglobal.$Eventual = Eventual;\n"]} | ||
global.$Eventual = exports.Eventual; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventual.js","sourceRoot":"","sources":["../../src/eventual.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivityCall, isActivityCall } from \"./calls/activity-call.js\";\nimport { AwaitAll, createAwaitAll } from \"./await-all.js\";\nimport { chain, Chain } from \"./chain.js\";\nimport type { Program } from \"./interpret.js\";\nimport { Result } from \"./result.js\";\nimport {\n  isSleepForCall,\n  isSleepUntilCall,\n  SleepForCall,\n  SleepUntilCall,\n} from \"./calls/sleep-call.js\";\nimport {\n  isExpectSignalCall,\n  ExpectSignalCall,\n} from \"./calls/expect-signal-call.js\";\nimport {\n  isRegisterSignalHandlerCall,\n  RegisterSignalHandlerCall,\n} from \"./calls/signal-handler-call.js\";\nimport { isSendSignalCall, SendSignalCall } from \"./calls/send-signal-call.js\";\nimport { isWorkflowCall, WorkflowCall } from \"./calls/workflow-call.js\";\nimport { ConditionCall, isConditionCall } from \"./calls/condition-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { AwaitAny, createAwaitAny } from \"./await-any.js\";\nimport { AwaitAllSettled, createAwaitAllSettled } from \"./await-all-settled.js\";\nimport { createRace, Race } from \"./race.js\";\nimport {\n  isPublishEventsCall,\n  PublishEventsCall,\n} from \"./calls/send-events-call.js\";\n\nexport type AwaitedEventual<T> = T extends Promise<infer U>\n  ? Awaited<U>\n  : T extends Program<infer U>\n  ? AwaitedEventual<U>\n  : T extends Eventual<infer U>\n  ? AwaitedEventual<U>\n  : T;\n\nconst EventualSymbol = Symbol.for(\"eventual:Eventual\");\n\nexport interface EventualBase<Kind extends EventualKind, R extends Result> {\n  [EventualSymbol]: Kind;\n  result?: R;\n}\n\nexport enum EventualKind {\n  ActivityCall = 1,\n  AwaitAll = 0,\n  AwaitAllSettled = 12,\n  AwaitAny = 10,\n  Chain = 2,\n  ConditionCall = 9,\n  ExpectSignalCall = 6,\n  PublishEventsCall = 13,\n  Race = 11,\n  RegisterSignalHandlerCall = 7,\n  SendSignalCall = 8,\n  SleepForCall = 3,\n  SleepUntilCall = 4,\n  WorkflowCall = 5,\n}\n\nexport function isEventual(a: any): a is Eventual {\n  return a && typeof a === \"object\" && EventualSymbol in a;\n}\n\nexport function isEventualOfKind<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  a: any\n): a is E {\n  return isEventual(a) && a[EventualSymbol] === kind;\n}\n\nexport function createEventual<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  e: Omit<E, typeof EventualSymbol>\n): E {\n  (e as E)[EventualSymbol] = kind;\n  return e as E;\n}\n\nexport type Eventual<T = any> =\n  | AwaitAll<T extends any[] ? T : never>\n  | AwaitAllSettled<T extends any[] ? T : never>\n  | AwaitAny<T extends any[] ? T : never>\n  | Chain<T>\n  | CommandCall<T>\n  | Race<T extends any[] ? T : never>;\n\n/**\n * Calls which emit commands.\n */\nexport type CommandCall<T = any> =\n  | ActivityCall<T>\n  | ConditionCall\n  | ExpectSignalCall<T>\n  | RegisterSignalHandlerCall<T>\n  | PublishEventsCall\n  | SendSignalCall\n  | SleepForCall\n  | SleepUntilCall\n  | WorkflowCall<T>;\n\nexport function isCommandCall(call: Eventual): call is CommandCall {\n  return (\n    isActivityCall(call) ||\n    isConditionCall(call) ||\n    isExpectSignalCall(call) ||\n    isPublishEventsCall(call) ||\n    isRegisterSignalHandlerCall(call) ||\n    isSendSignalCall(call) ||\n    isSleepForCall(call) ||\n    isSleepUntilCall(call) ||\n    isWorkflowCall(call)\n  );\n}\n\nexport const Eventual = {\n  /**\n   * Wait for all {@link activities} to complete or until at least one throws.\n   *\n   * This is the equivalent behavior to Promise.all.\n   */\n  all<A extends Eventual[]>(\n    activities: A\n  ): AwaitAll<EventualArrayPositional<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.all is only valid in a workflow\");\n    }\n\n    return createAwaitAll(activities) as any;\n  },\n  any<A extends Eventual[]>(activities: A): AwaitAny<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.any is only valid in a workflow\");\n    }\n\n    return createAwaitAny(activities) as any;\n  },\n  race<A extends Eventual[]>(activities: A): Race<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.race is only valid in a workflow\");\n    }\n\n    return createRace(activities) as any;\n  },\n  allSettled<A extends Eventual[]>(\n    activities: A\n  ): AwaitAllSettled<EventualArrayPromiseResult<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.allSettled is only valid in a workflow\");\n    }\n\n    return createAwaitAllSettled(activities) as any;\n  },\n};\n\nexport interface EventualCallCollector {\n  pushEventual<E extends Eventual>(activity: E): E;\n}\n\nexport type EventualArrayPositional<A extends Eventual[]> = {\n  [i in keyof A]: A[i] extends Eventual<infer T> ? T : A[i];\n};\n\nexport type EventualArrayPromiseResult<A extends Eventual[]> = {\n  [i in keyof A]:\n    | PromiseFulfilledResult<A[i] extends Eventual<infer T> ? T : A[i]>\n    | PromiseRejectedResult;\n};\n\nexport type EventualArrayUnion<A extends Eventual<any>[]> =\n  A[number] extends Eventual<infer T> ? T : never;\n\n// the below globals are required by the transformer\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var $eventual: typeof chain;\n  // eslint-disable-next-line no-var\n  var $Eventual: typeof Eventual;\n}\n\nglobal.$eventual = chain;\nglobal.$Eventual = Eventual;\n"]} |
@@ -80,2 +80,2 @@ "use strict"; | ||
exports.getEventClient = getEventClient; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":";;;AAuDA,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;AAEnB,MAAM,SAAS,GAAG,GAA0B,EAAE,CACnD,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,KAAK,IAAI,GAAG,EAAoB,CAAC,CAAC;AADtD,QAAA,SAAS,aAC6C;AAE5D,MAAM,MAAM,GAAG,GAAuB,EAAE,CAC7C,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,GAAG,EAAiB,CAAC,CAAC;AADhD,QAAA,MAAM,UAC0C;AAEtD,MAAM,kBAAkB,GAAG,GAAwB,EAAE,CAC1D,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AADtC,QAAA,kBAAkB,sBACoB;AAE5C,MAAM,kBAAkB,GAAG,GAAyC,EAAE,CAC3E,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AADtC,QAAA,kBAAkB,sBACoB;AAEnD,MAAM,iBAAiB,GAAG,GAA0B,EAAE;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,iBAAiB,CAAC;IACzD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,SAAgB,gBAAgB,CAAqB,QAAW;IAC9D,OAAO,iBAAiB,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpD,CAAC;AAFD,4CAEC;AAED,SAAgB,oBAAoB,CAAC,SAAgC;IACnE,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAFD,oDAEC;AAED,SAAgB,sBAAsB;IACpC,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAFD,wDAEC;AAED;;;GAGG;AACH,SAAgB,sBAAsB,CAAC,MAAsB;IAC3D,UAAU,CAAC,SAAS,CAAC,cAAc,GAAG,MAAM,CAAC;AAC/C,CAAC;AAFD,wDAEC;AAED;;GAEG;AACH,SAAgB,iBAAiB;IAC/B,IAAI,UAAU,CAAC,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,cAAc,CAAC;AAC7C,CAAC;AALD,8CAKC;AAED,SAAgB,kBAAkB,CAAC,OAAwB;IACzD,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC;AACjD,CAAC;AAFD,gDAEC;AAED,SAAgB,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,eAAe,CAAC;IAErD,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAC;KACH;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AATD,gDASC;AAED;;;GAGG;AACH,SAAgB,mBAAmB,CAAC,MAAmB;IACrD,UAAU,CAAC,SAAS,CAAC,WAAW,GAAG,MAAM,CAAC;AAC5C,CAAC;AAFD,kDAEC;AAED;;GAEG;AACH,SAAgB,cAAc;IAC5B,IAAI,UAAU,CAAC,SAAS,CAAC,WAAW,KAAK,SAAS,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,WAAW,CAAC;AAC1C,CAAC;AALD,wCAKC","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":";;;AAwDA,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;AAEnB,MAAM,SAAS,GAAG,GAA0B,EAAE,CACnD,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,KAAK,IAAI,GAAG,EAAoB,CAAC,CAAC;AADtD,QAAA,SAAS,aAC6C;AAE5D,MAAM,MAAM,GAAG,GAAuB,EAAE,CAC7C,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,GAAG,EAAiB,CAAC,CAAC;AADhD,QAAA,MAAM,UAC0C;AAEtD,MAAM,kBAAkB,GAAG,GAAwB,EAAE,CAC1D,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AADtC,QAAA,kBAAkB,sBACoB;AAE5C,MAAM,kBAAkB,GAAG,GAAyC,EAAE,CAC3E,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AADtC,QAAA,kBAAkB,sBACoB;AAEnD,MAAM,iBAAiB,GAAG,GAA0B,EAAE;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,iBAAiB,CAAC;IACzD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,SAAgB,gBAAgB,CAAqB,QAAW;IAC9D,OAAO,iBAAiB,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpD,CAAC;AAFD,4CAEC;AAED,SAAgB,oBAAoB,CAAC,SAAgC;IACnE,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAFD,oDAEC;AAED,SAAgB,sBAAsB;IACpC,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAFD,wDAEC;AAED;;;GAGG;AACH,SAAgB,sBAAsB,CAAC,MAAsB;IAC3D,UAAU,CAAC,SAAS,CAAC,cAAc,GAAG,MAAM,CAAC;AAC/C,CAAC;AAFD,wDAEC;AAED;;GAEG;AACH,SAAgB,iBAAiB;IAC/B,IAAI,UAAU,CAAC,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,cAAc,CAAC;AAC7C,CAAC;AALD,8CAKC;AAED,SAAgB,kBAAkB,CAAC,OAAwB;IACzD,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC;AACjD,CAAC;AAFD,gDAEC;AAED,SAAgB,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,eAAe,CAAC;IAErD,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAC;KACH;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AATD,gDASC;AAED;;;GAGG;AACH,SAAgB,mBAAmB,CAAC,MAAmB;IACrD,UAAU,CAAC,SAAS,CAAC,WAAW,GAAG,MAAM,CAAC;AAC5C,CAAC;AAFD,kDAEC;AAED;;GAEG;AACH,SAAgB,cAAc;IAC5B,IAAI,UAAU,CAAC,SAAS,CAAC,WAAW,KAAK,SAAS,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,WAAW,CAAC;AAC1C,CAAC;AALD,wCAKC","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]} |
@@ -22,3 +22,3 @@ "use strict"; | ||
return await (0, global_js_1.getWorkflowClient)().heartbeatActivity({ | ||
activityToken: activityToken, | ||
activityToken, | ||
}); | ||
@@ -37,2 +37,2 @@ } | ||
exports.heartbeat = heartbeat; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBb0U7QUFFcEUsaURBQTRFO0FBRTVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxJQUFBLDZCQUFpQixHQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYSxFQUFFLGFBQWE7U0FDN0IsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLElBQUEsMkJBQWdCLEdBQUUsRUFBRTtRQUM3QixNQUFNLEtBQUssR0FBRyxJQUFBLDhCQUFrQixHQUFFLENBQUMsYUFBYSxDQUFDO1FBQ2pELE9BQU8sTUFBTSxJQUFBLDZCQUFpQixHQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUM7QUFyQkQsOEJBcUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0QWN0aXZpdHlDb250ZXh0LCBnZXRXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgSGVhcnRiZWF0UmVzcG9uc2UgfSBmcm9tIFwiLi9ydW50aW1lL2NsaWVudHMvd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBpc0FjdGl2aXR5V29ya2VyLCBpc09yY2hlc3RyYXRvcldvcmtlciB9IGZyb20gXCIuL3J1bnRpbWUvZmxhZ3MuanNcIjtcblxuLyoqXG4gKiBTZW5kcyBhIGhlYXJ0YmVhdCBmb3IgdGhlIGN1cnJlbnQgYWN0aXZpdHkgb3IgdG8gdGhlIHByb3ZpZGVkIGFjdGl2aXR5IHRva2VuLlxuICpcbiAqIElmIGNhbGxlZCBmcm9tIG91dHNpZGUgb2YgYW4ge0BsaW5rIGFjdGl2aXR5fSwgdGhlIGFjdGl2aXR5IHRva2VuIG11c3QgYmUgcHJvdmlkZWQuXG4gKlxuICogSWYgdGhlIGFjdGl2aXR5IGhhcyBhIGhlYXJ0YmVhdFRpbWVvdXQgc2V0IGFuZCB0aGUgd29ya2Zsb3cgaGFzIG5vdCByZWNlaXZlZCBhIGhlYXJ0YmVhdCBpbiBoZWFydGJlYXRUaW1lb3V0U2Vjb25kcyxcbiAqIHRoZSB3b3JrZmxvdyB3aWxsIHRocm93IGEge0BsaW5rIEhlYXJ0YmVhdFRpbWVvdXR9IGFuZCBjYW5jZWwgdGhlIGFjdGl2aXR5LlxuICpcbiAqIEByZXR1cm5zIHtAbGluayBIZWFydGJlYXRSZXNwb25zZX0gd2hpY2ggaGFzIHJlc3BvbnNlLmNhbmNlbGxlZCBpZiB0aGUgYWN0aXZpdHkgd2FzIGNhbmNlbGxlZCBmb3IgYW55IHJlYXNvbiAoZXg6IHdvcmtmbG93IGNvbXBsZXRlZCwgZmFpbGVkLCBvciB0aGUgYWN0aXZpdHkgdGltZWQgb3V0KS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIGhlYXJ0YmVhdChcbiAgYWN0aXZpdHlUb2tlbj86IHN0cmluZ1xuKTogUHJvbWlzZTxIZWFydGJlYXRSZXNwb25zZT4ge1xuICBpZiAoaXNPcmNoZXN0cmF0b3JXb3JrZXIoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiSGVhcnRiZWF0IGlzIG5vdCBjdXJyZW50bHkgc3VwcG9ydGVkIGZyb20gd2l0aGluIGEgd29ya2Zsb3cuIFVzZSBhbiBhY3Rpdml0eSB3aXRoIGBoZWFydGJlYXQoKWAuXCJcbiAgICApO1xuICB9IGVsc2UgaWYgKGFjdGl2aXR5VG9rZW4pIHtcbiAgICByZXR1cm4gYXdhaXQgZ2V0V29ya2Zsb3dDbGllbnQoKS5oZWFydGJlYXRBY3Rpdml0eSh7XG4gICAgICBhY3Rpdml0eVRva2VuOiBhY3Rpdml0eVRva2VuLFxuICAgIH0pO1xuICB9IGVsc2UgaWYgKGlzQWN0aXZpdHlXb3JrZXIoKSkge1xuICAgIGNvbnN0IHRva2VuID0gZ2V0QWN0aXZpdHlDb250ZXh0KCkuYWN0aXZpdHlUb2tlbjtcbiAgICByZXR1cm4gYXdhaXQgZ2V0V29ya2Zsb3dDbGllbnQoKS5oZWFydGJlYXRBY3Rpdml0eSh7XG4gICAgICBhY3Rpdml0eVRva2VuOiB0b2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkFjdGl2aXR5IHRva2VuIG11c3QgYmUgcHJvdmlkZWQgd2hlbiBub3Qgd2l0aGluIGFuIEFjdGl2aXR5LlwiXG4gICAgKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBb0U7QUFFcEUsaURBQTRFO0FBRTVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxJQUFBLDZCQUFpQixHQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYTtTQUNkLENBQUMsQ0FBQztLQUNKO1NBQU0sSUFBSSxJQUFBLDJCQUFnQixHQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsSUFBQSw4QkFBa0IsR0FBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0sSUFBQSw2QkFBaUIsR0FBRSxDQUFDLGlCQUFpQixDQUFDO1lBQ2pELGFBQWEsRUFBRSxLQUFLO1NBQ3JCLENBQUMsQ0FBQztLQUNKO1NBQU07UUFDTCxNQUFNLElBQUksS0FBSyxDQUNiLDhEQUE4RCxDQUMvRCxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBckJELDhCQXFCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0V29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IEhlYXJ0YmVhdFJlc3BvbnNlIH0gZnJvbSBcIi4vcnVudGltZS9jbGllbnRzL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBjb21wbGV0ZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBoZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ== |
import { Eventual } from "./eventual.js"; | ||
export declare const ResultSymbol: unique symbol; | ||
export type Result<T = any> = Pending | Resolved<T> | Failed; | ||
export declare namespace Result { | ||
function resolved<T>(value: T): Resolved<T>; | ||
function failed(error: any): Failed; | ||
function pending<A extends Eventual>(activity: A): Pending<A>; | ||
} | ||
export declare const Result: { | ||
resolved<T>(value: T): Resolved<T>; | ||
failed(error: any): Failed; | ||
pending<A extends Eventual<any>>(activity: A): Pending<A>; | ||
}; | ||
export declare enum ResultKind { | ||
@@ -10,0 +10,0 @@ Pending = 0, |
@@ -6,5 +6,4 @@ "use strict"; | ||
exports.ResultSymbol = Symbol.for("eventual:Result"); | ||
var Result; | ||
(function (Result) { | ||
function resolved(value) { | ||
exports.Result = { | ||
resolved(value) { | ||
return { | ||
@@ -14,5 +13,4 @@ [exports.ResultSymbol]: ResultKind.Resolved, | ||
}; | ||
} | ||
Result.resolved = resolved; | ||
function failed(error) { | ||
}, | ||
failed(error) { | ||
return { | ||
@@ -22,5 +20,4 @@ [exports.ResultSymbol]: ResultKind.Failed, | ||
}; | ||
} | ||
Result.failed = failed; | ||
function pending(activity) { | ||
}, | ||
pending(activity) { | ||
return { | ||
@@ -30,5 +27,4 @@ [exports.ResultSymbol]: ResultKind.Pending, | ||
}; | ||
} | ||
Result.pending = pending; | ||
})(Result = exports.Result || (exports.Result = {})); | ||
}, | ||
}; | ||
var ResultKind; | ||
@@ -57,2 +53,2 @@ (function (ResultKind) { | ||
exports.isResolvedOrFailed = (0, util_js_1.or)(isResolved, isFailed); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Jlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSx1Q0FBK0I7QUFFbEIsUUFBQSxZQUFZLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBSTFELElBQWlCLE1BQU0sQ0FxQnRCO0FBckJELFdBQWlCLE1BQU07SUFDckIsU0FBZ0IsUUFBUSxDQUFJLEtBQVE7UUFDbEMsT0FBTztZQUNMLENBQUMsb0JBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxRQUFRO1lBQ25DLEtBQUs7U0FDTixDQUFDO0lBQ0osQ0FBQztJQUxlLGVBQVEsV0FLdkIsQ0FBQTtJQUVELFNBQWdCLE1BQU0sQ0FBQyxLQUFVO1FBQy9CLE9BQU87WUFDTCxDQUFDLG9CQUFZLENBQUMsRUFBRSxVQUFVLENBQUMsTUFBTTtZQUNqQyxLQUFLO1NBQ04sQ0FBQztJQUNKLENBQUM7SUFMZSxhQUFNLFNBS3JCLENBQUE7SUFFRCxTQUFnQixPQUFPLENBQXFCLFFBQVc7UUFDckQsT0FBTztZQUNMLENBQUMsb0JBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxPQUFPO1lBQ2xDLFFBQVE7U0FDVCxDQUFDO0lBQ0osQ0FBQztJQUxlLGNBQU8sVUFLdEIsQ0FBQTtBQUNILENBQUMsRUFyQmdCLE1BQU0sR0FBTixjQUFNLEtBQU4sY0FBTSxRQXFCdEI7QUFFRCxJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDcEIsaURBQVcsQ0FBQTtJQUNYLG1EQUFZLENBQUE7SUFDWiwrQ0FBVSxDQUFBO0FBQ1osQ0FBQyxFQUpXLFVBQVUsR0FBVixrQkFBVSxLQUFWLGtCQUFVLFFBSXJCO0FBaUJELFNBQWdCLFFBQVEsQ0FBQyxDQUFNO0lBQzdCLE9BQU8sQ0FBQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxvQkFBWSxJQUFJLENBQUMsQ0FBQztBQUN6RCxDQUFDO0FBRkQsNEJBRUM7QUFFRCxTQUFnQixTQUFTLENBQUMsTUFBMEI7SUFDbEQsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLG9CQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsT0FBTyxDQUFDO0FBQ3pFLENBQUM7QUFGRCw4QkFFQztBQUVELFNBQWdCLFVBQVUsQ0FDeEIsTUFBNkI7SUFFN0IsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLG9CQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsUUFBUSxDQUFDO0FBQzFFLENBQUM7QUFKRCxnQ0FJQztBQUVELFNBQWdCLFFBQVEsQ0FBQyxNQUEwQjtJQUNqRCxPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsb0JBQVksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxNQUFNLENBQUM7QUFDeEUsQ0FBQztBQUZELDRCQUVDO0FBRVksUUFBQSxrQkFBa0IsR0FBRyxJQUFBLFlBQUUsRUFBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudHVhbCB9IGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgeyBvciB9IGZyb20gXCIuL3V0aWwuanNcIjtcblxuZXhwb3J0IGNvbnN0IFJlc3VsdFN5bWJvbCA9IFN5bWJvbC5mb3IoXCJldmVudHVhbDpSZXN1bHRcIik7XG5cbmV4cG9ydCB0eXBlIFJlc3VsdDxUID0gYW55PiA9IFBlbmRpbmcgfCBSZXNvbHZlZDxUPiB8IEZhaWxlZDtcblxuZXhwb3J0IG5hbWVzcGFjZSBSZXN1bHQge1xuICBleHBvcnQgZnVuY3Rpb24gcmVzb2x2ZWQ8VD4odmFsdWU6IFQpOiBSZXNvbHZlZDxUPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlJlc29sdmVkLFxuICAgICAgdmFsdWUsXG4gICAgfTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmYWlsZWQoZXJyb3I6IGFueSk6IEZhaWxlZCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLkZhaWxlZCxcbiAgICAgIGVycm9yLFxuICAgIH07XG4gIH1cblxuICBleHBvcnQgZnVuY3Rpb24gcGVuZGluZzxBIGV4dGVuZHMgRXZlbnR1YWw+KGFjdGl2aXR5OiBBKTogUGVuZGluZzxBPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlBlbmRpbmcsXG4gICAgICBhY3Rpdml0eSxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBlbnVtIFJlc3VsdEtpbmQge1xuICBQZW5kaW5nID0gMCxcbiAgUmVzb2x2ZWQgPSAxLFxuICBGYWlsZWQgPSAyLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBlbmRpbmc8QSBleHRlbmRzIEV2ZW50dWFsID0gRXZlbnR1YWw+IHtcbiAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuUGVuZGluZztcbiAgYWN0aXZpdHk6IEE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWQ8VCA9IGFueT4ge1xuICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5SZXNvbHZlZDtcbiAgdmFsdWU6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkIHtcbiAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuRmFpbGVkO1xuICBlcnJvcjogYW55O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXN1bHQoYTogYW55KTogYSBpcyBSZXN1bHQge1xuICByZXR1cm4gYSAmJiB0eXBlb2YgYSA9PT0gXCJvYmplY3RcIiAmJiBSZXN1bHRTeW1ib2wgaW4gYTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUGVuZGluZyhyZXN1bHQ6IFJlc3VsdCB8IHVuZGVmaW5lZCk6IHJlc3VsdCBpcyBQZW5kaW5nIHtcbiAgcmV0dXJuIGlzUmVzdWx0KHJlc3VsdCkgJiYgcmVzdWx0W1Jlc3VsdFN5bWJvbF0gPT09IFJlc3VsdEtpbmQuUGVuZGluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVzb2x2ZWQ8VD4oXG4gIHJlc3VsdDogUmVzdWx0PFQ+IHwgdW5kZWZpbmVkXG4pOiByZXN1bHQgaXMgUmVzb2x2ZWQ8VD4ge1xuICByZXR1cm4gaXNSZXN1bHQocmVzdWx0KSAmJiByZXN1bHRbUmVzdWx0U3ltYm9sXSA9PT0gUmVzdWx0S2luZC5SZXNvbHZlZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkKHJlc3VsdDogUmVzdWx0IHwgdW5kZWZpbmVkKTogcmVzdWx0IGlzIEZhaWxlZCB7XG4gIHJldHVybiBpc1Jlc3VsdChyZXN1bHQpICYmIHJlc3VsdFtSZXN1bHRTeW1ib2xdID09PSBSZXN1bHRLaW5kLkZhaWxlZDtcbn1cblxuZXhwb3J0IGNvbnN0IGlzUmVzb2x2ZWRPckZhaWxlZCA9IG9yKGlzUmVzb2x2ZWQsIGlzRmFpbGVkKTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Jlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFDQSx1Q0FBK0I7QUFFbEIsUUFBQSxZQUFZLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBSTdDLFFBQUEsTUFBTSxHQUFHO0lBQ3BCLFFBQVEsQ0FBSSxLQUFRO1FBQ2xCLE9BQU87WUFDTCxDQUFDLG9CQUFZLENBQUMsRUFBRSxVQUFVLENBQUMsUUFBUTtZQUNuQyxLQUFLO1NBQ04sQ0FBQztJQUNKLENBQUM7SUFDRCxNQUFNLENBQUMsS0FBVTtRQUNmLE9BQU87WUFDTCxDQUFDLG9CQUFZLENBQUMsRUFBRSxVQUFVLENBQUMsTUFBTTtZQUNqQyxLQUFLO1NBQ04sQ0FBQztJQUNKLENBQUM7SUFDRCxPQUFPLENBQXFCLFFBQVc7UUFDckMsT0FBTztZQUNMLENBQUMsb0JBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxPQUFPO1lBQ2xDLFFBQVE7U0FDVCxDQUFDO0lBQ0osQ0FBQztDQUNGLENBQUM7QUFFRixJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDcEIsaURBQVcsQ0FBQTtJQUNYLG1EQUFZLENBQUE7SUFDWiwrQ0FBVSxDQUFBO0FBQ1osQ0FBQyxFQUpXLFVBQVUsR0FBVixrQkFBVSxLQUFWLGtCQUFVLFFBSXJCO0FBaUJELFNBQWdCLFFBQVEsQ0FBQyxDQUFNO0lBQzdCLE9BQU8sQ0FBQyxJQUFJLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxvQkFBWSxJQUFJLENBQUMsQ0FBQztBQUN6RCxDQUFDO0FBRkQsNEJBRUM7QUFFRCxTQUFnQixTQUFTLENBQUMsTUFBMEI7SUFDbEQsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLG9CQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsT0FBTyxDQUFDO0FBQ3pFLENBQUM7QUFGRCw4QkFFQztBQUVELFNBQWdCLFVBQVUsQ0FDeEIsTUFBNkI7SUFFN0IsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLG9CQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsUUFBUSxDQUFDO0FBQzFFLENBQUM7QUFKRCxnQ0FJQztBQUVELFNBQWdCLFFBQVEsQ0FBQyxNQUEwQjtJQUNqRCxPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsb0JBQVksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxNQUFNLENBQUM7QUFDeEUsQ0FBQztBQUZELDRCQUVDO0FBRVksUUFBQSxrQkFBa0IsR0FBRyxJQUFBLFlBQUUsRUFBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudHVhbCB9IGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgeyBvciB9IGZyb20gXCIuL3V0aWwuanNcIjtcblxuZXhwb3J0IGNvbnN0IFJlc3VsdFN5bWJvbCA9IFN5bWJvbC5mb3IoXCJldmVudHVhbDpSZXN1bHRcIik7XG5cbmV4cG9ydCB0eXBlIFJlc3VsdDxUID0gYW55PiA9IFBlbmRpbmcgfCBSZXNvbHZlZDxUPiB8IEZhaWxlZDtcblxuZXhwb3J0IGNvbnN0IFJlc3VsdCA9IHtcbiAgcmVzb2x2ZWQ8VD4odmFsdWU6IFQpOiBSZXNvbHZlZDxUPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlJlc29sdmVkLFxuICAgICAgdmFsdWUsXG4gICAgfTtcbiAgfSxcbiAgZmFpbGVkKGVycm9yOiBhbnkpOiBGYWlsZWQge1xuICAgIHJldHVybiB7XG4gICAgICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5GYWlsZWQsXG4gICAgICBlcnJvcixcbiAgICB9O1xuICB9LFxuICBwZW5kaW5nPEEgZXh0ZW5kcyBFdmVudHVhbD4oYWN0aXZpdHk6IEEpOiBQZW5kaW5nPEE+IHtcbiAgICByZXR1cm4ge1xuICAgICAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuUGVuZGluZyxcbiAgICAgIGFjdGl2aXR5LFxuICAgIH07XG4gIH0sXG59O1xuXG5leHBvcnQgZW51bSBSZXN1bHRLaW5kIHtcbiAgUGVuZGluZyA9IDAsXG4gIFJlc29sdmVkID0gMSxcbiAgRmFpbGVkID0gMixcbn1cblxuZXhwb3J0IGludGVyZmFjZSBQZW5kaW5nPEEgZXh0ZW5kcyBFdmVudHVhbCA9IEV2ZW50dWFsPiB7XG4gIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlBlbmRpbmc7XG4gIGFjdGl2aXR5OiBBO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlc29sdmVkPFQgPSBhbnk+IHtcbiAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuUmVzb2x2ZWQ7XG4gIHZhbHVlOiBUO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZhaWxlZCB7XG4gIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLkZhaWxlZDtcbiAgZXJyb3I6IGFueTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVzdWx0KGE6IGFueSk6IGEgaXMgUmVzdWx0IHtcbiAgcmV0dXJuIGEgJiYgdHlwZW9mIGEgPT09IFwib2JqZWN0XCIgJiYgUmVzdWx0U3ltYm9sIGluIGE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1BlbmRpbmcocmVzdWx0OiBSZXN1bHQgfCB1bmRlZmluZWQpOiByZXN1bHQgaXMgUGVuZGluZyB7XG4gIHJldHVybiBpc1Jlc3VsdChyZXN1bHQpICYmIHJlc3VsdFtSZXN1bHRTeW1ib2xdID09PSBSZXN1bHRLaW5kLlBlbmRpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1Jlc29sdmVkPFQ+KFxuICByZXN1bHQ6IFJlc3VsdDxUPiB8IHVuZGVmaW5lZFxuKTogcmVzdWx0IGlzIFJlc29sdmVkPFQ+IHtcbiAgcmV0dXJuIGlzUmVzdWx0KHJlc3VsdCkgJiYgcmVzdWx0W1Jlc3VsdFN5bWJvbF0gPT09IFJlc3VsdEtpbmQuUmVzb2x2ZWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZChyZXN1bHQ6IFJlc3VsdCB8IHVuZGVmaW5lZCk6IHJlc3VsdCBpcyBGYWlsZWQge1xuICByZXR1cm4gaXNSZXN1bHQocmVzdWx0KSAmJiByZXN1bHRbUmVzdWx0U3ltYm9sXSA9PT0gUmVzdWx0S2luZC5GYWlsZWQ7XG59XG5cbmV4cG9ydCBjb25zdCBpc1Jlc29sdmVkT3JGYWlsZWQgPSBvcihpc1Jlc29sdmVkLCBpc0ZhaWxlZCk7XG4iXX0= |
@@ -60,6 +60,6 @@ import { HistoryStateEvent } from "../../workflow-events.js"; | ||
export type Schedule = RelativeSchedule | AbsoluteSchedule; | ||
export declare namespace Schedule { | ||
function relative(timerSeconds: number, baseTime?: Date): RelativeSchedule; | ||
function absolute(untilTime: string): AbsoluteSchedule; | ||
} | ||
export declare const Schedule: { | ||
relative(timerSeconds: number, baseTime?: Date): RelativeSchedule; | ||
absolute(untilTime: string): AbsoluteSchedule; | ||
}; | ||
export type TimerRequestBase<T extends TimerRequestType> = { | ||
@@ -66,0 +66,0 @@ type: T; |
@@ -9,5 +9,4 @@ "use strict"; | ||
})(TimerRequestType = exports.TimerRequestType || (exports.TimerRequestType = {})); | ||
var Schedule; | ||
(function (Schedule) { | ||
function relative(timerSeconds, baseTime = new Date()) { | ||
exports.Schedule = { | ||
relative(timerSeconds, baseTime = new Date()) { | ||
return { | ||
@@ -18,5 +17,4 @@ type: "Relative", | ||
}; | ||
} | ||
Schedule.relative = relative; | ||
function absolute(untilTime) { | ||
}, | ||
absolute(untilTime) { | ||
return { | ||
@@ -26,5 +24,4 @@ type: "Absolute", | ||
}; | ||
} | ||
Schedule.absolute = absolute; | ||
})(Schedule = exports.Schedule || (exports.Schedule = {})); | ||
}, | ||
}; | ||
function isTimerScheduleEventRequest(timerRequest) { | ||
@@ -39,2 +36,2 @@ return timerRequest && timerRequest.type === TimerRequestType.ScheduleEvent; | ||
exports.isActivityHeartbeatMonitorRequest = isActivityHeartbeatMonitorRequest; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXItY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy90aW1lci1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBdURBLElBQVksZ0JBR1g7QUFIRCxXQUFZLGdCQUFnQjtJQUMxQixtREFBK0IsQ0FBQTtJQUMvQiwrREFBMkMsQ0FBQTtBQUM3QyxDQUFDLEVBSFcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFHM0I7QUFlRCxJQUFpQixRQUFRLENBa0J4QjtBQWxCRCxXQUFpQixRQUFRO0lBQ3ZCLFNBQWdCLFFBQVEsQ0FDdEIsWUFBb0IsRUFDcEIsV0FBaUIsSUFBSSxJQUFJLEVBQUU7UUFFM0IsT0FBTztZQUNMLElBQUksRUFBRSxVQUFVO1lBQ2hCLFlBQVk7WUFDWixRQUFRO1NBQ1QsQ0FBQztJQUNKLENBQUM7SUFUZSxpQkFBUSxXQVN2QixDQUFBO0lBRUQsU0FBZ0IsUUFBUSxDQUFDLFNBQWlCO1FBQ3hDLE9BQU87WUFDTCxJQUFJLEVBQUUsVUFBVTtZQUNoQixTQUFTO1NBQ1YsQ0FBQztJQUNKLENBQUM7SUFMZSxpQkFBUSxXQUt2QixDQUFBO0FBQ0gsQ0FBQyxFQWxCZ0IsUUFBUSxHQUFSLGdCQUFRLEtBQVIsZ0JBQVEsUUFrQnhCO0FBZ0JELFNBQWdCLDJCQUEyQixDQUN6QyxZQUEwQjtJQUUxQixPQUFPLFlBQVksSUFBSSxZQUFZLENBQUMsSUFBSSxLQUFLLGdCQUFnQixDQUFDLGFBQWEsQ0FBQztBQUM5RSxDQUFDO0FBSkQsa0VBSUM7QUFTRCxTQUFnQixpQ0FBaUMsQ0FDL0MsWUFBMEI7SUFFMUIsT0FBTyxDQUNMLFlBQVk7UUFDWixZQUFZLENBQUMsSUFBSSxLQUFLLGdCQUFnQixDQUFDLHdCQUF3QixDQUNoRSxDQUFDO0FBQ0osQ0FBQztBQVBELDhFQU9DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSGlzdG9yeVN0YXRlRXZlbnQgfSBmcm9tIFwiLi4vLi4vd29ya2Zsb3ctZXZlbnRzLmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgVGltZXJDbGllbnQge1xuICAvKipcbiAgICogU3RhcnRzIGEgdGltZXIgdXNpbmcgU1FTJ3MgbWVzc2FnZSBkZWxheS5cbiAgICpcbiAgICogVGhlIHRpbWVyUmVxdWVzdC51bnRpbFRpbWUgbWF5IG9ubHkgYmUgMTUgbWludXRlcyBvciBmZXdlciBpbiB0aGUgZnV0dXJlLlxuICAgKlxuICAgKiBGb3IgbG9uZ2VyIHVzZSB7QGxpbmsgVGltZXJDbGllbnQuc3RhcnRUaW1lcn0uXG4gICAqXG4gICAqIFRoZSBTUVMgUXVldWUgd2lsbCBkZWxheSBmb3IgZmxvb3IodW50aWxUaW1lIC0gY3VycmVudFRpbWUpIHNlY29uZHMgdW50aWwgdGhlIHRpbWVyIGhhbmRsZXIgY2FuIHBpY2sgdXAgdGhlIG1lc3NhZ2UuXG4gICAqXG4gICAqIEZpbmFsbHkgdGhlIHRpbWVyIGhhbmRsZXIgd2FpdHMgdGhlIHJlbWFpbmluZyAodW50aWxUaW1lIC0gY3VycmVudFRpbWUpIG1pbGxpc2Vjb25kcyBpZiBuZWNlc3NhcnkgYW5kIHRoZW4gc2VuZHNcbiAgICogdGhlIHtAbGluayBUaW1lclJlcXVlc3R9IHByb3ZpZGVkLlxuICAgKi9cbiAgc3RhcnRTaG9ydFRpbWVyKHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0KTogUHJvbWlzZTxudW1iZXI+O1xuXG4gIC8qKlxuICAgKiBTdGFydHMgYSB0aW1lciBvZiBhbnkgKHBvc2l0aXZlKSBsZW5ndGguXG4gICAqXG4gICAqIElmIHRoZSB0aW1lciBpcyBsb25nZXIgdGhhbiAxNSBtaW51dGVzIChjb25maWd1cmFibGUgdmlhIGBwcm9wcy5zbGVlcFF1ZXVlVGhyZXNob2xkTWlsbGlzYCksXG4gICAqIHRoZSB0aW1lciB3aWxsIGNyZWF0ZSBhICBFdmVudEJyaWRnZSBzY2hlZHVsZSB1bnRpbCB0aGUgdW50aWxUaW1lIC0gcHJvcHMuc2xlZXBRdWV1ZVRocmVzaG9sZE1pbGxpc1xuICAgKiB3aGVuIHRoZSB0aW1lciB3aWxsIGJlIG1vdmVkIHRvIHRoZSBTUVMgcXVldWUuXG4gICAqXG4gICAqIFRoZSBTUVMgUXVldWUgd2lsbCBkZWxheSBmb3IgZmxvb3IodW50aWxUaW1lIC0gY3VycmVudFRpbWUpIHNlY29uZHMgdW50aWwgdGhlIHRpbWVyIGhhbmRsZXIgY2FuIHBpY2sgdXAgdGhlIG1lc3NhZ2UuXG4gICAqXG4gICAqIEZpbmFsbHkgdGhlIHRpbWVyIGhhbmRsZXIgd2FpdHMgdGhlIHJlbWFpbmluZyAodW50aWxUaW1lIC0gY3VycmVudFRpbWUpIG1pbGxpc2Vjb25kcyBpZiBuZWNlc3NhcnkgYW5kIHRoZW4gc2VuZHNcbiAgICogdGhlIHtAbGluayBUaW1lclJlcXVlc3R9IHByb3ZpZGVkLlxuICAgKi9cbiAgc3RhcnRUaW1lcih0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdCk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFdoZW4gc3RhcnRUaW1lciBpcyB1c2VkLCB0aGUgRXZlbnRCcmlkZ2Ugc2NoZWR1bGUgd2lsbCBub3Qgc2VsZiBkZWxldGUuXG4gICAqXG4gICAqIFVzZSB0aGlzIG1ldGhvZCB0byBjbGVhbiB0aGUgc2NoZWR1bGUuXG4gICAqXG4gICAqIFRoZSBwcm92aWRlZCBzY2hlZHVsZS1mb3J3YXJkZXIgZnVuY3Rpb24gd2lsbCBjYWxsIHRoaXMgbWV0aG9kIGluIEV2ZW50dWFsIHdoZW5cbiAgICogdGhlIHRpbWVyIGlzIHRyYW5zZmVycmVkIGZyb20gRXZlbnRCcmlkZ2UgdG8gU1FTIGF0IGBwcm9wcy5zbGVlcFF1ZXVlVGhyZXNob2xkTWlsbGlzYC5cbiAgICovXG4gIGNsZWFyU2NoZWR1bGUoc2NoZWR1bGVOYW1lOiBzdHJpbmcpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBTY2hlZHVsZXMgYW55IGV2ZW50IGZvciBhIHdvcmtmbG93IGF0IGEgZnV0dXJlIHRpbWUuXG4gICAqXG4gICAqIEhlbHBlciBmb3IgdXNpbmcge0BsaW5rIFRpbWVyQ2xpZW50LnN0YXJ0VGltZXJ9IHdpdGggYSB7QGxpbmsgVGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdH0uXG4gICAqL1xuICBzY2hlZHVsZUV2ZW50PEUgZXh0ZW5kcyBIaXN0b3J5U3RhdGVFdmVudD4oXG4gICAgcmVxdWVzdDogU2NoZWR1bGVFdmVudFJlcXVlc3Q8RT5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cblxuZXhwb3J0IHR5cGUgVGltZXJSZXF1ZXN0ID1cbiAgfCBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0XG4gIHwgQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yUmVxdWVzdDtcblxuZXhwb3J0IGVudW0gVGltZXJSZXF1ZXN0VHlwZSB7XG4gIFNjaGVkdWxlRXZlbnQgPSBcIlNjaGVkdWxlRXZlbnRcIixcbiAgQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yID0gXCJDaGVja0hlYXJ0YmVhdFwiLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlbGF0aXZlU2NoZWR1bGUge1xuICB0eXBlOiBcIlJlbGF0aXZlXCI7XG4gIHRpbWVyU2Vjb25kczogbnVtYmVyO1xuICBiYXNlVGltZTogRGF0ZTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBBYnNvbHV0ZVNjaGVkdWxlIHtcbiAgdHlwZTogXCJBYnNvbHV0ZVwiO1xuICB1bnRpbFRpbWU6IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgU2NoZWR1bGUgPSBSZWxhdGl2ZVNjaGVkdWxlIHwgQWJzb2x1dGVTY2hlZHVsZTtcblxuZXhwb3J0IG5hbWVzcGFjZSBTY2hlZHVsZSB7XG4gIGV4cG9ydCBmdW5jdGlvbiByZWxhdGl2ZShcbiAgICB0aW1lclNlY29uZHM6IG51bWJlcixcbiAgICBiYXNlVGltZTogRGF0ZSA9IG5ldyBEYXRlKClcbiAgKTogUmVsYXRpdmVTY2hlZHVsZSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHR5cGU6IFwiUmVsYXRpdmVcIixcbiAgICAgIHRpbWVyU2Vjb25kcyxcbiAgICAgIGJhc2VUaW1lLFxuICAgIH07XG4gIH1cblxuICBleHBvcnQgZnVuY3Rpb24gYWJzb2x1dGUodW50aWxUaW1lOiBzdHJpbmcpOiBBYnNvbHV0ZVNjaGVkdWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogXCJBYnNvbHV0ZVwiLFxuICAgICAgdW50aWxUaW1lLFxuICAgIH07XG4gIH1cbn1cblxuZXhwb3J0IHR5cGUgVGltZXJSZXF1ZXN0QmFzZTxUIGV4dGVuZHMgVGltZXJSZXF1ZXN0VHlwZT4gPSB7XG4gIHR5cGU6IFQ7XG4gIHNjaGVkdWxlOiBTY2hlZHVsZTtcbn07XG5cbi8qKlxuICogRm9yd2FyZCBhbiBldmVudCB0byB0aGUgV29ya2Zsb3cgUXVldWUuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgVGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdFxuICBleHRlbmRzIFRpbWVyUmVxdWVzdEJhc2U8VGltZXJSZXF1ZXN0VHlwZS5TY2hlZHVsZUV2ZW50PiB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGV2ZW50OiBIaXN0b3J5U3RhdGVFdmVudDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzVGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdChcbiAgdGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3Rcbik6IHRpbWVyUmVxdWVzdCBpcyBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0IHtcbiAgcmV0dXJuIHRpbWVyUmVxdWVzdCAmJiB0aW1lclJlcXVlc3QudHlwZSA9PT0gVGltZXJSZXF1ZXN0VHlwZS5TY2hlZHVsZUV2ZW50O1xufVxuXG5leHBvcnQgdHlwZSBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0ID1cbiAgVGltZXJSZXF1ZXN0QmFzZTxUaW1lclJlcXVlc3RUeXBlLkFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvcj4gJiB7XG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgICBhY3Rpdml0eVNlcTogbnVtYmVyO1xuICAgIGhlYXJ0YmVhdFNlY29uZHM6IG51bWJlcjtcbiAgfTtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yUmVxdWVzdChcbiAgdGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3Rcbik6IHRpbWVyUmVxdWVzdCBpcyBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0IHtcbiAgcmV0dXJuIChcbiAgICB0aW1lclJlcXVlc3QgJiZcbiAgICB0aW1lclJlcXVlc3QudHlwZSA9PT0gVGltZXJSZXF1ZXN0VHlwZS5BY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JcbiAgKTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2hlZHVsZUZvcndhcmRlclJlcXVlc3Qge1xuICBzY2hlZHVsZU5hbWU6IHN0cmluZztcbiAgY2xlYXJTY2hlZHVsZTogYm9vbGVhbjtcbiAgdGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3Q7XG4gIGZvcndhcmRUaW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBJU08gODYwMSBUaW1lc3RhbXAgZGV0ZXJtaW5pbmcgd2hlbiB0aGUgbWVzc2FnZSBzaG91bGQgYmUgdmlzaWJsZSB0byB0aGUgdGltZXIgcXVldWUuXG4gICAqL1xuICB1bnRpbFRpbWU6IHN0cmluZztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTY2hlZHVsZUV2ZW50UmVxdWVzdDxFIGV4dGVuZHMgSGlzdG9yeVN0YXRlRXZlbnQ+XG4gIGV4dGVuZHMgT21pdDxUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0LCBcImV2ZW50XCIgfCBcInR5cGVcIj4ge1xuICBldmVudDogT21pdDxFLCBcInRpbWVzdGFtcFwiPjtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXItY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy90aW1lci1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBdURBLElBQVksZ0JBR1g7QUFIRCxXQUFZLGdCQUFnQjtJQUMxQixtREFBK0IsQ0FBQTtJQUMvQiwrREFBMkMsQ0FBQTtBQUM3QyxDQUFDLEVBSFcsZ0JBQWdCLEdBQWhCLHdCQUFnQixLQUFoQix3QkFBZ0IsUUFHM0I7QUFlWSxRQUFBLFFBQVEsR0FBRztJQUN0QixRQUFRLENBQ04sWUFBb0IsRUFDcEIsV0FBaUIsSUFBSSxJQUFJLEVBQUU7UUFFM0IsT0FBTztZQUNMLElBQUksRUFBRSxVQUFVO1lBQ2hCLFlBQVk7WUFDWixRQUFRO1NBQ1QsQ0FBQztJQUNKLENBQUM7SUFDRCxRQUFRLENBQUMsU0FBaUI7UUFDeEIsT0FBTztZQUNMLElBQUksRUFBRSxVQUFVO1lBQ2hCLFNBQVM7U0FDVixDQUFDO0lBQ0osQ0FBQztDQUNGLENBQUM7QUFnQkYsU0FBZ0IsMkJBQTJCLENBQ3pDLFlBQTBCO0lBRTFCLE9BQU8sWUFBWSxJQUFJLFlBQVksQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsYUFBYSxDQUFDO0FBQzlFLENBQUM7QUFKRCxrRUFJQztBQVNELFNBQWdCLGlDQUFpQyxDQUMvQyxZQUEwQjtJQUUxQixPQUFPLENBQ0wsWUFBWTtRQUNaLFlBQVksQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsd0JBQXdCLENBQ2hFLENBQUM7QUFDSixDQUFDO0FBUEQsOEVBT0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIaXN0b3J5U3RhdGVFdmVudCB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUaW1lckNsaWVudCB7XG4gIC8qKlxuICAgKiBTdGFydHMgYSB0aW1lciB1c2luZyBTUVMncyBtZXNzYWdlIGRlbGF5LlxuICAgKlxuICAgKiBUaGUgdGltZXJSZXF1ZXN0LnVudGlsVGltZSBtYXkgb25seSBiZSAxNSBtaW51dGVzIG9yIGZld2VyIGluIHRoZSBmdXR1cmUuXG4gICAqXG4gICAqIEZvciBsb25nZXIgdXNlIHtAbGluayBUaW1lckNsaWVudC5zdGFydFRpbWVyfS5cbiAgICpcbiAgICogVGhlIFNRUyBRdWV1ZSB3aWxsIGRlbGF5IGZvciBmbG9vcih1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgc2Vjb25kcyB1bnRpbCB0aGUgdGltZXIgaGFuZGxlciBjYW4gcGljayB1cCB0aGUgbWVzc2FnZS5cbiAgICpcbiAgICogRmluYWxseSB0aGUgdGltZXIgaGFuZGxlciB3YWl0cyB0aGUgcmVtYWluaW5nICh1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgbWlsbGlzZWNvbmRzIGlmIG5lY2Vzc2FyeSBhbmQgdGhlbiBzZW5kc1xuICAgKiB0aGUge0BsaW5rIFRpbWVyUmVxdWVzdH0gcHJvdmlkZWQuXG4gICAqL1xuICBzdGFydFNob3J0VGltZXIodGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3QpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgLyoqXG4gICAqIFN0YXJ0cyBhIHRpbWVyIG9mIGFueSAocG9zaXRpdmUpIGxlbmd0aC5cbiAgICpcbiAgICogSWYgdGhlIHRpbWVyIGlzIGxvbmdlciB0aGFuIDE1IG1pbnV0ZXMgKGNvbmZpZ3VyYWJsZSB2aWEgYHByb3BzLnNsZWVwUXVldWVUaHJlc2hvbGRNaWxsaXNgKSxcbiAgICogdGhlIHRpbWVyIHdpbGwgY3JlYXRlIGEgIEV2ZW50QnJpZGdlIHNjaGVkdWxlIHVudGlsIHRoZSB1bnRpbFRpbWUgLSBwcm9wcy5zbGVlcFF1ZXVlVGhyZXNob2xkTWlsbGlzXG4gICAqIHdoZW4gdGhlIHRpbWVyIHdpbGwgYmUgbW92ZWQgdG8gdGhlIFNRUyBxdWV1ZS5cbiAgICpcbiAgICogVGhlIFNRUyBRdWV1ZSB3aWxsIGRlbGF5IGZvciBmbG9vcih1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgc2Vjb25kcyB1bnRpbCB0aGUgdGltZXIgaGFuZGxlciBjYW4gcGljayB1cCB0aGUgbWVzc2FnZS5cbiAgICpcbiAgICogRmluYWxseSB0aGUgdGltZXIgaGFuZGxlciB3YWl0cyB0aGUgcmVtYWluaW5nICh1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgbWlsbGlzZWNvbmRzIGlmIG5lY2Vzc2FyeSBhbmQgdGhlbiBzZW5kc1xuICAgKiB0aGUge0BsaW5rIFRpbWVyUmVxdWVzdH0gcHJvdmlkZWQuXG4gICAqL1xuICBzdGFydFRpbWVyKHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0KTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogV2hlbiBzdGFydFRpbWVyIGlzIHVzZWQsIHRoZSBFdmVudEJyaWRnZSBzY2hlZHVsZSB3aWxsIG5vdCBzZWxmIGRlbGV0ZS5cbiAgICpcbiAgICogVXNlIHRoaXMgbWV0aG9kIHRvIGNsZWFuIHRoZSBzY2hlZHVsZS5cbiAgICpcbiAgICogVGhlIHByb3ZpZGVkIHNjaGVkdWxlLWZvcndhcmRlciBmdW5jdGlvbiB3aWxsIGNhbGwgdGhpcyBtZXRob2QgaW4gRXZlbnR1YWwgd2hlblxuICAgKiB0aGUgdGltZXIgaXMgdHJhbnNmZXJyZWQgZnJvbSBFdmVudEJyaWRnZSB0byBTUVMgYXQgYHByb3BzLnNsZWVwUXVldWVUaHJlc2hvbGRNaWxsaXNgLlxuICAgKi9cbiAgY2xlYXJTY2hlZHVsZShzY2hlZHVsZU5hbWU6IHN0cmluZyk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFNjaGVkdWxlcyBhbnkgZXZlbnQgZm9yIGEgd29ya2Zsb3cgYXQgYSBmdXR1cmUgdGltZS5cbiAgICpcbiAgICogSGVscGVyIGZvciB1c2luZyB7QGxpbmsgVGltZXJDbGllbnQuc3RhcnRUaW1lcn0gd2l0aCBhIHtAbGluayBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0fS5cbiAgICovXG4gIHNjaGVkdWxlRXZlbnQ8RSBleHRlbmRzIEhpc3RvcnlTdGF0ZUV2ZW50PihcbiAgICByZXF1ZXN0OiBTY2hlZHVsZUV2ZW50UmVxdWVzdDxFPlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuXG5leHBvcnQgdHlwZSBUaW1lclJlcXVlc3QgPVxuICB8IFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3RcbiAgfCBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0O1xuXG5leHBvcnQgZW51bSBUaW1lclJlcXVlc3RUeXBlIHtcbiAgU2NoZWR1bGVFdmVudCA9IFwiU2NoZWR1bGVFdmVudFwiLFxuICBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3IgPSBcIkNoZWNrSGVhcnRiZWF0XCIsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVsYXRpdmVTY2hlZHVsZSB7XG4gIHR5cGU6IFwiUmVsYXRpdmVcIjtcbiAgdGltZXJTZWNvbmRzOiBudW1iZXI7XG4gIGJhc2VUaW1lOiBEYXRlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFic29sdXRlU2NoZWR1bGUge1xuICB0eXBlOiBcIkFic29sdXRlXCI7XG4gIHVudGlsVGltZTogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBTY2hlZHVsZSA9IFJlbGF0aXZlU2NoZWR1bGUgfCBBYnNvbHV0ZVNjaGVkdWxlO1xuXG5leHBvcnQgY29uc3QgU2NoZWR1bGUgPSB7XG4gIHJlbGF0aXZlKFxuICAgIHRpbWVyU2Vjb25kczogbnVtYmVyLFxuICAgIGJhc2VUaW1lOiBEYXRlID0gbmV3IERhdGUoKVxuICApOiBSZWxhdGl2ZVNjaGVkdWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogXCJSZWxhdGl2ZVwiLFxuICAgICAgdGltZXJTZWNvbmRzLFxuICAgICAgYmFzZVRpbWUsXG4gICAgfTtcbiAgfSxcbiAgYWJzb2x1dGUodW50aWxUaW1lOiBzdHJpbmcpOiBBYnNvbHV0ZVNjaGVkdWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogXCJBYnNvbHV0ZVwiLFxuICAgICAgdW50aWxUaW1lLFxuICAgIH07XG4gIH0sXG59O1xuXG5leHBvcnQgdHlwZSBUaW1lclJlcXVlc3RCYXNlPFQgZXh0ZW5kcyBUaW1lclJlcXVlc3RUeXBlPiA9IHtcbiAgdHlwZTogVDtcbiAgc2NoZWR1bGU6IFNjaGVkdWxlO1xufTtcblxuLyoqXG4gKiBGb3J3YXJkIGFuIGV2ZW50IHRvIHRoZSBXb3JrZmxvdyBRdWV1ZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0XG4gIGV4dGVuZHMgVGltZXJSZXF1ZXN0QmFzZTxUaW1lclJlcXVlc3RUeXBlLlNjaGVkdWxlRXZlbnQ+IHtcbiAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgZXZlbnQ6IEhpc3RvcnlTdGF0ZUV2ZW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0KFxuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdFxuKTogdGltZXJSZXF1ZXN0IGlzIFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3Qge1xuICByZXR1cm4gdGltZXJSZXF1ZXN0ICYmIHRpbWVyUmVxdWVzdC50eXBlID09PSBUaW1lclJlcXVlc3RUeXBlLlNjaGVkdWxlRXZlbnQ7XG59XG5cbmV4cG9ydCB0eXBlIEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3QgPVxuICBUaW1lclJlcXVlc3RCYXNlPFRpbWVyUmVxdWVzdFR5cGUuQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yPiAmIHtcbiAgICBleGVjdXRpb25JZDogc3RyaW5nO1xuICAgIGFjdGl2aXR5U2VxOiBudW1iZXI7XG4gICAgaGVhcnRiZWF0U2Vjb25kczogbnVtYmVyO1xuICB9O1xuXG5leHBvcnQgZnVuY3Rpb24gaXNBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0KFxuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdFxuKTogdGltZXJSZXF1ZXN0IGlzIEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3Qge1xuICByZXR1cm4gKFxuICAgIHRpbWVyUmVxdWVzdCAmJlxuICAgIHRpbWVyUmVxdWVzdC50eXBlID09PSBUaW1lclJlcXVlc3RUeXBlLkFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclxuICApO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVkdWxlRm9yd2FyZGVyUmVxdWVzdCB7XG4gIHNjaGVkdWxlTmFtZTogc3RyaW5nO1xuICBjbGVhclNjaGVkdWxlOiBib29sZWFuO1xuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdDtcbiAgZm9yd2FyZFRpbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIElTTyA4NjAxIFRpbWVzdGFtcCBkZXRlcm1pbmluZyB3aGVuIHRoZSBtZXNzYWdlIHNob3VsZCBiZSB2aXNpYmxlIHRvIHRoZSB0aW1lciBxdWV1ZS5cbiAgICovXG4gIHVudGlsVGltZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVkdWxlRXZlbnRSZXF1ZXN0PEUgZXh0ZW5kcyBIaXN0b3J5U3RhdGVFdmVudD5cbiAgZXh0ZW5kcyBPbWl0PFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3QsIFwiZXZlbnRcIiB8IFwidHlwZVwiPiB7XG4gIGV2ZW50OiBPbWl0PEUsIFwidGltZXN0YW1wXCI+O1xufVxuIl19 |
@@ -38,7 +38,7 @@ import { HistoryStateEvent } from "../../workflow-events.js"; | ||
*/ | ||
completeActivity({ activityToken: activityToken, result, }: CompleteActivityRequest): Promise<void>; | ||
completeActivity({ activityToken, result, }: CompleteActivityRequest): Promise<void>; | ||
/** | ||
* Fails an async activity causing it to throw the given error. | ||
*/ | ||
failActivity({ activityToken: activityToken, error, message, }: FailActivityRequest): Promise<void>; | ||
failActivity({ activityToken, error, message, }: FailActivityRequest): Promise<void>; | ||
/** | ||
@@ -45,0 +45,0 @@ * Submits a "heartbeat" for the given activityToken. |
@@ -29,3 +29,3 @@ "use strict"; | ||
*/ | ||
async completeActivity({ activityToken: activityToken, result, }) { | ||
async completeActivity({ activityToken, result, }) { | ||
await this.sendActivityResult(activityToken, { | ||
@@ -39,3 +39,3 @@ type: workflow_events_js_1.WorkflowEventType.ActivityCompleted, | ||
*/ | ||
async failActivity({ activityToken: activityToken, error, message, }) { | ||
async failActivity({ activityToken, error, message, }) { | ||
await this.sendActivityResult(activityToken, { | ||
@@ -69,2 +69,2 @@ type: workflow_events_js_1.WorkflowEventType.ActivityFailed, | ||
exports.WorkflowClient = WorkflowClient; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":";;;AAAA,iEAOkC;AAClC,qDAAgE;AAGhE,4DAA2D;AAG3D,MAAsB,cAAc;IAClC,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IA8BpE;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,IAAA,gCAAW,EACT;YACE,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,SAAS,EACT,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EAAE,aAAa,EAC5B,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EAAE,aAAa,EAC5B,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IACD;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,IAAA,uCAAmB,EAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,8BAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CACzB,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAE9B,aAAqB,EAAE,KAAgD;QACvE,MAAM,IAAI,GAAG,IAAA,uCAAmB,EAAC,aAAa,CAAC,CAAC;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAA,gCAAW,EAAqC;YAC9C,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;CACF;AArHD,wCAqHC","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(private activityRuntimeClient: ActivityRuntimeClient) {}\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startWorkflow<W extends Workflow = Workflow>(\n    request: StartWorkflowRequest<W>\n  ): Promise<string>;\n  /**\n   * Submit events to be processed by a workflow's orchestrator.\n   *\n   * @param executionId ID of the workflow execution\n   * @param events events to submit for processing\n   */\n  public abstract submitWorkflowTask(\n    executionId: string,\n    ...events: HistoryStateEvent[]\n  ): Promise<void>;\n\n  public abstract getExecutions(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        undefined,\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Completes an async activity causing it to return the given value.\n   */\n  public async completeActivity({\n    activityToken: activityToken,\n    result,\n  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken: activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      new Date().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivityCompleted | ActivityFailed\n  >(activityToken: string, event: Omit<E, \"seq\" | \"duration\" | \"timestamp\">) {\n    const data = decodeActivityToken(activityToken);\n    await this.submitWorkflowTask(\n      data.payload.executionId,\n      createEvent<ActivityCompleted | ActivityFailed>({\n        ...event,\n        seq: data.payload.seq,\n      })\n    );\n  }\n}\n\nexport interface SendSignalRequest {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":";;;AAAA,iEAOkC;AAClC,qDAAgE;AAGhE,4DAA2D;AAG3D,MAAsB,cAAc;IAClC,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IA+BpE;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,IAAA,gCAAW,EACT;YACE,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,SAAS,EACT,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EACb,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,IAAA,uCAAmB,EAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,8BAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CACzB,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAE9B,aAAqB,EAAE,KAAgD;QACvE,MAAM,IAAI,GAAG,IAAA,uCAAmB,EAAC,aAAa,CAAC,CAAC;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAA,gCAAW,EAAqC;YAC9C,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;CACF;AAvHD,wCAuHC","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(private activityRuntimeClient: ActivityRuntimeClient) {}\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startWorkflow<W extends Workflow = Workflow>(\n    request: StartWorkflowRequest<W>\n  ): Promise<string>;\n\n  /**\n   * Submit events to be processed by a workflow's orchestrator.\n   *\n   * @param executionId ID of the workflow execution\n   * @param events events to submit for processing\n   */\n  public abstract submitWorkflowTask(\n    executionId: string,\n    ...events: HistoryStateEvent[]\n  ): Promise<void>;\n\n  public abstract getExecutions(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        undefined,\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Completes an async activity causing it to return the given value.\n   */\n  public async completeActivity({\n    activityToken,\n    result,\n  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      new Date().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivityCompleted | ActivityFailed\n  >(activityToken: string, event: Omit<E, \"seq\" | \"duration\" | \"timestamp\">) {\n    const data = decodeActivityToken(activityToken);\n    await this.submitWorkflowTask(\n      data.payload.executionId,\n      createEvent<ActivityCompleted | ActivityFailed>({\n        ...event,\n        seq: data.payload.seq,\n      })\n    );\n  }\n}\n\nexport interface SendSignalRequest {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]} |
@@ -18,4 +18,11 @@ import { Command } from "../command.js"; | ||
executeCommand(workflow: Workflow, executionId: string, command: Command, baseTime: Date): Promise<HistoryStateEvent>; | ||
private scheduleActivity; | ||
private scheduleChildWorkflow; | ||
private scheduleSleep; | ||
private executeExpectSignal; | ||
private sendSignal; | ||
private startCondition; | ||
private publishEvents; | ||
} | ||
export {}; | ||
//# sourceMappingURL=command-executor.d.ts.map |
@@ -18,25 +18,24 @@ "use strict"; | ||
async executeCommand(workflow, executionId, command, baseTime) { | ||
const self = this; | ||
if ((0, command_js_1.isScheduleActivityCommand)(command)) { | ||
return await scheduleActivity(command); | ||
return await this.scheduleActivity(workflow, executionId, command, baseTime); | ||
} | ||
else if ((0, command_js_1.isScheduleWorkflowCommand)(command)) { | ||
return scheduleChildWorkflow(command); | ||
return this.scheduleChildWorkflow(executionId, command); | ||
} | ||
else if ((0, command_js_1.isSleepForCommand)(command) || (0, command_js_1.isSleepUntilCommand)(command)) { | ||
// all sleep times are computed using the start time of the WorkflowTaskStarted | ||
return scheduleSleep(command); | ||
return this.scheduleSleep(executionId, command, baseTime); | ||
} | ||
else if ((0, command_js_1.isExpectSignalCommand)(command)) { | ||
// should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)? | ||
return executeExpectSignal(command); | ||
return this.executeExpectSignal(executionId, command, baseTime); | ||
} | ||
else if ((0, command_js_1.isSendSignalCommand)(command)) { | ||
return sendSignal(command); | ||
return this.sendSignal(executionId, command); | ||
} | ||
else if ((0, command_js_1.isStartConditionCommand)(command)) { | ||
return startCondition(command); | ||
return this.startCondition(executionId, command, baseTime); | ||
} | ||
else if ((0, command_js_1.isPublishEventsCommand)(command)) { | ||
return publishEvents(command); | ||
return this.publishEvents(command); | ||
} | ||
@@ -46,128 +45,128 @@ else { | ||
} | ||
async function scheduleActivity(command) { | ||
const request = { | ||
scheduledTime: new Date().toISOString(), | ||
workflowName: workflow.workflowName, | ||
} | ||
async scheduleActivity(workflow, executionId, command, baseTime) { | ||
const request = { | ||
scheduledTime: new Date().toISOString(), | ||
workflowName: workflow.workflowName, | ||
executionId, | ||
command, | ||
retry: 0, | ||
}; | ||
const timeoutStarter = command.timeoutSeconds | ||
? await this.props.timerClient.scheduleEvent({ | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
event: { | ||
type: workflow_events_js_1.WorkflowEventType.ActivityTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
command, | ||
retry: 0, | ||
}; | ||
const timeoutStarter = command.timeoutSeconds | ||
? await self.props.timerClient.scheduleEvent({ | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
event: { | ||
type: workflow_events_js_1.WorkflowEventType.ActivityTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
}) | ||
: undefined; | ||
const activityStarter = self.props.workflowRuntimeClient.startActivity(request); | ||
await Promise.all([activityStarter, timeoutStarter]); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ActivityScheduled, | ||
}) | ||
: undefined; | ||
const activityStarter = this.props.workflowRuntimeClient.startActivity(request); | ||
await Promise.all([activityStarter, timeoutStarter]); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ActivityScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
}); | ||
} | ||
async scheduleChildWorkflow(executionId, command) { | ||
await this.props.workflowClient.startWorkflow({ | ||
workflowName: command.name, | ||
input: command.input, | ||
parentExecutionId: executionId, | ||
executionName: (0, execution_id_js_1.formatChildExecutionName)(executionId, command.seq), | ||
seq: command.seq, | ||
...command.opts, | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ChildWorkflowScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
input: command.input, | ||
}); | ||
} | ||
async scheduleSleep(executionId, command, baseTime) { | ||
// TODO validate | ||
const untilTime = (0, command_js_1.isSleepUntilCommand)(command) | ||
? new Date(command.untilTime) | ||
: new Date(baseTime.getTime() + command.durationSeconds * 1000); | ||
const untilTimeIso = untilTime.toISOString(); | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: workflow_events_js_1.WorkflowEventType.SleepCompleted, | ||
seq: command.seq, | ||
name: command.name, | ||
}, | ||
schedule: index_js_2.Schedule.absolute(untilTimeIso), | ||
executionId, | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.SleepScheduled, | ||
seq: command.seq, | ||
untilTime: untilTime.toISOString(), | ||
}); | ||
} | ||
async executeExpectSignal(executionId, command, baseTime) { | ||
if (command.timeoutSeconds) { | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: workflow_events_js_1.WorkflowEventType.ExpectSignalTimedOut, | ||
}, | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
executionId, | ||
}); | ||
} | ||
async function scheduleChildWorkflow(command) { | ||
await self.props.workflowClient.startWorkflow({ | ||
workflowName: command.name, | ||
input: command.input, | ||
parentExecutionId: executionId, | ||
executionName: (0, execution_id_js_1.formatChildExecutionName)(executionId, command.seq), | ||
seq: command.seq, | ||
...command.opts, | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ChildWorkflowScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
input: command.input, | ||
}); | ||
} | ||
async function scheduleSleep(command) { | ||
// TODO validate | ||
const untilTime = (0, command_js_1.isSleepUntilCommand)(command) | ||
? new Date(command.untilTime) | ||
: new Date(baseTime.getTime() + command.durationSeconds * 1000); | ||
const untilTimeIso = untilTime.toISOString(); | ||
await self.props.timerClient.scheduleEvent({ | ||
return (0, workflow_events_js_1.createEvent)({ | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: workflow_events_js_1.WorkflowEventType.ExpectSignalStarted, | ||
timeoutSeconds: command.timeoutSeconds, | ||
}); | ||
} | ||
async sendSignal(executionId, command) { | ||
const childExecutionId = (0, index_js_1.isChildExecutionTarget)(command.target) | ||
? (0, execution_id_js_1.formatExecutionId)(command.target.workflowName, (0, execution_id_js_1.formatChildExecutionName)(executionId, command.target.seq)) | ||
: command.target.executionId; | ||
await this.props.workflowClient.sendSignal({ | ||
signal: command.signalId, | ||
executionId: childExecutionId, | ||
id: `${executionId}/${command.seq}`, | ||
payload: command.payload, | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.SignalSent, | ||
executionId: childExecutionId, | ||
seq: command.seq, | ||
signalId: command.signalId, | ||
payload: command.payload, | ||
}); | ||
} | ||
async startCondition(executionId, command, baseTime) { | ||
if (command.timeoutSeconds) { | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: workflow_events_js_1.WorkflowEventType.SleepCompleted, | ||
type: workflow_events_js_1.WorkflowEventType.ConditionTimedOut, | ||
seq: command.seq, | ||
}, | ||
schedule: index_js_2.Schedule.absolute(untilTimeIso), | ||
executionId, | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.SleepScheduled, | ||
seq: command.seq, | ||
untilTime: untilTime.toISOString(), | ||
}); | ||
} | ||
async function executeExpectSignal(command) { | ||
if (command.timeoutSeconds) { | ||
await self.props.timerClient.scheduleEvent({ | ||
event: { | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: workflow_events_js_1.WorkflowEventType.ExpectSignalTimedOut, | ||
}, | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
executionId, | ||
}); | ||
} | ||
return (0, workflow_events_js_1.createEvent)({ | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: workflow_events_js_1.WorkflowEventType.ExpectSignalStarted, | ||
timeoutSeconds: command.timeoutSeconds, | ||
}); | ||
} | ||
async function sendSignal(command) { | ||
const childExecutionId = (0, index_js_1.isChildExecutionTarget)(command.target) | ||
? (0, execution_id_js_1.formatExecutionId)(command.target.workflowName, (0, execution_id_js_1.formatChildExecutionName)(executionId, command.target.seq)) | ||
: command.target.executionId; | ||
await self.props.workflowClient.sendSignal({ | ||
signal: command.signalId, | ||
executionId: childExecutionId, | ||
id: `${executionId}/${command.seq}`, | ||
payload: command.payload, | ||
}); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.SignalSent, | ||
executionId: childExecutionId, | ||
seq: command.seq, | ||
signalId: command.signalId, | ||
payload: command.payload, | ||
}); | ||
} | ||
async function startCondition(command) { | ||
if (command.timeoutSeconds) { | ||
await self.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: workflow_events_js_1.WorkflowEventType.ConditionTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
schedule: index_js_2.Schedule.relative(command.timeoutSeconds, baseTime), | ||
}); | ||
} | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ConditionStarted, | ||
seq: command.seq, | ||
}); | ||
} | ||
async function publishEvents(command) { | ||
await self.props.eventClient.publish(...command.events); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.EventsPublished, | ||
events: command.events, | ||
seq: command.seq, | ||
}); | ||
} | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.ConditionStarted, | ||
seq: command.seq, | ||
}); | ||
} | ||
async publishEvents(command) { | ||
await this.props.eventClient.publish(...command.events); | ||
return (0, workflow_events_js_1.createEvent)({ | ||
type: workflow_events_js_1.WorkflowEventType.EventsPublished, | ||
events: command.events, | ||
seq: command.seq, | ||
}); | ||
} | ||
} | ||
exports.CommandExecutor = CommandExecutor; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-executor.js","sourceRoot":"","sources":["../../../src/runtime/command-executor.ts"],"names":[],"mappings":";;;AAAA,8CAkBuB;AACvB,8DAc+B;AAC/B,0CAAsE;AACtE,wCAAyC;AAEzC,uDAAgF;AAEhF,yCAMoB;AASpB;;GAEG;AACH,MAAa,eAAe;IAC1B,YAAoB,KAA2B;QAA3B,UAAK,GAAL,KAAK,CAAsB;IAAG,CAAC;IAEnD,KAAK,CAAC,cAAc,CAClB,QAAkB,EAClB,WAAmB,EACnB,OAAgB,EAChB,QAAc;QAEd,MAAM,IAAI,GAAG,IAAI,CAAC;QAClB,IAAI,IAAA,sCAAyB,EAAC,OAAO,CAAC,EAAE;YACtC,OAAO,MAAM,gBAAgB,CAAC,OAAO,CAAC,CAAC;SACxC;aAAM,IAAI,IAAA,sCAAyB,EAAC,OAAO,CAAC,EAAE;YAC7C,OAAO,qBAAqB,CAAC,OAAO,CAAC,CAAC;SACvC;aAAM,IAAI,IAAA,8BAAiB,EAAC,OAAO,CAAC,IAAI,IAAA,gCAAmB,EAAC,OAAO,CAAC,EAAE;YACrE,+EAA+E;YAC/E,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;SAC/B;aAAM,IAAI,IAAA,kCAAqB,EAAC,OAAO,CAAC,EAAE;YACzC,2FAA2F;YAC3F,OAAO,mBAAmB,CAAC,OAAO,CAAC,CAAC;SACrC;aAAM,IAAI,IAAA,gCAAmB,EAAC,OAAO,CAAC,EAAE;YACvC,OAAO,UAAU,CAAC,OAAO,CAAC,CAAC;SAC5B;aAAM,IAAI,IAAA,oCAAuB,EAAC,OAAO,CAAC,EAAE;YAC3C,OAAO,cAAc,CAAC,OAAO,CAAC,CAAC;SAChC;aAAM,IAAI,IAAA,mCAAsB,EAAC,OAAO,CAAC,EAAE;YAC1C,OAAO,aAAa,CAAC,OAAO,CAAC,CAAC;SAC/B;aAAM;YACL,OAAO,IAAA,qBAAW,EAAC,OAAO,EAAE,sBAAsB,CAAC,CAAC;SACrD;QAED,KAAK,UAAU,gBAAgB,CAAC,OAAgC;YAC9D,MAAM,OAAO,GAA0B;gBACrC,aAAa,EAAE,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE;gBACvC,YAAY,EAAE,QAAQ,CAAC,YAAY;gBACnC,WAAW;gBACX,OAAO;gBACP,KAAK,EAAE,CAAC;aACT,CAAC;YAEF,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc;gBAC3C,CAAC,CAAC,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAmB;oBAC3D,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,QAAQ,CAAC;oBAC7D,KAAK,EAAE;wBACL,IAAI,EAAE,sCAAiB,CAAC,gBAAgB;wBACxC,GAAG,EAAE,OAAO,CAAC,GAAG;qBACjB;oBACD,WAAW;iBACZ,CAAC;gBACJ,CAAC,CAAC,SAAS,CAAC;YAEd,MAAM,eAAe,GACnB,IAAI,CAAC,KAAK,CAAC,qBAAqB,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC;YAE1D,MAAM,OAAO,CAAC,GAAG,CAAC,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC,CAAC;YAErD,OAAO,IAAA,gCAAW,EAAoB;gBACpC,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;gBACzC,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,IAAI,EAAE,OAAO,CAAC,IAAI;aACnB,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,qBAAqB,CAClC,OAAgC;YAEhC,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,aAAa,CAAC;gBAC5C,YAAY,EAAE,OAAO,CAAC,IAAI;gBAC1B,KAAK,EAAE,OAAO,CAAC,KAAK;gBACpB,iBAAiB,EAAE,WAAW;gBAC9B,aAAa,EAAE,IAAA,0CAAwB,EAAC,WAAW,EAAE,OAAO,CAAC,GAAG,CAAC;gBACjE,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,GAAG,OAAO,CAAC,IAAI;aAChB,CAAC,CAAC;YAEH,OAAO,IAAA,gCAAW,EAAyB;gBACzC,IAAI,EAAE,sCAAiB,CAAC,sBAAsB;gBAC9C,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,IAAI,EAAE,OAAO,CAAC,IAAI;gBAClB,KAAK,EAAE,OAAO,CAAC,KAAK;aACrB,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,aAAa,CAC1B,OAA4C;YAE5C,gBAAgB;YAChB,MAAM,SAAS,GAAG,IAAA,gCAAmB,EAAC,OAAO,CAAC;gBAC5C,CAAC,CAAC,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC;gBAC7B,CAAC,CAAC,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,GAAG,OAAO,CAAC,eAAe,GAAG,IAAI,CAAC,CAAC;YAClE,MAAM,YAAY,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;YAE7C,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAiB;gBACzD,KAAK,EAAE;oBACL,IAAI,EAAE,sCAAiB,CAAC,cAAc;oBACtC,GAAG,EAAE,OAAO,CAAC,GAAG;iBACjB;gBACD,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,YAAY,CAAC;gBACzC,WAAW;aACZ,CAAC,CAAC;YAEH,OAAO,IAAA,gCAAW,EAAiB;gBACjC,IAAI,EAAE,sCAAiB,CAAC,cAAc;gBACtC,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,SAAS,EAAE,SAAS,CAAC,WAAW,EAAE;aACnC,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,mBAAmB,CAChC,OAA4B;YAE5B,IAAI,OAAO,CAAC,cAAc,EAAE;gBAC1B,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAuB;oBAC/D,KAAK,EAAE;wBACL,QAAQ,EAAE,OAAO,CAAC,QAAQ;wBAC1B,GAAG,EAAE,OAAO,CAAC,GAAG;wBAChB,IAAI,EAAE,sCAAiB,CAAC,oBAAoB;qBAC7C;oBACD,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,QAAQ,CAAC;oBAC7D,WAAW;iBACZ,CAAC,CAAC;aACJ;YAED,OAAO,IAAA,gCAAW,EAAsB;gBACtC,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,IAAI,EAAE,sCAAiB,CAAC,mBAAmB;gBAC3C,cAAc,EAAE,OAAO,CAAC,cAAc;aACvC,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,UAAU,CAAC,OAA0B;YAClD,MAAM,gBAAgB,GAAG,IAAA,iCAAsB,EAAC,OAAO,CAAC,MAAM,CAAC;gBAC7D,CAAC,CAAC,IAAA,mCAAiB,EACf,OAAO,CAAC,MAAM,CAAC,YAAY,EAC3B,IAAA,0CAAwB,EAAC,WAAW,EAAE,OAAO,CAAC,MAAM,CAAC,GAAG,CAAC,CAC1D;gBACH,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,WAAW,CAAC;YAE/B,MAAM,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC,UAAU,CAAC;gBACzC,MAAM,EAAE,OAAO,CAAC,QAAQ;gBACxB,WAAW,EAAE,gBAAgB;gBAC7B,EAAE,EAAE,GAAG,WAAW,IAAI,OAAO,CAAC,GAAG,EAAE;gBACnC,OAAO,EAAE,OAAO,CAAC,OAAO;aACzB,CAAC,CAAC;YAEH,OAAO,IAAA,gCAAW,EAAa;gBAC7B,IAAI,EAAE,sCAAiB,CAAC,UAAU;gBAClC,WAAW,EAAE,gBAAgB;gBAC7B,GAAG,EAAE,OAAO,CAAC,GAAG;gBAChB,QAAQ,EAAE,OAAO,CAAC,QAAQ;gBAC1B,OAAO,EAAE,OAAO,CAAC,OAAO;aACzB,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,cAAc,CAAC,OAA8B;YAC1D,IAAI,OAAO,CAAC,cAAc,EAAE;gBAC1B,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAoB;oBAC5D,KAAK,EAAE;wBACL,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;wBACzC,GAAG,EAAE,OAAO,CAAC,GAAG;qBACjB;oBACD,WAAW;oBACX,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,OAAO,CAAC,cAAc,EAAE,QAAQ,CAAC;iBAC9D,CAAC,CAAC;aACJ;YAED,OAAO,IAAA,gCAAW,EAAmB;gBACnC,IAAI,EAAE,sCAAiB,CAAC,gBAAgB;gBACxC,GAAG,EAAE,OAAO,CAAC,GAAI;aAClB,CAAC,CAAC;QACL,CAAC;QAED,KAAK,UAAU,aAAa,CAAC,OAA6B;YACxD,MAAM,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,MAAM,CAAC,CAAC;YACxD,OAAO,IAAA,gCAAW,EAAkB;gBAClC,IAAI,EAAE,sCAAiB,CAAC,eAAe;gBACvC,MAAM,EAAE,OAAO,CAAC,MAAM;gBACtB,GAAG,EAAE,OAAO,CAAC,GAAI;aAClB,CAAC,CAAC;QACL,CAAC;IACH,CAAC;CACF;AArLD,0CAqLC","sourcesContent":["import {\n  Command,\n  ExpectSignalCommand,\n  isExpectSignalCommand,\n  isPublishEventsCommand,\n  isScheduleActivityCommand,\n  isScheduleWorkflowCommand,\n  isSendSignalCommand,\n  isSleepForCommand,\n  isSleepUntilCommand,\n  isStartConditionCommand,\n  PublishEventsCommand,\n  ScheduleActivityCommand,\n  ScheduleWorkflowCommand,\n  SendSignalCommand,\n  SleepForCommand,\n  SleepUntilCommand,\n  StartConditionCommand,\n} from \"../command.js\";\nimport {\n  ActivityTimedOut,\n  WorkflowEventType,\n  createEvent,\n  ActivityScheduled,\n  ChildWorkflowScheduled,\n  SleepScheduled,\n  SleepCompleted,\n  ExpectSignalStarted,\n  ExpectSignalTimedOut,\n  HistoryStateEvent,\n  ConditionStarted,\n  ConditionTimedOut,\n  SignalSent,\n} from \"../workflow-events.js\";\nimport { EventsPublished, isChildExecutionTarget } from \"../index.js\";\nimport { assertNever } from \"../util.js\";\nimport { Workflow } from \"../workflow.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution-id.js\";\nimport { ActivityWorkerRequest } from \"./handlers/activity-worker.js\";\nimport {\n  EventClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"./index.js\";\n\ninterface CommandExecutorProps {\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  timerClient: TimerClient;\n  workflowClient: WorkflowClient;\n  eventClient: EventClient;\n}\n\n/**\n * Uses the clients to execute all supported commands and return events.\n */\nexport class CommandExecutor {\n  constructor(private props: CommandExecutorProps) {}\n\n  async executeCommand(\n    workflow: Workflow,\n    executionId: string,\n    command: Command,\n    baseTime: Date\n  ): Promise<HistoryStateEvent> {\n    const self = this;\n    if (isScheduleActivityCommand(command)) {\n      return await scheduleActivity(command);\n    } else if (isScheduleWorkflowCommand(command)) {\n      return scheduleChildWorkflow(command);\n    } else if (isSleepForCommand(command) || isSleepUntilCommand(command)) {\n      // all sleep times are computed using the start time of the WorkflowTaskStarted\n      return scheduleSleep(command);\n    } else if (isExpectSignalCommand(command)) {\n      // should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)?\n      return executeExpectSignal(command);\n    } else if (isSendSignalCommand(command)) {\n      return sendSignal(command);\n    } else if (isStartConditionCommand(command)) {\n      return startCondition(command);\n    } else if (isPublishEventsCommand(command)) {\n      return publishEvents(command);\n    } else {\n      return assertNever(command, `unknown command type`);\n    }\n\n    async function scheduleActivity(command: ScheduleActivityCommand) {\n      const request: ActivityWorkerRequest = {\n        scheduledTime: new Date().toISOString(),\n        workflowName: workflow.workflowName,\n        executionId,\n        command,\n        retry: 0,\n      };\n\n      const timeoutStarter = command.timeoutSeconds\n        ? await self.props.timerClient.scheduleEvent<ActivityTimedOut>({\n            schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n            event: {\n              type: WorkflowEventType.ActivityTimedOut,\n              seq: command.seq,\n            },\n            executionId,\n          })\n        : undefined;\n\n      const activityStarter =\n        self.props.workflowRuntimeClient.startActivity(request);\n\n      await Promise.all([activityStarter, timeoutStarter]);\n\n      return createEvent<ActivityScheduled>({\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      });\n    }\n\n    async function scheduleChildWorkflow(\n      command: ScheduleWorkflowCommand\n    ): Promise<ChildWorkflowScheduled> {\n      await self.props.workflowClient.startWorkflow({\n        workflowName: command.name,\n        input: command.input,\n        parentExecutionId: executionId,\n        executionName: formatChildExecutionName(executionId, command.seq),\n        seq: command.seq,\n        ...command.opts,\n      });\n\n      return createEvent<ChildWorkflowScheduled>({\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      });\n    }\n\n    async function scheduleSleep(\n      command: SleepForCommand | SleepUntilCommand\n    ): Promise<SleepScheduled> {\n      // TODO validate\n      const untilTime = isSleepUntilCommand(command)\n        ? new Date(command.untilTime)\n        : new Date(baseTime.getTime() + command.durationSeconds * 1000);\n      const untilTimeIso = untilTime.toISOString();\n\n      await self.props.timerClient.scheduleEvent<SleepCompleted>({\n        event: {\n          type: WorkflowEventType.SleepCompleted,\n          seq: command.seq,\n        },\n        schedule: Schedule.absolute(untilTimeIso),\n        executionId,\n      });\n\n      return createEvent<SleepScheduled>({\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      });\n    }\n\n    async function executeExpectSignal(\n      command: ExpectSignalCommand\n    ): Promise<ExpectSignalStarted> {\n      if (command.timeoutSeconds) {\n        await self.props.timerClient.scheduleEvent<ExpectSignalTimedOut>({\n          event: {\n            signalId: command.signalId,\n            seq: command.seq,\n            type: WorkflowEventType.ExpectSignalTimedOut,\n          },\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n          executionId,\n        });\n      }\n\n      return createEvent<ExpectSignalStarted>({\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      });\n    }\n\n    async function sendSignal(command: SendSignalCommand) {\n      const childExecutionId = isChildExecutionTarget(command.target)\n        ? formatExecutionId(\n            command.target.workflowName,\n            formatChildExecutionName(executionId, command.target.seq)\n          )\n        : command.target.executionId;\n\n      await self.props.workflowClient.sendSignal({\n        signal: command.signalId,\n        executionId: childExecutionId,\n        id: `${executionId}/${command.seq}`,\n        payload: command.payload,\n      });\n\n      return createEvent<SignalSent>({\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      });\n    }\n\n    async function startCondition(command: StartConditionCommand) {\n      if (command.timeoutSeconds) {\n        await self.props.timerClient.scheduleEvent<ConditionTimedOut>({\n          event: {\n            type: WorkflowEventType.ConditionTimedOut,\n            seq: command.seq,\n          },\n          executionId,\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n        });\n      }\n\n      return createEvent<ConditionStarted>({\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      });\n    }\n\n    async function publishEvents(command: PublishEventsCommand) {\n      await self.props.eventClient.publish(...command.events);\n      return createEvent<EventsPublished>({\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      });\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-executor.js","sourceRoot":"","sources":["../../../src/runtime/command-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Command,\n  ExpectSignalCommand,\n  isExpectSignalCommand,\n  isPublishEventsCommand,\n  isScheduleActivityCommand,\n  isScheduleWorkflowCommand,\n  isSendSignalCommand,\n  isSleepForCommand,\n  isSleepUntilCommand,\n  isStartConditionCommand,\n  PublishEventsCommand,\n  ScheduleActivityCommand,\n  ScheduleWorkflowCommand,\n  SendSignalCommand,\n  SleepForCommand,\n  SleepUntilCommand,\n  StartConditionCommand,\n} from \"../command.js\";\nimport {\n  ActivityTimedOut,\n  WorkflowEventType,\n  createEvent,\n  ActivityScheduled,\n  ChildWorkflowScheduled,\n  SleepScheduled,\n  SleepCompleted,\n  ExpectSignalStarted,\n  ExpectSignalTimedOut,\n  HistoryStateEvent,\n  ConditionStarted,\n  ConditionTimedOut,\n  SignalSent,\n} from \"../workflow-events.js\";\nimport { EventsPublished, isChildExecutionTarget } from \"../index.js\";\nimport { assertNever } from \"../util.js\";\nimport { Workflow } from \"../workflow.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution-id.js\";\nimport { ActivityWorkerRequest } from \"./handlers/activity-worker.js\";\nimport {\n  EventClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"./index.js\";\n\ninterface CommandExecutorProps {\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  timerClient: TimerClient;\n  workflowClient: WorkflowClient;\n  eventClient: EventClient;\n}\n\n/**\n * Uses the clients to execute all supported commands and return events.\n */\nexport class CommandExecutor {\n  constructor(private props: CommandExecutorProps) {}\n\n  public async executeCommand(\n    workflow: Workflow,\n    executionId: string,\n    command: Command,\n    baseTime: Date\n  ): Promise<HistoryStateEvent> {\n    if (isScheduleActivityCommand(command)) {\n      return await this.scheduleActivity(\n        workflow,\n        executionId,\n        command,\n        baseTime\n      );\n    } else if (isScheduleWorkflowCommand(command)) {\n      return this.scheduleChildWorkflow(executionId, command);\n    } else if (isSleepForCommand(command) || isSleepUntilCommand(command)) {\n      // all sleep times are computed using the start time of the WorkflowTaskStarted\n      return this.scheduleSleep(executionId, command, baseTime);\n    } else if (isExpectSignalCommand(command)) {\n      // should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)?\n      return this.executeExpectSignal(executionId, command, baseTime);\n    } else if (isSendSignalCommand(command)) {\n      return this.sendSignal(executionId, command);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command);\n    } else {\n      return assertNever(command, `unknown command type`);\n    }\n  }\n\n  private async scheduleActivity(\n    workflow: Workflow,\n    executionId: string,\n    command: ScheduleActivityCommand,\n    baseTime: Date\n  ) {\n    const request: ActivityWorkerRequest = {\n      scheduledTime: new Date().toISOString(),\n      workflowName: workflow.workflowName,\n      executionId,\n      command,\n      retry: 0,\n    };\n\n    const timeoutStarter = command.timeoutSeconds\n      ? await this.props.timerClient.scheduleEvent<ActivityTimedOut>({\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n          event: {\n            type: WorkflowEventType.ActivityTimedOut,\n            seq: command.seq,\n          },\n          executionId,\n        })\n      : undefined;\n\n    const activityStarter =\n      this.props.workflowRuntimeClient.startActivity(request);\n\n    await Promise.all([activityStarter, timeoutStarter]);\n\n    return createEvent<ActivityScheduled>({\n      type: WorkflowEventType.ActivityScheduled,\n      seq: command.seq,\n      name: command.name,\n    });\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startWorkflow({\n      workflowName: command.name,\n      input: command.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, command.seq),\n      seq: command.seq,\n      ...command.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>({\n      type: WorkflowEventType.ChildWorkflowScheduled,\n      seq: command.seq,\n      name: command.name,\n      input: command.input,\n    });\n  }\n\n  private async scheduleSleep(\n    executionId: string,\n\n    command: SleepForCommand | SleepUntilCommand,\n    baseTime: Date\n  ): Promise<SleepScheduled> {\n    // TODO validate\n    const untilTime = isSleepUntilCommand(command)\n      ? new Date(command.untilTime)\n      : new Date(baseTime.getTime() + command.durationSeconds * 1000);\n    const untilTimeIso = untilTime.toISOString();\n\n    await this.props.timerClient.scheduleEvent<SleepCompleted>({\n      event: {\n        type: WorkflowEventType.SleepCompleted,\n        seq: command.seq,\n      },\n      schedule: Schedule.absolute(untilTimeIso),\n      executionId,\n    });\n\n    return createEvent<SleepScheduled>({\n      type: WorkflowEventType.SleepScheduled,\n      seq: command.seq,\n      untilTime: untilTime.toISOString(),\n    });\n  }\n\n  private async executeExpectSignal(\n    executionId: string,\n\n    command: ExpectSignalCommand,\n    baseTime: Date\n  ): Promise<ExpectSignalStarted> {\n    if (command.timeoutSeconds) {\n      await this.props.timerClient.scheduleEvent<ExpectSignalTimedOut>({\n        event: {\n          signalId: command.signalId,\n          seq: command.seq,\n          type: WorkflowEventType.ExpectSignalTimedOut,\n        },\n        schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n        executionId,\n      });\n    }\n\n    return createEvent<ExpectSignalStarted>({\n      signalId: command.signalId,\n      seq: command.seq,\n      type: WorkflowEventType.ExpectSignalStarted,\n      timeoutSeconds: command.timeoutSeconds,\n    });\n  }\n\n  private async sendSignal(executionId: string, command: SendSignalCommand) {\n    const childExecutionId = isChildExecutionTarget(command.target)\n      ? formatExecutionId(\n          command.target.workflowName,\n          formatChildExecutionName(executionId, command.target.seq)\n        )\n      : command.target.executionId;\n\n    await this.props.workflowClient.sendSignal({\n      signal: command.signalId,\n      executionId: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>({\n      type: WorkflowEventType.SignalSent,\n      executionId: childExecutionId,\n      seq: command.seq,\n      signalId: command.signalId,\n      payload: command.payload,\n    });\n  }\n\n  private async startCondition(\n    executionId: string,\n    command: StartConditionCommand,\n    baseTime: Date\n  ) {\n    if (command.timeoutSeconds) {\n      await this.props.timerClient.scheduleEvent<ConditionTimedOut>({\n        event: {\n          type: WorkflowEventType.ConditionTimedOut,\n          seq: command.seq,\n        },\n        executionId,\n        schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n      });\n    }\n\n    return createEvent<ConditionStarted>({\n      type: WorkflowEventType.ConditionStarted,\n      seq: command.seq!,\n    });\n  }\n\n  private async publishEvents(command: PublishEventsCommand) {\n    await this.props.eventClient.publish(...command.events);\n    return createEvent<EventsPublished>({\n      type: WorkflowEventType.EventsPublished,\n      events: command.events,\n      seq: command.seq!,\n    });\n  }\n}\n"]} |
@@ -16,3 +16,3 @@ "use strict"; | ||
exports.formatExecutionId = formatExecutionId; | ||
//API Gateway doesn't agree with uri encoding in path parameter... so we have these. for now | ||
// API Gateway doesn't agree with uri encoding in path parameter... so we have these. for now | ||
function encodeExecutionId(executionId) { | ||
@@ -41,2 +41,2 @@ return Buffer.from(executionId, "utf-8").toString("base64"); | ||
exports.formatChildExecutionName = formatChildExecutionName; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWlkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3J1bnRpbWUvZXhlY3V0aW9uLWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUtBLFNBQWdCLGFBQWEsQ0FBQyxDQUFNO0lBQ2xDLE9BQU8sT0FBTyxDQUFDLEtBQUssUUFBUSxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRkQsc0NBRUM7QUFFRCxTQUFnQixpQkFBaUIsQ0FBQyxXQUF3QjtJQUN4RCxPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFFLENBQUM7QUFDcEMsQ0FBQztBQUZELDhDQUVDO0FBRUQsU0FBZ0IsaUJBQWlCLENBRy9CLFlBQW9CLEVBQUUsRUFBVTtJQUNoQyxPQUFPLEdBQUcsWUFBWSxJQUFJLEVBQUUsRUFBbUMsQ0FBQztBQUNsRSxDQUFDO0FBTEQsOENBS0M7QUFFRCw0RkFBNEY7QUFDNUYsU0FBZ0IsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUZELDhDQUVDO0FBRUQsU0FBZ0IsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUZELDhDQUVDO0FBRVksUUFBQSw0QkFBNEIsR0FBRyxjQUFjLENBQUM7QUFFM0Q7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0Isd0JBQXdCLENBQ3RDLGlCQUF5QixFQUN6QixHQUFXO0lBRVgsT0FBTyxHQUFHLG9DQUE0QixHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FDaEUsR0FBRyxFQUNILEdBQUcsQ0FDSixJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQ2IsQ0FBQztBQVJELDREQVFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgRXhlY3V0aW9uSUQ8XG4gIFdvcmtmbG93TmFtZSBleHRlbmRzIHN0cmluZyA9IHN0cmluZyxcbiAgSUQgZXh0ZW5kcyBzdHJpbmcgPSBzdHJpbmdcbj4gPSBgJHtXb3JrZmxvd05hbWV9LyR7SUR9YDtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXhlY3V0aW9uSWQoYTogYW55KTogYSBpcyBFeGVjdXRpb25JRCB7XG4gIHJldHVybiB0eXBlb2YgYSA9PT0gXCJzdHJpbmdcIiAmJiBhLnNwbGl0KFwiL1wiKS5sZW5ndGggPT09IDI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZVdvcmtmbG93TmFtZShleGVjdXRpb25JZDogRXhlY3V0aW9uSUQpOiBzdHJpbmcge1xuICByZXR1cm4gZXhlY3V0aW9uSWQuc3BsaXQoXCIvXCIpWzBdITtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdEV4ZWN1dGlvbklkPFxuICBXb3JrZmxvd05hbWUgZXh0ZW5kcyBzdHJpbmcsXG4gIElEIGV4dGVuZHMgc3RyaW5nXG4+KHdvcmtmbG93TmFtZTogc3RyaW5nLCBpZDogc3RyaW5nKTogRXhlY3V0aW9uSUQ8V29ya2Zsb3dOYW1lLCBJRD4ge1xuICByZXR1cm4gYCR7d29ya2Zsb3dOYW1lfS8ke2lkfWAgYXMgRXhlY3V0aW9uSUQ8V29ya2Zsb3dOYW1lLCBJRD47XG59XG5cbi8vQVBJIEdhdGV3YXkgZG9lc24ndCBhZ3JlZSB3aXRoIHVyaSBlbmNvZGluZyBpbiBwYXRoIHBhcmFtZXRlci4uLiBzbyB3ZSBoYXZlIHRoZXNlLiBmb3Igbm93XG5leHBvcnQgZnVuY3Rpb24gZW5jb2RlRXhlY3V0aW9uSWQoZXhlY3V0aW9uSWQ6IHN0cmluZykge1xuICByZXR1cm4gQnVmZmVyLmZyb20oZXhlY3V0aW9uSWQsIFwidXRmLThcIikudG9TdHJpbmcoXCJiYXNlNjRcIik7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBkZWNvZGVFeGVjdXRpb25JZChleGVjdXRpb25JZDogc3RyaW5nKSB7XG4gIHJldHVybiBCdWZmZXIuZnJvbShleGVjdXRpb25JZCwgXCJiYXNlNjRcIikudG9TdHJpbmcoXCJ1dGYtOFwiKTtcbn1cblxuZXhwb3J0IGNvbnN0IElOVEVSTkFMX0VYRUNVVElPTl9JRF9QUkVGSVggPSBcIiMjRVZFTlRVQUwjI1wiO1xuXG4vKipcbiAqIEZvcm1hdHMgYW4gY2hpbGQgd29ya2Zsb3cgZXhlY3V0aW9uIGFzIGEgdW5pcXVlLCBkZXRlcm1pbmlzdGljIG5hbWUuXG4gKiAxLiB3ZSBwcmVmaXggaXQgd2l0aCB7QGxpbmsgSU5URVJOQUxfRVhFQ1VUSU9OX0lEX1BSRUZJWH0gdG8gZW5zdXJlIGl0IGlzIGltcG9zc2libGUgZm9yIGEgdXNlciB0byBjcmVhdGUgaXQuXG4gKiAyLiB3ZSBjb25zdHJ1Y3QgdGhlIG5hbWUgZnJvbSB0aGUgcGFyZW50IGV4ZWN1dGlvbiBJRCBhbmQgdGhlIHNlcSAtIHRoaXMgZW5zdXJlcyB1bmlxdWVuZXNzIGFuZCBpcyBkZXRlcm1pbmlzdGljXG4gKlxuICogSXQgbXVzdCBiZSBkZXRlcm1pbmlzdGljIHRvIGVuc3VyZSBpZGVtcG90ZW5jeS5cbiAqXG4gKiBAcGFyYW0gcGFyZW50RXhlY3V0aW9uSWQgaWQgb2YgdGhlIGNhbGxlciBleGVjdXRpb24gdXNlZCB0byBjb21wdXRlIHRoZSBjaGlsZCB3b3JrZmxvdyBuYW1lXG4gKiBAcGFyYW0gc2VxIHBvc2l0aW9uIHRoYXQgc3RhcnRlZCB0aGUgY2hpbGQgd29ya2Zsb3dcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdENoaWxkRXhlY3V0aW9uTmFtZShcbiAgcGFyZW50RXhlY3V0aW9uSWQ6IHN0cmluZyxcbiAgc2VxOiBudW1iZXJcbik6IHN0cmluZyB7XG4gIHJldHVybiBgJHtJTlRFUk5BTF9FWEVDVVRJT05fSURfUFJFRklYfSR7cGFyZW50RXhlY3V0aW9uSWQucmVwbGFjZShcbiAgICBcIi9cIixcbiAgICBcIi1cIlxuICApfS0ke3NlcX1gO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWlkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3J1bnRpbWUvZXhlY3V0aW9uLWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUtBLFNBQWdCLGFBQWEsQ0FBQyxDQUFNO0lBQ2xDLE9BQU8sT0FBTyxDQUFDLEtBQUssUUFBUSxJQUFJLENBQUMsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQztBQUM1RCxDQUFDO0FBRkQsc0NBRUM7QUFFRCxTQUFnQixpQkFBaUIsQ0FBQyxXQUF3QjtJQUN4RCxPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFFLENBQUM7QUFDcEMsQ0FBQztBQUZELDhDQUVDO0FBRUQsU0FBZ0IsaUJBQWlCLENBRy9CLFlBQW9CLEVBQUUsRUFBVTtJQUNoQyxPQUFPLEdBQUcsWUFBWSxJQUFJLEVBQUUsRUFBbUMsQ0FBQztBQUNsRSxDQUFDO0FBTEQsOENBS0M7QUFFRCw2RkFBNkY7QUFDN0YsU0FBZ0IsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxPQUFPLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUZELDhDQUVDO0FBRUQsU0FBZ0IsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUZELDhDQUVDO0FBRVksUUFBQSw0QkFBNEIsR0FBRyxjQUFjLENBQUM7QUFFM0Q7Ozs7Ozs7OztHQVNHO0FBQ0gsU0FBZ0Isd0JBQXdCLENBQ3RDLGlCQUF5QixFQUN6QixHQUFXO0lBRVgsT0FBTyxHQUFHLG9DQUE0QixHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FDaEUsR0FBRyxFQUNILEdBQUcsQ0FDSixJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQ2IsQ0FBQztBQVJELDREQVFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHR5cGUgRXhlY3V0aW9uSUQ8XG4gIFdvcmtmbG93TmFtZSBleHRlbmRzIHN0cmluZyA9IHN0cmluZyxcbiAgSUQgZXh0ZW5kcyBzdHJpbmcgPSBzdHJpbmdcbj4gPSBgJHtXb3JrZmxvd05hbWV9LyR7SUR9YDtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzRXhlY3V0aW9uSWQoYTogYW55KTogYSBpcyBFeGVjdXRpb25JRCB7XG4gIHJldHVybiB0eXBlb2YgYSA9PT0gXCJzdHJpbmdcIiAmJiBhLnNwbGl0KFwiL1wiKS5sZW5ndGggPT09IDI7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZVdvcmtmbG93TmFtZShleGVjdXRpb25JZDogRXhlY3V0aW9uSUQpOiBzdHJpbmcge1xuICByZXR1cm4gZXhlY3V0aW9uSWQuc3BsaXQoXCIvXCIpWzBdITtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZvcm1hdEV4ZWN1dGlvbklkPFxuICBXb3JrZmxvd05hbWUgZXh0ZW5kcyBzdHJpbmcsXG4gIElEIGV4dGVuZHMgc3RyaW5nXG4+KHdvcmtmbG93TmFtZTogc3RyaW5nLCBpZDogc3RyaW5nKTogRXhlY3V0aW9uSUQ8V29ya2Zsb3dOYW1lLCBJRD4ge1xuICByZXR1cm4gYCR7d29ya2Zsb3dOYW1lfS8ke2lkfWAgYXMgRXhlY3V0aW9uSUQ8V29ya2Zsb3dOYW1lLCBJRD47XG59XG5cbi8vIEFQSSBHYXRld2F5IGRvZXNuJ3QgYWdyZWUgd2l0aCB1cmkgZW5jb2RpbmcgaW4gcGF0aCBwYXJhbWV0ZXIuLi4gc28gd2UgaGF2ZSB0aGVzZS4gZm9yIG5vd1xuZXhwb3J0IGZ1bmN0aW9uIGVuY29kZUV4ZWN1dGlvbklkKGV4ZWN1dGlvbklkOiBzdHJpbmcpIHtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKGV4ZWN1dGlvbklkLCBcInV0Zi04XCIpLnRvU3RyaW5nKFwiYmFzZTY0XCIpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVjb2RlRXhlY3V0aW9uSWQoZXhlY3V0aW9uSWQ6IHN0cmluZykge1xuICByZXR1cm4gQnVmZmVyLmZyb20oZXhlY3V0aW9uSWQsIFwiYmFzZTY0XCIpLnRvU3RyaW5nKFwidXRmLThcIik7XG59XG5cbmV4cG9ydCBjb25zdCBJTlRFUk5BTF9FWEVDVVRJT05fSURfUFJFRklYID0gXCIjI0VWRU5UVUFMIyNcIjtcblxuLyoqXG4gKiBGb3JtYXRzIGFuIGNoaWxkIHdvcmtmbG93IGV4ZWN1dGlvbiBhcyBhIHVuaXF1ZSwgZGV0ZXJtaW5pc3RpYyBuYW1lLlxuICogMS4gd2UgcHJlZml4IGl0IHdpdGgge0BsaW5rIElOVEVSTkFMX0VYRUNVVElPTl9JRF9QUkVGSVh9IHRvIGVuc3VyZSBpdCBpcyBpbXBvc3NpYmxlIGZvciBhIHVzZXIgdG8gY3JlYXRlIGl0LlxuICogMi4gd2UgY29uc3RydWN0IHRoZSBuYW1lIGZyb20gdGhlIHBhcmVudCBleGVjdXRpb24gSUQgYW5kIHRoZSBzZXEgLSB0aGlzIGVuc3VyZXMgdW5pcXVlbmVzcyBhbmQgaXMgZGV0ZXJtaW5pc3RpY1xuICpcbiAqIEl0IG11c3QgYmUgZGV0ZXJtaW5pc3RpYyB0byBlbnN1cmUgaWRlbXBvdGVuY3kuXG4gKlxuICogQHBhcmFtIHBhcmVudEV4ZWN1dGlvbklkIGlkIG9mIHRoZSBjYWxsZXIgZXhlY3V0aW9uIHVzZWQgdG8gY29tcHV0ZSB0aGUgY2hpbGQgd29ya2Zsb3cgbmFtZVxuICogQHBhcmFtIHNlcSBwb3NpdGlvbiB0aGF0IHN0YXJ0ZWQgdGhlIGNoaWxkIHdvcmtmbG93XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRDaGlsZEV4ZWN1dGlvbk5hbWUoXG4gIHBhcmVudEV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gIHNlcTogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7SU5URVJOQUxfRVhFQ1VUSU9OX0lEX1BSRUZJWH0ke3BhcmVudEV4ZWN1dGlvbklkLnJlcGxhY2UoXG4gICAgXCIvXCIsXG4gICAgXCItXCJcbiAgKX0tJHtzZXF9YDtcbn1cbiJdfQ== |
@@ -181,3 +181,3 @@ "use strict"; | ||
const newWorkflowEvents = []; | ||
let resultEvent = undefined; | ||
let resultEvent; | ||
const seenEvents = new Set(originalHistory.map(workflow_events_js_1.getEventId)); | ||
@@ -305,2 +305,2 @@ for await (const event of executionGenerator) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":"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","sourcesContent":["import { inspect } from \"util\";\nimport { Command } from \"../../command.js\";\nimport { WorkflowContext } from \"../../context.js\";\nimport {\n  createEvent,\n  getEventId,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isWorkflowCompleted,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowCompleted,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowTaskCompleted,\n  WorkflowTaskStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  CompleteExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isCompleteExecution,\n} from \"../../execution.js\";\nimport { isFailed, isResolved, isResult, Result } from \"../../result.js\";\nimport { lookupWorkflow, progressWorkflow, Workflow } from \"../../workflow.js\";\nimport {\n  EventClient,\n  ExecutionHistoryClient,\n  MetricsClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"../clients/index.js\";\nimport { CommandExecutor } from \"../command-executor.js\";\nimport { isExecutionId, parseWorkflowName } from \"../execution-id.js\";\nimport type { Logger } from \"../logger.js\";\nimport { MetricsCommon, OrchestratorMetrics } from \"../metrics/constants.js\";\nimport { MetricsLogger } from \"../metrics/metrics-logger.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed, timedSync } from \"../metrics/utils.js\";\nimport { promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\n\n/**\n * The Orchestrator's client dependencies.\n */\nexport interface OrchestratorDependencies {\n  executionHistoryClient: ExecutionHistoryClient;\n  timerClient: TimerClient;\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  workflowClient: WorkflowClient;\n  metricsClient: MetricsClient;\n  eventClient: EventClient;\n  logger: Logger;\n}\n\nexport interface OrchestratorResult {\n  /**\n   * IDs of the Executions that failed to orchestrate.\n   */\n  failedExecutionIds: string[];\n}\n\n/**\n * Creates a generic function for orchestrating a batch of executions\n * that can be used in runtime implementations. This implementation is\n * decoupled from a runtime's specifics by the clients. A runtime must\n * inject its own client implementations designed for that platform.\n */\nexport function createOrchestrator({\n  executionHistoryClient,\n  timerClient,\n  workflowRuntimeClient,\n  workflowClient,\n  metricsClient,\n  eventClient,\n  logger,\n}: OrchestratorDependencies): (\n  eventsByExecutionId: Record<string, HistoryStateEvent[]>\n) => Promise<OrchestratorResult> {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (eventsByExecutionId) => {\n    logger.debug(\"Handle workflowQueue records\");\n\n    logger.info(\n      \"Found execution ids: \" + Object.keys(eventsByExecutionId).join(\", \")\n    );\n\n    // for each execution id\n    const results = await promiseAllSettledPartitioned(\n      Object.entries(eventsByExecutionId),\n      async ([executionId, records]) => {\n        if (!isExecutionId(executionId)) {\n          throw new Error(`invalid ExecutionID: '${executionId}'`);\n        }\n        const workflowName = parseWorkflowName(executionId);\n        if (workflowName === undefined) {\n          throw new Error(`execution ID '${executionId}' does not exist`);\n        }\n        const workflow = lookupWorkflow(workflowName);\n        if (workflow === undefined) {\n          throw new Error(`no such workflow with name '${workflowName}'`);\n        }\n        // TODO: get workflow from execution id\n        return orchestrateExecution(workflow, executionId, records);\n      }\n    );\n\n    logger.debug(\n      \"Executions succeeded: \" +\n        results.fulfilled.map(([[executionId]]) => executionId).join(\",\")\n    );\n\n    if (results.rejected.length > 0) {\n      logger.error(\n        \"Executions failed: \\n\" +\n          results.rejected\n            .map(([[executionId], error]) => `${executionId}: ${error}`)\n            .join(\"\\n\")\n      );\n    }\n\n    return {\n      failedExecutionIds: results.rejected.map((rejected) => rejected[0][0]),\n    };\n  };\n\n  async function orchestrateExecution(\n    workflow: Workflow,\n    executionId: string,\n    events: HistoryStateEvent[]\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = new Date();\n    try {\n      // load\n      const history = await loadHistory();\n\n      // execute\n      const { updatedHistoryEvents, newEvents, resultEvent } =\n        await executeWorkflow(history);\n\n      // persist\n      await persistWorkflowResult(resultEvent);\n      await saveNewEventsToExecutionHistory(newEvents);\n      await updateHistory(updatedHistoryEvents);\n\n      // Only log these metrics once the orchestrator has completed successfully.\n      logEventMetrics(metrics, events, start);\n    } catch (err) {\n      executionLogger.error(inspect(err));\n      throw err;\n    } finally {\n      await metrics.flush();\n    }\n\n    /**\n     * Executes the workflow and returns the history and events to persist.\n     */\n    async function executeWorkflow(history: HistoryStateEvent[]) {\n      // length of time the oldest event in the queue.\n      const maxTaskAge = Math.max(\n        ...events.map(\n          (event) => new Date().getTime() - Date.parse(event.timestamp)\n        )\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.MaxTaskAge,\n        maxTaskAge,\n        Unit.Milliseconds\n      );\n\n      return partitionExecutionResults(history, executeWorkflowGenerator());\n\n      async function* executeWorkflowGenerator() {\n        yield createEvent<WorkflowTaskStarted>(\n          {\n            type: WorkflowEventType.WorkflowTaskStarted,\n          },\n          start\n        );\n\n        const workflowContext: WorkflowContext = {\n          name: workflow.workflowName,\n        };\n\n        const startEvent = history.find(isWorkflowStarted);\n\n        /**\n         * Check to see if this is the first run of the workflow (or all others have failed).\n         * If so, check to see if the workflow has timeout to start.\n         */\n        if (!startEvent) {\n          const newWorkflowStart = events.find(isWorkflowStarted);\n\n          if (newWorkflowStart?.timeoutTime) {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 1);\n            await timed(\n              metrics,\n              OrchestratorMetrics.TimeoutStartedDuration,\n              () =>\n                timerClient.scheduleEvent<WorkflowTimedOut>({\n                  schedule: Schedule.absolute(newWorkflowStart.timeoutTime!),\n                  event: createEvent<WorkflowTimedOut>({\n                    type: WorkflowEventType.WorkflowTimedOut,\n                  }),\n                  executionId,\n                })\n            );\n          } else {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 0);\n          }\n        }\n\n        const {\n          result,\n          commands: newCommands,\n          history: updatedHistoryEvents,\n        } = timedSync(\n          metrics,\n          OrchestratorMetrics.AdvanceExecutionDuration,\n          () => {\n            try {\n              return progressWorkflow(\n                workflow,\n                history,\n                events,\n                workflowContext,\n                executionId\n              );\n            } catch (err) {\n              console.log(\"workflow error\");\n              executionLogger.error(inspect(err));\n              throw err;\n            }\n          }\n        );\n\n        metrics.setProperty(\n          OrchestratorMetrics.AdvanceExecutionEvents,\n          updatedHistoryEvents.length\n        );\n\n        yield* updatedHistoryEvents;\n\n        executionLogger.debug(\n          \"Workflow terminated with: \" + JSON.stringify(result)\n        );\n\n        executionLogger.info(`Found ${newCommands.length} new commands.`);\n\n        yield* await timed(\n          metrics,\n          OrchestratorMetrics.InvokeCommandsDuration,\n          () => processCommands(newCommands)\n        );\n\n        metrics.putMetric(\n          OrchestratorMetrics.CommandsInvoked,\n          newCommands.length,\n          Unit.Count\n        );\n\n        // tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n        // This represent the workflow orchestration time of User Perceived Latency\n        // Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n        // AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n        metrics.putMetric(\n          OrchestratorMetrics.TimeToCommandsInvoked,\n          maxTaskAge + (new Date().getTime() - start.getTime())\n        );\n\n        yield createEvent<WorkflowTaskCompleted>({\n          type: WorkflowEventType.WorkflowTaskCompleted,\n        });\n\n        if (isResult(result)) {\n          if (isFailed(result)) {\n            const [error, message] = extendsError(result.error)\n              ? [result.error.name, result.error.message]\n              : [\"Error\", JSON.stringify(result.error)];\n            yield createEvent<WorkflowFailed>({\n              type: WorkflowEventType.WorkflowFailed,\n              error,\n              message,\n            });\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>({\n              type: WorkflowEventType.WorkflowCompleted,\n              output: result.value,\n            });\n          }\n        }\n\n        return result;\n      }\n\n      /**\n       * Partitions the events output by the workflow.\n       *\n       * We need two different collection of events.\n       *\n       * History Events - these are the events that workflow uses to maintain state.\n       *                  each run of the workflow we may filter or add events to this collection.\n       *                  these events will be persisted for the next run.\n       * Workflow Events - these are fined grained events emitted by the workflow. They drive UIs,\n       *                   visualization and debugging. They may not be used in the interpreter.\n       *                   The new ones will be persisted after each run.\n       */\n      async function partitionExecutionResults(\n        originalHistory: HistoryStateEvent[],\n        executionGenerator: AsyncGenerator<WorkflowEvent, Result | undefined>\n      ) {\n        const updatedHistoryEvents: HistoryStateEvent[] = [];\n        const newWorkflowEvents: WorkflowEvent[] = [];\n        let resultEvent: WorkflowCompleted | WorkflowFailed | undefined =\n          undefined;\n        const seenEvents: Set<string> = new Set(\n          originalHistory.map(getEventId)\n        );\n\n        for await (const event of executionGenerator) {\n          const id = getEventId(event);\n          // newWorkflowEvents are the unique new events generated by this workflow execution.\n          if (!seenEvents.has(id)) {\n            newWorkflowEvents.push(event);\n            seenEvents.add(id);\n          }\n          if (isWorkflowCompleted(event) || isWorkflowFailed(event)) {\n            resultEvent = event;\n          }\n          // updatedHistoryEvents are all HistoryEvents old and new.\n          if (isWorkflowStarted(event) || isHistoryEvent(event)) {\n            updatedHistoryEvents.push(event);\n          }\n        }\n\n        return {\n          updatedHistoryEvents,\n          newEvents: newWorkflowEvents,\n          resultEvent,\n        };\n      }\n    }\n\n    async function loadHistory(): Promise<HistoryStateEvent[]> {\n      executionLogger.debug(\"Load history\");\n      // load history\n      const history = await timed(\n        metrics,\n        OrchestratorMetrics.LoadHistoryDuration,\n        async () => workflowRuntimeClient.getHistory(executionId)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.LoadedHistoryEvents,\n        history.length\n      );\n\n      return history;\n    }\n\n    /**\n     * Saves all new events generated by this execution to the {@link ExecutionHistoryClient}.\n     */\n    async function saveNewEventsToExecutionHistory(newEvents: WorkflowEvent[]) {\n      await timed(\n        metrics,\n        OrchestratorMetrics.AddNewExecutionEventsDuration,\n        () => executionHistoryClient.putEvents(executionId, newEvents)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.NewExecutionEvents,\n        newEvents.length\n      );\n    }\n\n    /**\n     * Saves all of the History Events (the ones the workflow uses) to s3.\n     *\n     * @param updatedHistoryEvents - The previous history plus task events minus any filtered events plus synthetic events.\n     * @param commandEvents - events produced by the commands run.\n     */\n    async function updateHistory(updatedHistoryEvents: HistoryStateEvent[]) {\n      console.debug(\n        \"New history to save\",\n        JSON.stringify(updatedHistoryEvents)\n      );\n\n      // update history from new commands and events\n      // for now, we'll just write the awaitable command events to s3 as those are the ones needed to reconstruct the workflow.\n      const { bytes: historyUpdatedBytes } = await timed(\n        metrics,\n        OrchestratorMetrics.SaveHistoryDuration,\n        () =>\n          workflowRuntimeClient.updateHistory({\n            executionId,\n            events: updatedHistoryEvents,\n          })\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.SavedHistoryEvents,\n        updatedHistoryEvents.length\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.SavedHistoryBytes,\n        historyUpdatedBytes,\n        Unit.Bytes\n      );\n    }\n\n    async function persistWorkflowResult(\n      resultEvent?: WorkflowCompleted | WorkflowFailed\n    ) {\n      // if the workflow is complete, add success and failure to the commands.\n      if (resultEvent) {\n        if (isWorkflowFailed(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.failExecution({\n                executionId,\n                error: resultEvent.error,\n                message: resultEvent.message,\n              })\n          );\n\n          logExecutionCompleteMetrics(execution);\n        } else if (isWorkflowCompleted(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.completeExecution({\n                executionId,\n                result: resultEvent.output,\n              })\n          );\n          logExecutionCompleteMetrics(execution);\n        }\n      }\n    }\n\n    /**\n     * Generate events from commands and create a function which will start the commands.\n     *\n     * Does not actually write the commands out.\n     */\n    async function processCommands(\n      commands: Command[]\n    ): Promise<HistoryStateEvent[]> {\n      console.debug(\"Commands to send\", JSON.stringify(commands));\n      // register command events\n      return await Promise.all(\n        commands.map((command) =>\n          commandExecutor.executeCommand(workflow, executionId, command, start)\n        )\n      );\n    }\n\n    function initializeMetrics() {\n      const metrics = metricsClient.createMetricsLogger();\n      metricsClient.createMetricsLogger();\n      metrics.resetDimensions(false);\n      metrics.setNamespace(MetricsCommon.EventualNamespace);\n      metrics.setDimensions({\n        [MetricsCommon.WorkflowNameDimension]: workflow.workflowName,\n      });\n      // number of events that came from the workflow task\n      metrics.setProperty(OrchestratorMetrics.TaskEvents, events.length);\n      // number of workflow tasks that are being processed in the batch (max: 10)\n      metrics.setProperty(OrchestratorMetrics.AggregatedTasks, events.length);\n\n      metrics.setProperty(OrchestratorMetrics.ExecutionId, executionId);\n      metrics.setProperty(\n        OrchestratorMetrics.Version,\n        OrchestratorMetrics.VersionV1\n      );\n      return metrics;\n    }\n\n    function logExecutionCompleteMetrics(\n      execution: CompleteExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.COMPLETE ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.COMPLETE ? 0 : 1,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionTotalDuration,\n        new Date(execution.endTime).getTime() -\n          new Date(execution.startTime).getTime()\n      );\n      if (isCompleteExecution(execution)) {\n        metrics.putMetric(\n          OrchestratorMetrics.ExecutionResultBytes,\n          execution.result ? JSON.stringify(execution.result).length : 0,\n          Unit.Bytes\n        );\n      }\n    }\n  }\n}\n\n/** Logs metrics specific to the incoming events */\nfunction logEventMetrics(\n  metrics: MetricsLogger,\n  events: WorkflowEvent[],\n  now: Date\n) {\n  const sleepCompletedEvents = events.filter(isSleepCompleted);\n  if (sleepCompletedEvents.length > 0) {\n    const sleepCompletedVariance = sleepCompletedEvents.map(\n      (s) => now.getTime() - new Date(s.timestamp).getTime()\n    );\n    const avg =\n      sleepCompletedVariance.reduce((t, n) => t + n, 0) /\n      sleepCompletedVariance.length;\n    metrics.setProperty(OrchestratorMetrics.SleepVarianceMillis, avg);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":"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","sourcesContent":["import { inspect } from \"util\";\nimport { Command } from \"../../command.js\";\nimport { WorkflowContext } from \"../../context.js\";\nimport {\n  createEvent,\n  getEventId,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isWorkflowCompleted,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowCompleted,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowTaskCompleted,\n  WorkflowTaskStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  CompleteExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isCompleteExecution,\n} from \"../../execution.js\";\nimport { isFailed, isResolved, isResult, Result } from \"../../result.js\";\nimport { lookupWorkflow, progressWorkflow, Workflow } from \"../../workflow.js\";\nimport {\n  EventClient,\n  ExecutionHistoryClient,\n  MetricsClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"../clients/index.js\";\nimport { CommandExecutor } from \"../command-executor.js\";\nimport { isExecutionId, parseWorkflowName } from \"../execution-id.js\";\nimport type { Logger } from \"../logger.js\";\nimport { MetricsCommon, OrchestratorMetrics } from \"../metrics/constants.js\";\nimport { MetricsLogger } from \"../metrics/metrics-logger.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed, timedSync } from \"../metrics/utils.js\";\nimport { promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\n\n/**\n * The Orchestrator's client dependencies.\n */\nexport interface OrchestratorDependencies {\n  executionHistoryClient: ExecutionHistoryClient;\n  timerClient: TimerClient;\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  workflowClient: WorkflowClient;\n  metricsClient: MetricsClient;\n  eventClient: EventClient;\n  logger: Logger;\n}\n\nexport interface OrchestratorResult {\n  /**\n   * IDs of the Executions that failed to orchestrate.\n   */\n  failedExecutionIds: string[];\n}\n\n/**\n * Creates a generic function for orchestrating a batch of executions\n * that can be used in runtime implementations. This implementation is\n * decoupled from a runtime's specifics by the clients. A runtime must\n * inject its own client implementations designed for that platform.\n */\nexport function createOrchestrator({\n  executionHistoryClient,\n  timerClient,\n  workflowRuntimeClient,\n  workflowClient,\n  metricsClient,\n  eventClient,\n  logger,\n}: OrchestratorDependencies): (\n  eventsByExecutionId: Record<string, HistoryStateEvent[]>\n) => Promise<OrchestratorResult> {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (eventsByExecutionId) => {\n    logger.debug(\"Handle workflowQueue records\");\n\n    logger.info(\n      \"Found execution ids: \" + Object.keys(eventsByExecutionId).join(\", \")\n    );\n\n    // for each execution id\n    const results = await promiseAllSettledPartitioned(\n      Object.entries(eventsByExecutionId),\n      async ([executionId, records]) => {\n        if (!isExecutionId(executionId)) {\n          throw new Error(`invalid ExecutionID: '${executionId}'`);\n        }\n        const workflowName = parseWorkflowName(executionId);\n        if (workflowName === undefined) {\n          throw new Error(`execution ID '${executionId}' does not exist`);\n        }\n        const workflow = lookupWorkflow(workflowName);\n        if (workflow === undefined) {\n          throw new Error(`no such workflow with name '${workflowName}'`);\n        }\n        // TODO: get workflow from execution id\n        return orchestrateExecution(workflow, executionId, records);\n      }\n    );\n\n    logger.debug(\n      \"Executions succeeded: \" +\n        results.fulfilled.map(([[executionId]]) => executionId).join(\",\")\n    );\n\n    if (results.rejected.length > 0) {\n      logger.error(\n        \"Executions failed: \\n\" +\n          results.rejected\n            .map(([[executionId], error]) => `${executionId}: ${error}`)\n            .join(\"\\n\")\n      );\n    }\n\n    return {\n      failedExecutionIds: results.rejected.map((rejected) => rejected[0][0]),\n    };\n  };\n\n  async function orchestrateExecution(\n    workflow: Workflow,\n    executionId: string,\n    events: HistoryStateEvent[]\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = new Date();\n    try {\n      // load\n      const history = await loadHistory();\n\n      // execute\n      const { updatedHistoryEvents, newEvents, resultEvent } =\n        await executeWorkflow(history);\n\n      // persist\n      await persistWorkflowResult(resultEvent);\n      await saveNewEventsToExecutionHistory(newEvents);\n      await updateHistory(updatedHistoryEvents);\n\n      // Only log these metrics once the orchestrator has completed successfully.\n      logEventMetrics(metrics, events, start);\n    } catch (err) {\n      executionLogger.error(inspect(err));\n      throw err;\n    } finally {\n      await metrics.flush();\n    }\n\n    /**\n     * Executes the workflow and returns the history and events to persist.\n     */\n    async function executeWorkflow(history: HistoryStateEvent[]) {\n      // length of time the oldest event in the queue.\n      const maxTaskAge = Math.max(\n        ...events.map(\n          (event) => new Date().getTime() - Date.parse(event.timestamp)\n        )\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.MaxTaskAge,\n        maxTaskAge,\n        Unit.Milliseconds\n      );\n\n      return partitionExecutionResults(history, executeWorkflowGenerator());\n\n      async function* executeWorkflowGenerator() {\n        yield createEvent<WorkflowTaskStarted>(\n          {\n            type: WorkflowEventType.WorkflowTaskStarted,\n          },\n          start\n        );\n\n        const workflowContext: WorkflowContext = {\n          name: workflow.workflowName,\n        };\n\n        const startEvent = history.find(isWorkflowStarted);\n\n        /**\n         * Check to see if this is the first run of the workflow (or all others have failed).\n         * If so, check to see if the workflow has timeout to start.\n         */\n        if (!startEvent) {\n          const newWorkflowStart = events.find(isWorkflowStarted);\n\n          if (newWorkflowStart?.timeoutTime) {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 1);\n            await timed(\n              metrics,\n              OrchestratorMetrics.TimeoutStartedDuration,\n              () =>\n                timerClient.scheduleEvent<WorkflowTimedOut>({\n                  schedule: Schedule.absolute(newWorkflowStart.timeoutTime!),\n                  event: createEvent<WorkflowTimedOut>({\n                    type: WorkflowEventType.WorkflowTimedOut,\n                  }),\n                  executionId,\n                })\n            );\n          } else {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 0);\n          }\n        }\n\n        const {\n          result,\n          commands: newCommands,\n          history: updatedHistoryEvents,\n        } = timedSync(\n          metrics,\n          OrchestratorMetrics.AdvanceExecutionDuration,\n          () => {\n            try {\n              return progressWorkflow(\n                workflow,\n                history,\n                events,\n                workflowContext,\n                executionId\n              );\n            } catch (err) {\n              console.log(\"workflow error\");\n              executionLogger.error(inspect(err));\n              throw err;\n            }\n          }\n        );\n\n        metrics.setProperty(\n          OrchestratorMetrics.AdvanceExecutionEvents,\n          updatedHistoryEvents.length\n        );\n\n        yield* updatedHistoryEvents;\n\n        executionLogger.debug(\n          \"Workflow terminated with: \" + JSON.stringify(result)\n        );\n\n        executionLogger.info(`Found ${newCommands.length} new commands.`);\n\n        yield* await timed(\n          metrics,\n          OrchestratorMetrics.InvokeCommandsDuration,\n          () => processCommands(newCommands)\n        );\n\n        metrics.putMetric(\n          OrchestratorMetrics.CommandsInvoked,\n          newCommands.length,\n          Unit.Count\n        );\n\n        // tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n        // This represent the workflow orchestration time of User Perceived Latency\n        // Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n        // AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n        metrics.putMetric(\n          OrchestratorMetrics.TimeToCommandsInvoked,\n          maxTaskAge + (new Date().getTime() - start.getTime())\n        );\n\n        yield createEvent<WorkflowTaskCompleted>({\n          type: WorkflowEventType.WorkflowTaskCompleted,\n        });\n\n        if (isResult(result)) {\n          if (isFailed(result)) {\n            const [error, message] = extendsError(result.error)\n              ? [result.error.name, result.error.message]\n              : [\"Error\", JSON.stringify(result.error)];\n            yield createEvent<WorkflowFailed>({\n              type: WorkflowEventType.WorkflowFailed,\n              error,\n              message,\n            });\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>({\n              type: WorkflowEventType.WorkflowCompleted,\n              output: result.value,\n            });\n          }\n        }\n\n        return result;\n      }\n\n      /**\n       * Partitions the events output by the workflow.\n       *\n       * We need two different collection of events.\n       *\n       * History Events - these are the events that workflow uses to maintain state.\n       *                  each run of the workflow we may filter or add events to this collection.\n       *                  these events will be persisted for the next run.\n       * Workflow Events - these are fined grained events emitted by the workflow. They drive UIs,\n       *                   visualization and debugging. They may not be used in the interpreter.\n       *                   The new ones will be persisted after each run.\n       */\n      async function partitionExecutionResults(\n        originalHistory: HistoryStateEvent[],\n        executionGenerator: AsyncGenerator<WorkflowEvent, Result | undefined>\n      ) {\n        const updatedHistoryEvents: HistoryStateEvent[] = [];\n        const newWorkflowEvents: WorkflowEvent[] = [];\n        let resultEvent: WorkflowCompleted | WorkflowFailed | undefined;\n        const seenEvents: Set<string> = new Set(\n          originalHistory.map(getEventId)\n        );\n\n        for await (const event of executionGenerator) {\n          const id = getEventId(event);\n          // newWorkflowEvents are the unique new events generated by this workflow execution.\n          if (!seenEvents.has(id)) {\n            newWorkflowEvents.push(event);\n            seenEvents.add(id);\n          }\n          if (isWorkflowCompleted(event) || isWorkflowFailed(event)) {\n            resultEvent = event;\n          }\n          // updatedHistoryEvents are all HistoryEvents old and new.\n          if (isWorkflowStarted(event) || isHistoryEvent(event)) {\n            updatedHistoryEvents.push(event);\n          }\n        }\n\n        return {\n          updatedHistoryEvents,\n          newEvents: newWorkflowEvents,\n          resultEvent,\n        };\n      }\n    }\n\n    async function loadHistory(): Promise<HistoryStateEvent[]> {\n      executionLogger.debug(\"Load history\");\n      // load history\n      const history = await timed(\n        metrics,\n        OrchestratorMetrics.LoadHistoryDuration,\n        async () => workflowRuntimeClient.getHistory(executionId)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.LoadedHistoryEvents,\n        history.length\n      );\n\n      return history;\n    }\n\n    /**\n     * Saves all new events generated by this execution to the {@link ExecutionHistoryClient}.\n     */\n    async function saveNewEventsToExecutionHistory(newEvents: WorkflowEvent[]) {\n      await timed(\n        metrics,\n        OrchestratorMetrics.AddNewExecutionEventsDuration,\n        () => executionHistoryClient.putEvents(executionId, newEvents)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.NewExecutionEvents,\n        newEvents.length\n      );\n    }\n\n    /**\n     * Saves all of the History Events (the ones the workflow uses) to s3.\n     *\n     * @param updatedHistoryEvents - The previous history plus task events minus any filtered events plus synthetic events.\n     * @param commandEvents - events produced by the commands run.\n     */\n    async function updateHistory(updatedHistoryEvents: HistoryStateEvent[]) {\n      console.debug(\n        \"New history to save\",\n        JSON.stringify(updatedHistoryEvents)\n      );\n\n      // update history from new commands and events\n      // for now, we'll just write the awaitable command events to s3 as those are the ones needed to reconstruct the workflow.\n      const { bytes: historyUpdatedBytes } = await timed(\n        metrics,\n        OrchestratorMetrics.SaveHistoryDuration,\n        () =>\n          workflowRuntimeClient.updateHistory({\n            executionId,\n            events: updatedHistoryEvents,\n          })\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.SavedHistoryEvents,\n        updatedHistoryEvents.length\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.SavedHistoryBytes,\n        historyUpdatedBytes,\n        Unit.Bytes\n      );\n    }\n\n    async function persistWorkflowResult(\n      resultEvent?: WorkflowCompleted | WorkflowFailed\n    ) {\n      // if the workflow is complete, add success and failure to the commands.\n      if (resultEvent) {\n        if (isWorkflowFailed(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.failExecution({\n                executionId,\n                error: resultEvent.error,\n                message: resultEvent.message,\n              })\n          );\n\n          logExecutionCompleteMetrics(execution);\n        } else if (isWorkflowCompleted(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.completeExecution({\n                executionId,\n                result: resultEvent.output,\n              })\n          );\n          logExecutionCompleteMetrics(execution);\n        }\n      }\n    }\n\n    /**\n     * Generate events from commands and create a function which will start the commands.\n     *\n     * Does not actually write the commands out.\n     */\n    async function processCommands(\n      commands: Command[]\n    ): Promise<HistoryStateEvent[]> {\n      console.debug(\"Commands to send\", JSON.stringify(commands));\n      // register command events\n      return await Promise.all(\n        commands.map((command) =>\n          commandExecutor.executeCommand(workflow, executionId, command, start)\n        )\n      );\n    }\n\n    function initializeMetrics() {\n      const metrics = metricsClient.createMetricsLogger();\n      metricsClient.createMetricsLogger();\n      metrics.resetDimensions(false);\n      metrics.setNamespace(MetricsCommon.EventualNamespace);\n      metrics.setDimensions({\n        [MetricsCommon.WorkflowNameDimension]: workflow.workflowName,\n      });\n      // number of events that came from the workflow task\n      metrics.setProperty(OrchestratorMetrics.TaskEvents, events.length);\n      // number of workflow tasks that are being processed in the batch (max: 10)\n      metrics.setProperty(OrchestratorMetrics.AggregatedTasks, events.length);\n\n      metrics.setProperty(OrchestratorMetrics.ExecutionId, executionId);\n      metrics.setProperty(\n        OrchestratorMetrics.Version,\n        OrchestratorMetrics.VersionV1\n      );\n      return metrics;\n    }\n\n    function logExecutionCompleteMetrics(\n      execution: CompleteExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.COMPLETE ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.COMPLETE ? 0 : 1,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionTotalDuration,\n        new Date(execution.endTime).getTime() -\n          new Date(execution.startTime).getTime()\n      );\n      if (isCompleteExecution(execution)) {\n        metrics.putMetric(\n          OrchestratorMetrics.ExecutionResultBytes,\n          execution.result ? JSON.stringify(execution.result).length : 0,\n          Unit.Bytes\n        );\n      }\n    }\n  }\n}\n\n/** Logs metrics specific to the incoming events */\nfunction logEventMetrics(\n  metrics: MetricsLogger,\n  events: WorkflowEvent[],\n  now: Date\n) {\n  const sleepCompletedEvents = events.filter(isSleepCompleted);\n  if (sleepCompletedEvents.length > 0) {\n    const sleepCompletedVariance = sleepCompletedEvents.map(\n      (s) => now.getTime() - new Date(s.timestamp).getTime()\n    );\n    const avg =\n      sleepCompletedVariance.reduce((t, n) => t + n, 0) /\n      sleepCompletedVariance.length;\n    metrics.setProperty(OrchestratorMetrics.SleepVarianceMillis, avg);\n  }\n}\n"]} |
"use strict"; | ||
Object.defineProperty(exports, "__esModule", { value: true }); | ||
exports.SchedulerForwarderMetrics = exports.ActivityMetrics = exports.OrchestratorMetrics = exports.MetricsCommon = void 0; | ||
/* eslint-disable @typescript-eslint/no-namespace */ | ||
var MetricsCommon; | ||
@@ -181,2 +182,2 @@ (function (MetricsCommon) { | ||
})(SchedulerForwarderMetrics = exports.SchedulerForwarderMetrics || (exports.SchedulerForwarderMetrics = {})); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/runtime/metrics/constants.ts"],"names":[],"mappings":"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","sourcesContent":["export namespace MetricsCommon {\n  export const EventualNamespace = \"Eventual\";\n  export const WorkflowNameDimension = \"WorkflowName\";\n}\n\nexport namespace OrchestratorMetrics {\n  /**\n   * Number of events which were delivered with the current batch of {@link WorkflowTask}s.\n   */\n  export const TaskEvents = \"TaskEvents\";\n  /**\n   * Number of workflow tasks being batch executed by the orchestrator for an execution id.\n   */\n  export const AggregatedTasks = \"AggregatedTasks\";\n  /**\n   * Execution ID of the {@link WorkflowTask}s being evaluated.\n   */\n  export const ExecutionId = \"ExecutionId\";\n  /**\n   * Version of the orchestrator.\n   */\n  export const Version = \"Version\";\n  export const VersionV1 = \"v1\";\n  /**\n   * The greatest amount of time a {@link WorkflowTask} being processed has waited in the Workflow Queue.\n   *\n   * Used to determine when the workflow queue is falling behind (maxTaskAge is growing).\n   */\n  export const MaxTaskAge = \"MaxTaskAge\";\n  /**\n   * The time it takes to load history data from S3.\n   */\n  export const LoadHistoryDuration = \"LoadHistoryDuration\";\n  /**\n   * The number of events present in the history file.\n   */\n  export const LoadedHistoryEvents = \"LoadedHistoryEvents\";\n  /**\n   * The amount of time it takes to run the workflow code to progress the {@link Execution}.\n   */\n  export const AdvanceExecutionDuration = \"AdvanceExecutionDuration\";\n  /**\n   * The number of events submitted to the workflow code to replay and advance the {@link Execution}.\n   */\n  export const AdvanceExecutionEvents = \"AdvanceExecutionEvents\";\n  /**\n   * The amount of time it takes to start all of the commands returned by the workflow code.\n   */\n  export const InvokeCommandsDuration = \"InvokeCommandsDuration\";\n  /**\n   * The number of commands returned by the workflow.\n   */\n  export const CommandsInvoked = \"CommandsInvoked\";\n  /**\n   * Tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n   * This represent the workflow orchestration time of User Perceived Latency\n   * Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n   * AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n   */\n  export const TimeToCommandsInvoked = \"TimeToCommandsInvoked\";\n  /**\n   * Amount of time it takes to write history back to s3.\n   */\n  export const SaveHistoryDuration = \"SaveHistoryDuration\";\n  /**\n   * Number of events written to s3.\n   */\n  export const SavedHistoryEvents = \"SavedHistoryEvents\";\n  /**\n   * Size of the history fle written in bytes.\n   */\n  export const SavedHistoryBytes = \"SavedHistoryBytes\";\n  /**\n   * Amount of time it takes to update the workflow entry with a Complete or Failed status.\n   */\n  export const ExecutionStatusUpdateDuration = \"ExecutionStatusUpdateDuration\";\n  /**\n   * Amount of time it take to add newly generated events to dynamo.\n   */\n  export const AddNewExecutionEventsDuration = \"AddNewExecutionEventsDuration\";\n  /**\n   * Number of new events generated evaluating the current Workflow Tasks batch.\n   */\n  export const NewExecutionEvents = \"NewExecutionEvents\";\n  /**\n   * Whether the execution completed without error.\n   */\n  export const ExecutionComplete = \"ExecutionComplete\";\n  /**\n   * Whether the execution completed with an error.\n   */\n  export const ExecutionFailed = \"ExecutionFailed\";\n  /**\n   * Total time it took the workflow to complete.\n   */\n  export const ExecutionTotalDuration = \"ExecutionTotalDuration\";\n  /**\n   * The size of the workflow result in bytes.\n   */\n  export const ExecutionResultBytes = \"ExecutionResultBytes\";\n  /**\n   * Number of milliseconds between the expected sleep wakeup time and the actual incoming {@link SleepCompleted} event.\n   */\n  export const SleepVarianceMillis = \"SleepVarianceMillis\";\n  /**\n   * 1 when a workflow has a timeout and 0 when it does not.\n   */\n  export const TimeoutStarted = \"TimeoutStarted\";\n  /**\n   * When a workflow has a timeout, measures the time it takes to start the timeout.\n   */\n  export const TimeoutStartedDuration = \"TimeoutStartedDuration\";\n}\n\nexport namespace ActivityMetrics {\n  /**\n   * The age of the request, or the time from when it was sent to when it was started processing.\n   */\n  export const ActivityRequestAge = \"ActivityRequestAge\";\n  /**\n   * The amount of time it took to claim (lock) the activity to enforce exactly once processing.\n   */\n  export const ClaimDuration = \"ClaimDuration\";\n  /**\n   * Whether this activity invocation was rejected when claiming the activity.\n   */\n  export const ClaimRejected = \"ClaimRejected\";\n  /**\n   * Whether an error was thrown that the activity name could not be found.\n   */\n  export const NotFoundError = \"NotFoundError\";\n  /**\n   * The amount of time it took to run the activity's code.\n   */\n  export const OperationDuration = \"OperationDuration\";\n  /**\n   * Whether this activity returned a result or not on completion.\n   */\n  export const HasResult = \"HasResult\";\n  /**\n   * Returned {@link asyncResult}.\n   */\n  export const AsyncResult = \"AsyncResult\";\n  /**\n   * The size in bytes of the result generated by the activity, if one was generated.\n   */\n  export const ResultBytes = \"ResultBytes\";\n  /**\n   * Whether the activity completed with errors.\n   */\n  export const ActivityFailed = \"ActivityFailed\";\n  /**\n   * Whether the activity completed without error.\n   */\n  export const ActivityCompleted = \"ActivityCompleted\";\n  /**\n   * The total duration of the activity after being scheduled, including the time\n   * waiting to be executed.\n   */\n  export const TotalDuration = \"TotalDuration\";\n  /**\n   * amount of time it took to submit a workflow task to SQS to resume the workflow.\n   */\n  export const SubmitWorkflowTaskDuration = \"SubmitWorkflowTaskDuration\";\n}\n\nexport namespace SchedulerForwarderMetrics {\n  /**\n   * The time between the scheduler trigger time and the Scheduler Forwarder seeing the message.\n   */\n  export const SchedulerTimeDelay = \"SchedulerTimeDelay\";\n  /**\n   * Seconds the timer queue is told to wait until handling the request.\n   */\n  export const TimerQueueDelaySeconds = \"TimerQueueDelaySeconds\";\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/runtime/metrics/constants.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\nexport namespace MetricsCommon {\n  export const EventualNamespace = \"Eventual\";\n  export const WorkflowNameDimension = \"WorkflowName\";\n}\n\nexport namespace OrchestratorMetrics {\n  /**\n   * Number of events which were delivered with the current batch of {@link WorkflowTask}s.\n   */\n  export const TaskEvents = \"TaskEvents\";\n  /**\n   * Number of workflow tasks being batch executed by the orchestrator for an execution id.\n   */\n  export const AggregatedTasks = \"AggregatedTasks\";\n  /**\n   * Execution ID of the {@link WorkflowTask}s being evaluated.\n   */\n  export const ExecutionId = \"ExecutionId\";\n  /**\n   * Version of the orchestrator.\n   */\n  export const Version = \"Version\";\n  export const VersionV1 = \"v1\";\n  /**\n   * The greatest amount of time a {@link WorkflowTask} being processed has waited in the Workflow Queue.\n   *\n   * Used to determine when the workflow queue is falling behind (maxTaskAge is growing).\n   */\n  export const MaxTaskAge = \"MaxTaskAge\";\n  /**\n   * The time it takes to load history data from S3.\n   */\n  export const LoadHistoryDuration = \"LoadHistoryDuration\";\n  /**\n   * The number of events present in the history file.\n   */\n  export const LoadedHistoryEvents = \"LoadedHistoryEvents\";\n  /**\n   * The amount of time it takes to run the workflow code to progress the {@link Execution}.\n   */\n  export const AdvanceExecutionDuration = \"AdvanceExecutionDuration\";\n  /**\n   * The number of events submitted to the workflow code to replay and advance the {@link Execution}.\n   */\n  export const AdvanceExecutionEvents = \"AdvanceExecutionEvents\";\n  /**\n   * The amount of time it takes to start all of the commands returned by the workflow code.\n   */\n  export const InvokeCommandsDuration = \"InvokeCommandsDuration\";\n  /**\n   * The number of commands returned by the workflow.\n   */\n  export const CommandsInvoked = \"CommandsInvoked\";\n  /**\n   * Tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n   * This represent the workflow orchestration time of User Perceived Latency\n   * Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n   * AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n   */\n  export const TimeToCommandsInvoked = \"TimeToCommandsInvoked\";\n  /**\n   * Amount of time it takes to write history back to s3.\n   */\n  export const SaveHistoryDuration = \"SaveHistoryDuration\";\n  /**\n   * Number of events written to s3.\n   */\n  export const SavedHistoryEvents = \"SavedHistoryEvents\";\n  /**\n   * Size of the history fle written in bytes.\n   */\n  export const SavedHistoryBytes = \"SavedHistoryBytes\";\n  /**\n   * Amount of time it takes to update the workflow entry with a Complete or Failed status.\n   */\n  export const ExecutionStatusUpdateDuration = \"ExecutionStatusUpdateDuration\";\n  /**\n   * Amount of time it take to add newly generated events to dynamo.\n   */\n  export const AddNewExecutionEventsDuration = \"AddNewExecutionEventsDuration\";\n  /**\n   * Number of new events generated evaluating the current Workflow Tasks batch.\n   */\n  export const NewExecutionEvents = \"NewExecutionEvents\";\n  /**\n   * Whether the execution completed without error.\n   */\n  export const ExecutionComplete = \"ExecutionComplete\";\n  /**\n   * Whether the execution completed with an error.\n   */\n  export const ExecutionFailed = \"ExecutionFailed\";\n  /**\n   * Total time it took the workflow to complete.\n   */\n  export const ExecutionTotalDuration = \"ExecutionTotalDuration\";\n  /**\n   * The size of the workflow result in bytes.\n   */\n  export const ExecutionResultBytes = \"ExecutionResultBytes\";\n  /**\n   * Number of milliseconds between the expected sleep wakeup time and the actual incoming {@link SleepCompleted} event.\n   */\n  export const SleepVarianceMillis = \"SleepVarianceMillis\";\n  /**\n   * 1 when a workflow has a timeout and 0 when it does not.\n   */\n  export const TimeoutStarted = \"TimeoutStarted\";\n  /**\n   * When a workflow has a timeout, measures the time it takes to start the timeout.\n   */\n  export const TimeoutStartedDuration = \"TimeoutStartedDuration\";\n}\n\nexport namespace ActivityMetrics {\n  /**\n   * The age of the request, or the time from when it was sent to when it was started processing.\n   */\n  export const ActivityRequestAge = \"ActivityRequestAge\";\n  /**\n   * The amount of time it took to claim (lock) the activity to enforce exactly once processing.\n   */\n  export const ClaimDuration = \"ClaimDuration\";\n  /**\n   * Whether this activity invocation was rejected when claiming the activity.\n   */\n  export const ClaimRejected = \"ClaimRejected\";\n  /**\n   * Whether an error was thrown that the activity name could not be found.\n   */\n  export const NotFoundError = \"NotFoundError\";\n  /**\n   * The amount of time it took to run the activity's code.\n   */\n  export const OperationDuration = \"OperationDuration\";\n  /**\n   * Whether this activity returned a result or not on completion.\n   */\n  export const HasResult = \"HasResult\";\n  /**\n   * Returned {@link asyncResult}.\n   */\n  export const AsyncResult = \"AsyncResult\";\n  /**\n   * The size in bytes of the result generated by the activity, if one was generated.\n   */\n  export const ResultBytes = \"ResultBytes\";\n  /**\n   * Whether the activity completed with errors.\n   */\n  export const ActivityFailed = \"ActivityFailed\";\n  /**\n   * Whether the activity completed without error.\n   */\n  export const ActivityCompleted = \"ActivityCompleted\";\n  /**\n   * The total duration of the activity after being scheduled, including the time\n   * waiting to be executed.\n   */\n  export const TotalDuration = \"TotalDuration\";\n  /**\n   * amount of time it took to submit a workflow task to SQS to resume the workflow.\n   */\n  export const SubmitWorkflowTaskDuration = \"SubmitWorkflowTaskDuration\";\n}\n\nexport namespace SchedulerForwarderMetrics {\n  /**\n   * The time between the scheduler trigger time and the Scheduler Forwarder seeing the message.\n   */\n  export const SchedulerTimeDelay = \"SchedulerTimeDelay\";\n  /**\n   * Seconds the timer queue is told to wait until handling the request.\n   */\n  export const TimerQueueDelaySeconds = \"TimerQueueDelaySeconds\";\n}\n"]} |
@@ -34,3 +34,3 @@ export interface Secret<T> { | ||
#private; | ||
readonly cachingConfig: CachingConfig; | ||
private readonly cachingConfig; | ||
constructor(cachingConfig?: CachingConfig); | ||
@@ -37,0 +37,0 @@ /** |
@@ -72,2 +72,2 @@ "use strict"; | ||
exports.JsonSecret = JsonSecret; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFJQTs7Ozs7R0FLRztBQUNILE1BQWEsZUFBZTtJQUMxQixZQUFxQixLQUFRO1FBQVIsVUFBSyxHQUFMLEtBQUssQ0FBRztJQUFHLENBQUM7SUFFMUIsU0FBUztRQUNkLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQztDQUNGO0FBTkQsMENBTUM7QUFpQkQ7O0dBRUc7QUFDSCxNQUFzQixpQkFBaUI7SUFVckMsWUFBWSxhQUE2QjtRQVB6QywyQ0FLYztRQUdaLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxJQUFJO1lBQ3BDLE9BQU8sRUFBRSxJQUFJO1lBQ2IsR0FBRyxFQUFFLFNBQVM7U0FDZixDQUFDO0lBQ0osQ0FBQztJQU9NLEtBQUssQ0FBQyxTQUFTLENBQUMsU0FBZ0I7UUFDckMsSUFDRSx1QkFBQSxJQUFJLGdDQUFPLEtBQUssU0FBUztZQUN6QixTQUFTO1lBQ1QsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU87WUFDM0IsQ0FBQyx1QkFBQSxJQUFJLGdDQUFPO2dCQUNWLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxLQUFLLFNBQVM7Z0JBQ3BDLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsdUJBQUEsSUFBSSxnQ0FBTyxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUU7b0JBQ3RELElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLEVBQzNCO1lBQ0EsdUJBQUEsSUFBSSw0QkFBVTtnQkFDWixLQUFLLEVBQUUsTUFBTSxJQUFJLENBQUMsY0FBYyxFQUFFO2dCQUNsQyxXQUFXLEVBQUUsSUFBSSxJQUFJLEVBQUU7YUFDeEIsTUFBQSxDQUFDO1NBQ0g7UUFDRCxPQUFPLHVCQUFBLElBQUksZ0NBQU8sQ0FBQyxLQUFLLENBQUM7SUFDM0IsQ0FBQztDQUNGO0FBdkNELDhDQXVDQzs7QUFFRDs7R0FFRztBQUNILE1BQWEsVUFBVTtJQUNyQixZQUFxQixNQUFzQjtRQUF0QixXQUFNLEdBQU4sTUFBTSxDQUFnQjtJQUFHLENBQUM7SUFFeEMsS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7Q0FDRjtBQU5ELGdDQU1DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBTZWNyZXQ8VD4ge1xuICBnZXRTZWNyZXQoKTogUHJvbWlzZTxUPjtcbn1cblxuLyoqXG4gKiBBIHtAbGluayBTZWNyZXR9IGltcGxlbWVudGF0aW9uIHRoYXQgc3RvcmVzIHRoZSBzZWNyZXQgaGFyZC1jb2RlZCBpbiBwbGFpbiB0ZXh0LlxuICpcbiAqIFRoaXMgaXMgYW4gaW5zZWN1cmUgQVBJIGFuZCBzaG91bGQgb25seSBiZSB1c2VkIHdoZW4gc2FmZSwgc3VjaCBhcyBpbiBhIGRldlxuICogZW52aXJvbm1lbnQuXG4gKi9cbmV4cG9ydCBjbGFzcyBQbGFpblRleHRTZWNyZXQ8VCA9IHN0cmluZz4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSB2YWx1ZTogVCkge31cblxuICBwdWJsaWMgZ2V0U2VjcmV0KCkge1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUodGhpcy52YWx1ZSk7XG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBDYWNoaW5nQ29uZmlnIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgY2FjaGluZyBpcyBlbmFibGVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICBlbmFibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIE51bWJlciBvZiBtaWxsaXNlY29uZHMgdG8gY2FjaGUgdGhlIHNlY3JldCB2YWx1ZSBmb3IuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gVFRMLCBhbGwgdmFsdWVzIGFyZSBjYWNoZWQgaW5kZWZpbml0ZWx5XG4gICAqL1xuICB0dGw/OiBudW1iZXI7XG59XG5cbi8qKlxuICogQSBiYXNlIGltcGxlbWVudGF0aW9uIG9mIGEge0BsaW5rIFNlY3JldH0gdGhhdCBzdXBwb3J0cyBjYWNoaW5nLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUNhY2hpbmdTZWNyZXQ8VD4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICByZWFkb25seSBjYWNoaW5nQ29uZmlnOiBDYWNoaW5nQ29uZmlnO1xuXG4gICN2YWx1ZTpcbiAgICB8IHtcbiAgICAgICAgdmFsdWU6IFQ7XG4gICAgICAgIHJlZnJlc2hUaW1lOiBEYXRlO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKGNhY2hpbmdDb25maWc/OiBDYWNoaW5nQ29uZmlnKSB7XG4gICAgdGhpcy5jYWNoaW5nQ29uZmlnID0gY2FjaGluZ0NvbmZpZyA/PyB7XG4gICAgICBlbmFibGVkOiB0cnVlLFxuICAgICAgdHRsOiB1bmRlZmluZWQsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIGEgZnJlc2ggdmVyc2lvbiBvZiB0aGUgc2VjcmV0IGZyb20gdGhlIHJlbW90ZSBzdG9yZS5cbiAgICovXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXRGcmVzaFNlY3JldCgpOiBQcm9taXNlPFQ+O1xuXG4gIHB1YmxpYyBhc3luYyBnZXRTZWNyZXQoYnVzdENhY2hlPzogdHJ1ZSk6IFByb21pc2U8VD4ge1xuICAgIGlmIChcbiAgICAgIHRoaXMuI3ZhbHVlID09PSB1bmRlZmluZWQgfHxcbiAgICAgIGJ1c3RDYWNoZSB8fFxuICAgICAgIXRoaXMuY2FjaGluZ0NvbmZpZy5lbmFibGVkIHx8XG4gICAgICAodGhpcy4jdmFsdWUgJiZcbiAgICAgICAgdGhpcy5jYWNoaW5nQ29uZmlnLnR0bCAhPT0gdW5kZWZpbmVkICYmXG4gICAgICAgIG5ldyBEYXRlKCkuZ2V0VGltZSgpIC0gdGhpcy4jdmFsdWUucmVmcmVzaFRpbWUuZ2V0VGltZSgpID5cbiAgICAgICAgICB0aGlzLmNhY2hpbmdDb25maWcudHRsKVxuICAgICkge1xuICAgICAgdGhpcy4jdmFsdWUgPSB7XG4gICAgICAgIHZhbHVlOiBhd2FpdCB0aGlzLmdldEZyZXNoU2VjcmV0KCksXG4gICAgICAgIHJlZnJlc2hUaW1lOiBuZXcgRGF0ZSgpLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuI3ZhbHVlLnZhbHVlO1xuICB9XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU2VjcmV0fSBwYXJzZWQgZnJvbSAgSlNPTi5cbiAqL1xuZXhwb3J0IGNsYXNzIEpzb25TZWNyZXQ8VD4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSBzZWNyZXQ6IFNlY3JldDxzdHJpbmc+KSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRTZWNyZXQoKTogUHJvbWlzZTxUPiB7XG4gICAgcmV0dXJuIEpTT04ucGFyc2UoYXdhaXQgdGhpcy5zZWNyZXQuZ2V0U2VjcmV0KCkpO1xuICB9XG59XG4iXX0= | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7QUFJQTs7Ozs7R0FLRztBQUNILE1BQWEsZUFBZTtJQUMxQixZQUFxQixLQUFRO1FBQVIsVUFBSyxHQUFMLEtBQUssQ0FBRztJQUFHLENBQUM7SUFFMUIsU0FBUztRQUNkLE9BQU8sT0FBTyxDQUFDLE9BQU8sQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFDckMsQ0FBQztDQUNGO0FBTkQsMENBTUM7QUFpQkQ7O0dBRUc7QUFDSCxNQUFzQixpQkFBaUI7SUFVckMsWUFBWSxhQUE2QjtRQVB6QywyQ0FLYztRQUdaLElBQUksQ0FBQyxhQUFhLEdBQUcsYUFBYSxJQUFJO1lBQ3BDLE9BQU8sRUFBRSxJQUFJO1lBQ2IsR0FBRyxFQUFFLFNBQVM7U0FDZixDQUFDO0lBQ0osQ0FBQztJQU9NLEtBQUssQ0FBQyxTQUFTLENBQUMsU0FBZ0I7UUFDckMsSUFDRSx1QkFBQSxJQUFJLGdDQUFPLEtBQUssU0FBUztZQUN6QixTQUFTO1lBQ1QsQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLE9BQU87WUFDM0IsQ0FBQyx1QkFBQSxJQUFJLGdDQUFPO2dCQUNWLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxLQUFLLFNBQVM7Z0JBQ3BDLElBQUksSUFBSSxFQUFFLENBQUMsT0FBTyxFQUFFLEdBQUcsdUJBQUEsSUFBSSxnQ0FBTyxDQUFDLFdBQVcsQ0FBQyxPQUFPLEVBQUU7b0JBQ3RELElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLEVBQzNCO1lBQ0EsdUJBQUEsSUFBSSw0QkFBVTtnQkFDWixLQUFLLEVBQUUsTUFBTSxJQUFJLENBQUMsY0FBYyxFQUFFO2dCQUNsQyxXQUFXLEVBQUUsSUFBSSxJQUFJLEVBQUU7YUFDeEIsTUFBQSxDQUFDO1NBQ0g7UUFDRCxPQUFPLHVCQUFBLElBQUksZ0NBQU8sQ0FBQyxLQUFLLENBQUM7SUFDM0IsQ0FBQztDQUNGO0FBdkNELDhDQXVDQzs7QUFFRDs7R0FFRztBQUNILE1BQWEsVUFBVTtJQUNyQixZQUFxQixNQUFzQjtRQUF0QixXQUFNLEdBQU4sTUFBTSxDQUFnQjtJQUFHLENBQUM7SUFFeEMsS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7Q0FDRjtBQU5ELGdDQU1DIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBTZWNyZXQ8VD4ge1xuICBnZXRTZWNyZXQoKTogUHJvbWlzZTxUPjtcbn1cblxuLyoqXG4gKiBBIHtAbGluayBTZWNyZXR9IGltcGxlbWVudGF0aW9uIHRoYXQgc3RvcmVzIHRoZSBzZWNyZXQgaGFyZC1jb2RlZCBpbiBwbGFpbiB0ZXh0LlxuICpcbiAqIFRoaXMgaXMgYW4gaW5zZWN1cmUgQVBJIGFuZCBzaG91bGQgb25seSBiZSB1c2VkIHdoZW4gc2FmZSwgc3VjaCBhcyBpbiBhIGRldlxuICogZW52aXJvbm1lbnQuXG4gKi9cbmV4cG9ydCBjbGFzcyBQbGFpblRleHRTZWNyZXQ8VCA9IHN0cmluZz4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSB2YWx1ZTogVCkge31cblxuICBwdWJsaWMgZ2V0U2VjcmV0KCkge1xuICAgIHJldHVybiBQcm9taXNlLnJlc29sdmUodGhpcy52YWx1ZSk7XG4gIH1cbn1cblxuZXhwb3J0IGludGVyZmFjZSBDYWNoaW5nQ29uZmlnIHtcbiAgLyoqXG4gICAqIFdoZXRoZXIgY2FjaGluZyBpcyBlbmFibGVkLlxuICAgKlxuICAgKiBAZGVmYXVsdCB0cnVlXG4gICAqL1xuICBlbmFibGVkPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIE51bWJlciBvZiBtaWxsaXNlY29uZHMgdG8gY2FjaGUgdGhlIHNlY3JldCB2YWx1ZSBmb3IuXG4gICAqXG4gICAqIEBkZWZhdWx0IC0gbm8gVFRMLCBhbGwgdmFsdWVzIGFyZSBjYWNoZWQgaW5kZWZpbml0ZWx5XG4gICAqL1xuICB0dGw/OiBudW1iZXI7XG59XG5cbi8qKlxuICogQSBiYXNlIGltcGxlbWVudGF0aW9uIG9mIGEge0BsaW5rIFNlY3JldH0gdGhhdCBzdXBwb3J0cyBjYWNoaW5nLlxuICovXG5leHBvcnQgYWJzdHJhY3QgY2xhc3MgQmFzZUNhY2hpbmdTZWNyZXQ8VD4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICBwcml2YXRlIHJlYWRvbmx5IGNhY2hpbmdDb25maWc6IENhY2hpbmdDb25maWc7XG5cbiAgI3ZhbHVlOlxuICAgIHwge1xuICAgICAgICB2YWx1ZTogVDtcbiAgICAgICAgcmVmcmVzaFRpbWU6IERhdGU7XG4gICAgICB9XG4gICAgfCB1bmRlZmluZWQ7XG5cbiAgY29uc3RydWN0b3IoY2FjaGluZ0NvbmZpZz86IENhY2hpbmdDb25maWcpIHtcbiAgICB0aGlzLmNhY2hpbmdDb25maWcgPSBjYWNoaW5nQ29uZmlnID8/IHtcbiAgICAgIGVuYWJsZWQ6IHRydWUsXG4gICAgICB0dGw6IHVuZGVmaW5lZCxcbiAgICB9O1xuICB9XG5cbiAgLyoqXG4gICAqIEdldHMgYSBmcmVzaCB2ZXJzaW9uIG9mIHRoZSBzZWNyZXQgZnJvbSB0aGUgcmVtb3RlIHN0b3JlLlxuICAgKi9cbiAgcHJvdGVjdGVkIGFic3RyYWN0IGdldEZyZXNoU2VjcmV0KCk6IFByb21pc2U8VD47XG5cbiAgcHVibGljIGFzeW5jIGdldFNlY3JldChidXN0Q2FjaGU/OiB0cnVlKTogUHJvbWlzZTxUPiB7XG4gICAgaWYgKFxuICAgICAgdGhpcy4jdmFsdWUgPT09IHVuZGVmaW5lZCB8fFxuICAgICAgYnVzdENhY2hlIHx8XG4gICAgICAhdGhpcy5jYWNoaW5nQ29uZmlnLmVuYWJsZWQgfHxcbiAgICAgICh0aGlzLiN2YWx1ZSAmJlxuICAgICAgICB0aGlzLmNhY2hpbmdDb25maWcudHRsICE9PSB1bmRlZmluZWQgJiZcbiAgICAgICAgbmV3IERhdGUoKS5nZXRUaW1lKCkgLSB0aGlzLiN2YWx1ZS5yZWZyZXNoVGltZS5nZXRUaW1lKCkgPlxuICAgICAgICAgIHRoaXMuY2FjaGluZ0NvbmZpZy50dGwpXG4gICAgKSB7XG4gICAgICB0aGlzLiN2YWx1ZSA9IHtcbiAgICAgICAgdmFsdWU6IGF3YWl0IHRoaXMuZ2V0RnJlc2hTZWNyZXQoKSxcbiAgICAgICAgcmVmcmVzaFRpbWU6IG5ldyBEYXRlKCksXG4gICAgICB9O1xuICAgIH1cbiAgICByZXR1cm4gdGhpcy4jdmFsdWUudmFsdWU7XG4gIH1cbn1cblxuLyoqXG4gKiBBIHtAbGluayBTZWNyZXR9IHBhcnNlZCBmcm9tICBKU09OLlxuICovXG5leHBvcnQgY2xhc3MgSnNvblNlY3JldDxUPiBpbXBsZW1lbnRzIFNlY3JldDxUPiB7XG4gIGNvbnN0cnVjdG9yKHJlYWRvbmx5IHNlY3JldDogU2VjcmV0PHN0cmluZz4pIHt9XG5cbiAgcHVibGljIGFzeW5jIGdldFNlY3JldCgpOiBQcm9taXNlPFQ+IHtcbiAgICByZXR1cm4gSlNPTi5wYXJzZShhd2FpdCB0aGlzLnNlY3JldC5nZXRTZWNyZXQoKSk7XG4gIH1cbn1cbiJdfQ== |
@@ -141,2 +141,2 @@ "use strict"; | ||
exports.isExecutionTarget = isExecutionTarget; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":";;;AAAA,qEAAmE;AACnE,2EAAiF;AACjF,yEAAuE;AACvE,iDAA0D;AAC1D,2CAAgD;AAChD,iCAA6B;AAkB7B,SAAgB,MAAM,CAAiB,IAAY;IACjD,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAFD,wBAEC;AAED,MAAa,MAAM;IACjB,YAA4B,EAAU;QAAV,OAAE,GAAF,EAAE,CAAQ;IAAG,CAAC;IAC1C;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BG;IACH,EAAE,CAAC,OAAuC;QACxC,OAAO,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjC,CAAC;IACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACH,MAAM,CAAC,IAA0B;QAC/B,OAAO,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IACD;;;;;;;;;OASG;IACH,IAAI,CAAC,WAAmB,EAAE,GAAG,IAA8B;QACzD,OAAO,UAAU,CAAkB,WAAW,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACjE,CAAC;CACF;AAlFD,wBAkFC;AAuCD,SAAgB,YAAY,CAC1B,MAA4B,EAC5B,IAA0B;IAE1B,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;KAC7D;IAED,OAAO,IAAA,8CAAsB,EAC3B,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,IAAI,EAAE,cAAc,CACd,CAAC;AACX,CAAC;AAZD,oCAYC;AAuCD,SAAgB,QAAQ,CACtB,MAA4B,EAC5B,OAAmC;IAEnC,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IAED,OAAO,IAAA,wDAA+B,EACpC,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAc,CACf,CAAC;AACJ,CAAC;AAZD,4BAYC;AA+BD,SAAgB,UAAU,CACxB,WAAmB,EACnB,MAA4B,EAC5B,OAAa,EACb,EAAW;IAEX,IAAI,IAAA,+BAAoB,GAAE,EAAE;QAC1B,OAAO,IAAA,0CAAoB,EACzB,EAAE,IAAI,EAAE,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,EACjD,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAO,CACU,CAAC;KACrB;SAAM;QACL,OAAO,IAAA,6BAAiB,GAAE,CAAC,UAAU,CAAC;YACpC,WAAW;YACX,MAAM;YACN,EAAE,EAAE,EAAE,IAAI,IAAA,YAAI,GAAE;YAChB,OAAO;SACR,CAAC,CAAC;KACJ;AACH,CAAC;AApBD,gCAoBC;AAID,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,iEAAS,CAAA;IACT,2EAAc,CAAA;AAChB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B;AAaD,SAAgB,sBAAsB,CACpC,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,cAAc,CAAC;AACzD,CAAC;AAJD,wDAIC;AAED,SAAgB,iBAAiB,CAC/B,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,CAAC;AACpD,CAAC;AAJD,8CAIC","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(public readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = new Signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.on(async () => {\n   *       await sleepFor(10);\n   *       done = true;\n   *    });\n   *\n   *    await condition(() => done);\n   * });\n   * ```\n   *\n   * To remove the handler, call the dispose method.\n   *\n   * ```ts\n   * const handler = mySignal.on(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  on(handler: SignalHandlerFunction<Payload>): SignalsHandler {\n    return onSignal(this, handler);\n  }\n  /**\n   * Waits for a signal to be received by the workflow.\n   *\n   * The first signal received will resolve the Promise with the payload of the promise.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expect();\n   *\n   *    return payload;\n   * });\n   * ```\n   *\n   * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n   * when the provided time has elapsed.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  expect(opts?: ExpectSignalOptions): Promise<Payload> {\n    return expectSignal(this, opts);\n  }\n  /**\n   * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.send(\"payload\");\n   * })\n   * ```\n   */\n  send(executionId: string, ...args: SendSignalProps<Payload>): Promise<void> {\n    return sendSignal<Signal<Payload>>(executionId, this, ...args);\n  }\n}\n\nexport type SignalPayload<E extends Signal<any>> = E extends Signal<infer P>\n  ? P\n  : never;\n\nexport interface ExpectSignalOptions {\n  /**\n   * Optional. Seconds to wait for the signal to be received.\n   *\n   * After the provided seconds, the promise will reject.\n   */\n  timeoutSeconds: number;\n}\n\n/**\n * Waits for a signal to be received by the workflow.\n *\n * The first signal received will resolve the Promise with the payload of the promise.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    const payload = await expectSignal(\"MySignal\");\n *\n *    return payload;\n * });\n * ```\n *\n * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n * when the provided time has elapsed.\n */\nexport function expectSignal<SignalPayload = any>(\n  signalId: string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload>;\nexport function expectSignal<E extends Signal<any>>(\n  signal: E,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<E>>;\nexport function expectSignal(\n  signal: Signal<any> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<any>> {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"expectSignal is only valid in a workflow\");\n  }\n\n  return createExpectSignalCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    opts?.timeoutSeconds\n  ) as any;\n}\n\n/**\n * Listens for a signal matching the signalId provided.\n *\n * When the signal is received, the handler is invoked.\n * If the handler return a promise, the handler is added as a {@link Chain}\n * and progressed until completion.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    let done = false;\n *    onSignal(\"MySignal\", async () => {\n *       await sleepFor(10);\n *       done = true;\n *    });\n *\n *    await condition(() => done);\n * });\n * ```\n *\n * To remove the handler, call the dispose method.\n *\n * ```ts\n * const handler = onSignal(\"MySignal\", () => {});\n *\n * await sleepFor(10);\n *\n * handler.dispose();\n * ```\n */\nexport function onSignal<E extends Signal<any>>(\n  signal: E,\n  handler: SignalHandlerFunction<SignalPayload<E>>\n): SignalsHandler;\nexport function onSignal<Payload = void>(\n  signalId: string,\n  handler: SignalHandlerFunction<Payload>\n): SignalsHandler;\nexport function onSignal(\n  signal: Signal<any> | string,\n  handler: SignalHandlerFunction<any>\n): SignalsHandler {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"onSignal is only valid in a workflow\");\n  }\n\n  return createRegisterSignalHandlerCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    handler as any\n  );\n}\n\nexport type SendSignalProps<SignalPayload> = [SignalPayload] extends\n  | [undefined]\n  | [void]\n  ? [id?: string]\n  : [payload: SignalPayload, id?: string];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = new Signal<string>(\"MySignal\");\n * workflow(\"wf\", async () => {\n *    sendSignal(\"mySignal\", \"payload\");\n *    sendSignal(mySignal, \"payload\");\n * })\n * ```\n *\n * @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.\n */\nexport function sendSignal<S extends Signal<any>>(\n  executionId: string,\n  signal: S,\n  ...args: SendSignalProps<SignalPayload<S>>\n): Promise<void>;\nexport function sendSignal<Payload = any>(\n  executionId: string,\n  signalId: string,\n  ...args: SendSignalProps<Payload>\n): Promise<void>;\nexport function sendSignal(\n  executionId: string,\n  signal: string | Signal<any>,\n  payload?: any,\n  id?: string\n): Promise<void> {\n  if (isOrchestratorWorker()) {\n    return createSendSignalCall(\n      { type: SignalTargetType.Execution, executionId },\n      typeof signal === \"string\" ? signal : signal.id,\n      payload\n    ) as unknown as any;\n  } else {\n    return getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":";;;AAAA,qEAAmE;AACnE,2EAAiF;AACjF,yEAAuE;AACvE,iDAA0D;AAC1D,2CAAgD;AAChD,iCAA6B;AAkB7B,SAAgB,MAAM,CAAiB,IAAY;IACjD,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAFD,wBAEC;AAED,MAAa,MAAM;IACjB,YAAqB,EAAU;QAAV,OAAE,GAAF,EAAE,CAAQ;IAAG,CAAC;IACnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BG;IACI,EAAE,CAAC,OAAuC;QAC/C,OAAO,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACI,MAAM,CAAC,IAA0B;QACtC,OAAO,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;;;;OASG;IACI,IAAI,CACT,WAAmB,EACnB,GAAG,IAA8B;QAEjC,OAAO,UAAU,CAAkB,WAAW,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACjE,CAAC;CACF;AAvFD,wBAuFC;AAuCD,SAAgB,YAAY,CAC1B,MAA4B,EAC5B,IAA0B;IAE1B,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;KAC7D;IAED,OAAO,IAAA,8CAAsB,EAC3B,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,IAAI,EAAE,cAAc,CACd,CAAC;AACX,CAAC;AAZD,oCAYC;AAuCD,SAAgB,QAAQ,CACtB,MAA4B,EAC5B,OAAmC;IAEnC,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IAED,OAAO,IAAA,wDAA+B,EACpC,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAc,CACf,CAAC;AACJ,CAAC;AAZD,4BAYC;AA+BD,SAAgB,UAAU,CACxB,WAAmB,EACnB,MAA4B,EAC5B,OAAa,EACb,EAAW;IAEX,IAAI,IAAA,+BAAoB,GAAE,EAAE;QAC1B,OAAO,IAAA,0CAAoB,EACzB,EAAE,IAAI,EAAE,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,EACjD,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAO,CACU,CAAC;KACrB;SAAM;QACL,OAAO,IAAA,6BAAiB,GAAE,CAAC,UAAU,CAAC;YACpC,WAAW;YACX,MAAM;YACN,EAAE,EAAE,EAAE,IAAI,IAAA,YAAI,GAAE;YAChB,OAAO;SACR,CAAC,CAAC;KACJ;AACH,CAAC;AApBD,gCAoBC;AAID,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,iEAAS,CAAA;IACT,2EAAc,CAAA;AAChB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B;AAaD,SAAgB,sBAAsB,CACpC,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,cAAc,CAAC;AACzD,CAAC;AAJD,wDAIC;AAED,SAAgB,iBAAiB,CAC/B,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,CAAC;AACpD,CAAC;AAJD,8CAIC","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = new Signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.on(async () => {\n   *       await sleepFor(10);\n   *       done = true;\n   *    });\n   *\n   *    await condition(() => done);\n   * });\n   * ```\n   *\n   * To remove the handler, call the dispose method.\n   *\n   * ```ts\n   * const handler = mySignal.on(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  public on(handler: SignalHandlerFunction<Payload>): SignalsHandler {\n    return onSignal(this, handler);\n  }\n\n  /**\n   * Waits for a signal to be received by the workflow.\n   *\n   * The first signal received will resolve the Promise with the payload of the promise.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expect();\n   *\n   *    return payload;\n   * });\n   * ```\n   *\n   * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n   * when the provided time has elapsed.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  public expect(opts?: ExpectSignalOptions): Promise<Payload> {\n    return expectSignal(this, opts);\n  }\n\n  /**\n   * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.send(\"payload\");\n   * })\n   * ```\n   */\n  public send(\n    executionId: string,\n    ...args: SendSignalProps<Payload>\n  ): Promise<void> {\n    return sendSignal<Signal<Payload>>(executionId, this, ...args);\n  }\n}\n\nexport type SignalPayload<E extends Signal<any>> = E extends Signal<infer P>\n  ? P\n  : never;\n\nexport interface ExpectSignalOptions {\n  /**\n   * Optional. Seconds to wait for the signal to be received.\n   *\n   * After the provided seconds, the promise will reject.\n   */\n  timeoutSeconds: number;\n}\n\n/**\n * Waits for a signal to be received by the workflow.\n *\n * The first signal received will resolve the Promise with the payload of the promise.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    const payload = await expectSignal(\"MySignal\");\n *\n *    return payload;\n * });\n * ```\n *\n * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n * when the provided time has elapsed.\n */\nexport function expectSignal<SignalPayload = any>(\n  signalId: string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload>;\nexport function expectSignal<E extends Signal<any>>(\n  signal: E,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<E>>;\nexport function expectSignal(\n  signal: Signal<any> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<any>> {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"expectSignal is only valid in a workflow\");\n  }\n\n  return createExpectSignalCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    opts?.timeoutSeconds\n  ) as any;\n}\n\n/**\n * Listens for a signal matching the signalId provided.\n *\n * When the signal is received, the handler is invoked.\n * If the handler return a promise, the handler is added as a {@link Chain}\n * and progressed until completion.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    let done = false;\n *    onSignal(\"MySignal\", async () => {\n *       await sleepFor(10);\n *       done = true;\n *    });\n *\n *    await condition(() => done);\n * });\n * ```\n *\n * To remove the handler, call the dispose method.\n *\n * ```ts\n * const handler = onSignal(\"MySignal\", () => {});\n *\n * await sleepFor(10);\n *\n * handler.dispose();\n * ```\n */\nexport function onSignal<E extends Signal<any>>(\n  signal: E,\n  handler: SignalHandlerFunction<SignalPayload<E>>\n): SignalsHandler;\nexport function onSignal<Payload = void>(\n  signalId: string,\n  handler: SignalHandlerFunction<Payload>\n): SignalsHandler;\nexport function onSignal(\n  signal: Signal<any> | string,\n  handler: SignalHandlerFunction<any>\n): SignalsHandler {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"onSignal is only valid in a workflow\");\n  }\n\n  return createRegisterSignalHandlerCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    handler as any\n  );\n}\n\nexport type SendSignalProps<SignalPayload> = [SignalPayload] extends\n  | [undefined]\n  | [void]\n  ? [id?: string]\n  : [payload: SignalPayload, id?: string];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = new Signal<string>(\"MySignal\");\n * workflow(\"wf\", async () => {\n *    sendSignal(\"mySignal\", \"payload\");\n *    sendSignal(mySignal, \"payload\");\n * })\n * ```\n *\n * @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.\n */\nexport function sendSignal<S extends Signal<any>>(\n  executionId: string,\n  signal: S,\n  ...args: SendSignalProps<SignalPayload<S>>\n): Promise<void>;\nexport function sendSignal<Payload = any>(\n  executionId: string,\n  signalId: string,\n  ...args: SendSignalProps<Payload>\n): Promise<void>;\nexport function sendSignal(\n  executionId: string,\n  signal: string | Signal<any>,\n  payload?: any,\n  id?: string\n): Promise<void> {\n  if (isOrchestratorWorker()) {\n    return createSendSignalCall(\n      { type: SignalTargetType.Execution, executionId },\n      typeof signal === \"string\" ? signal : signal.id,\n      payload\n    ) as unknown as any;\n  } else {\n    return getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]} |
@@ -29,5 +29,5 @@ "use strict"; | ||
!!err.prototype && | ||
err.prototype.isPrototypeOf(Error)))); | ||
Object.prototype.isPrototypeOf.call(err.prototype, Error)))); | ||
} | ||
exports.extendsError = extendsError; | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLFNBQWdCLFdBQVcsQ0FBQyxLQUFZLEVBQUUsR0FBWTtJQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDLEdBQUcsSUFBSSx1Q0FBdUMsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUN6RSxDQUFDO0FBRkQsa0NBRUM7QUFFRCxTQUFnQixhQUFhLENBQUksS0FBUyxFQUFFLEdBQVk7SUFDdEQsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxJQUFJLDRDQUE0QyxDQUFDLENBQUM7S0FDdEU7SUFDRCxPQUFPLEtBQU0sQ0FBQztBQUNoQixDQUFDO0FBTEQsc0NBS0M7QUFFRCxTQUFnQixHQUFHLENBQ2pCLENBQW1CO0lBRW5CLE9BQU8sQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQVEsQ0FBQztBQUNwQyxDQUFDO0FBSkQsa0JBSUM7QUFFRCxTQUFnQixFQUFFLENBQ2hCLEdBQUcsVUFBYTtJQUVoQixPQUFPLENBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFRLENBQUM7QUFDakUsQ0FBQztBQUpELGdCQUlDO0FBRUQsU0FBZ0IsWUFBWSxDQUFDLEdBQVk7SUFDdkMsT0FBTyxDQUNMLENBQUMsQ0FBQyxHQUFHO1FBQ0wsT0FBTyxHQUFHLEtBQUssUUFBUTtRQUN2QixDQUFDLEdBQUcsWUFBWSxLQUFLO1lBQ25CLENBQUMsV0FBVyxJQUFJLEdBQUc7Z0JBQ2pCLENBQUMsQ0FBQyxHQUFHLENBQUMsU0FBUztnQkFDZixHQUFHLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ3pDLENBQUM7QUFDSixDQUFDO0FBVEQsb0NBU0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gYXNzZXJ0TmV2ZXIobmV2ZXI6IG5ldmVyLCBtc2c/OiBzdHJpbmcpOiBuZXZlciB7XG4gIHRocm93IG5ldyBFcnJvcihtc2cgPz8gYHJlYWNoZWQgdW5yZWFjaGFibGUgY29kZSB3aXRoIHZhbHVlICR7bmV2ZXJ9YCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc3NlcnROb25OdWxsPFQ+KHZhbHVlPzogVCwgbXNnPzogc3RyaW5nKTogTm9uTnVsbGFibGU8VD4ge1xuICBpZiAoIXZhbHVlKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKG1zZyA/PyBcImV4cGVjdGVkIHZhbHVlIHRvIGJlIGRlZmluZWQgYW5kIG5vdCBudWxsLlwiKTtcbiAgfVxuICByZXR1cm4gdmFsdWUhO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbm90PFQsIFUgZXh0ZW5kcyBUPihcbiAgZjogKGE6IFQpID0+IGEgaXMgVVxuKTogKGE6IFQpID0+IGEgaXMgRXhjbHVkZTxULCBVPiB7XG4gIHJldHVybiAoKGE6IGFueSkgPT4gIWYoYSkpIGFzIGFueTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9yPEYgZXh0ZW5kcyAoKGE6IGFueSkgPT4gYSBpcyBhbnkpW10+KFxuICAuLi5jb25kaXRpb25zOiBGXG4pOiAoYTogYW55KSA9PiBhIGlzIEZbbnVtYmVyXSBleHRlbmRzIChhOiBhbnkpID0+IGEgaXMgaW5mZXIgVCA/IFQgOiBuZXZlciB7XG4gIHJldHVybiAoKGE6IGFueSkgPT4gY29uZGl0aW9ucy5zb21lKChjb25kKSA9PiBjb25kKGEpKSkgYXMgYW55O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXh0ZW5kc0Vycm9yKGVycjogdW5rbm93bik6IGVyciBpcyBFcnJvciB7XG4gIHJldHVybiAoXG4gICAgISFlcnIgJiZcbiAgICB0eXBlb2YgZXJyID09PSBcIm9iamVjdFwiICYmXG4gICAgKGVyciBpbnN0YW5jZW9mIEVycm9yIHx8XG4gICAgICAoXCJwcm90b3R5cGVcIiBpbiBlcnIgJiZcbiAgICAgICAgISFlcnIucHJvdG90eXBlICYmXG4gICAgICAgIGVyci5wcm90b3R5cGUuaXNQcm90b3R5cGVPZihFcnJvcikpKVxuICApO1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLFNBQWdCLFdBQVcsQ0FBQyxLQUFZLEVBQUUsR0FBWTtJQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDLEdBQUcsSUFBSSx1Q0FBdUMsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUN6RSxDQUFDO0FBRkQsa0NBRUM7QUFFRCxTQUFnQixhQUFhLENBQUksS0FBUyxFQUFFLEdBQVk7SUFDdEQsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxJQUFJLDRDQUE0QyxDQUFDLENBQUM7S0FDdEU7SUFDRCxPQUFPLEtBQU0sQ0FBQztBQUNoQixDQUFDO0FBTEQsc0NBS0M7QUFFRCxTQUFnQixHQUFHLENBQ2pCLENBQW1CO0lBRW5CLE9BQU8sQ0FBQyxDQUFDLENBQU0sRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQVEsQ0FBQztBQUNwQyxDQUFDO0FBSkQsa0JBSUM7QUFFRCxTQUFnQixFQUFFLENBQ2hCLEdBQUcsVUFBYTtJQUVoQixPQUFPLENBQUMsQ0FBQyxDQUFNLEVBQUUsRUFBRSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFRLENBQUM7QUFDakUsQ0FBQztBQUpELGdCQUlDO0FBRUQsU0FBZ0IsWUFBWSxDQUFDLEdBQVk7SUFDdkMsT0FBTyxDQUNMLENBQUMsQ0FBQyxHQUFHO1FBQ0wsT0FBTyxHQUFHLEtBQUssUUFBUTtRQUN2QixDQUFDLEdBQUcsWUFBWSxLQUFLO1lBQ25CLENBQUMsV0FBVyxJQUFJLEdBQUc7Z0JBQ2pCLENBQUMsQ0FBQyxHQUFHLENBQUMsU0FBUztnQkFDZixNQUFNLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ2hFLENBQUM7QUFDSixDQUFDO0FBVEQsb0NBU0MiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgZnVuY3Rpb24gYXNzZXJ0TmV2ZXIobmV2ZXI6IG5ldmVyLCBtc2c/OiBzdHJpbmcpOiBuZXZlciB7XG4gIHRocm93IG5ldyBFcnJvcihtc2cgPz8gYHJlYWNoZWQgdW5yZWFjaGFibGUgY29kZSB3aXRoIHZhbHVlICR7bmV2ZXJ9YCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBhc3NlcnROb25OdWxsPFQ+KHZhbHVlPzogVCwgbXNnPzogc3RyaW5nKTogTm9uTnVsbGFibGU8VD4ge1xuICBpZiAoIXZhbHVlKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKG1zZyA/PyBcImV4cGVjdGVkIHZhbHVlIHRvIGJlIGRlZmluZWQgYW5kIG5vdCBudWxsLlwiKTtcbiAgfVxuICByZXR1cm4gdmFsdWUhO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gbm90PFQsIFUgZXh0ZW5kcyBUPihcbiAgZjogKGE6IFQpID0+IGEgaXMgVVxuKTogKGE6IFQpID0+IGEgaXMgRXhjbHVkZTxULCBVPiB7XG4gIHJldHVybiAoKGE6IGFueSkgPT4gIWYoYSkpIGFzIGFueTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG9yPEYgZXh0ZW5kcyAoKGE6IGFueSkgPT4gYSBpcyBhbnkpW10+KFxuICAuLi5jb25kaXRpb25zOiBGXG4pOiAoYTogYW55KSA9PiBhIGlzIEZbbnVtYmVyXSBleHRlbmRzIChhOiBhbnkpID0+IGEgaXMgaW5mZXIgVCA/IFQgOiBuZXZlciB7XG4gIHJldHVybiAoKGE6IGFueSkgPT4gY29uZGl0aW9ucy5zb21lKChjb25kKSA9PiBjb25kKGEpKSkgYXMgYW55O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZXh0ZW5kc0Vycm9yKGVycjogdW5rbm93bik6IGVyciBpcyBFcnJvciB7XG4gIHJldHVybiAoXG4gICAgISFlcnIgJiZcbiAgICB0eXBlb2YgZXJyID09PSBcIm9iamVjdFwiICYmXG4gICAgKGVyciBpbnN0YW5jZW9mIEVycm9yIHx8XG4gICAgICAoXCJwcm90b3R5cGVcIiBpbiBlcnIgJiZcbiAgICAgICAgISFlcnIucHJvdG90eXBlICYmXG4gICAgICAgIE9iamVjdC5wcm90b3R5cGUuaXNQcm90b3R5cGVPZi5jYWxsKGVyci5wcm90b3R5cGUsIEVycm9yKSkpXG4gICk7XG59XG4iXX0= |
@@ -136,10 +136,3 @@ import { ExecutionContext } from "./context.js"; | ||
} | ||
export interface WorkflowTaskCompleted extends BaseEvent { | ||
type: WorkflowEventType.WorkflowTaskCompleted; | ||
} | ||
export declare function isTaskCompleted(event: WorkflowEvent): event is WorkflowTaskCompleted; | ||
export interface WorkflowCompleted extends BaseEvent { | ||
type: WorkflowEventType.WorkflowCompleted; | ||
output: any; | ||
} | ||
export declare function isWorkflowCompleted(event: WorkflowEvent): event is WorkflowCompleted; | ||
@@ -146,0 +139,0 @@ export declare function isWorkflowFailed(event: WorkflowEvent): event is WorkflowFailed; |
@@ -184,2 +184,2 @@ "use strict"; | ||
exports.createEvent = createEvent; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-events.js","sourceRoot":"","sources":["../../src/workflow-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ulid } from \"ulidx\";\nimport { ExecutionContext } from \"./context.js\";\nimport { EventEnvelope } from \"./event.js\";\nimport { or } from \"./util.js\";\n\nexport interface BaseEvent {\n  type: WorkflowEventType;\n  id: string;\n  timestamp: string;\n}\n\n/**\n * Common fields for events that {@link Eventual} actives with in order semantics.\n */\nexport interface HistoryEventBase extends Omit<BaseEvent, \"id\"> {\n  seq: number;\n}\n\nexport enum WorkflowEventType {\n  ActivityCompleted = \"ActivityCompleted\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowCompleted = \"ChildWorkflowCompleted\",\n  ChildWorkflowFailed = \"ChildWorkflowFailed\",\n  ChildWorkflowScheduled = \"ChildWorkflowScheduled\",\n  ConditionStarted = \"ConditionStarted\",\n  ConditionTimedOut = \"ConditionTimedOut\",\n  EventsPublished = \"EventsPublished\",\n  ExpectSignalStarted = \"ExpectSignalStarted\",\n  ExpectSignalTimedOut = \"ExpectSignalTimedOut\",\n  SignalReceived = \"SignalReceived\",\n  SignalSent = \"SignalSent\",\n  SleepCompleted = \"SleepCompleted\",\n  SleepScheduled = \"SleepScheduled\",\n  WorkflowCompleted = \"WorkflowCompleted\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowTaskCompleted = \"TaskCompleted\",\n  WorkflowTaskStarted = \"TaskStarted\",\n  WorkflowTimedOut = \"WorkflowTimedOut\",\n}\n\n/**\n * Events generated by the engine that represent the in-order state of the workflow.\n */\nexport type WorkflowEvent =\n  | HistoryEvent\n  | WorkflowTaskCompleted\n  | WorkflowTaskStarted\n  | WorkflowCompleted\n  | WorkflowFailed\n  | WorkflowStarted;\n\nexport type ScheduledEvent =\n  | ActivityScheduled\n  | ChildWorkflowScheduled\n  | ConditionStarted\n  | EventsPublished\n  | ExpectSignalStarted\n  | SignalSent\n  | SleepScheduled;\n\nexport type CompletedEvent =\n  | ActivityCompleted\n  | ChildWorkflowCompleted\n  | SleepCompleted;\n\nexport type FailedEvent =\n  | ActivityFailed\n  | ActivityHeartbeatTimedOut\n  | ActivityTimedOut\n  | ChildWorkflowFailed\n  | ConditionTimedOut\n  | ExpectSignalTimedOut;\n\n/**\n * Events used by the workflow to replay an execution.\n */\nexport type HistoryEvent =\n  | CompletedEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isCompletedEvent(event) ||\n    isFailedEvent(event) ||\n    isScheduledEvent(event) ||\n    isSignalReceived(event) ||\n    isWorkflowTimedOut(event)\n  );\n}\n\n/**\n * Events that we save into history.\n */\nexport type HistoryStateEvent = HistoryEvent | WorkflowStarted;\n\nexport interface WorkflowStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowStarted;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: any;\n  /**\n   * Optional ISO timestamp after which the workflow should timeout.\n   */\n  timeoutTime?: string;\n  context: Omit<ExecutionContext, \"id\" | \"startTime\">;\n}\nexport interface WorkflowTaskStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskStarted;\n  /**\n   * An execution ID of the parent workflow execution that\n   * started this workflow if this is a child workflow.\n   */\n  parent?: string;\n}\n\nexport interface ActivityScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ActivityScheduled;\n  name: string;\n}\n\nexport interface ActivityCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ActivityCompleted;\n  result: any;\n}\n\nexport interface ActivityFailed extends HistoryEventBase {\n  type: WorkflowEventType.ActivityFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ActivityHeartbeatTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport interface WorkflowFailed extends BaseEvent {\n  type: WorkflowEventType.WorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ChildWorkflowScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowScheduled;\n  name: string;\n  input?: any;\n}\n\nexport interface ChildWorkflowCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowCompleted;\n  result: any;\n}\n\nexport interface ChildWorkflowFailed extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport function isWorkflowStarted(\n  event: WorkflowEvent\n): event is WorkflowStarted {\n  return event.type === WorkflowEventType.WorkflowStarted;\n}\n\nexport function isTaskStarted(\n  event: WorkflowEvent\n): event is WorkflowTaskStarted {\n  return event.type === WorkflowEventType.WorkflowTaskStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivityCompleted(\n  event: WorkflowEvent\n): event is ActivityCompleted {\n  return event.type === WorkflowEventType.ActivityCompleted;\n}\n\nexport function isActivityFailed(\n  event: WorkflowEvent\n): event is ActivityFailed {\n  return event.type === WorkflowEventType.ActivityFailed;\n}\n\nexport function isActivityHeartbeatTimedOut(\n  event: WorkflowEvent\n): event is ActivityHeartbeatTimedOut {\n  return event.type === WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface SleepScheduled extends HistoryEventBase {\n  type: WorkflowEventType.SleepScheduled;\n  untilTime: string;\n}\n\nexport function isSleepScheduled(\n  event: WorkflowEvent\n): event is SleepScheduled {\n  return event.type === WorkflowEventType.SleepScheduled;\n}\n\nexport interface SleepCompleted extends HistoryEventBase {\n  type: WorkflowEventType.SleepCompleted;\n  result?: undefined;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport function isTaskCompleted(\n  event: WorkflowEvent\n): event is WorkflowTaskCompleted {\n  return event.type === WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport function isWorkflowCompleted(\n  event: WorkflowEvent\n): event is WorkflowCompleted {\n  return event.type === WorkflowEventType.WorkflowCompleted;\n}\n\nexport function isWorkflowFailed(\n  event: WorkflowEvent\n): event is WorkflowFailed {\n  return event.type === WorkflowEventType.WorkflowFailed;\n}\n\nexport function isChildWorkflowScheduled(\n  event: WorkflowEvent\n): event is ChildWorkflowScheduled {\n  return event.type === WorkflowEventType.ChildWorkflowScheduled;\n}\nexport function isChildWorkflowCompleted(\n  event: WorkflowEvent\n): event is ChildWorkflowCompleted {\n  return event.type === WorkflowEventType.ChildWorkflowCompleted;\n}\nexport function isChildWorkflowFailed(\n  event: WorkflowEvent\n): event is ChildWorkflowFailed {\n  return event.type === WorkflowEventType.ChildWorkflowFailed;\n}\n\nexport function isSleepCompleted(\n  event: WorkflowEvent\n): event is SleepCompleted {\n  return event.type === WorkflowEventType.SleepCompleted;\n}\n\nexport interface ExpectSignalStarted extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalStarted;\n  signalId: string;\n  timeoutSeconds?: number;\n}\n\nexport interface ExpectSignalTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalTimedOut;\n  signalId: string;\n}\n\nexport interface SignalReceived<Payload = any> extends BaseEvent {\n  type: WorkflowEventType.SignalReceived;\n  signalId: string;\n  payload?: Payload;\n}\n\nexport function isExpectSignalStarted(\n  event: WorkflowEvent\n): event is ExpectSignalStarted {\n  return event.type === WorkflowEventType.ExpectSignalStarted;\n}\n\nexport function isExpectSignalTimedOut(\n  event: WorkflowEvent\n): event is ExpectSignalTimedOut {\n  return event.type === WorkflowEventType.ExpectSignalTimedOut;\n}\n\nexport function isSignalReceived(\n  event: WorkflowEvent\n): event is SignalReceived {\n  return event.type === WorkflowEventType.SignalReceived;\n}\n\nexport interface SignalSent extends HistoryEventBase {\n  type: WorkflowEventType.SignalSent;\n  payload?: any;\n  signalId: string;\n  executionId: string;\n}\n\nexport function isSignalSent(event: WorkflowEvent): event is SignalSent {\n  return event.type === WorkflowEventType.SignalSent;\n}\n\nexport interface EventsPublished extends HistoryEventBase {\n  type: WorkflowEventType.EventsPublished;\n  events: EventEnvelope[];\n}\n\nexport function isEventsPublished(\n  event: WorkflowEvent\n): event is EventsPublished {\n  return event.type === WorkflowEventType.EventsPublished;\n}\n\nexport interface ConditionStarted extends HistoryEventBase {\n  type: WorkflowEventType.ConditionStarted;\n}\n\nexport function isConditionStarted(\n  event: WorkflowEvent\n): event is ConditionStarted {\n  return event.type === WorkflowEventType.ConditionStarted;\n}\n\nexport interface ConditionTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ConditionTimedOut;\n}\n\nexport function isConditionTimedOut(\n  event: WorkflowEvent\n): event is ConditionTimedOut {\n  return event.type === WorkflowEventType.ConditionTimedOut;\n}\n\nexport interface ActivityTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityTimedOut;\n}\n\nexport interface WorkflowTimedOut extends BaseEvent {\n  type: WorkflowEventType.WorkflowTimedOut;\n}\n\nexport function isActivityTimedOut(\n  event: WorkflowEvent\n): event is ActivityTimedOut {\n  return event.type === WorkflowEventType.ActivityTimedOut;\n}\n\nexport function isWorkflowTimedOut(\n  event: WorkflowEvent\n): event is WorkflowTimedOut {\n  return event.type === WorkflowEventType.WorkflowTimedOut;\n}\n\nexport const isScheduledEvent = or(\n  isActivityScheduled,\n  isChildWorkflowScheduled,\n  isConditionStarted,\n  isEventsPublished,\n  isExpectSignalStarted,\n  isSignalSent,\n  isSleepScheduled\n);\n\nexport const isCompletedEvent = or(\n  isActivityCompleted,\n  isChildWorkflowCompleted,\n  isSleepCompleted\n);\n\nexport const isFailedEvent = or(\n  isActivityFailed,\n  isActivityTimedOut,\n  isActivityHeartbeatTimedOut,\n  isChildWorkflowFailed,\n  isConditionTimedOut,\n  isExpectSignalTimedOut,\n  isWorkflowTimedOut\n);\n\nexport function assertEventType<T extends WorkflowEvent>(\n  event: any,\n  type: T[\"type\"]\n): asserts event is T {\n  if (!event || event.type !== type) {\n    throw new Error(`Expected event of type ${type}`);\n  }\n}\n\n/**\n * Compute the ID of an event.\n *\n * Some events have a computed ID to save space.\n */\nexport function getEventId(event: WorkflowEvent): string {\n  if (\n    isHistoryEvent(event) &&\n    !isSignalReceived(event) &&\n    !isWorkflowTimedOut(event)\n  ) {\n    return `${event.seq}_${event.type}`;\n  } else {\n    return event.id;\n  }\n}\n\n/**\n * Filters out events that are also present in origin events.\n *\n * Events are taken only if their ID ({@link getEventId}) is unique across all other events.\n */\nexport function filterEvents<T extends WorkflowEvent>(\n  originEvents: T[],\n  events: T[]\n): T[] {\n  const ids = new Set(originEvents.map(getEventId));\n\n  return events.filter((event) => {\n    const id = getEventId(event);\n    if (ids.has(id)) {\n      return false;\n    }\n    ids.add(id);\n    return true;\n  });\n}\n\ntype UnresolvedEvent<T extends WorkflowEvent> = Omit<T, \"id\" | \"timestamp\">;\n\nexport function createEvent<T extends WorkflowEvent>(\n  event: UnresolvedEvent<T>,\n  time: Date = new Date(),\n  id: string = ulid()\n): T {\n  const timestamp = time.toISOString();\n\n  // history events do not have IDs, use getEventId\n  if (\n    isHistoryEvent(event as unknown as WorkflowEvent) &&\n    !isSignalReceived(event as unknown as WorkflowEvent)\n  ) {\n    return { ...(event as any), timestamp };\n  }\n\n  return { ...event, id, timestamp } as T;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-events.js","sourceRoot":"","sources":["../../src/workflow-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ulid } from \"ulidx\";\nimport { ExecutionContext } from \"./context.js\";\nimport { EventEnvelope } from \"./event.js\";\nimport { or } from \"./util.js\";\n\nexport interface BaseEvent {\n  type: WorkflowEventType;\n  id: string;\n  timestamp: string;\n}\n\n/**\n * Common fields for events that {@link Eventual} actives with in order semantics.\n */\nexport interface HistoryEventBase extends Omit<BaseEvent, \"id\"> {\n  seq: number;\n}\n\nexport enum WorkflowEventType {\n  ActivityCompleted = \"ActivityCompleted\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowCompleted = \"ChildWorkflowCompleted\",\n  ChildWorkflowFailed = \"ChildWorkflowFailed\",\n  ChildWorkflowScheduled = \"ChildWorkflowScheduled\",\n  ConditionStarted = \"ConditionStarted\",\n  ConditionTimedOut = \"ConditionTimedOut\",\n  EventsPublished = \"EventsPublished\",\n  ExpectSignalStarted = \"ExpectSignalStarted\",\n  ExpectSignalTimedOut = \"ExpectSignalTimedOut\",\n  SignalReceived = \"SignalReceived\",\n  SignalSent = \"SignalSent\",\n  SleepCompleted = \"SleepCompleted\",\n  SleepScheduled = \"SleepScheduled\",\n  WorkflowCompleted = \"WorkflowCompleted\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowTaskCompleted = \"TaskCompleted\",\n  WorkflowTaskStarted = \"TaskStarted\",\n  WorkflowTimedOut = \"WorkflowTimedOut\",\n}\n\n/**\n * Events generated by the engine that represent the in-order state of the workflow.\n */\nexport type WorkflowEvent =\n  | HistoryEvent\n  | WorkflowTaskCompleted\n  | WorkflowTaskStarted\n  | WorkflowCompleted\n  | WorkflowFailed\n  | WorkflowStarted;\n\nexport type ScheduledEvent =\n  | ActivityScheduled\n  | ChildWorkflowScheduled\n  | ConditionStarted\n  | EventsPublished\n  | ExpectSignalStarted\n  | SignalSent\n  | SleepScheduled;\n\nexport type CompletedEvent =\n  | ActivityCompleted\n  | ChildWorkflowCompleted\n  | SleepCompleted;\n\nexport type FailedEvent =\n  | ActivityFailed\n  | ActivityHeartbeatTimedOut\n  | ActivityTimedOut\n  | ChildWorkflowFailed\n  | ConditionTimedOut\n  | ExpectSignalTimedOut;\n\n/**\n * Events used by the workflow to replay an execution.\n */\nexport type HistoryEvent =\n  | CompletedEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isCompletedEvent(event) ||\n    isFailedEvent(event) ||\n    isScheduledEvent(event) ||\n    isSignalReceived(event) ||\n    isWorkflowTimedOut(event)\n  );\n}\n\n/**\n * Events that we save into history.\n */\nexport type HistoryStateEvent = HistoryEvent | WorkflowStarted;\n\nexport interface WorkflowStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowStarted;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: any;\n  /**\n   * Optional ISO timestamp after which the workflow should timeout.\n   */\n  timeoutTime?: string;\n  context: Omit<ExecutionContext, \"id\" | \"startTime\">;\n}\nexport interface WorkflowTaskStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskStarted;\n  /**\n   * An execution ID of the parent workflow execution that\n   * started this workflow if this is a child workflow.\n   */\n  parent?: string;\n}\n\nexport interface ActivityScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ActivityScheduled;\n  name: string;\n}\n\nexport interface ActivityCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ActivityCompleted;\n  result: any;\n}\n\nexport interface ActivityFailed extends HistoryEventBase {\n  type: WorkflowEventType.ActivityFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ActivityHeartbeatTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport interface WorkflowFailed extends BaseEvent {\n  type: WorkflowEventType.WorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ChildWorkflowScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowScheduled;\n  name: string;\n  input?: any;\n}\n\nexport interface ChildWorkflowCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowCompleted;\n  result: any;\n}\n\nexport interface ChildWorkflowFailed extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport function isWorkflowStarted(\n  event: WorkflowEvent\n): event is WorkflowStarted {\n  return event.type === WorkflowEventType.WorkflowStarted;\n}\n\nexport function isTaskStarted(\n  event: WorkflowEvent\n): event is WorkflowTaskStarted {\n  return event.type === WorkflowEventType.WorkflowTaskStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivityCompleted(\n  event: WorkflowEvent\n): event is ActivityCompleted {\n  return event.type === WorkflowEventType.ActivityCompleted;\n}\n\nexport function isActivityFailed(\n  event: WorkflowEvent\n): event is ActivityFailed {\n  return event.type === WorkflowEventType.ActivityFailed;\n}\n\nexport function isActivityHeartbeatTimedOut(\n  event: WorkflowEvent\n): event is ActivityHeartbeatTimedOut {\n  return event.type === WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface SleepScheduled extends HistoryEventBase {\n  type: WorkflowEventType.SleepScheduled;\n  untilTime: string;\n}\n\nexport function isSleepScheduled(\n  event: WorkflowEvent\n): event is SleepScheduled {\n  return event.type === WorkflowEventType.SleepScheduled;\n}\n\nexport interface SleepCompleted extends HistoryEventBase {\n  type: WorkflowEventType.SleepCompleted;\n  result?: undefined;\n}\n\nexport function isTaskCompleted(\n  event: WorkflowEvent\n): event is WorkflowTaskCompleted {\n  return event.type === WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport function isWorkflowCompleted(\n  event: WorkflowEvent\n): event is WorkflowCompleted {\n  return event.type === WorkflowEventType.WorkflowCompleted;\n}\n\nexport function isWorkflowFailed(\n  event: WorkflowEvent\n): event is WorkflowFailed {\n  return event.type === WorkflowEventType.WorkflowFailed;\n}\n\nexport function isChildWorkflowScheduled(\n  event: WorkflowEvent\n): event is ChildWorkflowScheduled {\n  return event.type === WorkflowEventType.ChildWorkflowScheduled;\n}\nexport function isChildWorkflowCompleted(\n  event: WorkflowEvent\n): event is ChildWorkflowCompleted {\n  return event.type === WorkflowEventType.ChildWorkflowCompleted;\n}\nexport function isChildWorkflowFailed(\n  event: WorkflowEvent\n): event is ChildWorkflowFailed {\n  return event.type === WorkflowEventType.ChildWorkflowFailed;\n}\n\nexport function isSleepCompleted(\n  event: WorkflowEvent\n): event is SleepCompleted {\n  return event.type === WorkflowEventType.SleepCompleted;\n}\n\nexport interface ExpectSignalStarted extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalStarted;\n  signalId: string;\n  timeoutSeconds?: number;\n}\n\nexport interface ExpectSignalTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalTimedOut;\n  signalId: string;\n}\n\nexport interface SignalReceived<Payload = any> extends BaseEvent {\n  type: WorkflowEventType.SignalReceived;\n  signalId: string;\n  payload?: Payload;\n}\n\nexport function isExpectSignalStarted(\n  event: WorkflowEvent\n): event is ExpectSignalStarted {\n  return event.type === WorkflowEventType.ExpectSignalStarted;\n}\n\nexport function isExpectSignalTimedOut(\n  event: WorkflowEvent\n): event is ExpectSignalTimedOut {\n  return event.type === WorkflowEventType.ExpectSignalTimedOut;\n}\n\nexport function isSignalReceived(\n  event: WorkflowEvent\n): event is SignalReceived {\n  return event.type === WorkflowEventType.SignalReceived;\n}\n\nexport interface SignalSent extends HistoryEventBase {\n  type: WorkflowEventType.SignalSent;\n  payload?: any;\n  signalId: string;\n  executionId: string;\n}\n\nexport function isSignalSent(event: WorkflowEvent): event is SignalSent {\n  return event.type === WorkflowEventType.SignalSent;\n}\n\nexport interface EventsPublished extends HistoryEventBase {\n  type: WorkflowEventType.EventsPublished;\n  events: EventEnvelope[];\n}\n\nexport function isEventsPublished(\n  event: WorkflowEvent\n): event is EventsPublished {\n  return event.type === WorkflowEventType.EventsPublished;\n}\n\nexport interface ConditionStarted extends HistoryEventBase {\n  type: WorkflowEventType.ConditionStarted;\n}\n\nexport function isConditionStarted(\n  event: WorkflowEvent\n): event is ConditionStarted {\n  return event.type === WorkflowEventType.ConditionStarted;\n}\n\nexport interface ConditionTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ConditionTimedOut;\n}\n\nexport function isConditionTimedOut(\n  event: WorkflowEvent\n): event is ConditionTimedOut {\n  return event.type === WorkflowEventType.ConditionTimedOut;\n}\n\nexport interface ActivityTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityTimedOut;\n}\n\nexport interface WorkflowTimedOut extends BaseEvent {\n  type: WorkflowEventType.WorkflowTimedOut;\n}\n\nexport function isActivityTimedOut(\n  event: WorkflowEvent\n): event is ActivityTimedOut {\n  return event.type === WorkflowEventType.ActivityTimedOut;\n}\n\nexport function isWorkflowTimedOut(\n  event: WorkflowEvent\n): event is WorkflowTimedOut {\n  return event.type === WorkflowEventType.WorkflowTimedOut;\n}\n\nexport const isScheduledEvent = or(\n  isActivityScheduled,\n  isChildWorkflowScheduled,\n  isConditionStarted,\n  isEventsPublished,\n  isExpectSignalStarted,\n  isSignalSent,\n  isSleepScheduled\n);\n\nexport const isCompletedEvent = or(\n  isActivityCompleted,\n  isChildWorkflowCompleted,\n  isSleepCompleted\n);\n\nexport const isFailedEvent = or(\n  isActivityFailed,\n  isActivityTimedOut,\n  isActivityHeartbeatTimedOut,\n  isChildWorkflowFailed,\n  isConditionTimedOut,\n  isExpectSignalTimedOut,\n  isWorkflowTimedOut\n);\n\nexport function assertEventType<T extends WorkflowEvent>(\n  event: any,\n  type: T[\"type\"]\n): asserts event is T {\n  if (!event || event.type !== type) {\n    throw new Error(`Expected event of type ${type}`);\n  }\n}\n\n/**\n * Compute the ID of an event.\n *\n * Some events have a computed ID to save space.\n */\nexport function getEventId(event: WorkflowEvent): string {\n  if (\n    isHistoryEvent(event) &&\n    !isSignalReceived(event) &&\n    !isWorkflowTimedOut(event)\n  ) {\n    return `${event.seq}_${event.type}`;\n  } else {\n    return event.id;\n  }\n}\n\n/**\n * Filters out events that are also present in origin events.\n *\n * Events are taken only if their ID ({@link getEventId}) is unique across all other events.\n */\nexport function filterEvents<T extends WorkflowEvent>(\n  originEvents: T[],\n  events: T[]\n): T[] {\n  const ids = new Set(originEvents.map(getEventId));\n\n  return events.filter((event) => {\n    const id = getEventId(event);\n    if (ids.has(id)) {\n      return false;\n    }\n    ids.add(id);\n    return true;\n  });\n}\n\ntype UnresolvedEvent<T extends WorkflowEvent> = Omit<T, \"id\" | \"timestamp\">;\n\nexport function createEvent<T extends WorkflowEvent>(\n  event: UnresolvedEvent<T>,\n  time: Date = new Date(),\n  id: string = ulid()\n): T {\n  const timestamp = time.toISOString();\n\n  // history events do not have IDs, use getEventId\n  if (\n    isHistoryEvent(event as unknown as WorkflowEvent) &&\n    !isSignalReceived(event as unknown as WorkflowEvent)\n  ) {\n    return { ...(event as any), timestamp };\n  }\n\n  return { ...event, id, timestamp } as T;\n}\n"]} |
@@ -21,3 +21,3 @@ import { CompleteActivityRequest } from "./runtime/clients/workflow-client.js"; | ||
} | ||
export interface ActivityFunction<Arguments extends any[], Output extends any = any> { | ||
export interface ActivityFunction<Arguments extends any[], Output = any> { | ||
(...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>; | ||
@@ -47,3 +47,3 @@ /** | ||
} | ||
export interface ActivityHandler<Arguments extends any[], Output extends any = any> { | ||
export interface ActivityHandler<Arguments extends any[], Output = any> { | ||
(...args: Arguments): Promise<Awaited<Output>> | Output | AsyncResult<Output> | Promise<AsyncResult<Awaited<Output>>>; | ||
@@ -95,4 +95,4 @@ } | ||
*/ | ||
export declare function activity<Arguments extends any[], Output extends any = any>(activityID: string, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output extends any = any>(activityID: string, opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output = any>(activityID: string, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
export declare function activity<Arguments extends any[], Output = any>(activityID: string, opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>): ActivityFunction<Arguments, Output>; | ||
/** | ||
@@ -99,0 +99,0 @@ * Retrieve an activity function that has been registered in a workflow. |
@@ -72,2 +72,2 @@ import { createActivityCall } from "./calls/activity-call.js"; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAqE5E,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;AAU3D,MAAM,UAAU,aAAa,CAAC,GAAQ;IACpC,OAAO,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,gBAAgB,CAAC;AAC7D,CAAC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,YAAqD;IAErD,IAAI,CAAC,gBAAgB,EAAE,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IACD,MAAM,eAAe,GAAG,kBAAkB,EAAE,CAAC;IAC7C,IAAI,CAAC,eAAe,EAAE;QACpB,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;KACH;IACD,MAAM,YAAY,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAClD,OAAO;QACL,CAAC,gBAAgB,CAAC,EAAE,gBAAoD;KACzE,CAAC;AACJ,CAAC;AAwBD,MAAM,UAAU,QAAQ,CACtB,UAAkB,EAClB,GAAG,IAE8C;IAEjD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxE,IAAI,IAAyC,CAAC;IAC9C,IAAI,oBAAoB,EAAE,EAAE;QAC1B,+FAA+F;QAC/F,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;YACnE,OAAO,kBAAkB,CACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;QACX,CAAC,CAAwC,CAAC;KAC3C;SAAM;QACL,4DAA4D;QAC5D,yDAAyD;QACzD,kBAAkB,EAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;QAC3C,4EAA4E;QAC5E,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAGpC,CAAC;KACH;IACD,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,iBAAiB,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,CAAC,CAAC;IACF,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CACjC,UAAkB;IAElB,OAAO,kBAAkB,EAAE,CAAC,UAAU,CAAyB,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,wBAAwB;IACtC,OAAO,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;AAC3C,CAAC","sourcesContent":["import { createActivityCall } from \"./calls/activity-call.js\";\nimport {\n  callableActivities,\n  getActivityContext,\n  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<\n  Arguments extends any[],\n  Output extends any = any\n> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n}\n\nexport interface ActivityHandler<\n  Arguments extends any[],\n  Output extends any = any\n> {\n  (...args: Arguments):\n    | Promise<Awaited<Output>>\n    | Output\n    | AsyncResult<Output>\n    | Promise<AsyncResult<Awaited<Output>>>;\n}\n\nexport type UnwrapAsync<Output> = Output extends AsyncResult<infer O>\n  ? O\n  : Output;\n\nconst AsyncTokenSymbol = Symbol.for(\"eventual:AsyncToken\");\n\n/**\n * When returned from an activity, the activity will become async,\n * allowing it to run \"forever\". The\n */\nexport interface AsyncResult<Output = any> {\n  [AsyncTokenSymbol]: typeof AsyncTokenSymbol & Output;\n}\n\nexport function isAsyncResult(obj: any): obj is AsyncResult {\n  return !!obj && obj[AsyncTokenSymbol] === AsyncTokenSymbol;\n}\n\n/**\n * When returned from an {@link activity}, tells the system to make the current\n * activity async. This allows the activity to defer sending a response from the\n * current function and instead complete the activity with {@link WorkflowClient.completeActivity}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the completeActivity function will be called later with a string result.\n *    return asyncResult<string>(async (activityToken) => {\n *       // before exiting, send the activityToken to a sqs queue to be completed later\n *       // you could invoke any service here\n *       await sqs.send(new SendMessageCommand({ ..., message: JSONl.stringify({ activityToken })));\n *    });\n * })\n * ```\n *\n * @param tokenContext is a callback which provides the activityToken. The activity token is used\n *                     to completeActivity and heartbeatActivity from outside of the\n *                     activity.\n */\nexport async function asyncResult<Output = any>(\n  tokenContext: (token: string) => Promise<void> | void\n): Promise<AsyncResult<Output>> {\n  if (!isActivityWorker()) {\n    throw new Error(\"asyncResult can only be called from within an activity.\");\n  }\n  const activityContext = getActivityContext();\n  if (!activityContext) {\n    throw new Error(\n      \"Activity context has not been set yet, asyncResult can only be used from within an activity.\"\n    );\n  }\n  await tokenContext(activityContext.activityToken);\n  return {\n    [AsyncTokenSymbol]: AsyncTokenSymbol as typeof AsyncTokenSymbol & Output,\n  };\n}\n\nexport interface ActivityContext {\n  workflowName: string;\n  executionId: string;\n  activityToken: string;\n  scheduledTime: string;\n}\n\n/**\n * Registers a function as an Activity.\n *\n * @param activityID a string that uniquely identifies the Activity within a single workflow context.\n * @param handler the function that handles the activity\n */\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  opts: ActivityOptions,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output extends any = any>(\n  activityID: string,\n  ...args:\n    | [opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>]\n    | [handler: ActivityHandler<Arguments, Output>]\n): ActivityFunction<Arguments, Output> {\n  const [opts, handler] = args.length === 1 ? [undefined, args[0]] : args;\n  let func: ActivityFunction<Arguments, Output>;\n  if (isOrchestratorWorker()) {\n    // if we're in the orchestrator, return a command to invoke the activity in the worker function\n    func = ((...args: Parameters<ActivityFunction<Arguments, Output>>) => {\n      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    }) as ActivityFunction<Arguments, Output>;\n  } else {\n    // otherwise we must be in an activity, event or api handler\n    // register the handler to be looked up during execution.\n    callableActivities()[activityID] = handler;\n    // calling the activity from outside the orchestrator just calls the handler\n    func = ((...args) => handler(...args)) as ActivityFunction<\n      Arguments,\n      Output\n    >;\n  }\n  func.complete = async function (request) {\n    return getWorkflowClient().completeActivity(request);\n  };\n  return func;\n}\n\n/**\n * Retrieve an activity function that has been registered in a workflow.\n */\nexport function getCallableActivity(\n  activityId: string\n): ActivityHandler<any> | undefined {\n  return callableActivities()[activityId] as ActivityHandler<any>;\n}\n\nexport function getCallableActivityNames() {\n  return Object.keys(callableActivities());\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AA+D5E,MAAM,gBAAgB,GAAG,MAAM,CAAC,GAAG,CAAC,qBAAqB,CAAC,CAAC;AAU3D,MAAM,UAAU,aAAa,CAAC,GAAQ;IACpC,OAAO,CAAC,CAAC,GAAG,IAAI,GAAG,CAAC,gBAAgB,CAAC,KAAK,gBAAgB,CAAC;AAC7D,CAAC;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,MAAM,CAAC,KAAK,UAAU,WAAW,CAC/B,YAAqD;IAErD,IAAI,CAAC,gBAAgB,EAAE,EAAE;QACvB,MAAM,IAAI,KAAK,CAAC,yDAAyD,CAAC,CAAC;KAC5E;IACD,MAAM,eAAe,GAAG,kBAAkB,EAAE,CAAC;IAC7C,IAAI,CAAC,eAAe,EAAE;QACpB,MAAM,IAAI,KAAK,CACb,8FAA8F,CAC/F,CAAC;KACH;IACD,MAAM,YAAY,CAAC,eAAe,CAAC,aAAa,CAAC,CAAC;IAClD,OAAO;QACL,CAAC,gBAAgB,CAAC,EAAE,gBAAoD;KACzE,CAAC;AACJ,CAAC;AAwBD,MAAM,UAAU,QAAQ,CACtB,UAAkB,EAClB,GAAG,IAE8C;IAEjD,MAAM,CAAC,IAAI,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC,MAAM,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;IACxE,IAAI,IAAyC,CAAC;IAC9C,IAAI,oBAAoB,EAAE,EAAE;QAC1B,+FAA+F;QAC/F,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;YACnE,OAAO,kBAAkB,CACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;QACX,CAAC,CAAwC,CAAC;KAC3C;SAAM;QACL,4DAA4D;QAC5D,yDAAyD;QACzD,kBAAkB,EAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;QAC3C,4EAA4E;QAC5E,IAAI,GAAG,CAAC,CAAC,GAAG,IAAI,EAAE,EAAE,CAAC,OAAO,CAAC,GAAG,IAAI,CAAC,CAGpC,CAAC;KACH;IACD,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,iBAAiB,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,CAAC,CAAC;IACF,OAAO,IAAI,CAAC;AACd,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,mBAAmB,CACjC,UAAkB;IAElB,OAAO,kBAAkB,EAAE,CAAC,UAAU,CAAyB,CAAC;AAClE,CAAC;AAED,MAAM,UAAU,wBAAwB;IACtC,OAAO,MAAM,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAC;AAC3C,CAAC","sourcesContent":["import { createActivityCall } from \"./calls/activity-call.js\";\nimport {\n  callableActivities,\n  getActivityContext,\n  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<Arguments extends any[], Output = any> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n}\n\nexport interface ActivityHandler<Arguments extends any[], Output = any> {\n  (...args: Arguments):\n    | Promise<Awaited<Output>>\n    | Output\n    | AsyncResult<Output>\n    | Promise<AsyncResult<Awaited<Output>>>;\n}\n\nexport type UnwrapAsync<Output> = Output extends AsyncResult<infer O>\n  ? O\n  : Output;\n\nconst AsyncTokenSymbol = Symbol.for(\"eventual:AsyncToken\");\n\n/**\n * When returned from an activity, the activity will become async,\n * allowing it to run \"forever\". The\n */\nexport interface AsyncResult<Output = any> {\n  [AsyncTokenSymbol]: typeof AsyncTokenSymbol & Output;\n}\n\nexport function isAsyncResult(obj: any): obj is AsyncResult {\n  return !!obj && obj[AsyncTokenSymbol] === AsyncTokenSymbol;\n}\n\n/**\n * When returned from an {@link activity}, tells the system to make the current\n * activity async. This allows the activity to defer sending a response from the\n * current function and instead complete the activity with {@link WorkflowClient.completeActivity}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the completeActivity function will be called later with a string result.\n *    return asyncResult<string>(async (activityToken) => {\n *       // before exiting, send the activityToken to a sqs queue to be completed later\n *       // you could invoke any service here\n *       await sqs.send(new SendMessageCommand({ ..., message: JSONl.stringify({ activityToken })));\n *    });\n * })\n * ```\n *\n * @param tokenContext is a callback which provides the activityToken. The activity token is used\n *                     to completeActivity and heartbeatActivity from outside of the\n *                     activity.\n */\nexport async function asyncResult<Output = any>(\n  tokenContext: (token: string) => Promise<void> | void\n): Promise<AsyncResult<Output>> {\n  if (!isActivityWorker()) {\n    throw new Error(\"asyncResult can only be called from within an activity.\");\n  }\n  const activityContext = getActivityContext();\n  if (!activityContext) {\n    throw new Error(\n      \"Activity context has not been set yet, asyncResult can only be used from within an activity.\"\n    );\n  }\n  await tokenContext(activityContext.activityToken);\n  return {\n    [AsyncTokenSymbol]: AsyncTokenSymbol as typeof AsyncTokenSymbol & Output,\n  };\n}\n\nexport interface ActivityContext {\n  workflowName: string;\n  executionId: string;\n  activityToken: string;\n  scheduledTime: string;\n}\n\n/**\n * Registers a function as an Activity.\n *\n * @param activityID a string that uniquely identifies the Activity within a single workflow context.\n * @param handler the function that handles the activity\n */\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  opts: ActivityOptions,\n  handler: ActivityHandler<Arguments, Output>\n): ActivityFunction<Arguments, Output>;\nexport function activity<Arguments extends any[], Output = any>(\n  activityID: string,\n  ...args:\n    | [opts: ActivityOptions, handler: ActivityHandler<Arguments, Output>]\n    | [handler: ActivityHandler<Arguments, Output>]\n): ActivityFunction<Arguments, Output> {\n  const [opts, handler] = args.length === 1 ? [undefined, args[0]] : args;\n  let func: ActivityFunction<Arguments, Output>;\n  if (isOrchestratorWorker()) {\n    // if we're in the orchestrator, return a command to invoke the activity in the worker function\n    func = ((...args: Parameters<ActivityFunction<Arguments, Output>>) => {\n      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    }) as ActivityFunction<Arguments, Output>;\n  } else {\n    // otherwise we must be in an activity, event or api handler\n    // register the handler to be looked up during execution.\n    callableActivities()[activityID] = handler;\n    // calling the activity from outside the orchestrator just calls the handler\n    func = ((...args) => handler(...args)) as ActivityFunction<\n      Arguments,\n      Output\n    >;\n  }\n  func.complete = async function (request) {\n    return getWorkflowClient().completeActivity(request);\n  };\n  return func;\n}\n\n/**\n * Retrieve an activity function that has been registered in a workflow.\n */\nexport function getCallableActivity(\n  activityId: string\n): ActivityHandler<any> | undefined {\n  return callableActivities()[activityId] as ActivityHandler<any>;\n}\n\nexport function getCallableActivityNames() {\n  return Object.keys(callableActivities());\n}\n"]} |
@@ -9,3 +9,3 @@ import { createEventual, EventualKind, isEventualOfKind, } from "../eventual.js"; | ||
return registerEventual(createEventual(EventualKind.RegisterSignalHandlerCall, { | ||
signalId: signalId, | ||
signalId, | ||
handler, | ||
@@ -17,2 +17,2 @@ dispose: function () { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmFsLWhhbmRsZXItY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy9zaWduYWwtaGFuZGxlci1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxjQUFjLEVBRWQsWUFBWSxFQUNaLGdCQUFnQixHQUNqQixNQUFNLGdCQUFnQixDQUFDO0FBRXhCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVoRCxPQUFPLEVBQVksTUFBTSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRWhELE1BQU0sVUFBVSwyQkFBMkIsQ0FDekMsQ0FBTTtJQUVOLE9BQU8sZ0JBQWdCLENBQUMsWUFBWSxDQUFDLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ3JFLENBQUM7QUFVRCxNQUFNLFVBQVUsK0JBQStCLENBQzdDLFFBQWdCLEVBQ2hCLE9BQTZDO0lBRTdDLE9BQU8sZ0JBQWdCLENBQ3JCLGNBQWMsQ0FBQyxZQUFZLENBQUMseUJBQXlCLEVBQUU7UUFDckQsUUFBUSxFQUFFLFFBQVE7UUFDbEIsT0FBTztRQUNQLE9BQU8sRUFBRTtZQUNQLElBQUksQ0FBQyxNQUFNLEdBQUcsTUFBTSxDQUFDLFFBQVEsQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUMzQyxDQUFDO0tBQ0YsQ0FBQyxDQUNILENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgY3JlYXRlRXZlbnR1YWwsXG4gIEV2ZW50dWFsQmFzZSxcbiAgRXZlbnR1YWxLaW5kLFxuICBpc0V2ZW50dWFsT2ZLaW5kLFxufSBmcm9tIFwiLi4vZXZlbnR1YWwuanNcIjtcbmltcG9ydCB7IFNpZ25hbHNIYW5kbGVyIH0gZnJvbSBcIi4uL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IHJlZ2lzdGVyRXZlbnR1YWwgfSBmcm9tIFwiLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBQcm9ncmFtIH0gZnJvbSBcIi4uL2ludGVycHJldC5qc1wiO1xuaW1wb3J0IHsgUmVzb2x2ZWQsIFJlc3VsdCB9IGZyb20gXCIuLi9yZXN1bHQuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbChcbiAgYTogYW55XG4pOiBhIGlzIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwge1xuICByZXR1cm4gaXNFdmVudHVhbE9mS2luZChFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwgYSk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbDxUID0gYW55PlxuICBleHRlbmRzIEV2ZW50dWFsQmFzZTxFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwgUmVzb2x2ZWQ+LFxuICAgIFNpZ25hbHNIYW5kbGVyIHtcbiAgc2VxPzogbnVtYmVyO1xuICBzaWduYWxJZDogc3RyaW5nO1xuICBoYW5kbGVyOiAoaW5wdXQ6IFQpID0+IFByb2dyYW0gfCB2b2lkO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbChcbiAgc2lnbmFsSWQ6IHN0cmluZyxcbiAgaGFuZGxlcjogUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbFtcImhhbmRsZXJcIl1cbik6IFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwge1xuICByZXR1cm4gcmVnaXN0ZXJFdmVudHVhbChcbiAgICBjcmVhdGVFdmVudHVhbChFdmVudHVhbEtpbmQuUmVnaXN0ZXJTaWduYWxIYW5kbGVyQ2FsbCwge1xuICAgICAgc2lnbmFsSWQ6IHNpZ25hbElkLFxuICAgICAgaGFuZGxlcixcbiAgICAgIGRpc3Bvc2U6IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgdGhpcy5yZXN1bHQgPSBSZXN1bHQucmVzb2x2ZWQodW5kZWZpbmVkKTtcbiAgICAgIH0sXG4gICAgfSlcbiAgKTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbmFsLWhhbmRsZXItY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy9zaWduYWwtaGFuZGxlci1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxjQUFjLEVBRWQsWUFBWSxFQUNaLGdCQUFnQixHQUNqQixNQUFNLGdCQUFnQixDQUFDO0FBRXhCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVoRCxPQUFPLEVBQVksTUFBTSxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBRWhELE1BQU0sVUFBVSwyQkFBMkIsQ0FDekMsQ0FBTTtJQUVOLE9BQU8sZ0JBQWdCLENBQUMsWUFBWSxDQUFDLHlCQUF5QixFQUFFLENBQUMsQ0FBQyxDQUFDO0FBQ3JFLENBQUM7QUFVRCxNQUFNLFVBQVUsK0JBQStCLENBQzdDLFFBQWdCLEVBQ2hCLE9BQTZDO0lBRTdDLE9BQU8sZ0JBQWdCLENBQ3JCLGNBQWMsQ0FBQyxZQUFZLENBQUMseUJBQXlCLEVBQUU7UUFDckQsUUFBUTtRQUNSLE9BQU87UUFDUCxPQUFPLEVBQUU7WUFDUCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsU0FBUyxDQUFDLENBQUM7UUFDM0MsQ0FBQztLQUNGLENBQUMsQ0FDSCxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGNyZWF0ZUV2ZW50dWFsLFxuICBFdmVudHVhbEJhc2UsXG4gIEV2ZW50dWFsS2luZCxcbiAgaXNFdmVudHVhbE9mS2luZCxcbn0gZnJvbSBcIi4uL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgeyBTaWduYWxzSGFuZGxlciB9IGZyb20gXCIuLi9zaWduYWxzLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlckV2ZW50dWFsIH0gZnJvbSBcIi4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgUHJvZ3JhbSB9IGZyb20gXCIuLi9pbnRlcnByZXQuanNcIjtcbmltcG9ydCB7IFJlc29sdmVkLCBSZXN1bHQgfSBmcm9tIFwiLi4vcmVzdWx0LmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1JlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwoXG4gIGE6IGFueVxuKTogYSBpcyBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIHtcbiAgcmV0dXJuIGlzRXZlbnR1YWxPZktpbmQoRXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIGEpO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGw8VCA9IGFueT5cbiAgZXh0ZW5kcyBFdmVudHVhbEJhc2U8RXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIFJlc29sdmVkPixcbiAgICBTaWduYWxzSGFuZGxlciB7XG4gIHNlcT86IG51bWJlcjtcbiAgc2lnbmFsSWQ6IHN0cmluZztcbiAgaGFuZGxlcjogKGlucHV0OiBUKSA9PiBQcm9ncmFtIHwgdm9pZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwoXG4gIHNpZ25hbElkOiBzdHJpbmcsXG4gIGhhbmRsZXI6IFJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGxbXCJoYW5kbGVyXCJdXG4pOiBSZWdpc3RlclNpZ25hbEhhbmRsZXJDYWxsIHtcbiAgcmV0dXJuIHJlZ2lzdGVyRXZlbnR1YWwoXG4gICAgY3JlYXRlRXZlbnR1YWwoRXZlbnR1YWxLaW5kLlJlZ2lzdGVyU2lnbmFsSGFuZGxlckNhbGwsIHtcbiAgICAgIHNpZ25hbElkLFxuICAgICAgaGFuZGxlcixcbiAgICAgIGRpc3Bvc2U6IGZ1bmN0aW9uICgpIHtcbiAgICAgICAgdGhpcy5yZXN1bHQgPSBSZXN1bHQucmVzb2x2ZWQodW5kZWZpbmVkKTtcbiAgICAgIH0sXG4gICAgfSlcbiAgKTtcbn1cbiJdfQ== |
@@ -76,2 +76,2 @@ export class EventualError extends Error { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWMsU0FBUSxLQUFLO0lBQ3RDLFlBQVksSUFBWSxFQUFFLE9BQWdCO1FBQ3hDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFDRDs7T0FFRztJQUNILE1BQU07UUFDSixPQUFPO1lBQ0wsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1NBQ3RCLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFDRCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsYUFBYTtJQUNqRCxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQyxrQkFBa0IsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFDRDs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSCxNQUFNLE9BQU8sT0FBUSxTQUFRLGFBQWE7SUFDeEMsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxPQUFPO0lBQzNDLFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxrQkFBa0IsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFDRDs7R0FFRztBQUNILE1BQU0sT0FBTyx5QkFBMEIsU0FBUSxhQUFhO0lBQzFELFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLDJCQUEyQixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzlDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBFdmVudHVhbEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICB9XG4gIC8qKlxuICAgKiBQcm92aWRlcyBhIHJlYXNvbmFibGUgZm9ybSB3aGVuIHJ1bm5pbmcgSlNPTi5zdHJpbmdpZnkuXG4gICAqL1xuICB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIG1lc3NhZ2U6IHRoaXMubWVzc2FnZSxcbiAgICB9O1xuICB9XG59XG5leHBvcnQgY2xhc3MgRGV0ZXJtaW5pc21FcnJvciBleHRlbmRzIEV2ZW50dWFsRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIoXCJEZXRlcm1pbmlzbUVycm9yXCIsIG1lc3NhZ2UpO1xuICB9XG59XG4vKipcbiAqIFRocm93biBmcm9tIHdpdGhpbiBhIHdvcmtmbG93IHdoZW4gYW55IHNldCB0aW1lb3V0IGV4cGlyZXMuXG4gKlxuICogYGBgdHNcbiAqIGNvbnN0IG15QWN0ID0gbmV3IGFjdGl2aXR5KFwibXlBY3RcIiwge3RpbWVvdXRTZWNvbmRzOiAxMDB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3QgdGltZSBvdXQhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IHRpbWVkIG91dCFcIjtcbiAqICAgICAgIH1cbiAqICAgICAgIHRocm93IGVycjtcbiAqICAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFRpbWVvdXQgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiVGltZW91dFwiLCBtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIFRocm93biB3aGVuIGFuIGFjdGl2aXR5IGZhaWxzIHRvIHNlbmQgaGVhcnRiZWF0cy5cbiAqXG4gKiBgYGB0c1xuICogY29uc3QgbXlBY3QgPSBuZXcgYWN0aXZpdHkoXCJteUFjdFwiLCB7aGVhcnRiZWF0U2Vjb25kczogMTB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGNvbXBsZXRlZCBzdWNjZXNzZnVsbHkhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIEhlYXJ0YmVhdFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3Qgc2VuZCBoZWFydGJlYXRzIVwiO1xuICogICAgICAgfVxuICogICAgICAgdGhyb3cgZXJyO1xuICogICAgfVxuICogfSlcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgSGVhcnRiZWF0VGltZW91dCBleHRlbmRzIFRpbWVvdXQge1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gXCJIZWFydGJlYXRUaW1lb3V0XCI7XG4gIH1cbn1cbi8qKlxuICogVGhyb3duIHdoZW4gYSBwYXJ0aWN1bGFyIGNvbnRleHQgb25seSBzdXBwb3J0IHN5bmNocm9ub3VzIG9wZXJhdGlvbnMgKGV4OiBjb25kaXRpb24gcHJlZGljYXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIFN5bmNocm9ub3VzT3BlcmF0aW9uRXJyb3IgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiU3luY2hyb25vdXNPcGVyYXRpb25FcnJvclwiLCBtZXNzYWdlKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXJyb3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGFBQWMsU0FBUSxLQUFLO0lBQ3RDLFlBQVksSUFBWSxFQUFFLE9BQWdCO1FBQ3hDLEtBQUssQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUNmLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ25CLENBQUM7SUFFRDs7T0FFRztJQUNJLE1BQU07UUFDWCxPQUFPO1lBQ0wsSUFBSSxFQUFFLElBQUksQ0FBQyxJQUFJO1lBQ2YsT0FBTyxFQUFFLElBQUksQ0FBQyxPQUFPO1NBQ3RCLENBQUM7SUFDSixDQUFDO0NBQ0Y7QUFDRCxNQUFNLE9BQU8sZ0JBQWlCLFNBQVEsYUFBYTtJQUNqRCxZQUFZLE9BQWdCO1FBQzFCLEtBQUssQ0FBQyxrQkFBa0IsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFDRDs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FpQkc7QUFDSCxNQUFNLE9BQU8sT0FBUSxTQUFRLGFBQWE7SUFDeEMsWUFBWSxPQUFnQjtRQUMxQixLQUFLLENBQUMsU0FBUyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzVCLENBQUM7Q0FDRjtBQUVEOzs7Ozs7Ozs7Ozs7Ozs7OztHQWlCRztBQUNILE1BQU0sT0FBTyxnQkFBaUIsU0FBUSxPQUFPO0lBQzNDLFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLE9BQU8sQ0FBQyxDQUFDO1FBQ2YsSUFBSSxDQUFDLElBQUksR0FBRyxrQkFBa0IsQ0FBQztJQUNqQyxDQUFDO0NBQ0Y7QUFDRDs7R0FFRztBQUNILE1BQU0sT0FBTyx5QkFBMEIsU0FBUSxhQUFhO0lBQzFELFlBQVksT0FBZ0I7UUFDMUIsS0FBSyxDQUFDLDJCQUEyQixFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzlDLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBFdmVudHVhbEVycm9yIGV4dGVuZHMgRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihuYW1lOiBzdHJpbmcsIG1lc3NhZ2U/OiBzdHJpbmcpIHtcbiAgICBzdXBlcihtZXNzYWdlKTtcbiAgICB0aGlzLm5hbWUgPSBuYW1lO1xuICB9XG5cbiAgLyoqXG4gICAqIFByb3ZpZGVzIGEgcmVhc29uYWJsZSBmb3JtIHdoZW4gcnVubmluZyBKU09OLnN0cmluZ2lmeS5cbiAgICovXG4gIHB1YmxpYyB0b0pTT04oKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIG5hbWU6IHRoaXMubmFtZSxcbiAgICAgIG1lc3NhZ2U6IHRoaXMubWVzc2FnZSxcbiAgICB9O1xuICB9XG59XG5leHBvcnQgY2xhc3MgRGV0ZXJtaW5pc21FcnJvciBleHRlbmRzIEV2ZW50dWFsRXJyb3Ige1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIoXCJEZXRlcm1pbmlzbUVycm9yXCIsIG1lc3NhZ2UpO1xuICB9XG59XG4vKipcbiAqIFRocm93biBmcm9tIHdpdGhpbiBhIHdvcmtmbG93IHdoZW4gYW55IHNldCB0aW1lb3V0IGV4cGlyZXMuXG4gKlxuICogYGBgdHNcbiAqIGNvbnN0IG15QWN0ID0gbmV3IGFjdGl2aXR5KFwibXlBY3RcIiwge3RpbWVvdXRTZWNvbmRzOiAxMDB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3QgdGltZSBvdXQhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IHRpbWVkIG91dCFcIjtcbiAqICAgICAgIH1cbiAqICAgICAgIHRocm93IGVycjtcbiAqICAgIH1cbiAqIH0pXG4gKiBgYGBcbiAqL1xuZXhwb3J0IGNsYXNzIFRpbWVvdXQgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiVGltZW91dFwiLCBtZXNzYWdlKTtcbiAgfVxufVxuXG4vKipcbiAqIFRocm93biB3aGVuIGFuIGFjdGl2aXR5IGZhaWxzIHRvIHNlbmQgaGVhcnRiZWF0cy5cbiAqXG4gKiBgYGB0c1xuICogY29uc3QgbXlBY3QgPSBuZXcgYWN0aXZpdHkoXCJteUFjdFwiLCB7aGVhcnRiZWF0U2Vjb25kczogMTB9LCBhc3luYyAoKSA9PiB7IC4uLiB9KTtcbiAqIHdvcmtmbG93KFwibXlXb3JrZmxvd1wiLCBhc3luYyAoKSA9PiB7XG4gKiAgICB0cnkge1xuICogICAgICAgYXdhaXQgbXlBY3QoKTtcbiAqICAgICAgIHJldHVybiBcImFjdGl2aXR5IGNvbXBsZXRlZCBzdWNjZXNzZnVsbHkhXCI7XG4gKiAgICB9IGNhdGNoIChlcnIpIHtcbiAqICAgICAgIGlmKGVyciBpbnN0YW5jZW9mIEhlYXJ0YmVhdFRpbWVvdXQpIHtcbiAqICAgICAgICAgIHJldHVybiBcImFjdGl2aXR5IGRpZCBub3Qgc2VuZCBoZWFydGJlYXRzIVwiO1xuICogICAgICAgfVxuICogICAgICAgdGhyb3cgZXJyO1xuICogICAgfVxuICogfSlcbiAqIGBgYFxuICovXG5leHBvcnQgY2xhc3MgSGVhcnRiZWF0VGltZW91dCBleHRlbmRzIFRpbWVvdXQge1xuICBjb25zdHJ1Y3RvcihtZXNzYWdlPzogc3RyaW5nKSB7XG4gICAgc3VwZXIobWVzc2FnZSk7XG4gICAgdGhpcy5uYW1lID0gXCJIZWFydGJlYXRUaW1lb3V0XCI7XG4gIH1cbn1cbi8qKlxuICogVGhyb3duIHdoZW4gYSBwYXJ0aWN1bGFyIGNvbnRleHQgb25seSBzdXBwb3J0IHN5bmNocm9ub3VzIG9wZXJhdGlvbnMgKGV4OiBjb25kaXRpb24gcHJlZGljYXRlKS5cbiAqL1xuZXhwb3J0IGNsYXNzIFN5bmNocm9ub3VzT3BlcmF0aW9uRXJyb3IgZXh0ZW5kcyBFdmVudHVhbEVycm9yIHtcbiAgY29uc3RydWN0b3IobWVzc2FnZT86IHN0cmluZykge1xuICAgIHN1cGVyKFwiU3luY2hyb25vdXNPcGVyYXRpb25FcnJvclwiLCBtZXNzYWdlKTtcbiAgfVxufVxuIl19 |
import { ActivityCall } from "./calls/activity-call.js"; | ||
import { AwaitAll } from "./await-all.js"; | ||
import { Chain } from "./chain.js"; | ||
import { chain, Chain } from "./chain.js"; | ||
import type { Program } from "./interpret.js"; | ||
@@ -47,3 +47,3 @@ import { Result } from "./result.js"; | ||
export declare function isCommandCall(call: Eventual): call is CommandCall; | ||
export declare namespace Eventual { | ||
export declare const Eventual: { | ||
/** | ||
@@ -54,7 +54,7 @@ * Wait for all {@link activities} to complete or until at least one throws. | ||
*/ | ||
function all<A extends Eventual[]>(activities: A): AwaitAll<EventualArrayPositional<A>>; | ||
function any<A extends Eventual[]>(activities: A): AwaitAny<EventualArrayUnion<A>>; | ||
function race<A extends Eventual[]>(activities: A): Race<EventualArrayUnion<A>>; | ||
function allSettled<A extends Eventual[]>(activities: A): AwaitAllSettled<EventualArrayPromiseResult<A>>; | ||
} | ||
all<A extends Eventual<any>[]>(activities: A): AwaitAll<EventualArrayPositional<A>>; | ||
any<A_1 extends Eventual<any>[]>(activities: A_1): AwaitAny<EventualArrayUnion<A_1>>; | ||
race<A_2 extends Eventual<any>[]>(activities: A_2): Race<EventualArrayUnion<A_2>>; | ||
allSettled<A_3 extends Eventual<any>[]>(activities: A_3): AwaitAllSettled<EventualArrayPromiseResult<A_3>>; | ||
}; | ||
export interface EventualCallCollector { | ||
@@ -70,3 +70,7 @@ pushEventual<E extends Eventual>(activity: E): E; | ||
export type EventualArrayUnion<A extends Eventual<any>[]> = A[number] extends Eventual<infer T> ? T : never; | ||
declare global { | ||
var $eventual: typeof chain; | ||
var $Eventual: typeof Eventual; | ||
} | ||
export {}; | ||
//# sourceMappingURL=eventual.d.ts.map |
@@ -54,4 +54,3 @@ import { isActivityCall } from "./calls/activity-call.js"; | ||
} | ||
export var Eventual; | ||
(function (Eventual) { | ||
export const Eventual = { | ||
/** | ||
@@ -62,3 +61,3 @@ * Wait for all {@link activities} to complete or until at least one throws. | ||
*/ | ||
function all(activities) { | ||
all(activities) { | ||
if (!isOrchestratorWorker()) { | ||
@@ -68,5 +67,4 @@ throw new Error("Eventual.all is only valid in a workflow"); | ||
return createAwaitAll(activities); | ||
} | ||
Eventual.all = all; | ||
function any(activities) { | ||
}, | ||
any(activities) { | ||
if (!isOrchestratorWorker()) { | ||
@@ -76,5 +74,4 @@ throw new Error("Eventual.any is only valid in a workflow"); | ||
return createAwaitAny(activities); | ||
} | ||
Eventual.any = any; | ||
function race(activities) { | ||
}, | ||
race(activities) { | ||
if (!isOrchestratorWorker()) { | ||
@@ -84,5 +81,4 @@ throw new Error("Eventual.race is only valid in a workflow"); | ||
return createRace(activities); | ||
} | ||
Eventual.race = race; | ||
function allSettled(activities) { | ||
}, | ||
allSettled(activities) { | ||
if (!isOrchestratorWorker()) { | ||
@@ -92,10 +88,6 @@ throw new Error("Eventual.allSettled is only valid in a workflow"); | ||
return createAwaitAllSettled(activities); | ||
} | ||
Eventual.allSettled = allSettled; | ||
})(Eventual || (Eventual = {})); | ||
// the below globals are required by the transformer | ||
// @ts-ignore | ||
}, | ||
}; | ||
global.$eventual = chain; | ||
// @ts-ignore | ||
global.$Eventual = Eventual; | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventual.js","sourceRoot":"","sources":["../../src/eventual.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivityCall, isActivityCall } from \"./calls/activity-call.js\";\nimport { AwaitAll, createAwaitAll } from \"./await-all.js\";\nimport { chain, Chain } from \"./chain.js\";\nimport type { Program } from \"./interpret.js\";\nimport { Result } from \"./result.js\";\nimport {\n  isSleepForCall,\n  isSleepUntilCall,\n  SleepForCall,\n  SleepUntilCall,\n} from \"./calls/sleep-call.js\";\nimport {\n  isExpectSignalCall,\n  ExpectSignalCall,\n} from \"./calls/expect-signal-call.js\";\nimport {\n  isRegisterSignalHandlerCall,\n  RegisterSignalHandlerCall,\n} from \"./calls/signal-handler-call.js\";\nimport { isSendSignalCall, SendSignalCall } from \"./calls/send-signal-call.js\";\nimport { isWorkflowCall, WorkflowCall } from \"./calls/workflow-call.js\";\nimport { ConditionCall, isConditionCall } from \"./calls/condition-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { AwaitAny, createAwaitAny } from \"./await-any.js\";\nimport { AwaitAllSettled, createAwaitAllSettled } from \"./await-all-settled.js\";\nimport { createRace, Race } from \"./race.js\";\nimport {\n  isPublishEventsCall,\n  PublishEventsCall,\n} from \"./calls/send-events-call.js\";\n\nexport type AwaitedEventual<T> = T extends Promise<infer U>\n  ? Awaited<U>\n  : T extends Program<infer U>\n  ? AwaitedEventual<U>\n  : T extends Eventual<infer U>\n  ? AwaitedEventual<U>\n  : T;\n\nconst EventualSymbol = Symbol.for(\"eventual:Eventual\");\n\nexport interface EventualBase<Kind extends EventualKind, R extends Result> {\n  [EventualSymbol]: Kind;\n  result?: R;\n}\n\nexport enum EventualKind {\n  ActivityCall = 1,\n  AwaitAll = 0,\n  AwaitAllSettled = 12,\n  AwaitAny = 10,\n  Chain = 2,\n  ConditionCall = 9,\n  ExpectSignalCall = 6,\n  PublishEventsCall = 13,\n  Race = 11,\n  RegisterSignalHandlerCall = 7,\n  SendSignalCall = 8,\n  SleepForCall = 3,\n  SleepUntilCall = 4,\n  WorkflowCall = 5,\n}\n\nexport function isEventual(a: any): a is Eventual {\n  return a && typeof a === \"object\" && EventualSymbol in a;\n}\n\nexport function isEventualOfKind<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  a: any\n): a is E {\n  return isEventual(a) && a[EventualSymbol] === kind;\n}\n\nexport function createEventual<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  e: Omit<E, typeof EventualSymbol>\n): E {\n  (e as E)[EventualSymbol] = kind;\n  return e as E;\n}\n\nexport type Eventual<T = any> =\n  | AwaitAll<T extends any[] ? T : never>\n  | AwaitAllSettled<T extends any[] ? T : never>\n  | AwaitAny<T extends any[] ? T : never>\n  | Chain<T>\n  | CommandCall<T>\n  | Race<T extends any[] ? T : never>;\n\n/**\n * Calls which emit commands.\n */\nexport type CommandCall<T = any> =\n  | ActivityCall<T>\n  | ConditionCall\n  | ExpectSignalCall<T>\n  | RegisterSignalHandlerCall<T>\n  | PublishEventsCall\n  | SendSignalCall\n  | SleepForCall\n  | SleepUntilCall\n  | WorkflowCall<T>;\n\nexport function isCommandCall(call: Eventual): call is CommandCall {\n  return (\n    isActivityCall(call) ||\n    isConditionCall(call) ||\n    isExpectSignalCall(call) ||\n    isPublishEventsCall(call) ||\n    isRegisterSignalHandlerCall(call) ||\n    isSendSignalCall(call) ||\n    isSleepForCall(call) ||\n    isSleepUntilCall(call) ||\n    isWorkflowCall(call)\n  );\n}\n\nexport namespace Eventual {\n  /**\n   * Wait for all {@link activities} to complete or until at least one throws.\n   *\n   * This is the equivalent behavior to Promise.all.\n   */\n  export function all<A extends Eventual[]>(\n    activities: A\n  ): AwaitAll<EventualArrayPositional<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.all is only valid in a workflow\");\n    }\n\n    return createAwaitAll(activities) as any;\n  }\n\n  export function any<A extends Eventual[]>(\n    activities: A\n  ): AwaitAny<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.any is only valid in a workflow\");\n    }\n\n    return createAwaitAny(activities) as any;\n  }\n\n  export function race<A extends Eventual[]>(\n    activities: A\n  ): Race<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.race is only valid in a workflow\");\n    }\n\n    return createRace(activities) as any;\n  }\n\n  export function allSettled<A extends Eventual[]>(\n    activities: A\n  ): AwaitAllSettled<EventualArrayPromiseResult<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.allSettled is only valid in a workflow\");\n    }\n\n    return createAwaitAllSettled(activities) as any;\n  }\n}\n\nexport interface EventualCallCollector {\n  pushEventual<E extends Eventual>(activity: E): E;\n}\n\nexport type EventualArrayPositional<A extends Eventual[]> = {\n  [i in keyof A]: A[i] extends Eventual<infer T> ? T : A[i];\n};\n\nexport type EventualArrayPromiseResult<A extends Eventual[]> = {\n  [i in keyof A]:\n    | PromiseFulfilledResult<A[i] extends Eventual<infer T> ? T : A[i]>\n    | PromiseRejectedResult;\n};\n\nexport type EventualArrayUnion<A extends Eventual<any>[]> =\n  A[number] extends Eventual<infer T> ? T : never;\n\n// the below globals are required by the transformer\n\n// @ts-ignore\nglobal.$eventual = chain;\n// @ts-ignore\nglobal.$Eventual = Eventual;\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventual.js","sourceRoot":"","sources":["../../src/eventual.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivityCall, isActivityCall } from \"./calls/activity-call.js\";\nimport { AwaitAll, createAwaitAll } from \"./await-all.js\";\nimport { chain, Chain } from \"./chain.js\";\nimport type { Program } from \"./interpret.js\";\nimport { Result } from \"./result.js\";\nimport {\n  isSleepForCall,\n  isSleepUntilCall,\n  SleepForCall,\n  SleepUntilCall,\n} from \"./calls/sleep-call.js\";\nimport {\n  isExpectSignalCall,\n  ExpectSignalCall,\n} from \"./calls/expect-signal-call.js\";\nimport {\n  isRegisterSignalHandlerCall,\n  RegisterSignalHandlerCall,\n} from \"./calls/signal-handler-call.js\";\nimport { isSendSignalCall, SendSignalCall } from \"./calls/send-signal-call.js\";\nimport { isWorkflowCall, WorkflowCall } from \"./calls/workflow-call.js\";\nimport { ConditionCall, isConditionCall } from \"./calls/condition-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { AwaitAny, createAwaitAny } from \"./await-any.js\";\nimport { AwaitAllSettled, createAwaitAllSettled } from \"./await-all-settled.js\";\nimport { createRace, Race } from \"./race.js\";\nimport {\n  isPublishEventsCall,\n  PublishEventsCall,\n} from \"./calls/send-events-call.js\";\n\nexport type AwaitedEventual<T> = T extends Promise<infer U>\n  ? Awaited<U>\n  : T extends Program<infer U>\n  ? AwaitedEventual<U>\n  : T extends Eventual<infer U>\n  ? AwaitedEventual<U>\n  : T;\n\nconst EventualSymbol = Symbol.for(\"eventual:Eventual\");\n\nexport interface EventualBase<Kind extends EventualKind, R extends Result> {\n  [EventualSymbol]: Kind;\n  result?: R;\n}\n\nexport enum EventualKind {\n  ActivityCall = 1,\n  AwaitAll = 0,\n  AwaitAllSettled = 12,\n  AwaitAny = 10,\n  Chain = 2,\n  ConditionCall = 9,\n  ExpectSignalCall = 6,\n  PublishEventsCall = 13,\n  Race = 11,\n  RegisterSignalHandlerCall = 7,\n  SendSignalCall = 8,\n  SleepForCall = 3,\n  SleepUntilCall = 4,\n  WorkflowCall = 5,\n}\n\nexport function isEventual(a: any): a is Eventual {\n  return a && typeof a === \"object\" && EventualSymbol in a;\n}\n\nexport function isEventualOfKind<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  a: any\n): a is E {\n  return isEventual(a) && a[EventualSymbol] === kind;\n}\n\nexport function createEventual<E extends Eventual>(\n  kind: E[typeof EventualSymbol],\n  e: Omit<E, typeof EventualSymbol>\n): E {\n  (e as E)[EventualSymbol] = kind;\n  return e as E;\n}\n\nexport type Eventual<T = any> =\n  | AwaitAll<T extends any[] ? T : never>\n  | AwaitAllSettled<T extends any[] ? T : never>\n  | AwaitAny<T extends any[] ? T : never>\n  | Chain<T>\n  | CommandCall<T>\n  | Race<T extends any[] ? T : never>;\n\n/**\n * Calls which emit commands.\n */\nexport type CommandCall<T = any> =\n  | ActivityCall<T>\n  | ConditionCall\n  | ExpectSignalCall<T>\n  | RegisterSignalHandlerCall<T>\n  | PublishEventsCall\n  | SendSignalCall\n  | SleepForCall\n  | SleepUntilCall\n  | WorkflowCall<T>;\n\nexport function isCommandCall(call: Eventual): call is CommandCall {\n  return (\n    isActivityCall(call) ||\n    isConditionCall(call) ||\n    isExpectSignalCall(call) ||\n    isPublishEventsCall(call) ||\n    isRegisterSignalHandlerCall(call) ||\n    isSendSignalCall(call) ||\n    isSleepForCall(call) ||\n    isSleepUntilCall(call) ||\n    isWorkflowCall(call)\n  );\n}\n\nexport const Eventual = {\n  /**\n   * Wait for all {@link activities} to complete or until at least one throws.\n   *\n   * This is the equivalent behavior to Promise.all.\n   */\n  all<A extends Eventual[]>(\n    activities: A\n  ): AwaitAll<EventualArrayPositional<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.all is only valid in a workflow\");\n    }\n\n    return createAwaitAll(activities) as any;\n  },\n  any<A extends Eventual[]>(activities: A): AwaitAny<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.any is only valid in a workflow\");\n    }\n\n    return createAwaitAny(activities) as any;\n  },\n  race<A extends Eventual[]>(activities: A): Race<EventualArrayUnion<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.race is only valid in a workflow\");\n    }\n\n    return createRace(activities) as any;\n  },\n  allSettled<A extends Eventual[]>(\n    activities: A\n  ): AwaitAllSettled<EventualArrayPromiseResult<A>> {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\"Eventual.allSettled is only valid in a workflow\");\n    }\n\n    return createAwaitAllSettled(activities) as any;\n  },\n};\n\nexport interface EventualCallCollector {\n  pushEventual<E extends Eventual>(activity: E): E;\n}\n\nexport type EventualArrayPositional<A extends Eventual[]> = {\n  [i in keyof A]: A[i] extends Eventual<infer T> ? T : A[i];\n};\n\nexport type EventualArrayPromiseResult<A extends Eventual[]> = {\n  [i in keyof A]:\n    | PromiseFulfilledResult<A[i] extends Eventual<infer T> ? T : A[i]>\n    | PromiseRejectedResult;\n};\n\nexport type EventualArrayUnion<A extends Eventual<any>[]> =\n  A[number] extends Eventual<infer T> ? T : never;\n\n// the below globals are required by the transformer\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var $eventual: typeof chain;\n  // eslint-disable-next-line no-var\n  var $Eventual: typeof Eventual;\n}\n\nglobal.$eventual = chain;\nglobal.$Eventual = Eventual;\n"]} |
@@ -64,2 +64,2 @@ globalThis._eventual = {}; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":"AAuDA,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;AAE1B,MAAM,CAAC,MAAM,SAAS,GAAG,GAA0B,EAAE,CACnD,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,KAAK,IAAI,GAAG,EAAoB,CAAC,CAAC;AAEnE,MAAM,CAAC,MAAM,MAAM,GAAG,GAAuB,EAAE,CAC7C,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,GAAG,EAAiB,CAAC,CAAC;AAE7D,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAwB,EAAE,CAC1D,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAyC,EAAE,CAC3E,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,iBAAiB,GAAG,GAA0B,EAAE;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,iBAAiB,CAAC;IACzD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,UAAU,gBAAgB,CAAqB,QAAW;IAC9D,OAAO,iBAAiB,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,SAAgC;IACnE,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,sBAAsB;IACpC,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,MAAsB;IAC3D,UAAU,CAAC,SAAS,CAAC,cAAc,GAAG,MAAM,CAAC;AAC/C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,UAAU,CAAC,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,cAAc,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAAwB;IACzD,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,eAAe,CAAC;IAErD,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAC;KACH;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAmB;IACrD,UAAU,CAAC,SAAS,CAAC,WAAW,GAAG,MAAM,CAAC;AAC5C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc;IAC5B,IAAI,UAAU,CAAC,SAAS,CAAC,WAAW,KAAK,SAAS,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,WAAW,CAAC;AAC1C,CAAC","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":"AAwDA,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;AAE1B,MAAM,CAAC,MAAM,SAAS,GAAG,GAA0B,EAAE,CACnD,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,KAAK,IAAI,GAAG,EAAoB,CAAC,CAAC;AAEnE,MAAM,CAAC,MAAM,MAAM,GAAG,GAAuB,EAAE,CAC7C,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,GAAG,EAAiB,CAAC,CAAC;AAE7D,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAwB,EAAE,CAC1D,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAyC,EAAE,CAC3E,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,iBAAiB,GAAG,GAA0B,EAAE;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,iBAAiB,CAAC;IACzD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,UAAU,gBAAgB,CAAqB,QAAW;IAC9D,OAAO,iBAAiB,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,SAAgC;IACnE,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,sBAAsB;IACpC,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,MAAsB;IAC3D,UAAU,CAAC,SAAS,CAAC,cAAc,GAAG,MAAM,CAAC;AAC/C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,UAAU,CAAC,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,cAAc,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAAwB;IACzD,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,eAAe,CAAC;IAErD,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAC;KACH;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAmB;IACrD,UAAU,CAAC,SAAS,CAAC,WAAW,GAAG,MAAM,CAAC;AAC5C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc;IAC5B,IAAI,UAAU,CAAC,SAAS,CAAC,WAAW,KAAK,SAAS,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,WAAW,CAAC;AAC1C,CAAC","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]} |
@@ -19,3 +19,3 @@ import { getActivityContext, getWorkflowClient } from "./global.js"; | ||
return await getWorkflowClient().heartbeatActivity({ | ||
activityToken: activityToken, | ||
activityToken, | ||
}); | ||
@@ -33,2 +33,2 @@ } | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksb0JBQW9CLEVBQUUsRUFBRTtRQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLGtHQUFrRyxDQUNuRyxDQUFDO0tBQ0g7U0FBTSxJQUFJLGFBQWEsRUFBRTtRQUN4QixPQUFPLE1BQU0saUJBQWlCLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztZQUNqRCxhQUFhLEVBQUUsYUFBYTtTQUM3QixDQUFDLENBQUM7S0FDSjtTQUFNLElBQUksZ0JBQWdCLEVBQUUsRUFBRTtRQUM3QixNQUFNLEtBQUssR0FBRyxrQkFBa0IsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0saUJBQWlCLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztZQUNqRCxhQUFhLEVBQUUsS0FBSztTQUNyQixDQUFDLENBQUM7S0FDSjtTQUFNO1FBQ0wsTUFBTSxJQUFJLEtBQUssQ0FDYiw4REFBOEQsQ0FDL0QsQ0FBQztLQUNIO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0V29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IEhlYXJ0YmVhdFJlc3BvbnNlIH0gZnJvbSBcIi4vcnVudGltZS9jbGllbnRzL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBjb21wbGV0ZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBoZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksb0JBQW9CLEVBQUUsRUFBRTtRQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLGtHQUFrRyxDQUNuRyxDQUFDO0tBQ0g7U0FBTSxJQUFJLGFBQWEsRUFBRTtRQUN4QixPQUFPLE1BQU0saUJBQWlCLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztZQUNqRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLGdCQUFnQixFQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDakQsT0FBTyxNQUFNLGlCQUFpQixFQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRBY3Rpdml0eUNvbnRleHQsIGdldFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBIZWFydGJlYXRSZXNwb25zZSB9IGZyb20gXCIuL3J1bnRpbWUvY2xpZW50cy93b3JrZmxvdy1jbGllbnQuanNcIjtcbmltcG9ydCB7IGlzQWN0aXZpdHlXb3JrZXIsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vcnVudGltZS9mbGFncy5qc1wiO1xuXG4vKipcbiAqIFNlbmRzIGEgaGVhcnRiZWF0IGZvciB0aGUgY3VycmVudCBhY3Rpdml0eSBvciB0byB0aGUgcHJvdmlkZWQgYWN0aXZpdHkgdG9rZW4uXG4gKlxuICogSWYgY2FsbGVkIGZyb20gb3V0c2lkZSBvZiBhbiB7QGxpbmsgYWN0aXZpdHl9LCB0aGUgYWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZC5cbiAqXG4gKiBJZiB0aGUgYWN0aXZpdHkgaGFzIGEgaGVhcnRiZWF0VGltZW91dCBzZXQgYW5kIHRoZSB3b3JrZmxvdyBoYXMgbm90IHJlY2VpdmVkIGEgaGVhcnRiZWF0IGluIGhlYXJ0YmVhdFRpbWVvdXRTZWNvbmRzLFxuICogdGhlIHdvcmtmbG93IHdpbGwgdGhyb3cgYSB7QGxpbmsgSGVhcnRiZWF0VGltZW91dH0gYW5kIGNhbmNlbCB0aGUgYWN0aXZpdHkuXG4gKlxuICogQHJldHVybnMge0BsaW5rIEhlYXJ0YmVhdFJlc3BvbnNlfSB3aGljaCBoYXMgcmVzcG9uc2UuY2FuY2VsbGVkIGlmIHRoZSBhY3Rpdml0eSB3YXMgY2FuY2VsbGVkIGZvciBhbnkgcmVhc29uIChleDogd29ya2Zsb3cgY29tcGxldGVkLCBmYWlsZWQsIG9yIHRoZSBhY3Rpdml0eSB0aW1lZCBvdXQpLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaGVhcnRiZWF0KFxuICBhY3Rpdml0eVRva2VuPzogc3RyaW5nXG4pOiBQcm9taXNlPEhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJIZWFydGJlYXQgaXMgbm90IGN1cnJlbnRseSBzdXBwb3J0ZWQgZnJvbSB3aXRoaW4gYSB3b3JrZmxvdy4gVXNlIGFuIGFjdGl2aXR5IHdpdGggYGhlYXJ0YmVhdCgpYC5cIlxuICAgICk7XG4gIH0gZWxzZSBpZiAoYWN0aXZpdHlUb2tlbikge1xuICAgIHJldHVybiBhd2FpdCBnZXRXb3JrZmxvd0NsaWVudCgpLmhlYXJ0YmVhdEFjdGl2aXR5KHtcbiAgICAgIGFjdGl2aXR5VG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSBpZiAoaXNBY3Rpdml0eVdvcmtlcigpKSB7XG4gICAgY29uc3QgdG9rZW4gPSBnZXRBY3Rpdml0eUNvbnRleHQoKS5hY3Rpdml0eVRva2VuO1xuICAgIHJldHVybiBhd2FpdCBnZXRXb3JrZmxvd0NsaWVudCgpLmhlYXJ0YmVhdEFjdGl2aXR5KHtcbiAgICAgIGFjdGl2aXR5VG9rZW46IHRva2VuLFxuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZCB3aGVuIG5vdCB3aXRoaW4gYW4gQWN0aXZpdHkuXCJcbiAgICApO1xuICB9XG59XG4iXX0= |
import { Eventual } from "./eventual.js"; | ||
export declare const ResultSymbol: unique symbol; | ||
export type Result<T = any> = Pending | Resolved<T> | Failed; | ||
export declare namespace Result { | ||
function resolved<T>(value: T): Resolved<T>; | ||
function failed(error: any): Failed; | ||
function pending<A extends Eventual>(activity: A): Pending<A>; | ||
} | ||
export declare const Result: { | ||
resolved<T>(value: T): Resolved<T>; | ||
failed(error: any): Failed; | ||
pending<A extends Eventual<any>>(activity: A): Pending<A>; | ||
}; | ||
export declare enum ResultKind { | ||
@@ -10,0 +10,0 @@ Pending = 0, |
import { or } from "./util.js"; | ||
export const ResultSymbol = Symbol.for("eventual:Result"); | ||
export var Result; | ||
(function (Result) { | ||
function resolved(value) { | ||
export const Result = { | ||
resolved(value) { | ||
return { | ||
@@ -10,5 +9,4 @@ [ResultSymbol]: ResultKind.Resolved, | ||
}; | ||
} | ||
Result.resolved = resolved; | ||
function failed(error) { | ||
}, | ||
failed(error) { | ||
return { | ||
@@ -18,5 +16,4 @@ [ResultSymbol]: ResultKind.Failed, | ||
}; | ||
} | ||
Result.failed = failed; | ||
function pending(activity) { | ||
}, | ||
pending(activity) { | ||
return { | ||
@@ -26,5 +23,4 @@ [ResultSymbol]: ResultKind.Pending, | ||
}; | ||
} | ||
Result.pending = pending; | ||
})(Result || (Result = {})); | ||
}, | ||
}; | ||
export var ResultKind; | ||
@@ -49,2 +45,2 @@ (function (ResultKind) { | ||
export const isResolvedOrFailed = or(isResolved, isFailed); | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Jlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFJMUQsTUFBTSxLQUFXLE1BQU0sQ0FxQnRCO0FBckJELFdBQWlCLE1BQU07SUFDckIsU0FBZ0IsUUFBUSxDQUFJLEtBQVE7UUFDbEMsT0FBTztZQUNMLENBQUMsWUFBWSxDQUFDLEVBQUUsVUFBVSxDQUFDLFFBQVE7WUFDbkMsS0FBSztTQUNOLENBQUM7SUFDSixDQUFDO0lBTGUsZUFBUSxXQUt2QixDQUFBO0lBRUQsU0FBZ0IsTUFBTSxDQUFDLEtBQVU7UUFDL0IsT0FBTztZQUNMLENBQUMsWUFBWSxDQUFDLEVBQUUsVUFBVSxDQUFDLE1BQU07WUFDakMsS0FBSztTQUNOLENBQUM7SUFDSixDQUFDO0lBTGUsYUFBTSxTQUtyQixDQUFBO0lBRUQsU0FBZ0IsT0FBTyxDQUFxQixRQUFXO1FBQ3JELE9BQU87WUFDTCxDQUFDLFlBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxPQUFPO1lBQ2xDLFFBQVE7U0FDVCxDQUFDO0lBQ0osQ0FBQztJQUxlLGNBQU8sVUFLdEIsQ0FBQTtBQUNILENBQUMsRUFyQmdCLE1BQU0sS0FBTixNQUFNLFFBcUJ0QjtBQUVELE1BQU0sQ0FBTixJQUFZLFVBSVg7QUFKRCxXQUFZLFVBQVU7SUFDcEIsaURBQVcsQ0FBQTtJQUNYLG1EQUFZLENBQUE7SUFDWiwrQ0FBVSxDQUFBO0FBQ1osQ0FBQyxFQUpXLFVBQVUsS0FBVixVQUFVLFFBSXJCO0FBaUJELE1BQU0sVUFBVSxRQUFRLENBQUMsQ0FBTTtJQUM3QixPQUFPLENBQUMsSUFBSSxPQUFPLENBQUMsS0FBSyxRQUFRLElBQUksWUFBWSxJQUFJLENBQUMsQ0FBQztBQUN6RCxDQUFDO0FBRUQsTUFBTSxVQUFVLFNBQVMsQ0FBQyxNQUEwQjtJQUNsRCxPQUFPLFFBQVEsQ0FBQyxNQUFNLENBQUMsSUFBSSxNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssVUFBVSxDQUFDLE9BQU8sQ0FBQztBQUN6RSxDQUFDO0FBRUQsTUFBTSxVQUFVLFVBQVUsQ0FDeEIsTUFBNkI7SUFFN0IsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxRQUFRLENBQUM7QUFDMUUsQ0FBQztBQUVELE1BQU0sVUFBVSxRQUFRLENBQUMsTUFBMEI7SUFDakQsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxNQUFNLENBQUM7QUFDeEUsQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLEVBQUUsQ0FBQyxVQUFVLEVBQUUsUUFBUSxDQUFDLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudHVhbCB9IGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgeyBvciB9IGZyb20gXCIuL3V0aWwuanNcIjtcblxuZXhwb3J0IGNvbnN0IFJlc3VsdFN5bWJvbCA9IFN5bWJvbC5mb3IoXCJldmVudHVhbDpSZXN1bHRcIik7XG5cbmV4cG9ydCB0eXBlIFJlc3VsdDxUID0gYW55PiA9IFBlbmRpbmcgfCBSZXNvbHZlZDxUPiB8IEZhaWxlZDtcblxuZXhwb3J0IG5hbWVzcGFjZSBSZXN1bHQge1xuICBleHBvcnQgZnVuY3Rpb24gcmVzb2x2ZWQ8VD4odmFsdWU6IFQpOiBSZXNvbHZlZDxUPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlJlc29sdmVkLFxuICAgICAgdmFsdWUsXG4gICAgfTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBmYWlsZWQoZXJyb3I6IGFueSk6IEZhaWxlZCB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLkZhaWxlZCxcbiAgICAgIGVycm9yLFxuICAgIH07XG4gIH1cblxuICBleHBvcnQgZnVuY3Rpb24gcGVuZGluZzxBIGV4dGVuZHMgRXZlbnR1YWw+KGFjdGl2aXR5OiBBKTogUGVuZGluZzxBPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlBlbmRpbmcsXG4gICAgICBhY3Rpdml0eSxcbiAgICB9O1xuICB9XG59XG5cbmV4cG9ydCBlbnVtIFJlc3VsdEtpbmQge1xuICBQZW5kaW5nID0gMCxcbiAgUmVzb2x2ZWQgPSAxLFxuICBGYWlsZWQgPSAyLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIFBlbmRpbmc8QSBleHRlbmRzIEV2ZW50dWFsID0gRXZlbnR1YWw+IHtcbiAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuUGVuZGluZztcbiAgYWN0aXZpdHk6IEE7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVzb2x2ZWQ8VCA9IGFueT4ge1xuICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5SZXNvbHZlZDtcbiAgdmFsdWU6IFQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkIHtcbiAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuRmFpbGVkO1xuICBlcnJvcjogYW55O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXN1bHQoYTogYW55KTogYSBpcyBSZXN1bHQge1xuICByZXR1cm4gYSAmJiB0eXBlb2YgYSA9PT0gXCJvYmplY3RcIiAmJiBSZXN1bHRTeW1ib2wgaW4gYTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUGVuZGluZyhyZXN1bHQ6IFJlc3VsdCB8IHVuZGVmaW5lZCk6IHJlc3VsdCBpcyBQZW5kaW5nIHtcbiAgcmV0dXJuIGlzUmVzdWx0KHJlc3VsdCkgJiYgcmVzdWx0W1Jlc3VsdFN5bWJvbF0gPT09IFJlc3VsdEtpbmQuUGVuZGluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzUmVzb2x2ZWQ8VD4oXG4gIHJlc3VsdDogUmVzdWx0PFQ+IHwgdW5kZWZpbmVkXG4pOiByZXN1bHQgaXMgUmVzb2x2ZWQ8VD4ge1xuICByZXR1cm4gaXNSZXN1bHQocmVzdWx0KSAmJiByZXN1bHRbUmVzdWx0U3ltYm9sXSA9PT0gUmVzdWx0S2luZC5SZXNvbHZlZDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkKHJlc3VsdDogUmVzdWx0IHwgdW5kZWZpbmVkKTogcmVzdWx0IGlzIEZhaWxlZCB7XG4gIHJldHVybiBpc1Jlc3VsdChyZXN1bHQpICYmIHJlc3VsdFtSZXN1bHRTeW1ib2xdID09PSBSZXN1bHRLaW5kLkZhaWxlZDtcbn1cblxuZXhwb3J0IGNvbnN0IGlzUmVzb2x2ZWRPckZhaWxlZCA9IG9yKGlzUmVzb2x2ZWQsIGlzRmFpbGVkKTtcbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVzdWx0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3Jlc3VsdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsRUFBRSxFQUFFLE1BQU0sV0FBVyxDQUFDO0FBRS9CLE1BQU0sQ0FBQyxNQUFNLFlBQVksR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFJMUQsTUFBTSxDQUFDLE1BQU0sTUFBTSxHQUFHO0lBQ3BCLFFBQVEsQ0FBSSxLQUFRO1FBQ2xCLE9BQU87WUFDTCxDQUFDLFlBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxRQUFRO1lBQ25DLEtBQUs7U0FDTixDQUFDO0lBQ0osQ0FBQztJQUNELE1BQU0sQ0FBQyxLQUFVO1FBQ2YsT0FBTztZQUNMLENBQUMsWUFBWSxDQUFDLEVBQUUsVUFBVSxDQUFDLE1BQU07WUFDakMsS0FBSztTQUNOLENBQUM7SUFDSixDQUFDO0lBQ0QsT0FBTyxDQUFxQixRQUFXO1FBQ3JDLE9BQU87WUFDTCxDQUFDLFlBQVksQ0FBQyxFQUFFLFVBQVUsQ0FBQyxPQUFPO1lBQ2xDLFFBQVE7U0FDVCxDQUFDO0lBQ0osQ0FBQztDQUNGLENBQUM7QUFFRixNQUFNLENBQU4sSUFBWSxVQUlYO0FBSkQsV0FBWSxVQUFVO0lBQ3BCLGlEQUFXLENBQUE7SUFDWCxtREFBWSxDQUFBO0lBQ1osK0NBQVUsQ0FBQTtBQUNaLENBQUMsRUFKVyxVQUFVLEtBQVYsVUFBVSxRQUlyQjtBQWlCRCxNQUFNLFVBQVUsUUFBUSxDQUFDLENBQU07SUFDN0IsT0FBTyxDQUFDLElBQUksT0FBTyxDQUFDLEtBQUssUUFBUSxJQUFJLFlBQVksSUFBSSxDQUFDLENBQUM7QUFDekQsQ0FBQztBQUVELE1BQU0sVUFBVSxTQUFTLENBQUMsTUFBMEI7SUFDbEQsT0FBTyxRQUFRLENBQUMsTUFBTSxDQUFDLElBQUksTUFBTSxDQUFDLFlBQVksQ0FBQyxLQUFLLFVBQVUsQ0FBQyxPQUFPLENBQUM7QUFDekUsQ0FBQztBQUVELE1BQU0sVUFBVSxVQUFVLENBQ3hCLE1BQTZCO0lBRTdCLE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsUUFBUSxDQUFDO0FBQzFFLENBQUM7QUFFRCxNQUFNLFVBQVUsUUFBUSxDQUFDLE1BQTBCO0lBQ2pELE9BQU8sUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxZQUFZLENBQUMsS0FBSyxVQUFVLENBQUMsTUFBTSxDQUFDO0FBQ3hFLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxFQUFFLENBQUMsVUFBVSxFQUFFLFFBQVEsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnR1YWwgfSBmcm9tIFwiLi9ldmVudHVhbC5qc1wiO1xuaW1wb3J0IHsgb3IgfSBmcm9tIFwiLi91dGlsLmpzXCI7XG5cbmV4cG9ydCBjb25zdCBSZXN1bHRTeW1ib2wgPSBTeW1ib2wuZm9yKFwiZXZlbnR1YWw6UmVzdWx0XCIpO1xuXG5leHBvcnQgdHlwZSBSZXN1bHQ8VCA9IGFueT4gPSBQZW5kaW5nIHwgUmVzb2x2ZWQ8VD4gfCBGYWlsZWQ7XG5cbmV4cG9ydCBjb25zdCBSZXN1bHQgPSB7XG4gIHJlc29sdmVkPFQ+KHZhbHVlOiBUKTogUmVzb2x2ZWQ8VD4ge1xuICAgIHJldHVybiB7XG4gICAgICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5SZXNvbHZlZCxcbiAgICAgIHZhbHVlLFxuICAgIH07XG4gIH0sXG4gIGZhaWxlZChlcnJvcjogYW55KTogRmFpbGVkIHtcbiAgICByZXR1cm4ge1xuICAgICAgW1Jlc3VsdFN5bWJvbF06IFJlc3VsdEtpbmQuRmFpbGVkLFxuICAgICAgZXJyb3IsXG4gICAgfTtcbiAgfSxcbiAgcGVuZGluZzxBIGV4dGVuZHMgRXZlbnR1YWw+KGFjdGl2aXR5OiBBKTogUGVuZGluZzxBPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlBlbmRpbmcsXG4gICAgICBhY3Rpdml0eSxcbiAgICB9O1xuICB9LFxufTtcblxuZXhwb3J0IGVudW0gUmVzdWx0S2luZCB7XG4gIFBlbmRpbmcgPSAwLFxuICBSZXNvbHZlZCA9IDEsXG4gIEZhaWxlZCA9IDIsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUGVuZGluZzxBIGV4dGVuZHMgRXZlbnR1YWwgPSBFdmVudHVhbD4ge1xuICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5QZW5kaW5nO1xuICBhY3Rpdml0eTogQTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZXNvbHZlZDxUID0gYW55PiB7XG4gIFtSZXN1bHRTeW1ib2xdOiBSZXN1bHRLaW5kLlJlc29sdmVkO1xuICB2YWx1ZTogVDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGYWlsZWQge1xuICBbUmVzdWx0U3ltYm9sXTogUmVzdWx0S2luZC5GYWlsZWQ7XG4gIGVycm9yOiBhbnk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1Jlc3VsdChhOiBhbnkpOiBhIGlzIFJlc3VsdCB7XG4gIHJldHVybiBhICYmIHR5cGVvZiBhID09PSBcIm9iamVjdFwiICYmIFJlc3VsdFN5bWJvbCBpbiBhO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNQZW5kaW5nKHJlc3VsdDogUmVzdWx0IHwgdW5kZWZpbmVkKTogcmVzdWx0IGlzIFBlbmRpbmcge1xuICByZXR1cm4gaXNSZXN1bHQocmVzdWx0KSAmJiByZXN1bHRbUmVzdWx0U3ltYm9sXSA9PT0gUmVzdWx0S2luZC5QZW5kaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNSZXNvbHZlZDxUPihcbiAgcmVzdWx0OiBSZXN1bHQ8VD4gfCB1bmRlZmluZWRcbik6IHJlc3VsdCBpcyBSZXNvbHZlZDxUPiB7XG4gIHJldHVybiBpc1Jlc3VsdChyZXN1bHQpICYmIHJlc3VsdFtSZXN1bHRTeW1ib2xdID09PSBSZXN1bHRLaW5kLlJlc29sdmVkO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNGYWlsZWQocmVzdWx0OiBSZXN1bHQgfCB1bmRlZmluZWQpOiByZXN1bHQgaXMgRmFpbGVkIHtcbiAgcmV0dXJuIGlzUmVzdWx0KHJlc3VsdCkgJiYgcmVzdWx0W1Jlc3VsdFN5bWJvbF0gPT09IFJlc3VsdEtpbmQuRmFpbGVkO1xufVxuXG5leHBvcnQgY29uc3QgaXNSZXNvbHZlZE9yRmFpbGVkID0gb3IoaXNSZXNvbHZlZCwgaXNGYWlsZWQpO1xuIl19 |
@@ -60,6 +60,6 @@ import { HistoryStateEvent } from "../../workflow-events.js"; | ||
export type Schedule = RelativeSchedule | AbsoluteSchedule; | ||
export declare namespace Schedule { | ||
function relative(timerSeconds: number, baseTime?: Date): RelativeSchedule; | ||
function absolute(untilTime: string): AbsoluteSchedule; | ||
} | ||
export declare const Schedule: { | ||
relative(timerSeconds: number, baseTime?: Date): RelativeSchedule; | ||
absolute(untilTime: string): AbsoluteSchedule; | ||
}; | ||
export type TimerRequestBase<T extends TimerRequestType> = { | ||
@@ -66,0 +66,0 @@ type: T; |
@@ -6,5 +6,4 @@ export var TimerRequestType; | ||
})(TimerRequestType || (TimerRequestType = {})); | ||
export var Schedule; | ||
(function (Schedule) { | ||
function relative(timerSeconds, baseTime = new Date()) { | ||
export const Schedule = { | ||
relative(timerSeconds, baseTime = new Date()) { | ||
return { | ||
@@ -15,5 +14,4 @@ type: "Relative", | ||
}; | ||
} | ||
Schedule.relative = relative; | ||
function absolute(untilTime) { | ||
}, | ||
absolute(untilTime) { | ||
return { | ||
@@ -23,5 +21,4 @@ type: "Absolute", | ||
}; | ||
} | ||
Schedule.absolute = absolute; | ||
})(Schedule || (Schedule = {})); | ||
}, | ||
}; | ||
export function isTimerScheduleEventRequest(timerRequest) { | ||
@@ -34,2 +31,2 @@ return timerRequest && timerRequest.type === TimerRequestType.ScheduleEvent; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXItY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy90aW1lci1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDMUIsbURBQStCLENBQUE7SUFDL0IsK0RBQTJDLENBQUE7QUFDN0MsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLEtBQVcsUUFBUSxDQWtCeEI7QUFsQkQsV0FBaUIsUUFBUTtJQUN2QixTQUFnQixRQUFRLENBQ3RCLFlBQW9CLEVBQ3BCLFdBQWlCLElBQUksSUFBSSxFQUFFO1FBRTNCLE9BQU87WUFDTCxJQUFJLEVBQUUsVUFBVTtZQUNoQixZQUFZO1lBQ1osUUFBUTtTQUNULENBQUM7SUFDSixDQUFDO0lBVGUsaUJBQVEsV0FTdkIsQ0FBQTtJQUVELFNBQWdCLFFBQVEsQ0FBQyxTQUFpQjtRQUN4QyxPQUFPO1lBQ0wsSUFBSSxFQUFFLFVBQVU7WUFDaEIsU0FBUztTQUNWLENBQUM7SUFDSixDQUFDO0lBTGUsaUJBQVEsV0FLdkIsQ0FBQTtBQUNILENBQUMsRUFsQmdCLFFBQVEsS0FBUixRQUFRLFFBa0J4QjtBQWdCRCxNQUFNLFVBQVUsMkJBQTJCLENBQ3pDLFlBQTBCO0lBRTFCLE9BQU8sWUFBWSxJQUFJLFlBQVksQ0FBQyxJQUFJLEtBQUssZ0JBQWdCLENBQUMsYUFBYSxDQUFDO0FBQzlFLENBQUM7QUFTRCxNQUFNLFVBQVUsaUNBQWlDLENBQy9DLFlBQTBCO0lBRTFCLE9BQU8sQ0FDTCxZQUFZO1FBQ1osWUFBWSxDQUFDLElBQUksS0FBSyxnQkFBZ0IsQ0FBQyx3QkFBd0IsQ0FDaEUsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBIaXN0b3J5U3RhdGVFdmVudCB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBUaW1lckNsaWVudCB7XG4gIC8qKlxuICAgKiBTdGFydHMgYSB0aW1lciB1c2luZyBTUVMncyBtZXNzYWdlIGRlbGF5LlxuICAgKlxuICAgKiBUaGUgdGltZXJSZXF1ZXN0LnVudGlsVGltZSBtYXkgb25seSBiZSAxNSBtaW51dGVzIG9yIGZld2VyIGluIHRoZSBmdXR1cmUuXG4gICAqXG4gICAqIEZvciBsb25nZXIgdXNlIHtAbGluayBUaW1lckNsaWVudC5zdGFydFRpbWVyfS5cbiAgICpcbiAgICogVGhlIFNRUyBRdWV1ZSB3aWxsIGRlbGF5IGZvciBmbG9vcih1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgc2Vjb25kcyB1bnRpbCB0aGUgdGltZXIgaGFuZGxlciBjYW4gcGljayB1cCB0aGUgbWVzc2FnZS5cbiAgICpcbiAgICogRmluYWxseSB0aGUgdGltZXIgaGFuZGxlciB3YWl0cyB0aGUgcmVtYWluaW5nICh1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgbWlsbGlzZWNvbmRzIGlmIG5lY2Vzc2FyeSBhbmQgdGhlbiBzZW5kc1xuICAgKiB0aGUge0BsaW5rIFRpbWVyUmVxdWVzdH0gcHJvdmlkZWQuXG4gICAqL1xuICBzdGFydFNob3J0VGltZXIodGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3QpOiBQcm9taXNlPG51bWJlcj47XG5cbiAgLyoqXG4gICAqIFN0YXJ0cyBhIHRpbWVyIG9mIGFueSAocG9zaXRpdmUpIGxlbmd0aC5cbiAgICpcbiAgICogSWYgdGhlIHRpbWVyIGlzIGxvbmdlciB0aGFuIDE1IG1pbnV0ZXMgKGNvbmZpZ3VyYWJsZSB2aWEgYHByb3BzLnNsZWVwUXVldWVUaHJlc2hvbGRNaWxsaXNgKSxcbiAgICogdGhlIHRpbWVyIHdpbGwgY3JlYXRlIGEgIEV2ZW50QnJpZGdlIHNjaGVkdWxlIHVudGlsIHRoZSB1bnRpbFRpbWUgLSBwcm9wcy5zbGVlcFF1ZXVlVGhyZXNob2xkTWlsbGlzXG4gICAqIHdoZW4gdGhlIHRpbWVyIHdpbGwgYmUgbW92ZWQgdG8gdGhlIFNRUyBxdWV1ZS5cbiAgICpcbiAgICogVGhlIFNRUyBRdWV1ZSB3aWxsIGRlbGF5IGZvciBmbG9vcih1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgc2Vjb25kcyB1bnRpbCB0aGUgdGltZXIgaGFuZGxlciBjYW4gcGljayB1cCB0aGUgbWVzc2FnZS5cbiAgICpcbiAgICogRmluYWxseSB0aGUgdGltZXIgaGFuZGxlciB3YWl0cyB0aGUgcmVtYWluaW5nICh1bnRpbFRpbWUgLSBjdXJyZW50VGltZSkgbWlsbGlzZWNvbmRzIGlmIG5lY2Vzc2FyeSBhbmQgdGhlbiBzZW5kc1xuICAgKiB0aGUge0BsaW5rIFRpbWVyUmVxdWVzdH0gcHJvdmlkZWQuXG4gICAqL1xuICBzdGFydFRpbWVyKHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0KTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogV2hlbiBzdGFydFRpbWVyIGlzIHVzZWQsIHRoZSBFdmVudEJyaWRnZSBzY2hlZHVsZSB3aWxsIG5vdCBzZWxmIGRlbGV0ZS5cbiAgICpcbiAgICogVXNlIHRoaXMgbWV0aG9kIHRvIGNsZWFuIHRoZSBzY2hlZHVsZS5cbiAgICpcbiAgICogVGhlIHByb3ZpZGVkIHNjaGVkdWxlLWZvcndhcmRlciBmdW5jdGlvbiB3aWxsIGNhbGwgdGhpcyBtZXRob2QgaW4gRXZlbnR1YWwgd2hlblxuICAgKiB0aGUgdGltZXIgaXMgdHJhbnNmZXJyZWQgZnJvbSBFdmVudEJyaWRnZSB0byBTUVMgYXQgYHByb3BzLnNsZWVwUXVldWVUaHJlc2hvbGRNaWxsaXNgLlxuICAgKi9cbiAgY2xlYXJTY2hlZHVsZShzY2hlZHVsZU5hbWU6IHN0cmluZyk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFNjaGVkdWxlcyBhbnkgZXZlbnQgZm9yIGEgd29ya2Zsb3cgYXQgYSBmdXR1cmUgdGltZS5cbiAgICpcbiAgICogSGVscGVyIGZvciB1c2luZyB7QGxpbmsgVGltZXJDbGllbnQuc3RhcnRUaW1lcn0gd2l0aCBhIHtAbGluayBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0fS5cbiAgICovXG4gIHNjaGVkdWxlRXZlbnQ8RSBleHRlbmRzIEhpc3RvcnlTdGF0ZUV2ZW50PihcbiAgICByZXF1ZXN0OiBTY2hlZHVsZUV2ZW50UmVxdWVzdDxFPlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuXG5leHBvcnQgdHlwZSBUaW1lclJlcXVlc3QgPVxuICB8IFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3RcbiAgfCBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0O1xuXG5leHBvcnQgZW51bSBUaW1lclJlcXVlc3RUeXBlIHtcbiAgU2NoZWR1bGVFdmVudCA9IFwiU2NoZWR1bGVFdmVudFwiLFxuICBBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3IgPSBcIkNoZWNrSGVhcnRiZWF0XCIsXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgUmVsYXRpdmVTY2hlZHVsZSB7XG4gIHR5cGU6IFwiUmVsYXRpdmVcIjtcbiAgdGltZXJTZWNvbmRzOiBudW1iZXI7XG4gIGJhc2VUaW1lOiBEYXRlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEFic29sdXRlU2NoZWR1bGUge1xuICB0eXBlOiBcIkFic29sdXRlXCI7XG4gIHVudGlsVGltZTogc3RyaW5nO1xufVxuXG5leHBvcnQgdHlwZSBTY2hlZHVsZSA9IFJlbGF0aXZlU2NoZWR1bGUgfCBBYnNvbHV0ZVNjaGVkdWxlO1xuXG5leHBvcnQgbmFtZXNwYWNlIFNjaGVkdWxlIHtcbiAgZXhwb3J0IGZ1bmN0aW9uIHJlbGF0aXZlKFxuICAgIHRpbWVyU2Vjb25kczogbnVtYmVyLFxuICAgIGJhc2VUaW1lOiBEYXRlID0gbmV3IERhdGUoKVxuICApOiBSZWxhdGl2ZVNjaGVkdWxlIHtcbiAgICByZXR1cm4ge1xuICAgICAgdHlwZTogXCJSZWxhdGl2ZVwiLFxuICAgICAgdGltZXJTZWNvbmRzLFxuICAgICAgYmFzZVRpbWUsXG4gICAgfTtcbiAgfVxuXG4gIGV4cG9ydCBmdW5jdGlvbiBhYnNvbHV0ZSh1bnRpbFRpbWU6IHN0cmluZyk6IEFic29sdXRlU2NoZWR1bGUge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiBcIkFic29sdXRlXCIsXG4gICAgICB1bnRpbFRpbWUsXG4gICAgfTtcbiAgfVxufVxuXG5leHBvcnQgdHlwZSBUaW1lclJlcXVlc3RCYXNlPFQgZXh0ZW5kcyBUaW1lclJlcXVlc3RUeXBlPiA9IHtcbiAgdHlwZTogVDtcbiAgc2NoZWR1bGU6IFNjaGVkdWxlO1xufTtcblxuLyoqXG4gKiBGb3J3YXJkIGFuIGV2ZW50IHRvIHRoZSBXb3JrZmxvdyBRdWV1ZS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0XG4gIGV4dGVuZHMgVGltZXJSZXF1ZXN0QmFzZTxUaW1lclJlcXVlc3RUeXBlLlNjaGVkdWxlRXZlbnQ+IHtcbiAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgZXZlbnQ6IEhpc3RvcnlTdGF0ZUV2ZW50O1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNUaW1lclNjaGVkdWxlRXZlbnRSZXF1ZXN0KFxuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdFxuKTogdGltZXJSZXF1ZXN0IGlzIFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3Qge1xuICByZXR1cm4gdGltZXJSZXF1ZXN0ICYmIHRpbWVyUmVxdWVzdC50eXBlID09PSBUaW1lclJlcXVlc3RUeXBlLlNjaGVkdWxlRXZlbnQ7XG59XG5cbmV4cG9ydCB0eXBlIEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3QgPVxuICBUaW1lclJlcXVlc3RCYXNlPFRpbWVyUmVxdWVzdFR5cGUuQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yPiAmIHtcbiAgICBleGVjdXRpb25JZDogc3RyaW5nO1xuICAgIGFjdGl2aXR5U2VxOiBudW1iZXI7XG4gICAgaGVhcnRiZWF0U2Vjb25kczogbnVtYmVyO1xuICB9O1xuXG5leHBvcnQgZnVuY3Rpb24gaXNBY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3JSZXF1ZXN0KFxuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdFxuKTogdGltZXJSZXF1ZXN0IGlzIEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3Qge1xuICByZXR1cm4gKFxuICAgIHRpbWVyUmVxdWVzdCAmJlxuICAgIHRpbWVyUmVxdWVzdC50eXBlID09PSBUaW1lclJlcXVlc3RUeXBlLkFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclxuICApO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVkdWxlRm9yd2FyZGVyUmVxdWVzdCB7XG4gIHNjaGVkdWxlTmFtZTogc3RyaW5nO1xuICBjbGVhclNjaGVkdWxlOiBib29sZWFuO1xuICB0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdDtcbiAgZm9yd2FyZFRpbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIElTTyA4NjAxIFRpbWVzdGFtcCBkZXRlcm1pbmluZyB3aGVuIHRoZSBtZXNzYWdlIHNob3VsZCBiZSB2aXNpYmxlIHRvIHRoZSB0aW1lciBxdWV1ZS5cbiAgICovXG4gIHVudGlsVGltZTogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFNjaGVkdWxlRXZlbnRSZXF1ZXN0PEUgZXh0ZW5kcyBIaXN0b3J5U3RhdGVFdmVudD5cbiAgZXh0ZW5kcyBPbWl0PFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3QsIFwiZXZlbnRcIiB8IFwidHlwZVwiPiB7XG4gIGV2ZW50OiBPbWl0PEUsIFwidGltZXN0YW1wXCI+O1xufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZXItY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy90aW1lci1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBdURBLE1BQU0sQ0FBTixJQUFZLGdCQUdYO0FBSEQsV0FBWSxnQkFBZ0I7SUFDMUIsbURBQStCLENBQUE7SUFDL0IsK0RBQTJDLENBQUE7QUFDN0MsQ0FBQyxFQUhXLGdCQUFnQixLQUFoQixnQkFBZ0IsUUFHM0I7QUFlRCxNQUFNLENBQUMsTUFBTSxRQUFRLEdBQUc7SUFDdEIsUUFBUSxDQUNOLFlBQW9CLEVBQ3BCLFdBQWlCLElBQUksSUFBSSxFQUFFO1FBRTNCLE9BQU87WUFDTCxJQUFJLEVBQUUsVUFBVTtZQUNoQixZQUFZO1lBQ1osUUFBUTtTQUNULENBQUM7SUFDSixDQUFDO0lBQ0QsUUFBUSxDQUFDLFNBQWlCO1FBQ3hCLE9BQU87WUFDTCxJQUFJLEVBQUUsVUFBVTtZQUNoQixTQUFTO1NBQ1YsQ0FBQztJQUNKLENBQUM7Q0FDRixDQUFDO0FBZ0JGLE1BQU0sVUFBVSwyQkFBMkIsQ0FDekMsWUFBMEI7SUFFMUIsT0FBTyxZQUFZLElBQUksWUFBWSxDQUFDLElBQUksS0FBSyxnQkFBZ0IsQ0FBQyxhQUFhLENBQUM7QUFDOUUsQ0FBQztBQVNELE1BQU0sVUFBVSxpQ0FBaUMsQ0FDL0MsWUFBMEI7SUFFMUIsT0FBTyxDQUNMLFlBQVk7UUFDWixZQUFZLENBQUMsSUFBSSxLQUFLLGdCQUFnQixDQUFDLHdCQUF3QixDQUNoRSxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhpc3RvcnlTdGF0ZUV2ZW50IH0gZnJvbSBcIi4uLy4uL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFRpbWVyQ2xpZW50IHtcbiAgLyoqXG4gICAqIFN0YXJ0cyBhIHRpbWVyIHVzaW5nIFNRUydzIG1lc3NhZ2UgZGVsYXkuXG4gICAqXG4gICAqIFRoZSB0aW1lclJlcXVlc3QudW50aWxUaW1lIG1heSBvbmx5IGJlIDE1IG1pbnV0ZXMgb3IgZmV3ZXIgaW4gdGhlIGZ1dHVyZS5cbiAgICpcbiAgICogRm9yIGxvbmdlciB1c2Uge0BsaW5rIFRpbWVyQ2xpZW50LnN0YXJ0VGltZXJ9LlxuICAgKlxuICAgKiBUaGUgU1FTIFF1ZXVlIHdpbGwgZGVsYXkgZm9yIGZsb29yKHVudGlsVGltZSAtIGN1cnJlbnRUaW1lKSBzZWNvbmRzIHVudGlsIHRoZSB0aW1lciBoYW5kbGVyIGNhbiBwaWNrIHVwIHRoZSBtZXNzYWdlLlxuICAgKlxuICAgKiBGaW5hbGx5IHRoZSB0aW1lciBoYW5kbGVyIHdhaXRzIHRoZSByZW1haW5pbmcgKHVudGlsVGltZSAtIGN1cnJlbnRUaW1lKSBtaWxsaXNlY29uZHMgaWYgbmVjZXNzYXJ5IGFuZCB0aGVuIHNlbmRzXG4gICAqIHRoZSB7QGxpbmsgVGltZXJSZXF1ZXN0fSBwcm92aWRlZC5cbiAgICovXG4gIHN0YXJ0U2hvcnRUaW1lcih0aW1lclJlcXVlc3Q6IFRpbWVyUmVxdWVzdCk6IFByb21pc2U8bnVtYmVyPjtcblxuICAvKipcbiAgICogU3RhcnRzIGEgdGltZXIgb2YgYW55IChwb3NpdGl2ZSkgbGVuZ3RoLlxuICAgKlxuICAgKiBJZiB0aGUgdGltZXIgaXMgbG9uZ2VyIHRoYW4gMTUgbWludXRlcyAoY29uZmlndXJhYmxlIHZpYSBgcHJvcHMuc2xlZXBRdWV1ZVRocmVzaG9sZE1pbGxpc2ApLFxuICAgKiB0aGUgdGltZXIgd2lsbCBjcmVhdGUgYSAgRXZlbnRCcmlkZ2Ugc2NoZWR1bGUgdW50aWwgdGhlIHVudGlsVGltZSAtIHByb3BzLnNsZWVwUXVldWVUaHJlc2hvbGRNaWxsaXNcbiAgICogd2hlbiB0aGUgdGltZXIgd2lsbCBiZSBtb3ZlZCB0byB0aGUgU1FTIHF1ZXVlLlxuICAgKlxuICAgKiBUaGUgU1FTIFF1ZXVlIHdpbGwgZGVsYXkgZm9yIGZsb29yKHVudGlsVGltZSAtIGN1cnJlbnRUaW1lKSBzZWNvbmRzIHVudGlsIHRoZSB0aW1lciBoYW5kbGVyIGNhbiBwaWNrIHVwIHRoZSBtZXNzYWdlLlxuICAgKlxuICAgKiBGaW5hbGx5IHRoZSB0aW1lciBoYW5kbGVyIHdhaXRzIHRoZSByZW1haW5pbmcgKHVudGlsVGltZSAtIGN1cnJlbnRUaW1lKSBtaWxsaXNlY29uZHMgaWYgbmVjZXNzYXJ5IGFuZCB0aGVuIHNlbmRzXG4gICAqIHRoZSB7QGxpbmsgVGltZXJSZXF1ZXN0fSBwcm92aWRlZC5cbiAgICovXG4gIHN0YXJ0VGltZXIodGltZXJSZXF1ZXN0OiBUaW1lclJlcXVlc3QpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBXaGVuIHN0YXJ0VGltZXIgaXMgdXNlZCwgdGhlIEV2ZW50QnJpZGdlIHNjaGVkdWxlIHdpbGwgbm90IHNlbGYgZGVsZXRlLlxuICAgKlxuICAgKiBVc2UgdGhpcyBtZXRob2QgdG8gY2xlYW4gdGhlIHNjaGVkdWxlLlxuICAgKlxuICAgKiBUaGUgcHJvdmlkZWQgc2NoZWR1bGUtZm9yd2FyZGVyIGZ1bmN0aW9uIHdpbGwgY2FsbCB0aGlzIG1ldGhvZCBpbiBFdmVudHVhbCB3aGVuXG4gICAqIHRoZSB0aW1lciBpcyB0cmFuc2ZlcnJlZCBmcm9tIEV2ZW50QnJpZGdlIHRvIFNRUyBhdCBgcHJvcHMuc2xlZXBRdWV1ZVRocmVzaG9sZE1pbGxpc2AuXG4gICAqL1xuICBjbGVhclNjaGVkdWxlKHNjaGVkdWxlTmFtZTogc3RyaW5nKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogU2NoZWR1bGVzIGFueSBldmVudCBmb3IgYSB3b3JrZmxvdyBhdCBhIGZ1dHVyZSB0aW1lLlxuICAgKlxuICAgKiBIZWxwZXIgZm9yIHVzaW5nIHtAbGluayBUaW1lckNsaWVudC5zdGFydFRpbWVyfSB3aXRoIGEge0BsaW5rIFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3R9LlxuICAgKi9cbiAgc2NoZWR1bGVFdmVudDxFIGV4dGVuZHMgSGlzdG9yeVN0YXRlRXZlbnQ+KFxuICAgIHJlcXVlc3Q6IFNjaGVkdWxlRXZlbnRSZXF1ZXN0PEU+XG4gICk6IFByb21pc2U8dm9pZD47XG59XG5cbmV4cG9ydCB0eXBlIFRpbWVyUmVxdWVzdCA9XG4gIHwgVGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdFxuICB8IEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3Q7XG5cbmV4cG9ydCBlbnVtIFRpbWVyUmVxdWVzdFR5cGUge1xuICBTY2hlZHVsZUV2ZW50ID0gXCJTY2hlZHVsZUV2ZW50XCIsXG4gIEFjdGl2aXR5SGVhcnRiZWF0TW9uaXRvciA9IFwiQ2hlY2tIZWFydGJlYXRcIixcbn1cblxuZXhwb3J0IGludGVyZmFjZSBSZWxhdGl2ZVNjaGVkdWxlIHtcbiAgdHlwZTogXCJSZWxhdGl2ZVwiO1xuICB0aW1lclNlY29uZHM6IG51bWJlcjtcbiAgYmFzZVRpbWU6IERhdGU7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQWJzb2x1dGVTY2hlZHVsZSB7XG4gIHR5cGU6IFwiQWJzb2x1dGVcIjtcbiAgdW50aWxUaW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCB0eXBlIFNjaGVkdWxlID0gUmVsYXRpdmVTY2hlZHVsZSB8IEFic29sdXRlU2NoZWR1bGU7XG5cbmV4cG9ydCBjb25zdCBTY2hlZHVsZSA9IHtcbiAgcmVsYXRpdmUoXG4gICAgdGltZXJTZWNvbmRzOiBudW1iZXIsXG4gICAgYmFzZVRpbWU6IERhdGUgPSBuZXcgRGF0ZSgpXG4gICk6IFJlbGF0aXZlU2NoZWR1bGUge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiBcIlJlbGF0aXZlXCIsXG4gICAgICB0aW1lclNlY29uZHMsXG4gICAgICBiYXNlVGltZSxcbiAgICB9O1xuICB9LFxuICBhYnNvbHV0ZSh1bnRpbFRpbWU6IHN0cmluZyk6IEFic29sdXRlU2NoZWR1bGUge1xuICAgIHJldHVybiB7XG4gICAgICB0eXBlOiBcIkFic29sdXRlXCIsXG4gICAgICB1bnRpbFRpbWUsXG4gICAgfTtcbiAgfSxcbn07XG5cbmV4cG9ydCB0eXBlIFRpbWVyUmVxdWVzdEJhc2U8VCBleHRlbmRzIFRpbWVyUmVxdWVzdFR5cGU+ID0ge1xuICB0eXBlOiBUO1xuICBzY2hlZHVsZTogU2NoZWR1bGU7XG59O1xuXG4vKipcbiAqIEZvcndhcmQgYW4gZXZlbnQgdG8gdGhlIFdvcmtmbG93IFF1ZXVlLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFRpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3RcbiAgZXh0ZW5kcyBUaW1lclJlcXVlc3RCYXNlPFRpbWVyUmVxdWVzdFR5cGUuU2NoZWR1bGVFdmVudD4ge1xuICBleGVjdXRpb25JZDogc3RyaW5nO1xuICBldmVudDogSGlzdG9yeVN0YXRlRXZlbnQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1RpbWVyU2NoZWR1bGVFdmVudFJlcXVlc3QoXG4gIHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0XG4pOiB0aW1lclJlcXVlc3QgaXMgVGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdCB7XG4gIHJldHVybiB0aW1lclJlcXVlc3QgJiYgdGltZXJSZXF1ZXN0LnR5cGUgPT09IFRpbWVyUmVxdWVzdFR5cGUuU2NoZWR1bGVFdmVudDtcbn1cblxuZXhwb3J0IHR5cGUgQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yUmVxdWVzdCA9XG4gIFRpbWVyUmVxdWVzdEJhc2U8VGltZXJSZXF1ZXN0VHlwZS5BY3Rpdml0eUhlYXJ0YmVhdE1vbml0b3I+ICYge1xuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gICAgYWN0aXZpdHlTZXE6IG51bWJlcjtcbiAgICBoZWFydGJlYXRTZWNvbmRzOiBudW1iZXI7XG4gIH07XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0FjdGl2aXR5SGVhcnRiZWF0TW9uaXRvclJlcXVlc3QoXG4gIHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0XG4pOiB0aW1lclJlcXVlc3QgaXMgQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yUmVxdWVzdCB7XG4gIHJldHVybiAoXG4gICAgdGltZXJSZXF1ZXN0ICYmXG4gICAgdGltZXJSZXF1ZXN0LnR5cGUgPT09IFRpbWVyUmVxdWVzdFR5cGUuQWN0aXZpdHlIZWFydGJlYXRNb25pdG9yXG4gICk7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZWR1bGVGb3J3YXJkZXJSZXF1ZXN0IHtcbiAgc2NoZWR1bGVOYW1lOiBzdHJpbmc7XG4gIGNsZWFyU2NoZWR1bGU6IGJvb2xlYW47XG4gIHRpbWVyUmVxdWVzdDogVGltZXJSZXF1ZXN0O1xuICBmb3J3YXJkVGltZTogc3RyaW5nO1xuICAvKipcbiAgICogSVNPIDg2MDEgVGltZXN0YW1wIGRldGVybWluaW5nIHdoZW4gdGhlIG1lc3NhZ2Ugc2hvdWxkIGJlIHZpc2libGUgdG8gdGhlIHRpbWVyIHF1ZXVlLlxuICAgKi9cbiAgdW50aWxUaW1lOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgU2NoZWR1bGVFdmVudFJlcXVlc3Q8RSBleHRlbmRzIEhpc3RvcnlTdGF0ZUV2ZW50PlxuICBleHRlbmRzIE9taXQ8VGltZXJTY2hlZHVsZUV2ZW50UmVxdWVzdCwgXCJldmVudFwiIHwgXCJ0eXBlXCI+IHtcbiAgZXZlbnQ6IE9taXQ8RSwgXCJ0aW1lc3RhbXBcIj47XG59XG4iXX0= |
@@ -38,7 +38,7 @@ import { HistoryStateEvent } from "../../workflow-events.js"; | ||
*/ | ||
completeActivity({ activityToken: activityToken, result, }: CompleteActivityRequest): Promise<void>; | ||
completeActivity({ activityToken, result, }: CompleteActivityRequest): Promise<void>; | ||
/** | ||
* Fails an async activity causing it to throw the given error. | ||
*/ | ||
failActivity({ activityToken: activityToken, error, message, }: FailActivityRequest): Promise<void>; | ||
failActivity({ activityToken, error, message, }: FailActivityRequest): Promise<void>; | ||
/** | ||
@@ -45,0 +45,0 @@ * Submits a "heartbeat" for the given activityToken. |
@@ -26,3 +26,3 @@ import { createEvent, WorkflowEventType, } from "../../workflow-events.js"; | ||
*/ | ||
async completeActivity({ activityToken: activityToken, result, }) { | ||
async completeActivity({ activityToken, result, }) { | ||
await this.sendActivityResult(activityToken, { | ||
@@ -36,3 +36,3 @@ type: WorkflowEventType.ActivityCompleted, | ||
*/ | ||
async failActivity({ activityToken: activityToken, error, message, }) { | ||
async failActivity({ activityToken, error, message, }) { | ||
await this.sendActivityResult(activityToken, { | ||
@@ -65,2 +65,2 @@ type: WorkflowEventType.ActivityFailed, | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAGX,iBAAiB,GAClB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAa,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,MAAM,OAAgB,cAAc;IAClC,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IA8BpE;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,WAAW,CACT;YACE,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,SAAS,EACT,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EAAE,aAAa,EAC5B,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,iBAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EAAE,aAAa,EAC5B,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IACD;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,eAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CACzB,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAE9B,aAAqB,EAAE,KAAgD;QACvE,MAAM,IAAI,GAAG,mBAAmB,CAAC,aAAa,CAAC,CAAC;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,WAAW,CAAqC;YAC9C,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;CACF","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(private activityRuntimeClient: ActivityRuntimeClient) {}\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startWorkflow<W extends Workflow = Workflow>(\n    request: StartWorkflowRequest<W>\n  ): Promise<string>;\n  /**\n   * Submit events to be processed by a workflow's orchestrator.\n   *\n   * @param executionId ID of the workflow execution\n   * @param events events to submit for processing\n   */\n  public abstract submitWorkflowTask(\n    executionId: string,\n    ...events: HistoryStateEvent[]\n  ): Promise<void>;\n\n  public abstract getExecutions(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        undefined,\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Completes an async activity causing it to return the given value.\n   */\n  public async completeActivity({\n    activityToken: activityToken,\n    result,\n  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken: activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      new Date().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivityCompleted | ActivityFailed\n  >(activityToken: string, event: Omit<E, \"seq\" | \"duration\" | \"timestamp\">) {\n    const data = decodeActivityToken(activityToken);\n    await this.submitWorkflowTask(\n      data.payload.executionId,\n      createEvent<ActivityCompleted | ActivityFailed>({\n        ...event,\n        seq: data.payload.seq,\n      })\n    );\n  }\n}\n\nexport interface SendSignalRequest {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAGX,iBAAiB,GAClB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAa,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,MAAM,OAAgB,cAAc;IAClC,YAAoB,qBAA4C;QAA5C,0BAAqB,GAArB,qBAAqB,CAAuB;IAAG,CAAC;IA+BpE;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,WAAW,CACT;YACE,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,SAAS,EACT,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,iBAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EACb,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,eAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CACzB,CAAC;IACJ,CAAC;IAEO,KAAK,CAAC,kBAAkB,CAE9B,aAAqB,EAAE,KAAgD;QACvE,MAAM,IAAI,GAAG,mBAAmB,CAAC,aAAa,CAAC,CAAC;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,WAAW,CAAqC;YAC9C,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,CAAC,CACH,CAAC;IACJ,CAAC;CACF","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(private activityRuntimeClient: ActivityRuntimeClient) {}\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startWorkflow<W extends Workflow = Workflow>(\n    request: StartWorkflowRequest<W>\n  ): Promise<string>;\n\n  /**\n   * Submit events to be processed by a workflow's orchestrator.\n   *\n   * @param executionId ID of the workflow execution\n   * @param events events to submit for processing\n   */\n  public abstract submitWorkflowTask(\n    executionId: string,\n    ...events: HistoryStateEvent[]\n  ): Promise<void>;\n\n  public abstract getExecutions(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        undefined,\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Completes an async activity causing it to return the given value.\n   */\n  public async completeActivity({\n    activityToken,\n    result,\n  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      new Date().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivityCompleted | ActivityFailed\n  >(activityToken: string, event: Omit<E, \"seq\" | \"duration\" | \"timestamp\">) {\n    const data = decodeActivityToken(activityToken);\n    await this.submitWorkflowTask(\n      data.payload.executionId,\n      createEvent<ActivityCompleted | ActivityFailed>({\n        ...event,\n        seq: data.payload.seq,\n      })\n    );\n  }\n}\n\nexport interface SendSignalRequest {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]} |
@@ -18,4 +18,11 @@ import { Command } from "../command.js"; | ||
executeCommand(workflow: Workflow, executionId: string, command: Command, baseTime: Date): Promise<HistoryStateEvent>; | ||
private scheduleActivity; | ||
private scheduleChildWorkflow; | ||
private scheduleSleep; | ||
private executeExpectSignal; | ||
private sendSignal; | ||
private startCondition; | ||
private publishEvents; | ||
} | ||
export {}; | ||
//# sourceMappingURL=command-executor.d.ts.map |
@@ -15,25 +15,24 @@ import { isExpectSignalCommand, isPublishEventsCommand, isScheduleActivityCommand, isScheduleWorkflowCommand, isSendSignalCommand, isSleepForCommand, isSleepUntilCommand, isStartConditionCommand, } from "../command.js"; | ||
async executeCommand(workflow, executionId, command, baseTime) { | ||
const self = this; | ||
if (isScheduleActivityCommand(command)) { | ||
return await scheduleActivity(command); | ||
return await this.scheduleActivity(workflow, executionId, command, baseTime); | ||
} | ||
else if (isScheduleWorkflowCommand(command)) { | ||
return scheduleChildWorkflow(command); | ||
return this.scheduleChildWorkflow(executionId, command); | ||
} | ||
else if (isSleepForCommand(command) || isSleepUntilCommand(command)) { | ||
// all sleep times are computed using the start time of the WorkflowTaskStarted | ||
return scheduleSleep(command); | ||
return this.scheduleSleep(executionId, command, baseTime); | ||
} | ||
else if (isExpectSignalCommand(command)) { | ||
// should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)? | ||
return executeExpectSignal(command); | ||
return this.executeExpectSignal(executionId, command, baseTime); | ||
} | ||
else if (isSendSignalCommand(command)) { | ||
return sendSignal(command); | ||
return this.sendSignal(executionId, command); | ||
} | ||
else if (isStartConditionCommand(command)) { | ||
return startCondition(command); | ||
return this.startCondition(executionId, command, baseTime); | ||
} | ||
else if (isPublishEventsCommand(command)) { | ||
return publishEvents(command); | ||
return this.publishEvents(command); | ||
} | ||
@@ -43,127 +42,127 @@ else { | ||
} | ||
async function scheduleActivity(command) { | ||
const request = { | ||
scheduledTime: new Date().toISOString(), | ||
workflowName: workflow.workflowName, | ||
} | ||
async scheduleActivity(workflow, executionId, command, baseTime) { | ||
const request = { | ||
scheduledTime: new Date().toISOString(), | ||
workflowName: workflow.workflowName, | ||
executionId, | ||
command, | ||
retry: 0, | ||
}; | ||
const timeoutStarter = command.timeoutSeconds | ||
? await this.props.timerClient.scheduleEvent({ | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
event: { | ||
type: WorkflowEventType.ActivityTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
command, | ||
retry: 0, | ||
}; | ||
const timeoutStarter = command.timeoutSeconds | ||
? await self.props.timerClient.scheduleEvent({ | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
event: { | ||
type: WorkflowEventType.ActivityTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
}) | ||
: undefined; | ||
const activityStarter = self.props.workflowRuntimeClient.startActivity(request); | ||
await Promise.all([activityStarter, timeoutStarter]); | ||
return createEvent({ | ||
type: WorkflowEventType.ActivityScheduled, | ||
}) | ||
: undefined; | ||
const activityStarter = this.props.workflowRuntimeClient.startActivity(request); | ||
await Promise.all([activityStarter, timeoutStarter]); | ||
return createEvent({ | ||
type: WorkflowEventType.ActivityScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
}); | ||
} | ||
async scheduleChildWorkflow(executionId, command) { | ||
await this.props.workflowClient.startWorkflow({ | ||
workflowName: command.name, | ||
input: command.input, | ||
parentExecutionId: executionId, | ||
executionName: formatChildExecutionName(executionId, command.seq), | ||
seq: command.seq, | ||
...command.opts, | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.ChildWorkflowScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
input: command.input, | ||
}); | ||
} | ||
async scheduleSleep(executionId, command, baseTime) { | ||
// TODO validate | ||
const untilTime = isSleepUntilCommand(command) | ||
? new Date(command.untilTime) | ||
: new Date(baseTime.getTime() + command.durationSeconds * 1000); | ||
const untilTimeIso = untilTime.toISOString(); | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: WorkflowEventType.SleepCompleted, | ||
seq: command.seq, | ||
name: command.name, | ||
}, | ||
schedule: Schedule.absolute(untilTimeIso), | ||
executionId, | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.SleepScheduled, | ||
seq: command.seq, | ||
untilTime: untilTime.toISOString(), | ||
}); | ||
} | ||
async executeExpectSignal(executionId, command, baseTime) { | ||
if (command.timeoutSeconds) { | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: WorkflowEventType.ExpectSignalTimedOut, | ||
}, | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
executionId, | ||
}); | ||
} | ||
async function scheduleChildWorkflow(command) { | ||
await self.props.workflowClient.startWorkflow({ | ||
workflowName: command.name, | ||
input: command.input, | ||
parentExecutionId: executionId, | ||
executionName: formatChildExecutionName(executionId, command.seq), | ||
seq: command.seq, | ||
...command.opts, | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.ChildWorkflowScheduled, | ||
seq: command.seq, | ||
name: command.name, | ||
input: command.input, | ||
}); | ||
} | ||
async function scheduleSleep(command) { | ||
// TODO validate | ||
const untilTime = isSleepUntilCommand(command) | ||
? new Date(command.untilTime) | ||
: new Date(baseTime.getTime() + command.durationSeconds * 1000); | ||
const untilTimeIso = untilTime.toISOString(); | ||
await self.props.timerClient.scheduleEvent({ | ||
return createEvent({ | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: WorkflowEventType.ExpectSignalStarted, | ||
timeoutSeconds: command.timeoutSeconds, | ||
}); | ||
} | ||
async sendSignal(executionId, command) { | ||
const childExecutionId = isChildExecutionTarget(command.target) | ||
? formatExecutionId(command.target.workflowName, formatChildExecutionName(executionId, command.target.seq)) | ||
: command.target.executionId; | ||
await this.props.workflowClient.sendSignal({ | ||
signal: command.signalId, | ||
executionId: childExecutionId, | ||
id: `${executionId}/${command.seq}`, | ||
payload: command.payload, | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.SignalSent, | ||
executionId: childExecutionId, | ||
seq: command.seq, | ||
signalId: command.signalId, | ||
payload: command.payload, | ||
}); | ||
} | ||
async startCondition(executionId, command, baseTime) { | ||
if (command.timeoutSeconds) { | ||
await this.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: WorkflowEventType.SleepCompleted, | ||
type: WorkflowEventType.ConditionTimedOut, | ||
seq: command.seq, | ||
}, | ||
schedule: Schedule.absolute(untilTimeIso), | ||
executionId, | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.SleepScheduled, | ||
seq: command.seq, | ||
untilTime: untilTime.toISOString(), | ||
}); | ||
} | ||
async function executeExpectSignal(command) { | ||
if (command.timeoutSeconds) { | ||
await self.props.timerClient.scheduleEvent({ | ||
event: { | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: WorkflowEventType.ExpectSignalTimedOut, | ||
}, | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
executionId, | ||
}); | ||
} | ||
return createEvent({ | ||
signalId: command.signalId, | ||
seq: command.seq, | ||
type: WorkflowEventType.ExpectSignalStarted, | ||
timeoutSeconds: command.timeoutSeconds, | ||
}); | ||
} | ||
async function sendSignal(command) { | ||
const childExecutionId = isChildExecutionTarget(command.target) | ||
? formatExecutionId(command.target.workflowName, formatChildExecutionName(executionId, command.target.seq)) | ||
: command.target.executionId; | ||
await self.props.workflowClient.sendSignal({ | ||
signal: command.signalId, | ||
executionId: childExecutionId, | ||
id: `${executionId}/${command.seq}`, | ||
payload: command.payload, | ||
}); | ||
return createEvent({ | ||
type: WorkflowEventType.SignalSent, | ||
executionId: childExecutionId, | ||
seq: command.seq, | ||
signalId: command.signalId, | ||
payload: command.payload, | ||
}); | ||
} | ||
async function startCondition(command) { | ||
if (command.timeoutSeconds) { | ||
await self.props.timerClient.scheduleEvent({ | ||
event: { | ||
type: WorkflowEventType.ConditionTimedOut, | ||
seq: command.seq, | ||
}, | ||
executionId, | ||
schedule: Schedule.relative(command.timeoutSeconds, baseTime), | ||
}); | ||
} | ||
return createEvent({ | ||
type: WorkflowEventType.ConditionStarted, | ||
seq: command.seq, | ||
}); | ||
} | ||
async function publishEvents(command) { | ||
await self.props.eventClient.publish(...command.events); | ||
return createEvent({ | ||
type: WorkflowEventType.EventsPublished, | ||
events: command.events, | ||
seq: command.seq, | ||
}); | ||
} | ||
return createEvent({ | ||
type: WorkflowEventType.ConditionStarted, | ||
seq: command.seq, | ||
}); | ||
} | ||
async publishEvents(command) { | ||
await this.props.eventClient.publish(...command.events); | ||
return createEvent({ | ||
type: WorkflowEventType.EventsPublished, | ||
events: command.events, | ||
seq: command.seq, | ||
}); | ||
} | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-executor.js","sourceRoot":"","sources":["../../../src/runtime/command-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Command,\n  ExpectSignalCommand,\n  isExpectSignalCommand,\n  isPublishEventsCommand,\n  isScheduleActivityCommand,\n  isScheduleWorkflowCommand,\n  isSendSignalCommand,\n  isSleepForCommand,\n  isSleepUntilCommand,\n  isStartConditionCommand,\n  PublishEventsCommand,\n  ScheduleActivityCommand,\n  ScheduleWorkflowCommand,\n  SendSignalCommand,\n  SleepForCommand,\n  SleepUntilCommand,\n  StartConditionCommand,\n} from \"../command.js\";\nimport {\n  ActivityTimedOut,\n  WorkflowEventType,\n  createEvent,\n  ActivityScheduled,\n  ChildWorkflowScheduled,\n  SleepScheduled,\n  SleepCompleted,\n  ExpectSignalStarted,\n  ExpectSignalTimedOut,\n  HistoryStateEvent,\n  ConditionStarted,\n  ConditionTimedOut,\n  SignalSent,\n} from \"../workflow-events.js\";\nimport { EventsPublished, isChildExecutionTarget } from \"../index.js\";\nimport { assertNever } from \"../util.js\";\nimport { Workflow } from \"../workflow.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution-id.js\";\nimport { ActivityWorkerRequest } from \"./handlers/activity-worker.js\";\nimport {\n  EventClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"./index.js\";\n\ninterface CommandExecutorProps {\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  timerClient: TimerClient;\n  workflowClient: WorkflowClient;\n  eventClient: EventClient;\n}\n\n/**\n * Uses the clients to execute all supported commands and return events.\n */\nexport class CommandExecutor {\n  constructor(private props: CommandExecutorProps) {}\n\n  async executeCommand(\n    workflow: Workflow,\n    executionId: string,\n    command: Command,\n    baseTime: Date\n  ): Promise<HistoryStateEvent> {\n    const self = this;\n    if (isScheduleActivityCommand(command)) {\n      return await scheduleActivity(command);\n    } else if (isScheduleWorkflowCommand(command)) {\n      return scheduleChildWorkflow(command);\n    } else if (isSleepForCommand(command) || isSleepUntilCommand(command)) {\n      // all sleep times are computed using the start time of the WorkflowTaskStarted\n      return scheduleSleep(command);\n    } else if (isExpectSignalCommand(command)) {\n      // should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)?\n      return executeExpectSignal(command);\n    } else if (isSendSignalCommand(command)) {\n      return sendSignal(command);\n    } else if (isStartConditionCommand(command)) {\n      return startCondition(command);\n    } else if (isPublishEventsCommand(command)) {\n      return publishEvents(command);\n    } else {\n      return assertNever(command, `unknown command type`);\n    }\n\n    async function scheduleActivity(command: ScheduleActivityCommand) {\n      const request: ActivityWorkerRequest = {\n        scheduledTime: new Date().toISOString(),\n        workflowName: workflow.workflowName,\n        executionId,\n        command,\n        retry: 0,\n      };\n\n      const timeoutStarter = command.timeoutSeconds\n        ? await self.props.timerClient.scheduleEvent<ActivityTimedOut>({\n            schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n            event: {\n              type: WorkflowEventType.ActivityTimedOut,\n              seq: command.seq,\n            },\n            executionId,\n          })\n        : undefined;\n\n      const activityStarter =\n        self.props.workflowRuntimeClient.startActivity(request);\n\n      await Promise.all([activityStarter, timeoutStarter]);\n\n      return createEvent<ActivityScheduled>({\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      });\n    }\n\n    async function scheduleChildWorkflow(\n      command: ScheduleWorkflowCommand\n    ): Promise<ChildWorkflowScheduled> {\n      await self.props.workflowClient.startWorkflow({\n        workflowName: command.name,\n        input: command.input,\n        parentExecutionId: executionId,\n        executionName: formatChildExecutionName(executionId, command.seq),\n        seq: command.seq,\n        ...command.opts,\n      });\n\n      return createEvent<ChildWorkflowScheduled>({\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      });\n    }\n\n    async function scheduleSleep(\n      command: SleepForCommand | SleepUntilCommand\n    ): Promise<SleepScheduled> {\n      // TODO validate\n      const untilTime = isSleepUntilCommand(command)\n        ? new Date(command.untilTime)\n        : new Date(baseTime.getTime() + command.durationSeconds * 1000);\n      const untilTimeIso = untilTime.toISOString();\n\n      await self.props.timerClient.scheduleEvent<SleepCompleted>({\n        event: {\n          type: WorkflowEventType.SleepCompleted,\n          seq: command.seq,\n        },\n        schedule: Schedule.absolute(untilTimeIso),\n        executionId,\n      });\n\n      return createEvent<SleepScheduled>({\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      });\n    }\n\n    async function executeExpectSignal(\n      command: ExpectSignalCommand\n    ): Promise<ExpectSignalStarted> {\n      if (command.timeoutSeconds) {\n        await self.props.timerClient.scheduleEvent<ExpectSignalTimedOut>({\n          event: {\n            signalId: command.signalId,\n            seq: command.seq,\n            type: WorkflowEventType.ExpectSignalTimedOut,\n          },\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n          executionId,\n        });\n      }\n\n      return createEvent<ExpectSignalStarted>({\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      });\n    }\n\n    async function sendSignal(command: SendSignalCommand) {\n      const childExecutionId = isChildExecutionTarget(command.target)\n        ? formatExecutionId(\n            command.target.workflowName,\n            formatChildExecutionName(executionId, command.target.seq)\n          )\n        : command.target.executionId;\n\n      await self.props.workflowClient.sendSignal({\n        signal: command.signalId,\n        executionId: childExecutionId,\n        id: `${executionId}/${command.seq}`,\n        payload: command.payload,\n      });\n\n      return createEvent<SignalSent>({\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      });\n    }\n\n    async function startCondition(command: StartConditionCommand) {\n      if (command.timeoutSeconds) {\n        await self.props.timerClient.scheduleEvent<ConditionTimedOut>({\n          event: {\n            type: WorkflowEventType.ConditionTimedOut,\n            seq: command.seq,\n          },\n          executionId,\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n        });\n      }\n\n      return createEvent<ConditionStarted>({\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      });\n    }\n\n    async function publishEvents(command: PublishEventsCommand) {\n      await self.props.eventClient.publish(...command.events);\n      return createEvent<EventsPublished>({\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      });\n    }\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"command-executor.js","sourceRoot":"","sources":["../../../src/runtime/command-executor.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Command,\n  ExpectSignalCommand,\n  isExpectSignalCommand,\n  isPublishEventsCommand,\n  isScheduleActivityCommand,\n  isScheduleWorkflowCommand,\n  isSendSignalCommand,\n  isSleepForCommand,\n  isSleepUntilCommand,\n  isStartConditionCommand,\n  PublishEventsCommand,\n  ScheduleActivityCommand,\n  ScheduleWorkflowCommand,\n  SendSignalCommand,\n  SleepForCommand,\n  SleepUntilCommand,\n  StartConditionCommand,\n} from \"../command.js\";\nimport {\n  ActivityTimedOut,\n  WorkflowEventType,\n  createEvent,\n  ActivityScheduled,\n  ChildWorkflowScheduled,\n  SleepScheduled,\n  SleepCompleted,\n  ExpectSignalStarted,\n  ExpectSignalTimedOut,\n  HistoryStateEvent,\n  ConditionStarted,\n  ConditionTimedOut,\n  SignalSent,\n} from \"../workflow-events.js\";\nimport { EventsPublished, isChildExecutionTarget } from \"../index.js\";\nimport { assertNever } from \"../util.js\";\nimport { Workflow } from \"../workflow.js\";\nimport { formatChildExecutionName, formatExecutionId } from \"./execution-id.js\";\nimport { ActivityWorkerRequest } from \"./handlers/activity-worker.js\";\nimport {\n  EventClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"./index.js\";\n\ninterface CommandExecutorProps {\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  timerClient: TimerClient;\n  workflowClient: WorkflowClient;\n  eventClient: EventClient;\n}\n\n/**\n * Uses the clients to execute all supported commands and return events.\n */\nexport class CommandExecutor {\n  constructor(private props: CommandExecutorProps) {}\n\n  public async executeCommand(\n    workflow: Workflow,\n    executionId: string,\n    command: Command,\n    baseTime: Date\n  ): Promise<HistoryStateEvent> {\n    if (isScheduleActivityCommand(command)) {\n      return await this.scheduleActivity(\n        workflow,\n        executionId,\n        command,\n        baseTime\n      );\n    } else if (isScheduleWorkflowCommand(command)) {\n      return this.scheduleChildWorkflow(executionId, command);\n    } else if (isSleepForCommand(command) || isSleepUntilCommand(command)) {\n      // all sleep times are computed using the start time of the WorkflowTaskStarted\n      return this.scheduleSleep(executionId, command, baseTime);\n    } else if (isExpectSignalCommand(command)) {\n      // should the timeout command be generic (ex: StartTimeout) or specific (ex: ExpectSignal)?\n      return this.executeExpectSignal(executionId, command, baseTime);\n    } else if (isSendSignalCommand(command)) {\n      return this.sendSignal(executionId, command);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command);\n    } else {\n      return assertNever(command, `unknown command type`);\n    }\n  }\n\n  private async scheduleActivity(\n    workflow: Workflow,\n    executionId: string,\n    command: ScheduleActivityCommand,\n    baseTime: Date\n  ) {\n    const request: ActivityWorkerRequest = {\n      scheduledTime: new Date().toISOString(),\n      workflowName: workflow.workflowName,\n      executionId,\n      command,\n      retry: 0,\n    };\n\n    const timeoutStarter = command.timeoutSeconds\n      ? await this.props.timerClient.scheduleEvent<ActivityTimedOut>({\n          schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n          event: {\n            type: WorkflowEventType.ActivityTimedOut,\n            seq: command.seq,\n          },\n          executionId,\n        })\n      : undefined;\n\n    const activityStarter =\n      this.props.workflowRuntimeClient.startActivity(request);\n\n    await Promise.all([activityStarter, timeoutStarter]);\n\n    return createEvent<ActivityScheduled>({\n      type: WorkflowEventType.ActivityScheduled,\n      seq: command.seq,\n      name: command.name,\n    });\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startWorkflow({\n      workflowName: command.name,\n      input: command.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, command.seq),\n      seq: command.seq,\n      ...command.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>({\n      type: WorkflowEventType.ChildWorkflowScheduled,\n      seq: command.seq,\n      name: command.name,\n      input: command.input,\n    });\n  }\n\n  private async scheduleSleep(\n    executionId: string,\n\n    command: SleepForCommand | SleepUntilCommand,\n    baseTime: Date\n  ): Promise<SleepScheduled> {\n    // TODO validate\n    const untilTime = isSleepUntilCommand(command)\n      ? new Date(command.untilTime)\n      : new Date(baseTime.getTime() + command.durationSeconds * 1000);\n    const untilTimeIso = untilTime.toISOString();\n\n    await this.props.timerClient.scheduleEvent<SleepCompleted>({\n      event: {\n        type: WorkflowEventType.SleepCompleted,\n        seq: command.seq,\n      },\n      schedule: Schedule.absolute(untilTimeIso),\n      executionId,\n    });\n\n    return createEvent<SleepScheduled>({\n      type: WorkflowEventType.SleepScheduled,\n      seq: command.seq,\n      untilTime: untilTime.toISOString(),\n    });\n  }\n\n  private async executeExpectSignal(\n    executionId: string,\n\n    command: ExpectSignalCommand,\n    baseTime: Date\n  ): Promise<ExpectSignalStarted> {\n    if (command.timeoutSeconds) {\n      await this.props.timerClient.scheduleEvent<ExpectSignalTimedOut>({\n        event: {\n          signalId: command.signalId,\n          seq: command.seq,\n          type: WorkflowEventType.ExpectSignalTimedOut,\n        },\n        schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n        executionId,\n      });\n    }\n\n    return createEvent<ExpectSignalStarted>({\n      signalId: command.signalId,\n      seq: command.seq,\n      type: WorkflowEventType.ExpectSignalStarted,\n      timeoutSeconds: command.timeoutSeconds,\n    });\n  }\n\n  private async sendSignal(executionId: string, command: SendSignalCommand) {\n    const childExecutionId = isChildExecutionTarget(command.target)\n      ? formatExecutionId(\n          command.target.workflowName,\n          formatChildExecutionName(executionId, command.target.seq)\n        )\n      : command.target.executionId;\n\n    await this.props.workflowClient.sendSignal({\n      signal: command.signalId,\n      executionId: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>({\n      type: WorkflowEventType.SignalSent,\n      executionId: childExecutionId,\n      seq: command.seq,\n      signalId: command.signalId,\n      payload: command.payload,\n    });\n  }\n\n  private async startCondition(\n    executionId: string,\n    command: StartConditionCommand,\n    baseTime: Date\n  ) {\n    if (command.timeoutSeconds) {\n      await this.props.timerClient.scheduleEvent<ConditionTimedOut>({\n        event: {\n          type: WorkflowEventType.ConditionTimedOut,\n          seq: command.seq,\n        },\n        executionId,\n        schedule: Schedule.relative(command.timeoutSeconds, baseTime),\n      });\n    }\n\n    return createEvent<ConditionStarted>({\n      type: WorkflowEventType.ConditionStarted,\n      seq: command.seq!,\n    });\n  }\n\n  private async publishEvents(command: PublishEventsCommand) {\n    await this.props.eventClient.publish(...command.events);\n    return createEvent<EventsPublished>({\n      type: WorkflowEventType.EventsPublished,\n      events: command.events,\n      seq: command.seq!,\n    });\n  }\n}\n"]} |
@@ -10,3 +10,3 @@ export function isExecutionId(a) { | ||
} | ||
//API Gateway doesn't agree with uri encoding in path parameter... so we have these. for now | ||
// API Gateway doesn't agree with uri encoding in path parameter... so we have these. for now | ||
export function encodeExecutionId(executionId) { | ||
@@ -32,2 +32,2 @@ return Buffer.from(executionId, "utf-8").toString("base64"); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWlkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3J1bnRpbWUvZXhlY3V0aW9uLWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE1BQU0sVUFBVSxhQUFhLENBQUMsQ0FBTTtJQUNsQyxPQUFPLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7QUFDNUQsQ0FBQztBQUVELE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxXQUF3QjtJQUN4RCxPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFFLENBQUM7QUFDcEMsQ0FBQztBQUVELE1BQU0sVUFBVSxpQkFBaUIsQ0FHL0IsWUFBb0IsRUFBRSxFQUFVO0lBQ2hDLE9BQU8sR0FBRyxZQUFZLElBQUksRUFBRSxFQUFtQyxDQUFDO0FBQ2xFLENBQUM7QUFFRCw0RkFBNEY7QUFDNUYsTUFBTSxVQUFVLGlCQUFpQixDQUFDLFdBQW1CO0lBQ25ELE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQzlELENBQUM7QUFFRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLGNBQWMsQ0FBQztBQUUzRDs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLFVBQVUsd0JBQXdCLENBQ3RDLGlCQUF5QixFQUN6QixHQUFXO0lBRVgsT0FBTyxHQUFHLDRCQUE0QixHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FDaEUsR0FBRyxFQUNILEdBQUcsQ0FDSixJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEV4ZWN1dGlvbklEPFxuICBXb3JrZmxvd05hbWUgZXh0ZW5kcyBzdHJpbmcgPSBzdHJpbmcsXG4gIElEIGV4dGVuZHMgc3RyaW5nID0gc3RyaW5nXG4+ID0gYCR7V29ya2Zsb3dOYW1lfS8ke0lEfWA7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0V4ZWN1dGlvbklkKGE6IGFueSk6IGEgaXMgRXhlY3V0aW9uSUQge1xuICByZXR1cm4gdHlwZW9mIGEgPT09IFwic3RyaW5nXCIgJiYgYS5zcGxpdChcIi9cIikubGVuZ3RoID09PSAyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VXb3JrZmxvd05hbWUoZXhlY3V0aW9uSWQ6IEV4ZWN1dGlvbklEKTogc3RyaW5nIHtcbiAgcmV0dXJuIGV4ZWN1dGlvbklkLnNwbGl0KFwiL1wiKVswXSE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRFeGVjdXRpb25JZDxcbiAgV29ya2Zsb3dOYW1lIGV4dGVuZHMgc3RyaW5nLFxuICBJRCBleHRlbmRzIHN0cmluZ1xuPih3b3JrZmxvd05hbWU6IHN0cmluZywgaWQ6IHN0cmluZyk6IEV4ZWN1dGlvbklEPFdvcmtmbG93TmFtZSwgSUQ+IHtcbiAgcmV0dXJuIGAke3dvcmtmbG93TmFtZX0vJHtpZH1gIGFzIEV4ZWN1dGlvbklEPFdvcmtmbG93TmFtZSwgSUQ+O1xufVxuXG4vL0FQSSBHYXRld2F5IGRvZXNuJ3QgYWdyZWUgd2l0aCB1cmkgZW5jb2RpbmcgaW4gcGF0aCBwYXJhbWV0ZXIuLi4gc28gd2UgaGF2ZSB0aGVzZS4gZm9yIG5vd1xuZXhwb3J0IGZ1bmN0aW9uIGVuY29kZUV4ZWN1dGlvbklkKGV4ZWN1dGlvbklkOiBzdHJpbmcpIHtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKGV4ZWN1dGlvbklkLCBcInV0Zi04XCIpLnRvU3RyaW5nKFwiYmFzZTY0XCIpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZGVjb2RlRXhlY3V0aW9uSWQoZXhlY3V0aW9uSWQ6IHN0cmluZykge1xuICByZXR1cm4gQnVmZmVyLmZyb20oZXhlY3V0aW9uSWQsIFwiYmFzZTY0XCIpLnRvU3RyaW5nKFwidXRmLThcIik7XG59XG5cbmV4cG9ydCBjb25zdCBJTlRFUk5BTF9FWEVDVVRJT05fSURfUFJFRklYID0gXCIjI0VWRU5UVUFMIyNcIjtcblxuLyoqXG4gKiBGb3JtYXRzIGFuIGNoaWxkIHdvcmtmbG93IGV4ZWN1dGlvbiBhcyBhIHVuaXF1ZSwgZGV0ZXJtaW5pc3RpYyBuYW1lLlxuICogMS4gd2UgcHJlZml4IGl0IHdpdGgge0BsaW5rIElOVEVSTkFMX0VYRUNVVElPTl9JRF9QUkVGSVh9IHRvIGVuc3VyZSBpdCBpcyBpbXBvc3NpYmxlIGZvciBhIHVzZXIgdG8gY3JlYXRlIGl0LlxuICogMi4gd2UgY29uc3RydWN0IHRoZSBuYW1lIGZyb20gdGhlIHBhcmVudCBleGVjdXRpb24gSUQgYW5kIHRoZSBzZXEgLSB0aGlzIGVuc3VyZXMgdW5pcXVlbmVzcyBhbmQgaXMgZGV0ZXJtaW5pc3RpY1xuICpcbiAqIEl0IG11c3QgYmUgZGV0ZXJtaW5pc3RpYyB0byBlbnN1cmUgaWRlbXBvdGVuY3kuXG4gKlxuICogQHBhcmFtIHBhcmVudEV4ZWN1dGlvbklkIGlkIG9mIHRoZSBjYWxsZXIgZXhlY3V0aW9uIHVzZWQgdG8gY29tcHV0ZSB0aGUgY2hpbGQgd29ya2Zsb3cgbmFtZVxuICogQHBhcmFtIHNlcSBwb3NpdGlvbiB0aGF0IHN0YXJ0ZWQgdGhlIGNoaWxkIHdvcmtmbG93XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRDaGlsZEV4ZWN1dGlvbk5hbWUoXG4gIHBhcmVudEV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gIHNlcTogbnVtYmVyXG4pOiBzdHJpbmcge1xuICByZXR1cm4gYCR7SU5URVJOQUxfRVhFQ1VUSU9OX0lEX1BSRUZJWH0ke3BhcmVudEV4ZWN1dGlvbklkLnJlcGxhY2UoXG4gICAgXCIvXCIsXG4gICAgXCItXCJcbiAgKX0tJHtzZXF9YDtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWlkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL3J1bnRpbWUvZXhlY3V0aW9uLWlkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtBLE1BQU0sVUFBVSxhQUFhLENBQUMsQ0FBTTtJQUNsQyxPQUFPLE9BQU8sQ0FBQyxLQUFLLFFBQVEsSUFBSSxDQUFDLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDLE1BQU0sS0FBSyxDQUFDLENBQUM7QUFDNUQsQ0FBQztBQUVELE1BQU0sVUFBVSxpQkFBaUIsQ0FBQyxXQUF3QjtJQUN4RCxPQUFPLFdBQVcsQ0FBQyxLQUFLLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFFLENBQUM7QUFDcEMsQ0FBQztBQUVELE1BQU0sVUFBVSxpQkFBaUIsQ0FHL0IsWUFBb0IsRUFBRSxFQUFVO0lBQ2hDLE9BQU8sR0FBRyxZQUFZLElBQUksRUFBRSxFQUFtQyxDQUFDO0FBQ2xFLENBQUM7QUFFRCw2RkFBNkY7QUFDN0YsTUFBTSxVQUFVLGlCQUFpQixDQUFDLFdBQW1CO0lBQ25ELE9BQU8sTUFBTSxDQUFDLElBQUksQ0FBQyxXQUFXLEVBQUUsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0FBQzlELENBQUM7QUFFRCxNQUFNLFVBQVUsaUJBQWlCLENBQUMsV0FBbUI7SUFDbkQsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLFdBQVcsRUFBRSxRQUFRLENBQUMsQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDOUQsQ0FBQztBQUVELE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLGNBQWMsQ0FBQztBQUUzRDs7Ozs7Ozs7O0dBU0c7QUFDSCxNQUFNLFVBQVUsd0JBQXdCLENBQ3RDLGlCQUF5QixFQUN6QixHQUFXO0lBRVgsT0FBTyxHQUFHLDRCQUE0QixHQUFHLGlCQUFpQixDQUFDLE9BQU8sQ0FDaEUsR0FBRyxFQUNILEdBQUcsQ0FDSixJQUFJLEdBQUcsRUFBRSxDQUFDO0FBQ2IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEV4ZWN1dGlvbklEPFxuICBXb3JrZmxvd05hbWUgZXh0ZW5kcyBzdHJpbmcgPSBzdHJpbmcsXG4gIElEIGV4dGVuZHMgc3RyaW5nID0gc3RyaW5nXG4+ID0gYCR7V29ya2Zsb3dOYW1lfS8ke0lEfWA7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0V4ZWN1dGlvbklkKGE6IGFueSk6IGEgaXMgRXhlY3V0aW9uSUQge1xuICByZXR1cm4gdHlwZW9mIGEgPT09IFwic3RyaW5nXCIgJiYgYS5zcGxpdChcIi9cIikubGVuZ3RoID09PSAyO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VXb3JrZmxvd05hbWUoZXhlY3V0aW9uSWQ6IEV4ZWN1dGlvbklEKTogc3RyaW5nIHtcbiAgcmV0dXJuIGV4ZWN1dGlvbklkLnNwbGl0KFwiL1wiKVswXSE7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBmb3JtYXRFeGVjdXRpb25JZDxcbiAgV29ya2Zsb3dOYW1lIGV4dGVuZHMgc3RyaW5nLFxuICBJRCBleHRlbmRzIHN0cmluZ1xuPih3b3JrZmxvd05hbWU6IHN0cmluZywgaWQ6IHN0cmluZyk6IEV4ZWN1dGlvbklEPFdvcmtmbG93TmFtZSwgSUQ+IHtcbiAgcmV0dXJuIGAke3dvcmtmbG93TmFtZX0vJHtpZH1gIGFzIEV4ZWN1dGlvbklEPFdvcmtmbG93TmFtZSwgSUQ+O1xufVxuXG4vLyBBUEkgR2F0ZXdheSBkb2Vzbid0IGFncmVlIHdpdGggdXJpIGVuY29kaW5nIGluIHBhdGggcGFyYW1ldGVyLi4uIHNvIHdlIGhhdmUgdGhlc2UuIGZvciBub3dcbmV4cG9ydCBmdW5jdGlvbiBlbmNvZGVFeGVjdXRpb25JZChleGVjdXRpb25JZDogc3RyaW5nKSB7XG4gIHJldHVybiBCdWZmZXIuZnJvbShleGVjdXRpb25JZCwgXCJ1dGYtOFwiKS50b1N0cmluZyhcImJhc2U2NFwiKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGRlY29kZUV4ZWN1dGlvbklkKGV4ZWN1dGlvbklkOiBzdHJpbmcpIHtcbiAgcmV0dXJuIEJ1ZmZlci5mcm9tKGV4ZWN1dGlvbklkLCBcImJhc2U2NFwiKS50b1N0cmluZyhcInV0Zi04XCIpO1xufVxuXG5leHBvcnQgY29uc3QgSU5URVJOQUxfRVhFQ1VUSU9OX0lEX1BSRUZJWCA9IFwiIyNFVkVOVFVBTCMjXCI7XG5cbi8qKlxuICogRm9ybWF0cyBhbiBjaGlsZCB3b3JrZmxvdyBleGVjdXRpb24gYXMgYSB1bmlxdWUsIGRldGVybWluaXN0aWMgbmFtZS5cbiAqIDEuIHdlIHByZWZpeCBpdCB3aXRoIHtAbGluayBJTlRFUk5BTF9FWEVDVVRJT05fSURfUFJFRklYfSB0byBlbnN1cmUgaXQgaXMgaW1wb3NzaWJsZSBmb3IgYSB1c2VyIHRvIGNyZWF0ZSBpdC5cbiAqIDIuIHdlIGNvbnN0cnVjdCB0aGUgbmFtZSBmcm9tIHRoZSBwYXJlbnQgZXhlY3V0aW9uIElEIGFuZCB0aGUgc2VxIC0gdGhpcyBlbnN1cmVzIHVuaXF1ZW5lc3MgYW5kIGlzIGRldGVybWluaXN0aWNcbiAqXG4gKiBJdCBtdXN0IGJlIGRldGVybWluaXN0aWMgdG8gZW5zdXJlIGlkZW1wb3RlbmN5LlxuICpcbiAqIEBwYXJhbSBwYXJlbnRFeGVjdXRpb25JZCBpZCBvZiB0aGUgY2FsbGVyIGV4ZWN1dGlvbiB1c2VkIHRvIGNvbXB1dGUgdGhlIGNoaWxkIHdvcmtmbG93IG5hbWVcbiAqIEBwYXJhbSBzZXEgcG9zaXRpb24gdGhhdCBzdGFydGVkIHRoZSBjaGlsZCB3b3JrZmxvd1xuICovXG5leHBvcnQgZnVuY3Rpb24gZm9ybWF0Q2hpbGRFeGVjdXRpb25OYW1lKFxuICBwYXJlbnRFeGVjdXRpb25JZDogc3RyaW5nLFxuICBzZXE6IG51bWJlclxuKTogc3RyaW5nIHtcbiAgcmV0dXJuIGAke0lOVEVSTkFMX0VYRUNVVElPTl9JRF9QUkVGSVh9JHtwYXJlbnRFeGVjdXRpb25JZC5yZXBsYWNlKFxuICAgIFwiL1wiLFxuICAgIFwiLVwiXG4gICl9LSR7c2VxfWA7XG59XG4iXX0= |
@@ -178,3 +178,3 @@ import { inspect } from "util"; | ||
const newWorkflowEvents = []; | ||
let resultEvent = undefined; | ||
let resultEvent; | ||
const seenEvents = new Set(originalHistory.map(getEventId)); | ||
@@ -301,2 +301,2 @@ for await (const event of executionGenerator) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":"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","sourcesContent":["import { inspect } from \"util\";\nimport { Command } from \"../../command.js\";\nimport { WorkflowContext } from \"../../context.js\";\nimport {\n  createEvent,\n  getEventId,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isWorkflowCompleted,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowCompleted,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowTaskCompleted,\n  WorkflowTaskStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  CompleteExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isCompleteExecution,\n} from \"../../execution.js\";\nimport { isFailed, isResolved, isResult, Result } from \"../../result.js\";\nimport { lookupWorkflow, progressWorkflow, Workflow } from \"../../workflow.js\";\nimport {\n  EventClient,\n  ExecutionHistoryClient,\n  MetricsClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"../clients/index.js\";\nimport { CommandExecutor } from \"../command-executor.js\";\nimport { isExecutionId, parseWorkflowName } from \"../execution-id.js\";\nimport type { Logger } from \"../logger.js\";\nimport { MetricsCommon, OrchestratorMetrics } from \"../metrics/constants.js\";\nimport { MetricsLogger } from \"../metrics/metrics-logger.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed, timedSync } from \"../metrics/utils.js\";\nimport { promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\n\n/**\n * The Orchestrator's client dependencies.\n */\nexport interface OrchestratorDependencies {\n  executionHistoryClient: ExecutionHistoryClient;\n  timerClient: TimerClient;\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  workflowClient: WorkflowClient;\n  metricsClient: MetricsClient;\n  eventClient: EventClient;\n  logger: Logger;\n}\n\nexport interface OrchestratorResult {\n  /**\n   * IDs of the Executions that failed to orchestrate.\n   */\n  failedExecutionIds: string[];\n}\n\n/**\n * Creates a generic function for orchestrating a batch of executions\n * that can be used in runtime implementations. This implementation is\n * decoupled from a runtime's specifics by the clients. A runtime must\n * inject its own client implementations designed for that platform.\n */\nexport function createOrchestrator({\n  executionHistoryClient,\n  timerClient,\n  workflowRuntimeClient,\n  workflowClient,\n  metricsClient,\n  eventClient,\n  logger,\n}: OrchestratorDependencies): (\n  eventsByExecutionId: Record<string, HistoryStateEvent[]>\n) => Promise<OrchestratorResult> {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (eventsByExecutionId) => {\n    logger.debug(\"Handle workflowQueue records\");\n\n    logger.info(\n      \"Found execution ids: \" + Object.keys(eventsByExecutionId).join(\", \")\n    );\n\n    // for each execution id\n    const results = await promiseAllSettledPartitioned(\n      Object.entries(eventsByExecutionId),\n      async ([executionId, records]) => {\n        if (!isExecutionId(executionId)) {\n          throw new Error(`invalid ExecutionID: '${executionId}'`);\n        }\n        const workflowName = parseWorkflowName(executionId);\n        if (workflowName === undefined) {\n          throw new Error(`execution ID '${executionId}' does not exist`);\n        }\n        const workflow = lookupWorkflow(workflowName);\n        if (workflow === undefined) {\n          throw new Error(`no such workflow with name '${workflowName}'`);\n        }\n        // TODO: get workflow from execution id\n        return orchestrateExecution(workflow, executionId, records);\n      }\n    );\n\n    logger.debug(\n      \"Executions succeeded: \" +\n        results.fulfilled.map(([[executionId]]) => executionId).join(\",\")\n    );\n\n    if (results.rejected.length > 0) {\n      logger.error(\n        \"Executions failed: \\n\" +\n          results.rejected\n            .map(([[executionId], error]) => `${executionId}: ${error}`)\n            .join(\"\\n\")\n      );\n    }\n\n    return {\n      failedExecutionIds: results.rejected.map((rejected) => rejected[0][0]),\n    };\n  };\n\n  async function orchestrateExecution(\n    workflow: Workflow,\n    executionId: string,\n    events: HistoryStateEvent[]\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = new Date();\n    try {\n      // load\n      const history = await loadHistory();\n\n      // execute\n      const { updatedHistoryEvents, newEvents, resultEvent } =\n        await executeWorkflow(history);\n\n      // persist\n      await persistWorkflowResult(resultEvent);\n      await saveNewEventsToExecutionHistory(newEvents);\n      await updateHistory(updatedHistoryEvents);\n\n      // Only log these metrics once the orchestrator has completed successfully.\n      logEventMetrics(metrics, events, start);\n    } catch (err) {\n      executionLogger.error(inspect(err));\n      throw err;\n    } finally {\n      await metrics.flush();\n    }\n\n    /**\n     * Executes the workflow and returns the history and events to persist.\n     */\n    async function executeWorkflow(history: HistoryStateEvent[]) {\n      // length of time the oldest event in the queue.\n      const maxTaskAge = Math.max(\n        ...events.map(\n          (event) => new Date().getTime() - Date.parse(event.timestamp)\n        )\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.MaxTaskAge,\n        maxTaskAge,\n        Unit.Milliseconds\n      );\n\n      return partitionExecutionResults(history, executeWorkflowGenerator());\n\n      async function* executeWorkflowGenerator() {\n        yield createEvent<WorkflowTaskStarted>(\n          {\n            type: WorkflowEventType.WorkflowTaskStarted,\n          },\n          start\n        );\n\n        const workflowContext: WorkflowContext = {\n          name: workflow.workflowName,\n        };\n\n        const startEvent = history.find(isWorkflowStarted);\n\n        /**\n         * Check to see if this is the first run of the workflow (or all others have failed).\n         * If so, check to see if the workflow has timeout to start.\n         */\n        if (!startEvent) {\n          const newWorkflowStart = events.find(isWorkflowStarted);\n\n          if (newWorkflowStart?.timeoutTime) {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 1);\n            await timed(\n              metrics,\n              OrchestratorMetrics.TimeoutStartedDuration,\n              () =>\n                timerClient.scheduleEvent<WorkflowTimedOut>({\n                  schedule: Schedule.absolute(newWorkflowStart.timeoutTime!),\n                  event: createEvent<WorkflowTimedOut>({\n                    type: WorkflowEventType.WorkflowTimedOut,\n                  }),\n                  executionId,\n                })\n            );\n          } else {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 0);\n          }\n        }\n\n        const {\n          result,\n          commands: newCommands,\n          history: updatedHistoryEvents,\n        } = timedSync(\n          metrics,\n          OrchestratorMetrics.AdvanceExecutionDuration,\n          () => {\n            try {\n              return progressWorkflow(\n                workflow,\n                history,\n                events,\n                workflowContext,\n                executionId\n              );\n            } catch (err) {\n              console.log(\"workflow error\");\n              executionLogger.error(inspect(err));\n              throw err;\n            }\n          }\n        );\n\n        metrics.setProperty(\n          OrchestratorMetrics.AdvanceExecutionEvents,\n          updatedHistoryEvents.length\n        );\n\n        yield* updatedHistoryEvents;\n\n        executionLogger.debug(\n          \"Workflow terminated with: \" + JSON.stringify(result)\n        );\n\n        executionLogger.info(`Found ${newCommands.length} new commands.`);\n\n        yield* await timed(\n          metrics,\n          OrchestratorMetrics.InvokeCommandsDuration,\n          () => processCommands(newCommands)\n        );\n\n        metrics.putMetric(\n          OrchestratorMetrics.CommandsInvoked,\n          newCommands.length,\n          Unit.Count\n        );\n\n        // tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n        // This represent the workflow orchestration time of User Perceived Latency\n        // Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n        // AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n        metrics.putMetric(\n          OrchestratorMetrics.TimeToCommandsInvoked,\n          maxTaskAge + (new Date().getTime() - start.getTime())\n        );\n\n        yield createEvent<WorkflowTaskCompleted>({\n          type: WorkflowEventType.WorkflowTaskCompleted,\n        });\n\n        if (isResult(result)) {\n          if (isFailed(result)) {\n            const [error, message] = extendsError(result.error)\n              ? [result.error.name, result.error.message]\n              : [\"Error\", JSON.stringify(result.error)];\n            yield createEvent<WorkflowFailed>({\n              type: WorkflowEventType.WorkflowFailed,\n              error,\n              message,\n            });\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>({\n              type: WorkflowEventType.WorkflowCompleted,\n              output: result.value,\n            });\n          }\n        }\n\n        return result;\n      }\n\n      /**\n       * Partitions the events output by the workflow.\n       *\n       * We need two different collection of events.\n       *\n       * History Events - these are the events that workflow uses to maintain state.\n       *                  each run of the workflow we may filter or add events to this collection.\n       *                  these events will be persisted for the next run.\n       * Workflow Events - these are fined grained events emitted by the workflow. They drive UIs,\n       *                   visualization and debugging. They may not be used in the interpreter.\n       *                   The new ones will be persisted after each run.\n       */\n      async function partitionExecutionResults(\n        originalHistory: HistoryStateEvent[],\n        executionGenerator: AsyncGenerator<WorkflowEvent, Result | undefined>\n      ) {\n        const updatedHistoryEvents: HistoryStateEvent[] = [];\n        const newWorkflowEvents: WorkflowEvent[] = [];\n        let resultEvent: WorkflowCompleted | WorkflowFailed | undefined =\n          undefined;\n        const seenEvents: Set<string> = new Set(\n          originalHistory.map(getEventId)\n        );\n\n        for await (const event of executionGenerator) {\n          const id = getEventId(event);\n          // newWorkflowEvents are the unique new events generated by this workflow execution.\n          if (!seenEvents.has(id)) {\n            newWorkflowEvents.push(event);\n            seenEvents.add(id);\n          }\n          if (isWorkflowCompleted(event) || isWorkflowFailed(event)) {\n            resultEvent = event;\n          }\n          // updatedHistoryEvents are all HistoryEvents old and new.\n          if (isWorkflowStarted(event) || isHistoryEvent(event)) {\n            updatedHistoryEvents.push(event);\n          }\n        }\n\n        return {\n          updatedHistoryEvents,\n          newEvents: newWorkflowEvents,\n          resultEvent,\n        };\n      }\n    }\n\n    async function loadHistory(): Promise<HistoryStateEvent[]> {\n      executionLogger.debug(\"Load history\");\n      // load history\n      const history = await timed(\n        metrics,\n        OrchestratorMetrics.LoadHistoryDuration,\n        async () => workflowRuntimeClient.getHistory(executionId)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.LoadedHistoryEvents,\n        history.length\n      );\n\n      return history;\n    }\n\n    /**\n     * Saves all new events generated by this execution to the {@link ExecutionHistoryClient}.\n     */\n    async function saveNewEventsToExecutionHistory(newEvents: WorkflowEvent[]) {\n      await timed(\n        metrics,\n        OrchestratorMetrics.AddNewExecutionEventsDuration,\n        () => executionHistoryClient.putEvents(executionId, newEvents)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.NewExecutionEvents,\n        newEvents.length\n      );\n    }\n\n    /**\n     * Saves all of the History Events (the ones the workflow uses) to s3.\n     *\n     * @param updatedHistoryEvents - The previous history plus task events minus any filtered events plus synthetic events.\n     * @param commandEvents - events produced by the commands run.\n     */\n    async function updateHistory(updatedHistoryEvents: HistoryStateEvent[]) {\n      console.debug(\n        \"New history to save\",\n        JSON.stringify(updatedHistoryEvents)\n      );\n\n      // update history from new commands and events\n      // for now, we'll just write the awaitable command events to s3 as those are the ones needed to reconstruct the workflow.\n      const { bytes: historyUpdatedBytes } = await timed(\n        metrics,\n        OrchestratorMetrics.SaveHistoryDuration,\n        () =>\n          workflowRuntimeClient.updateHistory({\n            executionId,\n            events: updatedHistoryEvents,\n          })\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.SavedHistoryEvents,\n        updatedHistoryEvents.length\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.SavedHistoryBytes,\n        historyUpdatedBytes,\n        Unit.Bytes\n      );\n    }\n\n    async function persistWorkflowResult(\n      resultEvent?: WorkflowCompleted | WorkflowFailed\n    ) {\n      // if the workflow is complete, add success and failure to the commands.\n      if (resultEvent) {\n        if (isWorkflowFailed(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.failExecution({\n                executionId,\n                error: resultEvent.error,\n                message: resultEvent.message,\n              })\n          );\n\n          logExecutionCompleteMetrics(execution);\n        } else if (isWorkflowCompleted(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.completeExecution({\n                executionId,\n                result: resultEvent.output,\n              })\n          );\n          logExecutionCompleteMetrics(execution);\n        }\n      }\n    }\n\n    /**\n     * Generate events from commands and create a function which will start the commands.\n     *\n     * Does not actually write the commands out.\n     */\n    async function processCommands(\n      commands: Command[]\n    ): Promise<HistoryStateEvent[]> {\n      console.debug(\"Commands to send\", JSON.stringify(commands));\n      // register command events\n      return await Promise.all(\n        commands.map((command) =>\n          commandExecutor.executeCommand(workflow, executionId, command, start)\n        )\n      );\n    }\n\n    function initializeMetrics() {\n      const metrics = metricsClient.createMetricsLogger();\n      metricsClient.createMetricsLogger();\n      metrics.resetDimensions(false);\n      metrics.setNamespace(MetricsCommon.EventualNamespace);\n      metrics.setDimensions({\n        [MetricsCommon.WorkflowNameDimension]: workflow.workflowName,\n      });\n      // number of events that came from the workflow task\n      metrics.setProperty(OrchestratorMetrics.TaskEvents, events.length);\n      // number of workflow tasks that are being processed in the batch (max: 10)\n      metrics.setProperty(OrchestratorMetrics.AggregatedTasks, events.length);\n\n      metrics.setProperty(OrchestratorMetrics.ExecutionId, executionId);\n      metrics.setProperty(\n        OrchestratorMetrics.Version,\n        OrchestratorMetrics.VersionV1\n      );\n      return metrics;\n    }\n\n    function logExecutionCompleteMetrics(\n      execution: CompleteExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.COMPLETE ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.COMPLETE ? 0 : 1,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionTotalDuration,\n        new Date(execution.endTime).getTime() -\n          new Date(execution.startTime).getTime()\n      );\n      if (isCompleteExecution(execution)) {\n        metrics.putMetric(\n          OrchestratorMetrics.ExecutionResultBytes,\n          execution.result ? JSON.stringify(execution.result).length : 0,\n          Unit.Bytes\n        );\n      }\n    }\n  }\n}\n\n/** Logs metrics specific to the incoming events */\nfunction logEventMetrics(\n  metrics: MetricsLogger,\n  events: WorkflowEvent[],\n  now: Date\n) {\n  const sleepCompletedEvents = events.filter(isSleepCompleted);\n  if (sleepCompletedEvents.length > 0) {\n    const sleepCompletedVariance = sleepCompletedEvents.map(\n      (s) => now.getTime() - new Date(s.timestamp).getTime()\n    );\n    const avg =\n      sleepCompletedVariance.reduce((t, n) => t + n, 0) /\n      sleepCompletedVariance.length;\n    metrics.setProperty(OrchestratorMetrics.SleepVarianceMillis, avg);\n  }\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":"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","sourcesContent":["import { inspect } from \"util\";\nimport { Command } from \"../../command.js\";\nimport { WorkflowContext } from \"../../context.js\";\nimport {\n  createEvent,\n  getEventId,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isWorkflowCompleted,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowCompleted,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowTaskCompleted,\n  WorkflowTaskStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  CompleteExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isCompleteExecution,\n} from \"../../execution.js\";\nimport { isFailed, isResolved, isResult, Result } from \"../../result.js\";\nimport { lookupWorkflow, progressWorkflow, Workflow } from \"../../workflow.js\";\nimport {\n  EventClient,\n  ExecutionHistoryClient,\n  MetricsClient,\n  Schedule,\n  TimerClient,\n  WorkflowClient,\n  WorkflowRuntimeClient,\n} from \"../clients/index.js\";\nimport { CommandExecutor } from \"../command-executor.js\";\nimport { isExecutionId, parseWorkflowName } from \"../execution-id.js\";\nimport type { Logger } from \"../logger.js\";\nimport { MetricsCommon, OrchestratorMetrics } from \"../metrics/constants.js\";\nimport { MetricsLogger } from \"../metrics/metrics-logger.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed, timedSync } from \"../metrics/utils.js\";\nimport { promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\n\n/**\n * The Orchestrator's client dependencies.\n */\nexport interface OrchestratorDependencies {\n  executionHistoryClient: ExecutionHistoryClient;\n  timerClient: TimerClient;\n  workflowRuntimeClient: WorkflowRuntimeClient;\n  workflowClient: WorkflowClient;\n  metricsClient: MetricsClient;\n  eventClient: EventClient;\n  logger: Logger;\n}\n\nexport interface OrchestratorResult {\n  /**\n   * IDs of the Executions that failed to orchestrate.\n   */\n  failedExecutionIds: string[];\n}\n\n/**\n * Creates a generic function for orchestrating a batch of executions\n * that can be used in runtime implementations. This implementation is\n * decoupled from a runtime's specifics by the clients. A runtime must\n * inject its own client implementations designed for that platform.\n */\nexport function createOrchestrator({\n  executionHistoryClient,\n  timerClient,\n  workflowRuntimeClient,\n  workflowClient,\n  metricsClient,\n  eventClient,\n  logger,\n}: OrchestratorDependencies): (\n  eventsByExecutionId: Record<string, HistoryStateEvent[]>\n) => Promise<OrchestratorResult> {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (eventsByExecutionId) => {\n    logger.debug(\"Handle workflowQueue records\");\n\n    logger.info(\n      \"Found execution ids: \" + Object.keys(eventsByExecutionId).join(\", \")\n    );\n\n    // for each execution id\n    const results = await promiseAllSettledPartitioned(\n      Object.entries(eventsByExecutionId),\n      async ([executionId, records]) => {\n        if (!isExecutionId(executionId)) {\n          throw new Error(`invalid ExecutionID: '${executionId}'`);\n        }\n        const workflowName = parseWorkflowName(executionId);\n        if (workflowName === undefined) {\n          throw new Error(`execution ID '${executionId}' does not exist`);\n        }\n        const workflow = lookupWorkflow(workflowName);\n        if (workflow === undefined) {\n          throw new Error(`no such workflow with name '${workflowName}'`);\n        }\n        // TODO: get workflow from execution id\n        return orchestrateExecution(workflow, executionId, records);\n      }\n    );\n\n    logger.debug(\n      \"Executions succeeded: \" +\n        results.fulfilled.map(([[executionId]]) => executionId).join(\",\")\n    );\n\n    if (results.rejected.length > 0) {\n      logger.error(\n        \"Executions failed: \\n\" +\n          results.rejected\n            .map(([[executionId], error]) => `${executionId}: ${error}`)\n            .join(\"\\n\")\n      );\n    }\n\n    return {\n      failedExecutionIds: results.rejected.map((rejected) => rejected[0][0]),\n    };\n  };\n\n  async function orchestrateExecution(\n    workflow: Workflow,\n    executionId: string,\n    events: HistoryStateEvent[]\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = new Date();\n    try {\n      // load\n      const history = await loadHistory();\n\n      // execute\n      const { updatedHistoryEvents, newEvents, resultEvent } =\n        await executeWorkflow(history);\n\n      // persist\n      await persistWorkflowResult(resultEvent);\n      await saveNewEventsToExecutionHistory(newEvents);\n      await updateHistory(updatedHistoryEvents);\n\n      // Only log these metrics once the orchestrator has completed successfully.\n      logEventMetrics(metrics, events, start);\n    } catch (err) {\n      executionLogger.error(inspect(err));\n      throw err;\n    } finally {\n      await metrics.flush();\n    }\n\n    /**\n     * Executes the workflow and returns the history and events to persist.\n     */\n    async function executeWorkflow(history: HistoryStateEvent[]) {\n      // length of time the oldest event in the queue.\n      const maxTaskAge = Math.max(\n        ...events.map(\n          (event) => new Date().getTime() - Date.parse(event.timestamp)\n        )\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.MaxTaskAge,\n        maxTaskAge,\n        Unit.Milliseconds\n      );\n\n      return partitionExecutionResults(history, executeWorkflowGenerator());\n\n      async function* executeWorkflowGenerator() {\n        yield createEvent<WorkflowTaskStarted>(\n          {\n            type: WorkflowEventType.WorkflowTaskStarted,\n          },\n          start\n        );\n\n        const workflowContext: WorkflowContext = {\n          name: workflow.workflowName,\n        };\n\n        const startEvent = history.find(isWorkflowStarted);\n\n        /**\n         * Check to see if this is the first run of the workflow (or all others have failed).\n         * If so, check to see if the workflow has timeout to start.\n         */\n        if (!startEvent) {\n          const newWorkflowStart = events.find(isWorkflowStarted);\n\n          if (newWorkflowStart?.timeoutTime) {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 1);\n            await timed(\n              metrics,\n              OrchestratorMetrics.TimeoutStartedDuration,\n              () =>\n                timerClient.scheduleEvent<WorkflowTimedOut>({\n                  schedule: Schedule.absolute(newWorkflowStart.timeoutTime!),\n                  event: createEvent<WorkflowTimedOut>({\n                    type: WorkflowEventType.WorkflowTimedOut,\n                  }),\n                  executionId,\n                })\n            );\n          } else {\n            metrics.setProperty(OrchestratorMetrics.TimeoutStarted, 0);\n          }\n        }\n\n        const {\n          result,\n          commands: newCommands,\n          history: updatedHistoryEvents,\n        } = timedSync(\n          metrics,\n          OrchestratorMetrics.AdvanceExecutionDuration,\n          () => {\n            try {\n              return progressWorkflow(\n                workflow,\n                history,\n                events,\n                workflowContext,\n                executionId\n              );\n            } catch (err) {\n              console.log(\"workflow error\");\n              executionLogger.error(inspect(err));\n              throw err;\n            }\n          }\n        );\n\n        metrics.setProperty(\n          OrchestratorMetrics.AdvanceExecutionEvents,\n          updatedHistoryEvents.length\n        );\n\n        yield* updatedHistoryEvents;\n\n        executionLogger.debug(\n          \"Workflow terminated with: \" + JSON.stringify(result)\n        );\n\n        executionLogger.info(`Found ${newCommands.length} new commands.`);\n\n        yield* await timed(\n          metrics,\n          OrchestratorMetrics.InvokeCommandsDuration,\n          () => processCommands(newCommands)\n        );\n\n        metrics.putMetric(\n          OrchestratorMetrics.CommandsInvoked,\n          newCommands.length,\n          Unit.Count\n        );\n\n        // tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n        // This represent the workflow orchestration time of User Perceived Latency\n        // Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n        // AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n        metrics.putMetric(\n          OrchestratorMetrics.TimeToCommandsInvoked,\n          maxTaskAge + (new Date().getTime() - start.getTime())\n        );\n\n        yield createEvent<WorkflowTaskCompleted>({\n          type: WorkflowEventType.WorkflowTaskCompleted,\n        });\n\n        if (isResult(result)) {\n          if (isFailed(result)) {\n            const [error, message] = extendsError(result.error)\n              ? [result.error.name, result.error.message]\n              : [\"Error\", JSON.stringify(result.error)];\n            yield createEvent<WorkflowFailed>({\n              type: WorkflowEventType.WorkflowFailed,\n              error,\n              message,\n            });\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>({\n              type: WorkflowEventType.WorkflowCompleted,\n              output: result.value,\n            });\n          }\n        }\n\n        return result;\n      }\n\n      /**\n       * Partitions the events output by the workflow.\n       *\n       * We need two different collection of events.\n       *\n       * History Events - these are the events that workflow uses to maintain state.\n       *                  each run of the workflow we may filter or add events to this collection.\n       *                  these events will be persisted for the next run.\n       * Workflow Events - these are fined grained events emitted by the workflow. They drive UIs,\n       *                   visualization and debugging. They may not be used in the interpreter.\n       *                   The new ones will be persisted after each run.\n       */\n      async function partitionExecutionResults(\n        originalHistory: HistoryStateEvent[],\n        executionGenerator: AsyncGenerator<WorkflowEvent, Result | undefined>\n      ) {\n        const updatedHistoryEvents: HistoryStateEvent[] = [];\n        const newWorkflowEvents: WorkflowEvent[] = [];\n        let resultEvent: WorkflowCompleted | WorkflowFailed | undefined;\n        const seenEvents: Set<string> = new Set(\n          originalHistory.map(getEventId)\n        );\n\n        for await (const event of executionGenerator) {\n          const id = getEventId(event);\n          // newWorkflowEvents are the unique new events generated by this workflow execution.\n          if (!seenEvents.has(id)) {\n            newWorkflowEvents.push(event);\n            seenEvents.add(id);\n          }\n          if (isWorkflowCompleted(event) || isWorkflowFailed(event)) {\n            resultEvent = event;\n          }\n          // updatedHistoryEvents are all HistoryEvents old and new.\n          if (isWorkflowStarted(event) || isHistoryEvent(event)) {\n            updatedHistoryEvents.push(event);\n          }\n        }\n\n        return {\n          updatedHistoryEvents,\n          newEvents: newWorkflowEvents,\n          resultEvent,\n        };\n      }\n    }\n\n    async function loadHistory(): Promise<HistoryStateEvent[]> {\n      executionLogger.debug(\"Load history\");\n      // load history\n      const history = await timed(\n        metrics,\n        OrchestratorMetrics.LoadHistoryDuration,\n        async () => workflowRuntimeClient.getHistory(executionId)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.LoadedHistoryEvents,\n        history.length\n      );\n\n      return history;\n    }\n\n    /**\n     * Saves all new events generated by this execution to the {@link ExecutionHistoryClient}.\n     */\n    async function saveNewEventsToExecutionHistory(newEvents: WorkflowEvent[]) {\n      await timed(\n        metrics,\n        OrchestratorMetrics.AddNewExecutionEventsDuration,\n        () => executionHistoryClient.putEvents(executionId, newEvents)\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.NewExecutionEvents,\n        newEvents.length\n      );\n    }\n\n    /**\n     * Saves all of the History Events (the ones the workflow uses) to s3.\n     *\n     * @param updatedHistoryEvents - The previous history plus task events minus any filtered events plus synthetic events.\n     * @param commandEvents - events produced by the commands run.\n     */\n    async function updateHistory(updatedHistoryEvents: HistoryStateEvent[]) {\n      console.debug(\n        \"New history to save\",\n        JSON.stringify(updatedHistoryEvents)\n      );\n\n      // update history from new commands and events\n      // for now, we'll just write the awaitable command events to s3 as those are the ones needed to reconstruct the workflow.\n      const { bytes: historyUpdatedBytes } = await timed(\n        metrics,\n        OrchestratorMetrics.SaveHistoryDuration,\n        () =>\n          workflowRuntimeClient.updateHistory({\n            executionId,\n            events: updatedHistoryEvents,\n          })\n      );\n\n      metrics.setProperty(\n        OrchestratorMetrics.SavedHistoryEvents,\n        updatedHistoryEvents.length\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.SavedHistoryBytes,\n        historyUpdatedBytes,\n        Unit.Bytes\n      );\n    }\n\n    async function persistWorkflowResult(\n      resultEvent?: WorkflowCompleted | WorkflowFailed\n    ) {\n      // if the workflow is complete, add success and failure to the commands.\n      if (resultEvent) {\n        if (isWorkflowFailed(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.failExecution({\n                executionId,\n                error: resultEvent.error,\n                message: resultEvent.message,\n              })\n          );\n\n          logExecutionCompleteMetrics(execution);\n        } else if (isWorkflowCompleted(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.completeExecution({\n                executionId,\n                result: resultEvent.output,\n              })\n          );\n          logExecutionCompleteMetrics(execution);\n        }\n      }\n    }\n\n    /**\n     * Generate events from commands and create a function which will start the commands.\n     *\n     * Does not actually write the commands out.\n     */\n    async function processCommands(\n      commands: Command[]\n    ): Promise<HistoryStateEvent[]> {\n      console.debug(\"Commands to send\", JSON.stringify(commands));\n      // register command events\n      return await Promise.all(\n        commands.map((command) =>\n          commandExecutor.executeCommand(workflow, executionId, command, start)\n        )\n      );\n    }\n\n    function initializeMetrics() {\n      const metrics = metricsClient.createMetricsLogger();\n      metricsClient.createMetricsLogger();\n      metrics.resetDimensions(false);\n      metrics.setNamespace(MetricsCommon.EventualNamespace);\n      metrics.setDimensions({\n        [MetricsCommon.WorkflowNameDimension]: workflow.workflowName,\n      });\n      // number of events that came from the workflow task\n      metrics.setProperty(OrchestratorMetrics.TaskEvents, events.length);\n      // number of workflow tasks that are being processed in the batch (max: 10)\n      metrics.setProperty(OrchestratorMetrics.AggregatedTasks, events.length);\n\n      metrics.setProperty(OrchestratorMetrics.ExecutionId, executionId);\n      metrics.setProperty(\n        OrchestratorMetrics.Version,\n        OrchestratorMetrics.VersionV1\n      );\n      return metrics;\n    }\n\n    function logExecutionCompleteMetrics(\n      execution: CompleteExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.COMPLETE ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.COMPLETE ? 0 : 1,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionTotalDuration,\n        new Date(execution.endTime).getTime() -\n          new Date(execution.startTime).getTime()\n      );\n      if (isCompleteExecution(execution)) {\n        metrics.putMetric(\n          OrchestratorMetrics.ExecutionResultBytes,\n          execution.result ? JSON.stringify(execution.result).length : 0,\n          Unit.Bytes\n        );\n      }\n    }\n  }\n}\n\n/** Logs metrics specific to the incoming events */\nfunction logEventMetrics(\n  metrics: MetricsLogger,\n  events: WorkflowEvent[],\n  now: Date\n) {\n  const sleepCompletedEvents = events.filter(isSleepCompleted);\n  if (sleepCompletedEvents.length > 0) {\n    const sleepCompletedVariance = sleepCompletedEvents.map(\n      (s) => now.getTime() - new Date(s.timestamp).getTime()\n    );\n    const avg =\n      sleepCompletedVariance.reduce((t, n) => t + n, 0) /\n      sleepCompletedVariance.length;\n    metrics.setProperty(OrchestratorMetrics.SleepVarianceMillis, avg);\n  }\n}\n"]} |
@@ -0,1 +1,2 @@ | ||
/* eslint-disable @typescript-eslint/no-namespace */ | ||
export var MetricsCommon; | ||
@@ -178,2 +179,2 @@ (function (MetricsCommon) { | ||
})(SchedulerForwarderMetrics || (SchedulerForwarderMetrics = {})); | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/runtime/metrics/constants.ts"],"names":[],"mappings":"AAAA,MAAM,KAAW,aAAa,CAG7B;AAHD,WAAiB,aAAa;IACf,+BAAiB,GAAG,UAAU,CAAC;IAC/B,mCAAqB,GAAG,cAAc,CAAC;AACtD,CAAC,EAHgB,aAAa,KAAb,aAAa,QAG7B;AAED,MAAM,KAAW,mBAAmB,CA2GnC;AA3GD,WAAiB,mBAAmB;IAClC;;OAEG;IACU,8BAAU,GAAG,YAAY,CAAC;IACvC;;OAEG;IACU,mCAAe,GAAG,iBAAiB,CAAC;IACjD;;OAEG;IACU,+BAAW,GAAG,aAAa,CAAC;IACzC;;OAEG;IACU,2BAAO,GAAG,SAAS,CAAC;IACpB,6BAAS,GAAG,IAAI,CAAC;IAC9B;;;;OAIG;IACU,8BAAU,GAAG,YAAY,CAAC;IACvC;;OAEG;IACU,uCAAmB,GAAG,qBAAqB,CAAC;IACzD;;OAEG;IACU,uCAAmB,GAAG,qBAAqB,CAAC;IACzD;;OAEG;IACU,4CAAwB,GAAG,0BAA0B,CAAC;IACnE;;OAEG;IACU,0CAAsB,GAAG,wBAAwB,CAAC;IAC/D;;OAEG;IACU,0CAAsB,GAAG,wBAAwB,CAAC;IAC/D;;OAEG;IACU,mCAAe,GAAG,iBAAiB,CAAC;IACjD;;;;;OAKG;IACU,yCAAqB,GAAG,uBAAuB,CAAC;IAC7D;;OAEG;IACU,uCAAmB,GAAG,qBAAqB,CAAC;IACzD;;OAEG;IACU,sCAAkB,GAAG,oBAAoB,CAAC;IACvD;;OAEG;IACU,qCAAiB,GAAG,mBAAmB,CAAC;IACrD;;OAEG;IACU,iDAA6B,GAAG,+BAA+B,CAAC;IAC7E;;OAEG;IACU,iDAA6B,GAAG,+BAA+B,CAAC;IAC7E;;OAEG;IACU,sCAAkB,GAAG,oBAAoB,CAAC;IACvD;;OAEG;IACU,qCAAiB,GAAG,mBAAmB,CAAC;IACrD;;OAEG;IACU,mCAAe,GAAG,iBAAiB,CAAC;IACjD;;OAEG;IACU,0CAAsB,GAAG,wBAAwB,CAAC;IAC/D;;OAEG;IACU,wCAAoB,GAAG,sBAAsB,CAAC;IAC3D;;OAEG;IACU,uCAAmB,GAAG,qBAAqB,CAAC;IACzD;;OAEG;IACU,kCAAc,GAAG,gBAAgB,CAAC;IAC/C;;OAEG;IACU,0CAAsB,GAAG,wBAAwB,CAAC;AACjE,CAAC,EA3GgB,mBAAmB,KAAnB,mBAAmB,QA2GnC;AAED,MAAM,KAAW,eAAe,CAkD/B;AAlDD,WAAiB,eAAe;IAC9B;;OAEG;IACU,kCAAkB,GAAG,oBAAoB,CAAC;IACvD;;OAEG;IACU,6BAAa,GAAG,eAAe,CAAC;IAC7C;;OAEG;IACU,6BAAa,GAAG,eAAe,CAAC;IAC7C;;OAEG;IACU,6BAAa,GAAG,eAAe,CAAC;IAC7C;;OAEG;IACU,iCAAiB,GAAG,mBAAmB,CAAC;IACrD;;OAEG;IACU,yBAAS,GAAG,WAAW,CAAC;IACrC;;OAEG;IACU,2BAAW,GAAG,aAAa,CAAC;IACzC;;OAEG;IACU,2BAAW,GAAG,aAAa,CAAC;IACzC;;OAEG;IACU,8BAAc,GAAG,gBAAgB,CAAC;IAC/C;;OAEG;IACU,iCAAiB,GAAG,mBAAmB,CAAC;IACrD;;;OAGG;IACU,6BAAa,GAAG,eAAe,CAAC;IAC7C;;OAEG;IACU,0CAA0B,GAAG,4BAA4B,CAAC;AACzE,CAAC,EAlDgB,eAAe,KAAf,eAAe,QAkD/B;AAED,MAAM,KAAW,yBAAyB,CASzC;AATD,WAAiB,yBAAyB;IACxC;;OAEG;IACU,4CAAkB,GAAG,oBAAoB,CAAC;IACvD;;OAEG;IACU,gDAAsB,GAAG,wBAAwB,CAAC;AACjE,CAAC,EATgB,yBAAyB,KAAzB,yBAAyB,QASzC","sourcesContent":["export namespace MetricsCommon {\n  export const EventualNamespace = \"Eventual\";\n  export const WorkflowNameDimension = \"WorkflowName\";\n}\n\nexport namespace OrchestratorMetrics {\n  /**\n   * Number of events which were delivered with the current batch of {@link WorkflowTask}s.\n   */\n  export const TaskEvents = \"TaskEvents\";\n  /**\n   * Number of workflow tasks being batch executed by the orchestrator for an execution id.\n   */\n  export const AggregatedTasks = \"AggregatedTasks\";\n  /**\n   * Execution ID of the {@link WorkflowTask}s being evaluated.\n   */\n  export const ExecutionId = \"ExecutionId\";\n  /**\n   * Version of the orchestrator.\n   */\n  export const Version = \"Version\";\n  export const VersionV1 = \"v1\";\n  /**\n   * The greatest amount of time a {@link WorkflowTask} being processed has waited in the Workflow Queue.\n   *\n   * Used to determine when the workflow queue is falling behind (maxTaskAge is growing).\n   */\n  export const MaxTaskAge = \"MaxTaskAge\";\n  /**\n   * The time it takes to load history data from S3.\n   */\n  export const LoadHistoryDuration = \"LoadHistoryDuration\";\n  /**\n   * The number of events present in the history file.\n   */\n  export const LoadedHistoryEvents = \"LoadedHistoryEvents\";\n  /**\n   * The amount of time it takes to run the workflow code to progress the {@link Execution}.\n   */\n  export const AdvanceExecutionDuration = \"AdvanceExecutionDuration\";\n  /**\n   * The number of events submitted to the workflow code to replay and advance the {@link Execution}.\n   */\n  export const AdvanceExecutionEvents = \"AdvanceExecutionEvents\";\n  /**\n   * The amount of time it takes to start all of the commands returned by the workflow code.\n   */\n  export const InvokeCommandsDuration = \"InvokeCommandsDuration\";\n  /**\n   * The number of commands returned by the workflow.\n   */\n  export const CommandsInvoked = \"CommandsInvoked\";\n  /**\n   * Tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n   * This represent the workflow orchestration time of User Perceived Latency\n   * Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n   * AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n   */\n  export const TimeToCommandsInvoked = \"TimeToCommandsInvoked\";\n  /**\n   * Amount of time it takes to write history back to s3.\n   */\n  export const SaveHistoryDuration = \"SaveHistoryDuration\";\n  /**\n   * Number of events written to s3.\n   */\n  export const SavedHistoryEvents = \"SavedHistoryEvents\";\n  /**\n   * Size of the history fle written in bytes.\n   */\n  export const SavedHistoryBytes = \"SavedHistoryBytes\";\n  /**\n   * Amount of time it takes to update the workflow entry with a Complete or Failed status.\n   */\n  export const ExecutionStatusUpdateDuration = \"ExecutionStatusUpdateDuration\";\n  /**\n   * Amount of time it take to add newly generated events to dynamo.\n   */\n  export const AddNewExecutionEventsDuration = \"AddNewExecutionEventsDuration\";\n  /**\n   * Number of new events generated evaluating the current Workflow Tasks batch.\n   */\n  export const NewExecutionEvents = \"NewExecutionEvents\";\n  /**\n   * Whether the execution completed without error.\n   */\n  export const ExecutionComplete = \"ExecutionComplete\";\n  /**\n   * Whether the execution completed with an error.\n   */\n  export const ExecutionFailed = \"ExecutionFailed\";\n  /**\n   * Total time it took the workflow to complete.\n   */\n  export const ExecutionTotalDuration = \"ExecutionTotalDuration\";\n  /**\n   * The size of the workflow result in bytes.\n   */\n  export const ExecutionResultBytes = \"ExecutionResultBytes\";\n  /**\n   * Number of milliseconds between the expected sleep wakeup time and the actual incoming {@link SleepCompleted} event.\n   */\n  export const SleepVarianceMillis = \"SleepVarianceMillis\";\n  /**\n   * 1 when a workflow has a timeout and 0 when it does not.\n   */\n  export const TimeoutStarted = \"TimeoutStarted\";\n  /**\n   * When a workflow has a timeout, measures the time it takes to start the timeout.\n   */\n  export const TimeoutStartedDuration = \"TimeoutStartedDuration\";\n}\n\nexport namespace ActivityMetrics {\n  /**\n   * The age of the request, or the time from when it was sent to when it was started processing.\n   */\n  export const ActivityRequestAge = \"ActivityRequestAge\";\n  /**\n   * The amount of time it took to claim (lock) the activity to enforce exactly once processing.\n   */\n  export const ClaimDuration = \"ClaimDuration\";\n  /**\n   * Whether this activity invocation was rejected when claiming the activity.\n   */\n  export const ClaimRejected = \"ClaimRejected\";\n  /**\n   * Whether an error was thrown that the activity name could not be found.\n   */\n  export const NotFoundError = \"NotFoundError\";\n  /**\n   * The amount of time it took to run the activity's code.\n   */\n  export const OperationDuration = \"OperationDuration\";\n  /**\n   * Whether this activity returned a result or not on completion.\n   */\n  export const HasResult = \"HasResult\";\n  /**\n   * Returned {@link asyncResult}.\n   */\n  export const AsyncResult = \"AsyncResult\";\n  /**\n   * The size in bytes of the result generated by the activity, if one was generated.\n   */\n  export const ResultBytes = \"ResultBytes\";\n  /**\n   * Whether the activity completed with errors.\n   */\n  export const ActivityFailed = \"ActivityFailed\";\n  /**\n   * Whether the activity completed without error.\n   */\n  export const ActivityCompleted = \"ActivityCompleted\";\n  /**\n   * The total duration of the activity after being scheduled, including the time\n   * waiting to be executed.\n   */\n  export const TotalDuration = \"TotalDuration\";\n  /**\n   * amount of time it took to submit a workflow task to SQS to resume the workflow.\n   */\n  export const SubmitWorkflowTaskDuration = \"SubmitWorkflowTaskDuration\";\n}\n\nexport namespace SchedulerForwarderMetrics {\n  /**\n   * The time between the scheduler trigger time and the Scheduler Forwarder seeing the message.\n   */\n  export const SchedulerTimeDelay = \"SchedulerTimeDelay\";\n  /**\n   * Seconds the timer queue is told to wait until handling the request.\n   */\n  export const TimerQueueDelaySeconds = \"TimerQueueDelaySeconds\";\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../../src/runtime/metrics/constants.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-namespace */\nexport namespace MetricsCommon {\n  export const EventualNamespace = \"Eventual\";\n  export const WorkflowNameDimension = \"WorkflowName\";\n}\n\nexport namespace OrchestratorMetrics {\n  /**\n   * Number of events which were delivered with the current batch of {@link WorkflowTask}s.\n   */\n  export const TaskEvents = \"TaskEvents\";\n  /**\n   * Number of workflow tasks being batch executed by the orchestrator for an execution id.\n   */\n  export const AggregatedTasks = \"AggregatedTasks\";\n  /**\n   * Execution ID of the {@link WorkflowTask}s being evaluated.\n   */\n  export const ExecutionId = \"ExecutionId\";\n  /**\n   * Version of the orchestrator.\n   */\n  export const Version = \"Version\";\n  export const VersionV1 = \"v1\";\n  /**\n   * The greatest amount of time a {@link WorkflowTask} being processed has waited in the Workflow Queue.\n   *\n   * Used to determine when the workflow queue is falling behind (maxTaskAge is growing).\n   */\n  export const MaxTaskAge = \"MaxTaskAge\";\n  /**\n   * The time it takes to load history data from S3.\n   */\n  export const LoadHistoryDuration = \"LoadHistoryDuration\";\n  /**\n   * The number of events present in the history file.\n   */\n  export const LoadedHistoryEvents = \"LoadedHistoryEvents\";\n  /**\n   * The amount of time it takes to run the workflow code to progress the {@link Execution}.\n   */\n  export const AdvanceExecutionDuration = \"AdvanceExecutionDuration\";\n  /**\n   * The number of events submitted to the workflow code to replay and advance the {@link Execution}.\n   */\n  export const AdvanceExecutionEvents = \"AdvanceExecutionEvents\";\n  /**\n   * The amount of time it takes to start all of the commands returned by the workflow code.\n   */\n  export const InvokeCommandsDuration = \"InvokeCommandsDuration\";\n  /**\n   * The number of commands returned by the workflow.\n   */\n  export const CommandsInvoked = \"CommandsInvoked\";\n  /**\n   * Tracks the time it takes for a workflow task to be scheduled until new commands could be emitted.\n   * This represent the workflow orchestration time of User Perceived Latency\n   * Average expected time for an activity to be invoked until it is considered complete by the workflow should follow:\n   * AvgActivityDuration(N) = Avg(TimeToCommandsInvoked) + Avg(ActivityDuration(N))\n   */\n  export const TimeToCommandsInvoked = \"TimeToCommandsInvoked\";\n  /**\n   * Amount of time it takes to write history back to s3.\n   */\n  export const SaveHistoryDuration = \"SaveHistoryDuration\";\n  /**\n   * Number of events written to s3.\n   */\n  export const SavedHistoryEvents = \"SavedHistoryEvents\";\n  /**\n   * Size of the history fle written in bytes.\n   */\n  export const SavedHistoryBytes = \"SavedHistoryBytes\";\n  /**\n   * Amount of time it takes to update the workflow entry with a Complete or Failed status.\n   */\n  export const ExecutionStatusUpdateDuration = \"ExecutionStatusUpdateDuration\";\n  /**\n   * Amount of time it take to add newly generated events to dynamo.\n   */\n  export const AddNewExecutionEventsDuration = \"AddNewExecutionEventsDuration\";\n  /**\n   * Number of new events generated evaluating the current Workflow Tasks batch.\n   */\n  export const NewExecutionEvents = \"NewExecutionEvents\";\n  /**\n   * Whether the execution completed without error.\n   */\n  export const ExecutionComplete = \"ExecutionComplete\";\n  /**\n   * Whether the execution completed with an error.\n   */\n  export const ExecutionFailed = \"ExecutionFailed\";\n  /**\n   * Total time it took the workflow to complete.\n   */\n  export const ExecutionTotalDuration = \"ExecutionTotalDuration\";\n  /**\n   * The size of the workflow result in bytes.\n   */\n  export const ExecutionResultBytes = \"ExecutionResultBytes\";\n  /**\n   * Number of milliseconds between the expected sleep wakeup time and the actual incoming {@link SleepCompleted} event.\n   */\n  export const SleepVarianceMillis = \"SleepVarianceMillis\";\n  /**\n   * 1 when a workflow has a timeout and 0 when it does not.\n   */\n  export const TimeoutStarted = \"TimeoutStarted\";\n  /**\n   * When a workflow has a timeout, measures the time it takes to start the timeout.\n   */\n  export const TimeoutStartedDuration = \"TimeoutStartedDuration\";\n}\n\nexport namespace ActivityMetrics {\n  /**\n   * The age of the request, or the time from when it was sent to when it was started processing.\n   */\n  export const ActivityRequestAge = \"ActivityRequestAge\";\n  /**\n   * The amount of time it took to claim (lock) the activity to enforce exactly once processing.\n   */\n  export const ClaimDuration = \"ClaimDuration\";\n  /**\n   * Whether this activity invocation was rejected when claiming the activity.\n   */\n  export const ClaimRejected = \"ClaimRejected\";\n  /**\n   * Whether an error was thrown that the activity name could not be found.\n   */\n  export const NotFoundError = \"NotFoundError\";\n  /**\n   * The amount of time it took to run the activity's code.\n   */\n  export const OperationDuration = \"OperationDuration\";\n  /**\n   * Whether this activity returned a result or not on completion.\n   */\n  export const HasResult = \"HasResult\";\n  /**\n   * Returned {@link asyncResult}.\n   */\n  export const AsyncResult = \"AsyncResult\";\n  /**\n   * The size in bytes of the result generated by the activity, if one was generated.\n   */\n  export const ResultBytes = \"ResultBytes\";\n  /**\n   * Whether the activity completed with errors.\n   */\n  export const ActivityFailed = \"ActivityFailed\";\n  /**\n   * Whether the activity completed without error.\n   */\n  export const ActivityCompleted = \"ActivityCompleted\";\n  /**\n   * The total duration of the activity after being scheduled, including the time\n   * waiting to be executed.\n   */\n  export const TotalDuration = \"TotalDuration\";\n  /**\n   * amount of time it took to submit a workflow task to SQS to resume the workflow.\n   */\n  export const SubmitWorkflowTaskDuration = \"SubmitWorkflowTaskDuration\";\n}\n\nexport namespace SchedulerForwarderMetrics {\n  /**\n   * The time between the scheduler trigger time and the Scheduler Forwarder seeing the message.\n   */\n  export const SchedulerTimeDelay = \"SchedulerTimeDelay\";\n  /**\n   * Seconds the timer queue is told to wait until handling the request.\n   */\n  export const TimerQueueDelaySeconds = \"TimerQueueDelaySeconds\";\n}\n"]} |
@@ -34,3 +34,3 @@ export interface Secret<T> { | ||
#private; | ||
readonly cachingConfig: CachingConfig; | ||
private readonly cachingConfig; | ||
constructor(cachingConfig?: CachingConfig); | ||
@@ -37,0 +37,0 @@ /** |
@@ -66,2 +66,2 @@ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) { | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFJQTs7Ozs7R0FLRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQXFCLEtBQVE7UUFBUixVQUFLLEdBQUwsS0FBSyxDQUFHO0lBQUcsQ0FBQztJQUUxQixTQUFTO1FBQ2QsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFpQkQ7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLGlCQUFpQjtJQVVyQyxZQUFZLGFBQTZCO1FBUHpDLDJDQUtjO1FBR1osSUFBSSxDQUFDLGFBQWEsR0FBRyxhQUFhLElBQUk7WUFDcEMsT0FBTyxFQUFFLElBQUk7WUFDYixHQUFHLEVBQUUsU0FBUztTQUNmLENBQUM7SUFDSixDQUFDO0lBT00sS0FBSyxDQUFDLFNBQVMsQ0FBQyxTQUFnQjtRQUNyQyxJQUNFLHVCQUFBLElBQUksZ0NBQU8sS0FBSyxTQUFTO1lBQ3pCLFNBQVM7WUFDVCxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTztZQUMzQixDQUFDLHVCQUFBLElBQUksZ0NBQU87Z0JBQ1YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLEtBQUssU0FBUztnQkFDcEMsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyx1QkFBQSxJQUFJLGdDQUFPLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRTtvQkFDdEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsRUFDM0I7WUFDQSx1QkFBQSxJQUFJLDRCQUFVO2dCQUNaLEtBQUssRUFBRSxNQUFNLElBQUksQ0FBQyxjQUFjLEVBQUU7Z0JBQ2xDLFdBQVcsRUFBRSxJQUFJLElBQUksRUFBRTthQUN4QixNQUFBLENBQUM7U0FDSDtRQUNELE9BQU8sdUJBQUEsSUFBSSxnQ0FBTyxDQUFDLEtBQUssQ0FBQztJQUMzQixDQUFDO0NBQ0Y7O0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sVUFBVTtJQUNyQixZQUFxQixNQUFzQjtRQUF0QixXQUFNLEdBQU4sTUFBTSxDQUFnQjtJQUFHLENBQUM7SUFFeEMsS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0PFQ+IHtcbiAgZ2V0U2VjcmV0KCk6IFByb21pc2U8VD47XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU2VjcmV0fSBpbXBsZW1lbnRhdGlvbiB0aGF0IHN0b3JlcyB0aGUgc2VjcmV0IGhhcmQtY29kZWQgaW4gcGxhaW4gdGV4dC5cbiAqXG4gKiBUaGlzIGlzIGFuIGluc2VjdXJlIEFQSSBhbmQgc2hvdWxkIG9ubHkgYmUgdXNlZCB3aGVuIHNhZmUsIHN1Y2ggYXMgaW4gYSBkZXZcbiAqIGVudmlyb25tZW50LlxuICovXG5leHBvcnQgY2xhc3MgUGxhaW5UZXh0U2VjcmV0PFQgPSBzdHJpbmc+IGltcGxlbWVudHMgU2VjcmV0PFQ+IHtcbiAgY29uc3RydWN0b3IocmVhZG9ubHkgdmFsdWU6IFQpIHt9XG5cbiAgcHVibGljIGdldFNlY3JldCgpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHRoaXMudmFsdWUpO1xuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FjaGluZ0NvbmZpZyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIGNhY2hpbmcgaXMgZW5hYmxlZC5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZW5hYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBOdW1iZXIgb2YgbWlsbGlzZWNvbmRzIHRvIGNhY2hlIHRoZSBzZWNyZXQgdmFsdWUgZm9yLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIFRUTCwgYWxsIHZhbHVlcyBhcmUgY2FjaGVkIGluZGVmaW5pdGVseVxuICAgKi9cbiAgdHRsPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIEEgYmFzZSBpbXBsZW1lbnRhdGlvbiBvZiBhIHtAbGluayBTZWNyZXR9IHRoYXQgc3VwcG9ydHMgY2FjaGluZy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VDYWNoaW5nU2VjcmV0PFQ+IGltcGxlbWVudHMgU2VjcmV0PFQ+IHtcbiAgcmVhZG9ubHkgY2FjaGluZ0NvbmZpZzogQ2FjaGluZ0NvbmZpZztcblxuICAjdmFsdWU6XG4gICAgfCB7XG4gICAgICAgIHZhbHVlOiBUO1xuICAgICAgICByZWZyZXNoVGltZTogRGF0ZTtcbiAgICAgIH1cbiAgICB8IHVuZGVmaW5lZDtcblxuICBjb25zdHJ1Y3RvcihjYWNoaW5nQ29uZmlnPzogQ2FjaGluZ0NvbmZpZykge1xuICAgIHRoaXMuY2FjaGluZ0NvbmZpZyA9IGNhY2hpbmdDb25maWcgPz8ge1xuICAgICAgZW5hYmxlZDogdHJ1ZSxcbiAgICAgIHR0bDogdW5kZWZpbmVkLFxuICAgIH07XG4gIH1cblxuICAvKipcbiAgICogR2V0cyBhIGZyZXNoIHZlcnNpb24gb2YgdGhlIHNlY3JldCBmcm9tIHRoZSByZW1vdGUgc3RvcmUuXG4gICAqL1xuICBwcm90ZWN0ZWQgYWJzdHJhY3QgZ2V0RnJlc2hTZWNyZXQoKTogUHJvbWlzZTxUPjtcblxuICBwdWJsaWMgYXN5bmMgZ2V0U2VjcmV0KGJ1c3RDYWNoZT86IHRydWUpOiBQcm9taXNlPFQ+IHtcbiAgICBpZiAoXG4gICAgICB0aGlzLiN2YWx1ZSA9PT0gdW5kZWZpbmVkIHx8XG4gICAgICBidXN0Q2FjaGUgfHxcbiAgICAgICF0aGlzLmNhY2hpbmdDb25maWcuZW5hYmxlZCB8fFxuICAgICAgKHRoaXMuI3ZhbHVlICYmXG4gICAgICAgIHRoaXMuY2FjaGluZ0NvbmZpZy50dGwgIT09IHVuZGVmaW5lZCAmJlxuICAgICAgICBuZXcgRGF0ZSgpLmdldFRpbWUoKSAtIHRoaXMuI3ZhbHVlLnJlZnJlc2hUaW1lLmdldFRpbWUoKSA+XG4gICAgICAgICAgdGhpcy5jYWNoaW5nQ29uZmlnLnR0bClcbiAgICApIHtcbiAgICAgIHRoaXMuI3ZhbHVlID0ge1xuICAgICAgICB2YWx1ZTogYXdhaXQgdGhpcy5nZXRGcmVzaFNlY3JldCgpLFxuICAgICAgICByZWZyZXNoVGltZTogbmV3IERhdGUoKSxcbiAgICAgIH07XG4gICAgfVxuICAgIHJldHVybiB0aGlzLiN2YWx1ZS52YWx1ZTtcbiAgfVxufVxuXG4vKipcbiAqIEEge0BsaW5rIFNlY3JldH0gcGFyc2VkIGZyb20gIEpTT04uXG4gKi9cbmV4cG9ydCBjbGFzcyBKc29uU2VjcmV0PFQ+IGltcGxlbWVudHMgU2VjcmV0PFQ+IHtcbiAgY29uc3RydWN0b3IocmVhZG9ubHkgc2VjcmV0OiBTZWNyZXQ8c3RyaW5nPikge31cblxuICBwdWJsaWMgYXN5bmMgZ2V0U2VjcmV0KCk6IFByb21pc2U8VD4ge1xuICAgIHJldHVybiBKU09OLnBhcnNlKGF3YWl0IHRoaXMuc2VjcmV0LmdldFNlY3JldCgpKTtcbiAgfVxufVxuIl19 | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjcmV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL3NlY3JldC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7QUFJQTs7Ozs7R0FLRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQXFCLEtBQVE7UUFBUixVQUFLLEdBQUwsS0FBSyxDQUFHO0lBQUcsQ0FBQztJQUUxQixTQUFTO1FBQ2QsT0FBTyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNyQyxDQUFDO0NBQ0Y7QUFpQkQ7O0dBRUc7QUFDSCxNQUFNLE9BQWdCLGlCQUFpQjtJQVVyQyxZQUFZLGFBQTZCO1FBUHpDLDJDQUtjO1FBR1osSUFBSSxDQUFDLGFBQWEsR0FBRyxhQUFhLElBQUk7WUFDcEMsT0FBTyxFQUFFLElBQUk7WUFDYixHQUFHLEVBQUUsU0FBUztTQUNmLENBQUM7SUFDSixDQUFDO0lBT00sS0FBSyxDQUFDLFNBQVMsQ0FBQyxTQUFnQjtRQUNyQyxJQUNFLHVCQUFBLElBQUksZ0NBQU8sS0FBSyxTQUFTO1lBQ3pCLFNBQVM7WUFDVCxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsT0FBTztZQUMzQixDQUFDLHVCQUFBLElBQUksZ0NBQU87Z0JBQ1YsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLEtBQUssU0FBUztnQkFDcEMsSUFBSSxJQUFJLEVBQUUsQ0FBQyxPQUFPLEVBQUUsR0FBRyx1QkFBQSxJQUFJLGdDQUFPLENBQUMsV0FBVyxDQUFDLE9BQU8sRUFBRTtvQkFDdEQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsRUFDM0I7WUFDQSx1QkFBQSxJQUFJLDRCQUFVO2dCQUNaLEtBQUssRUFBRSxNQUFNLElBQUksQ0FBQyxjQUFjLEVBQUU7Z0JBQ2xDLFdBQVcsRUFBRSxJQUFJLElBQUksRUFBRTthQUN4QixNQUFBLENBQUM7U0FDSDtRQUNELE9BQU8sdUJBQUEsSUFBSSxnQ0FBTyxDQUFDLEtBQUssQ0FBQztJQUMzQixDQUFDO0NBQ0Y7O0FBRUQ7O0dBRUc7QUFDSCxNQUFNLE9BQU8sVUFBVTtJQUNyQixZQUFxQixNQUFzQjtRQUF0QixXQUFNLEdBQU4sTUFBTSxDQUFnQjtJQUFHLENBQUM7SUFFeEMsS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLEVBQUUsQ0FBQyxDQUFDO0lBQ25ELENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgU2VjcmV0PFQ+IHtcbiAgZ2V0U2VjcmV0KCk6IFByb21pc2U8VD47XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU2VjcmV0fSBpbXBsZW1lbnRhdGlvbiB0aGF0IHN0b3JlcyB0aGUgc2VjcmV0IGhhcmQtY29kZWQgaW4gcGxhaW4gdGV4dC5cbiAqXG4gKiBUaGlzIGlzIGFuIGluc2VjdXJlIEFQSSBhbmQgc2hvdWxkIG9ubHkgYmUgdXNlZCB3aGVuIHNhZmUsIHN1Y2ggYXMgaW4gYSBkZXZcbiAqIGVudmlyb25tZW50LlxuICovXG5leHBvcnQgY2xhc3MgUGxhaW5UZXh0U2VjcmV0PFQgPSBzdHJpbmc+IGltcGxlbWVudHMgU2VjcmV0PFQ+IHtcbiAgY29uc3RydWN0b3IocmVhZG9ubHkgdmFsdWU6IFQpIHt9XG5cbiAgcHVibGljIGdldFNlY3JldCgpIHtcbiAgICByZXR1cm4gUHJvbWlzZS5yZXNvbHZlKHRoaXMudmFsdWUpO1xuICB9XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ2FjaGluZ0NvbmZpZyB7XG4gIC8qKlxuICAgKiBXaGV0aGVyIGNhY2hpbmcgaXMgZW5hYmxlZC5cbiAgICpcbiAgICogQGRlZmF1bHQgdHJ1ZVxuICAgKi9cbiAgZW5hYmxlZD86IGJvb2xlYW47XG4gIC8qKlxuICAgKiBOdW1iZXIgb2YgbWlsbGlzZWNvbmRzIHRvIGNhY2hlIHRoZSBzZWNyZXQgdmFsdWUgZm9yLlxuICAgKlxuICAgKiBAZGVmYXVsdCAtIG5vIFRUTCwgYWxsIHZhbHVlcyBhcmUgY2FjaGVkIGluZGVmaW5pdGVseVxuICAgKi9cbiAgdHRsPzogbnVtYmVyO1xufVxuXG4vKipcbiAqIEEgYmFzZSBpbXBsZW1lbnRhdGlvbiBvZiBhIHtAbGluayBTZWNyZXR9IHRoYXQgc3VwcG9ydHMgY2FjaGluZy5cbiAqL1xuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEJhc2VDYWNoaW5nU2VjcmV0PFQ+IGltcGxlbWVudHMgU2VjcmV0PFQ+IHtcbiAgcHJpdmF0ZSByZWFkb25seSBjYWNoaW5nQ29uZmlnOiBDYWNoaW5nQ29uZmlnO1xuXG4gICN2YWx1ZTpcbiAgICB8IHtcbiAgICAgICAgdmFsdWU6IFQ7XG4gICAgICAgIHJlZnJlc2hUaW1lOiBEYXRlO1xuICAgICAgfVxuICAgIHwgdW5kZWZpbmVkO1xuXG4gIGNvbnN0cnVjdG9yKGNhY2hpbmdDb25maWc/OiBDYWNoaW5nQ29uZmlnKSB7XG4gICAgdGhpcy5jYWNoaW5nQ29uZmlnID0gY2FjaGluZ0NvbmZpZyA/PyB7XG4gICAgICBlbmFibGVkOiB0cnVlLFxuICAgICAgdHRsOiB1bmRlZmluZWQsXG4gICAgfTtcbiAgfVxuXG4gIC8qKlxuICAgKiBHZXRzIGEgZnJlc2ggdmVyc2lvbiBvZiB0aGUgc2VjcmV0IGZyb20gdGhlIHJlbW90ZSBzdG9yZS5cbiAgICovXG4gIHByb3RlY3RlZCBhYnN0cmFjdCBnZXRGcmVzaFNlY3JldCgpOiBQcm9taXNlPFQ+O1xuXG4gIHB1YmxpYyBhc3luYyBnZXRTZWNyZXQoYnVzdENhY2hlPzogdHJ1ZSk6IFByb21pc2U8VD4ge1xuICAgIGlmIChcbiAgICAgIHRoaXMuI3ZhbHVlID09PSB1bmRlZmluZWQgfHxcbiAgICAgIGJ1c3RDYWNoZSB8fFxuICAgICAgIXRoaXMuY2FjaGluZ0NvbmZpZy5lbmFibGVkIHx8XG4gICAgICAodGhpcy4jdmFsdWUgJiZcbiAgICAgICAgdGhpcy5jYWNoaW5nQ29uZmlnLnR0bCAhPT0gdW5kZWZpbmVkICYmXG4gICAgICAgIG5ldyBEYXRlKCkuZ2V0VGltZSgpIC0gdGhpcy4jdmFsdWUucmVmcmVzaFRpbWUuZ2V0VGltZSgpID5cbiAgICAgICAgICB0aGlzLmNhY2hpbmdDb25maWcudHRsKVxuICAgICkge1xuICAgICAgdGhpcy4jdmFsdWUgPSB7XG4gICAgICAgIHZhbHVlOiBhd2FpdCB0aGlzLmdldEZyZXNoU2VjcmV0KCksXG4gICAgICAgIHJlZnJlc2hUaW1lOiBuZXcgRGF0ZSgpLFxuICAgICAgfTtcbiAgICB9XG4gICAgcmV0dXJuIHRoaXMuI3ZhbHVlLnZhbHVlO1xuICB9XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU2VjcmV0fSBwYXJzZWQgZnJvbSAgSlNPTi5cbiAqL1xuZXhwb3J0IGNsYXNzIEpzb25TZWNyZXQ8VD4gaW1wbGVtZW50cyBTZWNyZXQ8VD4ge1xuICBjb25zdHJ1Y3RvcihyZWFkb25seSBzZWNyZXQ6IFNlY3JldDxzdHJpbmc+KSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRTZWNyZXQoKTogUHJvbWlzZTxUPiB7XG4gICAgcmV0dXJuIEpTT04ucGFyc2UoYXdhaXQgdGhpcy5zZWNyZXQuZ2V0U2VjcmV0KCkpO1xuICB9XG59XG4iXX0= |
@@ -131,2 +131,2 @@ import { createSendSignalCall } from "./calls/send-signal-call.js"; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":"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","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(public readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = new Signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.on(async () => {\n   *       await sleepFor(10);\n   *       done = true;\n   *    });\n   *\n   *    await condition(() => done);\n   * });\n   * ```\n   *\n   * To remove the handler, call the dispose method.\n   *\n   * ```ts\n   * const handler = mySignal.on(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  on(handler: SignalHandlerFunction<Payload>): SignalsHandler {\n    return onSignal(this, handler);\n  }\n  /**\n   * Waits for a signal to be received by the workflow.\n   *\n   * The first signal received will resolve the Promise with the payload of the promise.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expect();\n   *\n   *    return payload;\n   * });\n   * ```\n   *\n   * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n   * when the provided time has elapsed.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  expect(opts?: ExpectSignalOptions): Promise<Payload> {\n    return expectSignal(this, opts);\n  }\n  /**\n   * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.send(\"payload\");\n   * })\n   * ```\n   */\n  send(executionId: string, ...args: SendSignalProps<Payload>): Promise<void> {\n    return sendSignal<Signal<Payload>>(executionId, this, ...args);\n  }\n}\n\nexport type SignalPayload<E extends Signal<any>> = E extends Signal<infer P>\n  ? P\n  : never;\n\nexport interface ExpectSignalOptions {\n  /**\n   * Optional. Seconds to wait for the signal to be received.\n   *\n   * After the provided seconds, the promise will reject.\n   */\n  timeoutSeconds: number;\n}\n\n/**\n * Waits for a signal to be received by the workflow.\n *\n * The first signal received will resolve the Promise with the payload of the promise.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    const payload = await expectSignal(\"MySignal\");\n *\n *    return payload;\n * });\n * ```\n *\n * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n * when the provided time has elapsed.\n */\nexport function expectSignal<SignalPayload = any>(\n  signalId: string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload>;\nexport function expectSignal<E extends Signal<any>>(\n  signal: E,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<E>>;\nexport function expectSignal(\n  signal: Signal<any> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<any>> {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"expectSignal is only valid in a workflow\");\n  }\n\n  return createExpectSignalCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    opts?.timeoutSeconds\n  ) as any;\n}\n\n/**\n * Listens for a signal matching the signalId provided.\n *\n * When the signal is received, the handler is invoked.\n * If the handler return a promise, the handler is added as a {@link Chain}\n * and progressed until completion.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    let done = false;\n *    onSignal(\"MySignal\", async () => {\n *       await sleepFor(10);\n *       done = true;\n *    });\n *\n *    await condition(() => done);\n * });\n * ```\n *\n * To remove the handler, call the dispose method.\n *\n * ```ts\n * const handler = onSignal(\"MySignal\", () => {});\n *\n * await sleepFor(10);\n *\n * handler.dispose();\n * ```\n */\nexport function onSignal<E extends Signal<any>>(\n  signal: E,\n  handler: SignalHandlerFunction<SignalPayload<E>>\n): SignalsHandler;\nexport function onSignal<Payload = void>(\n  signalId: string,\n  handler: SignalHandlerFunction<Payload>\n): SignalsHandler;\nexport function onSignal(\n  signal: Signal<any> | string,\n  handler: SignalHandlerFunction<any>\n): SignalsHandler {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"onSignal is only valid in a workflow\");\n  }\n\n  return createRegisterSignalHandlerCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    handler as any\n  );\n}\n\nexport type SendSignalProps<SignalPayload> = [SignalPayload] extends\n  | [undefined]\n  | [void]\n  ? [id?: string]\n  : [payload: SignalPayload, id?: string];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = new Signal<string>(\"MySignal\");\n * workflow(\"wf\", async () => {\n *    sendSignal(\"mySignal\", \"payload\");\n *    sendSignal(mySignal, \"payload\");\n * })\n * ```\n *\n * @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.\n */\nexport function sendSignal<S extends Signal<any>>(\n  executionId: string,\n  signal: S,\n  ...args: SendSignalProps<SignalPayload<S>>\n): Promise<void>;\nexport function sendSignal<Payload = any>(\n  executionId: string,\n  signalId: string,\n  ...args: SendSignalProps<Payload>\n): Promise<void>;\nexport function sendSignal(\n  executionId: string,\n  signal: string | Signal<any>,\n  payload?: any,\n  id?: string\n): Promise<void> {\n  if (isOrchestratorWorker()) {\n    return createSendSignalCall(\n      { type: SignalTargetType.Execution, executionId },\n      typeof signal === \"string\" ? signal : signal.id,\n      payload\n    ) as unknown as any;\n  } else {\n    return getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":"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","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = new Signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.on(async () => {\n   *       await sleepFor(10);\n   *       done = true;\n   *    });\n   *\n   *    await condition(() => done);\n   * });\n   * ```\n   *\n   * To remove the handler, call the dispose method.\n   *\n   * ```ts\n   * const handler = mySignal.on(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  public on(handler: SignalHandlerFunction<Payload>): SignalsHandler {\n    return onSignal(this, handler);\n  }\n\n  /**\n   * Waits for a signal to be received by the workflow.\n   *\n   * The first signal received will resolve the Promise with the payload of the promise.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expect();\n   *\n   *    return payload;\n   * });\n   * ```\n   *\n   * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n   * when the provided time has elapsed.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  public expect(opts?: ExpectSignalOptions): Promise<Payload> {\n    return expectSignal(this, opts);\n  }\n\n  /**\n   * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.\n   *\n   * ```ts\n   * const mySignal = new Signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.send(\"payload\");\n   * })\n   * ```\n   */\n  public send(\n    executionId: string,\n    ...args: SendSignalProps<Payload>\n  ): Promise<void> {\n    return sendSignal<Signal<Payload>>(executionId, this, ...args);\n  }\n}\n\nexport type SignalPayload<E extends Signal<any>> = E extends Signal<infer P>\n  ? P\n  : never;\n\nexport interface ExpectSignalOptions {\n  /**\n   * Optional. Seconds to wait for the signal to be received.\n   *\n   * After the provided seconds, the promise will reject.\n   */\n  timeoutSeconds: number;\n}\n\n/**\n * Waits for a signal to be received by the workflow.\n *\n * The first signal received will resolve the Promise with the payload of the promise.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    const payload = await expectSignal(\"MySignal\");\n *\n *    return payload;\n * });\n * ```\n *\n * Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject\n * when the provided time has elapsed.\n */\nexport function expectSignal<SignalPayload = any>(\n  signalId: string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload>;\nexport function expectSignal<E extends Signal<any>>(\n  signal: E,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<E>>;\nexport function expectSignal(\n  signal: Signal<any> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload<any>> {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"expectSignal is only valid in a workflow\");\n  }\n\n  return createExpectSignalCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    opts?.timeoutSeconds\n  ) as any;\n}\n\n/**\n * Listens for a signal matching the signalId provided.\n *\n * When the signal is received, the handler is invoked.\n * If the handler return a promise, the handler is added as a {@link Chain}\n * and progressed until completion.\n *\n * ```ts\n * workflow(\"wf\", () => {\n *    let done = false;\n *    onSignal(\"MySignal\", async () => {\n *       await sleepFor(10);\n *       done = true;\n *    });\n *\n *    await condition(() => done);\n * });\n * ```\n *\n * To remove the handler, call the dispose method.\n *\n * ```ts\n * const handler = onSignal(\"MySignal\", () => {});\n *\n * await sleepFor(10);\n *\n * handler.dispose();\n * ```\n */\nexport function onSignal<E extends Signal<any>>(\n  signal: E,\n  handler: SignalHandlerFunction<SignalPayload<E>>\n): SignalsHandler;\nexport function onSignal<Payload = void>(\n  signalId: string,\n  handler: SignalHandlerFunction<Payload>\n): SignalsHandler;\nexport function onSignal(\n  signal: Signal<any> | string,\n  handler: SignalHandlerFunction<any>\n): SignalsHandler {\n  if (!isOrchestratorWorker()) {\n    throw new Error(\"onSignal is only valid in a workflow\");\n  }\n\n  return createRegisterSignalHandlerCall(\n    typeof signal === \"string\" ? signal : signal.id,\n    handler as any\n  );\n}\n\nexport type SendSignalProps<SignalPayload> = [SignalPayload] extends\n  | [undefined]\n  | [void]\n  ? [id?: string]\n  : [payload: SignalPayload, id?: string];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = new Signal<string>(\"MySignal\");\n * workflow(\"wf\", async () => {\n *    sendSignal(\"mySignal\", \"payload\");\n *    sendSignal(mySignal, \"payload\");\n * })\n * ```\n *\n * @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.\n */\nexport function sendSignal<S extends Signal<any>>(\n  executionId: string,\n  signal: S,\n  ...args: SendSignalProps<SignalPayload<S>>\n): Promise<void>;\nexport function sendSignal<Payload = any>(\n  executionId: string,\n  signalId: string,\n  ...args: SendSignalProps<Payload>\n): Promise<void>;\nexport function sendSignal(\n  executionId: string,\n  signal: string | Signal<any>,\n  payload?: any,\n  id?: string\n): Promise<void> {\n  if (isOrchestratorWorker()) {\n    return createSendSignalCall(\n      { type: SignalTargetType.Execution, executionId },\n      typeof signal === \"string\" ? signal : signal.id,\n      payload\n    ) as unknown as any;\n  } else {\n    return getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]} |
@@ -22,4 +22,4 @@ export function assertNever(never, msg) { | ||
!!err.prototype && | ||
err.prototype.isPrototypeOf(Error)))); | ||
Object.prototype.isPrototypeOf.call(err.prototype, Error)))); | ||
} | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBWSxFQUFFLEdBQVk7SUFDcEQsTUFBTSxJQUFJLEtBQUssQ0FBQyxHQUFHLElBQUksdUNBQXVDLEtBQUssRUFBRSxDQUFDLENBQUM7QUFDekUsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQUksS0FBUyxFQUFFLEdBQVk7SUFDdEQsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxJQUFJLDRDQUE0QyxDQUFDLENBQUM7S0FDdEU7SUFDRCxPQUFPLEtBQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsQ0FDakIsQ0FBbUI7SUFFbkIsT0FBTyxDQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBUSxDQUFDO0FBQ3BDLENBQUM7QUFFRCxNQUFNLFVBQVUsRUFBRSxDQUNoQixHQUFHLFVBQWE7SUFFaEIsT0FBTyxDQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBUSxDQUFDO0FBQ2pFLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLEdBQVk7SUFDdkMsT0FBTyxDQUNMLENBQUMsQ0FBQyxHQUFHO1FBQ0wsT0FBTyxHQUFHLEtBQUssUUFBUTtRQUN2QixDQUFDLEdBQUcsWUFBWSxLQUFLO1lBQ25CLENBQUMsV0FBVyxJQUFJLEdBQUc7Z0JBQ2pCLENBQUMsQ0FBQyxHQUFHLENBQUMsU0FBUztnQkFDZixHQUFHLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ3pDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGFzc2VydE5ldmVyKG5ldmVyOiBuZXZlciwgbXNnPzogc3RyaW5nKTogbmV2ZXIge1xuICB0aHJvdyBuZXcgRXJyb3IobXNnID8/IGByZWFjaGVkIHVucmVhY2hhYmxlIGNvZGUgd2l0aCB2YWx1ZSAke25ldmVyfWApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0Tm9uTnVsbDxUPih2YWx1ZT86IFQsIG1zZz86IHN0cmluZyk6IE5vbk51bGxhYmxlPFQ+IHtcbiAgaWYgKCF2YWx1ZSkge1xuICAgIHRocm93IG5ldyBFcnJvcihtc2cgPz8gXCJleHBlY3RlZCB2YWx1ZSB0byBiZSBkZWZpbmVkIGFuZCBub3QgbnVsbC5cIik7XG4gIH1cbiAgcmV0dXJuIHZhbHVlITtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vdDxULCBVIGV4dGVuZHMgVD4oXG4gIGY6IChhOiBUKSA9PiBhIGlzIFVcbik6IChhOiBUKSA9PiBhIGlzIEV4Y2x1ZGU8VCwgVT4ge1xuICByZXR1cm4gKChhOiBhbnkpID0+ICFmKGEpKSBhcyBhbnk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvcjxGIGV4dGVuZHMgKChhOiBhbnkpID0+IGEgaXMgYW55KVtdPihcbiAgLi4uY29uZGl0aW9uczogRlxuKTogKGE6IGFueSkgPT4gYSBpcyBGW251bWJlcl0gZXh0ZW5kcyAoYTogYW55KSA9PiBhIGlzIGluZmVyIFQgPyBUIDogbmV2ZXIge1xuICByZXR1cm4gKChhOiBhbnkpID0+IGNvbmRpdGlvbnMuc29tZSgoY29uZCkgPT4gY29uZChhKSkpIGFzIGFueTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4dGVuZHNFcnJvcihlcnI6IHVua25vd24pOiBlcnIgaXMgRXJyb3Ige1xuICByZXR1cm4gKFxuICAgICEhZXJyICYmXG4gICAgdHlwZW9mIGVyciA9PT0gXCJvYmplY3RcIiAmJlxuICAgIChlcnIgaW5zdGFuY2VvZiBFcnJvciB8fFxuICAgICAgKFwicHJvdG90eXBlXCIgaW4gZXJyICYmXG4gICAgICAgICEhZXJyLnByb3RvdHlwZSAmJlxuICAgICAgICBlcnIucHJvdG90eXBlLmlzUHJvdG90eXBlT2YoRXJyb3IpKSlcbiAgKTtcbn1cbiJdfQ== | ||
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sVUFBVSxXQUFXLENBQUMsS0FBWSxFQUFFLEdBQVk7SUFDcEQsTUFBTSxJQUFJLEtBQUssQ0FBQyxHQUFHLElBQUksdUNBQXVDLEtBQUssRUFBRSxDQUFDLENBQUM7QUFDekUsQ0FBQztBQUVELE1BQU0sVUFBVSxhQUFhLENBQUksS0FBUyxFQUFFLEdBQVk7SUFDdEQsSUFBSSxDQUFDLEtBQUssRUFBRTtRQUNWLE1BQU0sSUFBSSxLQUFLLENBQUMsR0FBRyxJQUFJLDRDQUE0QyxDQUFDLENBQUM7S0FDdEU7SUFDRCxPQUFPLEtBQU0sQ0FBQztBQUNoQixDQUFDO0FBRUQsTUFBTSxVQUFVLEdBQUcsQ0FDakIsQ0FBbUI7SUFFbkIsT0FBTyxDQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBUSxDQUFDO0FBQ3BDLENBQUM7QUFFRCxNQUFNLFVBQVUsRUFBRSxDQUNoQixHQUFHLFVBQWE7SUFFaEIsT0FBTyxDQUFDLENBQUMsQ0FBTSxFQUFFLEVBQUUsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLENBQUMsSUFBSSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBUSxDQUFDO0FBQ2pFLENBQUM7QUFFRCxNQUFNLFVBQVUsWUFBWSxDQUFDLEdBQVk7SUFDdkMsT0FBTyxDQUNMLENBQUMsQ0FBQyxHQUFHO1FBQ0wsT0FBTyxHQUFHLEtBQUssUUFBUTtRQUN2QixDQUFDLEdBQUcsWUFBWSxLQUFLO1lBQ25CLENBQUMsV0FBVyxJQUFJLEdBQUc7Z0JBQ2pCLENBQUMsQ0FBQyxHQUFHLENBQUMsU0FBUztnQkFDZixNQUFNLENBQUMsU0FBUyxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLFNBQVMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQ2hFLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGZ1bmN0aW9uIGFzc2VydE5ldmVyKG5ldmVyOiBuZXZlciwgbXNnPzogc3RyaW5nKTogbmV2ZXIge1xuICB0aHJvdyBuZXcgRXJyb3IobXNnID8/IGByZWFjaGVkIHVucmVhY2hhYmxlIGNvZGUgd2l0aCB2YWx1ZSAke25ldmVyfWApO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gYXNzZXJ0Tm9uTnVsbDxUPih2YWx1ZT86IFQsIG1zZz86IHN0cmluZyk6IE5vbk51bGxhYmxlPFQ+IHtcbiAgaWYgKCF2YWx1ZSkge1xuICAgIHRocm93IG5ldyBFcnJvcihtc2cgPz8gXCJleHBlY3RlZCB2YWx1ZSB0byBiZSBkZWZpbmVkIGFuZCBub3QgbnVsbC5cIik7XG4gIH1cbiAgcmV0dXJuIHZhbHVlITtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIG5vdDxULCBVIGV4dGVuZHMgVD4oXG4gIGY6IChhOiBUKSA9PiBhIGlzIFVcbik6IChhOiBUKSA9PiBhIGlzIEV4Y2x1ZGU8VCwgVT4ge1xuICByZXR1cm4gKChhOiBhbnkpID0+ICFmKGEpKSBhcyBhbnk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBvcjxGIGV4dGVuZHMgKChhOiBhbnkpID0+IGEgaXMgYW55KVtdPihcbiAgLi4uY29uZGl0aW9uczogRlxuKTogKGE6IGFueSkgPT4gYSBpcyBGW251bWJlcl0gZXh0ZW5kcyAoYTogYW55KSA9PiBhIGlzIGluZmVyIFQgPyBUIDogbmV2ZXIge1xuICByZXR1cm4gKChhOiBhbnkpID0+IGNvbmRpdGlvbnMuc29tZSgoY29uZCkgPT4gY29uZChhKSkpIGFzIGFueTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGV4dGVuZHNFcnJvcihlcnI6IHVua25vd24pOiBlcnIgaXMgRXJyb3Ige1xuICByZXR1cm4gKFxuICAgICEhZXJyICYmXG4gICAgdHlwZW9mIGVyciA9PT0gXCJvYmplY3RcIiAmJlxuICAgIChlcnIgaW5zdGFuY2VvZiBFcnJvciB8fFxuICAgICAgKFwicHJvdG90eXBlXCIgaW4gZXJyICYmXG4gICAgICAgICEhZXJyLnByb3RvdHlwZSAmJlxuICAgICAgICBPYmplY3QucHJvdG90eXBlLmlzUHJvdG90eXBlT2YuY2FsbChlcnIucHJvdG90eXBlLCBFcnJvcikpKVxuICApO1xufVxuIl19 |
@@ -136,10 +136,3 @@ import { ExecutionContext } from "./context.js"; | ||
} | ||
export interface WorkflowTaskCompleted extends BaseEvent { | ||
type: WorkflowEventType.WorkflowTaskCompleted; | ||
} | ||
export declare function isTaskCompleted(event: WorkflowEvent): event is WorkflowTaskCompleted; | ||
export interface WorkflowCompleted extends BaseEvent { | ||
type: WorkflowEventType.WorkflowCompleted; | ||
output: any; | ||
} | ||
export declare function isWorkflowCompleted(event: WorkflowEvent): event is WorkflowCompleted; | ||
@@ -146,0 +139,0 @@ export declare function isWorkflowFailed(event: WorkflowEvent): event is WorkflowFailed; |
@@ -153,2 +153,2 @@ import { ulid } from "ulidx"; | ||
} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-events.js","sourceRoot":"","sources":["../../src/workflow-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ulid } from \"ulidx\";\nimport { ExecutionContext } from \"./context.js\";\nimport { EventEnvelope } from \"./event.js\";\nimport { or } from \"./util.js\";\n\nexport interface BaseEvent {\n  type: WorkflowEventType;\n  id: string;\n  timestamp: string;\n}\n\n/**\n * Common fields for events that {@link Eventual} actives with in order semantics.\n */\nexport interface HistoryEventBase extends Omit<BaseEvent, \"id\"> {\n  seq: number;\n}\n\nexport enum WorkflowEventType {\n  ActivityCompleted = \"ActivityCompleted\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowCompleted = \"ChildWorkflowCompleted\",\n  ChildWorkflowFailed = \"ChildWorkflowFailed\",\n  ChildWorkflowScheduled = \"ChildWorkflowScheduled\",\n  ConditionStarted = \"ConditionStarted\",\n  ConditionTimedOut = \"ConditionTimedOut\",\n  EventsPublished = \"EventsPublished\",\n  ExpectSignalStarted = \"ExpectSignalStarted\",\n  ExpectSignalTimedOut = \"ExpectSignalTimedOut\",\n  SignalReceived = \"SignalReceived\",\n  SignalSent = \"SignalSent\",\n  SleepCompleted = \"SleepCompleted\",\n  SleepScheduled = \"SleepScheduled\",\n  WorkflowCompleted = \"WorkflowCompleted\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowTaskCompleted = \"TaskCompleted\",\n  WorkflowTaskStarted = \"TaskStarted\",\n  WorkflowTimedOut = \"WorkflowTimedOut\",\n}\n\n/**\n * Events generated by the engine that represent the in-order state of the workflow.\n */\nexport type WorkflowEvent =\n  | HistoryEvent\n  | WorkflowTaskCompleted\n  | WorkflowTaskStarted\n  | WorkflowCompleted\n  | WorkflowFailed\n  | WorkflowStarted;\n\nexport type ScheduledEvent =\n  | ActivityScheduled\n  | ChildWorkflowScheduled\n  | ConditionStarted\n  | EventsPublished\n  | ExpectSignalStarted\n  | SignalSent\n  | SleepScheduled;\n\nexport type CompletedEvent =\n  | ActivityCompleted\n  | ChildWorkflowCompleted\n  | SleepCompleted;\n\nexport type FailedEvent =\n  | ActivityFailed\n  | ActivityHeartbeatTimedOut\n  | ActivityTimedOut\n  | ChildWorkflowFailed\n  | ConditionTimedOut\n  | ExpectSignalTimedOut;\n\n/**\n * Events used by the workflow to replay an execution.\n */\nexport type HistoryEvent =\n  | CompletedEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isCompletedEvent(event) ||\n    isFailedEvent(event) ||\n    isScheduledEvent(event) ||\n    isSignalReceived(event) ||\n    isWorkflowTimedOut(event)\n  );\n}\n\n/**\n * Events that we save into history.\n */\nexport type HistoryStateEvent = HistoryEvent | WorkflowStarted;\n\nexport interface WorkflowStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowStarted;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: any;\n  /**\n   * Optional ISO timestamp after which the workflow should timeout.\n   */\n  timeoutTime?: string;\n  context: Omit<ExecutionContext, \"id\" | \"startTime\">;\n}\nexport interface WorkflowTaskStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskStarted;\n  /**\n   * An execution ID of the parent workflow execution that\n   * started this workflow if this is a child workflow.\n   */\n  parent?: string;\n}\n\nexport interface ActivityScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ActivityScheduled;\n  name: string;\n}\n\nexport interface ActivityCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ActivityCompleted;\n  result: any;\n}\n\nexport interface ActivityFailed extends HistoryEventBase {\n  type: WorkflowEventType.ActivityFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ActivityHeartbeatTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport interface WorkflowFailed extends BaseEvent {\n  type: WorkflowEventType.WorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ChildWorkflowScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowScheduled;\n  name: string;\n  input?: any;\n}\n\nexport interface ChildWorkflowCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowCompleted;\n  result: any;\n}\n\nexport interface ChildWorkflowFailed extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport function isWorkflowStarted(\n  event: WorkflowEvent\n): event is WorkflowStarted {\n  return event.type === WorkflowEventType.WorkflowStarted;\n}\n\nexport function isTaskStarted(\n  event: WorkflowEvent\n): event is WorkflowTaskStarted {\n  return event.type === WorkflowEventType.WorkflowTaskStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivityCompleted(\n  event: WorkflowEvent\n): event is ActivityCompleted {\n  return event.type === WorkflowEventType.ActivityCompleted;\n}\n\nexport function isActivityFailed(\n  event: WorkflowEvent\n): event is ActivityFailed {\n  return event.type === WorkflowEventType.ActivityFailed;\n}\n\nexport function isActivityHeartbeatTimedOut(\n  event: WorkflowEvent\n): event is ActivityHeartbeatTimedOut {\n  return event.type === WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface SleepScheduled extends HistoryEventBase {\n  type: WorkflowEventType.SleepScheduled;\n  untilTime: string;\n}\n\nexport function isSleepScheduled(\n  event: WorkflowEvent\n): event is SleepScheduled {\n  return event.type === WorkflowEventType.SleepScheduled;\n}\n\nexport interface SleepCompleted extends HistoryEventBase {\n  type: WorkflowEventType.SleepCompleted;\n  result?: undefined;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport function isTaskCompleted(\n  event: WorkflowEvent\n): event is WorkflowTaskCompleted {\n  return event.type === WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport function isWorkflowCompleted(\n  event: WorkflowEvent\n): event is WorkflowCompleted {\n  return event.type === WorkflowEventType.WorkflowCompleted;\n}\n\nexport function isWorkflowFailed(\n  event: WorkflowEvent\n): event is WorkflowFailed {\n  return event.type === WorkflowEventType.WorkflowFailed;\n}\n\nexport function isChildWorkflowScheduled(\n  event: WorkflowEvent\n): event is ChildWorkflowScheduled {\n  return event.type === WorkflowEventType.ChildWorkflowScheduled;\n}\nexport function isChildWorkflowCompleted(\n  event: WorkflowEvent\n): event is ChildWorkflowCompleted {\n  return event.type === WorkflowEventType.ChildWorkflowCompleted;\n}\nexport function isChildWorkflowFailed(\n  event: WorkflowEvent\n): event is ChildWorkflowFailed {\n  return event.type === WorkflowEventType.ChildWorkflowFailed;\n}\n\nexport function isSleepCompleted(\n  event: WorkflowEvent\n): event is SleepCompleted {\n  return event.type === WorkflowEventType.SleepCompleted;\n}\n\nexport interface ExpectSignalStarted extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalStarted;\n  signalId: string;\n  timeoutSeconds?: number;\n}\n\nexport interface ExpectSignalTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalTimedOut;\n  signalId: string;\n}\n\nexport interface SignalReceived<Payload = any> extends BaseEvent {\n  type: WorkflowEventType.SignalReceived;\n  signalId: string;\n  payload?: Payload;\n}\n\nexport function isExpectSignalStarted(\n  event: WorkflowEvent\n): event is ExpectSignalStarted {\n  return event.type === WorkflowEventType.ExpectSignalStarted;\n}\n\nexport function isExpectSignalTimedOut(\n  event: WorkflowEvent\n): event is ExpectSignalTimedOut {\n  return event.type === WorkflowEventType.ExpectSignalTimedOut;\n}\n\nexport function isSignalReceived(\n  event: WorkflowEvent\n): event is SignalReceived {\n  return event.type === WorkflowEventType.SignalReceived;\n}\n\nexport interface SignalSent extends HistoryEventBase {\n  type: WorkflowEventType.SignalSent;\n  payload?: any;\n  signalId: string;\n  executionId: string;\n}\n\nexport function isSignalSent(event: WorkflowEvent): event is SignalSent {\n  return event.type === WorkflowEventType.SignalSent;\n}\n\nexport interface EventsPublished extends HistoryEventBase {\n  type: WorkflowEventType.EventsPublished;\n  events: EventEnvelope[];\n}\n\nexport function isEventsPublished(\n  event: WorkflowEvent\n): event is EventsPublished {\n  return event.type === WorkflowEventType.EventsPublished;\n}\n\nexport interface ConditionStarted extends HistoryEventBase {\n  type: WorkflowEventType.ConditionStarted;\n}\n\nexport function isConditionStarted(\n  event: WorkflowEvent\n): event is ConditionStarted {\n  return event.type === WorkflowEventType.ConditionStarted;\n}\n\nexport interface ConditionTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ConditionTimedOut;\n}\n\nexport function isConditionTimedOut(\n  event: WorkflowEvent\n): event is ConditionTimedOut {\n  return event.type === WorkflowEventType.ConditionTimedOut;\n}\n\nexport interface ActivityTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityTimedOut;\n}\n\nexport interface WorkflowTimedOut extends BaseEvent {\n  type: WorkflowEventType.WorkflowTimedOut;\n}\n\nexport function isActivityTimedOut(\n  event: WorkflowEvent\n): event is ActivityTimedOut {\n  return event.type === WorkflowEventType.ActivityTimedOut;\n}\n\nexport function isWorkflowTimedOut(\n  event: WorkflowEvent\n): event is WorkflowTimedOut {\n  return event.type === WorkflowEventType.WorkflowTimedOut;\n}\n\nexport const isScheduledEvent = or(\n  isActivityScheduled,\n  isChildWorkflowScheduled,\n  isConditionStarted,\n  isEventsPublished,\n  isExpectSignalStarted,\n  isSignalSent,\n  isSleepScheduled\n);\n\nexport const isCompletedEvent = or(\n  isActivityCompleted,\n  isChildWorkflowCompleted,\n  isSleepCompleted\n);\n\nexport const isFailedEvent = or(\n  isActivityFailed,\n  isActivityTimedOut,\n  isActivityHeartbeatTimedOut,\n  isChildWorkflowFailed,\n  isConditionTimedOut,\n  isExpectSignalTimedOut,\n  isWorkflowTimedOut\n);\n\nexport function assertEventType<T extends WorkflowEvent>(\n  event: any,\n  type: T[\"type\"]\n): asserts event is T {\n  if (!event || event.type !== type) {\n    throw new Error(`Expected event of type ${type}`);\n  }\n}\n\n/**\n * Compute the ID of an event.\n *\n * Some events have a computed ID to save space.\n */\nexport function getEventId(event: WorkflowEvent): string {\n  if (\n    isHistoryEvent(event) &&\n    !isSignalReceived(event) &&\n    !isWorkflowTimedOut(event)\n  ) {\n    return `${event.seq}_${event.type}`;\n  } else {\n    return event.id;\n  }\n}\n\n/**\n * Filters out events that are also present in origin events.\n *\n * Events are taken only if their ID ({@link getEventId}) is unique across all other events.\n */\nexport function filterEvents<T extends WorkflowEvent>(\n  originEvents: T[],\n  events: T[]\n): T[] {\n  const ids = new Set(originEvents.map(getEventId));\n\n  return events.filter((event) => {\n    const id = getEventId(event);\n    if (ids.has(id)) {\n      return false;\n    }\n    ids.add(id);\n    return true;\n  });\n}\n\ntype UnresolvedEvent<T extends WorkflowEvent> = Omit<T, \"id\" | \"timestamp\">;\n\nexport function createEvent<T extends WorkflowEvent>(\n  event: UnresolvedEvent<T>,\n  time: Date = new Date(),\n  id: string = ulid()\n): T {\n  const timestamp = time.toISOString();\n\n  // history events do not have IDs, use getEventId\n  if (\n    isHistoryEvent(event as unknown as WorkflowEvent) &&\n    !isSignalReceived(event as unknown as WorkflowEvent)\n  ) {\n    return { ...(event as any), timestamp };\n  }\n\n  return { ...event, id, timestamp } as T;\n}\n"]} | ||
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-events.js","sourceRoot":"","sources":["../../src/workflow-events.ts"],"names":[],"mappings":"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","sourcesContent":["import { ulid } from \"ulidx\";\nimport { ExecutionContext } from \"./context.js\";\nimport { EventEnvelope } from \"./event.js\";\nimport { or } from \"./util.js\";\n\nexport interface BaseEvent {\n  type: WorkflowEventType;\n  id: string;\n  timestamp: string;\n}\n\n/**\n * Common fields for events that {@link Eventual} actives with in order semantics.\n */\nexport interface HistoryEventBase extends Omit<BaseEvent, \"id\"> {\n  seq: number;\n}\n\nexport enum WorkflowEventType {\n  ActivityCompleted = \"ActivityCompleted\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowCompleted = \"ChildWorkflowCompleted\",\n  ChildWorkflowFailed = \"ChildWorkflowFailed\",\n  ChildWorkflowScheduled = \"ChildWorkflowScheduled\",\n  ConditionStarted = \"ConditionStarted\",\n  ConditionTimedOut = \"ConditionTimedOut\",\n  EventsPublished = \"EventsPublished\",\n  ExpectSignalStarted = \"ExpectSignalStarted\",\n  ExpectSignalTimedOut = \"ExpectSignalTimedOut\",\n  SignalReceived = \"SignalReceived\",\n  SignalSent = \"SignalSent\",\n  SleepCompleted = \"SleepCompleted\",\n  SleepScheduled = \"SleepScheduled\",\n  WorkflowCompleted = \"WorkflowCompleted\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowTaskCompleted = \"TaskCompleted\",\n  WorkflowTaskStarted = \"TaskStarted\",\n  WorkflowTimedOut = \"WorkflowTimedOut\",\n}\n\n/**\n * Events generated by the engine that represent the in-order state of the workflow.\n */\nexport type WorkflowEvent =\n  | HistoryEvent\n  | WorkflowTaskCompleted\n  | WorkflowTaskStarted\n  | WorkflowCompleted\n  | WorkflowFailed\n  | WorkflowStarted;\n\nexport type ScheduledEvent =\n  | ActivityScheduled\n  | ChildWorkflowScheduled\n  | ConditionStarted\n  | EventsPublished\n  | ExpectSignalStarted\n  | SignalSent\n  | SleepScheduled;\n\nexport type CompletedEvent =\n  | ActivityCompleted\n  | ChildWorkflowCompleted\n  | SleepCompleted;\n\nexport type FailedEvent =\n  | ActivityFailed\n  | ActivityHeartbeatTimedOut\n  | ActivityTimedOut\n  | ChildWorkflowFailed\n  | ConditionTimedOut\n  | ExpectSignalTimedOut;\n\n/**\n * Events used by the workflow to replay an execution.\n */\nexport type HistoryEvent =\n  | CompletedEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isCompletedEvent(event) ||\n    isFailedEvent(event) ||\n    isScheduledEvent(event) ||\n    isSignalReceived(event) ||\n    isWorkflowTimedOut(event)\n  );\n}\n\n/**\n * Events that we save into history.\n */\nexport type HistoryStateEvent = HistoryEvent | WorkflowStarted;\n\nexport interface WorkflowStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowStarted;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: any;\n  /**\n   * Optional ISO timestamp after which the workflow should timeout.\n   */\n  timeoutTime?: string;\n  context: Omit<ExecutionContext, \"id\" | \"startTime\">;\n}\nexport interface WorkflowTaskStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskStarted;\n  /**\n   * An execution ID of the parent workflow execution that\n   * started this workflow if this is a child workflow.\n   */\n  parent?: string;\n}\n\nexport interface ActivityScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ActivityScheduled;\n  name: string;\n}\n\nexport interface ActivityCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ActivityCompleted;\n  result: any;\n}\n\nexport interface ActivityFailed extends HistoryEventBase {\n  type: WorkflowEventType.ActivityFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ActivityHeartbeatTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface WorkflowTaskCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport interface WorkflowCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowCompleted;\n  output: any;\n}\n\nexport interface WorkflowFailed extends BaseEvent {\n  type: WorkflowEventType.WorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport interface ChildWorkflowScheduled extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowScheduled;\n  name: string;\n  input?: any;\n}\n\nexport interface ChildWorkflowCompleted extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowCompleted;\n  result: any;\n}\n\nexport interface ChildWorkflowFailed extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowFailed;\n  error: string;\n  message: string;\n}\n\nexport function isWorkflowStarted(\n  event: WorkflowEvent\n): event is WorkflowStarted {\n  return event.type === WorkflowEventType.WorkflowStarted;\n}\n\nexport function isTaskStarted(\n  event: WorkflowEvent\n): event is WorkflowTaskStarted {\n  return event.type === WorkflowEventType.WorkflowTaskStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivityCompleted(\n  event: WorkflowEvent\n): event is ActivityCompleted {\n  return event.type === WorkflowEventType.ActivityCompleted;\n}\n\nexport function isActivityFailed(\n  event: WorkflowEvent\n): event is ActivityFailed {\n  return event.type === WorkflowEventType.ActivityFailed;\n}\n\nexport function isActivityHeartbeatTimedOut(\n  event: WorkflowEvent\n): event is ActivityHeartbeatTimedOut {\n  return event.type === WorkflowEventType.ActivityHeartbeatTimedOut;\n}\n\nexport interface SleepScheduled extends HistoryEventBase {\n  type: WorkflowEventType.SleepScheduled;\n  untilTime: string;\n}\n\nexport function isSleepScheduled(\n  event: WorkflowEvent\n): event is SleepScheduled {\n  return event.type === WorkflowEventType.SleepScheduled;\n}\n\nexport interface SleepCompleted extends HistoryEventBase {\n  type: WorkflowEventType.SleepCompleted;\n  result?: undefined;\n}\n\nexport function isTaskCompleted(\n  event: WorkflowEvent\n): event is WorkflowTaskCompleted {\n  return event.type === WorkflowEventType.WorkflowTaskCompleted;\n}\n\nexport function isWorkflowCompleted(\n  event: WorkflowEvent\n): event is WorkflowCompleted {\n  return event.type === WorkflowEventType.WorkflowCompleted;\n}\n\nexport function isWorkflowFailed(\n  event: WorkflowEvent\n): event is WorkflowFailed {\n  return event.type === WorkflowEventType.WorkflowFailed;\n}\n\nexport function isChildWorkflowScheduled(\n  event: WorkflowEvent\n): event is ChildWorkflowScheduled {\n  return event.type === WorkflowEventType.ChildWorkflowScheduled;\n}\nexport function isChildWorkflowCompleted(\n  event: WorkflowEvent\n): event is ChildWorkflowCompleted {\n  return event.type === WorkflowEventType.ChildWorkflowCompleted;\n}\nexport function isChildWorkflowFailed(\n  event: WorkflowEvent\n): event is ChildWorkflowFailed {\n  return event.type === WorkflowEventType.ChildWorkflowFailed;\n}\n\nexport function isSleepCompleted(\n  event: WorkflowEvent\n): event is SleepCompleted {\n  return event.type === WorkflowEventType.SleepCompleted;\n}\n\nexport interface ExpectSignalStarted extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalStarted;\n  signalId: string;\n  timeoutSeconds?: number;\n}\n\nexport interface ExpectSignalTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ExpectSignalTimedOut;\n  signalId: string;\n}\n\nexport interface SignalReceived<Payload = any> extends BaseEvent {\n  type: WorkflowEventType.SignalReceived;\n  signalId: string;\n  payload?: Payload;\n}\n\nexport function isExpectSignalStarted(\n  event: WorkflowEvent\n): event is ExpectSignalStarted {\n  return event.type === WorkflowEventType.ExpectSignalStarted;\n}\n\nexport function isExpectSignalTimedOut(\n  event: WorkflowEvent\n): event is ExpectSignalTimedOut {\n  return event.type === WorkflowEventType.ExpectSignalTimedOut;\n}\n\nexport function isSignalReceived(\n  event: WorkflowEvent\n): event is SignalReceived {\n  return event.type === WorkflowEventType.SignalReceived;\n}\n\nexport interface SignalSent extends HistoryEventBase {\n  type: WorkflowEventType.SignalSent;\n  payload?: any;\n  signalId: string;\n  executionId: string;\n}\n\nexport function isSignalSent(event: WorkflowEvent): event is SignalSent {\n  return event.type === WorkflowEventType.SignalSent;\n}\n\nexport interface EventsPublished extends HistoryEventBase {\n  type: WorkflowEventType.EventsPublished;\n  events: EventEnvelope[];\n}\n\nexport function isEventsPublished(\n  event: WorkflowEvent\n): event is EventsPublished {\n  return event.type === WorkflowEventType.EventsPublished;\n}\n\nexport interface ConditionStarted extends HistoryEventBase {\n  type: WorkflowEventType.ConditionStarted;\n}\n\nexport function isConditionStarted(\n  event: WorkflowEvent\n): event is ConditionStarted {\n  return event.type === WorkflowEventType.ConditionStarted;\n}\n\nexport interface ConditionTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ConditionTimedOut;\n}\n\nexport function isConditionTimedOut(\n  event: WorkflowEvent\n): event is ConditionTimedOut {\n  return event.type === WorkflowEventType.ConditionTimedOut;\n}\n\nexport interface ActivityTimedOut extends HistoryEventBase {\n  type: WorkflowEventType.ActivityTimedOut;\n}\n\nexport interface WorkflowTimedOut extends BaseEvent {\n  type: WorkflowEventType.WorkflowTimedOut;\n}\n\nexport function isActivityTimedOut(\n  event: WorkflowEvent\n): event is ActivityTimedOut {\n  return event.type === WorkflowEventType.ActivityTimedOut;\n}\n\nexport function isWorkflowTimedOut(\n  event: WorkflowEvent\n): event is WorkflowTimedOut {\n  return event.type === WorkflowEventType.WorkflowTimedOut;\n}\n\nexport const isScheduledEvent = or(\n  isActivityScheduled,\n  isChildWorkflowScheduled,\n  isConditionStarted,\n  isEventsPublished,\n  isExpectSignalStarted,\n  isSignalSent,\n  isSleepScheduled\n);\n\nexport const isCompletedEvent = or(\n  isActivityCompleted,\n  isChildWorkflowCompleted,\n  isSleepCompleted\n);\n\nexport const isFailedEvent = or(\n  isActivityFailed,\n  isActivityTimedOut,\n  isActivityHeartbeatTimedOut,\n  isChildWorkflowFailed,\n  isConditionTimedOut,\n  isExpectSignalTimedOut,\n  isWorkflowTimedOut\n);\n\nexport function assertEventType<T extends WorkflowEvent>(\n  event: any,\n  type: T[\"type\"]\n): asserts event is T {\n  if (!event || event.type !== type) {\n    throw new Error(`Expected event of type ${type}`);\n  }\n}\n\n/**\n * Compute the ID of an event.\n *\n * Some events have a computed ID to save space.\n */\nexport function getEventId(event: WorkflowEvent): string {\n  if (\n    isHistoryEvent(event) &&\n    !isSignalReceived(event) &&\n    !isWorkflowTimedOut(event)\n  ) {\n    return `${event.seq}_${event.type}`;\n  } else {\n    return event.id;\n  }\n}\n\n/**\n * Filters out events that are also present in origin events.\n *\n * Events are taken only if their ID ({@link getEventId}) is unique across all other events.\n */\nexport function filterEvents<T extends WorkflowEvent>(\n  originEvents: T[],\n  events: T[]\n): T[] {\n  const ids = new Set(originEvents.map(getEventId));\n\n  return events.filter((event) => {\n    const id = getEventId(event);\n    if (ids.has(id)) {\n      return false;\n    }\n    ids.add(id);\n    return true;\n  });\n}\n\ntype UnresolvedEvent<T extends WorkflowEvent> = Omit<T, \"id\" | \"timestamp\">;\n\nexport function createEvent<T extends WorkflowEvent>(\n  event: UnresolvedEvent<T>,\n  time: Date = new Date(),\n  id: string = ulid()\n): T {\n  const timestamp = time.toISOString();\n\n  // history events do not have IDs, use getEventId\n  if (\n    isHistoryEvent(event as unknown as WorkflowEvent) &&\n    !isSignalReceived(event as unknown as WorkflowEvent)\n  ) {\n    return { ...(event as any), timestamp };\n  }\n\n  return { ...event, id, timestamp } as T;\n}\n"]} |
{ | ||
"name": "@eventual/core", | ||
"version": "0.2.0", | ||
"version": "0.3.0", | ||
"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 too big to display
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
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
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 too big to display
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
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
1347762
10622