Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@eventual/core

Package Overview
Dependencies
Maintainers
2
Versions
164
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@eventual/core - npm Package Compare versions

Comparing version 0.5.1 to 0.5.2

62

lib/cjs/activity.d.ts

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

import { SendActivitySuccessRequest } from "./service-client.js";
import { SendActivityFailureRequest, SendActivityHeartbeatRequest, SendActivityHeartbeatResponse, SendActivitySuccessRequest } from "./service-client.js";
export interface ActivityOptions {

@@ -15,3 +15,3 @@ /**

* When set to a positive number, the activity must call {@link heartbeat} or
* {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.
* {@link EventualServiceClient.sendActivityHeartbeat} at least every heartbeatSeconds.
*

@@ -34,7 +34,7 @@ * If it fails to do so, the workflow will cancel the activity and throw an error.

* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publish({ token }));
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.on(async ({token}) => {
* await asyncActivity.complete({
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivitySuccess({
* activityToken: token,

@@ -46,3 +46,47 @@ * result: "done"

*/
complete(request: Omit<SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>, "type">): Promise<void>;
sendActivitySuccess(request: Omit<SendActivitySuccessRequest<Awaited<UnwrapAsync<Output>>>, "type">): Promise<void>;
/**
* Fail an activity request by its {@link SendActivityFailureRequest.activityToken}.
*
* This method is used in conjunction with {@link asyncResult} in an activity
* to perform asynchronous, long-running computations. For example:
*
* ```ts
* const tokenEvent = event("token");
*
* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivityFailure({
* activityToken: token,
* error: "MyError",
* message: "Something went wrong"
* });
* })
* ```
*/
sendActivityFailure(request: Omit<SendActivityFailureRequest, "type">): Promise<void>;
/**
* Heartbeat an activity request by its {@link SendActivityHeartbeatRequest.activityToken}.
*
* This method is used in conjunction with {@link asyncResult} in an activity
* to perform asynchronous, long-running computations. For example:
*
* ```ts
* const tokenEvent = event("token");
*
* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivityFailure({
* activityToken: token
* });
* })
* ```
*/
sendActivityHeartbeat(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
activityID: string;

@@ -68,3 +112,3 @@ }

* activity async. This allows the activity to defer sending a response from the
* current function and instead complete the activity with {@link WorkflowClient.completeActivity}.
* current function and instead complete the activity with {@link WorkflowClient.sendActivitySuccess}.
*

@@ -74,3 +118,3 @@ * ```ts

* activity("myActivity", () => {
* // tells the system that the completeActivity function will be called later with a string result.
* // tells the system that the sendActivitySuccess function will be called later with a string result.
* return asyncResult<string>(async (activityToken) => {

@@ -85,3 +129,3 @@ * // before exiting, send the activityToken to a sqs queue to be completed later

* @param tokenContext is a callback which provides the activityToken. The activity token is used
* to completeActivity and heartbeatActivity from outside of the
* to sendActivitySuccess and sendActivityHeartbeat from outside of the
* activity.

@@ -88,0 +132,0 @@ */

16

lib/cjs/activity.js

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

* activity async. This allows the activity to defer sending a response from the
* current function and instead complete the activity with {@link WorkflowClient.completeActivity}.
* current function and instead complete the activity with {@link WorkflowClient.sendActivitySuccess}.
*

@@ -21,3 +21,3 @@ * ```ts

* activity("myActivity", () => {
* // tells the system that the completeActivity function will be called later with a string result.
* // tells the system that the sendActivitySuccess function will be called later with a string result.
* return asyncResult<string>(async (activityToken) => {

@@ -32,3 +32,3 @@ * // before exiting, send the activityToken to a sqs queue to be completed later

* @param tokenContext is a callback which provides the activityToken. The activity token is used
* to completeActivity and heartbeatActivity from outside of the
* to sendActivitySuccess and sendActivityHeartbeat from outside of the
* activity.

@@ -64,5 +64,11 @@ */

});
func.complete = async function (request) {
func.sendActivitySuccess = async function (request) {
return (0, global_js_1.getServiceClient)().sendActivitySuccess(request);
};
func.sendActivityFailure = async function (request) {
return (0, global_js_1.getServiceClient)().sendActivityFailure(request);
};
func.sendActivityHeartbeat = async function (request) {
return (0, global_js_1.getServiceClient)().sendActivityHeartbeat(request);
};
func.activityID = activityID;

@@ -83,2 +89,2 @@ return func;

exports.getCallableActivityNames = getCallableActivityNames;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":";;;AAAA,+DAA8D;AAC9D,2CAIqB;AACrB,iDAA4E;AA2E5E,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,yDAAyD;IACzD,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;IAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;QACzE,IAAI,IAAA,+BAAoB,GAAE,EAAE;YAC1B,+FAA+F;YAC/F,OAAO,IAAA,qCAAkB,EACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;SACV;aAAM;YACL,4EAA4E;YAC5E,OAAO,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;SACzB;IACH,CAAC,CAAwC,CAAC;IAC1C,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,IAAA,4BAAgB,GAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC7B,OAAO,IAAI,CAAC;AACd,CAAC;AA5BD,4BA4BC;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  getServiceClient,\n} from \"./global.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { SendActivitySuccessRequest } from \"./service-client.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 SendActivitySuccessRequest.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: Omit<\n      SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>,\n      \"type\"\n    >\n  ): Promise<void>;\n\n  activityID: string;\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\nexport type ActivityArguments<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<infer Arguments extends any[]> ? Arguments : never;\n\nexport type ActivityOutput<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<any, infer Output> ? UnwrapAsync<Output> : never;\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  // register the handler to be looked up during execution.\n  callableActivities()[activityID] = handler;\n  const func = ((...args: Parameters<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      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    } else {\n      // calling the activity from outside the orchestrator just calls the handler\n      return handler(...args);\n    }\n  }) as ActivityFunction<Arguments, Output>;\n  func.complete = async function (request) {\n    return getServiceClient().sendActivitySuccess(request);\n  };\n  func.activityID = activityID;\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;AACrB,iDAA4E;AAmI5E,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,yDAAyD;IACzD,IAAA,8BAAkB,GAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;IAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;QACzE,IAAI,IAAA,+BAAoB,GAAE,EAAE;YAC1B,+FAA+F;YAC/F,OAAO,IAAA,qCAAkB,EACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;SACV;aAAM;YACL,4EAA4E;YAC5E,OAAO,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;SACzB;IACH,CAAC,CAAwC,CAAC;IAC1C,IAAI,CAAC,mBAAmB,GAAG,KAAK,WAAW,OAAO;QAChD,OAAO,IAAA,4BAAgB,GAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,mBAAmB,GAAG,KAAK,WAAW,OAAO;QAChD,OAAO,IAAA,4BAAgB,GAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,qBAAqB,GAAG,KAAK,WAAW,OAAO;QAClD,OAAO,IAAA,4BAAgB,GAAE,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC3D,CAAC,CAAC;IACF,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC7B,OAAO,IAAI,CAAC;AACd,CAAC;AAlCD,4BAkCC;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  getServiceClient,\n} from \"./global.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\nimport {\n  EventualServiceClient,\n  SendActivityFailureRequest,\n  SendActivityHeartbeatRequest,\n  SendActivityHeartbeatResponse,\n  SendActivitySuccessRequest,\n} from \"./service-client.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 EventualServiceClient.sendActivityHeartbeat} 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 SendActivitySuccessRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivitySuccess({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  sendActivitySuccess(\n    request: Omit<\n      SendActivitySuccessRequest<Awaited<UnwrapAsync<Output>>>,\n      \"type\"\n    >\n  ): Promise<void>;\n\n  /**\n   * Fail an activity request by its {@link SendActivityFailureRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivityFailure({\n   *     activityToken: token,\n   *     error: \"MyError\",\n   *     message: \"Something went wrong\"\n   *   });\n   * })\n   * ```\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Heartbeat an activity request by its {@link SendActivityHeartbeatRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivityFailure({\n   *     activityToken: token\n   *   });\n   * })\n   * ```\n   */\n  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n\n  activityID: string;\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\nexport type ActivityArguments<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<infer Arguments extends any[]> ? Arguments : never;\n\nexport type ActivityOutput<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<any, infer Output> ? UnwrapAsync<Output> : never;\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.sendActivitySuccess}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the sendActivitySuccess 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 sendActivitySuccess and sendActivityHeartbeat 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  // register the handler to be looked up during execution.\n  callableActivities()[activityID] = handler;\n  const func = ((...args: Parameters<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      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    } else {\n      // calling the activity from outside the orchestrator just calls the handler\n      return handler(...args);\n    }\n  }) as ActivityFunction<Arguments, Output>;\n  func.sendActivitySuccess = async function (request) {\n    return getServiceClient().sendActivitySuccess(request);\n  };\n  func.sendActivityFailure = async function (request) {\n    return getServiceClient().sendActivityFailure(request);\n  };\n  func.sendActivityHeartbeat = async function (request) {\n    return getServiceClient().sendActivityHeartbeat(request);\n  };\n  func.activityID = activityID;\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"]}

@@ -20,3 +20,4 @@ "use strict";

// this reference will be resolved by the runtime.
call.signal = function (signal, payload, id) {
call.sendSignal = function (signal, payload) {
const signalId = typeof signal === "string" ? signal : signal.id;
return (0, send_signal_call_js_1.createSendSignalCall)({

@@ -26,3 +27,3 @@ type: signals_js_1.SignalTargetType.ChildExecution,

workflowName: call.name,
}, signal.id, payload, id);
}, signalId, payload);
};

@@ -32,2 +33,2 @@ return call;

exports.createWorkflowCall = createWorkflowCall;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQU13QjtBQUV4Qiw0Q0FBZ0Q7QUFFaEQsOENBQWlEO0FBRWpELCtEQUE2RDtBQUU3RCxTQUFnQixjQUFjLENBQUksQ0FBYztJQUM5QyxPQUFPLElBQUEsOEJBQWdCLEVBQUMsMEJBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDeEQsQ0FBQztBQUZELHdDQUVDO0FBY0QsU0FBZ0Isa0JBQWtCLENBQ2hDLElBQVksRUFDWixLQUFXLEVBQ1gsSUFBc0I7SUFFdEIsTUFBTSxJQUFJLEdBQUcsSUFBQSw0QkFBZ0IsRUFDM0IsSUFBQSw0QkFBYyxFQUFlLDBCQUFZLENBQUMsWUFBWSxFQUFFO1FBQ3RELEtBQUs7UUFDTCxJQUFJO1FBQ0osSUFBSTtLQUNXLENBQUMsQ0FDbkIsQ0FBQztJQUVGLG9GQUFvRjtJQUNwRixrREFBa0Q7SUFDbEQsSUFBSSxDQUFDLE1BQU0sR0FBRyxVQUFVLE1BQU0sRUFBRSxPQUFRLEVBQUUsRUFBRztRQUMzQyxPQUFPLElBQUEsMENBQW9CLEVBQ3pCO1lBQ0UsSUFBSSxFQUFFLDZCQUFnQixDQUFDLGNBQWM7WUFDckMsR0FBRyxFQUFFLElBQUksQ0FBQyxHQUFJO1lBQ2QsWUFBWSxFQUFFLElBQUksQ0FBQyxJQUFJO1NBQ3hCLEVBQ0QsTUFBTSxDQUFDLEVBQUUsRUFDVCxPQUFPLEVBQ1AsRUFBRSxDQUNlLENBQUM7SUFDdEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBN0JELGdEQTZCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGNyZWF0ZUV2ZW50dWFsLFxuICBFdmVudHVhbCxcbiAgRXZlbnR1YWxCYXNlLFxuICBFdmVudHVhbEtpbmQsXG4gIGlzRXZlbnR1YWxPZktpbmQsXG59IGZyb20gXCIuLi9ldmVudHVhbC5qc1wiO1xuaW1wb3J0IHsgQ2hpbGRFeGVjdXRpb24gfSBmcm9tIFwiLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlckV2ZW50dWFsIH0gZnJvbSBcIi4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgUmVzdWx0IH0gZnJvbSBcIi4uL3Jlc3VsdC5qc1wiO1xuaW1wb3J0IHsgU2lnbmFsVGFyZ2V0VHlwZSB9IGZyb20gXCIuLi9zaWduYWxzLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvdywgV29ya2Zsb3dPcHRpb25zIH0gZnJvbSBcIi4uL3dvcmtmbG93LmpzXCI7XG5pbXBvcnQgeyBjcmVhdGVTZW5kU2lnbmFsQ2FsbCB9IGZyb20gXCIuL3NlbmQtc2lnbmFsLWNhbGwuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzV29ya2Zsb3dDYWxsPFQ+KGE6IEV2ZW50dWFsPFQ+KTogYSBpcyBXb3JrZmxvd0NhbGw8VD4ge1xuICByZXR1cm4gaXNFdmVudHVhbE9mS2luZChFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCBhKTtcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnR1YWx9IHJlcHJlc2VudGluZyBhbiBhd2FpdGVkIGNhbGwgdG8gYSB7QGxpbmsgV29ya2Zsb3d9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdvcmtmbG93Q2FsbDxUID0gYW55PlxuICBleHRlbmRzIEV2ZW50dWFsQmFzZTxFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCBSZXN1bHQ8VD4+LFxuICAgIENoaWxkRXhlY3V0aW9uIHtcbiAgbmFtZTogc3RyaW5nO1xuICBpbnB1dD86IGFueTtcbiAgc2VxPzogbnVtYmVyO1xuICBvcHRzPzogV29ya2Zsb3dPcHRpb25zO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV29ya2Zsb3dDYWxsKFxuICBuYW1lOiBzdHJpbmcsXG4gIGlucHV0PzogYW55LFxuICBvcHRzPzogV29ya2Zsb3dPcHRpb25zXG4pOiBXb3JrZmxvd0NhbGwge1xuICBjb25zdCBjYWxsID0gcmVnaXN0ZXJFdmVudHVhbChcbiAgICBjcmVhdGVFdmVudHVhbDxXb3JrZmxvd0NhbGw+KEV2ZW50dWFsS2luZC5Xb3JrZmxvd0NhbGwsIHtcbiAgICAgIGlucHV0LFxuICAgICAgbmFtZSxcbiAgICAgIG9wdHMsXG4gICAgfSBhcyBXb3JrZmxvd0NhbGwpXG4gICk7XG5cbiAgLy8gY3JlYXRlIGEgcmVmZXJlbmNlIHRvIHRoZSBjaGlsZCB3b3JrZmxvdyBzdGFydGVkIGF0IGEgc2VxdWVuY2UgaW4gdGhpcyBleGVjdXRpb24uXG4gIC8vIHRoaXMgcmVmZXJlbmNlIHdpbGwgYmUgcmVzb2x2ZWQgYnkgdGhlIHJ1bnRpbWUuXG4gIGNhbGwuc2lnbmFsID0gZnVuY3Rpb24gKHNpZ25hbCwgcGF5bG9hZD8sIGlkPykge1xuICAgIHJldHVybiBjcmVhdGVTZW5kU2lnbmFsQ2FsbChcbiAgICAgIHtcbiAgICAgICAgdHlwZTogU2lnbmFsVGFyZ2V0VHlwZS5DaGlsZEV4ZWN1dGlvbixcbiAgICAgICAgc2VxOiBjYWxsLnNlcSEsXG4gICAgICAgIHdvcmtmbG93TmFtZTogY2FsbC5uYW1lLFxuICAgICAgfSxcbiAgICAgIHNpZ25hbC5pZCxcbiAgICAgIHBheWxvYWQsXG4gICAgICBpZFxuICAgICkgYXMgdW5rbm93biBhcyBhbnk7XG4gIH07XG5cbiAgcmV0dXJuIGNhbGw7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGdEQU13QjtBQUV4Qiw0Q0FBZ0Q7QUFFaEQsOENBQWlEO0FBRWpELCtEQUE2RDtBQUU3RCxTQUFnQixjQUFjLENBQUksQ0FBYztJQUM5QyxPQUFPLElBQUEsOEJBQWdCLEVBQUMsMEJBQVksQ0FBQyxZQUFZLEVBQUUsQ0FBQyxDQUFDLENBQUM7QUFDeEQsQ0FBQztBQUZELHdDQUVDO0FBY0QsU0FBZ0Isa0JBQWtCLENBQ2hDLElBQVksRUFDWixLQUFXLEVBQ1gsSUFBc0I7SUFFdEIsTUFBTSxJQUFJLEdBQUcsSUFBQSw0QkFBZ0IsRUFDM0IsSUFBQSw0QkFBYyxFQUFlLDBCQUFZLENBQUMsWUFBWSxFQUFFO1FBQ3RELEtBQUs7UUFDTCxJQUFJO1FBQ0osSUFBSTtLQUNXLENBQUMsQ0FDbkIsQ0FBQztJQUVGLG9GQUFvRjtJQUNwRixrREFBa0Q7SUFDbEQsSUFBSSxDQUFDLFVBQVUsR0FBRyxVQUFVLE1BQU0sRUFBRSxPQUFRO1FBQzFDLE1BQU0sUUFBUSxHQUFHLE9BQU8sTUFBTSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ2pFLE9BQU8sSUFBQSwwQ0FBb0IsRUFDekI7WUFDRSxJQUFJLEVBQUUsNkJBQWdCLENBQUMsY0FBYztZQUNyQyxHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUk7WUFDZCxZQUFZLEVBQUUsSUFBSSxDQUFDLElBQUk7U0FDeEIsRUFDRCxRQUFRLEVBQ1IsT0FBTyxDQUNVLENBQUM7SUFDdEIsQ0FBQyxDQUFDO0lBRUYsT0FBTyxJQUFJLENBQUM7QUFDZCxDQUFDO0FBN0JELGdEQTZCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGNyZWF0ZUV2ZW50dWFsLFxuICBFdmVudHVhbCxcbiAgRXZlbnR1YWxCYXNlLFxuICBFdmVudHVhbEtpbmQsXG4gIGlzRXZlbnR1YWxPZktpbmQsXG59IGZyb20gXCIuLi9ldmVudHVhbC5qc1wiO1xuaW1wb3J0IHsgQ2hpbGRFeGVjdXRpb24gfSBmcm9tIFwiLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlckV2ZW50dWFsIH0gZnJvbSBcIi4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgUmVzdWx0IH0gZnJvbSBcIi4uL3Jlc3VsdC5qc1wiO1xuaW1wb3J0IHsgU2lnbmFsVGFyZ2V0VHlwZSB9IGZyb20gXCIuLi9zaWduYWxzLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvdywgV29ya2Zsb3dPcHRpb25zIH0gZnJvbSBcIi4uL3dvcmtmbG93LmpzXCI7XG5pbXBvcnQgeyBjcmVhdGVTZW5kU2lnbmFsQ2FsbCB9IGZyb20gXCIuL3NlbmQtc2lnbmFsLWNhbGwuanNcIjtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzV29ya2Zsb3dDYWxsPFQ+KGE6IEV2ZW50dWFsPFQ+KTogYSBpcyBXb3JrZmxvd0NhbGw8VD4ge1xuICByZXR1cm4gaXNFdmVudHVhbE9mS2luZChFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCBhKTtcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnR1YWx9IHJlcHJlc2VudGluZyBhbiBhd2FpdGVkIGNhbGwgdG8gYSB7QGxpbmsgV29ya2Zsb3d9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFdvcmtmbG93Q2FsbDxUID0gYW55PlxuICBleHRlbmRzIEV2ZW50dWFsQmFzZTxFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCBSZXN1bHQ8VD4+LFxuICAgIENoaWxkRXhlY3V0aW9uIHtcbiAgbmFtZTogc3RyaW5nO1xuICBpbnB1dD86IGFueTtcbiAgc2VxPzogbnVtYmVyO1xuICBvcHRzPzogV29ya2Zsb3dPcHRpb25zO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlV29ya2Zsb3dDYWxsKFxuICBuYW1lOiBzdHJpbmcsXG4gIGlucHV0PzogYW55LFxuICBvcHRzPzogV29ya2Zsb3dPcHRpb25zXG4pOiBXb3JrZmxvd0NhbGwge1xuICBjb25zdCBjYWxsID0gcmVnaXN0ZXJFdmVudHVhbChcbiAgICBjcmVhdGVFdmVudHVhbDxXb3JrZmxvd0NhbGw+KEV2ZW50dWFsS2luZC5Xb3JrZmxvd0NhbGwsIHtcbiAgICAgIGlucHV0LFxuICAgICAgbmFtZSxcbiAgICAgIG9wdHMsXG4gICAgfSBhcyBXb3JrZmxvd0NhbGwpXG4gICk7XG5cbiAgLy8gY3JlYXRlIGEgcmVmZXJlbmNlIHRvIHRoZSBjaGlsZCB3b3JrZmxvdyBzdGFydGVkIGF0IGEgc2VxdWVuY2UgaW4gdGhpcyBleGVjdXRpb24uXG4gIC8vIHRoaXMgcmVmZXJlbmNlIHdpbGwgYmUgcmVzb2x2ZWQgYnkgdGhlIHJ1bnRpbWUuXG4gIGNhbGwuc2VuZFNpZ25hbCA9IGZ1bmN0aW9uIChzaWduYWwsIHBheWxvYWQ/KSB7XG4gICAgY29uc3Qgc2lnbmFsSWQgPSB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkO1xuICAgIHJldHVybiBjcmVhdGVTZW5kU2lnbmFsQ2FsbChcbiAgICAgIHtcbiAgICAgICAgdHlwZTogU2lnbmFsVGFyZ2V0VHlwZS5DaGlsZEV4ZWN1dGlvbixcbiAgICAgICAgc2VxOiBjYWxsLnNlcSEsXG4gICAgICAgIHdvcmtmbG93TmFtZTogY2FsbC5uYW1lLFxuICAgICAgfSxcbiAgICAgIHNpZ25hbElkLFxuICAgICAgcGF5bG9hZFxuICAgICkgYXMgdW5rbm93biBhcyBhbnk7XG4gIH07XG5cbiAgcmV0dXJuIGNhbGw7XG59XG4iXX0=

@@ -30,3 +30,3 @@ /**

* that belongs within the service. An {@link Event} has a unique {@link name},
* may be {@link publish}ed and {@link on}d to.
* may be {@link publishEvents}ed and {@link onEvent}d to.
*/

@@ -44,3 +44,3 @@ export interface Event<E extends EventPayload = EventPayload> {

*/
on(handler: (event: E) => Promise<void>): void;
onEvent(handler: (event: E) => Promise<void>): void;
/**

@@ -51,3 +51,3 @@ * Publish events of this type within the service boundary.

*/
publish(...events: E[]): Promise<void>;
publishEvents(...events: E[]): Promise<void>;
}

@@ -105,3 +105,3 @@ /**

* const checkoutWorkflow = workflow("checkoutWorkflow", async (request) => {
* await checkoutEvent.publish({
* await checkoutEvent.publishEvents({
* customerId: request.customerId,

@@ -118,3 +118,3 @@ * cartId: request.cartId,

* ```ts
* checkoutEvent.on(async (checkout) => {
* checkoutEvent.onEvent(async (checkout) => {
* console.log(checkout);

@@ -121,0 +121,0 @@ * });

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

* const checkoutWorkflow = workflow("checkoutWorkflow", async (request) => {
* await checkoutEvent.publish({
* await checkoutEvent.publishEvents({
* customerId: request.customerId,

@@ -38,3 +38,3 @@ * cartId: request.cartId,

* ```ts
* checkoutEvent.on(async (checkout) => {
* checkoutEvent.onEvent(async (checkout) => {
* console.log(checkout);

@@ -53,3 +53,3 @@ * });

name,
on(handler) {
onEvent(handler) {
(0, global_js_1.eventSubscriptions)().push({

@@ -64,3 +64,3 @@ subscriptions: [

},
publish(...events) {
publishEvents(...events) {
const envelopes = events.map((event) => ({

@@ -82,2 +82,2 @@ name,

exports.event = event;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXNFO0FBQ3RFLDJDQUF5RDtBQUN6RCx5Q0FBb0U7QUFnR3BFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsU0FBZ0IsS0FBSyxDQUF5QixJQUFZO0lBQ3hELElBQUksSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLElBQUksa0JBQWtCLENBQUMsQ0FBQztLQUM3RDtJQUNELE1BQU0sS0FBSyxHQUFhO1FBQ3RCLElBQUk7UUFDSixFQUFFLENBQUMsT0FBTztZQUNSLElBQUEsOEJBQWtCLEdBQUUsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLGFBQWEsRUFBRTtvQkFDYjt3QkFDRSxJQUFJO3FCQUNMO2lCQUNGO2dCQUNELE9BQU8sRUFBRSxPQUFxQzthQUMvQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxDQUFDLEdBQUcsTUFBTTtZQUNmLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3ZDLElBQUk7Z0JBQ0osS0FBSzthQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0osSUFBSSxJQUFBLCtCQUFvQixHQUFFLEVBQUU7Z0JBQzFCLE9BQU8sSUFBQSw2Q0FBdUIsRUFBQyxTQUFTLENBQVEsQ0FBQzthQUNsRDtpQkFBTTtnQkFDTCxPQUFPLElBQUEsMkJBQWdCLEdBQUUsQ0FBQyxhQUFhLENBQUMsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQzthQUNoRTtRQUNILENBQUM7S0FDRixDQUFDO0lBQ0YsSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMxQixPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUE5QkQsc0JBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlUHVibGlzaEV2ZW50c0NhbGwgfSBmcm9tIFwiLi9jYWxscy9zZW5kLWV2ZW50cy1jYWxsLmpzXCI7XG5pbXBvcnQgeyBldmVudHMsIGV2ZW50U3Vic2NyaXB0aW9ucyB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgZ2V0U2VydmljZUNsaWVudCwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9pbmRleC5qc1wiO1xuXG4vKipcbiAqIEFuIEV2ZW50UGF5bG9hZCBpcyB0aGUgZGF0YSBzZW50IGFzIGFuIGV2ZW50LlxuICpcbiAqIEl0IG11c3QgYmUgYW4gb2JqZWN0LiBQcm9wZXJ0aWVzIGNhbiBiZSBhbnkgdHlwZSBzZXJpYWxpemFibGUgYXMgSlNPTi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFBheWxvYWQge1xuICBbcHJvcE5hbWU6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IHR5cGUgRXZlbnRQYXlsb2FkVHlwZTxFIGV4dGVuZHMgRXZlbnQ8YW55Pj4gPSBFIGV4dGVuZHMgRXZlbnQ8XG4gIGluZmVyIFBheWxvYWRcbj5cbiAgPyBQYXlsb2FkXG4gIDogbmV2ZXI7XG5cbi8qKlxuICogQW4gZW52ZWxvcGUgb2JqZWN0IGNvbnRhaW5pbmcgdGhlIHtAbGluayBldmVudH0gcGF5bG9hZCBhc3NvY2lhdGVkXG4gKiB3aXRoIGl0cyB1bmlxdWUge0BsaW5rIG5hbWV9LlxuICpcbiAqIFRoaXMgZW52ZWxvcGUgZGVjb3VwbGVzIHRoZSB7QGxpbmsgbmFtZX0gZnJvIHRoZSBwYXlsb2FkIHNvIHRoYXRcbiAqIHRoZXJlIGFyZSBubyBpbXBvc2l0aW9ucyBvbiB0aGUgc3RydWN0dXJlIG9mIGFuIGV2ZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50RW52ZWxvcGU8RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogVW5pcXVlIG5hbWUgaWRlbnRpZnlpbmcgdGhlIHR5cGUgb2YgdGhlIHtAbGluayBldmVudH0uXG4gICAqL1xuICBuYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50UGF5bG9hZH0uXG4gICAqL1xuICBldmVudDogRTtcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnR9IGlzIGFuIG9iamVjdCByZXByZXNlbnRpbmcgdGhlIGRlY2xhcmF0aW9uIG9mIGFuIGV2ZW50XG4gKiB0aGF0IGJlbG9uZ3Mgd2l0aGluIHRoZSBzZXJ2aWNlLiBBbiB7QGxpbmsgRXZlbnR9IGhhcyBhIHVuaXF1ZSB7QGxpbmsgbmFtZX0sXG4gKiBtYXkgYmUge0BsaW5rIHB1Ymxpc2h9ZWQgYW5kIHtAbGluayBvbn1kIHRvLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFRoZSBFdmVudCdzIGdsb2JhbGx5IHVuaXF1ZSBuYW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3Vic2NyaWJlIHRvIHRoaXMgZXZlbnQuIFRoZSB7QGxpbmsgaGFuZGxlcn0gd2lsbCBiZSBpbnZva2VkIGV2ZXJ5XG4gICAqIHRpbWUgYW4gZXZlbnQgd2l0aCB0aGlzIG5hbWUgaXMgcHVibGlzaGVkIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICpcbiAgICogQHBhcmFtIGhhbmRsZXIgdGhlIGhhbmRsZXIgZnVuY3Rpb24gdGhhdCB3aWxsIHByb2Nlc3MgdGhlIGV2ZW50LlxuICAgKi9cbiAgb24oaGFuZGxlcjogKGV2ZW50OiBFKSA9PiBQcm9taXNlPHZvaWQ+KTogdm9pZDtcbiAgLyoqXG4gICAqIFB1Ymxpc2ggZXZlbnRzIG9mIHRoaXMgdHlwZSB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudHMgYSBsaXN0IG9mIGV2ZW50cyB0byBwdWJsaXNoLlxuICAgKi9cbiAgcHVibGlzaCguLi5ldmVudHM6IEVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU3Vic2NyaXB0aW9ufSBpcyBhbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgaG93IHRvIHNlbGVjdCBldmVudHMgZnJvbVxuICogd2l0aGluIGEgc2VydmljZSBib3VuZGFyeSB0byByb3V0ZSB0byBhIHtAbGluayBFdmVudEhhbmRsZXJ9LlxuICpcbiAqIEZvciBub3csIHdlIG9ubHkgc3VwcG9ydCBtYXRjaGluZyBvbiBhIHNpbmdsZSBuYW1lLCBidXQgdGhpcyBvYmplY3QgY2FuIGJlXG4gKiBleHRlbmRlZCB3aXRoIG90aGVyIHByb3BlcnRpZXMgc3VjaCBhcyBzZWxlY3Rpb24gcHJlZGljYXRlcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb24ge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgZXZlbnQgdG8gc3Vic2NyaWJlIHRvLlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFuIHtAbGluayBFdmVudFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgYXNzb2NpYXRlcyBhIHtAbGluayBoYW5kbGVyfVxuICogZnVuY3Rpb24gd2l0aCBhIGxpc3Qgb2Yge0BsaW5rIHN1YnNjcmlwdGlvbnN9LiBUaGUge0BsaW5rIHN1YnNjcmlwdGlvbnN9XG4gKiBkZWZpbmUgd2hpY2ggZXZlbnRzIHRoaXMge0BsaW5rIGhhbmRsZXJ9IHNob3VsZCBiZSBpbnZva2VkIGZvci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBBIGxpc3Qgb2Yge0BsaW5rIFN1YnNjcmlwdGlvbn1zIHRoYXQgc2hvdWxkIGludm9rZSB0aGlzIHtAbGluayBoYW5kbGVyfS5cbiAgICovXG4gIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudEhhbmRsZXJ9IHRvIGludm9rZSBmb3IgYW55IGV2ZW50IHRoYXQgbWF0Y2hlcyBvbmUgb2ZcbiAgICogdGhlIHtAbGluayBzdWJzY3JpcHRpb25zfS5cbiAgICovXG4gIGhhbmRsZXI6IEV2ZW50SGFuZGxlcjxFPjtcbn1cblxuLyoqXG4gKiBBIEZ1bmN0aW9uIHRoYXQgcHJvY2Vzc2VzIGFuIHtAbGluayBldmVudH0gb2YgdHlwZSB7QGxpbmsgRX0uXG4gKi9cbmV4cG9ydCB0eXBlIEV2ZW50SGFuZGxlcjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPiA9IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPjtcblxuLyoqXG4gKiBEZWNsYXJlcyBhbiBldmVudCB0aGF0IGNhbiBiZSBwdWJsaXNoZWQgYW5kIHN1YnNjcmliZWQgdG8uXG4gKlxuICogVG8gZGVjbGFyZSBhbiB7QGxpbmsgRXZlbnR9LCBkZWZpbmUgYW4gaW50ZXJmYWNlIGRlc2NyaWJpbmcgdGhlIHR5cGVcbiAqIG9mIHRoZSBwYXlsb2FkIGFuZCB0aGVuIGRlY2xhcmUgYW4gZXZlbnQgb2JqZWN0IGdpdmluZyBpdCBhIHVuaXF1ZSBuYW1lLlxuICogYGBgdHNcbiAqIGludGVyZmFjZSBDaGVja291dEV2ZW50IHtcbiAqICAgY3VzdG9tZXJJZDogc3RyaW5nO1xuICogICBjYXJ0SWQ6IHN0cmluZztcbiAqICAgdGltZXN0YW1wOiBzdHJpbmc7XG4gKiB9XG4gKlxuICogY29uc3QgY2hlY2tvdXRFdmVudCA9IGV2ZW50PENoZWNrb3V0RXZlbnQ+KFwiQ2hlY2tvdXRcIik7XG4gKiBgYGBcbiAqXG4gKiBUbyBwdWJsaXNoIGV2ZW50cywgY2FsbCB0aGUgYHB1Ymxpc2hgIG1ldGhvZDpcbiAqIGBgYHRzXG4gKiBjb25zdCBjaGVja291dFdvcmtmbG93ID0gd29ya2Zsb3coXCJjaGVja291dFdvcmtmbG93XCIsIGFzeW5jIChyZXF1ZXN0KSA9PiB7XG4gKiAgIGF3YWl0IGNoZWNrb3V0RXZlbnQucHVibGlzaCh7XG4gKiAgICAgY3VzdG9tZXJJZDogcmVxdWVzdC5jdXN0b21lcklkLFxuICogICAgIGNhcnRJZDogcmVxdWVzdC5jYXJ0SWQsXG4gKiAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvVGltZVN0cmluZygpXG4gKiAgIH0pO1xuICogfSlcbiAqIGBgYFxuICpcbiAqIFRvIHN1YnNjcmliZSB0byBldmVudHMsIGNhbGwgdGhlIGBvbmAgbWV0aG9kLiBUaGlzIHdpbGwgcmVnaXN0ZXIgYVxuICogaGFuZGxlciB0aGF0IHdpbCBsYmUgaW52b2tlZCBmb3IgZXZlcnkgZXZlbnQgb2YgdGhpcyB0eXBlIHRoYXQgaXMgcmVjZWl2ZWQuXG4gKlxuICogYGBgdHNcbiAqIGNoZWNrb3V0RXZlbnQub24oYXN5bmMgKGNoZWNrb3V0KSA9PiB7XG4gKiAgIGNvbnNvbGUubG9nKGNoZWNrb3V0KTtcbiAqIH0pO1xuICogYGBgXG4gKlxuICogQHBhcmFtIG5hbWUgYSB1bmlxdWUgbmFtZSB0aGF0IGlkZW50aWZpZXMgdGhpcyBldmVudCB0eXBlIHdpdGhpbiB0aGUgU2VydmljZS5cbiAqIEByZXR1cm5zIGFuIHtAbGluayBFdmVudH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQ+KG5hbWU6IHN0cmluZyk6IEV2ZW50PEU+IHtcbiAgaWYgKGV2ZW50cygpLmhhcyhuYW1lKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgZXZlbnQgd2l0aCBuYW1lICcke25hbWV9JyBhbHJlYWR5IGV4aXN0c2ApO1xuICB9XG4gIGNvbnN0IGV2ZW50OiBFdmVudDxFPiA9IHtcbiAgICBuYW1lLFxuICAgIG9uKGhhbmRsZXIpIHtcbiAgICAgIGV2ZW50U3Vic2NyaXB0aW9ucygpLnB1c2goe1xuICAgICAgICBzdWJzY3JpcHRpb25zOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZSxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgICBoYW5kbGVyOiBoYW5kbGVyIGFzIEV2ZW50SGFuZGxlcjxFdmVudFBheWxvYWQ+LFxuICAgICAgfSk7XG4gICAgfSxcbiAgICBwdWJsaXNoKC4uLmV2ZW50cykge1xuICAgICAgY29uc3QgZW52ZWxvcGVzID0gZXZlbnRzLm1hcCgoZXZlbnQpID0+ICh7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIGV2ZW50LFxuICAgICAgfSkpO1xuICAgICAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICAgICAgcmV0dXJuIGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsKGVudmVsb3BlcykgYXMgYW55O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGdldFNlcnZpY2VDbGllbnQoKS5wdWJsaXNoRXZlbnRzKHsgZXZlbnRzOiBlbnZlbG9wZXMgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbiAgZXZlbnRzKCkuc2V0KG5hbWUsIGV2ZW50KTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXNFO0FBQ3RFLDJDQUF5RDtBQUN6RCx5Q0FBb0U7QUFnR3BFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsU0FBZ0IsS0FBSyxDQUF5QixJQUFZO0lBQ3hELElBQUksSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLElBQUksa0JBQWtCLENBQUMsQ0FBQztLQUM3RDtJQUNELE1BQU0sS0FBSyxHQUFhO1FBQ3RCLElBQUk7UUFDSixPQUFPLENBQUMsT0FBTztZQUNiLElBQUEsOEJBQWtCLEdBQUUsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLGFBQWEsRUFBRTtvQkFDYjt3QkFDRSxJQUFJO3FCQUNMO2lCQUNGO2dCQUNELE9BQU8sRUFBRSxPQUFxQzthQUMvQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsYUFBYSxDQUFDLEdBQUcsTUFBTTtZQUNyQixNQUFNLFNBQVMsR0FBRyxNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDO2dCQUN2QyxJQUFJO2dCQUNKLEtBQUs7YUFDTixDQUFDLENBQUMsQ0FBQztZQUNKLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO2dCQUMxQixPQUFPLElBQUEsNkNBQXVCLEVBQUMsU0FBUyxDQUFRLENBQUM7YUFDbEQ7aUJBQU07Z0JBQ0wsT0FBTyxJQUFBLDJCQUFnQixHQUFFLENBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxDQUFDLENBQUM7YUFDaEU7UUFDSCxDQUFDO0tBQ0YsQ0FBQztJQUNGLElBQUEsa0JBQU0sR0FBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDMUIsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDO0FBOUJELHNCQThCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vY2FsbHMvc2VuZC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgZXZlbnRzLCBldmVudFN1YnNjcmlwdGlvbnMgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGdldFNlcnZpY2VDbGllbnQsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vaW5kZXguanNcIjtcblxuLyoqXG4gKiBBbiBFdmVudFBheWxvYWQgaXMgdGhlIGRhdGEgc2VudCBhcyBhbiBldmVudC5cbiAqXG4gKiBJdCBtdXN0IGJlIGFuIG9iamVjdC4gUHJvcGVydGllcyBjYW4gYmUgYW55IHR5cGUgc2VyaWFsaXphYmxlIGFzIEpTT04uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRQYXlsb2FkIHtcbiAgW3Byb3BOYW1lOiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIEV2ZW50UGF5bG9hZFR5cGU8RSBleHRlbmRzIEV2ZW50PGFueT4+ID0gRSBleHRlbmRzIEV2ZW50PFxuICBpbmZlciBQYXlsb2FkXG4+XG4gID8gUGF5bG9hZFxuICA6IG5ldmVyO1xuXG4vKipcbiAqIEFuIGVudmVsb3BlIG9iamVjdCBjb250YWluaW5nIHRoZSB7QGxpbmsgZXZlbnR9IHBheWxvYWQgYXNzb2NpYXRlZFxuICogd2l0aCBpdHMgdW5pcXVlIHtAbGluayBuYW1lfS5cbiAqXG4gKiBUaGlzIGVudmVsb3BlIGRlY291cGxlcyB0aGUge0BsaW5rIG5hbWV9IGZybyB0aGUgcGF5bG9hZCBzbyB0aGF0XG4gKiB0aGVyZSBhcmUgbm8gaW1wb3NpdGlvbnMgb24gdGhlIHN0cnVjdHVyZSBvZiBhbiBldmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudEVudmVsb3BlPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFVuaXF1ZSBuYW1lIGlkZW50aWZ5aW5nIHRoZSB0eXBlIG9mIHRoZSB7QGxpbmsgZXZlbnR9LlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudFBheWxvYWR9LlxuICAgKi9cbiAgZXZlbnQ6IEU7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50fSBpcyBhbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBkZWNsYXJhdGlvbiBvZiBhbiBldmVudFxuICogdGhhdCBiZWxvbmdzIHdpdGhpbiB0aGUgc2VydmljZS4gQW4ge0BsaW5rIEV2ZW50fSBoYXMgYSB1bmlxdWUge0BsaW5rIG5hbWV9LFxuICogbWF5IGJlIHtAbGluayBwdWJsaXNoRXZlbnRzfWVkIGFuZCB7QGxpbmsgb25FdmVudH1kIHRvLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFRoZSBFdmVudCdzIGdsb2JhbGx5IHVuaXF1ZSBuYW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3Vic2NyaWJlIHRvIHRoaXMgZXZlbnQuIFRoZSB7QGxpbmsgaGFuZGxlcn0gd2lsbCBiZSBpbnZva2VkIGV2ZXJ5XG4gICAqIHRpbWUgYW4gZXZlbnQgd2l0aCB0aGlzIG5hbWUgaXMgcHVibGlzaGVkIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICpcbiAgICogQHBhcmFtIGhhbmRsZXIgdGhlIGhhbmRsZXIgZnVuY3Rpb24gdGhhdCB3aWxsIHByb2Nlc3MgdGhlIGV2ZW50LlxuICAgKi9cbiAgb25FdmVudChoYW5kbGVyOiAoZXZlbnQ6IEUpID0+IFByb21pc2U8dm9pZD4pOiB2b2lkO1xuICAvKipcbiAgICogUHVibGlzaCBldmVudHMgb2YgdGhpcyB0eXBlIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICpcbiAgICogQHBhcmFtIGV2ZW50cyBhIGxpc3Qgb2YgZXZlbnRzIHRvIHB1Ymxpc2guXG4gICAqL1xuICBwdWJsaXNoRXZlbnRzKC4uLmV2ZW50czogRVtdKTogUHJvbWlzZTx2b2lkPjtcbn1cblxuLyoqXG4gKiBBIHtAbGluayBTdWJzY3JpcHRpb259IGlzIGFuIG9iamVjdCB0aGF0IGRlc2NyaWJlcyBob3cgdG8gc2VsZWN0IGV2ZW50cyBmcm9tXG4gKiB3aXRoaW4gYSBzZXJ2aWNlIGJvdW5kYXJ5IHRvIHJvdXRlIHRvIGEge0BsaW5rIEV2ZW50SGFuZGxlcn0uXG4gKlxuICogRm9yIG5vdywgd2Ugb25seSBzdXBwb3J0IG1hdGNoaW5nIG9uIGEgc2luZ2xlIG5hbWUsIGJ1dCB0aGlzIG9iamVjdCBjYW4gYmVcbiAqIGV4dGVuZGVkIHdpdGggb3RoZXIgcHJvcGVydGllcyBzdWNoIGFzIHNlbGVjdGlvbiBwcmVkaWNhdGVzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIFN1YnNjcmlwdGlvbiB7XG4gIC8qKlxuICAgKiBOYW1lIG9mIHRoZSBldmVudCB0byBzdWJzY3JpYmUgdG8uXG4gICAqL1xuICBuYW1lOiBzdHJpbmc7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50U3Vic2NyaXB0aW9ufSBpcyBhbiBvYmplY3QgdGhhdCBhc3NvY2lhdGVzIGEge0BsaW5rIGhhbmRsZXJ9XG4gKiBmdW5jdGlvbiB3aXRoIGEgbGlzdCBvZiB7QGxpbmsgc3Vic2NyaXB0aW9uc30uIFRoZSB7QGxpbmsgc3Vic2NyaXB0aW9uc31cbiAqIGRlZmluZSB3aGljaCBldmVudHMgdGhpcyB7QGxpbmsgaGFuZGxlcn0gc2hvdWxkIGJlIGludm9rZWQgZm9yLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50U3Vic2NyaXB0aW9uPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIEEgbGlzdCBvZiB7QGxpbmsgU3Vic2NyaXB0aW9ufXMgdGhhdCBzaG91bGQgaW52b2tlIHRoaXMge0BsaW5rIGhhbmRsZXJ9LlxuICAgKi9cbiAgc3Vic2NyaXB0aW9uczogU3Vic2NyaXB0aW9uW107XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50SGFuZGxlcn0gdG8gaW52b2tlIGZvciBhbnkgZXZlbnQgdGhhdCBtYXRjaGVzIG9uZSBvZlxuICAgKiB0aGUge0BsaW5rIHN1YnNjcmlwdGlvbnN9LlxuICAgKi9cbiAgaGFuZGxlcjogRXZlbnRIYW5kbGVyPEU+O1xufVxuXG4vKipcbiAqIEEgRnVuY3Rpb24gdGhhdCBwcm9jZXNzZXMgYW4ge0BsaW5rIGV2ZW50fSBvZiB0eXBlIHtAbGluayBFfS5cbiAqL1xuZXhwb3J0IHR5cGUgRXZlbnRIYW5kbGVyPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQ+ID0gKGV2ZW50OiBFKSA9PiBQcm9taXNlPHZvaWQ+O1xuXG4vKipcbiAqIERlY2xhcmVzIGFuIGV2ZW50IHRoYXQgY2FuIGJlIHB1Ymxpc2hlZCBhbmQgc3Vic2NyaWJlZCB0by5cbiAqXG4gKiBUbyBkZWNsYXJlIGFuIHtAbGluayBFdmVudH0sIGRlZmluZSBhbiBpbnRlcmZhY2UgZGVzY3JpYmluZyB0aGUgdHlwZVxuICogb2YgdGhlIHBheWxvYWQgYW5kIHRoZW4gZGVjbGFyZSBhbiBldmVudCBvYmplY3QgZ2l2aW5nIGl0IGEgdW5pcXVlIG5hbWUuXG4gKiBgYGB0c1xuICogaW50ZXJmYWNlIENoZWNrb3V0RXZlbnQge1xuICogICBjdXN0b21lcklkOiBzdHJpbmc7XG4gKiAgIGNhcnRJZDogc3RyaW5nO1xuICogICB0aW1lc3RhbXA6IHN0cmluZztcbiAqIH1cbiAqXG4gKiBjb25zdCBjaGVja291dEV2ZW50ID0gZXZlbnQ8Q2hlY2tvdXRFdmVudD4oXCJDaGVja291dFwiKTtcbiAqIGBgYFxuICpcbiAqIFRvIHB1Ymxpc2ggZXZlbnRzLCBjYWxsIHRoZSBgcHVibGlzaGAgbWV0aG9kOlxuICogYGBgdHNcbiAqIGNvbnN0IGNoZWNrb3V0V29ya2Zsb3cgPSB3b3JrZmxvdyhcImNoZWNrb3V0V29ya2Zsb3dcIiwgYXN5bmMgKHJlcXVlc3QpID0+IHtcbiAqICAgYXdhaXQgY2hlY2tvdXRFdmVudC5wdWJsaXNoRXZlbnRzKHtcbiAqICAgICBjdXN0b21lcklkOiByZXF1ZXN0LmN1c3RvbWVySWQsXG4gKiAgICAgY2FydElkOiByZXF1ZXN0LmNhcnRJZCxcbiAqICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9UaW1lU3RyaW5nKClcbiAqICAgfSk7XG4gKiB9KVxuICogYGBgXG4gKlxuICogVG8gc3Vic2NyaWJlIHRvIGV2ZW50cywgY2FsbCB0aGUgYG9uYCBtZXRob2QuIFRoaXMgd2lsbCByZWdpc3RlciBhXG4gKiBoYW5kbGVyIHRoYXQgd2lsIGxiZSBpbnZva2VkIGZvciBldmVyeSBldmVudCBvZiB0aGlzIHR5cGUgdGhhdCBpcyByZWNlaXZlZC5cbiAqXG4gKiBgYGB0c1xuICogY2hlY2tvdXRFdmVudC5vbkV2ZW50KGFzeW5jIChjaGVja291dCkgPT4ge1xuICogICBjb25zb2xlLmxvZyhjaGVja291dCk7XG4gKiB9KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBuYW1lIGEgdW5pcXVlIG5hbWUgdGhhdCBpZGVudGlmaWVzIHRoaXMgZXZlbnQgdHlwZSB3aXRoaW4gdGhlIFNlcnZpY2UuXG4gKiBAcmV0dXJucyBhbiB7QGxpbmsgRXZlbnR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPihuYW1lOiBzdHJpbmcpOiBFdmVudDxFPiB7XG4gIGlmIChldmVudHMoKS5oYXMobmFtZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGV2ZW50IHdpdGggbmFtZSAnJHtuYW1lfScgYWxyZWFkeSBleGlzdHNgKTtcbiAgfVxuICBjb25zdCBldmVudDogRXZlbnQ8RT4gPSB7XG4gICAgbmFtZSxcbiAgICBvbkV2ZW50KGhhbmRsZXIpIHtcbiAgICAgIGV2ZW50U3Vic2NyaXB0aW9ucygpLnB1c2goe1xuICAgICAgICBzdWJzY3JpcHRpb25zOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZSxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgICBoYW5kbGVyOiBoYW5kbGVyIGFzIEV2ZW50SGFuZGxlcjxFdmVudFBheWxvYWQ+LFxuICAgICAgfSk7XG4gICAgfSxcbiAgICBwdWJsaXNoRXZlbnRzKC4uLmV2ZW50cykge1xuICAgICAgY29uc3QgZW52ZWxvcGVzID0gZXZlbnRzLm1hcCgoZXZlbnQpID0+ICh7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIGV2ZW50LFxuICAgICAgfSkpO1xuICAgICAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICAgICAgcmV0dXJuIGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsKGVudmVsb3BlcykgYXMgYW55O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGdldFNlcnZpY2VDbGllbnQoKS5wdWJsaXNoRXZlbnRzKHsgZXZlbnRzOiBlbnZlbG9wZXMgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbiAgZXZlbnRzKCkuc2V0KG5hbWUsIGV2ZW50KTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuIl19

@@ -49,3 +49,3 @@ import { ActivityCall } from "./calls/activity-call.js";

/**
* Wait for all {@link activities} to complete or until at least one throws.
* Wait for all {@link activities} to succeed or until at least one throws.
*

@@ -52,0 +52,0 @@ * This is the equivalent behavior to Promise.all.

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

/**
* Wait for all {@link activities} to complete or until at least one throws.
* Wait for all {@link activities} to succeed or until at least one throws.
*

@@ -95,2 +95,2 @@ * This is the equivalent behavior to Promise.all.

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"]}
//# 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 succeed 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"]}
import { EventualServiceClient } from "./service-client.js";
import { Signal, SendSignalProps, SignalPayload } from "./signals.js";
import { Signal, SendSignalProps } from "./signals.js";
import { Workflow, WorkflowOutput } from "./workflow.js";
export declare enum ExecutionStatus {
IN_PROGRESS = "IN_PROGRESS",
COMPLETE = "COMPLETE",
SUCCEEDED = "SUCCEEDED",
FAILED = "FAILED"

@@ -25,8 +25,8 @@ }

}
export type Execution<Result = any> = InProgressExecution | CompleteExecution<Result> | FailedExecution;
export type Execution<Result = any> = InProgressExecution | SucceededExecution<Result> | FailedExecution;
export interface InProgressExecution extends ExecutionBase {
status: ExecutionStatus.IN_PROGRESS;
}
export interface CompleteExecution<Result = any> extends ExecutionBase {
status: ExecutionStatus.COMPLETE;
export interface SucceededExecution<Result = any> extends ExecutionBase {
status: ExecutionStatus.SUCCEEDED;
endTime: string;

@@ -42,7 +42,7 @@ result?: Result;

export declare function isFailedExecution(execution: Execution): execution is FailedExecution;
export declare function isCompleteExecution(execution: Execution): execution is CompleteExecution;
export declare function isSucceededExecution(execution: Execution): execution is SucceededExecution;
/**
* A reference to a running execution.
*/
export declare class ExecutionHandle<W extends Workflow> {
export declare class ExecutionHandle<W extends Workflow> implements ChildExecution {
executionId: string;

@@ -58,3 +58,3 @@ private serviceClient;

*/
signal<Payload = any>(signal: string | Signal<Payload>, payload: Payload): Promise<void>;
sendSignal<Payload = any>(signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
}

@@ -73,3 +73,3 @@ /**

* const child = childWf();
* child.signal(mySignal);
* child.sendSignal(mySignal);
* await child;

@@ -81,5 +81,5 @@ * })

*/
signal<S extends Signal<any>>(signal: S, ...args: SendSignalProps<SignalPayload<S>>): Promise<void>;
sendSignal<Payload = any>(signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
}
export {};
//# sourceMappingURL=execution.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.ExecutionHandle = exports.isCompleteExecution = exports.isFailedExecution = exports.ExecutionStatus = void 0;
exports.ExecutionHandle = exports.isSucceededExecution = exports.isFailedExecution = exports.ExecutionStatus = void 0;
const ulidx_1 = require("ulidx");
var ExecutionStatus;
(function (ExecutionStatus) {
ExecutionStatus["IN_PROGRESS"] = "IN_PROGRESS";
ExecutionStatus["COMPLETE"] = "COMPLETE";
ExecutionStatus["SUCCEEDED"] = "SUCCEEDED";
ExecutionStatus["FAILED"] = "FAILED";

@@ -14,6 +15,6 @@ })(ExecutionStatus = exports.ExecutionStatus || (exports.ExecutionStatus = {}));

exports.isFailedExecution = isFailedExecution;
function isCompleteExecution(execution) {
return execution.status === ExecutionStatus.COMPLETE;
function isSucceededExecution(execution) {
return execution.status === ExecutionStatus.SUCCEEDED;
}
exports.isCompleteExecution = isCompleteExecution;
exports.isSucceededExecution = isSucceededExecution;
/**

@@ -36,3 +37,4 @@ * A reference to a running execution.

*/
async signal(signal, payload) {
async sendSignal(signal, ...args) {
const [payload] = args;
return this.serviceClient.sendSignal({

@@ -42,2 +44,3 @@ execution: this.executionId,

payload,
id: (0, ulidx_1.ulid)(),
});

@@ -47,2 +50,2 @@ }

exports.ExecutionHandle = ExecutionHandle;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFJQSxJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsOENBQTJCLENBQUE7SUFDM0Isd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLGVBQWUsR0FBZix1QkFBZSxLQUFmLHVCQUFlLFFBSTFCO0FBeUNELFNBQWdCLGlCQUFpQixDQUMvQixTQUFvQjtJQUVwQixPQUFPLFNBQVMsQ0FBQyxNQUFNLEtBQUssZUFBZSxDQUFDLE1BQU0sQ0FBQztBQUNyRCxDQUFDO0FBSkQsOENBSUM7QUFFRCxTQUFnQixtQkFBbUIsQ0FDakMsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUM7QUFDdkQsQ0FBQztBQUpELGtEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLGVBQWU7SUFDMUIsWUFDUyxXQUFtQixFQUNsQixhQUFvQztRQURyQyxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUNsQixrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7SUFDM0MsQ0FBQztJQUVKOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQzNDLElBQUksQ0FBQyxXQUFXLENBQ2pCLENBQWlDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLE1BQU0sQ0FDakIsTUFBZ0MsRUFDaEMsT0FBZ0I7UUFFaEIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQztZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDM0IsTUFBTSxFQUFFLE9BQU8sTUFBTSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN2RCxPQUFPO1NBQ1IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBNUJELDBDQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTaWduYWwsIFNlbmRTaWduYWxQcm9wcywgU2lnbmFsUGF5bG9hZCB9IGZyb20gXCIuL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd091dHB1dCB9IGZyb20gXCIuL3dvcmtmbG93LmpzXCI7XG5cbmV4cG9ydCBlbnVtIEV4ZWN1dGlvblN0YXR1cyB7XG4gIElOX1BST0dSRVNTID0gXCJJTl9QUk9HUkVTU1wiLFxuICBDT01QTEVURSA9IFwiQ09NUExFVEVcIixcbiAgRkFJTEVEID0gXCJGQUlMRURcIixcbn1cblxuaW50ZXJmYWNlIEV4ZWN1dGlvbkJhc2Uge1xuICBpZDogc3RyaW5nO1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cztcbiAgc3RhcnRUaW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93TmFtZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50XG4gICkge31cblxuICAvKipcbiAgICogQHJldHVybiB0aGUge0BsaW5rIEV4ZWN1dGlvbn0gd2l0aCB0aGUgc3RhdHVzLCByZXN1bHQsIGVycm9yLCBhbmQgb3RoZXIgZGF0YSBiYXNlZCBvbiB0aGUgY3VycmVudCBzdGF0dXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U3RhdHVzKCk6IFByb21pc2U8RXhlY3V0aW9uPFdvcmtmbG93T3V0cHV0PFc+Pj4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5zZXJ2aWNlQ2xpZW50LmdldEV4ZWN1dGlvbihcbiAgICAgIHRoaXMuZXhlY3V0aW9uSWRcbiAgICApKSBhcyBFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+O1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSB7QGxpbmsgc2lnbmFsfSB0byB0aGlzIGV4ZWN1dGlvbi5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBzaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgcGF5bG9hZDogUGF5bG9hZFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5zZXJ2aWNlQ2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uOiB0aGlzLmV4ZWN1dGlvbklkLFxuICAgICAgc2lnbmFsOiB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkLFxuICAgICAgcGF5bG9hZCxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGFuIGV4ZWN1dGlvbiBzdGFydGVkIGJ5IGFub3RoZXIgd29ya2Zsb3cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2hpbGRFeGVjdXRpb24ge1xuICAvKipcbiAgICogQWxsb3dzIGEge0BsaW5rIHdvcmtmbG93fSB0byBzZW5kIGEgc2lnbmFsIHRvIHRoZSB3b3JrZmxvdyB7QGxpbmsgRXhlY3V0aW9ufS5cbiAgICpcbiAgICogYGBgdHNcbiAgICogY29uc3QgbXlTaWduYWwgPSBzaWduYWw8c3RyaW5nPihcIk15U2lnbmFsXCIpO1xuICAgKiBjb25zdCBjaGlsZFdmID0gd29ya2Zsb3coLi4uKTtcbiAgICogd29ya2Zsb3coXCJ3ZlwiLCBhc3luYyAoKSA9PiB7XG4gICAqICAgIGNvbnN0IGNoaWxkID0gY2hpbGRXZigpO1xuICAgKiAgICBjaGlsZC5zaWduYWwobXlTaWduYWwpO1xuICAgKiAgICBhd2FpdCBjaGlsZDtcbiAgICogfSlcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBpZCBhbiBvcHRpb25hbCwgZXhlY3V0aW9uIHVuaXF1ZSBJRCwgd2lsbCBiZSB1c2VkIHRvIGRlLWR1cGUgdGhlIHNpZ25hbCBhdCB0aGUgdGFyZ2V0IGV4ZWN1dGlvbi5cbiAgICovXG4gIHNpZ25hbDxTIGV4dGVuZHMgU2lnbmFsPGFueT4+KFxuICAgIHNpZ25hbDogUyxcbiAgICAuLi5hcmdzOiBTZW5kU2lnbmFsUHJvcHM8U2lnbmFsUGF5bG9hZDxTPj5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSxpQ0FBNkI7QUFLN0IsSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3pCLDhDQUEyQixDQUFBO0lBQzNCLDBDQUF1QixDQUFBO0lBQ3ZCLG9DQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKVyxlQUFlLEdBQWYsdUJBQWUsS0FBZix1QkFBZSxRQUkxQjtBQXlDRCxTQUFnQixpQkFBaUIsQ0FDL0IsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxNQUFNLENBQUM7QUFDckQsQ0FBQztBQUpELDhDQUlDO0FBRUQsU0FBZ0Isb0JBQW9CLENBQ2xDLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsU0FBUyxDQUFDO0FBQ3hELENBQUM7QUFKRCxvREFJQztBQUVEOztHQUVHO0FBQ0gsTUFBYSxlQUFlO0lBQzFCLFlBQ1MsV0FBbUIsRUFDbEIsYUFBb0M7UUFEckMsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFDbEIsa0JBQWEsR0FBYixhQUFhLENBQXVCO0lBQzNDLENBQUM7SUFFSjs7T0FFRztJQUNJLEtBQUssQ0FBQyxTQUFTO1FBQ3BCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUMzQyxJQUFJLENBQUMsV0FBVyxDQUNqQixDQUFpQyxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxVQUFVLENBQ3JCLE1BQWdDLEVBQ2hDLEdBQUcsSUFBOEI7UUFFakMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxHQUFHLElBQUksQ0FBQztRQUN2QixPQUFPLElBQUksQ0FBQyxhQUFhLENBQUMsVUFBVSxDQUFDO1lBQ25DLFNBQVMsRUFBRSxJQUFJLENBQUMsV0FBVztZQUMzQixNQUFNLEVBQUUsT0FBTyxNQUFNLEtBQUssUUFBUSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxFQUFFO1lBQ3ZELE9BQU87WUFDUCxFQUFFLEVBQUUsSUFBQSxZQUFJLEdBQUU7U0FDWCxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0Y7QUE5QkQsMENBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdWxpZCB9IGZyb20gXCJ1bGlkeFwiO1xuaW1wb3J0IHsgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4vc2VydmljZS1jbGllbnQuanNcIjtcbmltcG9ydCB7IFNpZ25hbCwgU2VuZFNpZ25hbFByb3BzIH0gZnJvbSBcIi4vc2lnbmFscy5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3csIFdvcmtmbG93T3V0cHV0IH0gZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcblxuZXhwb3J0IGVudW0gRXhlY3V0aW9uU3RhdHVzIHtcbiAgSU5fUFJPR1JFU1MgPSBcIklOX1BST0dSRVNTXCIsXG4gIFNVQ0NFRURFRCA9IFwiU1VDQ0VFREVEXCIsXG4gIEZBSUxFRCA9IFwiRkFJTEVEXCIsXG59XG5cbmludGVyZmFjZSBFeGVjdXRpb25CYXNlIHtcbiAgaWQ6IHN0cmluZztcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXM7XG4gIHN0YXJ0VGltZTogc3RyaW5nO1xuICB3b3JrZmxvd05hbWU6IHN0cmluZztcbiAgcGFyZW50Pzoge1xuICAgIC8qKlxuICAgICAqIFNlcSBudW1iZXIgd2hlbiB0aGlzIGV4ZWN1dGlvbiBpcyB0aGUgY2hpbGQgb2YgYW5vdGhlciB3b3JrZmxvdy5cbiAgICAgKi9cbiAgICBzZXE6IG51bWJlcjtcbiAgICAvKipcbiAgICAgKiBJZCBvZiB0aGUgcGFyZW50IHdvcmtmbG93LCB3aGlsZSBwcmVzZW50LlxuICAgICAqL1xuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIH07XG59XG5cbmV4cG9ydCB0eXBlIEV4ZWN1dGlvbjxSZXN1bHQgPSBhbnk+ID1cbiAgfCBJblByb2dyZXNzRXhlY3V0aW9uXG4gIHwgU3VjY2VlZGVkRXhlY3V0aW9uPFJlc3VsdD5cbiAgfCBGYWlsZWRFeGVjdXRpb247XG5cbmV4cG9ydCBpbnRlcmZhY2UgSW5Qcm9ncmVzc0V4ZWN1dGlvbiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5JTl9QUk9HUkVTUztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBTdWNjZWVkZWRFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5TVUNDRUVERUQ7XG4gIGVuZFRpbWU6IHN0cmluZztcbiAgcmVzdWx0PzogUmVzdWx0O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZhaWxlZEV4ZWN1dGlvbiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5GQUlMRUQ7XG4gIGVuZFRpbWU6IHN0cmluZztcbiAgZXJyb3I6IHN0cmluZztcbiAgbWVzc2FnZTogc3RyaW5nO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNGYWlsZWRFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgRmFpbGVkRXhlY3V0aW9uIHtcbiAgcmV0dXJuIGV4ZWN1dGlvbi5zdGF0dXMgPT09IEV4ZWN1dGlvblN0YXR1cy5GQUlMRUQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1N1Y2NlZWRlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBTdWNjZWVkZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLlNVQ0NFRURFRDtcbn1cblxuLyoqXG4gKiBBIHJlZmVyZW5jZSB0byBhIHJ1bm5pbmcgZXhlY3V0aW9uLlxuICovXG5leHBvcnQgY2xhc3MgRXhlY3V0aW9uSGFuZGxlPFcgZXh0ZW5kcyBXb3JrZmxvdz4gaW1wbGVtZW50cyBDaGlsZEV4ZWN1dGlvbiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50XG4gICkge31cblxuICAvKipcbiAgICogQHJldHVybiB0aGUge0BsaW5rIEV4ZWN1dGlvbn0gd2l0aCB0aGUgc3RhdHVzLCByZXN1bHQsIGVycm9yLCBhbmQgb3RoZXIgZGF0YSBiYXNlZCBvbiB0aGUgY3VycmVudCBzdGF0dXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U3RhdHVzKCk6IFByb21pc2U8RXhlY3V0aW9uPFdvcmtmbG93T3V0cHV0PFc+Pj4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5zZXJ2aWNlQ2xpZW50LmdldEV4ZWN1dGlvbihcbiAgICAgIHRoaXMuZXhlY3V0aW9uSWRcbiAgICApKSBhcyBFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+O1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSB7QGxpbmsgc2lnbmFsfSB0byB0aGlzIGV4ZWN1dGlvbi5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBzZW5kU2lnbmFsPFBheWxvYWQgPSBhbnk+KFxuICAgIHNpZ25hbDogc3RyaW5nIHwgU2lnbmFsPFBheWxvYWQ+LFxuICAgIC4uLmFyZ3M6IFNlbmRTaWduYWxQcm9wczxQYXlsb2FkPlxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICBjb25zdCBbcGF5bG9hZF0gPSBhcmdzO1xuICAgIHJldHVybiB0aGlzLnNlcnZpY2VDbGllbnQuc2VuZFNpZ25hbCh7XG4gICAgICBleGVjdXRpb246IHRoaXMuZXhlY3V0aW9uSWQsXG4gICAgICBzaWduYWw6IHR5cGVvZiBzaWduYWwgPT09IFwic3RyaW5nXCIgPyBzaWduYWwgOiBzaWduYWwuaWQsXG4gICAgICBwYXlsb2FkLFxuICAgICAgaWQ6IHVsaWQoKSxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGFuIGV4ZWN1dGlvbiBzdGFydGVkIGJ5IGFub3RoZXIgd29ya2Zsb3cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2hpbGRFeGVjdXRpb24ge1xuICAvKipcbiAgICogQWxsb3dzIGEge0BsaW5rIHdvcmtmbG93fSB0byBzZW5kIGEgc2lnbmFsIHRvIHRoZSB3b3JrZmxvdyB7QGxpbmsgRXhlY3V0aW9ufS5cbiAgICpcbiAgICogYGBgdHNcbiAgICogY29uc3QgbXlTaWduYWwgPSBzaWduYWw8c3RyaW5nPihcIk15U2lnbmFsXCIpO1xuICAgKiBjb25zdCBjaGlsZFdmID0gd29ya2Zsb3coLi4uKTtcbiAgICogd29ya2Zsb3coXCJ3ZlwiLCBhc3luYyAoKSA9PiB7XG4gICAqICAgIGNvbnN0IGNoaWxkID0gY2hpbGRXZigpO1xuICAgKiAgICBjaGlsZC5zZW5kU2lnbmFsKG15U2lnbmFsKTtcbiAgICogICAgYXdhaXQgY2hpbGQ7XG4gICAqIH0pXG4gICAqIGBgYFxuICAgKlxuICAgKiBAcGFyYW0gaWQgYW4gb3B0aW9uYWwsIGV4ZWN1dGlvbiB1bmlxdWUgSUQsIHdpbGwgYmUgdXNlZCB0byBkZS1kdXBlIHRoZSBzaWduYWwgYXQgdGhlIHRhcmdldCBleGVjdXRpb24uXG4gICAqL1xuICBzZW5kU2lnbmFsPFBheWxvYWQgPSBhbnk+KFxuICAgIHNpZ25hbDogc3RyaW5nIHwgU2lnbmFsPFBheWxvYWQ+LFxuICAgIC4uLmFyZ3M6IFNlbmRTaWduYWxQcm9wczxQYXlsb2FkPlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuIl19

@@ -10,5 +10,5 @@ import { SendActivityHeartbeatResponse } from "./service-client.js";

*
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow completed, failed, or the activity timed out).
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow succeeded, failed, or the activity timed out).
*/
export declare function heartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
export declare function sendActivityHeartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
//# sourceMappingURL=heartbeat.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.heartbeat = void 0;
exports.sendActivityHeartbeat = void 0;
const global_js_1 = require("./global.js");

@@ -14,5 +14,5 @@ const flags_js_1 = require("./runtime/flags.js");

*
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow completed, failed, or the activity timed out).
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow succeeded, failed, or the activity timed out).
*/
async function heartbeat(activityToken) {
async function sendActivityHeartbeat(activityToken) {
if ((0, flags_js_1.isOrchestratorWorker)()) {

@@ -36,3 +36,3 @@ throw new Error("Heartbeat is not currently supported from within a workflow. Use an activity with `heartbeat()`.");

}
exports.heartbeat = heartbeat;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBbUU7QUFDbkUsaURBQTRFO0FBRzVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxJQUFBLDRCQUFnQixHQUFFLENBQUMscUJBQXFCLENBQUM7WUFDcEQsYUFBYTtTQUNkLENBQUMsQ0FBQztLQUNKO1NBQU0sSUFBSSxJQUFBLDJCQUFnQixHQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsSUFBQSw4QkFBa0IsR0FBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0sSUFBQSw0QkFBZ0IsR0FBRSxDQUFDLHFCQUFxQixDQUFDO1lBQ3BELGFBQWEsRUFBRSxLQUFLO1NBQ3JCLENBQUMsQ0FBQztLQUNKO1NBQU07UUFDTCxNQUFNLElBQUksS0FBSyxDQUNiLDhEQUE4RCxDQUMvRCxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBckJELDhCQXFCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0U2VydmljZUNsaWVudCB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5pbXBvcnQgeyBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZSB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBjb21wbGV0ZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBoZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8U2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ==
exports.sendActivityHeartbeat = sendActivityHeartbeat;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBbUU7QUFDbkUsaURBQTRFO0FBRzVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxxQkFBcUIsQ0FDekMsYUFBc0I7SUFFdEIsSUFBSSxJQUFBLCtCQUFvQixHQUFFLEVBQUU7UUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FDYixrR0FBa0csQ0FDbkcsQ0FBQztLQUNIO1NBQU0sSUFBSSxhQUFhLEVBQUU7UUFDeEIsT0FBTyxNQUFNLElBQUEsNEJBQWdCLEdBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLElBQUEsMkJBQWdCLEdBQUUsRUFBRTtRQUM3QixNQUFNLEtBQUssR0FBRyxJQUFBLDhCQUFrQixHQUFFLENBQUMsYUFBYSxDQUFDO1FBQ2pELE9BQU8sTUFBTSxJQUFBLDRCQUFnQixHQUFFLENBQUMscUJBQXFCLENBQUM7WUFDcEQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUM7QUFyQkQsc0RBcUJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgZ2V0QWN0aXZpdHlDb250ZXh0LCBnZXRTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBpc0FjdGl2aXR5V29ya2VyLCBpc09yY2hlc3RyYXRvcldvcmtlciB9IGZyb20gXCIuL3J1bnRpbWUvZmxhZ3MuanNcIjtcbmltcG9ydCB7IFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlc3BvbnNlIH0gZnJvbSBcIi4vc2VydmljZS1jbGllbnQuanNcIjtcblxuLyoqXG4gKiBTZW5kcyBhIGhlYXJ0YmVhdCBmb3IgdGhlIGN1cnJlbnQgYWN0aXZpdHkgb3IgdG8gdGhlIHByb3ZpZGVkIGFjdGl2aXR5IHRva2VuLlxuICpcbiAqIElmIGNhbGxlZCBmcm9tIG91dHNpZGUgb2YgYW4ge0BsaW5rIGFjdGl2aXR5fSwgdGhlIGFjdGl2aXR5IHRva2VuIG11c3QgYmUgcHJvdmlkZWQuXG4gKlxuICogSWYgdGhlIGFjdGl2aXR5IGhhcyBhIGhlYXJ0YmVhdFRpbWVvdXQgc2V0IGFuZCB0aGUgd29ya2Zsb3cgaGFzIG5vdCByZWNlaXZlZCBhIGhlYXJ0YmVhdCBpbiBoZWFydGJlYXRUaW1lb3V0U2Vjb25kcyxcbiAqIHRoZSB3b3JrZmxvdyB3aWxsIHRocm93IGEge0BsaW5rIEhlYXJ0YmVhdFRpbWVvdXR9IGFuZCBjYW5jZWwgdGhlIGFjdGl2aXR5LlxuICpcbiAqIEByZXR1cm5zIHtAbGluayBIZWFydGJlYXRSZXNwb25zZX0gd2hpY2ggaGFzIHJlc3BvbnNlLmNhbmNlbGxlZCBpZiB0aGUgYWN0aXZpdHkgd2FzIGNhbmNlbGxlZCBmb3IgYW55IHJlYXNvbiAoZXg6IHdvcmtmbG93IHN1Y2NlZWRlZCwgZmFpbGVkLCBvciB0aGUgYWN0aXZpdHkgdGltZWQgb3V0KS5cbiAqL1xuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNlbmRBY3Rpdml0eUhlYXJ0YmVhdChcbiAgYWN0aXZpdHlUb2tlbj86IHN0cmluZ1xuKTogUHJvbWlzZTxTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZT4ge1xuICBpZiAoaXNPcmNoZXN0cmF0b3JXb3JrZXIoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiSGVhcnRiZWF0IGlzIG5vdCBjdXJyZW50bHkgc3VwcG9ydGVkIGZyb20gd2l0aGluIGEgd29ya2Zsb3cuIFVzZSBhbiBhY3Rpdml0eSB3aXRoIGBoZWFydGJlYXQoKWAuXCJcbiAgICApO1xuICB9IGVsc2UgaWYgKGFjdGl2aXR5VG9rZW4pIHtcbiAgICByZXR1cm4gYXdhaXQgZ2V0U2VydmljZUNsaWVudCgpLnNlbmRBY3Rpdml0eUhlYXJ0YmVhdCh7XG4gICAgICBhY3Rpdml0eVRva2VuLFxuICAgIH0pO1xuICB9IGVsc2UgaWYgKGlzQWN0aXZpdHlXb3JrZXIoKSkge1xuICAgIGNvbnN0IHRva2VuID0gZ2V0QWN0aXZpdHlDb250ZXh0KCkuYWN0aXZpdHlUb2tlbjtcbiAgICByZXR1cm4gYXdhaXQgZ2V0U2VydmljZUNsaWVudCgpLnNlbmRBY3Rpdml0eUhlYXJ0YmVhdCh7XG4gICAgICBhY3Rpdml0eVRva2VuOiB0b2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkFjdGl2aXR5IHRva2VuIG11c3QgYmUgcHJvdmlkZWQgd2hlbiBub3Qgd2l0aGluIGFuIEFjdGl2aXR5LlwiXG4gICAgKTtcbiAgfVxufVxuIl19

@@ -9,4 +9,4 @@ import { EventEnvelope } from "../../event.js";

*/
publish(...event: EventEnvelope[]): Promise<void>;
publishEvents(...event: EventEnvelope[]): Promise<void>;
}
//# sourceMappingURL=event-client.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9ldmVudC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcblxuLyoqXG4gKiBBIENsaWVudCBmb3IgZW1pdHRpbmcgZXZlbnRzIGludG8gdGhlIEV2ZW50dWFsIFNlcnZpY2UncyBldmVudCBidXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRDbGllbnQge1xuICAvKipcbiAgICogRW1pdCBtdWx0aXBsZSBldmVudHMgaW50byB0aGUgRXZlbnR1YWwgU2VydmljZSdzIGV2ZW50IGJ1cy5cbiAgICovXG4gIHB1Ymxpc2goLi4uZXZlbnQ6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9ldmVudC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcblxuLyoqXG4gKiBBIENsaWVudCBmb3IgZW1pdHRpbmcgZXZlbnRzIGludG8gdGhlIEV2ZW50dWFsIFNlcnZpY2UncyBldmVudCBidXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRDbGllbnQge1xuICAvKipcbiAgICogRW1pdCBtdWx0aXBsZSBldmVudHMgaW50byB0aGUgRXZlbnR1YWwgU2VydmljZSdzIGV2ZW50IGJ1cy5cbiAgICovXG4gIHB1Ymxpc2hFdmVudHMoLi4uZXZlbnQ6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG4iXX0=

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

async startExecution(request) {
const executionId = await this.props.workflowClient.startWorkflow(request);
const { executionId } = await this.props.workflowClient.startExecution(request);
return new execution_js_1.ExecutionHandle(executionId, this);

@@ -44,15 +44,15 @@ }

publishEvents(request) {
return this.props.eventClient.publish(...request.events);
return this.props.eventClient.publishEvents(...request.events);
}
sendActivitySuccess(request) {
return this.props.workflowClient.completeActivity(request);
return this.props.workflowClient.sendActivitySuccess(request);
}
sendActivityFailure(request) {
return this.props.workflowClient.failActivity(request);
return this.props.workflowClient.sendActivityFailure(request);
}
sendActivityHeartbeat(request) {
return this.props.workflowClient.heartbeatActivity(request);
return this.props.workflowClient.sendActivityHeartbeat(request);
}
}
exports.RuntimeServiceClient = RuntimeServiceClient;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS1zZXJ2aWNlLWNsaWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3J1bnRpbWUtc2VydmljZS1jbGllbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWVBLHFEQUFnRTtBQUtoRSw2Q0FBa0U7QUFTbEU7Ozs7R0FJRztBQUNILE1BQWEsb0JBQW9CO0lBQy9CLFlBQW9CLEtBQWdDO1FBQWhDLFVBQUssR0FBTCxLQUFLLENBQTJCO0lBQUcsQ0FBQztJQUVqRCxLQUFLLENBQUMsWUFBWTtRQUN2QixPQUFPO1lBQ0wsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBQSxvQkFBUyxHQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUNwRSxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxjQUFjLENBQ3pCLE9BQWlDO1FBRWpDLE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUMvRCxPQUFPLENBQ1IsQ0FBQztRQUNGLE9BQU8sSUFBSSw4QkFBZSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0sS0FBSyxDQUFDLGFBQWEsQ0FDeEIsT0FBNkI7UUFFN0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVNLFlBQVksQ0FDakIsV0FBbUI7UUFFbkIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVNLG1CQUFtQixDQUN4QixPQUErQjtRQUUvQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFTSxLQUFLLENBQUMsMkJBQTJCLENBQ3RDLFdBQW1CO1FBRW5CLE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxVQUFVLENBQzlELFdBQVcsQ0FDWixDQUFDO1FBQ0YsT0FBTztZQUNMLE1BQU07U0FDUCxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBMEI7UUFDaEQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVNLGFBQWEsQ0FBQyxPQUE2QjtRQUNoRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLE9BQU8sQ0FBQyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUMzRCxDQUFDO0lBRU0sbUJBQW1CLENBQ3hCLE9BQXNEO1FBRXRELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsZ0JBQWdCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVNLG1CQUFtQixDQUN4QixPQUFpRDtRQUVqRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN6RCxDQUFDO0lBRU0scUJBQXFCLENBQzFCLE9BQW1EO1FBRW5ELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsaUJBQWlCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUQsQ0FBQztDQUNGO0FBeEVELG9EQXdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFNlbmRBY3Rpdml0eVN1Y2Nlc3NSZXF1ZXN0LFxuICBFdmVudHVhbFNlcnZpY2VDbGllbnQsXG4gIEV4ZWN1dGlvbkV2ZW50c1JlcXVlc3QsXG4gIEV4ZWN1dGlvbkV2ZW50c1Jlc3BvbnNlLFxuICBFeGVjdXRpb25IaXN0b3J5UmVzcG9uc2UsXG4gIFNlbmRBY3Rpdml0eUZhaWx1cmVSZXF1ZXN0LFxuICBHZXRFeGVjdXRpb25zUmVxdWVzdCxcbiAgR2V0RXhlY3V0aW9uc1Jlc3BvbnNlLFxuICBHZXRXb3JrZmxvd1Jlc3BvbnNlLFxuICBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXF1ZXN0LFxuICBQdWJsaXNoRXZlbnRzUmVxdWVzdCxcbiAgU3RhcnRFeGVjdXRpb25SZXF1ZXN0LFxuICBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZSxcbn0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBFeGVjdXRpb24sIEV4ZWN1dGlvbkhhbmRsZSB9IGZyb20gXCIuLi8uLi9leGVjdXRpb24uanNcIjtcbmltcG9ydCB7IFdvcmtmbG93IH0gZnJvbSBcIi4uLy4uL3dvcmtmbG93LmpzXCI7XG5pbXBvcnQgeyBFdmVudENsaWVudCB9IGZyb20gXCIuL2V2ZW50LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgRXhlY3V0aW9uSGlzdG9yeUNsaWVudCB9IGZyb20gXCIuL2V4ZWN1dGlvbi1oaXN0b3J5LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbFJlcXVlc3QsIFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4vd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvd1J1bnRpbWVDbGllbnQsIHdvcmtmbG93cyB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJ1bnRpbWVTZXJ2aWNlQ2xpZW50UHJvcHMge1xuICB3b3JrZmxvd0NsaWVudDogV29ya2Zsb3dDbGllbnQ7XG4gIGV4ZWN1dGlvbkhpc3RvcnlDbGllbnQ6IEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQ7XG4gIGV2ZW50Q2xpZW50OiBFdmVudENsaWVudDtcbiAgd29ya2Zsb3dSdW50aW1lQ2xpZW50OiBXb3JrZmxvd1J1bnRpbWVDbGllbnQ7XG59XG5cbi8qKlxuICogQW4gaW1wbGVtZW50YXRpb24gb2YgdGhlIHtAbGluayBFdmVudHVhbFNlcnZpY2VDbGllbnR9IHVzaW5nIHRoZSBldmVudHVhbCBydW50aW1lIGNsaWVudHMuXG4gKlxuICogSW50ZW5kZWQgdG8gYmUgdXNlZCB3aGVuIHRoZXJlIGlzIGRpcmVjdCBhY2Nlc3MgdG8gdGhlIGV2ZW50dWFsIHNlcnZpY2UgaW50ZXJuYWxzLlxuICovXG5leHBvcnQgY2xhc3MgUnVudGltZVNlcnZpY2VDbGllbnQgaW1wbGVtZW50cyBFdmVudHVhbFNlcnZpY2VDbGllbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHByb3BzOiBSdW50aW1lU2VydmljZUNsaWVudFByb3BzKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRXb3JrZmxvd3MoKTogUHJvbWlzZTxHZXRXb3JrZmxvd1Jlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHdvcmtmbG93czogQXJyYXkuZnJvbSh3b3JrZmxvd3MoKS5rZXlzKCkpLm1hcCgoaykgPT4gKHsgbmFtZTogayB9KSksXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzdGFydEV4ZWN1dGlvbjxXIGV4dGVuZHMgV29ya2Zsb3cgPSBXb3JrZmxvdz4oXG4gICAgcmVxdWVzdDogU3RhcnRFeGVjdXRpb25SZXF1ZXN0PFc+XG4gICk6IFByb21pc2U8RXhlY3V0aW9uSGFuZGxlPFc+PiB7XG4gICAgY29uc3QgZXhlY3V0aW9uSWQgPSBhd2FpdCB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LnN0YXJ0V29ya2Zsb3c8Vz4oXG4gICAgICByZXF1ZXN0XG4gICAgKTtcbiAgICByZXR1cm4gbmV3IEV4ZWN1dGlvbkhhbmRsZShleGVjdXRpb25JZCwgdGhpcyk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0RXhlY3V0aW9ucyhcbiAgICByZXF1ZXN0OiBHZXRFeGVjdXRpb25zUmVxdWVzdFxuICApOiBQcm9taXNlPEdldEV4ZWN1dGlvbnNSZXNwb25zZT4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmdldEV4ZWN1dGlvbnMocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0RXhlY3V0aW9uKFxuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxFeGVjdXRpb248YW55PiB8IHVuZGVmaW5lZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmdldEV4ZWN1dGlvbihleGVjdXRpb25JZCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0RXhlY3V0aW9uSGlzdG9yeShcbiAgICByZXF1ZXN0OiBFeGVjdXRpb25FdmVudHNSZXF1ZXN0XG4gICk6IFByb21pc2U8RXhlY3V0aW9uRXZlbnRzUmVzcG9uc2U+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5leGVjdXRpb25IaXN0b3J5Q2xpZW50LmdldEV2ZW50cyhyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRFeGVjdXRpb25Xb3JrZmxvd0hpc3RvcnkoXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZ1xuICApOiBQcm9taXNlPEV4ZWN1dGlvbkhpc3RvcnlSZXNwb25zZT4ge1xuICAgIGNvbnN0IGV2ZW50cyA9IGF3YWl0IHRoaXMucHJvcHMud29ya2Zsb3dSdW50aW1lQ2xpZW50LmdldEhpc3RvcnkoXG4gICAgICBleGVjdXRpb25JZFxuICAgICk7XG4gICAgcmV0dXJuIHtcbiAgICAgIGV2ZW50cyxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHNlbmRTaWduYWwocmVxdWVzdDogU2VuZFNpZ25hbFJlcXVlc3QpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5zZW5kU2lnbmFsKHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIHB1Ymxpc2hFdmVudHMocmVxdWVzdDogUHVibGlzaEV2ZW50c1JlcXVlc3QpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5ldmVudENsaWVudC5wdWJsaXNoKC4uLnJlcXVlc3QuZXZlbnRzKTtcbiAgfVxuXG4gIHB1YmxpYyBzZW5kQWN0aXZpdHlTdWNjZXNzKFxuICAgIHJlcXVlc3Q6IE9taXQ8U2VuZEFjdGl2aXR5U3VjY2Vzc1JlcXVlc3Q8YW55PiwgXCJ0eXBlXCI+XG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmNvbXBsZXRlQWN0aXZpdHkocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgc2VuZEFjdGl2aXR5RmFpbHVyZShcbiAgICByZXF1ZXN0OiBPbWl0PFNlbmRBY3Rpdml0eUZhaWx1cmVSZXF1ZXN0LCBcInR5cGVcIj5cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuZmFpbEFjdGl2aXR5KHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIHNlbmRBY3Rpdml0eUhlYXJ0YmVhdChcbiAgICByZXF1ZXN0OiBPbWl0PFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlcXVlc3QsIFwidHlwZVwiPlxuICApOiBQcm9taXNlPFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuaGVhcnRiZWF0QWN0aXZpdHkocmVxdWVzdCk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS1zZXJ2aWNlLWNsaWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3J1bnRpbWUtc2VydmljZS1jbGllbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQWVBLHFEQUFnRTtBQUtoRSw2Q0FBa0U7QUFTbEU7Ozs7R0FJRztBQUNILE1BQWEsb0JBQW9CO0lBQy9CLFlBQW9CLEtBQWdDO1FBQWhDLFVBQUssR0FBTCxLQUFLLENBQTJCO0lBQUcsQ0FBQztJQUVqRCxLQUFLLENBQUMsWUFBWTtRQUN2QixPQUFPO1lBQ0wsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsSUFBQSxvQkFBUyxHQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUNwRSxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxjQUFjLENBQ3pCLE9BQWlDO1FBRWpDLE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FDcEUsT0FBTyxDQUNSLENBQUM7UUFDRixPQUFPLElBQUksOEJBQWUsQ0FBQyxXQUFXLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDaEQsQ0FBQztJQUVNLEtBQUssQ0FBQyxhQUFhLENBQ3hCLE9BQTZCO1FBRTdCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzFELENBQUM7SUFFTSxZQUFZLENBQ2pCLFdBQW1CO1FBRW5CLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBQzdELENBQUM7SUFFTSxtQkFBbUIsQ0FDeEIsT0FBK0I7UUFFL0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLHNCQUFzQixDQUFDLFNBQVMsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBRU0sS0FBSyxDQUFDLDJCQUEyQixDQUN0QyxXQUFtQjtRQUVuQixNQUFNLE1BQU0sR0FBRyxNQUFNLElBQUksQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsVUFBVSxDQUM5RCxXQUFXLENBQ1osQ0FBQztRQUNGLE9BQU87WUFDTCxNQUFNO1NBQ1AsQ0FBQztJQUNKLENBQUM7SUFFTSxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQTBCO1FBQ2hELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3ZELENBQUM7SUFFTSxhQUFhLENBQUMsT0FBNkI7UUFDaEQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLFdBQVcsQ0FBQyxhQUFhLENBQUMsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDakUsQ0FBQztJQUVNLG1CQUFtQixDQUN4QixPQUFzRDtRQUV0RCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFTSxtQkFBbUIsQ0FDeEIsT0FBaUQ7UUFFakQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxtQkFBbUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNoRSxDQUFDO0lBRU0scUJBQXFCLENBQzFCLE9BQW1EO1FBRW5ELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMscUJBQXFCLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDbEUsQ0FBQztDQUNGO0FBeEVELG9EQXdFQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFNlbmRBY3Rpdml0eVN1Y2Nlc3NSZXF1ZXN0LFxuICBFdmVudHVhbFNlcnZpY2VDbGllbnQsXG4gIEV4ZWN1dGlvbkV2ZW50c1JlcXVlc3QsXG4gIEV4ZWN1dGlvbkV2ZW50c1Jlc3BvbnNlLFxuICBFeGVjdXRpb25IaXN0b3J5UmVzcG9uc2UsXG4gIFNlbmRBY3Rpdml0eUZhaWx1cmVSZXF1ZXN0LFxuICBHZXRFeGVjdXRpb25zUmVxdWVzdCxcbiAgR2V0RXhlY3V0aW9uc1Jlc3BvbnNlLFxuICBHZXRXb3JrZmxvd1Jlc3BvbnNlLFxuICBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXF1ZXN0LFxuICBQdWJsaXNoRXZlbnRzUmVxdWVzdCxcbiAgU3RhcnRFeGVjdXRpb25SZXF1ZXN0LFxuICBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZSxcbn0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBFeGVjdXRpb24sIEV4ZWN1dGlvbkhhbmRsZSB9IGZyb20gXCIuLi8uLi9leGVjdXRpb24uanNcIjtcbmltcG9ydCB7IFdvcmtmbG93IH0gZnJvbSBcIi4uLy4uL3dvcmtmbG93LmpzXCI7XG5pbXBvcnQgeyBFdmVudENsaWVudCB9IGZyb20gXCIuL2V2ZW50LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgRXhlY3V0aW9uSGlzdG9yeUNsaWVudCB9IGZyb20gXCIuL2V4ZWN1dGlvbi1oaXN0b3J5LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgU2VuZFNpZ25hbFJlcXVlc3QsIFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4vd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvd1J1bnRpbWVDbGllbnQsIHdvcmtmbG93cyB9IGZyb20gXCIuLi8uLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIFJ1bnRpbWVTZXJ2aWNlQ2xpZW50UHJvcHMge1xuICB3b3JrZmxvd0NsaWVudDogV29ya2Zsb3dDbGllbnQ7XG4gIGV4ZWN1dGlvbkhpc3RvcnlDbGllbnQ6IEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQ7XG4gIGV2ZW50Q2xpZW50OiBFdmVudENsaWVudDtcbiAgd29ya2Zsb3dSdW50aW1lQ2xpZW50OiBXb3JrZmxvd1J1bnRpbWVDbGllbnQ7XG59XG5cbi8qKlxuICogQW4gaW1wbGVtZW50YXRpb24gb2YgdGhlIHtAbGluayBFdmVudHVhbFNlcnZpY2VDbGllbnR9IHVzaW5nIHRoZSBldmVudHVhbCBydW50aW1lIGNsaWVudHMuXG4gKlxuICogSW50ZW5kZWQgdG8gYmUgdXNlZCB3aGVuIHRoZXJlIGlzIGRpcmVjdCBhY2Nlc3MgdG8gdGhlIGV2ZW50dWFsIHNlcnZpY2UgaW50ZXJuYWxzLlxuICovXG5leHBvcnQgY2xhc3MgUnVudGltZVNlcnZpY2VDbGllbnQgaW1wbGVtZW50cyBFdmVudHVhbFNlcnZpY2VDbGllbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHByb3BzOiBSdW50aW1lU2VydmljZUNsaWVudFByb3BzKSB7fVxuXG4gIHB1YmxpYyBhc3luYyBnZXRXb3JrZmxvd3MoKTogUHJvbWlzZTxHZXRXb3JrZmxvd1Jlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHtcbiAgICAgIHdvcmtmbG93czogQXJyYXkuZnJvbSh3b3JrZmxvd3MoKS5rZXlzKCkpLm1hcCgoaykgPT4gKHsgbmFtZTogayB9KSksXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzdGFydEV4ZWN1dGlvbjxXIGV4dGVuZHMgV29ya2Zsb3cgPSBXb3JrZmxvdz4oXG4gICAgcmVxdWVzdDogU3RhcnRFeGVjdXRpb25SZXF1ZXN0PFc+XG4gICk6IFByb21pc2U8RXhlY3V0aW9uSGFuZGxlPFc+PiB7XG4gICAgY29uc3QgeyBleGVjdXRpb25JZCB9ID0gYXdhaXQgdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5zdGFydEV4ZWN1dGlvbjxXPihcbiAgICAgIHJlcXVlc3RcbiAgICApO1xuICAgIHJldHVybiBuZXcgRXhlY3V0aW9uSGFuZGxlKGV4ZWN1dGlvbklkLCB0aGlzKTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRFeGVjdXRpb25zKFxuICAgIHJlcXVlc3Q6IEdldEV4ZWN1dGlvbnNSZXF1ZXN0XG4gICk6IFByb21pc2U8R2V0RXhlY3V0aW9uc1Jlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuZ2V0RXhlY3V0aW9ucyhyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBnZXRFeGVjdXRpb24oXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZ1xuICApOiBQcm9taXNlPEV4ZWN1dGlvbjxhbnk+IHwgdW5kZWZpbmVkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuZ2V0RXhlY3V0aW9uKGV4ZWN1dGlvbklkKTtcbiAgfVxuXG4gIHB1YmxpYyBnZXRFeGVjdXRpb25IaXN0b3J5KFxuICAgIHJlcXVlc3Q6IEV4ZWN1dGlvbkV2ZW50c1JlcXVlc3RcbiAgKTogUHJvbWlzZTxFeGVjdXRpb25FdmVudHNSZXNwb25zZT4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLmV4ZWN1dGlvbkhpc3RvcnlDbGllbnQuZ2V0RXZlbnRzKHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldEV4ZWN1dGlvbldvcmtmbG93SGlzdG9yeShcbiAgICBleGVjdXRpb25JZDogc3RyaW5nXG4gICk6IFByb21pc2U8RXhlY3V0aW9uSGlzdG9yeVJlc3BvbnNlPiB7XG4gICAgY29uc3QgZXZlbnRzID0gYXdhaXQgdGhpcy5wcm9wcy53b3JrZmxvd1J1bnRpbWVDbGllbnQuZ2V0SGlzdG9yeShcbiAgICAgIGV4ZWN1dGlvbklkXG4gICAgKTtcbiAgICByZXR1cm4ge1xuICAgICAgZXZlbnRzLFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc2VuZFNpZ25hbChyZXF1ZXN0OiBTZW5kU2lnbmFsUmVxdWVzdCk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LnNlbmRTaWduYWwocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgcHVibGlzaEV2ZW50cyhyZXF1ZXN0OiBQdWJsaXNoRXZlbnRzUmVxdWVzdCk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLmV2ZW50Q2xpZW50LnB1Ymxpc2hFdmVudHMoLi4ucmVxdWVzdC5ldmVudHMpO1xuICB9XG5cbiAgcHVibGljIHNlbmRBY3Rpdml0eVN1Y2Nlc3MoXG4gICAgcmVxdWVzdDogT21pdDxTZW5kQWN0aXZpdHlTdWNjZXNzUmVxdWVzdDxhbnk+LCBcInR5cGVcIj5cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuc2VuZEFjdGl2aXR5U3VjY2VzcyhyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBzZW5kQWN0aXZpdHlGYWlsdXJlKFxuICAgIHJlcXVlc3Q6IE9taXQ8U2VuZEFjdGl2aXR5RmFpbHVyZVJlcXVlc3QsIFwidHlwZVwiPlxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5zZW5kQWN0aXZpdHlGYWlsdXJlKHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIHNlbmRBY3Rpdml0eUhlYXJ0YmVhdChcbiAgICByZXF1ZXN0OiBPbWl0PFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlcXVlc3QsIFwidHlwZVwiPlxuICApOiBQcm9taXNlPFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuc2VuZEFjdGl2aXR5SGVhcnRiZWF0KHJlcXVlc3QpO1xuICB9XG59XG4iXX0=

@@ -6,3 +6,3 @@ import { HistoryStateEvent } from "../../workflow-events.js";

import { ActivityRuntimeClient } from "./activity-runtime-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse } from "../../service-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse, StartExecutionResponse } from "../../service-client.js";
export declare abstract class WorkflowClient {

@@ -18,3 +18,3 @@ private activityRuntimeClient;

*/
abstract startWorkflow<W extends Workflow = Workflow>(request: StartWorkflowRequest<W>): Promise<string>;
abstract startExecution<W extends Workflow = Workflow>(request: StartChildExecutionRequest<W> | StartExecutionRequest<W>): Promise<StartExecutionResponse>;
/**

@@ -37,9 +37,9 @@ * Submit events to be processed by a workflow's orchestrator.

/**
* Completes an async activity causing it to return the given value.
* Succeeds an async activity causing it to return the given value.
*/
completeActivity({ activityToken, result, }: Omit<SendActivitySuccessRequest, "type">): Promise<void>;
sendActivitySuccess({ activityToken, result, }: Omit<SendActivitySuccessRequest, "type">): Promise<void>;
/**
* Fails an async activity causing it to throw the given error.
*/
failActivity({ activityToken, error, message, }: Omit<SendActivityFailureRequest, "type">): Promise<void>;
sendActivityFailure({ activityToken, error, message, }: Omit<SendActivityFailureRequest, "type">): Promise<void>;
/**

@@ -50,3 +50,3 @@ * Submits a "heartbeat" for the given activityToken.

*/
heartbeatActivity(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
sendActivityHeartbeat(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
private sendActivityResult;

@@ -63,15 +63,9 @@ }

}
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId?: string;
export interface StartChildExecutionRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId: string;
/**
* Sequence ID of this execution if this is a child workflow
*/
seq?: number;
seq: number;
}
export interface StartWorkflowResponse {
/**
* ID of the started workflow execution.
*/
executionId: string;
}
//# sourceMappingURL=workflow-client.d.ts.map

@@ -31,7 +31,7 @@ "use strict";

/**
* Completes an async activity causing it to return the given value.
* Succeeds an async activity causing it to return the given value.
*/
async completeActivity({ activityToken, result, }) {
async sendActivitySuccess({ activityToken, result, }) {
await this.sendActivityResult(activityToken, {
type: workflow_events_js_1.WorkflowEventType.ActivityCompleted,
type: workflow_events_js_1.WorkflowEventType.ActivitySucceeded,
result,

@@ -43,3 +43,3 @@ });

*/
async failActivity({ activityToken, error, message, }) {
async sendActivityFailure({ activityToken, error, message, }) {
await this.sendActivityResult(activityToken, {

@@ -56,3 +56,3 @@ type: workflow_events_js_1.WorkflowEventType.ActivityFailed,

*/
async heartbeatActivity(request) {
async sendActivityHeartbeat(request) {
const data = (0, activity_token_js_1.decodeActivityToken)(request.activityToken);

@@ -74,2 +74,2 @@ const execution = await this.getExecution(data.payload.executionId);

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,qDAI4B;AAG5B,4DAA2D;AAY3D,MAAsB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IA+BJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,WAAW,GACf,OAAO,OAAO,CAAC,SAAS,KAAK,QAAQ;YACnC,CAAC,CAAC,OAAO,CAAC,SAAS;YACnB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC;QACpC,MAAM,IAAI,CAAC,kBAAkB,CAC3B,WAAW,EACX,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,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACmC;QACzC,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,GACkC;QACzC,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,OAAmD;QAEnD,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,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAC9B,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,EACT;YACE,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,EACD,IAAI,CAAC,QAAQ,EAAE,CAChB,CACF,CAAC;IACJ,CAAC;CACF;AAjID,wCAiIC","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  Execution,\n  ExecutionHandle,\n  ExecutionStatus,\n} from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\nimport {\n  SendActivitySuccessRequest,\n  SendActivityFailureRequest,\n  GetExecutionsRequest,\n  GetExecutionsResponse,\n  SendActivityHeartbeatRequest,\n  StartExecutionRequest,\n  SendActivityHeartbeatResponse,\n} from \"../../service-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\n    private activityRuntimeClient: ActivityRuntimeClient,\n    protected baseTime: () => Date\n  ) {}\n\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(\n    props: GetExecutionsRequest\n  ): Promise<GetExecutionsResponse>;\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    const executionId =\n      typeof request.execution === \"string\"\n        ? request.execution\n        : request.execution.executionId;\n    await this.submitWorkflowTask(\n      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        this.baseTime(),\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  }: Omit<SendActivitySuccessRequest, \"type\">): 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  }: Omit<SendActivityFailureRequest, \"type\">): 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: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse> {\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      this.baseTime().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        {\n          ...event,\n          seq: data.payload.seq,\n        },\n        this.baseTime()\n      )\n    );\n  }\n}\n\nexport interface SendSignalRequest<Payload = any> {\n  execution: ExecutionHandle<any> | string;\n  signal: string | Signal<Payload>;\n  payload?: Payload;\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 StartExecutionRequest<W>,\n    WorkflowOptions {\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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":";;;AAAA,iEAOkC;AAClC,qDAI4B;AAG5B,4DAA2D;AAa3D,MAAsB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IA+BJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,WAAW,GACf,OAAO,OAAO,CAAC,SAAS,KAAK,QAAQ;YACnC,CAAC,CAAC,OAAO,CAAC,SAAS;YACnB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC;QACpC,MAAM,IAAI,CAAC,kBAAkB,CAC3B,WAAW,EACX,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,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,mBAAmB,CAAC,EAC/B,aAAa,EACb,MAAM,GACmC;QACzC,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,mBAAmB,CAAC,EAC/B,aAAa,EACb,KAAK,EACL,OAAO,GACkC;QACzC,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,qBAAqB,CAChC,OAAmD;QAEnD,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,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAC9B,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,EACT;YACE,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,EACD,IAAI,CAAC,QAAQ,EAAE,CAChB,CACF,CAAC;IACJ,CAAC;CACF;AAjID,wCAiIC","sourcesContent":["import {\n  ActivitySucceeded,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  Execution,\n  ExecutionHandle,\n  ExecutionStatus,\n} from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\nimport {\n  SendActivitySuccessRequest,\n  SendActivityFailureRequest,\n  GetExecutionsRequest,\n  GetExecutionsResponse,\n  SendActivityHeartbeatRequest,\n  StartExecutionRequest,\n  SendActivityHeartbeatResponse,\n  StartExecutionResponse,\n} from \"../../service-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\n    private activityRuntimeClient: ActivityRuntimeClient,\n    protected baseTime: () => Date\n  ) {}\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startExecution<W extends Workflow = Workflow>(\n    request: StartChildExecutionRequest<W> | StartExecutionRequest<W>\n  ): Promise<StartExecutionResponse>;\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(\n    props: GetExecutionsRequest\n  ): Promise<GetExecutionsResponse>;\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    const executionId =\n      typeof request.execution === \"string\"\n        ? request.execution\n        : request.execution.executionId;\n    await this.submitWorkflowTask(\n      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        this.baseTime(),\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Succeeds an async activity causing it to return the given value.\n   */\n  public async sendActivitySuccess({\n    activityToken,\n    result,\n  }: Omit<SendActivitySuccessRequest, \"type\">): Promise<void> {\n    await this.sendActivityResult<ActivitySucceeded>(activityToken, {\n      type: WorkflowEventType.ActivitySucceeded,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async sendActivityFailure({\n    activityToken,\n    error,\n    message,\n  }: Omit<SendActivityFailureRequest, \"type\">): 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 sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse> {\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      this.baseTime().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivitySucceeded | 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<ActivitySucceeded | ActivityFailed>(\n        {\n          ...event,\n          seq: data.payload.seq,\n        },\n        this.baseTime()\n      )\n    );\n  }\n}\n\nexport interface SendSignalRequest<Payload = any> {\n  execution: ExecutionHandle<any> | string;\n  signal: string | Signal<Payload>;\n  payload?: Payload;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id?: string;\n}\n\nexport interface StartChildExecutionRequest<W extends Workflow = Workflow>\n  extends StartExecutionRequest<W>,\n    WorkflowOptions {\n  parentExecutionId: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq: number;\n}\n"]}
import { HistoryStateEvent } from "../../workflow-events.js";
import { CompleteExecution, FailedExecution } from "../../execution.js";
import { SucceededExecution, FailedExecution } from "../../execution.js";
import { ActivityWorkerRequest } from "../handlers/activity-worker.js";
import { WorkflowClient } from "./workflow-client.js";
export interface CompleteExecutionRequest {
export interface SucceedExecutionRequest {
executionId: string;

@@ -14,3 +14,3 @@ result?: any;

}
export declare function isFailedExecutionRequest(executionRequest: CompleteExecutionRequest | FailExecutionRequest): executionRequest is FailExecutionRequest;
export declare function isFailedExecutionRequest(executionRequest: SucceedExecutionRequest | FailExecutionRequest): executionRequest is FailExecutionRequest;
export interface UpdateHistoryRequest {

@@ -28,7 +28,7 @@ executionId: string;

abstract startActivity(request: ActivityWorkerRequest): Promise<void>;
completeExecution(request: CompleteExecutionRequest): Promise<CompleteExecution>;
succeedExecution(request: SucceedExecutionRequest): Promise<SucceededExecution>;
failExecution(request: FailExecutionRequest): Promise<FailedExecution>;
protected abstract updateExecution(request: FailExecutionRequest | CompleteExecutionRequest): Promise<CompleteExecution | FailedExecution>;
protected abstract updateExecution(request: FailExecutionRequest | SucceedExecutionRequest): Promise<SucceededExecution | FailedExecution>;
private reportCompletionToParent;
}
//# sourceMappingURL=workflow-runtime-client.d.ts.map

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

}
async completeExecution(request) {
async succeedExecution(request) {
const execution = await this.updateExecution(request);

@@ -35,3 +35,3 @@ console.log("execution", execution);

? {
type: workflow_events_js_1.WorkflowEventType.ChildWorkflowCompleted,
type: workflow_events_js_1.WorkflowEventType.ChildWorkflowSucceeded,
result: args[0],

@@ -48,2 +48,2 @@ }

exports.WorkflowRuntimeClient = WorkflowRuntimeClient;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctcnVudGltZS1jbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3dvcmtmbG93LXJ1bnRpbWUtY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlFQUFnRjtBQWdCaEYsU0FBZ0Isd0JBQXdCLENBQ3RDLGdCQUFpRTtJQUVqRSxPQUFPLE9BQU8sSUFBSSxnQkFBZ0IsQ0FBQztBQUNyQyxDQUFDO0FBSkQsNERBSUM7QUFPRCxNQUFzQixxQkFBcUI7SUFDekMsWUFBb0IsY0FBOEI7UUFBOUIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO0lBQUcsQ0FBQztJQVUvQyxLQUFLLENBQUMsaUJBQWlCLENBQzVCLE9BQWlDO1FBRWpDLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0RCxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLFNBQVMsQ0FBQyxNQUFNLEVBQUU7WUFDcEIsTUFBTSxJQUFJLENBQUMsd0JBQXdCLENBQ2pDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUM1QixTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFDcEIsT0FBTyxDQUFDLE1BQU0sQ0FDZixDQUFDO1NBQ0g7UUFFRCxPQUFPLFNBQThCLENBQUM7SUFDeEMsQ0FBQztJQUVNLEtBQUssQ0FBQyxhQUFhLENBQ3hCLE9BQTZCO1FBRTdCLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0RCxJQUFJLFNBQVMsQ0FBQyxNQUFNLEVBQUU7WUFDcEIsTUFBTSxJQUFJLENBQUMsd0JBQXdCLENBQ2pDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUM1QixTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFDcEIsT0FBTyxDQUFDLEtBQUssRUFDYixPQUFPLENBQUMsT0FBTyxDQUNoQixDQUFDO1NBQ0g7UUFFRCxPQUFPLFNBQTRCLENBQUM7SUFDdEMsQ0FBQztJQU1PLEtBQUssQ0FBQyx3QkFBd0IsQ0FDcEMsaUJBQXlCLEVBQ3pCLEdBQVcsRUFDWCxHQUFHLElBQXNEO1FBRXpELE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsRUFBRTtZQUM5RCxHQUFHO1lBQ0gsU0FBUyxFQUFFLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFO1lBQ25DLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUM7Z0JBQ25CLENBQUMsQ0FBQztvQkFDRSxJQUFJLEVBQUUsc0NBQWlCLENBQUMsc0JBQXNCO29CQUM5QyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDaEI7Z0JBQ0gsQ0FBQyxDQUFDO29CQUNFLElBQUksRUFBRSxzQ0FBaUIsQ0FBQyxtQkFBbUI7b0JBQzNDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO29CQUNkLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO2lCQUNqQixDQUFDO1NBQ1AsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBbkVELHNEQW1FQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhpc3RvcnlTdGF0ZUV2ZW50LCBXb3JrZmxvd0V2ZW50VHlwZSB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcbmltcG9ydCB7IENvbXBsZXRlRXhlY3V0aW9uLCBGYWlsZWRFeGVjdXRpb24gfSBmcm9tIFwiLi4vLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyBBY3Rpdml0eVdvcmtlclJlcXVlc3QgfSBmcm9tIFwiLi4vaGFuZGxlcnMvYWN0aXZpdHktd29ya2VyLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbXBsZXRlRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIHJlc3VsdD86IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGVycm9yOiBzdHJpbmc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkRXhlY3V0aW9uUmVxdWVzdChcbiAgZXhlY3V0aW9uUmVxdWVzdDogQ29tcGxldGVFeGVjdXRpb25SZXF1ZXN0IHwgRmFpbEV4ZWN1dGlvblJlcXVlc3Rcbik6IGV4ZWN1dGlvblJlcXVlc3QgaXMgRmFpbEV4ZWN1dGlvblJlcXVlc3Qge1xuICByZXR1cm4gXCJlcnJvclwiIGluIGV4ZWN1dGlvblJlcXVlc3Q7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlSGlzdG9yeVJlcXVlc3Qge1xuICBleGVjdXRpb25JZDogc3RyaW5nO1xuICBldmVudHM6IEhpc3RvcnlTdGF0ZUV2ZW50W107XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBXb3JrZmxvd1J1bnRpbWVDbGllbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHdvcmtmbG93Q2xpZW50OiBXb3JrZmxvd0NsaWVudCkge31cbiAgcHVibGljIGFic3RyYWN0IGdldEhpc3RvcnkoZXhlY3V0aW9uSWQ6IHN0cmluZyk6IFByb21pc2U8SGlzdG9yeVN0YXRlRXZlbnRbXT47XG5cbiAgLy8gVE9ETzogZXRhZ1xuICBwdWJsaWMgYWJzdHJhY3QgdXBkYXRlSGlzdG9yeShcbiAgICByZXF1ZXN0OiBVcGRhdGVIaXN0b3J5UmVxdWVzdFxuICApOiBQcm9taXNlPHsgYnl0ZXM6IG51bWJlciB9PjtcblxuICBwdWJsaWMgYWJzdHJhY3Qgc3RhcnRBY3Rpdml0eShyZXF1ZXN0OiBBY3Rpdml0eVdvcmtlclJlcXVlc3QpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIHB1YmxpYyBhc3luYyBjb21wbGV0ZUV4ZWN1dGlvbihcbiAgICByZXF1ZXN0OiBDb21wbGV0ZUV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxDb21wbGV0ZUV4ZWN1dGlvbj4ge1xuICAgIGNvbnN0IGV4ZWN1dGlvbiA9IGF3YWl0IHRoaXMudXBkYXRlRXhlY3V0aW9uKHJlcXVlc3QpO1xuICAgIGNvbnNvbGUubG9nKFwiZXhlY3V0aW9uXCIsIGV4ZWN1dGlvbik7XG4gICAgaWYgKGV4ZWN1dGlvbi5wYXJlbnQpIHtcbiAgICAgIGF3YWl0IHRoaXMucmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LmV4ZWN1dGlvbklkLFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LnNlcSxcbiAgICAgICAgcmVxdWVzdC5yZXN1bHRcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGV4ZWN1dGlvbiBhcyBDb21wbGV0ZUV4ZWN1dGlvbjtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBmYWlsRXhlY3V0aW9uKFxuICAgIHJlcXVlc3Q6IEZhaWxFeGVjdXRpb25SZXF1ZXN0XG4gICk6IFByb21pc2U8RmFpbGVkRXhlY3V0aW9uPiB7XG4gICAgY29uc3QgZXhlY3V0aW9uID0gYXdhaXQgdGhpcy51cGRhdGVFeGVjdXRpb24ocmVxdWVzdCk7XG4gICAgaWYgKGV4ZWN1dGlvbi5wYXJlbnQpIHtcbiAgICAgIGF3YWl0IHRoaXMucmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LmV4ZWN1dGlvbklkLFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LnNlcSxcbiAgICAgICAgcmVxdWVzdC5lcnJvcixcbiAgICAgICAgcmVxdWVzdC5tZXNzYWdlXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBleGVjdXRpb24gYXMgRmFpbGVkRXhlY3V0aW9uO1xuICB9XG5cbiAgcHJvdGVjdGVkIGFic3RyYWN0IHVwZGF0ZUV4ZWN1dGlvbihcbiAgICByZXF1ZXN0OiBGYWlsRXhlY3V0aW9uUmVxdWVzdCB8IENvbXBsZXRlRXhlY3V0aW9uUmVxdWVzdFxuICApOiBQcm9taXNlPENvbXBsZXRlRXhlY3V0aW9uIHwgRmFpbGVkRXhlY3V0aW9uPjtcblxuICBwcml2YXRlIGFzeW5jIHJlcG9ydENvbXBsZXRpb25Ub1BhcmVudChcbiAgICBwYXJlbnRFeGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHNlcTogbnVtYmVyLFxuICAgIC4uLmFyZ3M6IFtyZXN1bHQ6IGFueV0gfCBbZXJyb3I6IHN0cmluZywgbWVzc2FnZTogc3RyaW5nXVxuICApIHtcbiAgICBhd2FpdCB0aGlzLndvcmtmbG93Q2xpZW50LnN1Ym1pdFdvcmtmbG93VGFzayhwYXJlbnRFeGVjdXRpb25JZCwge1xuICAgICAgc2VxLFxuICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAuLi4oYXJncy5sZW5ndGggPT09IDFcbiAgICAgICAgPyB7XG4gICAgICAgICAgICB0eXBlOiBXb3JrZmxvd0V2ZW50VHlwZS5DaGlsZFdvcmtmbG93Q29tcGxldGVkLFxuICAgICAgICAgICAgcmVzdWx0OiBhcmdzWzBdLFxuICAgICAgICAgIH1cbiAgICAgICAgOiB7XG4gICAgICAgICAgICB0eXBlOiBXb3JrZmxvd0V2ZW50VHlwZS5DaGlsZFdvcmtmbG93RmFpbGVkLFxuICAgICAgICAgICAgZXJyb3I6IGFyZ3NbMF0sXG4gICAgICAgICAgICBtZXNzYWdlOiBhcmdzWzFdLFxuICAgICAgICAgIH0pLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctcnVudGltZS1jbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3dvcmtmbG93LXJ1bnRpbWUtY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBLGlFQUFnRjtBQWdCaEYsU0FBZ0Isd0JBQXdCLENBQ3RDLGdCQUFnRTtJQUVoRSxPQUFPLE9BQU8sSUFBSSxnQkFBZ0IsQ0FBQztBQUNyQyxDQUFDO0FBSkQsNERBSUM7QUFPRCxNQUFzQixxQkFBcUI7SUFDekMsWUFBb0IsY0FBOEI7UUFBOUIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO0lBQUcsQ0FBQztJQVUvQyxLQUFLLENBQUMsZ0JBQWdCLENBQzNCLE9BQWdDO1FBRWhDLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0RCxPQUFPLENBQUMsR0FBRyxDQUFDLFdBQVcsRUFBRSxTQUFTLENBQUMsQ0FBQztRQUNwQyxJQUFJLFNBQVMsQ0FBQyxNQUFNLEVBQUU7WUFDcEIsTUFBTSxJQUFJLENBQUMsd0JBQXdCLENBQ2pDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUM1QixTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFDcEIsT0FBTyxDQUFDLE1BQU0sQ0FDZixDQUFDO1NBQ0g7UUFFRCxPQUFPLFNBQStCLENBQUM7SUFDekMsQ0FBQztJQUVNLEtBQUssQ0FBQyxhQUFhLENBQ3hCLE9BQTZCO1FBRTdCLE1BQU0sU0FBUyxHQUFHLE1BQU0sSUFBSSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztRQUN0RCxJQUFJLFNBQVMsQ0FBQyxNQUFNLEVBQUU7WUFDcEIsTUFBTSxJQUFJLENBQUMsd0JBQXdCLENBQ2pDLFNBQVMsQ0FBQyxNQUFNLENBQUMsV0FBVyxFQUM1QixTQUFTLENBQUMsTUFBTSxDQUFDLEdBQUcsRUFDcEIsT0FBTyxDQUFDLEtBQUssRUFDYixPQUFPLENBQUMsT0FBTyxDQUNoQixDQUFDO1NBQ0g7UUFFRCxPQUFPLFNBQTRCLENBQUM7SUFDdEMsQ0FBQztJQU1PLEtBQUssQ0FBQyx3QkFBd0IsQ0FDcEMsaUJBQXlCLEVBQ3pCLEdBQVcsRUFDWCxHQUFHLElBQXNEO1FBRXpELE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxrQkFBa0IsQ0FBQyxpQkFBaUIsRUFBRTtZQUM5RCxHQUFHO1lBQ0gsU0FBUyxFQUFFLElBQUksSUFBSSxFQUFFLENBQUMsV0FBVyxFQUFFO1lBQ25DLEdBQUcsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUM7Z0JBQ25CLENBQUMsQ0FBQztvQkFDRSxJQUFJLEVBQUUsc0NBQWlCLENBQUMsc0JBQXNCO29CQUM5QyxNQUFNLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDaEI7Z0JBQ0gsQ0FBQyxDQUFDO29CQUNFLElBQUksRUFBRSxzQ0FBaUIsQ0FBQyxtQkFBbUI7b0JBQzNDLEtBQUssRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO29CQUNkLE9BQU8sRUFBRSxJQUFJLENBQUMsQ0FBQyxDQUFDO2lCQUNqQixDQUFDO1NBQ1AsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBbkVELHNEQW1FQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhpc3RvcnlTdGF0ZUV2ZW50LCBXb3JrZmxvd0V2ZW50VHlwZSB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcbmltcG9ydCB7IFN1Y2NlZWRlZEV4ZWN1dGlvbiwgRmFpbGVkRXhlY3V0aW9uIH0gZnJvbSBcIi4uLy4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgQWN0aXZpdHlXb3JrZXJSZXF1ZXN0IH0gZnJvbSBcIi4uL2hhbmRsZXJzL2FjdGl2aXR5LXdvcmtlci5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi93b3JrZmxvdy1jbGllbnQuanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTdWNjZWVkRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIHJlc3VsdD86IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGVycm9yOiBzdHJpbmc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkRXhlY3V0aW9uUmVxdWVzdChcbiAgZXhlY3V0aW9uUmVxdWVzdDogU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3QgfCBGYWlsRXhlY3V0aW9uUmVxdWVzdFxuKTogZXhlY3V0aW9uUmVxdWVzdCBpcyBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIHJldHVybiBcImVycm9yXCIgaW4gZXhlY3V0aW9uUmVxdWVzdDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVcGRhdGVIaXN0b3J5UmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGV2ZW50czogSGlzdG9yeVN0YXRlRXZlbnRbXTtcbn1cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFdvcmtmbG93UnVudGltZUNsaWVudCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgd29ya2Zsb3dDbGllbnQ6IFdvcmtmbG93Q2xpZW50KSB7fVxuICBwdWJsaWMgYWJzdHJhY3QgZ2V0SGlzdG9yeShleGVjdXRpb25JZDogc3RyaW5nKTogUHJvbWlzZTxIaXN0b3J5U3RhdGVFdmVudFtdPjtcblxuICAvLyBUT0RPOiBldGFnXG4gIHB1YmxpYyBhYnN0cmFjdCB1cGRhdGVIaXN0b3J5KFxuICAgIHJlcXVlc3Q6IFVwZGF0ZUhpc3RvcnlSZXF1ZXN0XG4gICk6IFByb21pc2U8eyBieXRlczogbnVtYmVyIH0+O1xuXG4gIHB1YmxpYyBhYnN0cmFjdCBzdGFydEFjdGl2aXR5KHJlcXVlc3Q6IEFjdGl2aXR5V29ya2VyUmVxdWVzdCk6IFByb21pc2U8dm9pZD47XG5cbiAgcHVibGljIGFzeW5jIHN1Y2NlZWRFeGVjdXRpb24oXG4gICAgcmVxdWVzdDogU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxTdWNjZWVkZWRFeGVjdXRpb24+IHtcbiAgICBjb25zdCBleGVjdXRpb24gPSBhd2FpdCB0aGlzLnVwZGF0ZUV4ZWN1dGlvbihyZXF1ZXN0KTtcbiAgICBjb25zb2xlLmxvZyhcImV4ZWN1dGlvblwiLCBleGVjdXRpb24pO1xuICAgIGlmIChleGVjdXRpb24ucGFyZW50KSB7XG4gICAgICBhd2FpdCB0aGlzLnJlcG9ydENvbXBsZXRpb25Ub1BhcmVudChcbiAgICAgICAgZXhlY3V0aW9uLnBhcmVudC5leGVjdXRpb25JZCxcbiAgICAgICAgZXhlY3V0aW9uLnBhcmVudC5zZXEsXG4gICAgICAgIHJlcXVlc3QucmVzdWx0XG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBleGVjdXRpb24gYXMgU3VjY2VlZGVkRXhlY3V0aW9uO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGZhaWxFeGVjdXRpb24oXG4gICAgcmVxdWVzdDogRmFpbEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxGYWlsZWRFeGVjdXRpb24+IHtcbiAgICBjb25zdCBleGVjdXRpb24gPSBhd2FpdCB0aGlzLnVwZGF0ZUV4ZWN1dGlvbihyZXF1ZXN0KTtcbiAgICBpZiAoZXhlY3V0aW9uLnBhcmVudCkge1xuICAgICAgYXdhaXQgdGhpcy5yZXBvcnRDb21wbGV0aW9uVG9QYXJlbnQoXG4gICAgICAgIGV4ZWN1dGlvbi5wYXJlbnQuZXhlY3V0aW9uSWQsXG4gICAgICAgIGV4ZWN1dGlvbi5wYXJlbnQuc2VxLFxuICAgICAgICByZXF1ZXN0LmVycm9yLFxuICAgICAgICByZXF1ZXN0Lm1lc3NhZ2VcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGV4ZWN1dGlvbiBhcyBGYWlsZWRFeGVjdXRpb247XG4gIH1cblxuICBwcm90ZWN0ZWQgYWJzdHJhY3QgdXBkYXRlRXhlY3V0aW9uKFxuICAgIHJlcXVlc3Q6IEZhaWxFeGVjdXRpb25SZXF1ZXN0IHwgU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxTdWNjZWVkZWRFeGVjdXRpb24gfCBGYWlsZWRFeGVjdXRpb24+O1xuXG4gIHByaXZhdGUgYXN5bmMgcmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgIHBhcmVudEV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gICAgc2VxOiBudW1iZXIsXG4gICAgLi4uYXJnczogW3Jlc3VsdDogYW55XSB8IFtlcnJvcjogc3RyaW5nLCBtZXNzYWdlOiBzdHJpbmddXG4gICkge1xuICAgIGF3YWl0IHRoaXMud29ya2Zsb3dDbGllbnQuc3VibWl0V29ya2Zsb3dUYXNrKHBhcmVudEV4ZWN1dGlvbklkLCB7XG4gICAgICBzZXEsXG4gICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgIC4uLihhcmdzLmxlbmd0aCA9PT0gMVxuICAgICAgICA/IHtcbiAgICAgICAgICAgIHR5cGU6IFdvcmtmbG93RXZlbnRUeXBlLkNoaWxkV29ya2Zsb3dTdWNjZWVkZWQsXG4gICAgICAgICAgICByZXN1bHQ6IGFyZ3NbMF0sXG4gICAgICAgICAgfVxuICAgICAgICA6IHtcbiAgICAgICAgICAgIHR5cGU6IFdvcmtmbG93RXZlbnRUeXBlLkNoaWxkV29ya2Zsb3dGYWlsZWQsXG4gICAgICAgICAgICBlcnJvcjogYXJnc1swXSxcbiAgICAgICAgICAgIG1lc3NhZ2U6IGFyZ3NbMV0sXG4gICAgICAgICAgfSksXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

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

async scheduleChildWorkflow(executionId, command, baseTime) {
await this.props.workflowClient.startWorkflow({
await this.props.workflowClient.startExecution({
workflow: command.name,

@@ -162,3 +162,3 @@ input: command.input,

async publishEvents(command, baseTime) {
await this.props.eventClient.publish(...command.events);
await this.props.eventClient.publishEvents(...command.events);
return (0, workflow_events_js_1.createEvent)({

@@ -172,2 +172,2 @@ type: workflow_events_js_1.WorkflowEventType.EventsPublished,

exports.CommandExecutor = CommandExecutor;
//# 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, baseTime);\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, baseTime);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command, baseTime);\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      {\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startWorkflow({\n      workflow: 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      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      },\n      baseTime\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      {\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    command: SendSignalCommand,\n    baseTime: Date\n  ) {\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      execution: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n\n  private async publishEvents(command: PublishEventsCommand, baseTime: Date) {\n    await this.props.eventClient.publish(...command.events);\n    return createEvent<EventsPublished>(\n      {\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      },\n      baseTime\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, baseTime);\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, baseTime);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command, baseTime);\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      {\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: 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      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      },\n      baseTime\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      {\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    command: SendSignalCommand,\n    baseTime: Date\n  ) {\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      execution: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n\n  private async publishEvents(command: PublishEventsCommand, baseTime: Date) {\n    await this.props.eventClient.publishEvents(...command.events);\n    return createEvent<EventsPublished>(\n      {\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n}\n"]}

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

* The activity has declared that it is async, other than logging, there is nothing left to do here.
* The activity should call {@link WorkflowClient.completeActivity} or {@link WorkflowClient.failActivity} when it is done.
* The activity should call {@link WorkflowClient.sendActivitySuccess} or {@link WorkflowClient.sendActivityFailure} when it is done.
*/

@@ -94,3 +94,3 @@ return;

const event = (0, workflow_events_js_1.createEvent)({
type: workflow_events_js_1.WorkflowEventType.ActivityCompleted,
type: workflow_events_js_1.WorkflowEventType.ActivitySucceeded,
seq: request.command.seq,

@@ -120,3 +120,3 @@ result,

metrics.putMetric(constants_js_1.ActivityMetrics.ActivityFailed, failed ? 1 : 0, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.ActivityMetrics.ActivityCompleted, failed ? 0 : 1, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.ActivityMetrics.ActivitySucceeded, failed ? 0 : 1, unit_js_1.Unit.Count);
// The total time from the activity being scheduled until it's result is send to the workflow.

@@ -132,2 +132,2 @@ metrics.putMetric(constants_js_1.ActivityMetrics.TotalDuration, duration);

exports.createActivityWorker = createActivityWorker;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-worker.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/activity-worker.ts"],"names":[],"mappings":"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","sourcesContent":["import { isAsyncResult } from \"../../activity.js\";\nimport { ScheduleActivityCommand } from \"../../command.js\";\nimport {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  isWorkflowFailed,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  clearActivityContext,\n  registerServiceClient,\n  setActivityContext,\n} from \"../../global.js\";\nimport { createActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"../clients/activity-runtime-client.js\";\nimport { MetricsClient } from \"../clients/metrics-client.js\";\nimport { WorkflowClient } from \"../clients/workflow-client.js\";\nimport {\n  RuntimeServiceClient,\n  Schedule,\n  TimerClient,\n  TimerRequestType,\n} from \"../index.js\";\nimport { Logger } from \"../logger.js\";\nimport { ActivityMetrics, MetricsCommon } from \"../metrics/constants.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed } from \"../metrics/utils.js\";\nimport type { EventClient } from \"../index.js\";\nimport { ActivityProvider } from \"../providers/activity-provider.js\";\nimport { ActivityNotFoundError } from \"../../error.js\";\nimport { extendsError } from \"../../util.js\";\n\nexport interface CreateActivityWorkerProps {\n  activityRuntimeClient: ActivityRuntimeClient;\n  workflowClient: WorkflowClient;\n  timerClient: TimerClient;\n  metricsClient: MetricsClient;\n  logger: Logger;\n  eventClient: EventClient;\n  activityProvider: ActivityProvider;\n  serviceClient?: RuntimeServiceClient;\n}\n\nexport interface ActivityWorkerRequest {\n  scheduledTime: string;\n  workflowName: string;\n  executionId: string;\n  command: ScheduleActivityCommand;\n  retry: number;\n}\n\nexport interface ActivityWorker {\n  (\n    request: ActivityWorkerRequest,\n    baseTime: Date,\n    /**\n     * Allows for a computed end time, for case like the test environment when the end time should be controlled.\n     */\n    getEndTime?: (startTime: Date) => Date\n  ): Promise<void>;\n}\n\n/**\n * Creates a generic function for handling activity worker requests\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 createActivityWorker({\n  activityRuntimeClient,\n  workflowClient,\n  timerClient,\n  metricsClient,\n  logger,\n  activityProvider,\n  serviceClient,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the service client available to all activity code\n  if (serviceClient) {\n    registerServiceClient(serviceClient);\n  }\n\n  return metricsClient.metricScope(\n    (metrics) =>\n      async (\n        request: ActivityWorkerRequest,\n        baseTime: Date,\n        getEndTime = () => new Date()\n      ) => {\n        logger.addPersistentLogAttributes({\n          workflowName: request.workflowName,\n          executionId: request.executionId,\n        });\n        const activityHandle = `${request.command.seq} for execution ${request.executionId} on retry ${request.retry}`;\n        metrics.resetDimensions(false);\n        metrics.setNamespace(MetricsCommon.EventualNamespace);\n        metrics.putDimensions({\n          ActivityName: request.command.name,\n          WorkflowName: request.workflowName,\n        });\n        // the time from the workflow emitting the activity scheduled command\n        // to the request being seen.\n        const start = baseTime;\n        const recordAge =\n          start.getTime() - new Date(request.scheduledTime).getTime();\n        metrics.putMetric(\n          ActivityMetrics.ActivityRequestAge,\n          recordAge,\n          Unit.Milliseconds\n        );\n        if (\n          !(await timed(metrics, ActivityMetrics.ClaimDuration, () =>\n            activityRuntimeClient.claimActivity(\n              request.executionId,\n              request.command.seq,\n              request.retry\n            )\n          ))\n        ) {\n          metrics.putMetric(ActivityMetrics.ClaimRejected, 1, Unit.Count);\n          logger.info(`Activity ${activityHandle} already claimed.`);\n          return;\n        }\n        if (request.command.heartbeatSeconds) {\n          await timerClient.startTimer({\n            activitySeq: request.command.seq,\n            type: TimerRequestType.ActivityHeartbeatMonitor,\n            executionId: request.executionId,\n            heartbeatSeconds: request.command.heartbeatSeconds,\n            schedule: Schedule.relative(request.command.heartbeatSeconds),\n          });\n        }\n        setActivityContext({\n          activityToken: createActivityToken(\n            request.executionId,\n            request.command.seq\n          ),\n          executionId: request.executionId,\n          scheduledTime: request.scheduledTime,\n          workflowName: request.workflowName,\n        });\n        metrics.putMetric(ActivityMetrics.ClaimRejected, 0, Unit.Count);\n\n        logger.info(`Processing ${activityHandle}.`);\n\n        const activity = activityProvider.getActivityHandler(\n          request.command.name\n        );\n        try {\n          if (!activity) {\n            metrics.putMetric(ActivityMetrics.NotFoundError, 1, Unit.Count);\n            throw new ActivityNotFoundError(\n              request.command.name,\n              activityProvider.getActivityIds()\n            );\n          }\n\n          const result = await timed(\n            metrics,\n            ActivityMetrics.OperationDuration,\n            () => activity(...request.command.args)\n          );\n          if (isAsyncResult(result)) {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 1);\n\n            // TODO: Send heartbeat on sync activity completion.\n\n            /**\n             * The activity has declared that it is async, other than logging, there is nothing left to do here.\n             * The activity should call {@link WorkflowClient.completeActivity} or {@link WorkflowClient.failActivity} when it is done.\n             */\n            return;\n          } else if (result) {\n            metrics.setProperty(ActivityMetrics.HasResult, 1);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n            metrics.putMetric(\n              ActivityMetrics.ResultBytes,\n              JSON.stringify(result).length,\n              Unit.Bytes\n            );\n          } else {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n          }\n\n          logger.info(\n            `Activity ${activityHandle} succeeded, reporting back to execution.`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityCompleted>(\n            {\n              type: WorkflowEventType.ActivityCompleted,\n              seq: request.command.seq,\n              result,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } catch (err) {\n          const [error, message] = extendsError(err)\n            ? [err.name, err.message]\n            : [\"Error\", JSON.stringify(err)];\n\n          logger.info(\n            `Activity ${activityHandle} failed, reporting failure back to execution: ${error}: ${message}`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityFailed>(\n            {\n              type: WorkflowEventType.ActivityFailed,\n              seq: request.command.seq,\n              error,\n              message,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } finally {\n          clearActivityContext();\n        }\n\n        function logActivityCompleteMetrics(failed: boolean, duration: number) {\n          metrics.putMetric(\n            ActivityMetrics.ActivityFailed,\n            failed ? 1 : 0,\n            Unit.Count\n          );\n          metrics.putMetric(\n            ActivityMetrics.ActivityCompleted,\n            failed ? 0 : 1,\n            Unit.Count\n          );\n          // The total time from the activity being scheduled until it's result is send to the workflow.\n          metrics.putMetric(ActivityMetrics.TotalDuration, duration);\n        }\n\n        async function finishActivity(\n          event: ActivityCompleted | ActivityFailed,\n          duration: number\n        ) {\n          await timed(metrics, ActivityMetrics.SubmitWorkflowTaskDuration, () =>\n            workflowClient.submitWorkflowTask(request.executionId, event)\n          );\n\n          logActivityCompleteMetrics(isWorkflowFailed(event), duration);\n        }\n      }\n  );\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-worker.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/activity-worker.ts"],"names":[],"mappings":"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","sourcesContent":["import { isAsyncResult } from \"../../activity.js\";\nimport { ScheduleActivityCommand } from \"../../command.js\";\nimport {\n  ActivitySucceeded,\n  ActivityFailed,\n  createEvent,\n  isWorkflowFailed,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  clearActivityContext,\n  registerServiceClient,\n  setActivityContext,\n} from \"../../global.js\";\nimport { createActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"../clients/activity-runtime-client.js\";\nimport { MetricsClient } from \"../clients/metrics-client.js\";\nimport { WorkflowClient } from \"../clients/workflow-client.js\";\nimport {\n  RuntimeServiceClient,\n  Schedule,\n  TimerClient,\n  TimerRequestType,\n} from \"../index.js\";\nimport { Logger } from \"../logger.js\";\nimport { ActivityMetrics, MetricsCommon } from \"../metrics/constants.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed } from \"../metrics/utils.js\";\nimport type { EventClient } from \"../index.js\";\nimport { ActivityProvider } from \"../providers/activity-provider.js\";\nimport { ActivityNotFoundError } from \"../../error.js\";\nimport { extendsError } from \"../../util.js\";\n\nexport interface CreateActivityWorkerProps {\n  activityRuntimeClient: ActivityRuntimeClient;\n  workflowClient: WorkflowClient;\n  timerClient: TimerClient;\n  metricsClient: MetricsClient;\n  logger: Logger;\n  eventClient: EventClient;\n  activityProvider: ActivityProvider;\n  serviceClient?: RuntimeServiceClient;\n}\n\nexport interface ActivityWorkerRequest {\n  scheduledTime: string;\n  workflowName: string;\n  executionId: string;\n  command: ScheduleActivityCommand;\n  retry: number;\n}\n\nexport interface ActivityWorker {\n  (\n    request: ActivityWorkerRequest,\n    baseTime: Date,\n    /**\n     * Allows for a computed end time, for case like the test environment when the end time should be controlled.\n     */\n    getEndTime?: (startTime: Date) => Date\n  ): Promise<void>;\n}\n\n/**\n * Creates a generic function for handling activity worker requests\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 createActivityWorker({\n  activityRuntimeClient,\n  workflowClient,\n  timerClient,\n  metricsClient,\n  logger,\n  activityProvider,\n  serviceClient,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the service client available to all activity code\n  if (serviceClient) {\n    registerServiceClient(serviceClient);\n  }\n\n  return metricsClient.metricScope(\n    (metrics) =>\n      async (\n        request: ActivityWorkerRequest,\n        baseTime: Date,\n        getEndTime = () => new Date()\n      ) => {\n        logger.addPersistentLogAttributes({\n          workflowName: request.workflowName,\n          executionId: request.executionId,\n        });\n        const activityHandle = `${request.command.seq} for execution ${request.executionId} on retry ${request.retry}`;\n        metrics.resetDimensions(false);\n        metrics.setNamespace(MetricsCommon.EventualNamespace);\n        metrics.putDimensions({\n          ActivityName: request.command.name,\n          WorkflowName: request.workflowName,\n        });\n        // the time from the workflow emitting the activity scheduled command\n        // to the request being seen.\n        const start = baseTime;\n        const recordAge =\n          start.getTime() - new Date(request.scheduledTime).getTime();\n        metrics.putMetric(\n          ActivityMetrics.ActivityRequestAge,\n          recordAge,\n          Unit.Milliseconds\n        );\n        if (\n          !(await timed(metrics, ActivityMetrics.ClaimDuration, () =>\n            activityRuntimeClient.claimActivity(\n              request.executionId,\n              request.command.seq,\n              request.retry\n            )\n          ))\n        ) {\n          metrics.putMetric(ActivityMetrics.ClaimRejected, 1, Unit.Count);\n          logger.info(`Activity ${activityHandle} already claimed.`);\n          return;\n        }\n        if (request.command.heartbeatSeconds) {\n          await timerClient.startTimer({\n            activitySeq: request.command.seq,\n            type: TimerRequestType.ActivityHeartbeatMonitor,\n            executionId: request.executionId,\n            heartbeatSeconds: request.command.heartbeatSeconds,\n            schedule: Schedule.relative(request.command.heartbeatSeconds),\n          });\n        }\n        setActivityContext({\n          activityToken: createActivityToken(\n            request.executionId,\n            request.command.seq\n          ),\n          executionId: request.executionId,\n          scheduledTime: request.scheduledTime,\n          workflowName: request.workflowName,\n        });\n        metrics.putMetric(ActivityMetrics.ClaimRejected, 0, Unit.Count);\n\n        logger.info(`Processing ${activityHandle}.`);\n\n        const activity = activityProvider.getActivityHandler(\n          request.command.name\n        );\n        try {\n          if (!activity) {\n            metrics.putMetric(ActivityMetrics.NotFoundError, 1, Unit.Count);\n            throw new ActivityNotFoundError(\n              request.command.name,\n              activityProvider.getActivityIds()\n            );\n          }\n\n          const result = await timed(\n            metrics,\n            ActivityMetrics.OperationDuration,\n            () => activity(...request.command.args)\n          );\n          if (isAsyncResult(result)) {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 1);\n\n            // TODO: Send heartbeat on sync activity completion.\n\n            /**\n             * The activity has declared that it is async, other than logging, there is nothing left to do here.\n             * The activity should call {@link WorkflowClient.sendActivitySuccess} or {@link WorkflowClient.sendActivityFailure} when it is done.\n             */\n            return;\n          } else if (result) {\n            metrics.setProperty(ActivityMetrics.HasResult, 1);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n            metrics.putMetric(\n              ActivityMetrics.ResultBytes,\n              JSON.stringify(result).length,\n              Unit.Bytes\n            );\n          } else {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n          }\n\n          logger.info(\n            `Activity ${activityHandle} succeeded, reporting back to execution.`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivitySucceeded>(\n            {\n              type: WorkflowEventType.ActivitySucceeded,\n              seq: request.command.seq,\n              result,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } catch (err) {\n          const [error, message] = extendsError(err)\n            ? [err.name, err.message]\n            : [\"Error\", JSON.stringify(err)];\n\n          logger.info(\n            `Activity ${activityHandle} failed, reporting failure back to execution: ${error}: ${message}`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityFailed>(\n            {\n              type: WorkflowEventType.ActivityFailed,\n              seq: request.command.seq,\n              error,\n              message,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } finally {\n          clearActivityContext();\n        }\n\n        function logActivityCompleteMetrics(failed: boolean, duration: number) {\n          metrics.putMetric(\n            ActivityMetrics.ActivityFailed,\n            failed ? 1 : 0,\n            Unit.Count\n          );\n          metrics.putMetric(\n            ActivityMetrics.ActivitySucceeded,\n            failed ? 0 : 1,\n            Unit.Count\n          );\n          // The total time from the activity being scheduled until it's result is send to the workflow.\n          metrics.putMetric(ActivityMetrics.TotalDuration, duration);\n        }\n\n        async function finishActivity(\n          event: ActivitySucceeded | ActivityFailed,\n          duration: number\n        ) {\n          await timed(metrics, ActivityMetrics.SubmitWorkflowTaskDuration, () =>\n            workflowClient.submitWorkflowTask(request.executionId, event)\n          );\n\n          logActivityCompleteMetrics(isWorkflowFailed(event), duration);\n        }\n      }\n  );\n}\n"]}

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

yield (0, workflow_events_js_1.createEvent)({
type: workflow_events_js_1.WorkflowEventType.WorkflowTaskStarted,
type: workflow_events_js_1.WorkflowEventType.WorkflowRunStarted,
}, start);

@@ -149,3 +149,3 @@ const workflowContext = {

yield (0, workflow_events_js_1.createEvent)({
type: workflow_events_js_1.WorkflowEventType.WorkflowTaskCompleted,
type: workflow_events_js_1.WorkflowEventType.WorkflowRunCompleted,
}, start);

@@ -165,3 +165,3 @@ if ((0, result_js_1.isResult)(result)) {

yield (0, workflow_events_js_1.createEvent)({
type: workflow_events_js_1.WorkflowEventType.WorkflowCompleted,
type: workflow_events_js_1.WorkflowEventType.WorkflowSucceeded,
output: result.value,

@@ -197,3 +197,3 @@ }, start);

}
if ((0, workflow_events_js_1.isWorkflowCompleted)(event) || (0, workflow_events_js_1.isWorkflowFailed)(event)) {
if ((0, workflow_events_js_1.isWorkflowSucceeded)(event) || (0, workflow_events_js_1.isWorkflowFailed)(event)) {
resultEvent = event;

@@ -255,4 +255,4 @@ }

}
else if ((0, workflow_events_js_1.isWorkflowCompleted)(resultEvent)) {
const execution = await (0, utils_js_1.timed)(metrics, constants_js_1.OrchestratorMetrics.ExecutionStatusUpdateDuration, () => workflowRuntimeClient.completeExecution({
else if ((0, workflow_events_js_1.isWorkflowSucceeded)(resultEvent)) {
const execution = await (0, utils_js_1.timed)(metrics, constants_js_1.OrchestratorMetrics.ExecutionStatusUpdateDuration, () => workflowRuntimeClient.succeedExecution({
executionId,

@@ -292,7 +292,7 @@ result: resultEvent.output,

function logExecutionCompleteMetrics(execution) {
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionComplete, execution.status === execution_js_1.ExecutionStatus.COMPLETE ? 1 : 0, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionFailed, execution.status === execution_js_1.ExecutionStatus.COMPLETE ? 0 : 1, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionComplete, execution.status === execution_js_1.ExecutionStatus.SUCCEEDED ? 1 : 0, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionFailed, execution.status === execution_js_1.ExecutionStatus.SUCCEEDED ? 0 : 1, unit_js_1.Unit.Count);
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionTotalDuration, new Date(execution.endTime).getTime() -
new Date(execution.startTime).getTime());
if ((0, execution_js_1.isCompleteExecution)(execution)) {
if ((0, execution_js_1.isSucceededExecution)(execution)) {
metrics.putMetric(constants_js_1.OrchestratorMetrics.ExecutionResultBytes, execution.result ? JSON.stringify(execution.result).length : 0, unit_js_1.Unit.Bytes);

@@ -314,2 +314,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":";;;AAAA,+BAA+B;AAG/B,iEAgBkC;AAClC,qDAK4B;AAC5B,+CAAyE;AACzE,mDAA+E;AAC/E,kDAQ6B;AAC7B,gEAAyD;AACzD,wDAAsE;AAEtE,0DAA6E;AAE7E,gDAA0C;AAC1C,kDAAuD;AACvD,0CAAoE;AACpE,2CAA6C;AA2B7C;;;;;GAKG;AACH,SAAgB,kBAAkB,CAAC,EACjC,sBAAsB,EACtB,WAAW,EACX,qBAAqB,EACrB,cAAc,EACd,aAAa,EACb,WAAW,EACX,MAAM,GACmB;IACzB,MAAM,eAAe,GAAG,IAAI,qCAAe,CAAC;QAC1C,WAAW;QACX,cAAc;QACd,qBAAqB;QACrB,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,GAAG,IAAI,IAAI,EAAE,EAAE,EAAE;QACpD,MAAM,kBAAkB,GAAG,IAAA,kBAAO,EAChC,aAAa,EACb,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAC3B,CAAC;QAEF,MAAM,mBAAmB,GAAG,MAAM,CAAC,WAAW,CAC5C,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC;YACjE,WAAW;YACX,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SACjC,CAAC,CACH,CAAC;QAEF,MAAM,CAAC,IAAI,CACT,uBAAuB,GAAG,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CACtE,CAAC;QAEF,wBAAwB;QACxB,MAAM,OAAO,GAAG,MAAM,IAAA,uCAA4B,EAChD,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,EACnC,KAAK,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,IAAA,+BAAa,EAAC,WAAW,CAAC,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,GAAG,CAAC,CAAC;aAC1D;YACD,MAAM,YAAY,GAAG,IAAA,mCAAiB,EAAC,WAAW,CAAC,CAAC;YACpD,IAAI,YAAY,KAAK,SAAS,EAAE;gBAC9B,MAAM,IAAI,KAAK,CAAC,iBAAiB,WAAW,kBAAkB,CAAC,CAAC;aACjE;YACD,MAAM,QAAQ,GAAG,IAAA,4BAAc,EAAC,YAAY,CAAC,CAAC;YAC9C,IAAI,QAAQ,KAAK,SAAS,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,+BAA+B,YAAY,GAAG,CAAC,CAAC;aACjE;YACD,uCAAuC;YACvC,OAAO,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QACxE,CAAC,CACF,CAAC;QAEF,MAAM,CAAC,KAAK,CACV,wBAAwB;YACtB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACpE,CAAC;QAEF,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/B,MAAM,CAAC,KAAK,CACV,uBAAuB;gBACrB,OAAO,CAAC,QAAQ;qBACb,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,WAAW,KAAK,KAAK,EAAE,CAAC;qBAC3D,IAAI,CAAC,IAAI,CAAC,CAChB,CAAC;SACH;QAED,OAAO;YACL,kBAAkB,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACvE,CAAC;IACJ,CAAC,CAAC;IAEF,KAAK,UAAU,oBAAoB,CACjC,QAAkB,EAClB,WAAmB,EACnB,MAA2B,EAC3B,QAAc;QAEd,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC;YACzC,uBAAuB,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,EAAE,WAAW,EAAE;SACtE,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;QACpC,MAAM,KAAK,GAAG,QAAQ,CAAC;QACvB,IAAI;YACF,OAAO;YACP,MAAM,OAAO,GAAG,MAAM,WAAW,EAAE,CAAC;YAEpC,UAAU;YACV,MAAM,EAAE,oBAAoB,EAAE,SAAS,EAAE,WAAW,EAAE,GACpD,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;YAEjC,UAAU;YACV,MAAM,qBAAqB,CAAC,WAAW,CAAC,CAAC;YACzC,MAAM,+BAA+B,CAAC,SAAS,CAAC,CAAC;YACjD,MAAM,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAE1C,2EAA2E;YAC3E,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;SACzC;QAAC,OAAO,GAAG,EAAE;YACZ,eAAe,CAAC,KAAK,CAAC,IAAA,cAAO,EAAC,GAAG,CAAC,CAAC,CAAC;YACpC,MAAM,GAAG,CAAC;SACX;gBAAS;YACR,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;SACvB;QAED;;WAEG;QACH,KAAK,UAAU,eAAe,CAAC,OAA4B;YACzD,gDAAgD;YAChD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CACzB,GAAG,MAAM,CAAC,GAAG,CACX,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAC9D,CACF,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,UAAU,EAC9B,UAAU,EACV,cAAI,CAAC,YAAY,CAClB,CAAC;YAEF,OAAO,yBAAyB,CAAC,OAAO,EAAE,wBAAwB,EAAE,CAAC,CAAC;YAEtE,KAAK,SAAS,CAAC,CAAC,wBAAwB;gBACtC,MAAM,IAAA,gCAAW,EACf;oBACE,IAAI,EAAE,sCAAiB,CAAC,mBAAmB;iBAC5C,EACD,KAAK,CACN,CAAC;gBAEF,MAAM,eAAe,GAAoB;oBACvC,IAAI,EAAE,QAAQ,CAAC,YAAY;iBAC5B,CAAC;gBAEF,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,sCAAiB,CAAC,CAAC;gBAEnD;;;mBAGG;gBACH,IAAI,CAAC,UAAU,EAAE;oBACf,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,sCAAiB,CAAC,CAAC;oBAExD,IAAI,gBAAgB,EAAE,WAAW,EAAE;wBACjC,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;wBAC3D,MAAM,IAAA,gBAAK,EACT,OAAO,EACP,kCAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CACH,WAAW,CAAC,aAAa,CAAmB;4BAC1C,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAY,CAAC;4BAC1D,KAAK,EAAE,IAAA,gCAAW,EAChB;gCACE,IAAI,EAAE,sCAAiB,CAAC,gBAAgB;6BACzC,EACD,KAAK,CACN;4BACD,WAAW;yBACZ,CAAC,CACL,CAAC;qBACH;yBAAM;wBACL,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;qBAC5D;iBACF;gBAED,MAAM,EACJ,MAAM,EACN,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,oBAAoB,GAC9B,GAAG,IAAA,oBAAS,EACX,OAAO,EACP,kCAAmB,CAAC,wBAAwB,EAC5C,GAAG,EAAE;oBACH,IAAI;wBACF,OAAO,IAAA,8BAAgB,EACrB,QAAQ,EACR,OAAO,EACP,MAAM,EACN,eAAe,EACf,WAAW,EACX,QAAQ,CACT,CAAC;qBACH;oBAAC,OAAO,GAAG,EAAE;wBACZ,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;wBAC9B,eAAe,CAAC,KAAK,CAAC,IAAA,cAAO,EAAC,GAAG,CAAC,CAAC,CAAC;wBACpC,MAAM,GAAG,CAAC;qBACX;gBACH,CAAC,CACF,CAAC;gBAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,sBAAsB,EAC1C,oBAAoB,CAAC,MAAM,CAC5B,CAAC;gBAEF,KAAK,CAAC,CAAC,oBAAoB,CAAC;gBAE5B,eAAe,CAAC,KAAK,CACnB,4BAA4B,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CACtD,CAAC;gBAEF,eAAe,CAAC,IAAI,CAAC,SAAS,WAAW,CAAC,MAAM,gBAAgB,CAAC,CAAC;gBAElE,KAAK,CAAC,CAAC,MAAM,IAAA,gBAAK,EAChB,OAAO,EACP,kCAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CAAC,eAAe,CAAC,WAAW,CAAC,CACnC,CAAC;gBAEF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,eAAe,EACnC,WAAW,CAAC,MAAM,EAClB,cAAI,CAAC,KAAK,CACX,CAAC;gBAEF,oGAAoG;gBACpG,2EAA2E;gBAC3E,qHAAqH;gBACrH,iFAAiF;gBACjF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,qBAAqB,EACzC,UAAU,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,CACtD,CAAC;gBAEF,MAAM,IAAA,gCAAW,EACf;oBACE,IAAI,EAAE,sCAAiB,CAAC,qBAAqB;iBAC9C,EACD,KAAK,CACN,CAAC;gBAEF,IAAI,IAAA,oBAAQ,EAAC,MAAM,CAAC,EAAE;oBACpB,IAAI,IAAA,oBAAQ,EAAC,MAAM,CAAC,EAAE;wBACpB,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,IAAA,sBAAY,EAAC,MAAM,CAAC,KAAK,CAAC;4BACjD,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC;4BAC3C,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;wBAC5C,MAAM,IAAA,gCAAW,EACf;4BACE,IAAI,EAAE,sCAAiB,CAAC,cAAc;4BACtC,KAAK;4BACL,OAAO;yBACR,EACD,KAAK,CACN,CAAC;qBACH;yBAAM,IAAI,IAAA,sBAAU,EAAM,MAAM,CAAC,EAAE;wBAClC,MAAM,IAAA,gCAAW,EACf;4BACE,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;4BACzC,MAAM,EAAE,MAAM,CAAC,KAAK;yBACrB,EACD,KAAK,CACN,CAAC;qBACH;iBACF;gBAED,OAAO,MAAM,CAAC;YAChB,CAAC;YAED;;;;;;;;;;;eAWG;YACH,KAAK,UAAU,yBAAyB,CACtC,eAAoC,EACpC,kBAAqE;gBAErE,MAAM,oBAAoB,GAAwB,EAAE,CAAC;gBACrD,MAAM,iBAAiB,GAAoB,EAAE,CAAC;gBAC9C,IAAI,WAA2D,CAAC;gBAChE,MAAM,UAAU,GAAgB,IAAI,GAAG,CACrC,eAAe,CAAC,GAAG,CAAC,+BAAU,CAAC,CAChC,CAAC;gBAEF,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,kBAAkB,EAAE;oBAC5C,MAAM,EAAE,GAAG,IAAA,+BAAU,EAAC,KAAK,CAAC,CAAC;oBAC7B,oFAAoF;oBACpF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;wBACvB,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC9B,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;qBACpB;oBACD,IAAI,IAAA,wCAAmB,EAAC,KAAK,CAAC,IAAI,IAAA,qCAAgB,EAAC,KAAK,CAAC,EAAE;wBACzD,WAAW,GAAG,KAAK,CAAC;qBACrB;oBACD,0DAA0D;oBAC1D,IAAI,IAAA,sCAAiB,EAAC,KAAK,CAAC,IAAI,IAAA,mCAAc,EAAC,KAAK,CAAC,EAAE;wBACrD,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAClC;iBACF;gBAED,OAAO;oBACL,oBAAoB;oBACpB,SAAS,EAAE,iBAAiB;oBAC5B,WAAW;iBACZ,CAAC;YACJ,CAAC;QACH,CAAC;QAED,KAAK,UAAU,WAAW;YACxB,eAAe,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACtC,eAAe;YACf,MAAM,OAAO,GAAG,MAAM,IAAA,gBAAK,EACzB,OAAO,EACP,kCAAmB,CAAC,mBAAmB,EACvC,KAAK,IAAI,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAAC,CAC1D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,mBAAmB,EACvC,OAAO,CAAC,MAAM,CACf,CAAC;YAEF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED;;WAEG;QACH,KAAK,UAAU,+BAA+B,CAAC,SAA0B;YACvE,MAAM,IAAA,gBAAK,EACT,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CAAC,sBAAsB,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,CAAC,CAC/D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,kBAAkB,EACtC,SAAS,CAAC,MAAM,CACjB,CAAC;QACJ,CAAC;QAED;;;;;WAKG;QACH,KAAK,UAAU,aAAa,CAAC,oBAAyC;YACpE,OAAO,CAAC,KAAK,CACX,qBAAqB,EACrB,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,CACrC,CAAC;YAEF,8CAA8C;YAC9C,yHAAyH;YACzH,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,MAAM,IAAA,gBAAK,EAChD,OAAO,EACP,kCAAmB,CAAC,mBAAmB,EACvC,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;gBAClC,WAAW;gBACX,MAAM,EAAE,oBAAoB;aAC7B,CAAC,CACL,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,kBAAkB,EACtC,oBAAoB,CAAC,MAAM,CAC5B,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,iBAAiB,EACrC,mBAAmB,EACnB,cAAI,CAAC,KAAK,CACX,CAAC;QACJ,CAAC;QAED,KAAK,UAAU,qBAAqB,CAClC,WAAgD;YAEhD,wEAAwE;YACxE,IAAI,WAAW,EAAE;gBACf,IAAI,IAAA,qCAAgB,EAAC,WAAW,CAAC,EAAE;oBACjC,MAAM,SAAS,GAAG,MAAM,IAAA,gBAAK,EAC3B,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;wBAClC,WAAW;wBACX,KAAK,EAAE,WAAW,CAAC,KAAK;wBACxB,OAAO,EAAE,WAAW,CAAC,OAAO;qBAC7B,CAAC,CACL,CAAC;oBAEF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;qBAAM,IAAI,IAAA,wCAAmB,EAAC,WAAW,CAAC,EAAE;oBAC3C,MAAM,SAAS,GAAG,MAAM,IAAA,gBAAK,EAC3B,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,iBAAiB,CAAC;wBACtC,WAAW;wBACX,MAAM,EAAE,WAAW,CAAC,MAAM;qBAC3B,CAAC,CACL,CAAC;oBACF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;aACF;QACH,CAAC;QAED;;;;WAIG;QACH,KAAK,UAAU,eAAe,CAC5B,QAAmB;YAEnB,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC5D,0BAA0B;YAC1B,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACvB,eAAe,CAAC,cAAc,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,CAAC,CACtE,CACF,CAAC;QACJ,CAAC;QAED,SAAS,iBAAiB;YACxB,MAAM,OAAO,GAAG,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpD,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAC/B,OAAO,CAAC,YAAY,CAAC,4BAAa,CAAC,iBAAiB,CAAC,CAAC;YACtD,OAAO,CAAC,aAAa,CAAC;gBACpB,CAAC,4BAAa,CAAC,qBAAqB,CAAC,EAAE,QAAQ,CAAC,YAAY;aAC7D,CAAC,CAAC;YACH,oDAAoD;YACpD,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACnE,2EAA2E;YAC3E,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAExE,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;YAClE,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,OAAO,EAC3B,kCAAmB,CAAC,SAAS,CAC9B,CAAC;YACF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,SAAS,2BAA2B,CAClC,SAA8C;YAE9C,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,iBAAiB,EACrC,SAAS,CAAC,MAAM,KAAK,8BAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACrD,cAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,eAAe,EACnC,SAAS,CAAC,MAAM,KAAK,8BAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACrD,cAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,sBAAsB,EAC1C,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;gBACnC,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAC1C,CAAC;YACF,IAAI,IAAA,kCAAmB,EAAC,SAAS,CAAC,EAAE;gBAClC,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,oBAAoB,EACxC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAC9D,cAAI,CAAC,KAAK,CACX,CAAC;aACH;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAxdD,gDAwdC;AAED,mDAAmD;AACnD,SAAS,eAAe,CACtB,OAAsB,EACtB,MAAuB,EACvB,GAAS;IAET,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,qCAAgB,CAAC,CAAC;IAC7D,IAAI,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;QACnC,MAAM,sBAAsB,GAAG,oBAAoB,CAAC,GAAG,CACrD,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CACvD,CAAC;QACF,MAAM,GAAG,GACP,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACjD,sBAAsB,CAAC,MAAM,CAAC;QAChC,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;KACnE;AACH,CAAC","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 { groupBy, promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\nimport { WorkflowTask } from \"../../tasks.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\nexport interface Orchestrator {\n  (workflowTasks: WorkflowTask[], baseTime?: Date): Promise<OrchestratorResult>;\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): Orchestrator {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (workflowTasks, baseTime = new Date()) => {\n    const tasksByExecutionId = groupBy(\n      workflowTasks,\n      (task) => task.executionId\n    );\n\n    const eventsByExecutionId = Object.fromEntries(\n      Object.entries(tasksByExecutionId).map(([executionId, records]) => [\n        executionId,\n        records.flatMap((e) => e.events),\n      ])\n    );\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, baseTime);\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    baseTime: Date\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = baseTime;\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                    {\n                      type: WorkflowEventType.WorkflowTimedOut,\n                    },\n                    start\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                baseTime\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          {\n            type: WorkflowEventType.WorkflowTaskCompleted,\n          },\n          start\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              {\n                type: WorkflowEventType.WorkflowFailed,\n                error,\n                message,\n              },\n              start\n            );\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>(\n              {\n                type: WorkflowEventType.WorkflowCompleted,\n                output: result.value,\n              },\n              start\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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":";;;AAAA,+BAA+B;AAG/B,iEAgBkC;AAClC,qDAK4B;AAC5B,+CAAyE;AACzE,mDAA+E;AAC/E,kDAQ6B;AAC7B,gEAAyD;AACzD,wDAAsE;AAEtE,0DAA6E;AAE7E,gDAA0C;AAC1C,kDAAuD;AACvD,0CAAoE;AACpE,2CAA6C;AA2B7C;;;;;GAKG;AACH,SAAgB,kBAAkB,CAAC,EACjC,sBAAsB,EACtB,WAAW,EACX,qBAAqB,EACrB,cAAc,EACd,aAAa,EACb,WAAW,EACX,MAAM,GACmB;IACzB,MAAM,eAAe,GAAG,IAAI,qCAAe,CAAC;QAC1C,WAAW;QACX,cAAc;QACd,qBAAqB;QACrB,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,GAAG,IAAI,IAAI,EAAE,EAAE,EAAE;QACpD,MAAM,kBAAkB,GAAG,IAAA,kBAAO,EAChC,aAAa,EACb,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAC3B,CAAC;QAEF,MAAM,mBAAmB,GAAG,MAAM,CAAC,WAAW,CAC5C,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC;YACjE,WAAW;YACX,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SACjC,CAAC,CACH,CAAC;QAEF,MAAM,CAAC,IAAI,CACT,uBAAuB,GAAG,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CACtE,CAAC;QAEF,wBAAwB;QACxB,MAAM,OAAO,GAAG,MAAM,IAAA,uCAA4B,EAChD,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,EACnC,KAAK,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,IAAA,+BAAa,EAAC,WAAW,CAAC,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,GAAG,CAAC,CAAC;aAC1D;YACD,MAAM,YAAY,GAAG,IAAA,mCAAiB,EAAC,WAAW,CAAC,CAAC;YACpD,IAAI,YAAY,KAAK,SAAS,EAAE;gBAC9B,MAAM,IAAI,KAAK,CAAC,iBAAiB,WAAW,kBAAkB,CAAC,CAAC;aACjE;YACD,MAAM,QAAQ,GAAG,IAAA,4BAAc,EAAC,YAAY,CAAC,CAAC;YAC9C,IAAI,QAAQ,KAAK,SAAS,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,+BAA+B,YAAY,GAAG,CAAC,CAAC;aACjE;YACD,uCAAuC;YACvC,OAAO,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QACxE,CAAC,CACF,CAAC;QAEF,MAAM,CAAC,KAAK,CACV,wBAAwB;YACtB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACpE,CAAC;QAEF,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/B,MAAM,CAAC,KAAK,CACV,uBAAuB;gBACrB,OAAO,CAAC,QAAQ;qBACb,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,WAAW,KAAK,KAAK,EAAE,CAAC;qBAC3D,IAAI,CAAC,IAAI,CAAC,CAChB,CAAC;SACH;QAED,OAAO;YACL,kBAAkB,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACvE,CAAC;IACJ,CAAC,CAAC;IAEF,KAAK,UAAU,oBAAoB,CACjC,QAAkB,EAClB,WAAmB,EACnB,MAA2B,EAC3B,QAAc;QAEd,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC;YACzC,uBAAuB,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,EAAE,WAAW,EAAE;SACtE,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;QACpC,MAAM,KAAK,GAAG,QAAQ,CAAC;QACvB,IAAI;YACF,OAAO;YACP,MAAM,OAAO,GAAG,MAAM,WAAW,EAAE,CAAC;YAEpC,UAAU;YACV,MAAM,EAAE,oBAAoB,EAAE,SAAS,EAAE,WAAW,EAAE,GACpD,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;YAEjC,UAAU;YACV,MAAM,qBAAqB,CAAC,WAAW,CAAC,CAAC;YACzC,MAAM,+BAA+B,CAAC,SAAS,CAAC,CAAC;YACjD,MAAM,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAE1C,2EAA2E;YAC3E,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;SACzC;QAAC,OAAO,GAAG,EAAE;YACZ,eAAe,CAAC,KAAK,CAAC,IAAA,cAAO,EAAC,GAAG,CAAC,CAAC,CAAC;YACpC,MAAM,GAAG,CAAC;SACX;gBAAS;YACR,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;SACvB;QAED;;WAEG;QACH,KAAK,UAAU,eAAe,CAAC,OAA4B;YACzD,gDAAgD;YAChD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CACzB,GAAG,MAAM,CAAC,GAAG,CACX,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAC9D,CACF,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,UAAU,EAC9B,UAAU,EACV,cAAI,CAAC,YAAY,CAClB,CAAC;YAEF,OAAO,yBAAyB,CAAC,OAAO,EAAE,wBAAwB,EAAE,CAAC,CAAC;YAEtE,KAAK,SAAS,CAAC,CAAC,wBAAwB;gBACtC,MAAM,IAAA,gCAAW,EACf;oBACE,IAAI,EAAE,sCAAiB,CAAC,kBAAkB;iBAC3C,EACD,KAAK,CACN,CAAC;gBAEF,MAAM,eAAe,GAAoB;oBACvC,IAAI,EAAE,QAAQ,CAAC,YAAY;iBAC5B,CAAC;gBAEF,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,sCAAiB,CAAC,CAAC;gBAEnD;;;mBAGG;gBACH,IAAI,CAAC,UAAU,EAAE;oBACf,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,sCAAiB,CAAC,CAAC;oBAExD,IAAI,gBAAgB,EAAE,WAAW,EAAE;wBACjC,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;wBAC3D,MAAM,IAAA,gBAAK,EACT,OAAO,EACP,kCAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CACH,WAAW,CAAC,aAAa,CAAmB;4BAC1C,QAAQ,EAAE,mBAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAY,CAAC;4BAC1D,KAAK,EAAE,IAAA,gCAAW,EAChB;gCACE,IAAI,EAAE,sCAAiB,CAAC,gBAAgB;6BACzC,EACD,KAAK,CACN;4BACD,WAAW;yBACZ,CAAC,CACL,CAAC;qBACH;yBAAM;wBACL,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;qBAC5D;iBACF;gBAED,MAAM,EACJ,MAAM,EACN,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,oBAAoB,GAC9B,GAAG,IAAA,oBAAS,EACX,OAAO,EACP,kCAAmB,CAAC,wBAAwB,EAC5C,GAAG,EAAE;oBACH,IAAI;wBACF,OAAO,IAAA,8BAAgB,EACrB,QAAQ,EACR,OAAO,EACP,MAAM,EACN,eAAe,EACf,WAAW,EACX,QAAQ,CACT,CAAC;qBACH;oBAAC,OAAO,GAAG,EAAE;wBACZ,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;wBAC9B,eAAe,CAAC,KAAK,CAAC,IAAA,cAAO,EAAC,GAAG,CAAC,CAAC,CAAC;wBACpC,MAAM,GAAG,CAAC;qBACX;gBACH,CAAC,CACF,CAAC;gBAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,sBAAsB,EAC1C,oBAAoB,CAAC,MAAM,CAC5B,CAAC;gBAEF,KAAK,CAAC,CAAC,oBAAoB,CAAC;gBAE5B,eAAe,CAAC,KAAK,CACnB,4BAA4B,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CACtD,CAAC;gBAEF,eAAe,CAAC,IAAI,CAAC,SAAS,WAAW,CAAC,MAAM,gBAAgB,CAAC,CAAC;gBAElE,KAAK,CAAC,CAAC,MAAM,IAAA,gBAAK,EAChB,OAAO,EACP,kCAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CAAC,eAAe,CAAC,WAAW,CAAC,CACnC,CAAC;gBAEF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,eAAe,EACnC,WAAW,CAAC,MAAM,EAClB,cAAI,CAAC,KAAK,CACX,CAAC;gBAEF,oGAAoG;gBACpG,2EAA2E;gBAC3E,qHAAqH;gBACrH,iFAAiF;gBACjF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,qBAAqB,EACzC,UAAU,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,CACtD,CAAC;gBAEF,MAAM,IAAA,gCAAW,EACf;oBACE,IAAI,EAAE,sCAAiB,CAAC,oBAAoB;iBAC7C,EACD,KAAK,CACN,CAAC;gBAEF,IAAI,IAAA,oBAAQ,EAAC,MAAM,CAAC,EAAE;oBACpB,IAAI,IAAA,oBAAQ,EAAC,MAAM,CAAC,EAAE;wBACpB,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,IAAA,sBAAY,EAAC,MAAM,CAAC,KAAK,CAAC;4BACjD,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC;4BAC3C,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;wBAC5C,MAAM,IAAA,gCAAW,EACf;4BACE,IAAI,EAAE,sCAAiB,CAAC,cAAc;4BACtC,KAAK;4BACL,OAAO;yBACR,EACD,KAAK,CACN,CAAC;qBACH;yBAAM,IAAI,IAAA,sBAAU,EAAM,MAAM,CAAC,EAAE;wBAClC,MAAM,IAAA,gCAAW,EACf;4BACE,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;4BACzC,MAAM,EAAE,MAAM,CAAC,KAAK;yBACrB,EACD,KAAK,CACN,CAAC;qBACH;iBACF;gBAED,OAAO,MAAM,CAAC;YAChB,CAAC;YAED;;;;;;;;;;;eAWG;YACH,KAAK,UAAU,yBAAyB,CACtC,eAAoC,EACpC,kBAAqE;gBAErE,MAAM,oBAAoB,GAAwB,EAAE,CAAC;gBACrD,MAAM,iBAAiB,GAAoB,EAAE,CAAC;gBAC9C,IAAI,WAA2D,CAAC;gBAChE,MAAM,UAAU,GAAgB,IAAI,GAAG,CACrC,eAAe,CAAC,GAAG,CAAC,+BAAU,CAAC,CAChC,CAAC;gBAEF,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,kBAAkB,EAAE;oBAC5C,MAAM,EAAE,GAAG,IAAA,+BAAU,EAAC,KAAK,CAAC,CAAC;oBAC7B,oFAAoF;oBACpF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;wBACvB,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC9B,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;qBACpB;oBACD,IAAI,IAAA,wCAAmB,EAAC,KAAK,CAAC,IAAI,IAAA,qCAAgB,EAAC,KAAK,CAAC,EAAE;wBACzD,WAAW,GAAG,KAAK,CAAC;qBACrB;oBACD,0DAA0D;oBAC1D,IAAI,IAAA,sCAAiB,EAAC,KAAK,CAAC,IAAI,IAAA,mCAAc,EAAC,KAAK,CAAC,EAAE;wBACrD,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAClC;iBACF;gBAED,OAAO;oBACL,oBAAoB;oBACpB,SAAS,EAAE,iBAAiB;oBAC5B,WAAW;iBACZ,CAAC;YACJ,CAAC;QACH,CAAC;QAED,KAAK,UAAU,WAAW;YACxB,eAAe,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACtC,eAAe;YACf,MAAM,OAAO,GAAG,MAAM,IAAA,gBAAK,EACzB,OAAO,EACP,kCAAmB,CAAC,mBAAmB,EACvC,KAAK,IAAI,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAAC,CAC1D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,mBAAmB,EACvC,OAAO,CAAC,MAAM,CACf,CAAC;YAEF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED;;WAEG;QACH,KAAK,UAAU,+BAA+B,CAAC,SAA0B;YACvE,MAAM,IAAA,gBAAK,EACT,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CAAC,sBAAsB,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,CAAC,CAC/D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,kBAAkB,EACtC,SAAS,CAAC,MAAM,CACjB,CAAC;QACJ,CAAC;QAED;;;;;WAKG;QACH,KAAK,UAAU,aAAa,CAAC,oBAAyC;YACpE,OAAO,CAAC,KAAK,CACX,qBAAqB,EACrB,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,CACrC,CAAC;YAEF,8CAA8C;YAC9C,yHAAyH;YACzH,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,MAAM,IAAA,gBAAK,EAChD,OAAO,EACP,kCAAmB,CAAC,mBAAmB,EACvC,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;gBAClC,WAAW;gBACX,MAAM,EAAE,oBAAoB;aAC7B,CAAC,CACL,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,kBAAkB,EACtC,oBAAoB,CAAC,MAAM,CAC5B,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,iBAAiB,EACrC,mBAAmB,EACnB,cAAI,CAAC,KAAK,CACX,CAAC;QACJ,CAAC;QAED,KAAK,UAAU,qBAAqB,CAClC,WAAgD;YAEhD,wEAAwE;YACxE,IAAI,WAAW,EAAE;gBACf,IAAI,IAAA,qCAAgB,EAAC,WAAW,CAAC,EAAE;oBACjC,MAAM,SAAS,GAAG,MAAM,IAAA,gBAAK,EAC3B,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;wBAClC,WAAW;wBACX,KAAK,EAAE,WAAW,CAAC,KAAK;wBACxB,OAAO,EAAE,WAAW,CAAC,OAAO;qBAC7B,CAAC,CACL,CAAC;oBAEF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;qBAAM,IAAI,IAAA,wCAAmB,EAAC,WAAW,CAAC,EAAE;oBAC3C,MAAM,SAAS,GAAG,MAAM,IAAA,gBAAK,EAC3B,OAAO,EACP,kCAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,gBAAgB,CAAC;wBACrC,WAAW;wBACX,MAAM,EAAE,WAAW,CAAC,MAAM;qBAC3B,CAAC,CACL,CAAC;oBACF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;aACF;QACH,CAAC;QAED;;;;WAIG;QACH,KAAK,UAAU,eAAe,CAC5B,QAAmB;YAEnB,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC5D,0BAA0B;YAC1B,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACvB,eAAe,CAAC,cAAc,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,CAAC,CACtE,CACF,CAAC;QACJ,CAAC;QAED,SAAS,iBAAiB;YACxB,MAAM,OAAO,GAAG,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpD,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAC/B,OAAO,CAAC,YAAY,CAAC,4BAAa,CAAC,iBAAiB,CAAC,CAAC;YACtD,OAAO,CAAC,aAAa,CAAC;gBACpB,CAAC,4BAAa,CAAC,qBAAqB,CAAC,EAAE,QAAQ,CAAC,YAAY;aAC7D,CAAC,CAAC;YACH,oDAAoD;YACpD,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACnE,2EAA2E;YAC3E,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAExE,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;YAClE,OAAO,CAAC,WAAW,CACjB,kCAAmB,CAAC,OAAO,EAC3B,kCAAmB,CAAC,SAAS,CAC9B,CAAC;YACF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,SAAS,2BAA2B,CAClC,SAA+C;YAE/C,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,iBAAiB,EACrC,SAAS,CAAC,MAAM,KAAK,8BAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtD,cAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,eAAe,EACnC,SAAS,CAAC,MAAM,KAAK,8BAAe,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACtD,cAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,sBAAsB,EAC1C,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;gBACnC,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAC1C,CAAC;YACF,IAAI,IAAA,mCAAoB,EAAC,SAAS,CAAC,EAAE;gBACnC,OAAO,CAAC,SAAS,CACf,kCAAmB,CAAC,oBAAoB,EACxC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAC9D,cAAI,CAAC,KAAK,CACX,CAAC;aACH;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAxdD,gDAwdC;AAED,mDAAmD;AACnD,SAAS,eAAe,CACtB,OAAsB,EACtB,MAAuB,EACvB,GAAS;IAET,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,qCAAgB,CAAC,CAAC;IAC7D,IAAI,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;QACnC,MAAM,sBAAsB,GAAG,oBAAoB,CAAC,GAAG,CACrD,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CACvD,CAAC;QACF,MAAM,GAAG,GACP,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACjD,sBAAsB,CAAC,MAAM,CAAC;QAChC,OAAO,CAAC,WAAW,CAAC,kCAAmB,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;KACnE;AACH,CAAC","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  isWorkflowSucceeded,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowSucceeded,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowRunCompleted,\n  WorkflowRunStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  SucceededExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isSucceededExecution,\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 { groupBy, promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\nimport { WorkflowTask } from \"../../tasks.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\nexport interface Orchestrator {\n  (workflowTasks: WorkflowTask[], baseTime?: Date): Promise<OrchestratorResult>;\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): Orchestrator {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (workflowTasks, baseTime = new Date()) => {\n    const tasksByExecutionId = groupBy(\n      workflowTasks,\n      (task) => task.executionId\n    );\n\n    const eventsByExecutionId = Object.fromEntries(\n      Object.entries(tasksByExecutionId).map(([executionId, records]) => [\n        executionId,\n        records.flatMap((e) => e.events),\n      ])\n    );\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, baseTime);\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    baseTime: Date\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = baseTime;\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<WorkflowRunStarted>(\n          {\n            type: WorkflowEventType.WorkflowRunStarted,\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                    {\n                      type: WorkflowEventType.WorkflowTimedOut,\n                    },\n                    start\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                baseTime\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<WorkflowRunCompleted>(\n          {\n            type: WorkflowEventType.WorkflowRunCompleted,\n          },\n          start\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              {\n                type: WorkflowEventType.WorkflowFailed,\n                error,\n                message,\n              },\n              start\n            );\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowSucceeded>(\n              {\n                type: WorkflowEventType.WorkflowSucceeded,\n                output: result.value,\n              },\n              start\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: WorkflowSucceeded | 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 (isWorkflowSucceeded(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?: WorkflowSucceeded | 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 (isWorkflowSucceeded(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.succeedExecution({\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: SucceededExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.SUCCEEDED ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.SUCCEEDED ? 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 (isSucceededExecution(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"]}

@@ -153,3 +153,3 @@ export declare namespace MetricsCommon {

*/
const ActivityCompleted = "ActivityCompleted";
const ActivitySucceeded = "ActivitySucceeded";
/**

@@ -156,0 +156,0 @@ * The total duration of the activity after being scheduled, including the time

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

*/
ActivityMetrics.ActivityCompleted = "ActivityCompleted";
ActivityMetrics.ActivitySucceeded = "ActivitySucceeded";
/**

@@ -183,2 +183,2 @@ * The total duration of the activity after being scheduled, including the time

})(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":["/* 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"]}
//# 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 ActivitySucceeded = \"ActivitySucceeded\";\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"]}

@@ -50,3 +50,3 @@ import { EventEnvelope } from "./event.js";

/**
* Successfully Completes an async activity with the given value.
* Succeeds an async activity with the given value.
*/

@@ -66,2 +66,5 @@ sendActivitySuccess(request: Omit<SendActivitySuccessRequest, "type">): Promise<void>;

export interface StartExecutionResponse {
/**
* ID of the started workflow execution.
*/
executionId: string;

@@ -68,0 +71,0 @@ }

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

exports.isSendActivityHeartbeatRequest = isSendActivityHeartbeatRequest;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-client.js","sourceRoot":"","sources":["../../src/service-client.ts"],"names":[],"mappings":";;;AA0KA,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,yCAAmB,CAAA;IACnB,yCAAmB,CAAA;IACnB,6CAAuB,CAAA;AACzB,CAAC,EAJW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAI7B;AAyBD,SAAgB,4BAA4B,CAC1C,OAA8B;IAE9B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAJD,oEAIC;AAED,SAAgB,4BAA4B,CAC1C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAJD,oEAIC;AAED,SAAgB,8BAA8B,CAC5C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,SAAS,CAAC;AACvD,CAAC;AAJD,wEAIC","sourcesContent":["import { EventEnvelope } from \"./event.js\";\nimport { Execution, ExecutionHandle, ExecutionStatus } from \"./execution.js\";\nimport { SendSignalRequest } from \"./runtime/clients/workflow-client.js\";\nimport { HistoryStateEvent, WorkflowEvent } from \"./workflow-events.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"./workflow.js\";\n\n/**\n * Top level Eventual Client used by systems outside of an Eventual Service to interact with it.\n */\nexport interface EventualServiceClient {\n  getWorkflows(): Promise<GetWorkflowResponse>;\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   */\n  startExecution<W extends Workflow>(\n    request: StartExecutionRequest<W>\n  ): Promise<ExecutionHandle<W>>;\n\n  /**\n   * Retrieves one or more workflow execution.\n   */\n  getExecutions(request: GetExecutionsRequest): Promise<GetExecutionsResponse>;\n\n  /**\n   * Retrieves a single workflow execution.\n   */\n  getExecution(executionId: string): Promise<Execution | undefined>;\n\n  /**\n   * Retrieves the workflow events for an execution.\n   */\n  getExecutionHistory(\n    request: ExecutionEventsRequest\n  ): Promise<ExecutionEventsResponse>;\n\n  /**\n   * Retrieves the workflow history events for an execution.\n   *\n   * @deprecated use {@link EventualServiceClient.getExecutionHistory}. This API will be removed in the future.\n   *\n   * TODO: Support the mixed use case of retrieving events and history events from\n   *       the {@link EventualServiceClient.getExecutionHistory} API.\n   */\n  getExecutionWorkflowHistory(\n    executionId: string\n  ): Promise<ExecutionHistoryResponse>;\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  sendSignal(request: SendSignalRequest): Promise<void>;\n\n  /**\n   * Publishes one or more events to the service.\n   */\n  publishEvents(request: PublishEventsRequest): Promise<void>;\n\n  /**\n   * Successfully Completes an async activity with the given value.\n   */\n  sendActivitySuccess(\n    request: Omit<SendActivitySuccessRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\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  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n}\n\nexport interface StartExecutionResponse {\n  executionId: string;\n}\n\nexport interface GetExecutionsRequest {\n  statuses?: ExecutionStatus[];\n  workflowName?: string;\n  nextToken?: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface GetExecutionsResponse {\n  executions: Execution[];\n  /**\n   * A token returned when there may be more executions to retrieve.\n   */\n  nextToken?: string;\n}\n\nexport interface PublishEventsRequest {\n  events: EventEnvelope<any>[];\n}\n\nexport interface ExecutionEventsRequest {\n  executionId: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  nextToken?: string;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface ExecutionEventsResponse {\n  events: WorkflowEvent[];\n  nextToken?: string;\n}\n\nexport interface ExecutionHistoryResponse {\n  events: HistoryStateEvent[];\n}\n\nexport type SortOrder = \"Asc\" | \"Desc\";\n\nexport interface StartExecutionRequest<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  workflow: string | W;\n  /**\n   * Input payload for the workflow function.\n   */\n  input: WorkflowInput<W>;\n}\n\nexport interface WorkflowReference {\n  name: string;\n}\n\nexport interface GetWorkflowResponse {\n  workflows: WorkflowReference[];\n}\n\nexport enum ActivityUpdateType {\n  Success = \"Success\",\n  Failure = \"Failure\",\n  Heartbeat = \"Heartbeat\",\n}\n\nexport type SendActivityUpdate<T = any> =\n  | SendActivitySuccessRequest<T>\n  | SendActivityFailureRequest\n  | SendActivityHeartbeatRequest;\n\nexport interface SendActivitySuccessRequest<T = any> {\n  type: ActivityUpdateType.Success;\n  activityToken: string;\n  result: T;\n}\n\nexport interface SendActivityFailureRequest {\n  type: ActivityUpdateType.Failure;\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface SendActivityHeartbeatRequest {\n  type: ActivityUpdateType.Heartbeat;\n  activityToken: string;\n}\n\nexport function isSendActivitySuccessRequest<T = any>(\n  request: SendActivityUpdate<T>\n): request is SendActivitySuccessRequest<T> {\n  return request.type === ActivityUpdateType.Success;\n}\n\nexport function isSendActivityFailureRequest(\n  request: SendActivityUpdate\n): request is SendActivityFailureRequest {\n  return request.type === ActivityUpdateType.Failure;\n}\n\nexport function isSendActivityHeartbeatRequest(\n  request: SendActivityUpdate\n): request is SendActivityHeartbeatRequest {\n  return request.type === ActivityUpdateType.Heartbeat;\n}\n\nexport type SendActivityUpdateResponse = SendActivityHeartbeatResponse | void;\n\nexport interface SendActivityHeartbeatResponse {\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 cancelled.\n   */\n  cancelled: boolean;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-client.js","sourceRoot":"","sources":["../../src/service-client.ts"],"names":[],"mappings":";;;AA6KA,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,yCAAmB,CAAA;IACnB,yCAAmB,CAAA;IACnB,6CAAuB,CAAA;AACzB,CAAC,EAJW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAI7B;AAyBD,SAAgB,4BAA4B,CAC1C,OAA8B;IAE9B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAJD,oEAIC;AAED,SAAgB,4BAA4B,CAC1C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAJD,oEAIC;AAED,SAAgB,8BAA8B,CAC5C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,SAAS,CAAC;AACvD,CAAC;AAJD,wEAIC","sourcesContent":["import { EventEnvelope } from \"./event.js\";\nimport { Execution, ExecutionHandle, ExecutionStatus } from \"./execution.js\";\nimport { SendSignalRequest } from \"./runtime/clients/workflow-client.js\";\nimport { HistoryStateEvent, WorkflowEvent } from \"./workflow-events.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"./workflow.js\";\n\n/**\n * Top level Eventual Client used by systems outside of an Eventual Service to interact with it.\n */\nexport interface EventualServiceClient {\n  getWorkflows(): Promise<GetWorkflowResponse>;\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   */\n  startExecution<W extends Workflow>(\n    request: StartExecutionRequest<W>\n  ): Promise<ExecutionHandle<W>>;\n\n  /**\n   * Retrieves one or more workflow execution.\n   */\n  getExecutions(request: GetExecutionsRequest): Promise<GetExecutionsResponse>;\n\n  /**\n   * Retrieves a single workflow execution.\n   */\n  getExecution(executionId: string): Promise<Execution | undefined>;\n\n  /**\n   * Retrieves the workflow events for an execution.\n   */\n  getExecutionHistory(\n    request: ExecutionEventsRequest\n  ): Promise<ExecutionEventsResponse>;\n\n  /**\n   * Retrieves the workflow history events for an execution.\n   *\n   * @deprecated use {@link EventualServiceClient.getExecutionHistory}. This API will be removed in the future.\n   *\n   * TODO: Support the mixed use case of retrieving events and history events from\n   *       the {@link EventualServiceClient.getExecutionHistory} API.\n   */\n  getExecutionWorkflowHistory(\n    executionId: string\n  ): Promise<ExecutionHistoryResponse>;\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  sendSignal(request: SendSignalRequest): Promise<void>;\n\n  /**\n   * Publishes one or more events to the service.\n   */\n  publishEvents(request: PublishEventsRequest): Promise<void>;\n\n  /**\n   * Succeeds an async activity with the given value.\n   */\n  sendActivitySuccess(\n    request: Omit<SendActivitySuccessRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\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  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n}\n\nexport interface StartExecutionResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface GetExecutionsRequest {\n  statuses?: ExecutionStatus[];\n  workflowName?: string;\n  nextToken?: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface GetExecutionsResponse {\n  executions: Execution[];\n  /**\n   * A token returned when there may be more executions to retrieve.\n   */\n  nextToken?: string;\n}\n\nexport interface PublishEventsRequest {\n  events: EventEnvelope<any>[];\n}\n\nexport interface ExecutionEventsRequest {\n  executionId: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  nextToken?: string;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface ExecutionEventsResponse {\n  events: WorkflowEvent[];\n  nextToken?: string;\n}\n\nexport interface ExecutionHistoryResponse {\n  events: HistoryStateEvent[];\n}\n\nexport type SortOrder = \"Asc\" | \"Desc\";\n\nexport interface StartExecutionRequest<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  workflow: string | W;\n  /**\n   * Input payload for the workflow function.\n   */\n  input: WorkflowInput<W>;\n}\n\nexport interface WorkflowReference {\n  name: string;\n}\n\nexport interface GetWorkflowResponse {\n  workflows: WorkflowReference[];\n}\n\nexport enum ActivityUpdateType {\n  Success = \"Success\",\n  Failure = \"Failure\",\n  Heartbeat = \"Heartbeat\",\n}\n\nexport type SendActivityUpdate<T = any> =\n  | SendActivitySuccessRequest<T>\n  | SendActivityFailureRequest\n  | SendActivityHeartbeatRequest;\n\nexport interface SendActivitySuccessRequest<T = any> {\n  type: ActivityUpdateType.Success;\n  activityToken: string;\n  result: T;\n}\n\nexport interface SendActivityFailureRequest {\n  type: ActivityUpdateType.Failure;\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface SendActivityHeartbeatRequest {\n  type: ActivityUpdateType.Heartbeat;\n  activityToken: string;\n}\n\nexport function isSendActivitySuccessRequest<T = any>(\n  request: SendActivityUpdate<T>\n): request is SendActivitySuccessRequest<T> {\n  return request.type === ActivityUpdateType.Success;\n}\n\nexport function isSendActivityFailureRequest(\n  request: SendActivityUpdate\n): request is SendActivityFailureRequest {\n  return request.type === ActivityUpdateType.Failure;\n}\n\nexport function isSendActivityHeartbeatRequest(\n  request: SendActivityUpdate\n): request is SendActivityHeartbeatRequest {\n  return request.type === ActivityUpdateType.Heartbeat;\n}\n\nexport type SendActivityUpdateResponse = SendActivityHeartbeatResponse | void;\n\nexport interface SendActivityHeartbeatResponse {\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 cancelled.\n   */\n  cancelled: boolean;\n}\n"]}

@@ -29,3 +29,3 @@ /**

* let done = false;
* mySignal.on(async () => {
* mySignal.onSignal(async () => {
* await sleepFor(10);

@@ -42,3 +42,3 @@ * done = true;

* ```ts
* const handler = mySignal.on(() => {});
* const handler = mySignal.onSignal(() => {});
*

@@ -50,3 +50,3 @@ * await sleepFor(10);

*/
on(handler: SignalHandlerFunction<Payload>): SignalsHandler;
onSignal(handler: SignalHandlerFunction<Payload>): SignalsHandler;
/**

@@ -60,3 +60,3 @@ * Waits for a signal to be received by the workflow.

* workflow("wf", async () => {
* const payload = await mySignal.expect();
* const payload = await mySignal.expectSignal();
*

@@ -74,3 +74,3 @@ * return payload;

* try {
* const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });
* const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });
*

@@ -84,3 +84,3 @@ * return payload;

*/
expect(opts?: ExpectSignalOptions): Promise<Payload>;
expectSignal(opts?: ExpectSignalOptions): Promise<Payload>;
/**

@@ -92,7 +92,7 @@ * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.

* workflow("wf", async () => {
* mySignal.send("payload");
* mySignal.sendSignal("payload");
* })
* ```
*/
send(executionId: string, ...args: SendSignalProps<Payload>): Promise<void>;
sendSignal(executionId: string, ...args: SendSignalProps<Payload>): Promise<void>;
}

@@ -124,4 +124,3 @@ export type SignalPayload<E extends Signal<any>> = E extends Signal<infer P> ? P : never;

*/
export declare function expectSignal<SignalPayload = any>(signalId: string, opts?: ExpectSignalOptions): Promise<SignalPayload>;
export declare function expectSignal<E extends Signal<any>>(signal: E, opts?: ExpectSignalOptions): Promise<SignalPayload<E>>;
export declare function expectSignal<SignalPayload = any>(signal: Signal<SignalPayload> | string, opts?: ExpectSignalOptions): Promise<SignalPayload>;
/**

@@ -156,5 +155,4 @@ * Listens for a signal matching the signalId provided.

*/
export declare function onSignal<E extends Signal<any>>(signal: E, handler: SignalHandlerFunction<SignalPayload<E>>): SignalsHandler;
export declare function onSignal<Payload = void>(signalId: string, handler: SignalHandlerFunction<Payload>): SignalsHandler;
export type SendSignalProps<SignalPayload> = [SignalPayload] extends [undefined] | [void] ? [id?: string] : [payload: SignalPayload, id?: string];
export declare function onSignal<Payload>(signal: Signal<Payload> | string, handler: SignalHandlerFunction<Payload>): SignalsHandler;
export type SendSignalProps<SignalPayload> = [SignalPayload] extends [undefined] | [void] ? [] : [payload: SignalPayload];
/**

@@ -173,4 +171,3 @@ * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.

*/
export declare function sendSignal<S extends Signal<any>>(executionId: string, signal: S, ...args: SendSignalProps<SignalPayload<S>>): Promise<void>;
export declare function sendSignal<Payload = any>(executionId: string, signalId: string, ...args: SendSignalProps<Payload>): Promise<void>;
export declare function sendSignal<Payload = any>(executionId: string, signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
export type SignalTarget = ExecutionTarget | ChildExecutionTarget;

@@ -177,0 +174,0 @@ export declare enum SignalTargetType {

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

* let done = false;
* mySignal.on(async () => {
* mySignal.onSignal(async () => {
* await sleepFor(10);

@@ -43,3 +43,3 @@ * done = true;

* ```ts
* const handler = mySignal.on(() => {});
* const handler = mySignal.onSignal(() => {});
*

@@ -51,3 +51,3 @@ * await sleepFor(10);

*/
on(handler) {
onSignal(handler) {
return onSignal(this, handler);

@@ -63,3 +63,3 @@ }

* workflow("wf", async () => {
* const payload = await mySignal.expect();
* const payload = await mySignal.expectSignal();
*

@@ -77,3 +77,3 @@ * return payload;

* try {
* const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });
* const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });
*

@@ -87,3 +87,3 @@ * return payload;

*/
expect(opts) {
expectSignal(opts) {
return expectSignal(this, opts);

@@ -97,7 +97,7 @@ }

* workflow("wf", async () => {
* mySignal.send("payload");
* mySignal.sendSignal("payload");
* })
* ```
*/
send(executionId, ...args) {
sendSignal(executionId, ...args) {
return sendSignal(executionId, this, ...args);

@@ -107,2 +107,18 @@ }

exports.Signal = Signal;
/**
* Waits for a signal to be received by the workflow.
*
* The first signal received will resolve the Promise with the payload of the promise.
*
* ```ts
* workflow("wf", () => {
* const payload = await expectSignal("MySignal");
*
* return payload;
* });
* ```
*
* Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject
* when the provided time has elapsed.
*/
function expectSignal(signal, opts) {

@@ -115,2 +131,31 @@ if (!(0, flags_js_1.isOrchestratorWorker)()) {

exports.expectSignal = expectSignal;
/**
* Listens for a signal matching the signalId provided.
*
* When the signal is received, the handler is invoked.
* If the handler return a promise, the handler is added as a {@link Chain}
* and progressed until completion.
*
* ```ts
* workflow("wf", () => {
* let done = false;
* onSignal("MySignal", async () => {
* await sleepFor(10);
* done = true;
* });
*
* await condition(() => done);
* });
* ```
*
* To remove the handler, call the dispose method.
*
* ```ts
* const handler = onSignal("MySignal", () => {});
*
* await sleepFor(10);
*
* handler.dispose();
* ```
*/
function onSignal(signal, handler) {

@@ -123,3 +168,17 @@ if (!(0, flags_js_1.isOrchestratorWorker)()) {

exports.onSignal = onSignal;
function sendSignal(executionId, signal, payload, id) {
/**
* Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.
*
* ```ts
* const mySignal = signal<string>("MySignal");
* workflow("wf", async () => {
* sendSignal("mySignal", "payload");
* sendSignal(mySignal, "payload");
* })
* ```
*
* @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.
*/
function sendSignal(executionId, signal, ...args) {
const [payload] = args;
if ((0, flags_js_1.isOrchestratorWorker)()) {

@@ -132,3 +191,3 @@ return (0, send_signal_call_js_1.createSendSignalCall)({ type: SignalTargetType.Execution, executionId }, typeof signal === "string" ? signal : signal.id, payload);

signal,
id: id ?? (0, ulidx_1.ulid)(),
id: (0, ulidx_1.ulid)(),
payload,

@@ -152,2 +211,2 @@ });

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,2CAA+C;AAC/C,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,4BAAgB,GAAE,CAAC,UAAU,CAAC;YACnC,SAAS,EAAE,WAAW;YACtB,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 { getServiceClient } 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 = 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 = 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 = 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 = 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 = 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 getServiceClient().sendSignal({\n      execution: 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 { getServiceClient } 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 = signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.onSignal(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.onSignal(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  public onSignal(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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expectSignal();\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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  public expectSignal(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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.sendSignal(\"payload\");\n   * })\n   * ```\n   */\n  public sendSignal(\n    executionId: string,\n    ...args: SendSignalProps<Payload>\n  ): Promise<void> {\n    return sendSignal(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  signal: Signal<SignalPayload> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload> {\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<Payload>(\n  signal: Signal<Payload> | string,\n  handler: SignalHandlerFunction<Payload>\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  ? []\n  : [payload: SignalPayload];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = 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<Payload = any>(\n  executionId: string,\n  signal: string | Signal<Payload>,\n  ...args: SendSignalProps<Payload>\n): Promise<void> {\n  const [payload] = args;\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 getServiceClient().sendSignal({\n      execution: executionId,\n      signal,\n      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"]}

@@ -15,3 +15,3 @@ import { ExecutionContext } from "./context.js";

export declare enum WorkflowEventType {
ActivityCompleted = "ActivityCompleted",
ActivitySucceeded = "ActivitySucceeded",
ActivityFailed = "ActivityFailed",

@@ -21,3 +21,3 @@ ActivityHeartbeatTimedOut = "ActivityHeartbeatTimedOut",

ActivityTimedOut = "ActivityTimedOut",
ChildWorkflowCompleted = "ChildWorkflowCompleted",
ChildWorkflowSucceeded = "ChildWorkflowSucceeded",
ChildWorkflowFailed = "ChildWorkflowFailed",

@@ -34,7 +34,7 @@ ChildWorkflowScheduled = "ChildWorkflowScheduled",

SleepScheduled = "SleepScheduled",
WorkflowCompleted = "WorkflowCompleted",
WorkflowSucceeded = "WorkflowSucceeded",
WorkflowFailed = "WorkflowFailed",
WorkflowStarted = "WorkflowStarted",
WorkflowTaskCompleted = "TaskCompleted",
WorkflowTaskStarted = "TaskStarted",
WorkflowRunCompleted = "WorkflowRunCompleted",
WorkflowRunStarted = "WorkflowRunStarted",
WorkflowTimedOut = "WorkflowTimedOut"

@@ -45,5 +45,5 @@ }

*/
export type WorkflowEvent = HistoryEvent | WorkflowTaskCompleted | WorkflowTaskStarted | WorkflowCompleted | WorkflowFailed | WorkflowStarted;
export type WorkflowEvent = HistoryEvent | WorkflowRunCompleted | WorkflowRunStarted | WorkflowSucceeded | WorkflowFailed | WorkflowStarted;
export type ScheduledEvent = ActivityScheduled | ChildWorkflowScheduled | ConditionStarted | EventsPublished | ExpectSignalStarted | SignalSent | SleepScheduled;
export type CompletedEvent = ActivityCompleted | ChildWorkflowCompleted | SleepCompleted;
export type SucceededEvent = ActivitySucceeded | ChildWorkflowSucceeded | SleepCompleted;
export type FailedEvent = ActivityFailed | ActivityHeartbeatTimedOut | ActivityTimedOut | ChildWorkflowFailed | ConditionTimedOut | ExpectSignalTimedOut;

@@ -53,3 +53,3 @@ /**

*/
export type HistoryEvent = CompletedEvent | FailedEvent | ScheduledEvent | SignalReceived | WorkflowTimedOut;
export type HistoryEvent = SucceededEvent | FailedEvent | ScheduledEvent | SignalReceived | WorkflowTimedOut;
export declare function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent;

@@ -76,4 +76,4 @@ /**

}
export interface WorkflowTaskStarted extends BaseEvent {
type: WorkflowEventType.WorkflowTaskStarted;
export interface WorkflowRunStarted extends BaseEvent {
type: WorkflowEventType.WorkflowRunStarted;
/**

@@ -89,4 +89,4 @@ * An execution ID of the parent workflow execution that

}
export interface ActivityCompleted extends HistoryEventBase {
type: WorkflowEventType.ActivityCompleted;
export interface ActivitySucceeded extends HistoryEventBase {
type: WorkflowEventType.ActivitySucceeded;
result: any;

@@ -102,7 +102,7 @@ }

}
export interface WorkflowTaskCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowTaskCompleted;
export interface WorkflowRunCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowRunCompleted;
}
export interface WorkflowCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowCompleted;
export interface WorkflowSucceeded extends BaseEvent {
type: WorkflowEventType.WorkflowSucceeded;
output: any;

@@ -120,4 +120,4 @@ }

}
export interface ChildWorkflowCompleted extends HistoryEventBase {
type: WorkflowEventType.ChildWorkflowCompleted;
export interface ChildWorkflowSucceeded extends HistoryEventBase {
type: WorkflowEventType.ChildWorkflowSucceeded;
result: any;

@@ -131,5 +131,5 @@ }

export declare function isWorkflowStarted(event: WorkflowEvent): event is WorkflowStarted;
export declare function isTaskStarted(event: WorkflowEvent): event is WorkflowTaskStarted;
export declare function isWorkflowRunStarted(event: WorkflowEvent): event is WorkflowRunStarted;
export declare function isActivityScheduled(event: WorkflowEvent): event is ActivityScheduled;
export declare function isActivityCompleted(event: WorkflowEvent): event is ActivityCompleted;
export declare function isActivitySucceeded(event: WorkflowEvent): event is ActivitySucceeded;
export declare function isActivityFailed(event: WorkflowEvent): event is ActivityFailed;

@@ -146,7 +146,7 @@ export declare function isActivityHeartbeatTimedOut(event: WorkflowEvent): event is ActivityHeartbeatTimedOut;

}
export declare function isTaskCompleted(event: WorkflowEvent): event is WorkflowTaskCompleted;
export declare function isWorkflowCompleted(event: WorkflowEvent): event is WorkflowCompleted;
export declare function isWorkflowRunCompleted(event: WorkflowEvent): event is WorkflowRunCompleted;
export declare function isWorkflowSucceeded(event: WorkflowEvent): event is WorkflowSucceeded;
export declare function isWorkflowFailed(event: WorkflowEvent): event is WorkflowFailed;
export declare function isChildWorkflowScheduled(event: WorkflowEvent): event is ChildWorkflowScheduled;
export declare function isChildWorkflowCompleted(event: WorkflowEvent): event is ChildWorkflowCompleted;
export declare function isChildWorkflowSucceeded(event: WorkflowEvent): event is ChildWorkflowSucceeded;
export declare function isChildWorkflowFailed(event: WorkflowEvent): event is ChildWorkflowFailed;

@@ -200,3 +200,3 @@ export declare function isSleepCompleted(event: WorkflowEvent): event is SleepCompleted;

export declare const isScheduledEvent: (a: any) => a is ActivityScheduled | ChildWorkflowScheduled | ConditionStarted | EventsPublished | ExpectSignalStarted | SignalSent | SleepScheduled;
export declare const isCompletedEvent: (a: any) => a is ActivityCompleted | ChildWorkflowCompleted | SleepCompleted;
export declare const isSucceededEvent: (a: any) => a is ActivitySucceeded | ChildWorkflowSucceeded | SleepCompleted;
export declare const isFailedEvent: (a: any) => a is ActivityFailed | ActivityHeartbeatTimedOut | ActivityTimedOut | ChildWorkflowFailed | ConditionTimedOut | ExpectSignalTimedOut | WorkflowTimedOut;

@@ -203,0 +203,0 @@ export declare function assertEventType<T extends WorkflowEvent>(event: any, type: T["type"]): asserts event is T;

"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.createEvent = exports.filterEvents = exports.getEventId = exports.assertEventType = exports.isFailedEvent = exports.isCompletedEvent = exports.isScheduledEvent = exports.isWorkflowTimedOut = exports.isActivityTimedOut = exports.isConditionTimedOut = exports.isConditionStarted = exports.isEventsPublished = exports.isSignalSent = exports.isSignalReceived = exports.isExpectSignalTimedOut = exports.isExpectSignalStarted = exports.isSleepCompleted = exports.isChildWorkflowFailed = exports.isChildWorkflowCompleted = exports.isChildWorkflowScheduled = exports.isWorkflowFailed = exports.isWorkflowCompleted = exports.isTaskCompleted = exports.isSleepScheduled = exports.isActivityHeartbeatTimedOut = exports.isActivityFailed = exports.isActivityCompleted = exports.isActivityScheduled = exports.isTaskStarted = exports.isWorkflowStarted = exports.isHistoryEvent = exports.WorkflowEventType = void 0;
exports.createEvent = exports.filterEvents = exports.getEventId = exports.assertEventType = exports.isFailedEvent = exports.isSucceededEvent = exports.isScheduledEvent = exports.isWorkflowTimedOut = exports.isActivityTimedOut = exports.isConditionTimedOut = exports.isConditionStarted = exports.isEventsPublished = exports.isSignalSent = exports.isSignalReceived = exports.isExpectSignalTimedOut = exports.isExpectSignalStarted = exports.isSleepCompleted = exports.isChildWorkflowFailed = exports.isChildWorkflowSucceeded = exports.isChildWorkflowScheduled = exports.isWorkflowFailed = exports.isWorkflowSucceeded = exports.isWorkflowRunCompleted = exports.isSleepScheduled = exports.isActivityHeartbeatTimedOut = exports.isActivityFailed = exports.isActivitySucceeded = exports.isActivityScheduled = exports.isWorkflowRunStarted = exports.isWorkflowStarted = exports.isHistoryEvent = exports.WorkflowEventType = void 0;
const ulidx_1 = require("ulidx");

@@ -8,3 +8,3 @@ const util_js_1 = require("./util.js");

(function (WorkflowEventType) {
WorkflowEventType["ActivityCompleted"] = "ActivityCompleted";
WorkflowEventType["ActivitySucceeded"] = "ActivitySucceeded";
WorkflowEventType["ActivityFailed"] = "ActivityFailed";

@@ -14,3 +14,3 @@ WorkflowEventType["ActivityHeartbeatTimedOut"] = "ActivityHeartbeatTimedOut";

WorkflowEventType["ActivityTimedOut"] = "ActivityTimedOut";
WorkflowEventType["ChildWorkflowCompleted"] = "ChildWorkflowCompleted";
WorkflowEventType["ChildWorkflowSucceeded"] = "ChildWorkflowSucceeded";
WorkflowEventType["ChildWorkflowFailed"] = "ChildWorkflowFailed";

@@ -27,11 +27,11 @@ WorkflowEventType["ChildWorkflowScheduled"] = "ChildWorkflowScheduled";

WorkflowEventType["SleepScheduled"] = "SleepScheduled";
WorkflowEventType["WorkflowCompleted"] = "WorkflowCompleted";
WorkflowEventType["WorkflowSucceeded"] = "WorkflowSucceeded";
WorkflowEventType["WorkflowFailed"] = "WorkflowFailed";
WorkflowEventType["WorkflowStarted"] = "WorkflowStarted";
WorkflowEventType["WorkflowTaskCompleted"] = "TaskCompleted";
WorkflowEventType["WorkflowTaskStarted"] = "TaskStarted";
WorkflowEventType["WorkflowRunCompleted"] = "WorkflowRunCompleted";
WorkflowEventType["WorkflowRunStarted"] = "WorkflowRunStarted";
WorkflowEventType["WorkflowTimedOut"] = "WorkflowTimedOut";
})(WorkflowEventType = exports.WorkflowEventType || (exports.WorkflowEventType = {}));
function isHistoryEvent(event) {
return ((0, exports.isCompletedEvent)(event) ||
return ((0, exports.isSucceededEvent)(event) ||
(0, exports.isFailedEvent)(event) ||

@@ -47,6 +47,6 @@ (0, exports.isScheduledEvent)(event) ||

exports.isWorkflowStarted = isWorkflowStarted;
function isTaskStarted(event) {
return event.type === WorkflowEventType.WorkflowTaskStarted;
function isWorkflowRunStarted(event) {
return event.type === WorkflowEventType.WorkflowRunStarted;
}
exports.isTaskStarted = isTaskStarted;
exports.isWorkflowRunStarted = isWorkflowRunStarted;
function isActivityScheduled(event) {

@@ -56,6 +56,6 @@ return event.type === WorkflowEventType.ActivityScheduled;

exports.isActivityScheduled = isActivityScheduled;
function isActivityCompleted(event) {
return event.type === WorkflowEventType.ActivityCompleted;
function isActivitySucceeded(event) {
return event.type === WorkflowEventType.ActivitySucceeded;
}
exports.isActivityCompleted = isActivityCompleted;
exports.isActivitySucceeded = isActivitySucceeded;
function isActivityFailed(event) {

@@ -73,10 +73,10 @@ return event.type === WorkflowEventType.ActivityFailed;

exports.isSleepScheduled = isSleepScheduled;
function isTaskCompleted(event) {
return event.type === WorkflowEventType.WorkflowTaskCompleted;
function isWorkflowRunCompleted(event) {
return event.type === WorkflowEventType.WorkflowRunCompleted;
}
exports.isTaskCompleted = isTaskCompleted;
function isWorkflowCompleted(event) {
return event.type === WorkflowEventType.WorkflowCompleted;
exports.isWorkflowRunCompleted = isWorkflowRunCompleted;
function isWorkflowSucceeded(event) {
return event.type === WorkflowEventType.WorkflowSucceeded;
}
exports.isWorkflowCompleted = isWorkflowCompleted;
exports.isWorkflowSucceeded = isWorkflowSucceeded;
function isWorkflowFailed(event) {

@@ -90,6 +90,6 @@ return event.type === WorkflowEventType.WorkflowFailed;

exports.isChildWorkflowScheduled = isChildWorkflowScheduled;
function isChildWorkflowCompleted(event) {
return event.type === WorkflowEventType.ChildWorkflowCompleted;
function isChildWorkflowSucceeded(event) {
return event.type === WorkflowEventType.ChildWorkflowSucceeded;
}
exports.isChildWorkflowCompleted = isChildWorkflowCompleted;
exports.isChildWorkflowSucceeded = isChildWorkflowSucceeded;
function isChildWorkflowFailed(event) {

@@ -140,3 +140,3 @@ return event.type === WorkflowEventType.ChildWorkflowFailed;

exports.isScheduledEvent = (0, util_js_1.or)(isActivityScheduled, isChildWorkflowScheduled, isConditionStarted, isEventsPublished, isExpectSignalStarted, isSignalSent, isSleepScheduled);
exports.isCompletedEvent = (0, util_js_1.or)(isActivityCompleted, isChildWorkflowCompleted, isSleepCompleted);
exports.isSucceededEvent = (0, util_js_1.or)(isActivitySucceeded, isChildWorkflowSucceeded, isSleepCompleted);
exports.isFailedEvent = (0, util_js_1.or)(isActivityFailed, isActivityTimedOut, isActivityHeartbeatTimedOut, isChildWorkflowFailed, isConditionTimedOut, isExpectSignalTimedOut, isWorkflowTimedOut);

@@ -192,2 +192,2 @@ function assertEventType(event, type) {

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 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,\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  ActivitySucceeded = \"ActivitySucceeded\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowSucceeded = \"ChildWorkflowSucceeded\",\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  WorkflowSucceeded = \"WorkflowSucceeded\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowRunCompleted = \"WorkflowRunCompleted\",\n  WorkflowRunStarted = \"WorkflowRunStarted\",\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  | WorkflowRunCompleted\n  | WorkflowRunStarted\n  | WorkflowSucceeded\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 SucceededEvent =\n  | ActivitySucceeded\n  | ChildWorkflowSucceeded\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  | SucceededEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isSucceededEvent(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 WorkflowRunStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowRunStarted;\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 ActivitySucceeded extends HistoryEventBase {\n  type: WorkflowEventType.ActivitySucceeded;\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 WorkflowRunCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowRunCompleted;\n}\n\nexport interface WorkflowSucceeded extends BaseEvent {\n  type: WorkflowEventType.WorkflowSucceeded;\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 ChildWorkflowSucceeded extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowSucceeded;\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 isWorkflowRunStarted(\n  event: WorkflowEvent\n): event is WorkflowRunStarted {\n  return event.type === WorkflowEventType.WorkflowRunStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivitySucceeded(\n  event: WorkflowEvent\n): event is ActivitySucceeded {\n  return event.type === WorkflowEventType.ActivitySucceeded;\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 isWorkflowRunCompleted(\n  event: WorkflowEvent\n): event is WorkflowRunCompleted {\n  return event.type === WorkflowEventType.WorkflowRunCompleted;\n}\n\nexport function isWorkflowSucceeded(\n  event: WorkflowEvent\n): event is WorkflowSucceeded {\n  return event.type === WorkflowEventType.WorkflowSucceeded;\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 isChildWorkflowSucceeded(\n  event: WorkflowEvent\n): event is ChildWorkflowSucceeded {\n  return event.type === WorkflowEventType.ChildWorkflowSucceeded;\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 isSucceededEvent = or(\n  isActivitySucceeded,\n  isChildWorkflowSucceeded,\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,\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"]}

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

import { SendActivitySuccessRequest } from "./service-client.js";
import { SendActivityFailureRequest, SendActivityHeartbeatRequest, SendActivityHeartbeatResponse, SendActivitySuccessRequest } from "./service-client.js";
export interface ActivityOptions {

@@ -15,3 +15,3 @@ /**

* When set to a positive number, the activity must call {@link heartbeat} or
* {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.
* {@link EventualServiceClient.sendActivityHeartbeat} at least every heartbeatSeconds.
*

@@ -34,7 +34,7 @@ * If it fails to do so, the workflow will cancel the activity and throw an error.

* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publish({ token }));
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.on(async ({token}) => {
* await asyncActivity.complete({
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivitySuccess({
* activityToken: token,

@@ -46,3 +46,47 @@ * result: "done"

*/
complete(request: Omit<SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>, "type">): Promise<void>;
sendActivitySuccess(request: Omit<SendActivitySuccessRequest<Awaited<UnwrapAsync<Output>>>, "type">): Promise<void>;
/**
* Fail an activity request by its {@link SendActivityFailureRequest.activityToken}.
*
* This method is used in conjunction with {@link asyncResult} in an activity
* to perform asynchronous, long-running computations. For example:
*
* ```ts
* const tokenEvent = event("token");
*
* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivityFailure({
* activityToken: token,
* error: "MyError",
* message: "Something went wrong"
* });
* })
* ```
*/
sendActivityFailure(request: Omit<SendActivityFailureRequest, "type">): Promise<void>;
/**
* Heartbeat an activity request by its {@link SendActivityHeartbeatRequest.activityToken}.
*
* This method is used in conjunction with {@link asyncResult} in an activity
* to perform asynchronous, long-running computations. For example:
*
* ```ts
* const tokenEvent = event("token");
*
* const asyncActivity = activity("async", () => {
* return asyncResult<string>(token => tokenEvent.publishEvents({ token }));
* });
*
* tokenEvent.onEvent(async ({token}) => {
* await asyncActivity.sendActivityFailure({
* activityToken: token
* });
* })
* ```
*/
sendActivityHeartbeat(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
activityID: string;

@@ -68,3 +112,3 @@ }

* activity async. This allows the activity to defer sending a response from the
* current function and instead complete the activity with {@link WorkflowClient.completeActivity}.
* current function and instead complete the activity with {@link WorkflowClient.sendActivitySuccess}.
*

@@ -74,3 +118,3 @@ * ```ts

* activity("myActivity", () => {
* // tells the system that the completeActivity function will be called later with a string result.
* // tells the system that the sendActivitySuccess function will be called later with a string result.
* return asyncResult<string>(async (activityToken) => {

@@ -85,3 +129,3 @@ * // before exiting, send the activityToken to a sqs queue to be completed later

* @param tokenContext is a callback which provides the activityToken. The activity token is used
* to completeActivity and heartbeatActivity from outside of the
* to sendActivitySuccess and sendActivityHeartbeat from outside of the
* activity.

@@ -88,0 +132,0 @@ */

@@ -11,3 +11,3 @@ import { createActivityCall } from "./calls/activity-call.js";

* activity async. This allows the activity to defer sending a response from the
* current function and instead complete the activity with {@link WorkflowClient.completeActivity}.
* current function and instead complete the activity with {@link WorkflowClient.sendActivitySuccess}.
*

@@ -17,3 +17,3 @@ * ```ts

* activity("myActivity", () => {
* // tells the system that the completeActivity function will be called later with a string result.
* // tells the system that the sendActivitySuccess function will be called later with a string result.
* return asyncResult<string>(async (activityToken) => {

@@ -28,3 +28,3 @@ * // before exiting, send the activityToken to a sqs queue to be completed later

* @param tokenContext is a callback which provides the activityToken. The activity token is used
* to completeActivity and heartbeatActivity from outside of the
* to sendActivitySuccess and sendActivityHeartbeat from outside of the
* activity.

@@ -59,5 +59,11 @@ */

});
func.complete = async function (request) {
func.sendActivitySuccess = async function (request) {
return getServiceClient().sendActivitySuccess(request);
};
func.sendActivityFailure = async function (request) {
return getServiceClient().sendActivityFailure(request);
};
func.sendActivityHeartbeat = async function (request) {
return getServiceClient().sendActivityHeartbeat(request);
};
func.activityID = activityID;

@@ -75,2 +81,2 @@ return func;

}
//# 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,gBAAgB,GACjB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AA2E5E,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,yDAAyD;IACzD,kBAAkB,EAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;IAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;QACzE,IAAI,oBAAoB,EAAE,EAAE;YAC1B,+FAA+F;YAC/F,OAAO,kBAAkB,CACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;SACV;aAAM;YACL,4EAA4E;YAC5E,OAAO,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;SACzB;IACH,CAAC,CAAwC,CAAC;IAC1C,IAAI,CAAC,QAAQ,GAAG,KAAK,WAAW,OAAO;QACrC,OAAO,gBAAgB,EAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC7B,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  getServiceClient,\n} from \"./global.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { SendActivitySuccessRequest } from \"./service-client.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 SendActivitySuccessRequest.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: Omit<\n      SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>,\n      \"type\"\n    >\n  ): Promise<void>;\n\n  activityID: string;\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\nexport type ActivityArguments<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<infer Arguments extends any[]> ? Arguments : never;\n\nexport type ActivityOutput<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<any, infer Output> ? UnwrapAsync<Output> : never;\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  // register the handler to be looked up during execution.\n  callableActivities()[activityID] = handler;\n  const func = ((...args: Parameters<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      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    } else {\n      // calling the activity from outside the orchestrator just calls the handler\n      return handler(...args);\n    }\n  }) as ActivityFunction<Arguments, Output>;\n  func.complete = async function (request) {\n    return getServiceClient().sendActivitySuccess(request);\n  };\n  func.activityID = activityID;\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,gBAAgB,GACjB,MAAM,aAAa,CAAC;AACrB,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAmI5E,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,yDAAyD;IACzD,kBAAkB,EAAE,CAAC,UAAU,CAAC,GAAG,OAAO,CAAC;IAC3C,MAAM,IAAI,GAAG,CAAC,CAAC,GAAG,IAAqD,EAAE,EAAE;QACzE,IAAI,oBAAoB,EAAE,EAAE;YAC1B,+FAA+F;YAC/F,OAAO,kBAAkB,CACvB,UAAU,EACV,IAAI,EACJ,IAAI,EAAE,cAAc,EACpB,IAAI,EAAE,gBAAgB,CAChB,CAAC;SACV;aAAM;YACL,4EAA4E;YAC5E,OAAO,OAAO,CAAC,GAAG,IAAI,CAAC,CAAC;SACzB;IACH,CAAC,CAAwC,CAAC;IAC1C,IAAI,CAAC,mBAAmB,GAAG,KAAK,WAAW,OAAO;QAChD,OAAO,gBAAgB,EAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,mBAAmB,GAAG,KAAK,WAAW,OAAO;QAChD,OAAO,gBAAgB,EAAE,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC;IACzD,CAAC,CAAC;IACF,IAAI,CAAC,qBAAqB,GAAG,KAAK,WAAW,OAAO;QAClD,OAAO,gBAAgB,EAAE,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC;IAC3D,CAAC,CAAC;IACF,IAAI,CAAC,UAAU,GAAG,UAAU,CAAC;IAC7B,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  getServiceClient,\n} from \"./global.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\nimport {\n  EventualServiceClient,\n  SendActivityFailureRequest,\n  SendActivityHeartbeatRequest,\n  SendActivityHeartbeatResponse,\n  SendActivitySuccessRequest,\n} from \"./service-client.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 EventualServiceClient.sendActivityHeartbeat} 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 SendActivitySuccessRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivitySuccess({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  sendActivitySuccess(\n    request: Omit<\n      SendActivitySuccessRequest<Awaited<UnwrapAsync<Output>>>,\n      \"type\"\n    >\n  ): Promise<void>;\n\n  /**\n   * Fail an activity request by its {@link SendActivityFailureRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivityFailure({\n   *     activityToken: token,\n   *     error: \"MyError\",\n   *     message: \"Something went wrong\"\n   *   });\n   * })\n   * ```\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Heartbeat an activity request by its {@link SendActivityHeartbeatRequest.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.publishEvents({ token }));\n   * });\n   *\n   * tokenEvent.onEvent(async ({token}) => {\n   *   await asyncActivity.sendActivityFailure({\n   *     activityToken: token\n   *   });\n   * })\n   * ```\n   */\n  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n\n  activityID: string;\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\nexport type ActivityArguments<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<infer Arguments extends any[]> ? Arguments : never;\n\nexport type ActivityOutput<A extends ActivityFunction<any, any>> =\n  A extends ActivityFunction<any, infer Output> ? UnwrapAsync<Output> : never;\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.sendActivitySuccess}.\n *\n * ```ts\n * const sqs = new SQSClient();\n * activity(\"myActivity\", () => {\n *    // tells the system that the sendActivitySuccess 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 sendActivitySuccess and sendActivityHeartbeat 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  // register the handler to be looked up during execution.\n  callableActivities()[activityID] = handler;\n  const func = ((...args: Parameters<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      return createActivityCall(\n        activityID,\n        args,\n        opts?.timeoutSeconds,\n        opts?.heartbeatSeconds\n      ) as any;\n    } else {\n      // calling the activity from outside the orchestrator just calls the handler\n      return handler(...args);\n    }\n  }) as ActivityFunction<Arguments, Output>;\n  func.sendActivitySuccess = async function (request) {\n    return getServiceClient().sendActivitySuccess(request);\n  };\n  func.sendActivityFailure = async function (request) {\n    return getServiceClient().sendActivityFailure(request);\n  };\n  func.sendActivityHeartbeat = async function (request) {\n    return getServiceClient().sendActivityHeartbeat(request);\n  };\n  func.activityID = activityID;\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"]}

@@ -16,3 +16,4 @@ import { createEventual, EventualKind, isEventualOfKind, } from "../eventual.js";

// this reference will be resolved by the runtime.
call.signal = function (signal, payload, id) {
call.sendSignal = function (signal, payload) {
const signalId = typeof signal === "string" ? signal : signal.id;
return createSendSignalCall({

@@ -22,6 +23,6 @@ type: SignalTargetType.ChildExecution,

workflowName: call.name,
}, signal.id, payload, id);
}, signalId, payload);
};
return call;
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxjQUFjLEVBR2QsWUFBWSxFQUNaLGdCQUFnQixHQUNqQixNQUFNLGdCQUFnQixDQUFDO0FBRXhCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFN0QsTUFBTSxVQUFVLGNBQWMsQ0FBSSxDQUFjO0lBQzlDLE9BQU8sZ0JBQWdCLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUMsQ0FBQztBQUN4RCxDQUFDO0FBY0QsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxJQUFZLEVBQ1osS0FBVyxFQUNYLElBQXNCO0lBRXRCLE1BQU0sSUFBSSxHQUFHLGdCQUFnQixDQUMzQixjQUFjLENBQWUsWUFBWSxDQUFDLFlBQVksRUFBRTtRQUN0RCxLQUFLO1FBQ0wsSUFBSTtRQUNKLElBQUk7S0FDVyxDQUFDLENBQ25CLENBQUM7SUFFRixvRkFBb0Y7SUFDcEYsa0RBQWtEO0lBQ2xELElBQUksQ0FBQyxNQUFNLEdBQUcsVUFBVSxNQUFNLEVBQUUsT0FBUSxFQUFFLEVBQUc7UUFDM0MsT0FBTyxvQkFBb0IsQ0FDekI7WUFDRSxJQUFJLEVBQUUsZ0JBQWdCLENBQUMsY0FBYztZQUNyQyxHQUFHLEVBQUUsSUFBSSxDQUFDLEdBQUk7WUFDZCxZQUFZLEVBQUUsSUFBSSxDQUFDLElBQUk7U0FDeEIsRUFDRCxNQUFNLENBQUMsRUFBRSxFQUNULE9BQU8sRUFDUCxFQUFFLENBQ2UsQ0FBQztJQUN0QixDQUFDLENBQUM7SUFFRixPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBjcmVhdGVFdmVudHVhbCxcbiAgRXZlbnR1YWwsXG4gIEV2ZW50dWFsQmFzZSxcbiAgRXZlbnR1YWxLaW5kLFxuICBpc0V2ZW50dWFsT2ZLaW5kLFxufSBmcm9tIFwiLi4vZXZlbnR1YWwuanNcIjtcbmltcG9ydCB7IENoaWxkRXhlY3V0aW9uIH0gZnJvbSBcIi4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgcmVnaXN0ZXJFdmVudHVhbCB9IGZyb20gXCIuLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IFJlc3VsdCB9IGZyb20gXCIuLi9yZXN1bHQuanNcIjtcbmltcG9ydCB7IFNpZ25hbFRhcmdldFR5cGUgfSBmcm9tIFwiLi4vc2lnbmFscy5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3csIFdvcmtmbG93T3B0aW9ucyB9IGZyb20gXCIuLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1dvcmtmbG93Q2FsbDxUPihhOiBFdmVudHVhbDxUPik6IGEgaXMgV29ya2Zsb3dDYWxsPFQ+IHtcbiAgcmV0dXJuIGlzRXZlbnR1YWxPZktpbmQoRXZlbnR1YWxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXb3JrZmxvd0NhbGw8VCA9IGFueT5cbiAgZXh0ZW5kcyBFdmVudHVhbEJhc2U8RXZlbnR1YWxLaW5kLldvcmtmbG93Q2FsbCwgUmVzdWx0PFQ+PixcbiAgICBDaGlsZEV4ZWN1dGlvbiB7XG4gIG5hbWU6IHN0cmluZztcbiAgaW5wdXQ/OiBhbnk7XG4gIHNlcT86IG51bWJlcjtcbiAgb3B0cz86IFdvcmtmbG93T3B0aW9ucztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVdvcmtmbG93Q2FsbChcbiAgbmFtZTogc3RyaW5nLFxuICBpbnB1dD86IGFueSxcbiAgb3B0cz86IFdvcmtmbG93T3B0aW9uc1xuKTogV29ya2Zsb3dDYWxsIHtcbiAgY29uc3QgY2FsbCA9IHJlZ2lzdGVyRXZlbnR1YWwoXG4gICAgY3JlYXRlRXZlbnR1YWw8V29ya2Zsb3dDYWxsPihFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCB7XG4gICAgICBpbnB1dCxcbiAgICAgIG5hbWUsXG4gICAgICBvcHRzLFxuICAgIH0gYXMgV29ya2Zsb3dDYWxsKVxuICApO1xuXG4gIC8vIGNyZWF0ZSBhIHJlZmVyZW5jZSB0byB0aGUgY2hpbGQgd29ya2Zsb3cgc3RhcnRlZCBhdCBhIHNlcXVlbmNlIGluIHRoaXMgZXhlY3V0aW9uLlxuICAvLyB0aGlzIHJlZmVyZW5jZSB3aWxsIGJlIHJlc29sdmVkIGJ5IHRoZSBydW50aW1lLlxuICBjYWxsLnNpZ25hbCA9IGZ1bmN0aW9uIChzaWduYWwsIHBheWxvYWQ/LCBpZD8pIHtcbiAgICByZXR1cm4gY3JlYXRlU2VuZFNpZ25hbENhbGwoXG4gICAgICB7XG4gICAgICAgIHR5cGU6IFNpZ25hbFRhcmdldFR5cGUuQ2hpbGRFeGVjdXRpb24sXG4gICAgICAgIHNlcTogY2FsbC5zZXEhLFxuICAgICAgICB3b3JrZmxvd05hbWU6IGNhbGwubmFtZSxcbiAgICAgIH0sXG4gICAgICBzaWduYWwuaWQsXG4gICAgICBwYXlsb2FkLFxuICAgICAgaWRcbiAgICApIGFzIHVua25vd24gYXMgYW55O1xuICB9O1xuXG4gIHJldHVybiBjYWxsO1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctY2FsbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYWxscy93b3JrZmxvdy1jYWxsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxjQUFjLEVBR2QsWUFBWSxFQUNaLGdCQUFnQixHQUNqQixNQUFNLGdCQUFnQixDQUFDO0FBRXhCLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGNBQWMsQ0FBQztBQUVoRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFakQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFFN0QsTUFBTSxVQUFVLGNBQWMsQ0FBSSxDQUFjO0lBQzlDLE9BQU8sZ0JBQWdCLENBQUMsWUFBWSxDQUFDLFlBQVksRUFBRSxDQUFDLENBQUMsQ0FBQztBQUN4RCxDQUFDO0FBY0QsTUFBTSxVQUFVLGtCQUFrQixDQUNoQyxJQUFZLEVBQ1osS0FBVyxFQUNYLElBQXNCO0lBRXRCLE1BQU0sSUFBSSxHQUFHLGdCQUFnQixDQUMzQixjQUFjLENBQWUsWUFBWSxDQUFDLFlBQVksRUFBRTtRQUN0RCxLQUFLO1FBQ0wsSUFBSTtRQUNKLElBQUk7S0FDVyxDQUFDLENBQ25CLENBQUM7SUFFRixvRkFBb0Y7SUFDcEYsa0RBQWtEO0lBQ2xELElBQUksQ0FBQyxVQUFVLEdBQUcsVUFBVSxNQUFNLEVBQUUsT0FBUTtRQUMxQyxNQUFNLFFBQVEsR0FBRyxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUUsQ0FBQztRQUNqRSxPQUFPLG9CQUFvQixDQUN6QjtZQUNFLElBQUksRUFBRSxnQkFBZ0IsQ0FBQyxjQUFjO1lBQ3JDLEdBQUcsRUFBRSxJQUFJLENBQUMsR0FBSTtZQUNkLFlBQVksRUFBRSxJQUFJLENBQUMsSUFBSTtTQUN4QixFQUNELFFBQVEsRUFDUixPQUFPLENBQ1UsQ0FBQztJQUN0QixDQUFDLENBQUM7SUFFRixPQUFPLElBQUksQ0FBQztBQUNkLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBjcmVhdGVFdmVudHVhbCxcbiAgRXZlbnR1YWwsXG4gIEV2ZW50dWFsQmFzZSxcbiAgRXZlbnR1YWxLaW5kLFxuICBpc0V2ZW50dWFsT2ZLaW5kLFxufSBmcm9tIFwiLi4vZXZlbnR1YWwuanNcIjtcbmltcG9ydCB7IENoaWxkRXhlY3V0aW9uIH0gZnJvbSBcIi4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgcmVnaXN0ZXJFdmVudHVhbCB9IGZyb20gXCIuLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IFJlc3VsdCB9IGZyb20gXCIuLi9yZXN1bHQuanNcIjtcbmltcG9ydCB7IFNpZ25hbFRhcmdldFR5cGUgfSBmcm9tIFwiLi4vc2lnbmFscy5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3csIFdvcmtmbG93T3B0aW9ucyB9IGZyb20gXCIuLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHsgY3JlYXRlU2VuZFNpZ25hbENhbGwgfSBmcm9tIFwiLi9zZW5kLXNpZ25hbC1jYWxsLmpzXCI7XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1dvcmtmbG93Q2FsbDxUPihhOiBFdmVudHVhbDxUPik6IGEgaXMgV29ya2Zsb3dDYWxsPFQ+IHtcbiAgcmV0dXJuIGlzRXZlbnR1YWxPZktpbmQoRXZlbnR1YWxLaW5kLldvcmtmbG93Q2FsbCwgYSk7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50dWFsfSByZXByZXNlbnRpbmcgYW4gYXdhaXRlZCBjYWxsIHRvIGEge0BsaW5rIFdvcmtmbG93fS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBXb3JrZmxvd0NhbGw8VCA9IGFueT5cbiAgZXh0ZW5kcyBFdmVudHVhbEJhc2U8RXZlbnR1YWxLaW5kLldvcmtmbG93Q2FsbCwgUmVzdWx0PFQ+PixcbiAgICBDaGlsZEV4ZWN1dGlvbiB7XG4gIG5hbWU6IHN0cmluZztcbiAgaW5wdXQ/OiBhbnk7XG4gIHNlcT86IG51bWJlcjtcbiAgb3B0cz86IFdvcmtmbG93T3B0aW9ucztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVdvcmtmbG93Q2FsbChcbiAgbmFtZTogc3RyaW5nLFxuICBpbnB1dD86IGFueSxcbiAgb3B0cz86IFdvcmtmbG93T3B0aW9uc1xuKTogV29ya2Zsb3dDYWxsIHtcbiAgY29uc3QgY2FsbCA9IHJlZ2lzdGVyRXZlbnR1YWwoXG4gICAgY3JlYXRlRXZlbnR1YWw8V29ya2Zsb3dDYWxsPihFdmVudHVhbEtpbmQuV29ya2Zsb3dDYWxsLCB7XG4gICAgICBpbnB1dCxcbiAgICAgIG5hbWUsXG4gICAgICBvcHRzLFxuICAgIH0gYXMgV29ya2Zsb3dDYWxsKVxuICApO1xuXG4gIC8vIGNyZWF0ZSBhIHJlZmVyZW5jZSB0byB0aGUgY2hpbGQgd29ya2Zsb3cgc3RhcnRlZCBhdCBhIHNlcXVlbmNlIGluIHRoaXMgZXhlY3V0aW9uLlxuICAvLyB0aGlzIHJlZmVyZW5jZSB3aWxsIGJlIHJlc29sdmVkIGJ5IHRoZSBydW50aW1lLlxuICBjYWxsLnNlbmRTaWduYWwgPSBmdW5jdGlvbiAoc2lnbmFsLCBwYXlsb2FkPykge1xuICAgIGNvbnN0IHNpZ25hbElkID0gdHlwZW9mIHNpZ25hbCA9PT0gXCJzdHJpbmdcIiA/IHNpZ25hbCA6IHNpZ25hbC5pZDtcbiAgICByZXR1cm4gY3JlYXRlU2VuZFNpZ25hbENhbGwoXG4gICAgICB7XG4gICAgICAgIHR5cGU6IFNpZ25hbFRhcmdldFR5cGUuQ2hpbGRFeGVjdXRpb24sXG4gICAgICAgIHNlcTogY2FsbC5zZXEhLFxuICAgICAgICB3b3JrZmxvd05hbWU6IGNhbGwubmFtZSxcbiAgICAgIH0sXG4gICAgICBzaWduYWxJZCxcbiAgICAgIHBheWxvYWRcbiAgICApIGFzIHVua25vd24gYXMgYW55O1xuICB9O1xuXG4gIHJldHVybiBjYWxsO1xufVxuIl19

@@ -30,3 +30,3 @@ /**

* that belongs within the service. An {@link Event} has a unique {@link name},
* may be {@link publish}ed and {@link on}d to.
* may be {@link publishEvents}ed and {@link onEvent}d to.
*/

@@ -44,3 +44,3 @@ export interface Event<E extends EventPayload = EventPayload> {

*/
on(handler: (event: E) => Promise<void>): void;
onEvent(handler: (event: E) => Promise<void>): void;
/**

@@ -51,3 +51,3 @@ * Publish events of this type within the service boundary.

*/
publish(...events: E[]): Promise<void>;
publishEvents(...events: E[]): Promise<void>;
}

@@ -105,3 +105,3 @@ /**

* const checkoutWorkflow = workflow("checkoutWorkflow", async (request) => {
* await checkoutEvent.publish({
* await checkoutEvent.publishEvents({
* customerId: request.customerId,

@@ -118,3 +118,3 @@ * cartId: request.cartId,

* ```ts
* checkoutEvent.on(async (checkout) => {
* checkoutEvent.onEvent(async (checkout) => {
* console.log(checkout);

@@ -121,0 +121,0 @@ * });

@@ -22,3 +22,3 @@ import { createPublishEventsCall } from "./calls/send-events-call.js";

* const checkoutWorkflow = workflow("checkoutWorkflow", async (request) => {
* await checkoutEvent.publish({
* await checkoutEvent.publishEvents({
* customerId: request.customerId,

@@ -35,3 +35,3 @@ * cartId: request.cartId,

* ```ts
* checkoutEvent.on(async (checkout) => {
* checkoutEvent.onEvent(async (checkout) => {
* console.log(checkout);

@@ -50,3 +50,3 @@ * });

name,
on(handler) {
onEvent(handler) {
eventSubscriptions().push({

@@ -61,3 +61,3 @@ subscriptions: [

},
publish(...events) {
publishEvents(...events) {
const envelopes = events.map((event) => ({

@@ -78,2 +78,2 @@ name,

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDdEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFnR3BFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsTUFBTSxVQUFVLEtBQUssQ0FBeUIsSUFBWTtJQUN4RCxJQUFJLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixJQUFJLGtCQUFrQixDQUFDLENBQUM7S0FDN0Q7SUFDRCxNQUFNLEtBQUssR0FBYTtRQUN0QixJQUFJO1FBQ0osRUFBRSxDQUFDLE9BQU87WUFDUixrQkFBa0IsRUFBRSxDQUFDLElBQUksQ0FBQztnQkFDeEIsYUFBYSxFQUFFO29CQUNiO3dCQUNFLElBQUk7cUJBQ0w7aUJBQ0Y7Z0JBQ0QsT0FBTyxFQUFFLE9BQXFDO2FBQy9DLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxPQUFPLENBQUMsR0FBRyxNQUFNO1lBQ2YsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDdkMsSUFBSTtnQkFDSixLQUFLO2FBQ04sQ0FBQyxDQUFDLENBQUM7WUFDSixJQUFJLG9CQUFvQixFQUFFLEVBQUU7Z0JBQzFCLE9BQU8sdUJBQXVCLENBQUMsU0FBUyxDQUFRLENBQUM7YUFDbEQ7aUJBQU07Z0JBQ0wsT0FBTyxnQkFBZ0IsRUFBRSxDQUFDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO2FBQ2hFO1FBQ0gsQ0FBQztLQUNGLENBQUM7SUFDRixNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzFCLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vY2FsbHMvc2VuZC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgZXZlbnRzLCBldmVudFN1YnNjcmlwdGlvbnMgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGdldFNlcnZpY2VDbGllbnQsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vaW5kZXguanNcIjtcblxuLyoqXG4gKiBBbiBFdmVudFBheWxvYWQgaXMgdGhlIGRhdGEgc2VudCBhcyBhbiBldmVudC5cbiAqXG4gKiBJdCBtdXN0IGJlIGFuIG9iamVjdC4gUHJvcGVydGllcyBjYW4gYmUgYW55IHR5cGUgc2VyaWFsaXphYmxlIGFzIEpTT04uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRQYXlsb2FkIHtcbiAgW3Byb3BOYW1lOiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIEV2ZW50UGF5bG9hZFR5cGU8RSBleHRlbmRzIEV2ZW50PGFueT4+ID0gRSBleHRlbmRzIEV2ZW50PFxuICBpbmZlciBQYXlsb2FkXG4+XG4gID8gUGF5bG9hZFxuICA6IG5ldmVyO1xuXG4vKipcbiAqIEFuIGVudmVsb3BlIG9iamVjdCBjb250YWluaW5nIHRoZSB7QGxpbmsgZXZlbnR9IHBheWxvYWQgYXNzb2NpYXRlZFxuICogd2l0aCBpdHMgdW5pcXVlIHtAbGluayBuYW1lfS5cbiAqXG4gKiBUaGlzIGVudmVsb3BlIGRlY291cGxlcyB0aGUge0BsaW5rIG5hbWV9IGZybyB0aGUgcGF5bG9hZCBzbyB0aGF0XG4gKiB0aGVyZSBhcmUgbm8gaW1wb3NpdGlvbnMgb24gdGhlIHN0cnVjdHVyZSBvZiBhbiBldmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudEVudmVsb3BlPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFVuaXF1ZSBuYW1lIGlkZW50aWZ5aW5nIHRoZSB0eXBlIG9mIHRoZSB7QGxpbmsgZXZlbnR9LlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudFBheWxvYWR9LlxuICAgKi9cbiAgZXZlbnQ6IEU7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50fSBpcyBhbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBkZWNsYXJhdGlvbiBvZiBhbiBldmVudFxuICogdGhhdCBiZWxvbmdzIHdpdGhpbiB0aGUgc2VydmljZS4gQW4ge0BsaW5rIEV2ZW50fSBoYXMgYSB1bmlxdWUge0BsaW5rIG5hbWV9LFxuICogbWF5IGJlIHtAbGluayBwdWJsaXNofWVkIGFuZCB7QGxpbmsgb259ZCB0by5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBUaGUgRXZlbnQncyBnbG9iYWxseSB1bmlxdWUgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIFN1YnNjcmliZSB0byB0aGlzIGV2ZW50LiBUaGUge0BsaW5rIGhhbmRsZXJ9IHdpbGwgYmUgaW52b2tlZCBldmVyeVxuICAgKiB0aW1lIGFuIGV2ZW50IHdpdGggdGhpcyBuYW1lIGlzIHB1Ymxpc2hlZCB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBoYW5kbGVyIHRoZSBoYW5kbGVyIGZ1bmN0aW9uIHRoYXQgd2lsbCBwcm9jZXNzIHRoZSBldmVudC5cbiAgICovXG4gIG9uKGhhbmRsZXI6IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPik6IHZvaWQ7XG4gIC8qKlxuICAgKiBQdWJsaXNoIGV2ZW50cyBvZiB0aGlzIHR5cGUgd2l0aGluIHRoZSBzZXJ2aWNlIGJvdW5kYXJ5LlxuICAgKlxuICAgKiBAcGFyYW0gZXZlbnRzIGEgbGlzdCBvZiBldmVudHMgdG8gcHVibGlzaC5cbiAgICovXG4gIHB1Ymxpc2goLi4uZXZlbnRzOiBFW10pOiBQcm9taXNlPHZvaWQ+O1xufVxuXG4vKipcbiAqIEEge0BsaW5rIFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGhvdyB0byBzZWxlY3QgZXZlbnRzIGZyb21cbiAqIHdpdGhpbiBhIHNlcnZpY2UgYm91bmRhcnkgdG8gcm91dGUgdG8gYSB7QGxpbmsgRXZlbnRIYW5kbGVyfS5cbiAqXG4gKiBGb3Igbm93LCB3ZSBvbmx5IHN1cHBvcnQgbWF0Y2hpbmcgb24gYSBzaW5nbGUgbmFtZSwgYnV0IHRoaXMgb2JqZWN0IGNhbiBiZVxuICogZXh0ZW5kZWQgd2l0aCBvdGhlciBwcm9wZXJ0aWVzIHN1Y2ggYXMgc2VsZWN0aW9uIHByZWRpY2F0ZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIGV2ZW50IHRvIHN1YnNjcmliZSB0by5cbiAgICovXG4gIG5hbWU6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnRTdWJzY3JpcHRpb259IGlzIGFuIG9iamVjdCB0aGF0IGFzc29jaWF0ZXMgYSB7QGxpbmsgaGFuZGxlcn1cbiAqIGZ1bmN0aW9uIHdpdGggYSBsaXN0IG9mIHtAbGluayBzdWJzY3JpcHRpb25zfS4gVGhlIHtAbGluayBzdWJzY3JpcHRpb25zfVxuICogZGVmaW5lIHdoaWNoIGV2ZW50cyB0aGlzIHtAbGluayBoYW5kbGVyfSBzaG91bGQgYmUgaW52b2tlZCBmb3IuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRTdWJzY3JpcHRpb248RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogQSBsaXN0IG9mIHtAbGluayBTdWJzY3JpcHRpb259cyB0aGF0IHNob3VsZCBpbnZva2UgdGhpcyB7QGxpbmsgaGFuZGxlcn0uXG4gICAqL1xuICBzdWJzY3JpcHRpb25zOiBTdWJzY3JpcHRpb25bXTtcbiAgLyoqXG4gICAqIFRoZSB7QGxpbmsgRXZlbnRIYW5kbGVyfSB0byBpbnZva2UgZm9yIGFueSBldmVudCB0aGF0IG1hdGNoZXMgb25lIG9mXG4gICAqIHRoZSB7QGxpbmsgc3Vic2NyaXB0aW9uc30uXG4gICAqL1xuICBoYW5kbGVyOiBFdmVudEhhbmRsZXI8RT47XG59XG5cbi8qKlxuICogQSBGdW5jdGlvbiB0aGF0IHByb2Nlc3NlcyBhbiB7QGxpbmsgZXZlbnR9IG9mIHR5cGUge0BsaW5rIEV9LlxuICovXG5leHBvcnQgdHlwZSBFdmVudEhhbmRsZXI8RSBleHRlbmRzIEV2ZW50UGF5bG9hZD4gPSAoZXZlbnQ6IEUpID0+IFByb21pc2U8dm9pZD47XG5cbi8qKlxuICogRGVjbGFyZXMgYW4gZXZlbnQgdGhhdCBjYW4gYmUgcHVibGlzaGVkIGFuZCBzdWJzY3JpYmVkIHRvLlxuICpcbiAqIFRvIGRlY2xhcmUgYW4ge0BsaW5rIEV2ZW50fSwgZGVmaW5lIGFuIGludGVyZmFjZSBkZXNjcmliaW5nIHRoZSB0eXBlXG4gKiBvZiB0aGUgcGF5bG9hZCBhbmQgdGhlbiBkZWNsYXJlIGFuIGV2ZW50IG9iamVjdCBnaXZpbmcgaXQgYSB1bmlxdWUgbmFtZS5cbiAqIGBgYHRzXG4gKiBpbnRlcmZhY2UgQ2hlY2tvdXRFdmVudCB7XG4gKiAgIGN1c3RvbWVySWQ6IHN0cmluZztcbiAqICAgY2FydElkOiBzdHJpbmc7XG4gKiAgIHRpbWVzdGFtcDogc3RyaW5nO1xuICogfVxuICpcbiAqIGNvbnN0IGNoZWNrb3V0RXZlbnQgPSBldmVudDxDaGVja291dEV2ZW50PihcIkNoZWNrb3V0XCIpO1xuICogYGBgXG4gKlxuICogVG8gcHVibGlzaCBldmVudHMsIGNhbGwgdGhlIGBwdWJsaXNoYCBtZXRob2Q6XG4gKiBgYGB0c1xuICogY29uc3QgY2hlY2tvdXRXb3JrZmxvdyA9IHdvcmtmbG93KFwiY2hlY2tvdXRXb3JrZmxvd1wiLCBhc3luYyAocmVxdWVzdCkgPT4ge1xuICogICBhd2FpdCBjaGVja291dEV2ZW50LnB1Ymxpc2goe1xuICogICAgIGN1c3RvbWVySWQ6IHJlcXVlc3QuY3VzdG9tZXJJZCxcbiAqICAgICBjYXJ0SWQ6IHJlcXVlc3QuY2FydElkLFxuICogICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b1RpbWVTdHJpbmcoKVxuICogICB9KTtcbiAqIH0pXG4gKiBgYGBcbiAqXG4gKiBUbyBzdWJzY3JpYmUgdG8gZXZlbnRzLCBjYWxsIHRoZSBgb25gIG1ldGhvZC4gVGhpcyB3aWxsIHJlZ2lzdGVyIGFcbiAqIGhhbmRsZXIgdGhhdCB3aWwgbGJlIGludm9rZWQgZm9yIGV2ZXJ5IGV2ZW50IG9mIHRoaXMgdHlwZSB0aGF0IGlzIHJlY2VpdmVkLlxuICpcbiAqIGBgYHRzXG4gKiBjaGVja291dEV2ZW50Lm9uKGFzeW5jIChjaGVja291dCkgPT4ge1xuICogICBjb25zb2xlLmxvZyhjaGVja291dCk7XG4gKiB9KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBuYW1lIGEgdW5pcXVlIG5hbWUgdGhhdCBpZGVudGlmaWVzIHRoaXMgZXZlbnQgdHlwZSB3aXRoaW4gdGhlIFNlcnZpY2UuXG4gKiBAcmV0dXJucyBhbiB7QGxpbmsgRXZlbnR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPihuYW1lOiBzdHJpbmcpOiBFdmVudDxFPiB7XG4gIGlmIChldmVudHMoKS5oYXMobmFtZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGV2ZW50IHdpdGggbmFtZSAnJHtuYW1lfScgYWxyZWFkeSBleGlzdHNgKTtcbiAgfVxuICBjb25zdCBldmVudDogRXZlbnQ8RT4gPSB7XG4gICAgbmFtZSxcbiAgICBvbihoYW5kbGVyKSB7XG4gICAgICBldmVudFN1YnNjcmlwdGlvbnMoKS5wdXNoKHtcbiAgICAgICAgc3Vic2NyaXB0aW9uczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgICAgaGFuZGxlcjogaGFuZGxlciBhcyBFdmVudEhhbmRsZXI8RXZlbnRQYXlsb2FkPixcbiAgICAgIH0pO1xuICAgIH0sXG4gICAgcHVibGlzaCguLi5ldmVudHMpIHtcbiAgICAgIGNvbnN0IGVudmVsb3BlcyA9IGV2ZW50cy5tYXAoKGV2ZW50KSA9PiAoe1xuICAgICAgICBuYW1lLFxuICAgICAgICBldmVudCxcbiAgICAgIH0pKTtcbiAgICAgIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgICAgIHJldHVybiBjcmVhdGVQdWJsaXNoRXZlbnRzQ2FsbChlbnZlbG9wZXMpIGFzIGFueTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBnZXRTZXJ2aWNlQ2xpZW50KCkucHVibGlzaEV2ZW50cyh7IGV2ZW50czogZW52ZWxvcGVzIH0pO1xuICAgICAgfVxuICAgIH0sXG4gIH07XG4gIGV2ZW50cygpLnNldChuYW1lLCBldmVudCk7XG4gIHJldHVybiBldmVudDtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"event.js","sourceRoot":"","sources":["../../src/event.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,MAAM,6BAA6B,CAAC;AACtE,OAAO,EAAE,MAAM,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAC;AACzD,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,YAAY,CAAC;AAgGpE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAqCG;AACH,MAAM,UAAU,KAAK,CAAyB,IAAY;IACxD,IAAI,MAAM,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE;QACtB,MAAM,IAAI,KAAK,CAAC,oBAAoB,IAAI,kBAAkB,CAAC,CAAC;KAC7D;IACD,MAAM,KAAK,GAAa;QACtB,IAAI;QACJ,OAAO,CAAC,OAAO;YACb,kBAAkB,EAAE,CAAC,IAAI,CAAC;gBACxB,aAAa,EAAE;oBACb;wBACE,IAAI;qBACL;iBACF;gBACD,OAAO,EAAE,OAAqC;aAC/C,CAAC,CAAC;QACL,CAAC;QACD,aAAa,CAAC,GAAG,MAAM;YACrB,MAAM,SAAS,GAAG,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC;gBACvC,IAAI;gBACJ,KAAK;aACN,CAAC,CAAC,CAAC;YACJ,IAAI,oBAAoB,EAAE,EAAE;gBAC1B,OAAO,uBAAuB,CAAC,SAAS,CAAQ,CAAC;aAClD;iBAAM;gBACL,OAAO,gBAAgB,EAAE,CAAC,aAAa,CAAC,EAAE,MAAM,EAAE,SAAS,EAAE,CAAC,CAAC;aAChE;QACH,CAAC;KACF,CAAC;IACF,MAAM,EAAE,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IAC1B,OAAO,KAAK,CAAC;AACf,CAAC","sourcesContent":["import { createPublishEventsCall } from \"./calls/send-events-call.js\";\nimport { events, eventSubscriptions } from \"./global.js\";\nimport { getServiceClient, isOrchestratorWorker } from \"./index.js\";\n\n/**\n * An EventPayload is the data sent as an event.\n *\n * It must be an object. Properties can be any type serializable as JSON.\n */\nexport interface EventPayload {\n  [propName: string]: any;\n}\n\nexport type EventPayloadType<E extends Event<any>> = E extends Event<\n  infer Payload\n>\n  ? Payload\n  : never;\n\n/**\n * An envelope object containing the {@link event} payload associated\n * with its unique {@link name}.\n *\n * This envelope decouples the {@link name} fro the payload so that\n * there are no impositions on the structure of an event.\n */\nexport interface EventEnvelope<E extends EventPayload = EventPayload> {\n  /**\n   * Unique name identifying the type of the {@link event}.\n   */\n  name: string;\n  /**\n   * The {@link EventPayload}.\n   */\n  event: E;\n}\n\n/**\n * An {@link Event} is an object representing the declaration of an event\n * that belongs within the service. An {@link Event} has a unique {@link name},\n * may be {@link publishEvents}ed and {@link onEvent}d to.\n */\nexport interface Event<E extends EventPayload = EventPayload> {\n  /**\n   * The Event's globally unique name.\n   */\n  readonly name: string;\n  /**\n   * Subscribe to this event. The {@link handler} will be invoked every\n   * time an event with this name is published within the service boundary.\n   *\n   * @param handler the handler function that will process the event.\n   */\n  onEvent(handler: (event: E) => Promise<void>): void;\n  /**\n   * Publish events of this type within the service boundary.\n   *\n   * @param events a list of events to publish.\n   */\n  publishEvents(...events: E[]): Promise<void>;\n}\n\n/**\n * A {@link Subscription} is an object that describes how to select events from\n * within a service boundary to route to a {@link EventHandler}.\n *\n * For now, we only support matching on a single name, but this object can be\n * extended with other properties such as selection predicates.\n */\nexport interface Subscription {\n  /**\n   * Name of the event to subscribe to.\n   */\n  name: string;\n}\n\n/**\n * An {@link EventSubscription} is an object that associates a {@link handler}\n * function with a list of {@link subscriptions}. The {@link subscriptions}\n * define which events this {@link handler} should be invoked for.\n */\nexport interface EventSubscription<E extends EventPayload = EventPayload> {\n  /**\n   * A list of {@link Subscription}s that should invoke this {@link handler}.\n   */\n  subscriptions: Subscription[];\n  /**\n   * The {@link EventHandler} to invoke for any event that matches one of\n   * the {@link subscriptions}.\n   */\n  handler: EventHandler<E>;\n}\n\n/**\n * A Function that processes an {@link event} of type {@link E}.\n */\nexport type EventHandler<E extends EventPayload> = (event: E) => Promise<void>;\n\n/**\n * Declares an event that can be published and subscribed to.\n *\n * To declare an {@link Event}, define an interface describing the type\n * of the payload and then declare an event object giving it a unique name.\n * ```ts\n * interface CheckoutEvent {\n *   customerId: string;\n *   cartId: string;\n *   timestamp: string;\n * }\n *\n * const checkoutEvent = event<CheckoutEvent>(\"Checkout\");\n * ```\n *\n * To publish events, call the `publish` method:\n * ```ts\n * const checkoutWorkflow = workflow(\"checkoutWorkflow\", async (request) => {\n *   await checkoutEvent.publishEvents({\n *     customerId: request.customerId,\n *     cartId: request.cartId,\n *     timestamp: new Date().toTimeString()\n *   });\n * })\n * ```\n *\n * To subscribe to events, call the `on` method. This will register a\n * handler that wil lbe invoked for every event of this type that is received.\n *\n * ```ts\n * checkoutEvent.onEvent(async (checkout) => {\n *   console.log(checkout);\n * });\n * ```\n *\n * @param name a unique name that identifies this event type within the Service.\n * @returns an {@link Event}\n */\nexport function event<E extends EventPayload>(name: string): Event<E> {\n  if (events().has(name)) {\n    throw new Error(`event with name '${name}' already exists`);\n  }\n  const event: Event<E> = {\n    name,\n    onEvent(handler) {\n      eventSubscriptions().push({\n        subscriptions: [\n          {\n            name,\n          },\n        ],\n        handler: handler as EventHandler<EventPayload>,\n      });\n    },\n    publishEvents(...events) {\n      const envelopes = events.map((event) => ({\n        name,\n        event,\n      }));\n      if (isOrchestratorWorker()) {\n        return createPublishEventsCall(envelopes) as any;\n      } else {\n        return getServiceClient().publishEvents({ events: envelopes });\n      }\n    },\n  };\n  events().set(name, event);\n  return event;\n}\n"]}

@@ -49,3 +49,3 @@ import { ActivityCall } from "./calls/activity-call.js";

/**
* Wait for all {@link activities} to complete or until at least one throws.
* Wait for all {@link activities} to succeed or until at least one throws.
*

@@ -52,0 +52,0 @@ * This is the equivalent behavior to Promise.all.

@@ -56,3 +56,3 @@ import { isActivityCall } from "./calls/activity-call.js";

/**
* Wait for all {@link activities} to complete or until at least one throws.
* Wait for all {@link activities} to succeed or until at least one throws.
*

@@ -88,2 +88,2 @@ * This is the equivalent behavior to Promise.all.

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 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"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"eventual.js","sourceRoot":"","sources":["../../src/eventual.ts"],"names":[],"mappings":"AAAA,OAAO,EAAgB,cAAc,EAAE,MAAM,0BAA0B,CAAC;AACxE,OAAO,EAAY,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAE,KAAK,EAAS,MAAM,YAAY,CAAC;AAG1C,OAAO,EACL,cAAc,EACd,gBAAgB,GAGjB,MAAM,uBAAuB,CAAC;AAC/B,OAAO,EACL,kBAAkB,GAEnB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EACL,2BAA2B,GAE5B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,gBAAgB,EAAkB,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAE,cAAc,EAAgB,MAAM,0BAA0B,CAAC;AACxE,OAAO,EAAiB,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAY,cAAc,EAAE,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAmB,qBAAqB,EAAE,MAAM,wBAAwB,CAAC;AAChF,OAAO,EAAE,UAAU,EAAQ,MAAM,WAAW,CAAC;AAC7C,OAAO,EACL,mBAAmB,GAEpB,MAAM,6BAA6B,CAAC;AAUrC,MAAM,cAAc,GAAG,MAAM,CAAC,GAAG,CAAC,mBAAmB,CAAC,CAAC;AAOvD,MAAM,CAAN,IAAY,YAeX;AAfD,WAAY,YAAY;IACtB,+DAAgB,CAAA;IAChB,uDAAY,CAAA;IACZ,sEAAoB,CAAA;IACpB,wDAAa,CAAA;IACb,iDAAS,CAAA;IACT,iEAAiB,CAAA;IACjB,uEAAoB,CAAA;IACpB,0EAAsB,CAAA;IACtB,gDAAS,CAAA;IACT,yFAA6B,CAAA;IAC7B,mEAAkB,CAAA;IAClB,+DAAgB,CAAA;IAChB,mEAAkB,CAAA;IAClB,+DAAgB,CAAA;AAClB,CAAC,EAfW,YAAY,KAAZ,YAAY,QAevB;AAED,MAAM,UAAU,UAAU,CAAC,CAAM;IAC/B,OAAO,CAAC,IAAI,OAAO,CAAC,KAAK,QAAQ,IAAI,cAAc,IAAI,CAAC,CAAC;AAC3D,CAAC;AAED,MAAM,UAAU,gBAAgB,CAC9B,IAA8B,EAC9B,CAAM;IAEN,OAAO,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,cAAc,CAAC,KAAK,IAAI,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,cAAc,CAC5B,IAA8B,EAC9B,CAAiC;IAEhC,CAAO,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC;IAChC,OAAO,CAAM,CAAC;AAChB,CAAC;AAwBD,MAAM,UAAU,aAAa,CAAC,IAAc;IAC1C,OAAO,CACL,cAAc,CAAC,IAAI,CAAC;QACpB,eAAe,CAAC,IAAI,CAAC;QACrB,kBAAkB,CAAC,IAAI,CAAC;QACxB,mBAAmB,CAAC,IAAI,CAAC;QACzB,2BAA2B,CAAC,IAAI,CAAC;QACjC,gBAAgB,CAAC,IAAI,CAAC;QACtB,cAAc,CAAC,IAAI,CAAC;QACpB,gBAAgB,CAAC,IAAI,CAAC;QACtB,cAAc,CAAC,IAAI,CAAC,CACrB,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,QAAQ,GAAG;IACtB;;;;OAIG;IACH,GAAG,CACD,UAAa;QAEb,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;SAC7D;QAED,OAAO,cAAc,CAAC,UAAU,CAAQ,CAAC;IAC3C,CAAC;IACD,GAAG,CAAuB,UAAa;QACrC,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;SAC7D;QAED,OAAO,cAAc,CAAC,UAAU,CAAQ,CAAC;IAC3C,CAAC;IACD,IAAI,CAAuB,UAAa;QACtC,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QAED,OAAO,UAAU,CAAC,UAAU,CAAQ,CAAC;IACvC,CAAC;IACD,UAAU,CACR,UAAa;QAEb,IAAI,CAAC,oBAAoB,EAAE,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,iDAAiD,CAAC,CAAC;SACpE;QAED,OAAO,qBAAqB,CAAC,UAAU,CAAQ,CAAC;IAClD,CAAC;CACF,CAAC;AA4BF,MAAM,CAAC,SAAS,GAAG,KAAK,CAAC;AACzB,MAAM,CAAC,SAAS,GAAG,QAAQ,CAAC","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 succeed 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"]}
import { EventualServiceClient } from "./service-client.js";
import { Signal, SendSignalProps, SignalPayload } from "./signals.js";
import { Signal, SendSignalProps } from "./signals.js";
import { Workflow, WorkflowOutput } from "./workflow.js";
export declare enum ExecutionStatus {
IN_PROGRESS = "IN_PROGRESS",
COMPLETE = "COMPLETE",
SUCCEEDED = "SUCCEEDED",
FAILED = "FAILED"

@@ -25,8 +25,8 @@ }

}
export type Execution<Result = any> = InProgressExecution | CompleteExecution<Result> | FailedExecution;
export type Execution<Result = any> = InProgressExecution | SucceededExecution<Result> | FailedExecution;
export interface InProgressExecution extends ExecutionBase {
status: ExecutionStatus.IN_PROGRESS;
}
export interface CompleteExecution<Result = any> extends ExecutionBase {
status: ExecutionStatus.COMPLETE;
export interface SucceededExecution<Result = any> extends ExecutionBase {
status: ExecutionStatus.SUCCEEDED;
endTime: string;

@@ -42,7 +42,7 @@ result?: Result;

export declare function isFailedExecution(execution: Execution): execution is FailedExecution;
export declare function isCompleteExecution(execution: Execution): execution is CompleteExecution;
export declare function isSucceededExecution(execution: Execution): execution is SucceededExecution;
/**
* A reference to a running execution.
*/
export declare class ExecutionHandle<W extends Workflow> {
export declare class ExecutionHandle<W extends Workflow> implements ChildExecution {
executionId: string;

@@ -58,3 +58,3 @@ private serviceClient;

*/
signal<Payload = any>(signal: string | Signal<Payload>, payload: Payload): Promise<void>;
sendSignal<Payload = any>(signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
}

@@ -73,3 +73,3 @@ /**

* const child = childWf();
* child.signal(mySignal);
* child.sendSignal(mySignal);
* await child;

@@ -81,5 +81,5 @@ * })

*/
signal<S extends Signal<any>>(signal: S, ...args: SendSignalProps<SignalPayload<S>>): Promise<void>;
sendSignal<Payload = any>(signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
}
export {};
//# sourceMappingURL=execution.d.ts.map

@@ -0,5 +1,6 @@

import { ulid } from "ulidx";
export var ExecutionStatus;
(function (ExecutionStatus) {
ExecutionStatus["IN_PROGRESS"] = "IN_PROGRESS";
ExecutionStatus["COMPLETE"] = "COMPLETE";
ExecutionStatus["SUCCEEDED"] = "SUCCEEDED";
ExecutionStatus["FAILED"] = "FAILED";

@@ -10,4 +11,4 @@ })(ExecutionStatus || (ExecutionStatus = {}));

}
export function isCompleteExecution(execution) {
return execution.status === ExecutionStatus.COMPLETE;
export function isSucceededExecution(execution) {
return execution.status === ExecutionStatus.SUCCEEDED;
}

@@ -31,3 +32,4 @@ /**

*/
async signal(signal, payload) {
async sendSignal(signal, ...args) {
const [payload] = args;
return this.serviceClient.sendSignal({

@@ -37,5 +39,6 @@ execution: this.executionId,

payload,
id: ulid(),
});
}
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3pCLDhDQUEyQixDQUFBO0lBQzNCLHdDQUFxQixDQUFBO0lBQ3JCLG9DQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKVyxlQUFlLEtBQWYsZUFBZSxRQUkxQjtBQXlDRCxNQUFNLFVBQVUsaUJBQWlCLENBQy9CLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsTUFBTSxDQUFDO0FBQ3JELENBQUM7QUFFRCxNQUFNLFVBQVUsbUJBQW1CLENBQ2pDLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDO0FBQ3ZELENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQ1MsV0FBbUIsRUFDbEIsYUFBb0M7UUFEckMsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFDbEIsa0JBQWEsR0FBYixhQUFhLENBQXVCO0lBQzNDLENBQUM7SUFFSjs7T0FFRztJQUNJLEtBQUssQ0FBQyxTQUFTO1FBQ3BCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUMzQyxJQUFJLENBQUMsV0FBVyxDQUNqQixDQUFpQyxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxNQUFNLENBQ2pCLE1BQWdDLEVBQ2hDLE9BQWdCO1FBRWhCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUM7WUFDbkMsU0FBUyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzNCLE1BQU0sRUFBRSxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdkQsT0FBTztTQUNSLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTaWduYWwsIFNlbmRTaWduYWxQcm9wcywgU2lnbmFsUGF5bG9hZCB9IGZyb20gXCIuL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd091dHB1dCB9IGZyb20gXCIuL3dvcmtmbG93LmpzXCI7XG5cbmV4cG9ydCBlbnVtIEV4ZWN1dGlvblN0YXR1cyB7XG4gIElOX1BST0dSRVNTID0gXCJJTl9QUk9HUkVTU1wiLFxuICBDT01QTEVURSA9IFwiQ09NUExFVEVcIixcbiAgRkFJTEVEID0gXCJGQUlMRURcIixcbn1cblxuaW50ZXJmYWNlIEV4ZWN1dGlvbkJhc2Uge1xuICBpZDogc3RyaW5nO1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cztcbiAgc3RhcnRUaW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93TmFtZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50XG4gICkge31cblxuICAvKipcbiAgICogQHJldHVybiB0aGUge0BsaW5rIEV4ZWN1dGlvbn0gd2l0aCB0aGUgc3RhdHVzLCByZXN1bHQsIGVycm9yLCBhbmQgb3RoZXIgZGF0YSBiYXNlZCBvbiB0aGUgY3VycmVudCBzdGF0dXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U3RhdHVzKCk6IFByb21pc2U8RXhlY3V0aW9uPFdvcmtmbG93T3V0cHV0PFc+Pj4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5zZXJ2aWNlQ2xpZW50LmdldEV4ZWN1dGlvbihcbiAgICAgIHRoaXMuZXhlY3V0aW9uSWRcbiAgICApKSBhcyBFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+O1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSB7QGxpbmsgc2lnbmFsfSB0byB0aGlzIGV4ZWN1dGlvbi5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBzaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgcGF5bG9hZDogUGF5bG9hZFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5zZXJ2aWNlQ2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uOiB0aGlzLmV4ZWN1dGlvbklkLFxuICAgICAgc2lnbmFsOiB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkLFxuICAgICAgcGF5bG9hZCxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGFuIGV4ZWN1dGlvbiBzdGFydGVkIGJ5IGFub3RoZXIgd29ya2Zsb3cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2hpbGRFeGVjdXRpb24ge1xuICAvKipcbiAgICogQWxsb3dzIGEge0BsaW5rIHdvcmtmbG93fSB0byBzZW5kIGEgc2lnbmFsIHRvIHRoZSB3b3JrZmxvdyB7QGxpbmsgRXhlY3V0aW9ufS5cbiAgICpcbiAgICogYGBgdHNcbiAgICogY29uc3QgbXlTaWduYWwgPSBzaWduYWw8c3RyaW5nPihcIk15U2lnbmFsXCIpO1xuICAgKiBjb25zdCBjaGlsZFdmID0gd29ya2Zsb3coLi4uKTtcbiAgICogd29ya2Zsb3coXCJ3ZlwiLCBhc3luYyAoKSA9PiB7XG4gICAqICAgIGNvbnN0IGNoaWxkID0gY2hpbGRXZigpO1xuICAgKiAgICBjaGlsZC5zaWduYWwobXlTaWduYWwpO1xuICAgKiAgICBhd2FpdCBjaGlsZDtcbiAgICogfSlcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBpZCBhbiBvcHRpb25hbCwgZXhlY3V0aW9uIHVuaXF1ZSBJRCwgd2lsbCBiZSB1c2VkIHRvIGRlLWR1cGUgdGhlIHNpZ25hbCBhdCB0aGUgdGFyZ2V0IGV4ZWN1dGlvbi5cbiAgICovXG4gIHNpZ25hbDxTIGV4dGVuZHMgU2lnbmFsPGFueT4+KFxuICAgIHNpZ25hbDogUyxcbiAgICAuLi5hcmdzOiBTZW5kU2lnbmFsUHJvcHM8U2lnbmFsUGF5bG9hZDxTPj5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sT0FBTyxDQUFDO0FBSzdCLE1BQU0sQ0FBTixJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsOENBQTJCLENBQUE7SUFDM0IsMENBQXVCLENBQUE7SUFDdkIsb0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLGVBQWUsS0FBZixlQUFlLFFBSTFCO0FBeUNELE1BQU0sVUFBVSxpQkFBaUIsQ0FDL0IsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxNQUFNLENBQUM7QUFDckQsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FDbEMsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxTQUFTLENBQUM7QUFDeEQsQ0FBQztBQUVEOztHQUVHO0FBQ0gsTUFBTSxPQUFPLGVBQWU7SUFDMUIsWUFDUyxXQUFtQixFQUNsQixhQUFvQztRQURyQyxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUNsQixrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7SUFDM0MsQ0FBQztJQUVKOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQzNDLElBQUksQ0FBQyxXQUFXLENBQ2pCLENBQWlDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFVBQVUsQ0FDckIsTUFBZ0MsRUFDaEMsR0FBRyxJQUE4QjtRQUVqQyxNQUFNLENBQUMsT0FBTyxDQUFDLEdBQUcsSUFBSSxDQUFDO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUM7WUFDbkMsU0FBUyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzNCLE1BQU0sRUFBRSxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdkQsT0FBTztZQUNQLEVBQUUsRUFBRSxJQUFJLEVBQUU7U0FDWCxDQUFDLENBQUM7SUFDTCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1bGlkIH0gZnJvbSBcInVsaWR4XCI7XG5pbXBvcnQgeyBFdmVudHVhbFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgU2lnbmFsLCBTZW5kU2lnbmFsUHJvcHMgfSBmcm9tIFwiLi9zaWduYWxzLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvdywgV29ya2Zsb3dPdXRwdXQgfSBmcm9tIFwiLi93b3JrZmxvdy5qc1wiO1xuXG5leHBvcnQgZW51bSBFeGVjdXRpb25TdGF0dXMge1xuICBJTl9QUk9HUkVTUyA9IFwiSU5fUFJPR1JFU1NcIixcbiAgU1VDQ0VFREVEID0gXCJTVUNDRUVERURcIixcbiAgRkFJTEVEID0gXCJGQUlMRURcIixcbn1cblxuaW50ZXJmYWNlIEV4ZWN1dGlvbkJhc2Uge1xuICBpZDogc3RyaW5nO1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cztcbiAgc3RhcnRUaW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93TmFtZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBTdWNjZWVkZWRFeGVjdXRpb248UmVzdWx0PlxuICB8IEZhaWxlZEV4ZWN1dGlvbjtcblxuZXhwb3J0IGludGVyZmFjZSBJblByb2dyZXNzRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLklOX1BST0dSRVNTO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFN1Y2NlZWRlZEV4ZWN1dGlvbjxSZXN1bHQgPSBhbnk+IGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLlNVQ0NFRURFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzU3VjY2VlZGVkRXhlY3V0aW9uKFxuICBleGVjdXRpb246IEV4ZWN1dGlvblxuKTogZXhlY3V0aW9uIGlzIFN1Y2NlZWRlZEV4ZWN1dGlvbiB7XG4gIHJldHVybiBleGVjdXRpb24uc3RhdHVzID09PSBFeGVjdXRpb25TdGF0dXMuU1VDQ0VFREVEO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PiBpbXBsZW1lbnRzIENoaWxkRXhlY3V0aW9uIHtcbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIGV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gICAgcHJpdmF0ZSBzZXJ2aWNlQ2xpZW50OiBFdmVudHVhbFNlcnZpY2VDbGllbnRcbiAgKSB7fVxuXG4gIC8qKlxuICAgKiBAcmV0dXJuIHRoZSB7QGxpbmsgRXhlY3V0aW9ufSB3aXRoIHRoZSBzdGF0dXMsIHJlc3VsdCwgZXJyb3IsIGFuZCBvdGhlciBkYXRhIGJhc2VkIG9uIHRoZSBjdXJyZW50IHN0YXR1cy5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBnZXRTdGF0dXMoKTogUHJvbWlzZTxFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+PiB7XG4gICAgcmV0dXJuIChhd2FpdCB0aGlzLnNlcnZpY2VDbGllbnQuZ2V0RXhlY3V0aW9uKFxuICAgICAgdGhpcy5leGVjdXRpb25JZFxuICAgICkpIGFzIEV4ZWN1dGlvbjxXb3JrZmxvd091dHB1dDxXPj47XG4gIH1cblxuICAvKipcbiAgICogU2VuZCBhIHtAbGluayBzaWduYWx9IHRvIHRoaXMgZXhlY3V0aW9uLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIHNlbmRTaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgLi4uYXJnczogU2VuZFNpZ25hbFByb3BzPFBheWxvYWQ+XG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIGNvbnN0IFtwYXlsb2FkXSA9IGFyZ3M7XG4gICAgcmV0dXJuIHRoaXMuc2VydmljZUNsaWVudC5zZW5kU2lnbmFsKHtcbiAgICAgIGV4ZWN1dGlvbjogdGhpcy5leGVjdXRpb25JZCxcbiAgICAgIHNpZ25hbDogdHlwZW9mIHNpZ25hbCA9PT0gXCJzdHJpbmdcIiA/IHNpZ25hbCA6IHNpZ25hbC5pZCxcbiAgICAgIHBheWxvYWQsXG4gICAgICBpZDogdWxpZCgpLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQSByZWZlcmVuY2UgdG8gYW4gZXhlY3V0aW9uIHN0YXJ0ZWQgYnkgYW5vdGhlciB3b3JrZmxvdy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDaGlsZEV4ZWN1dGlvbiB7XG4gIC8qKlxuICAgKiBBbGxvd3MgYSB7QGxpbmsgd29ya2Zsb3d9IHRvIHNlbmQgYSBzaWduYWwgdG8gdGhlIHdvcmtmbG93IHtAbGluayBFeGVjdXRpb259LlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiBjb25zdCBteVNpZ25hbCA9IHNpZ25hbDxzdHJpbmc+KFwiTXlTaWduYWxcIik7XG4gICAqIGNvbnN0IGNoaWxkV2YgPSB3b3JrZmxvdyguLi4pO1xuICAgKiB3b3JrZmxvdyhcIndmXCIsIGFzeW5jICgpID0+IHtcbiAgICogICAgY29uc3QgY2hpbGQgPSBjaGlsZFdmKCk7XG4gICAqICAgIGNoaWxkLnNlbmRTaWduYWwobXlTaWduYWwpO1xuICAgKiAgICBhd2FpdCBjaGlsZDtcbiAgICogfSlcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBpZCBhbiBvcHRpb25hbCwgZXhlY3V0aW9uIHVuaXF1ZSBJRCwgd2lsbCBiZSB1c2VkIHRvIGRlLWR1cGUgdGhlIHNpZ25hbCBhdCB0aGUgdGFyZ2V0IGV4ZWN1dGlvbi5cbiAgICovXG4gIHNlbmRTaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgLi4uYXJnczogU2VuZFNpZ25hbFByb3BzPFBheWxvYWQ+XG4gICk6IFByb21pc2U8dm9pZD47XG59XG4iXX0=

@@ -10,5 +10,5 @@ import { SendActivityHeartbeatResponse } from "./service-client.js";

*
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow completed, failed, or the activity timed out).
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow succeeded, failed, or the activity timed out).
*/
export declare function heartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
export declare function sendActivityHeartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
//# sourceMappingURL=heartbeat.d.ts.map

@@ -11,5 +11,5 @@ import { getActivityContext, getServiceClient } from "./global.js";

*
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow completed, failed, or the activity timed out).
* @returns {@link HeartbeatResponse} which has response.cancelled if the activity was cancelled for any reason (ex: workflow succeeded, failed, or the activity timed out).
*/
export async function heartbeat(activityToken) {
export async function sendActivityHeartbeat(activityToken) {
if (isOrchestratorWorker()) {

@@ -33,2 +33,2 @@ throw new Error("Heartbeat is not currently supported from within a workflow. Use an activity with `heartbeat()`.");

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDbkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksb0JBQW9CLEVBQUUsRUFBRTtRQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLGtHQUFrRyxDQUNuRyxDQUFDO0tBQ0g7U0FBTSxJQUFJLGFBQWEsRUFBRTtRQUN4QixPQUFPLE1BQU0sZ0JBQWdCLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLGdCQUFnQixFQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDakQsT0FBTyxNQUFNLGdCQUFnQixFQUFFLENBQUMscUJBQXFCLENBQUM7WUFDcEQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRBY3Rpdml0eUNvbnRleHQsIGdldFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGlzQWN0aXZpdHlXb3JrZXIsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vcnVudGltZS9mbGFncy5qc1wiO1xuaW1wb3J0IHsgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2UgfSBmcm9tIFwiLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuXG4vKipcbiAqIFNlbmRzIGEgaGVhcnRiZWF0IGZvciB0aGUgY3VycmVudCBhY3Rpdml0eSBvciB0byB0aGUgcHJvdmlkZWQgYWN0aXZpdHkgdG9rZW4uXG4gKlxuICogSWYgY2FsbGVkIGZyb20gb3V0c2lkZSBvZiBhbiB7QGxpbmsgYWN0aXZpdHl9LCB0aGUgYWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZC5cbiAqXG4gKiBJZiB0aGUgYWN0aXZpdHkgaGFzIGEgaGVhcnRiZWF0VGltZW91dCBzZXQgYW5kIHRoZSB3b3JrZmxvdyBoYXMgbm90IHJlY2VpdmVkIGEgaGVhcnRiZWF0IGluIGhlYXJ0YmVhdFRpbWVvdXRTZWNvbmRzLFxuICogdGhlIHdvcmtmbG93IHdpbGwgdGhyb3cgYSB7QGxpbmsgSGVhcnRiZWF0VGltZW91dH0gYW5kIGNhbmNlbCB0aGUgYWN0aXZpdHkuXG4gKlxuICogQHJldHVybnMge0BsaW5rIEhlYXJ0YmVhdFJlc3BvbnNlfSB3aGljaCBoYXMgcmVzcG9uc2UuY2FuY2VsbGVkIGlmIHRoZSBhY3Rpdml0eSB3YXMgY2FuY2VsbGVkIGZvciBhbnkgcmVhc29uIChleDogd29ya2Zsb3cgY29tcGxldGVkLCBmYWlsZWQsIG9yIHRoZSBhY3Rpdml0eSB0aW1lZCBvdXQpLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaGVhcnRiZWF0KFxuICBhY3Rpdml0eVRva2VuPzogc3RyaW5nXG4pOiBQcm9taXNlPFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJIZWFydGJlYXQgaXMgbm90IGN1cnJlbnRseSBzdXBwb3J0ZWQgZnJvbSB3aXRoaW4gYSB3b3JrZmxvdy4gVXNlIGFuIGFjdGl2aXR5IHdpdGggYGhlYXJ0YmVhdCgpYC5cIlxuICAgICk7XG4gIH0gZWxzZSBpZiAoYWN0aXZpdHlUb2tlbikge1xuICAgIHJldHVybiBhd2FpdCBnZXRTZXJ2aWNlQ2xpZW50KCkuc2VuZEFjdGl2aXR5SGVhcnRiZWF0KHtcbiAgICAgIGFjdGl2aXR5VG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSBpZiAoaXNBY3Rpdml0eVdvcmtlcigpKSB7XG4gICAgY29uc3QgdG9rZW4gPSBnZXRBY3Rpdml0eUNvbnRleHQoKS5hY3Rpdml0eVRva2VuO1xuICAgIHJldHVybiBhd2FpdCBnZXRTZXJ2aWNlQ2xpZW50KCkuc2VuZEFjdGl2aXR5SGVhcnRiZWF0KHtcbiAgICAgIGFjdGl2aXR5VG9rZW46IHRva2VuLFxuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZCB3aGVuIG5vdCB3aXRoaW4gYW4gQWN0aXZpdHkuXCJcbiAgICApO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDbkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxxQkFBcUIsQ0FDekMsYUFBc0I7SUFFdEIsSUFBSSxvQkFBb0IsRUFBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxnQkFBZ0IsRUFBRSxDQUFDLHFCQUFxQixDQUFDO1lBQ3BELGFBQWE7U0FDZCxDQUFDLENBQUM7S0FDSjtTQUFNLElBQUksZ0JBQWdCLEVBQUUsRUFBRTtRQUM3QixNQUFNLEtBQUssR0FBRyxrQkFBa0IsRUFBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0sZ0JBQWdCLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxhQUFhLEVBQUUsS0FBSztTQUNyQixDQUFDLENBQUM7S0FDSjtTQUFNO1FBQ0wsTUFBTSxJQUFJLEtBQUssQ0FDYiw4REFBOEQsQ0FDL0QsQ0FBQztLQUNIO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0U2VydmljZUNsaWVudCB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5pbXBvcnQgeyBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZSB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBzdWNjZWVkZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzZW5kQWN0aXZpdHlIZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8U2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ==

@@ -9,4 +9,4 @@ import { EventEnvelope } from "../../event.js";

*/
publish(...event: EventEnvelope[]): Promise<void>;
publishEvents(...event: EventEnvelope[]): Promise<void>;
}
//# sourceMappingURL=event-client.d.ts.map
export {};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9ldmVudC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcblxuLyoqXG4gKiBBIENsaWVudCBmb3IgZW1pdHRpbmcgZXZlbnRzIGludG8gdGhlIEV2ZW50dWFsIFNlcnZpY2UncyBldmVudCBidXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRDbGllbnQge1xuICAvKipcbiAgICogRW1pdCBtdWx0aXBsZSBldmVudHMgaW50byB0aGUgRXZlbnR1YWwgU2VydmljZSdzIGV2ZW50IGJ1cy5cbiAgICovXG4gIHB1Ymxpc2goLi4uZXZlbnQ6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9ldmVudC1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcblxuLyoqXG4gKiBBIENsaWVudCBmb3IgZW1pdHRpbmcgZXZlbnRzIGludG8gdGhlIEV2ZW50dWFsIFNlcnZpY2UncyBldmVudCBidXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRDbGllbnQge1xuICAvKipcbiAgICogRW1pdCBtdWx0aXBsZSBldmVudHMgaW50byB0aGUgRXZlbnR1YWwgU2VydmljZSdzIGV2ZW50IGJ1cy5cbiAgICovXG4gIHB1Ymxpc2hFdmVudHMoLi4uZXZlbnQ6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG4iXX0=

@@ -18,3 +18,3 @@ import { ExecutionHandle } from "../../execution.js";

async startExecution(request) {
const executionId = await this.props.workflowClient.startWorkflow(request);
const { executionId } = await this.props.workflowClient.startExecution(request);
return new ExecutionHandle(executionId, this);

@@ -41,14 +41,14 @@ }

publishEvents(request) {
return this.props.eventClient.publish(...request.events);
return this.props.eventClient.publishEvents(...request.events);
}
sendActivitySuccess(request) {
return this.props.workflowClient.completeActivity(request);
return this.props.workflowClient.sendActivitySuccess(request);
}
sendActivityFailure(request) {
return this.props.workflowClient.failActivity(request);
return this.props.workflowClient.sendActivityFailure(request);
}
sendActivityHeartbeat(request) {
return this.props.workflowClient.heartbeatActivity(request);
return this.props.workflowClient.sendActivityHeartbeat(request);
}
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS1zZXJ2aWNlLWNsaWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3J1bnRpbWUtc2VydmljZS1jbGllbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLE9BQU8sRUFBYSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUtoRSxPQUFPLEVBQXlCLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBU2xFOzs7O0dBSUc7QUFDSCxNQUFNLE9BQU8sb0JBQW9CO0lBQy9CLFlBQW9CLEtBQWdDO1FBQWhDLFVBQUssR0FBTCxLQUFLLENBQTJCO0lBQUcsQ0FBQztJQUVqRCxLQUFLLENBQUMsWUFBWTtRQUN2QixPQUFPO1lBQ0wsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUNwRSxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxjQUFjLENBQ3pCLE9BQWlDO1FBRWpDLE1BQU0sV0FBVyxHQUFHLE1BQU0sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsYUFBYSxDQUMvRCxPQUFPLENBQ1IsQ0FBQztRQUNGLE9BQU8sSUFBSSxlQUFlLENBQUMsV0FBVyxFQUFFLElBQUksQ0FBQyxDQUFDO0lBQ2hELENBQUM7SUFFTSxLQUFLLENBQUMsYUFBYSxDQUN4QixPQUE2QjtRQUU3QixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLGFBQWEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMxRCxDQUFDO0lBRU0sWUFBWSxDQUNqQixXQUFtQjtRQUVuQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLFlBQVksQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU0sbUJBQW1CLENBQ3hCLE9BQStCO1FBRS9CLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxzQkFBc0IsQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDOUQsQ0FBQztJQUVNLEtBQUssQ0FBQywyQkFBMkIsQ0FDdEMsV0FBbUI7UUFFbkIsTUFBTSxNQUFNLEdBQUcsTUFBTSxJQUFJLENBQUMsS0FBSyxDQUFDLHFCQUFxQixDQUFDLFVBQVUsQ0FDOUQsV0FBVyxDQUNaLENBQUM7UUFDRixPQUFPO1lBQ0wsTUFBTTtTQUNQLENBQUM7SUFDSixDQUFDO0lBRU0sS0FBSyxDQUFDLFVBQVUsQ0FBQyxPQUEwQjtRQUNoRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUN2RCxDQUFDO0lBRU0sYUFBYSxDQUFDLE9BQTZCO1FBQ2hELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLENBQUMsT0FBTyxDQUFDLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBQzNELENBQUM7SUFFTSxtQkFBbUIsQ0FDeEIsT0FBc0Q7UUFFdEQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxnQkFBZ0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM3RCxDQUFDO0lBRU0sbUJBQW1CLENBQ3hCLE9BQWlEO1FBRWpELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ3pELENBQUM7SUFFTSxxQkFBcUIsQ0FDMUIsT0FBbUQ7UUFFbkQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxpQkFBaUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUM5RCxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTZW5kQWN0aXZpdHlTdWNjZXNzUmVxdWVzdCxcbiAgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50LFxuICBFeGVjdXRpb25FdmVudHNSZXF1ZXN0LFxuICBFeGVjdXRpb25FdmVudHNSZXNwb25zZSxcbiAgRXhlY3V0aW9uSGlzdG9yeVJlc3BvbnNlLFxuICBTZW5kQWN0aXZpdHlGYWlsdXJlUmVxdWVzdCxcbiAgR2V0RXhlY3V0aW9uc1JlcXVlc3QsXG4gIEdldEV4ZWN1dGlvbnNSZXNwb25zZSxcbiAgR2V0V29ya2Zsb3dSZXNwb25zZSxcbiAgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVxdWVzdCxcbiAgUHVibGlzaEV2ZW50c1JlcXVlc3QsXG4gIFN0YXJ0RXhlY3V0aW9uUmVxdWVzdCxcbiAgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2UsXG59IGZyb20gXCIuLi8uLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgRXhlY3V0aW9uLCBFeGVjdXRpb25IYW5kbGUgfSBmcm9tIFwiLi4vLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvdyB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHsgRXZlbnRDbGllbnQgfSBmcm9tIFwiLi9ldmVudC1jbGllbnQuanNcIjtcbmltcG9ydCB7IEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQgfSBmcm9tIFwiLi9leGVjdXRpb24taGlzdG9yeS1jbGllbnQuanNcIjtcbmltcG9ydCB7IFNlbmRTaWduYWxSZXF1ZXN0LCBXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dSdW50aW1lQ2xpZW50LCB3b3JrZmxvd3MgfSBmcm9tIFwiLi4vLi4vaW5kZXguanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSdW50aW1lU2VydmljZUNsaWVudFByb3BzIHtcbiAgd29ya2Zsb3dDbGllbnQ6IFdvcmtmbG93Q2xpZW50O1xuICBleGVjdXRpb25IaXN0b3J5Q2xpZW50OiBFeGVjdXRpb25IaXN0b3J5Q2xpZW50O1xuICBldmVudENsaWVudDogRXZlbnRDbGllbnQ7XG4gIHdvcmtmbG93UnVudGltZUNsaWVudDogV29ya2Zsb3dSdW50aW1lQ2xpZW50O1xufVxuXG4vKipcbiAqIEFuIGltcGxlbWVudGF0aW9uIG9mIHRoZSB7QGxpbmsgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50fSB1c2luZyB0aGUgZXZlbnR1YWwgcnVudGltZSBjbGllbnRzLlxuICpcbiAqIEludGVuZGVkIHRvIGJlIHVzZWQgd2hlbiB0aGVyZSBpcyBkaXJlY3QgYWNjZXNzIHRvIHRoZSBldmVudHVhbCBzZXJ2aWNlIGludGVybmFscy5cbiAqL1xuZXhwb3J0IGNsYXNzIFJ1bnRpbWVTZXJ2aWNlQ2xpZW50IGltcGxlbWVudHMgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwcm9wczogUnVudGltZVNlcnZpY2VDbGllbnRQcm9wcykge31cblxuICBwdWJsaWMgYXN5bmMgZ2V0V29ya2Zsb3dzKCk6IFByb21pc2U8R2V0V29ya2Zsb3dSZXNwb25zZT4ge1xuICAgIHJldHVybiB7XG4gICAgICB3b3JrZmxvd3M6IEFycmF5LmZyb20od29ya2Zsb3dzKCkua2V5cygpKS5tYXAoKGspID0+ICh7IG5hbWU6IGsgfSkpLFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc3RhcnRFeGVjdXRpb248VyBleHRlbmRzIFdvcmtmbG93ID0gV29ya2Zsb3c+KFxuICAgIHJlcXVlc3Q6IFN0YXJ0RXhlY3V0aW9uUmVxdWVzdDxXPlxuICApOiBQcm9taXNlPEV4ZWN1dGlvbkhhbmRsZTxXPj4ge1xuICAgIGNvbnN0IGV4ZWN1dGlvbklkID0gYXdhaXQgdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5zdGFydFdvcmtmbG93PFc+KFxuICAgICAgcmVxdWVzdFxuICAgICk7XG4gICAgcmV0dXJuIG5ldyBFeGVjdXRpb25IYW5kbGUoZXhlY3V0aW9uSWQsIHRoaXMpO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGdldEV4ZWN1dGlvbnMoXG4gICAgcmVxdWVzdDogR2V0RXhlY3V0aW9uc1JlcXVlc3RcbiAgKTogUHJvbWlzZTxHZXRFeGVjdXRpb25zUmVzcG9uc2U+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5nZXRFeGVjdXRpb25zKHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIGdldEV4ZWN1dGlvbihcbiAgICBleGVjdXRpb25JZDogc3RyaW5nXG4gICk6IFByb21pc2U8RXhlY3V0aW9uPGFueT4gfCB1bmRlZmluZWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5nZXRFeGVjdXRpb24oZXhlY3V0aW9uSWQpO1xuICB9XG5cbiAgcHVibGljIGdldEV4ZWN1dGlvbkhpc3RvcnkoXG4gICAgcmVxdWVzdDogRXhlY3V0aW9uRXZlbnRzUmVxdWVzdFxuICApOiBQcm9taXNlPEV4ZWN1dGlvbkV2ZW50c1Jlc3BvbnNlPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMuZXhlY3V0aW9uSGlzdG9yeUNsaWVudC5nZXRFdmVudHMocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0RXhlY3V0aW9uV29ya2Zsb3dIaXN0b3J5KFxuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxFeGVjdXRpb25IaXN0b3J5UmVzcG9uc2U+IHtcbiAgICBjb25zdCBldmVudHMgPSBhd2FpdCB0aGlzLnByb3BzLndvcmtmbG93UnVudGltZUNsaWVudC5nZXRIaXN0b3J5KFxuICAgICAgZXhlY3V0aW9uSWRcbiAgICApO1xuICAgIHJldHVybiB7XG4gICAgICBldmVudHMsXG4gICAgfTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBzZW5kU2lnbmFsKHJlcXVlc3Q6IFNlbmRTaWduYWxSZXF1ZXN0KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuc2VuZFNpZ25hbChyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBwdWJsaXNoRXZlbnRzKHJlcXVlc3Q6IFB1Ymxpc2hFdmVudHNSZXF1ZXN0KTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMuZXZlbnRDbGllbnQucHVibGlzaCguLi5yZXF1ZXN0LmV2ZW50cyk7XG4gIH1cblxuICBwdWJsaWMgc2VuZEFjdGl2aXR5U3VjY2VzcyhcbiAgICByZXF1ZXN0OiBPbWl0PFNlbmRBY3Rpdml0eVN1Y2Nlc3NSZXF1ZXN0PGFueT4sIFwidHlwZVwiPlxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5jb21wbGV0ZUFjdGl2aXR5KHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIHNlbmRBY3Rpdml0eUZhaWx1cmUoXG4gICAgcmVxdWVzdDogT21pdDxTZW5kQWN0aXZpdHlGYWlsdXJlUmVxdWVzdCwgXCJ0eXBlXCI+XG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmZhaWxBY3Rpdml0eShyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBzZW5kQWN0aXZpdHlIZWFydGJlYXQoXG4gICAgcmVxdWVzdDogT21pdDxTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXF1ZXN0LCBcInR5cGVcIj5cbiAgKTogUHJvbWlzZTxTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZT4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmhlYXJ0YmVhdEFjdGl2aXR5KHJlcXVlc3QpO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicnVudGltZS1zZXJ2aWNlLWNsaWVudHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3J1bnRpbWUtc2VydmljZS1jbGllbnRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWVBLE9BQU8sRUFBYSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUtoRSxPQUFPLEVBQXlCLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBU2xFOzs7O0dBSUc7QUFDSCxNQUFNLE9BQU8sb0JBQW9CO0lBQy9CLFlBQW9CLEtBQWdDO1FBQWhDLFVBQUssR0FBTCxLQUFLLENBQTJCO0lBQUcsQ0FBQztJQUVqRCxLQUFLLENBQUMsWUFBWTtRQUN2QixPQUFPO1lBQ0wsU0FBUyxFQUFFLEtBQUssQ0FBQyxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUMsSUFBSSxFQUFFLENBQUMsQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLEVBQUUsRUFBRSxDQUFDLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQztTQUNwRSxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxjQUFjLENBQ3pCLE9BQWlDO1FBRWpDLE1BQU0sRUFBRSxXQUFXLEVBQUUsR0FBRyxNQUFNLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLGNBQWMsQ0FDcEUsT0FBTyxDQUNSLENBQUM7UUFDRixPQUFPLElBQUksZUFBZSxDQUFDLFdBQVcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUNoRCxDQUFDO0lBRU0sS0FBSyxDQUFDLGFBQWEsQ0FDeEIsT0FBNkI7UUFFN0IsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDMUQsQ0FBQztJQUVNLFlBQVksQ0FDakIsV0FBbUI7UUFFbkIsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQUMsV0FBVyxDQUFDLENBQUM7SUFDN0QsQ0FBQztJQUVNLG1CQUFtQixDQUN4QixPQUErQjtRQUUvQixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsc0JBQXNCLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFFTSxLQUFLLENBQUMsMkJBQTJCLENBQ3RDLFdBQW1CO1FBRW5CLE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxVQUFVLENBQzlELFdBQVcsQ0FDWixDQUFDO1FBQ0YsT0FBTztZQUNMLE1BQU07U0FDUCxDQUFDO0lBQ0osQ0FBQztJQUVNLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBMEI7UUFDaEQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDdkQsQ0FBQztJQUVNLGFBQWEsQ0FBQyxPQUE2QjtRQUNoRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNqRSxDQUFDO0lBRU0sbUJBQW1CLENBQ3hCLE9BQXNEO1FBRXRELE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsbUJBQW1CLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDaEUsQ0FBQztJQUVNLG1CQUFtQixDQUN4QixPQUFpRDtRQUVqRCxPQUFPLElBQUksQ0FBQyxLQUFLLENBQUMsY0FBYyxDQUFDLG1CQUFtQixDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBQ2hFLENBQUM7SUFFTSxxQkFBcUIsQ0FDMUIsT0FBbUQ7UUFFbkQsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxxQkFBcUIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNsRSxDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBTZW5kQWN0aXZpdHlTdWNjZXNzUmVxdWVzdCxcbiAgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50LFxuICBFeGVjdXRpb25FdmVudHNSZXF1ZXN0LFxuICBFeGVjdXRpb25FdmVudHNSZXNwb25zZSxcbiAgRXhlY3V0aW9uSGlzdG9yeVJlc3BvbnNlLFxuICBTZW5kQWN0aXZpdHlGYWlsdXJlUmVxdWVzdCxcbiAgR2V0RXhlY3V0aW9uc1JlcXVlc3QsXG4gIEdldEV4ZWN1dGlvbnNSZXNwb25zZSxcbiAgR2V0V29ya2Zsb3dSZXNwb25zZSxcbiAgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVxdWVzdCxcbiAgUHVibGlzaEV2ZW50c1JlcXVlc3QsXG4gIFN0YXJ0RXhlY3V0aW9uUmVxdWVzdCxcbiAgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2UsXG59IGZyb20gXCIuLi8uLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgRXhlY3V0aW9uLCBFeGVjdXRpb25IYW5kbGUgfSBmcm9tIFwiLi4vLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvdyB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy5qc1wiO1xuaW1wb3J0IHsgRXZlbnRDbGllbnQgfSBmcm9tIFwiLi9ldmVudC1jbGllbnQuanNcIjtcbmltcG9ydCB7IEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQgfSBmcm9tIFwiLi9leGVjdXRpb24taGlzdG9yeS1jbGllbnQuanNcIjtcbmltcG9ydCB7IFNlbmRTaWduYWxSZXF1ZXN0LCBXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dSdW50aW1lQ2xpZW50LCB3b3JrZmxvd3MgfSBmcm9tIFwiLi4vLi4vaW5kZXguanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBSdW50aW1lU2VydmljZUNsaWVudFByb3BzIHtcbiAgd29ya2Zsb3dDbGllbnQ6IFdvcmtmbG93Q2xpZW50O1xuICBleGVjdXRpb25IaXN0b3J5Q2xpZW50OiBFeGVjdXRpb25IaXN0b3J5Q2xpZW50O1xuICBldmVudENsaWVudDogRXZlbnRDbGllbnQ7XG4gIHdvcmtmbG93UnVudGltZUNsaWVudDogV29ya2Zsb3dSdW50aW1lQ2xpZW50O1xufVxuXG4vKipcbiAqIEFuIGltcGxlbWVudGF0aW9uIG9mIHRoZSB7QGxpbmsgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50fSB1c2luZyB0aGUgZXZlbnR1YWwgcnVudGltZSBjbGllbnRzLlxuICpcbiAqIEludGVuZGVkIHRvIGJlIHVzZWQgd2hlbiB0aGVyZSBpcyBkaXJlY3QgYWNjZXNzIHRvIHRoZSBldmVudHVhbCBzZXJ2aWNlIGludGVybmFscy5cbiAqL1xuZXhwb3J0IGNsYXNzIFJ1bnRpbWVTZXJ2aWNlQ2xpZW50IGltcGxlbWVudHMgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IHtcbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwcm9wczogUnVudGltZVNlcnZpY2VDbGllbnRQcm9wcykge31cblxuICBwdWJsaWMgYXN5bmMgZ2V0V29ya2Zsb3dzKCk6IFByb21pc2U8R2V0V29ya2Zsb3dSZXNwb25zZT4ge1xuICAgIHJldHVybiB7XG4gICAgICB3b3JrZmxvd3M6IEFycmF5LmZyb20od29ya2Zsb3dzKCkua2V5cygpKS5tYXAoKGspID0+ICh7IG5hbWU6IGsgfSkpLFxuICAgIH07XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgc3RhcnRFeGVjdXRpb248VyBleHRlbmRzIFdvcmtmbG93ID0gV29ya2Zsb3c+KFxuICAgIHJlcXVlc3Q6IFN0YXJ0RXhlY3V0aW9uUmVxdWVzdDxXPlxuICApOiBQcm9taXNlPEV4ZWN1dGlvbkhhbmRsZTxXPj4ge1xuICAgIGNvbnN0IHsgZXhlY3V0aW9uSWQgfSA9IGF3YWl0IHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuc3RhcnRFeGVjdXRpb248Vz4oXG4gICAgICByZXF1ZXN0XG4gICAgKTtcbiAgICByZXR1cm4gbmV3IEV4ZWN1dGlvbkhhbmRsZShleGVjdXRpb25JZCwgdGhpcyk7XG4gIH1cblxuICBwdWJsaWMgYXN5bmMgZ2V0RXhlY3V0aW9ucyhcbiAgICByZXF1ZXN0OiBHZXRFeGVjdXRpb25zUmVxdWVzdFxuICApOiBQcm9taXNlPEdldEV4ZWN1dGlvbnNSZXNwb25zZT4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmdldEV4ZWN1dGlvbnMocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0RXhlY3V0aW9uKFxuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmdcbiAgKTogUHJvbWlzZTxFeGVjdXRpb248YW55PiB8IHVuZGVmaW5lZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LmdldEV4ZWN1dGlvbihleGVjdXRpb25JZCk7XG4gIH1cblxuICBwdWJsaWMgZ2V0RXhlY3V0aW9uSGlzdG9yeShcbiAgICByZXF1ZXN0OiBFeGVjdXRpb25FdmVudHNSZXF1ZXN0XG4gICk6IFByb21pc2U8RXhlY3V0aW9uRXZlbnRzUmVzcG9uc2U+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5leGVjdXRpb25IaXN0b3J5Q2xpZW50LmdldEV2ZW50cyhyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBnZXRFeGVjdXRpb25Xb3JrZmxvd0hpc3RvcnkoXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZ1xuICApOiBQcm9taXNlPEV4ZWN1dGlvbkhpc3RvcnlSZXNwb25zZT4ge1xuICAgIGNvbnN0IGV2ZW50cyA9IGF3YWl0IHRoaXMucHJvcHMud29ya2Zsb3dSdW50aW1lQ2xpZW50LmdldEhpc3RvcnkoXG4gICAgICBleGVjdXRpb25JZFxuICAgICk7XG4gICAgcmV0dXJuIHtcbiAgICAgIGV2ZW50cyxcbiAgICB9O1xuICB9XG5cbiAgcHVibGljIGFzeW5jIHNlbmRTaWduYWwocmVxdWVzdDogU2VuZFNpZ25hbFJlcXVlc3QpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy53b3JrZmxvd0NsaWVudC5zZW5kU2lnbmFsKHJlcXVlc3QpO1xuICB9XG5cbiAgcHVibGljIHB1Ymxpc2hFdmVudHMocmVxdWVzdDogUHVibGlzaEV2ZW50c1JlcXVlc3QpOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5wcm9wcy5ldmVudENsaWVudC5wdWJsaXNoRXZlbnRzKC4uLnJlcXVlc3QuZXZlbnRzKTtcbiAgfVxuXG4gIHB1YmxpYyBzZW5kQWN0aXZpdHlTdWNjZXNzKFxuICAgIHJlcXVlc3Q6IE9taXQ8U2VuZEFjdGl2aXR5U3VjY2Vzc1JlcXVlc3Q8YW55PiwgXCJ0eXBlXCI+XG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LnNlbmRBY3Rpdml0eVN1Y2Nlc3MocmVxdWVzdCk7XG4gIH1cblxuICBwdWJsaWMgc2VuZEFjdGl2aXR5RmFpbHVyZShcbiAgICByZXF1ZXN0OiBPbWl0PFNlbmRBY3Rpdml0eUZhaWx1cmVSZXF1ZXN0LCBcInR5cGVcIj5cbiAgKTogUHJvbWlzZTx2b2lkPiB7XG4gICAgcmV0dXJuIHRoaXMucHJvcHMud29ya2Zsb3dDbGllbnQuc2VuZEFjdGl2aXR5RmFpbHVyZShyZXF1ZXN0KTtcbiAgfVxuXG4gIHB1YmxpYyBzZW5kQWN0aXZpdHlIZWFydGJlYXQoXG4gICAgcmVxdWVzdDogT21pdDxTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXF1ZXN0LCBcInR5cGVcIj5cbiAgKTogUHJvbWlzZTxTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZT4ge1xuICAgIHJldHVybiB0aGlzLnByb3BzLndvcmtmbG93Q2xpZW50LnNlbmRBY3Rpdml0eUhlYXJ0YmVhdChyZXF1ZXN0KTtcbiAgfVxufVxuIl19

@@ -6,3 +6,3 @@ import { HistoryStateEvent } from "../../workflow-events.js";

import { ActivityRuntimeClient } from "./activity-runtime-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse } from "../../service-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse, StartExecutionResponse } from "../../service-client.js";
export declare abstract class WorkflowClient {

@@ -18,3 +18,3 @@ private activityRuntimeClient;

*/
abstract startWorkflow<W extends Workflow = Workflow>(request: StartWorkflowRequest<W>): Promise<string>;
abstract startExecution<W extends Workflow = Workflow>(request: StartChildExecutionRequest<W> | StartExecutionRequest<W>): Promise<StartExecutionResponse>;
/**

@@ -37,9 +37,9 @@ * Submit events to be processed by a workflow's orchestrator.

/**
* Completes an async activity causing it to return the given value.
* Succeeds an async activity causing it to return the given value.
*/
completeActivity({ activityToken, result, }: Omit<SendActivitySuccessRequest, "type">): Promise<void>;
sendActivitySuccess({ activityToken, result, }: Omit<SendActivitySuccessRequest, "type">): Promise<void>;
/**
* Fails an async activity causing it to throw the given error.
*/
failActivity({ activityToken, error, message, }: Omit<SendActivityFailureRequest, "type">): Promise<void>;
sendActivityFailure({ activityToken, error, message, }: Omit<SendActivityFailureRequest, "type">): Promise<void>;
/**

@@ -50,3 +50,3 @@ * Submits a "heartbeat" for the given activityToken.

*/
heartbeatActivity(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
sendActivityHeartbeat(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
private sendActivityResult;

@@ -63,15 +63,9 @@ }

}
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId?: string;
export interface StartChildExecutionRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId: string;
/**
* Sequence ID of this execution if this is a child workflow
*/
seq?: number;
seq: number;
}
export interface StartWorkflowResponse {
/**
* ID of the started workflow execution.
*/
executionId: string;
}
//# sourceMappingURL=workflow-client.d.ts.map

@@ -28,7 +28,7 @@ import { createEvent, WorkflowEventType, } from "../../workflow-events.js";

/**
* Completes an async activity causing it to return the given value.
* Succeeds an async activity causing it to return the given value.
*/
async completeActivity({ activityToken, result, }) {
async sendActivitySuccess({ activityToken, result, }) {
await this.sendActivityResult(activityToken, {
type: WorkflowEventType.ActivityCompleted,
type: WorkflowEventType.ActivitySucceeded,
result,

@@ -40,3 +40,3 @@ });

*/
async failActivity({ activityToken, error, message, }) {
async sendActivityFailure({ activityToken, error, message, }) {
await this.sendActivityResult(activityToken, {

@@ -53,3 +53,3 @@ type: WorkflowEventType.ActivityFailed,

*/
async heartbeatActivity(request) {
async sendActivityHeartbeat(request) {
const data = decodeActivityToken(request.activityToken);

@@ -70,2 +70,2 @@ const execution = await this.getExecution(data.payload.executionId);

}
//# 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,EAGL,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAY3D,MAAM,OAAgB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IA+BJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,WAAW,GACf,OAAO,OAAO,CAAC,SAAS,KAAK,QAAQ;YACnC,CAAC,CAAC,OAAO,CAAC,SAAS;YACnB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC;QACpC,MAAM,IAAI,CAAC,kBAAkB,CAC3B,WAAW,EACX,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,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACmC;QACzC,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,GACkC;QACzC,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,OAAmD;QAEnD,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,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAC9B,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,CACT;YACE,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,EACD,IAAI,CAAC,QAAQ,EAAE,CAChB,CACF,CAAC;IACJ,CAAC;CACF","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  Execution,\n  ExecutionHandle,\n  ExecutionStatus,\n} from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\nimport {\n  SendActivitySuccessRequest,\n  SendActivityFailureRequest,\n  GetExecutionsRequest,\n  GetExecutionsResponse,\n  SendActivityHeartbeatRequest,\n  StartExecutionRequest,\n  SendActivityHeartbeatResponse,\n} from \"../../service-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\n    private activityRuntimeClient: ActivityRuntimeClient,\n    protected baseTime: () => Date\n  ) {}\n\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(\n    props: GetExecutionsRequest\n  ): Promise<GetExecutionsResponse>;\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    const executionId =\n      typeof request.execution === \"string\"\n        ? request.execution\n        : request.execution.executionId;\n    await this.submitWorkflowTask(\n      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        this.baseTime(),\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  }: Omit<SendActivitySuccessRequest, \"type\">): 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  }: Omit<SendActivityFailureRequest, \"type\">): 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: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse> {\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      this.baseTime().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        {\n          ...event,\n          seq: data.payload.seq,\n        },\n        this.baseTime()\n      )\n    );\n  }\n}\n\nexport interface SendSignalRequest<Payload = any> {\n  execution: ExecutionHandle<any> | string;\n  signal: string | Signal<Payload>;\n  payload?: Payload;\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 StartExecutionRequest<W>,\n    WorkflowOptions {\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"]}
//# 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,EAGL,eAAe,GAChB,MAAM,oBAAoB,CAAC;AAG5B,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAa3D,MAAM,OAAgB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IA+BJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,WAAW,GACf,OAAO,OAAO,CAAC,SAAS,KAAK,QAAQ;YACnC,CAAC,CAAC,OAAO,CAAC,SAAS;YACnB,CAAC,CAAC,OAAO,CAAC,SAAS,CAAC,WAAW,CAAC;QACpC,MAAM,IAAI,CAAC,kBAAkB,CAC3B,WAAW,EACX,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,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,mBAAmB,CAAC,EAC/B,aAAa,EACb,MAAM,GACmC;QACzC,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,mBAAmB,CAAC,EAC/B,aAAa,EACb,KAAK,EACL,OAAO,GACkC;QACzC,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,qBAAqB,CAChC,OAAmD;QAEnD,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,CAAC,QAAQ,EAAE,CAAC,WAAW,EAAE,CAC9B,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,CACT;YACE,GAAG,KAAK;YACR,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,GAAG;SACtB,EACD,IAAI,CAAC,QAAQ,EAAE,CAChB,CACF,CAAC;IACJ,CAAC;CACF","sourcesContent":["import {\n  ActivitySucceeded,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  Execution,\n  ExecutionHandle,\n  ExecutionStatus,\n} from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\nimport {\n  SendActivitySuccessRequest,\n  SendActivityFailureRequest,\n  GetExecutionsRequest,\n  GetExecutionsResponse,\n  SendActivityHeartbeatRequest,\n  StartExecutionRequest,\n  SendActivityHeartbeatResponse,\n  StartExecutionResponse,\n} from \"../../service-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\n    private activityRuntimeClient: ActivityRuntimeClient,\n    protected baseTime: () => Date\n  ) {}\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   * @returns\n   */\n  public abstract startExecution<W extends Workflow = Workflow>(\n    request: StartChildExecutionRequest<W> | StartExecutionRequest<W>\n  ): Promise<StartExecutionResponse>;\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(\n    props: GetExecutionsRequest\n  ): Promise<GetExecutionsResponse>;\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    const executionId =\n      typeof request.execution === \"string\"\n        ? request.execution\n        : request.execution.executionId;\n    await this.submitWorkflowTask(\n      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        this.baseTime(),\n        request.id\n      )\n    );\n  }\n\n  /**\n   * Succeeds an async activity causing it to return the given value.\n   */\n  public async sendActivitySuccess({\n    activityToken,\n    result,\n  }: Omit<SendActivitySuccessRequest, \"type\">): Promise<void> {\n    await this.sendActivityResult<ActivitySucceeded>(activityToken, {\n      type: WorkflowEventType.ActivitySucceeded,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async sendActivityFailure({\n    activityToken,\n    error,\n    message,\n  }: Omit<SendActivityFailureRequest, \"type\">): 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 sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse> {\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      this.baseTime().toISOString()\n    );\n  }\n\n  private async sendActivityResult<\n    E extends ActivitySucceeded | 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<ActivitySucceeded | ActivityFailed>(\n        {\n          ...event,\n          seq: data.payload.seq,\n        },\n        this.baseTime()\n      )\n    );\n  }\n}\n\nexport interface SendSignalRequest<Payload = any> {\n  execution: ExecutionHandle<any> | string;\n  signal: string | Signal<Payload>;\n  payload?: Payload;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id?: string;\n}\n\nexport interface StartChildExecutionRequest<W extends Workflow = Workflow>\n  extends StartExecutionRequest<W>,\n    WorkflowOptions {\n  parentExecutionId: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq: number;\n}\n"]}
import { HistoryStateEvent } from "../../workflow-events.js";
import { CompleteExecution, FailedExecution } from "../../execution.js";
import { SucceededExecution, FailedExecution } from "../../execution.js";
import { ActivityWorkerRequest } from "../handlers/activity-worker.js";
import { WorkflowClient } from "./workflow-client.js";
export interface CompleteExecutionRequest {
export interface SucceedExecutionRequest {
executionId: string;

@@ -14,3 +14,3 @@ result?: any;

}
export declare function isFailedExecutionRequest(executionRequest: CompleteExecutionRequest | FailExecutionRequest): executionRequest is FailExecutionRequest;
export declare function isFailedExecutionRequest(executionRequest: SucceedExecutionRequest | FailExecutionRequest): executionRequest is FailExecutionRequest;
export interface UpdateHistoryRequest {

@@ -28,7 +28,7 @@ executionId: string;

abstract startActivity(request: ActivityWorkerRequest): Promise<void>;
completeExecution(request: CompleteExecutionRequest): Promise<CompleteExecution>;
succeedExecution(request: SucceedExecutionRequest): Promise<SucceededExecution>;
failExecution(request: FailExecutionRequest): Promise<FailedExecution>;
protected abstract updateExecution(request: FailExecutionRequest | CompleteExecutionRequest): Promise<CompleteExecution | FailedExecution>;
protected abstract updateExecution(request: FailExecutionRequest | SucceedExecutionRequest): Promise<SucceededExecution | FailedExecution>;
private reportCompletionToParent;
}
//# sourceMappingURL=workflow-runtime-client.d.ts.map

@@ -9,3 +9,3 @@ import { WorkflowEventType } from "../../workflow-events.js";

}
async completeExecution(request) {
async succeedExecution(request) {
const execution = await this.updateExecution(request);

@@ -31,3 +31,3 @@ console.log("execution", execution);

? {
type: WorkflowEventType.ChildWorkflowCompleted,
type: WorkflowEventType.ChildWorkflowSucceeded,
result: args[0],

@@ -43,2 +43,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctcnVudGltZS1jbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3dvcmtmbG93LXJ1bnRpbWUtY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsaUJBQWlCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQWdCaEYsTUFBTSxVQUFVLHdCQUF3QixDQUN0QyxnQkFBaUU7SUFFakUsT0FBTyxPQUFPLElBQUksZ0JBQWdCLENBQUM7QUFDckMsQ0FBQztBQU9ELE1BQU0sT0FBZ0IscUJBQXFCO0lBQ3pDLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtJQUFHLENBQUM7SUFVL0MsS0FBSyxDQUFDLGlCQUFpQixDQUM1QixPQUFpQztRQUVqQyxNQUFNLFNBQVMsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEMsSUFBSSxTQUFTLENBQUMsTUFBTSxFQUFFO1lBQ3BCLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUNqQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFDNUIsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQ3BCLE9BQU8sQ0FBQyxNQUFNLENBQ2YsQ0FBQztTQUNIO1FBRUQsT0FBTyxTQUE4QixDQUFDO0lBQ3hDLENBQUM7SUFFTSxLQUFLLENBQUMsYUFBYSxDQUN4QixPQUE2QjtRQUU3QixNQUFNLFNBQVMsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdEQsSUFBSSxTQUFTLENBQUMsTUFBTSxFQUFFO1lBQ3BCLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUNqQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFDNUIsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQ3BCLE9BQU8sQ0FBQyxLQUFLLEVBQ2IsT0FBTyxDQUFDLE9BQU8sQ0FDaEIsQ0FBQztTQUNIO1FBRUQsT0FBTyxTQUE0QixDQUFDO0lBQ3RDLENBQUM7SUFNTyxLQUFLLENBQUMsd0JBQXdCLENBQ3BDLGlCQUF5QixFQUN6QixHQUFXLEVBQ1gsR0FBRyxJQUFzRDtRQUV6RCxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLEVBQUU7WUFDOUQsR0FBRztZQUNILFNBQVMsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRTtZQUNuQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDO2dCQUNuQixDQUFDLENBQUM7b0JBQ0UsSUFBSSxFQUFFLGlCQUFpQixDQUFDLHNCQUFzQjtvQkFDOUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7aUJBQ2hCO2dCQUNILENBQUMsQ0FBQztvQkFDRSxJQUFJLEVBQUUsaUJBQWlCLENBQUMsbUJBQW1CO29CQUMzQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztvQkFDZCxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDakIsQ0FBQztTQUNQLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhpc3RvcnlTdGF0ZUV2ZW50LCBXb3JrZmxvd0V2ZW50VHlwZSB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcbmltcG9ydCB7IENvbXBsZXRlRXhlY3V0aW9uLCBGYWlsZWRFeGVjdXRpb24gfSBmcm9tIFwiLi4vLi4vZXhlY3V0aW9uLmpzXCI7XG5pbXBvcnQgeyBBY3Rpdml0eVdvcmtlclJlcXVlc3QgfSBmcm9tIFwiLi4vaGFuZGxlcnMvYWN0aXZpdHktd29ya2VyLmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIENvbXBsZXRlRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIHJlc3VsdD86IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGVycm9yOiBzdHJpbmc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkRXhlY3V0aW9uUmVxdWVzdChcbiAgZXhlY3V0aW9uUmVxdWVzdDogQ29tcGxldGVFeGVjdXRpb25SZXF1ZXN0IHwgRmFpbEV4ZWN1dGlvblJlcXVlc3Rcbik6IGV4ZWN1dGlvblJlcXVlc3QgaXMgRmFpbEV4ZWN1dGlvblJlcXVlc3Qge1xuICByZXR1cm4gXCJlcnJvclwiIGluIGV4ZWN1dGlvblJlcXVlc3Q7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgVXBkYXRlSGlzdG9yeVJlcXVlc3Qge1xuICBleGVjdXRpb25JZDogc3RyaW5nO1xuICBldmVudHM6IEhpc3RvcnlTdGF0ZUV2ZW50W107XG59XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBXb3JrZmxvd1J1bnRpbWVDbGllbnQge1xuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHdvcmtmbG93Q2xpZW50OiBXb3JrZmxvd0NsaWVudCkge31cbiAgcHVibGljIGFic3RyYWN0IGdldEhpc3RvcnkoZXhlY3V0aW9uSWQ6IHN0cmluZyk6IFByb21pc2U8SGlzdG9yeVN0YXRlRXZlbnRbXT47XG5cbiAgLy8gVE9ETzogZXRhZ1xuICBwdWJsaWMgYWJzdHJhY3QgdXBkYXRlSGlzdG9yeShcbiAgICByZXF1ZXN0OiBVcGRhdGVIaXN0b3J5UmVxdWVzdFxuICApOiBQcm9taXNlPHsgYnl0ZXM6IG51bWJlciB9PjtcblxuICBwdWJsaWMgYWJzdHJhY3Qgc3RhcnRBY3Rpdml0eShyZXF1ZXN0OiBBY3Rpdml0eVdvcmtlclJlcXVlc3QpOiBQcm9taXNlPHZvaWQ+O1xuXG4gIHB1YmxpYyBhc3luYyBjb21wbGV0ZUV4ZWN1dGlvbihcbiAgICByZXF1ZXN0OiBDb21wbGV0ZUV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxDb21wbGV0ZUV4ZWN1dGlvbj4ge1xuICAgIGNvbnN0IGV4ZWN1dGlvbiA9IGF3YWl0IHRoaXMudXBkYXRlRXhlY3V0aW9uKHJlcXVlc3QpO1xuICAgIGNvbnNvbGUubG9nKFwiZXhlY3V0aW9uXCIsIGV4ZWN1dGlvbik7XG4gICAgaWYgKGV4ZWN1dGlvbi5wYXJlbnQpIHtcbiAgICAgIGF3YWl0IHRoaXMucmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LmV4ZWN1dGlvbklkLFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LnNlcSxcbiAgICAgICAgcmVxdWVzdC5yZXN1bHRcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGV4ZWN1dGlvbiBhcyBDb21wbGV0ZUV4ZWN1dGlvbjtcbiAgfVxuXG4gIHB1YmxpYyBhc3luYyBmYWlsRXhlY3V0aW9uKFxuICAgIHJlcXVlc3Q6IEZhaWxFeGVjdXRpb25SZXF1ZXN0XG4gICk6IFByb21pc2U8RmFpbGVkRXhlY3V0aW9uPiB7XG4gICAgY29uc3QgZXhlY3V0aW9uID0gYXdhaXQgdGhpcy51cGRhdGVFeGVjdXRpb24ocmVxdWVzdCk7XG4gICAgaWYgKGV4ZWN1dGlvbi5wYXJlbnQpIHtcbiAgICAgIGF3YWl0IHRoaXMucmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LmV4ZWN1dGlvbklkLFxuICAgICAgICBleGVjdXRpb24ucGFyZW50LnNlcSxcbiAgICAgICAgcmVxdWVzdC5lcnJvcixcbiAgICAgICAgcmVxdWVzdC5tZXNzYWdlXG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBleGVjdXRpb24gYXMgRmFpbGVkRXhlY3V0aW9uO1xuICB9XG5cbiAgcHJvdGVjdGVkIGFic3RyYWN0IHVwZGF0ZUV4ZWN1dGlvbihcbiAgICByZXF1ZXN0OiBGYWlsRXhlY3V0aW9uUmVxdWVzdCB8IENvbXBsZXRlRXhlY3V0aW9uUmVxdWVzdFxuICApOiBQcm9taXNlPENvbXBsZXRlRXhlY3V0aW9uIHwgRmFpbGVkRXhlY3V0aW9uPjtcblxuICBwcml2YXRlIGFzeW5jIHJlcG9ydENvbXBsZXRpb25Ub1BhcmVudChcbiAgICBwYXJlbnRFeGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHNlcTogbnVtYmVyLFxuICAgIC4uLmFyZ3M6IFtyZXN1bHQ6IGFueV0gfCBbZXJyb3I6IHN0cmluZywgbWVzc2FnZTogc3RyaW5nXVxuICApIHtcbiAgICBhd2FpdCB0aGlzLndvcmtmbG93Q2xpZW50LnN1Ym1pdFdvcmtmbG93VGFzayhwYXJlbnRFeGVjdXRpb25JZCwge1xuICAgICAgc2VxLFxuICAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvSVNPU3RyaW5nKCksXG4gICAgICAuLi4oYXJncy5sZW5ndGggPT09IDFcbiAgICAgICAgPyB7XG4gICAgICAgICAgICB0eXBlOiBXb3JrZmxvd0V2ZW50VHlwZS5DaGlsZFdvcmtmbG93Q29tcGxldGVkLFxuICAgICAgICAgICAgcmVzdWx0OiBhcmdzWzBdLFxuICAgICAgICAgIH1cbiAgICAgICAgOiB7XG4gICAgICAgICAgICB0eXBlOiBXb3JrZmxvd0V2ZW50VHlwZS5DaGlsZFdvcmtmbG93RmFpbGVkLFxuICAgICAgICAgICAgZXJyb3I6IGFyZ3NbMF0sXG4gICAgICAgICAgICBtZXNzYWdlOiBhcmdzWzFdLFxuICAgICAgICAgIH0pLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2Zsb3ctcnVudGltZS1jbGllbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL3dvcmtmbG93LXJ1bnRpbWUtY2xpZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBcUIsaUJBQWlCLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQWdCaEYsTUFBTSxVQUFVLHdCQUF3QixDQUN0QyxnQkFBZ0U7SUFFaEUsT0FBTyxPQUFPLElBQUksZ0JBQWdCLENBQUM7QUFDckMsQ0FBQztBQU9ELE1BQU0sT0FBZ0IscUJBQXFCO0lBQ3pDLFlBQW9CLGNBQThCO1FBQTlCLG1CQUFjLEdBQWQsY0FBYyxDQUFnQjtJQUFHLENBQUM7SUFVL0MsS0FBSyxDQUFDLGdCQUFnQixDQUMzQixPQUFnQztRQUVoQyxNQUFNLFNBQVMsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdEQsT0FBTyxDQUFDLEdBQUcsQ0FBQyxXQUFXLEVBQUUsU0FBUyxDQUFDLENBQUM7UUFDcEMsSUFBSSxTQUFTLENBQUMsTUFBTSxFQUFFO1lBQ3BCLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUNqQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFDNUIsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQ3BCLE9BQU8sQ0FBQyxNQUFNLENBQ2YsQ0FBQztTQUNIO1FBRUQsT0FBTyxTQUErQixDQUFDO0lBQ3pDLENBQUM7SUFFTSxLQUFLLENBQUMsYUFBYSxDQUN4QixPQUE2QjtRQUU3QixNQUFNLFNBQVMsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7UUFDdEQsSUFBSSxTQUFTLENBQUMsTUFBTSxFQUFFO1lBQ3BCLE1BQU0sSUFBSSxDQUFDLHdCQUF3QixDQUNqQyxTQUFTLENBQUMsTUFBTSxDQUFDLFdBQVcsRUFDNUIsU0FBUyxDQUFDLE1BQU0sQ0FBQyxHQUFHLEVBQ3BCLE9BQU8sQ0FBQyxLQUFLLEVBQ2IsT0FBTyxDQUFDLE9BQU8sQ0FDaEIsQ0FBQztTQUNIO1FBRUQsT0FBTyxTQUE0QixDQUFDO0lBQ3RDLENBQUM7SUFNTyxLQUFLLENBQUMsd0JBQXdCLENBQ3BDLGlCQUF5QixFQUN6QixHQUFXLEVBQ1gsR0FBRyxJQUFzRDtRQUV6RCxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsa0JBQWtCLENBQUMsaUJBQWlCLEVBQUU7WUFDOUQsR0FBRztZQUNILFNBQVMsRUFBRSxJQUFJLElBQUksRUFBRSxDQUFDLFdBQVcsRUFBRTtZQUNuQyxHQUFHLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDO2dCQUNuQixDQUFDLENBQUM7b0JBQ0UsSUFBSSxFQUFFLGlCQUFpQixDQUFDLHNCQUFzQjtvQkFDOUMsTUFBTSxFQUFFLElBQUksQ0FBQyxDQUFDLENBQUM7aUJBQ2hCO2dCQUNILENBQUMsQ0FBQztvQkFDRSxJQUFJLEVBQUUsaUJBQWlCLENBQUMsbUJBQW1CO29CQUMzQyxLQUFLLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztvQkFDZCxPQUFPLEVBQUUsSUFBSSxDQUFDLENBQUMsQ0FBQztpQkFDakIsQ0FBQztTQUNQLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEhpc3RvcnlTdGF0ZUV2ZW50LCBXb3JrZmxvd0V2ZW50VHlwZSB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcbmltcG9ydCB7IFN1Y2NlZWRlZEV4ZWN1dGlvbiwgRmFpbGVkRXhlY3V0aW9uIH0gZnJvbSBcIi4uLy4uL2V4ZWN1dGlvbi5qc1wiO1xuaW1wb3J0IHsgQWN0aXZpdHlXb3JrZXJSZXF1ZXN0IH0gZnJvbSBcIi4uL2hhbmRsZXJzL2FjdGl2aXR5LXdvcmtlci5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi93b3JrZmxvdy1jbGllbnQuanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBTdWNjZWVkRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIHJlc3VsdD86IGFueTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGVycm9yOiBzdHJpbmc7XG4gIG1lc3NhZ2U6IHN0cmluZztcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzRmFpbGVkRXhlY3V0aW9uUmVxdWVzdChcbiAgZXhlY3V0aW9uUmVxdWVzdDogU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3QgfCBGYWlsRXhlY3V0aW9uUmVxdWVzdFxuKTogZXhlY3V0aW9uUmVxdWVzdCBpcyBGYWlsRXhlY3V0aW9uUmVxdWVzdCB7XG4gIHJldHVybiBcImVycm9yXCIgaW4gZXhlY3V0aW9uUmVxdWVzdDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBVcGRhdGVIaXN0b3J5UmVxdWVzdCB7XG4gIGV4ZWN1dGlvbklkOiBzdHJpbmc7XG4gIGV2ZW50czogSGlzdG9yeVN0YXRlRXZlbnRbXTtcbn1cblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIFdvcmtmbG93UnVudGltZUNsaWVudCB7XG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgd29ya2Zsb3dDbGllbnQ6IFdvcmtmbG93Q2xpZW50KSB7fVxuICBwdWJsaWMgYWJzdHJhY3QgZ2V0SGlzdG9yeShleGVjdXRpb25JZDogc3RyaW5nKTogUHJvbWlzZTxIaXN0b3J5U3RhdGVFdmVudFtdPjtcblxuICAvLyBUT0RPOiBldGFnXG4gIHB1YmxpYyBhYnN0cmFjdCB1cGRhdGVIaXN0b3J5KFxuICAgIHJlcXVlc3Q6IFVwZGF0ZUhpc3RvcnlSZXF1ZXN0XG4gICk6IFByb21pc2U8eyBieXRlczogbnVtYmVyIH0+O1xuXG4gIHB1YmxpYyBhYnN0cmFjdCBzdGFydEFjdGl2aXR5KHJlcXVlc3Q6IEFjdGl2aXR5V29ya2VyUmVxdWVzdCk6IFByb21pc2U8dm9pZD47XG5cbiAgcHVibGljIGFzeW5jIHN1Y2NlZWRFeGVjdXRpb24oXG4gICAgcmVxdWVzdDogU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxTdWNjZWVkZWRFeGVjdXRpb24+IHtcbiAgICBjb25zdCBleGVjdXRpb24gPSBhd2FpdCB0aGlzLnVwZGF0ZUV4ZWN1dGlvbihyZXF1ZXN0KTtcbiAgICBjb25zb2xlLmxvZyhcImV4ZWN1dGlvblwiLCBleGVjdXRpb24pO1xuICAgIGlmIChleGVjdXRpb24ucGFyZW50KSB7XG4gICAgICBhd2FpdCB0aGlzLnJlcG9ydENvbXBsZXRpb25Ub1BhcmVudChcbiAgICAgICAgZXhlY3V0aW9uLnBhcmVudC5leGVjdXRpb25JZCxcbiAgICAgICAgZXhlY3V0aW9uLnBhcmVudC5zZXEsXG4gICAgICAgIHJlcXVlc3QucmVzdWx0XG4gICAgICApO1xuICAgIH1cblxuICAgIHJldHVybiBleGVjdXRpb24gYXMgU3VjY2VlZGVkRXhlY3V0aW9uO1xuICB9XG5cbiAgcHVibGljIGFzeW5jIGZhaWxFeGVjdXRpb24oXG4gICAgcmVxdWVzdDogRmFpbEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxGYWlsZWRFeGVjdXRpb24+IHtcbiAgICBjb25zdCBleGVjdXRpb24gPSBhd2FpdCB0aGlzLnVwZGF0ZUV4ZWN1dGlvbihyZXF1ZXN0KTtcbiAgICBpZiAoZXhlY3V0aW9uLnBhcmVudCkge1xuICAgICAgYXdhaXQgdGhpcy5yZXBvcnRDb21wbGV0aW9uVG9QYXJlbnQoXG4gICAgICAgIGV4ZWN1dGlvbi5wYXJlbnQuZXhlY3V0aW9uSWQsXG4gICAgICAgIGV4ZWN1dGlvbi5wYXJlbnQuc2VxLFxuICAgICAgICByZXF1ZXN0LmVycm9yLFxuICAgICAgICByZXF1ZXN0Lm1lc3NhZ2VcbiAgICAgICk7XG4gICAgfVxuXG4gICAgcmV0dXJuIGV4ZWN1dGlvbiBhcyBGYWlsZWRFeGVjdXRpb247XG4gIH1cblxuICBwcm90ZWN0ZWQgYWJzdHJhY3QgdXBkYXRlRXhlY3V0aW9uKFxuICAgIHJlcXVlc3Q6IEZhaWxFeGVjdXRpb25SZXF1ZXN0IHwgU3VjY2VlZEV4ZWN1dGlvblJlcXVlc3RcbiAgKTogUHJvbWlzZTxTdWNjZWVkZWRFeGVjdXRpb24gfCBGYWlsZWRFeGVjdXRpb24+O1xuXG4gIHByaXZhdGUgYXN5bmMgcmVwb3J0Q29tcGxldGlvblRvUGFyZW50KFxuICAgIHBhcmVudEV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gICAgc2VxOiBudW1iZXIsXG4gICAgLi4uYXJnczogW3Jlc3VsdDogYW55XSB8IFtlcnJvcjogc3RyaW5nLCBtZXNzYWdlOiBzdHJpbmddXG4gICkge1xuICAgIGF3YWl0IHRoaXMud29ya2Zsb3dDbGllbnQuc3VibWl0V29ya2Zsb3dUYXNrKHBhcmVudEV4ZWN1dGlvbklkLCB7XG4gICAgICBzZXEsXG4gICAgICB0aW1lc3RhbXA6IG5ldyBEYXRlKCkudG9JU09TdHJpbmcoKSxcbiAgICAgIC4uLihhcmdzLmxlbmd0aCA9PT0gMVxuICAgICAgICA/IHtcbiAgICAgICAgICAgIHR5cGU6IFdvcmtmbG93RXZlbnRUeXBlLkNoaWxkV29ya2Zsb3dTdWNjZWVkZWQsXG4gICAgICAgICAgICByZXN1bHQ6IGFyZ3NbMF0sXG4gICAgICAgICAgfVxuICAgICAgICA6IHtcbiAgICAgICAgICAgIHR5cGU6IFdvcmtmbG93RXZlbnRUeXBlLkNoaWxkV29ya2Zsb3dGYWlsZWQsXG4gICAgICAgICAgICBlcnJvcjogYXJnc1swXSxcbiAgICAgICAgICAgIG1lc3NhZ2U6IGFyZ3NbMV0sXG4gICAgICAgICAgfSksXG4gICAgfSk7XG4gIH1cbn1cbiJdfQ==

@@ -69,3 +69,3 @@ import { isExpectSignalCommand, isPublishEventsCommand, isScheduleActivityCommand, isScheduleWorkflowCommand, isSendSignalCommand, isSleepForCommand, isSleepUntilCommand, isStartConditionCommand, } from "../command.js";

async scheduleChildWorkflow(executionId, command, baseTime) {
await this.props.workflowClient.startWorkflow({
await this.props.workflowClient.startExecution({
workflow: command.name,

@@ -159,3 +159,3 @@ input: command.input,

async publishEvents(command, baseTime) {
await this.props.eventClient.publish(...command.events);
await this.props.eventClient.publishEvents(...command.events);
return createEvent({

@@ -168,2 +168,2 @@ type: WorkflowEventType.EventsPublished,

}
//# 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, baseTime);\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, baseTime);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command, baseTime);\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      {\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startWorkflow({\n      workflow: 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      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      },\n      baseTime\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      {\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    command: SendSignalCommand,\n    baseTime: Date\n  ) {\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      execution: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n\n  private async publishEvents(command: PublishEventsCommand, baseTime: Date) {\n    await this.props.eventClient.publish(...command.events);\n    return createEvent<EventsPublished>(\n      {\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      },\n      baseTime\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, baseTime);\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, baseTime);\n    } else if (isStartConditionCommand(command)) {\n      return this.startCondition(executionId, command, baseTime);\n    } else if (isPublishEventsCommand(command)) {\n      return this.publishEvents(command, baseTime);\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      {\n        type: WorkflowEventType.ActivityScheduled,\n        seq: command.seq,\n        name: command.name,\n      },\n      baseTime\n    );\n  }\n\n  private async scheduleChildWorkflow(\n    executionId: string,\n    command: ScheduleWorkflowCommand,\n    baseTime: Date\n  ): Promise<ChildWorkflowScheduled> {\n    await this.props.workflowClient.startExecution({\n      workflow: 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      {\n        type: WorkflowEventType.ChildWorkflowScheduled,\n        seq: command.seq,\n        name: command.name,\n        input: command.input,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.SleepScheduled,\n        seq: command.seq,\n        untilTime: untilTime.toISOString(),\n      },\n      baseTime\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      {\n        signalId: command.signalId,\n        seq: command.seq,\n        type: WorkflowEventType.ExpectSignalStarted,\n        timeoutSeconds: command.timeoutSeconds,\n      },\n      baseTime\n    );\n  }\n\n  private async sendSignal(\n    executionId: string,\n    command: SendSignalCommand,\n    baseTime: Date\n  ) {\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      execution: childExecutionId,\n      id: `${executionId}/${command.seq}`,\n      payload: command.payload,\n    });\n\n    return createEvent<SignalSent>(\n      {\n        type: WorkflowEventType.SignalSent,\n        executionId: childExecutionId,\n        seq: command.seq,\n        signalId: command.signalId,\n        payload: command.payload,\n      },\n      baseTime\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      {\n        type: WorkflowEventType.ConditionStarted,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n\n  private async publishEvents(command: PublishEventsCommand, baseTime: Date) {\n    await this.props.eventClient.publishEvents(...command.events);\n    return createEvent<EventsPublished>(\n      {\n        type: WorkflowEventType.EventsPublished,\n        events: command.events,\n        seq: command.seq!,\n      },\n      baseTime\n    );\n  }\n}\n"]}

@@ -74,3 +74,3 @@ import { isAsyncResult } from "../../activity.js";

* The activity has declared that it is async, other than logging, there is nothing left to do here.
* The activity should call {@link WorkflowClient.completeActivity} or {@link WorkflowClient.failActivity} when it is done.
* The activity should call {@link WorkflowClient.sendActivitySuccess} or {@link WorkflowClient.sendActivityFailure} when it is done.
*/

@@ -91,3 +91,3 @@ return;

const event = createEvent({
type: WorkflowEventType.ActivityCompleted,
type: WorkflowEventType.ActivitySucceeded,
seq: request.command.seq,

@@ -117,3 +117,3 @@ result,

metrics.putMetric(ActivityMetrics.ActivityFailed, failed ? 1 : 0, Unit.Count);
metrics.putMetric(ActivityMetrics.ActivityCompleted, failed ? 0 : 1, Unit.Count);
metrics.putMetric(ActivityMetrics.ActivitySucceeded, failed ? 0 : 1, Unit.Count);
// The total time from the activity being scheduled until it's result is send to the workflow.

@@ -128,2 +128,2 @@ metrics.putMetric(ActivityMetrics.TotalDuration, duration);

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-worker.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/activity-worker.ts"],"names":[],"mappings":"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","sourcesContent":["import { isAsyncResult } from \"../../activity.js\";\nimport { ScheduleActivityCommand } from \"../../command.js\";\nimport {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  isWorkflowFailed,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  clearActivityContext,\n  registerServiceClient,\n  setActivityContext,\n} from \"../../global.js\";\nimport { createActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"../clients/activity-runtime-client.js\";\nimport { MetricsClient } from \"../clients/metrics-client.js\";\nimport { WorkflowClient } from \"../clients/workflow-client.js\";\nimport {\n  RuntimeServiceClient,\n  Schedule,\n  TimerClient,\n  TimerRequestType,\n} from \"../index.js\";\nimport { Logger } from \"../logger.js\";\nimport { ActivityMetrics, MetricsCommon } from \"../metrics/constants.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed } from \"../metrics/utils.js\";\nimport type { EventClient } from \"../index.js\";\nimport { ActivityProvider } from \"../providers/activity-provider.js\";\nimport { ActivityNotFoundError } from \"../../error.js\";\nimport { extendsError } from \"../../util.js\";\n\nexport interface CreateActivityWorkerProps {\n  activityRuntimeClient: ActivityRuntimeClient;\n  workflowClient: WorkflowClient;\n  timerClient: TimerClient;\n  metricsClient: MetricsClient;\n  logger: Logger;\n  eventClient: EventClient;\n  activityProvider: ActivityProvider;\n  serviceClient?: RuntimeServiceClient;\n}\n\nexport interface ActivityWorkerRequest {\n  scheduledTime: string;\n  workflowName: string;\n  executionId: string;\n  command: ScheduleActivityCommand;\n  retry: number;\n}\n\nexport interface ActivityWorker {\n  (\n    request: ActivityWorkerRequest,\n    baseTime: Date,\n    /**\n     * Allows for a computed end time, for case like the test environment when the end time should be controlled.\n     */\n    getEndTime?: (startTime: Date) => Date\n  ): Promise<void>;\n}\n\n/**\n * Creates a generic function for handling activity worker requests\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 createActivityWorker({\n  activityRuntimeClient,\n  workflowClient,\n  timerClient,\n  metricsClient,\n  logger,\n  activityProvider,\n  serviceClient,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the service client available to all activity code\n  if (serviceClient) {\n    registerServiceClient(serviceClient);\n  }\n\n  return metricsClient.metricScope(\n    (metrics) =>\n      async (\n        request: ActivityWorkerRequest,\n        baseTime: Date,\n        getEndTime = () => new Date()\n      ) => {\n        logger.addPersistentLogAttributes({\n          workflowName: request.workflowName,\n          executionId: request.executionId,\n        });\n        const activityHandle = `${request.command.seq} for execution ${request.executionId} on retry ${request.retry}`;\n        metrics.resetDimensions(false);\n        metrics.setNamespace(MetricsCommon.EventualNamespace);\n        metrics.putDimensions({\n          ActivityName: request.command.name,\n          WorkflowName: request.workflowName,\n        });\n        // the time from the workflow emitting the activity scheduled command\n        // to the request being seen.\n        const start = baseTime;\n        const recordAge =\n          start.getTime() - new Date(request.scheduledTime).getTime();\n        metrics.putMetric(\n          ActivityMetrics.ActivityRequestAge,\n          recordAge,\n          Unit.Milliseconds\n        );\n        if (\n          !(await timed(metrics, ActivityMetrics.ClaimDuration, () =>\n            activityRuntimeClient.claimActivity(\n              request.executionId,\n              request.command.seq,\n              request.retry\n            )\n          ))\n        ) {\n          metrics.putMetric(ActivityMetrics.ClaimRejected, 1, Unit.Count);\n          logger.info(`Activity ${activityHandle} already claimed.`);\n          return;\n        }\n        if (request.command.heartbeatSeconds) {\n          await timerClient.startTimer({\n            activitySeq: request.command.seq,\n            type: TimerRequestType.ActivityHeartbeatMonitor,\n            executionId: request.executionId,\n            heartbeatSeconds: request.command.heartbeatSeconds,\n            schedule: Schedule.relative(request.command.heartbeatSeconds),\n          });\n        }\n        setActivityContext({\n          activityToken: createActivityToken(\n            request.executionId,\n            request.command.seq\n          ),\n          executionId: request.executionId,\n          scheduledTime: request.scheduledTime,\n          workflowName: request.workflowName,\n        });\n        metrics.putMetric(ActivityMetrics.ClaimRejected, 0, Unit.Count);\n\n        logger.info(`Processing ${activityHandle}.`);\n\n        const activity = activityProvider.getActivityHandler(\n          request.command.name\n        );\n        try {\n          if (!activity) {\n            metrics.putMetric(ActivityMetrics.NotFoundError, 1, Unit.Count);\n            throw new ActivityNotFoundError(\n              request.command.name,\n              activityProvider.getActivityIds()\n            );\n          }\n\n          const result = await timed(\n            metrics,\n            ActivityMetrics.OperationDuration,\n            () => activity(...request.command.args)\n          );\n          if (isAsyncResult(result)) {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 1);\n\n            // TODO: Send heartbeat on sync activity completion.\n\n            /**\n             * The activity has declared that it is async, other than logging, there is nothing left to do here.\n             * The activity should call {@link WorkflowClient.completeActivity} or {@link WorkflowClient.failActivity} when it is done.\n             */\n            return;\n          } else if (result) {\n            metrics.setProperty(ActivityMetrics.HasResult, 1);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n            metrics.putMetric(\n              ActivityMetrics.ResultBytes,\n              JSON.stringify(result).length,\n              Unit.Bytes\n            );\n          } else {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n          }\n\n          logger.info(\n            `Activity ${activityHandle} succeeded, reporting back to execution.`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityCompleted>(\n            {\n              type: WorkflowEventType.ActivityCompleted,\n              seq: request.command.seq,\n              result,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } catch (err) {\n          const [error, message] = extendsError(err)\n            ? [err.name, err.message]\n            : [\"Error\", JSON.stringify(err)];\n\n          logger.info(\n            `Activity ${activityHandle} failed, reporting failure back to execution: ${error}: ${message}`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityFailed>(\n            {\n              type: WorkflowEventType.ActivityFailed,\n              seq: request.command.seq,\n              error,\n              message,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } finally {\n          clearActivityContext();\n        }\n\n        function logActivityCompleteMetrics(failed: boolean, duration: number) {\n          metrics.putMetric(\n            ActivityMetrics.ActivityFailed,\n            failed ? 1 : 0,\n            Unit.Count\n          );\n          metrics.putMetric(\n            ActivityMetrics.ActivityCompleted,\n            failed ? 0 : 1,\n            Unit.Count\n          );\n          // The total time from the activity being scheduled until it's result is send to the workflow.\n          metrics.putMetric(ActivityMetrics.TotalDuration, duration);\n        }\n\n        async function finishActivity(\n          event: ActivityCompleted | ActivityFailed,\n          duration: number\n        ) {\n          await timed(metrics, ActivityMetrics.SubmitWorkflowTaskDuration, () =>\n            workflowClient.submitWorkflowTask(request.executionId, event)\n          );\n\n          logActivityCompleteMetrics(isWorkflowFailed(event), duration);\n        }\n      }\n  );\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity-worker.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/activity-worker.ts"],"names":[],"mappings":"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","sourcesContent":["import { isAsyncResult } from \"../../activity.js\";\nimport { ScheduleActivityCommand } from \"../../command.js\";\nimport {\n  ActivitySucceeded,\n  ActivityFailed,\n  createEvent,\n  isWorkflowFailed,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport {\n  clearActivityContext,\n  registerServiceClient,\n  setActivityContext,\n} from \"../../global.js\";\nimport { createActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"../clients/activity-runtime-client.js\";\nimport { MetricsClient } from \"../clients/metrics-client.js\";\nimport { WorkflowClient } from \"../clients/workflow-client.js\";\nimport {\n  RuntimeServiceClient,\n  Schedule,\n  TimerClient,\n  TimerRequestType,\n} from \"../index.js\";\nimport { Logger } from \"../logger.js\";\nimport { ActivityMetrics, MetricsCommon } from \"../metrics/constants.js\";\nimport { Unit } from \"../metrics/unit.js\";\nimport { timed } from \"../metrics/utils.js\";\nimport type { EventClient } from \"../index.js\";\nimport { ActivityProvider } from \"../providers/activity-provider.js\";\nimport { ActivityNotFoundError } from \"../../error.js\";\nimport { extendsError } from \"../../util.js\";\n\nexport interface CreateActivityWorkerProps {\n  activityRuntimeClient: ActivityRuntimeClient;\n  workflowClient: WorkflowClient;\n  timerClient: TimerClient;\n  metricsClient: MetricsClient;\n  logger: Logger;\n  eventClient: EventClient;\n  activityProvider: ActivityProvider;\n  serviceClient?: RuntimeServiceClient;\n}\n\nexport interface ActivityWorkerRequest {\n  scheduledTime: string;\n  workflowName: string;\n  executionId: string;\n  command: ScheduleActivityCommand;\n  retry: number;\n}\n\nexport interface ActivityWorker {\n  (\n    request: ActivityWorkerRequest,\n    baseTime: Date,\n    /**\n     * Allows for a computed end time, for case like the test environment when the end time should be controlled.\n     */\n    getEndTime?: (startTime: Date) => Date\n  ): Promise<void>;\n}\n\n/**\n * Creates a generic function for handling activity worker requests\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 createActivityWorker({\n  activityRuntimeClient,\n  workflowClient,\n  timerClient,\n  metricsClient,\n  logger,\n  activityProvider,\n  serviceClient,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the service client available to all activity code\n  if (serviceClient) {\n    registerServiceClient(serviceClient);\n  }\n\n  return metricsClient.metricScope(\n    (metrics) =>\n      async (\n        request: ActivityWorkerRequest,\n        baseTime: Date,\n        getEndTime = () => new Date()\n      ) => {\n        logger.addPersistentLogAttributes({\n          workflowName: request.workflowName,\n          executionId: request.executionId,\n        });\n        const activityHandle = `${request.command.seq} for execution ${request.executionId} on retry ${request.retry}`;\n        metrics.resetDimensions(false);\n        metrics.setNamespace(MetricsCommon.EventualNamespace);\n        metrics.putDimensions({\n          ActivityName: request.command.name,\n          WorkflowName: request.workflowName,\n        });\n        // the time from the workflow emitting the activity scheduled command\n        // to the request being seen.\n        const start = baseTime;\n        const recordAge =\n          start.getTime() - new Date(request.scheduledTime).getTime();\n        metrics.putMetric(\n          ActivityMetrics.ActivityRequestAge,\n          recordAge,\n          Unit.Milliseconds\n        );\n        if (\n          !(await timed(metrics, ActivityMetrics.ClaimDuration, () =>\n            activityRuntimeClient.claimActivity(\n              request.executionId,\n              request.command.seq,\n              request.retry\n            )\n          ))\n        ) {\n          metrics.putMetric(ActivityMetrics.ClaimRejected, 1, Unit.Count);\n          logger.info(`Activity ${activityHandle} already claimed.`);\n          return;\n        }\n        if (request.command.heartbeatSeconds) {\n          await timerClient.startTimer({\n            activitySeq: request.command.seq,\n            type: TimerRequestType.ActivityHeartbeatMonitor,\n            executionId: request.executionId,\n            heartbeatSeconds: request.command.heartbeatSeconds,\n            schedule: Schedule.relative(request.command.heartbeatSeconds),\n          });\n        }\n        setActivityContext({\n          activityToken: createActivityToken(\n            request.executionId,\n            request.command.seq\n          ),\n          executionId: request.executionId,\n          scheduledTime: request.scheduledTime,\n          workflowName: request.workflowName,\n        });\n        metrics.putMetric(ActivityMetrics.ClaimRejected, 0, Unit.Count);\n\n        logger.info(`Processing ${activityHandle}.`);\n\n        const activity = activityProvider.getActivityHandler(\n          request.command.name\n        );\n        try {\n          if (!activity) {\n            metrics.putMetric(ActivityMetrics.NotFoundError, 1, Unit.Count);\n            throw new ActivityNotFoundError(\n              request.command.name,\n              activityProvider.getActivityIds()\n            );\n          }\n\n          const result = await timed(\n            metrics,\n            ActivityMetrics.OperationDuration,\n            () => activity(...request.command.args)\n          );\n          if (isAsyncResult(result)) {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 1);\n\n            // TODO: Send heartbeat on sync activity completion.\n\n            /**\n             * The activity has declared that it is async, other than logging, there is nothing left to do here.\n             * The activity should call {@link WorkflowClient.sendActivitySuccess} or {@link WorkflowClient.sendActivityFailure} when it is done.\n             */\n            return;\n          } else if (result) {\n            metrics.setProperty(ActivityMetrics.HasResult, 1);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n            metrics.putMetric(\n              ActivityMetrics.ResultBytes,\n              JSON.stringify(result).length,\n              Unit.Bytes\n            );\n          } else {\n            metrics.setProperty(ActivityMetrics.HasResult, 0);\n            metrics.setProperty(ActivityMetrics.AsyncResult, 0);\n          }\n\n          logger.info(\n            `Activity ${activityHandle} succeeded, reporting back to execution.`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivitySucceeded>(\n            {\n              type: WorkflowEventType.ActivitySucceeded,\n              seq: request.command.seq,\n              result,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } catch (err) {\n          const [error, message] = extendsError(err)\n            ? [err.name, err.message]\n            : [\"Error\", JSON.stringify(err)];\n\n          logger.info(\n            `Activity ${activityHandle} failed, reporting failure back to execution: ${error}: ${message}`\n          );\n\n          const endTime = getEndTime(start);\n          const event = createEvent<ActivityFailed>(\n            {\n              type: WorkflowEventType.ActivityFailed,\n              seq: request.command.seq,\n              error,\n              message,\n            },\n            endTime\n          );\n\n          await finishActivity(\n            event,\n            recordAge + (endTime.getTime() - start.getTime())\n          );\n        } finally {\n          clearActivityContext();\n        }\n\n        function logActivityCompleteMetrics(failed: boolean, duration: number) {\n          metrics.putMetric(\n            ActivityMetrics.ActivityFailed,\n            failed ? 1 : 0,\n            Unit.Count\n          );\n          metrics.putMetric(\n            ActivityMetrics.ActivitySucceeded,\n            failed ? 0 : 1,\n            Unit.Count\n          );\n          // The total time from the activity being scheduled until it's result is send to the workflow.\n          metrics.putMetric(ActivityMetrics.TotalDuration, duration);\n        }\n\n        async function finishActivity(\n          event: ActivitySucceeded | ActivityFailed,\n          duration: number\n        ) {\n          await timed(metrics, ActivityMetrics.SubmitWorkflowTaskDuration, () =>\n            workflowClient.submitWorkflowTask(request.executionId, event)\n          );\n\n          logActivityCompleteMetrics(isWorkflowFailed(event), duration);\n        }\n      }\n  );\n}\n"]}
import { inspect } from "util";
import { createEvent, getEventId, isHistoryEvent, isSleepCompleted, isWorkflowCompleted, isWorkflowFailed, isWorkflowStarted, WorkflowEventType, } from "../../workflow-events.js";
import { ExecutionStatus, isCompleteExecution, } from "../../execution.js";
import { createEvent, getEventId, isHistoryEvent, isSleepCompleted, isWorkflowSucceeded, isWorkflowFailed, isWorkflowStarted, WorkflowEventType, } from "../../workflow-events.js";
import { ExecutionStatus, isSucceededExecution, } from "../../execution.js";
import { isFailed, isResolved, isResult } from "../../result.js";

@@ -97,3 +97,3 @@ import { lookupWorkflow, progressWorkflow } from "../../workflow.js";

yield createEvent({
type: WorkflowEventType.WorkflowTaskStarted,
type: WorkflowEventType.WorkflowRunStarted,
}, start);

@@ -146,3 +146,3 @@ const workflowContext = {

yield createEvent({
type: WorkflowEventType.WorkflowTaskCompleted,
type: WorkflowEventType.WorkflowRunCompleted,
}, start);

@@ -162,3 +162,3 @@ if (isResult(result)) {

yield createEvent({
type: WorkflowEventType.WorkflowCompleted,
type: WorkflowEventType.WorkflowSucceeded,
output: result.value,

@@ -194,3 +194,3 @@ }, start);

}
if (isWorkflowCompleted(event) || isWorkflowFailed(event)) {
if (isWorkflowSucceeded(event) || isWorkflowFailed(event)) {
resultEvent = event;

@@ -252,4 +252,4 @@ }

}
else if (isWorkflowCompleted(resultEvent)) {
const execution = await timed(metrics, OrchestratorMetrics.ExecutionStatusUpdateDuration, () => workflowRuntimeClient.completeExecution({
else if (isWorkflowSucceeded(resultEvent)) {
const execution = await timed(metrics, OrchestratorMetrics.ExecutionStatusUpdateDuration, () => workflowRuntimeClient.succeedExecution({
executionId,

@@ -289,7 +289,7 @@ result: resultEvent.output,

function logExecutionCompleteMetrics(execution) {
metrics.putMetric(OrchestratorMetrics.ExecutionComplete, execution.status === ExecutionStatus.COMPLETE ? 1 : 0, Unit.Count);
metrics.putMetric(OrchestratorMetrics.ExecutionFailed, execution.status === ExecutionStatus.COMPLETE ? 0 : 1, Unit.Count);
metrics.putMetric(OrchestratorMetrics.ExecutionComplete, execution.status === ExecutionStatus.SUCCEEDED ? 1 : 0, Unit.Count);
metrics.putMetric(OrchestratorMetrics.ExecutionFailed, execution.status === ExecutionStatus.SUCCEEDED ? 0 : 1, Unit.Count);
metrics.putMetric(OrchestratorMetrics.ExecutionTotalDuration, new Date(execution.endTime).getTime() -
new Date(execution.startTime).getTime());
if (isCompleteExecution(execution)) {
if (isSucceededExecution(execution)) {
metrics.putMetric(OrchestratorMetrics.ExecutionResultBytes, execution.result ? JSON.stringify(execution.result).length : 0, Unit.Bytes);

@@ -310,2 +310,2 @@ }

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"orchestrator.js","sourceRoot":"","sources":["../../../../src/runtime/handlers/orchestrator.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAG/B,OAAO,EACL,WAAW,EACX,UAAU,EAEV,cAAc,EACd,gBAAgB,EAChB,mBAAmB,EACnB,gBAAgB,EAChB,iBAAiB,EAGjB,iBAAiB,GAKlB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAEL,eAAe,EAEf,mBAAmB,GACpB,MAAM,oBAAoB,CAAC;AAC5B,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,QAAQ,EAAU,MAAM,iBAAiB,CAAC;AACzE,OAAO,EAAE,cAAc,EAAE,gBAAgB,EAAY,MAAM,mBAAmB,CAAC;AAC/E,OAAO,EAIL,QAAQ,GAIT,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AACzD,OAAO,EAAE,aAAa,EAAE,iBAAiB,EAAE,MAAM,oBAAoB,CAAC;AAEtE,OAAO,EAAE,aAAa,EAAE,mBAAmB,EAAE,MAAM,yBAAyB,CAAC;AAE7E,OAAO,EAAE,IAAI,EAAE,MAAM,oBAAoB,CAAC;AAC1C,OAAO,EAAE,KAAK,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,OAAO,EAAE,4BAA4B,EAAE,MAAM,aAAa,CAAC;AACpE,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AA2B7C;;;;;GAKG;AACH,MAAM,UAAU,kBAAkB,CAAC,EACjC,sBAAsB,EACtB,WAAW,EACX,qBAAqB,EACrB,cAAc,EACd,aAAa,EACb,WAAW,EACX,MAAM,GACmB;IACzB,MAAM,eAAe,GAAG,IAAI,eAAe,CAAC;QAC1C,WAAW;QACX,cAAc;QACd,qBAAqB;QACrB,WAAW;KACZ,CAAC,CAAC;IAEH,OAAO,KAAK,EAAE,aAAa,EAAE,QAAQ,GAAG,IAAI,IAAI,EAAE,EAAE,EAAE;QACpD,MAAM,kBAAkB,GAAG,OAAO,CAChC,aAAa,EACb,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,WAAW,CAC3B,CAAC;QAEF,MAAM,mBAAmB,GAAG,MAAM,CAAC,WAAW,CAC5C,MAAM,CAAC,OAAO,CAAC,kBAAkB,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE,CAAC;YACjE,WAAW;YACX,OAAO,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,MAAM,CAAC;SACjC,CAAC,CACH,CAAC;QAEF,MAAM,CAAC,IAAI,CACT,uBAAuB,GAAG,MAAM,CAAC,IAAI,CAAC,mBAAmB,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CACtE,CAAC;QAEF,wBAAwB;QACxB,MAAM,OAAO,GAAG,MAAM,4BAA4B,CAChD,MAAM,CAAC,OAAO,CAAC,mBAAmB,CAAC,EACnC,KAAK,EAAE,CAAC,WAAW,EAAE,OAAO,CAAC,EAAE,EAAE;YAC/B,IAAI,CAAC,aAAa,CAAC,WAAW,CAAC,EAAE;gBAC/B,MAAM,IAAI,KAAK,CAAC,yBAAyB,WAAW,GAAG,CAAC,CAAC;aAC1D;YACD,MAAM,YAAY,GAAG,iBAAiB,CAAC,WAAW,CAAC,CAAC;YACpD,IAAI,YAAY,KAAK,SAAS,EAAE;gBAC9B,MAAM,IAAI,KAAK,CAAC,iBAAiB,WAAW,kBAAkB,CAAC,CAAC;aACjE;YACD,MAAM,QAAQ,GAAG,cAAc,CAAC,YAAY,CAAC,CAAC;YAC9C,IAAI,QAAQ,KAAK,SAAS,EAAE;gBAC1B,MAAM,IAAI,KAAK,CAAC,+BAA+B,YAAY,GAAG,CAAC,CAAC;aACjE;YACD,uCAAuC;YACvC,OAAO,oBAAoB,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;QACxE,CAAC,CACF,CAAC;QAEF,MAAM,CAAC,KAAK,CACV,wBAAwB;YACtB,OAAO,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CACpE,CAAC;QAEF,IAAI,OAAO,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE;YAC/B,MAAM,CAAC,KAAK,CACV,uBAAuB;gBACrB,OAAO,CAAC,QAAQ;qBACb,GAAG,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,EAAE,EAAE,CAAC,GAAG,WAAW,KAAK,KAAK,EAAE,CAAC;qBAC3D,IAAI,CAAC,IAAI,CAAC,CAChB,CAAC;SACH;QAED,OAAO;YACL,kBAAkB,EAAE,OAAO,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;SACvE,CAAC;IACJ,CAAC,CAAC;IAEF,KAAK,UAAU,oBAAoB,CACjC,QAAkB,EAClB,WAAmB,EACnB,MAA2B,EAC3B,QAAc;QAEd,MAAM,eAAe,GAAG,MAAM,CAAC,WAAW,CAAC;YACzC,uBAAuB,EAAE,EAAE,YAAY,EAAE,QAAQ,CAAC,IAAI,EAAE,WAAW,EAAE;SACtE,CAAC,CAAC;QACH,MAAM,OAAO,GAAG,iBAAiB,EAAE,CAAC;QACpC,MAAM,KAAK,GAAG,QAAQ,CAAC;QACvB,IAAI;YACF,OAAO;YACP,MAAM,OAAO,GAAG,MAAM,WAAW,EAAE,CAAC;YAEpC,UAAU;YACV,MAAM,EAAE,oBAAoB,EAAE,SAAS,EAAE,WAAW,EAAE,GACpD,MAAM,eAAe,CAAC,OAAO,CAAC,CAAC;YAEjC,UAAU;YACV,MAAM,qBAAqB,CAAC,WAAW,CAAC,CAAC;YACzC,MAAM,+BAA+B,CAAC,SAAS,CAAC,CAAC;YACjD,MAAM,aAAa,CAAC,oBAAoB,CAAC,CAAC;YAE1C,2EAA2E;YAC3E,eAAe,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC;SACzC;QAAC,OAAO,GAAG,EAAE;YACZ,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;YACpC,MAAM,GAAG,CAAC;SACX;gBAAS;YACR,MAAM,OAAO,CAAC,KAAK,EAAE,CAAC;SACvB;QAED;;WAEG;QACH,KAAK,UAAU,eAAe,CAAC,OAA4B;YACzD,gDAAgD;YAChD,MAAM,UAAU,GAAG,IAAI,CAAC,GAAG,CACzB,GAAG,MAAM,CAAC,GAAG,CACX,CAAC,KAAK,EAAE,EAAE,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC,SAAS,CAAC,CAC9D,CACF,CAAC;YACF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,UAAU,EAC9B,UAAU,EACV,IAAI,CAAC,YAAY,CAClB,CAAC;YAEF,OAAO,yBAAyB,CAAC,OAAO,EAAE,wBAAwB,EAAE,CAAC,CAAC;YAEtE,KAAK,SAAS,CAAC,CAAC,wBAAwB;gBACtC,MAAM,WAAW,CACf;oBACE,IAAI,EAAE,iBAAiB,CAAC,mBAAmB;iBAC5C,EACD,KAAK,CACN,CAAC;gBAEF,MAAM,eAAe,GAAoB;oBACvC,IAAI,EAAE,QAAQ,CAAC,YAAY;iBAC5B,CAAC;gBAEF,MAAM,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;gBAEnD;;;mBAGG;gBACH,IAAI,CAAC,UAAU,EAAE;oBACf,MAAM,gBAAgB,GAAG,MAAM,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;oBAExD,IAAI,gBAAgB,EAAE,WAAW,EAAE;wBACjC,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;wBAC3D,MAAM,KAAK,CACT,OAAO,EACP,mBAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CACH,WAAW,CAAC,aAAa,CAAmB;4BAC1C,QAAQ,EAAE,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,CAAC,WAAY,CAAC;4BAC1D,KAAK,EAAE,WAAW,CAChB;gCACE,IAAI,EAAE,iBAAiB,CAAC,gBAAgB;6BACzC,EACD,KAAK,CACN;4BACD,WAAW;yBACZ,CAAC,CACL,CAAC;qBACH;yBAAM;wBACL,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,cAAc,EAAE,CAAC,CAAC,CAAC;qBAC5D;iBACF;gBAED,MAAM,EACJ,MAAM,EACN,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,oBAAoB,GAC9B,GAAG,SAAS,CACX,OAAO,EACP,mBAAmB,CAAC,wBAAwB,EAC5C,GAAG,EAAE;oBACH,IAAI;wBACF,OAAO,gBAAgB,CACrB,QAAQ,EACR,OAAO,EACP,MAAM,EACN,eAAe,EACf,WAAW,EACX,QAAQ,CACT,CAAC;qBACH;oBAAC,OAAO,GAAG,EAAE;wBACZ,OAAO,CAAC,GAAG,CAAC,gBAAgB,CAAC,CAAC;wBAC9B,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC;wBACpC,MAAM,GAAG,CAAC;qBACX;gBACH,CAAC,CACF,CAAC;gBAEF,OAAO,CAAC,WAAW,CACjB,mBAAmB,CAAC,sBAAsB,EAC1C,oBAAoB,CAAC,MAAM,CAC5B,CAAC;gBAEF,KAAK,CAAC,CAAC,oBAAoB,CAAC;gBAE5B,eAAe,CAAC,KAAK,CACnB,4BAA4B,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CACtD,CAAC;gBAEF,eAAe,CAAC,IAAI,CAAC,SAAS,WAAW,CAAC,MAAM,gBAAgB,CAAC,CAAC;gBAElE,KAAK,CAAC,CAAC,MAAM,KAAK,CAChB,OAAO,EACP,mBAAmB,CAAC,sBAAsB,EAC1C,GAAG,EAAE,CAAC,eAAe,CAAC,WAAW,CAAC,CACnC,CAAC;gBAEF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,eAAe,EACnC,WAAW,CAAC,MAAM,EAClB,IAAI,CAAC,KAAK,CACX,CAAC;gBAEF,oGAAoG;gBACpG,2EAA2E;gBAC3E,qHAAqH;gBACrH,iFAAiF;gBACjF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,qBAAqB,EACzC,UAAU,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,KAAK,CAAC,OAAO,EAAE,CAAC,CACtD,CAAC;gBAEF,MAAM,WAAW,CACf;oBACE,IAAI,EAAE,iBAAiB,CAAC,qBAAqB;iBAC9C,EACD,KAAK,CACN,CAAC;gBAEF,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE;oBACpB,IAAI,QAAQ,CAAC,MAAM,CAAC,EAAE;wBACpB,MAAM,CAAC,KAAK,EAAE,OAAO,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC;4BACjD,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC,OAAO,CAAC;4BAC3C,CAAC,CAAC,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC;wBAC5C,MAAM,WAAW,CACf;4BACE,IAAI,EAAE,iBAAiB,CAAC,cAAc;4BACtC,KAAK;4BACL,OAAO;yBACR,EACD,KAAK,CACN,CAAC;qBACH;yBAAM,IAAI,UAAU,CAAM,MAAM,CAAC,EAAE;wBAClC,MAAM,WAAW,CACf;4BACE,IAAI,EAAE,iBAAiB,CAAC,iBAAiB;4BACzC,MAAM,EAAE,MAAM,CAAC,KAAK;yBACrB,EACD,KAAK,CACN,CAAC;qBACH;iBACF;gBAED,OAAO,MAAM,CAAC;YAChB,CAAC;YAED;;;;;;;;;;;eAWG;YACH,KAAK,UAAU,yBAAyB,CACtC,eAAoC,EACpC,kBAAqE;gBAErE,MAAM,oBAAoB,GAAwB,EAAE,CAAC;gBACrD,MAAM,iBAAiB,GAAoB,EAAE,CAAC;gBAC9C,IAAI,WAA2D,CAAC;gBAChE,MAAM,UAAU,GAAgB,IAAI,GAAG,CACrC,eAAe,CAAC,GAAG,CAAC,UAAU,CAAC,CAChC,CAAC;gBAEF,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,kBAAkB,EAAE;oBAC5C,MAAM,EAAE,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;oBAC7B,oFAAoF;oBACpF,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;wBACvB,iBAAiB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;wBAC9B,UAAU,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;qBACpB;oBACD,IAAI,mBAAmB,CAAC,KAAK,CAAC,IAAI,gBAAgB,CAAC,KAAK,CAAC,EAAE;wBACzD,WAAW,GAAG,KAAK,CAAC;qBACrB;oBACD,0DAA0D;oBAC1D,IAAI,iBAAiB,CAAC,KAAK,CAAC,IAAI,cAAc,CAAC,KAAK,CAAC,EAAE;wBACrD,oBAAoB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;qBAClC;iBACF;gBAED,OAAO;oBACL,oBAAoB;oBACpB,SAAS,EAAE,iBAAiB;oBAC5B,WAAW;iBACZ,CAAC;YACJ,CAAC;QACH,CAAC;QAED,KAAK,UAAU,WAAW;YACxB,eAAe,CAAC,KAAK,CAAC,cAAc,CAAC,CAAC;YACtC,eAAe;YACf,MAAM,OAAO,GAAG,MAAM,KAAK,CACzB,OAAO,EACP,mBAAmB,CAAC,mBAAmB,EACvC,KAAK,IAAI,EAAE,CAAC,qBAAqB,CAAC,UAAU,CAAC,WAAW,CAAC,CAC1D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,mBAAmB,CAAC,mBAAmB,EACvC,OAAO,CAAC,MAAM,CACf,CAAC;YAEF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED;;WAEG;QACH,KAAK,UAAU,+BAA+B,CAAC,SAA0B;YACvE,MAAM,KAAK,CACT,OAAO,EACP,mBAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CAAC,sBAAsB,CAAC,SAAS,CAAC,WAAW,EAAE,SAAS,CAAC,CAC/D,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,mBAAmB,CAAC,kBAAkB,EACtC,SAAS,CAAC,MAAM,CACjB,CAAC;QACJ,CAAC;QAED;;;;;WAKG;QACH,KAAK,UAAU,aAAa,CAAC,oBAAyC;YACpE,OAAO,CAAC,KAAK,CACX,qBAAqB,EACrB,IAAI,CAAC,SAAS,CAAC,oBAAoB,CAAC,CACrC,CAAC;YAEF,8CAA8C;YAC9C,yHAAyH;YACzH,MAAM,EAAE,KAAK,EAAE,mBAAmB,EAAE,GAAG,MAAM,KAAK,CAChD,OAAO,EACP,mBAAmB,CAAC,mBAAmB,EACvC,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;gBAClC,WAAW;gBACX,MAAM,EAAE,oBAAoB;aAC7B,CAAC,CACL,CAAC;YAEF,OAAO,CAAC,WAAW,CACjB,mBAAmB,CAAC,kBAAkB,EACtC,oBAAoB,CAAC,MAAM,CAC5B,CAAC;YACF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,iBAAiB,EACrC,mBAAmB,EACnB,IAAI,CAAC,KAAK,CACX,CAAC;QACJ,CAAC;QAED,KAAK,UAAU,qBAAqB,CAClC,WAAgD;YAEhD,wEAAwE;YACxE,IAAI,WAAW,EAAE;gBACf,IAAI,gBAAgB,CAAC,WAAW,CAAC,EAAE;oBACjC,MAAM,SAAS,GAAG,MAAM,KAAK,CAC3B,OAAO,EACP,mBAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,aAAa,CAAC;wBAClC,WAAW;wBACX,KAAK,EAAE,WAAW,CAAC,KAAK;wBACxB,OAAO,EAAE,WAAW,CAAC,OAAO;qBAC7B,CAAC,CACL,CAAC;oBAEF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;qBAAM,IAAI,mBAAmB,CAAC,WAAW,CAAC,EAAE;oBAC3C,MAAM,SAAS,GAAG,MAAM,KAAK,CAC3B,OAAO,EACP,mBAAmB,CAAC,6BAA6B,EACjD,GAAG,EAAE,CACH,qBAAqB,CAAC,iBAAiB,CAAC;wBACtC,WAAW;wBACX,MAAM,EAAE,WAAW,CAAC,MAAM;qBAC3B,CAAC,CACL,CAAC;oBACF,2BAA2B,CAAC,SAAS,CAAC,CAAC;iBACxC;aACF;QACH,CAAC;QAED;;;;WAIG;QACH,KAAK,UAAU,eAAe,CAC5B,QAAmB;YAEnB,OAAO,CAAC,KAAK,CAAC,kBAAkB,EAAE,IAAI,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC;YAC5D,0BAA0B;YAC1B,OAAO,MAAM,OAAO,CAAC,GAAG,CACtB,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CACvB,eAAe,CAAC,cAAc,CAAC,QAAQ,EAAE,WAAW,EAAE,OAAO,EAAE,KAAK,CAAC,CACtE,CACF,CAAC;QACJ,CAAC;QAED,SAAS,iBAAiB;YACxB,MAAM,OAAO,GAAG,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpD,aAAa,CAAC,mBAAmB,EAAE,CAAC;YACpC,OAAO,CAAC,eAAe,CAAC,KAAK,CAAC,CAAC;YAC/B,OAAO,CAAC,YAAY,CAAC,aAAa,CAAC,iBAAiB,CAAC,CAAC;YACtD,OAAO,CAAC,aAAa,CAAC;gBACpB,CAAC,aAAa,CAAC,qBAAqB,CAAC,EAAE,QAAQ,CAAC,YAAY;aAC7D,CAAC,CAAC;YACH,oDAAoD;YACpD,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YACnE,2EAA2E;YAC3E,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,eAAe,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;YAExE,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;YAClE,OAAO,CAAC,WAAW,CACjB,mBAAmB,CAAC,OAAO,EAC3B,mBAAmB,CAAC,SAAS,CAC9B,CAAC;YACF,OAAO,OAAO,CAAC;QACjB,CAAC;QAED,SAAS,2BAA2B,CAClC,SAA8C;YAE9C,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,iBAAiB,EACrC,SAAS,CAAC,MAAM,KAAK,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACrD,IAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,eAAe,EACnC,SAAS,CAAC,MAAM,KAAK,eAAe,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,EACrD,IAAI,CAAC,KAAK,CACX,CAAC;YACF,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,sBAAsB,EAC1C,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE;gBACnC,IAAI,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CAC1C,CAAC;YACF,IAAI,mBAAmB,CAAC,SAAS,CAAC,EAAE;gBAClC,OAAO,CAAC,SAAS,CACf,mBAAmB,CAAC,oBAAoB,EACxC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,EAC9D,IAAI,CAAC,KAAK,CACX,CAAC;aACH;QACH,CAAC;IACH,CAAC;AACH,CAAC;AAED,mDAAmD;AACnD,SAAS,eAAe,CACtB,OAAsB,EACtB,MAAuB,EACvB,GAAS;IAET,MAAM,oBAAoB,GAAG,MAAM,CAAC,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAC7D,IAAI,oBAAoB,CAAC,MAAM,GAAG,CAAC,EAAE;QACnC,MAAM,sBAAsB,GAAG,oBAAoB,CAAC,GAAG,CACrD,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,OAAO,EAAE,CACvD,CAAC;QACF,MAAM,GAAG,GACP,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;YACjD,sBAAsB,CAAC,MAAM,CAAC;QAChC,OAAO,CAAC,WAAW,CAAC,mBAAmB,CAAC,mBAAmB,EAAE,GAAG,CAAC,CAAC;KACnE;AACH,CAAC","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 { groupBy, promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\nimport { WorkflowTask } from \"../../tasks.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\nexport interface Orchestrator {\n  (workflowTasks: WorkflowTask[], baseTime?: Date): Promise<OrchestratorResult>;\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): Orchestrator {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (workflowTasks, baseTime = new Date()) => {\n    const tasksByExecutionId = groupBy(\n      workflowTasks,\n      (task) => task.executionId\n    );\n\n    const eventsByExecutionId = Object.fromEntries(\n      Object.entries(tasksByExecutionId).map(([executionId, records]) => [\n        executionId,\n        records.flatMap((e) => e.events),\n      ])\n    );\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, baseTime);\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    baseTime: Date\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = baseTime;\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                    {\n                      type: WorkflowEventType.WorkflowTimedOut,\n                    },\n                    start\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                baseTime\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          {\n            type: WorkflowEventType.WorkflowTaskCompleted,\n          },\n          start\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              {\n                type: WorkflowEventType.WorkflowFailed,\n                error,\n                message,\n              },\n              start\n            );\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowCompleted>(\n              {\n                type: WorkflowEventType.WorkflowCompleted,\n                output: result.value,\n              },\n              start\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"]}
//# 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  isWorkflowSucceeded,\n  isWorkflowFailed,\n  isWorkflowStarted,\n  WorkflowSucceeded,\n  WorkflowEvent,\n  WorkflowEventType,\n  WorkflowFailed,\n  WorkflowRunCompleted,\n  WorkflowRunStarted,\n  WorkflowTimedOut,\n} from \"../../workflow-events.js\";\nimport {\n  SucceededExecution,\n  ExecutionStatus,\n  FailedExecution,\n  isSucceededExecution,\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 { groupBy, promiseAllSettledPartitioned } from \"../utils.js\";\nimport { extendsError } from \"../../util.js\";\nimport { WorkflowTask } from \"../../tasks.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\nexport interface Orchestrator {\n  (workflowTasks: WorkflowTask[], baseTime?: Date): Promise<OrchestratorResult>;\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): Orchestrator {\n  const commandExecutor = new CommandExecutor({\n    timerClient,\n    workflowClient,\n    workflowRuntimeClient,\n    eventClient,\n  });\n\n  return async (workflowTasks, baseTime = new Date()) => {\n    const tasksByExecutionId = groupBy(\n      workflowTasks,\n      (task) => task.executionId\n    );\n\n    const eventsByExecutionId = Object.fromEntries(\n      Object.entries(tasksByExecutionId).map(([executionId, records]) => [\n        executionId,\n        records.flatMap((e) => e.events),\n      ])\n    );\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, baseTime);\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    baseTime: Date\n  ) {\n    const executionLogger = logger.createChild({\n      persistentLogAttributes: { workflowName: workflow.name, executionId },\n    });\n    const metrics = initializeMetrics();\n    const start = baseTime;\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<WorkflowRunStarted>(\n          {\n            type: WorkflowEventType.WorkflowRunStarted,\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                    {\n                      type: WorkflowEventType.WorkflowTimedOut,\n                    },\n                    start\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                baseTime\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<WorkflowRunCompleted>(\n          {\n            type: WorkflowEventType.WorkflowRunCompleted,\n          },\n          start\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              {\n                type: WorkflowEventType.WorkflowFailed,\n                error,\n                message,\n              },\n              start\n            );\n          } else if (isResolved<any>(result)) {\n            yield createEvent<WorkflowSucceeded>(\n              {\n                type: WorkflowEventType.WorkflowSucceeded,\n                output: result.value,\n              },\n              start\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: WorkflowSucceeded | 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 (isWorkflowSucceeded(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?: WorkflowSucceeded | 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 (isWorkflowSucceeded(resultEvent)) {\n          const execution = await timed(\n            metrics,\n            OrchestratorMetrics.ExecutionStatusUpdateDuration,\n            () =>\n              workflowRuntimeClient.succeedExecution({\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: SucceededExecution | FailedExecution\n    ) {\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionComplete,\n        execution.status === ExecutionStatus.SUCCEEDED ? 1 : 0,\n        Unit.Count\n      );\n      metrics.putMetric(\n        OrchestratorMetrics.ExecutionFailed,\n        execution.status === ExecutionStatus.SUCCEEDED ? 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 (isSucceededExecution(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"]}

@@ -153,3 +153,3 @@ export declare namespace MetricsCommon {

*/
const ActivityCompleted = "ActivityCompleted";
const ActivitySucceeded = "ActivitySucceeded";
/**

@@ -156,0 +156,0 @@ * The total duration of the activity after being scheduled, including the time

@@ -157,3 +157,3 @@ /* eslint-disable @typescript-eslint/no-namespace */

*/
ActivityMetrics.ActivityCompleted = "ActivityCompleted";
ActivityMetrics.ActivitySucceeded = "ActivitySucceeded";
/**

@@ -180,2 +180,2 @@ * The total duration of the activity after being scheduled, including the time

})(SchedulerForwarderMetrics || (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":["/* 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"]}
//# 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 ActivitySucceeded = \"ActivitySucceeded\";\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"]}

@@ -50,3 +50,3 @@ import { EventEnvelope } from "./event.js";

/**
* Successfully Completes an async activity with the given value.
* Succeeds an async activity with the given value.
*/

@@ -66,2 +66,5 @@ sendActivitySuccess(request: Omit<SendActivitySuccessRequest, "type">): Promise<void>;

export interface StartExecutionResponse {
/**
* ID of the started workflow execution.
*/
executionId: string;

@@ -68,0 +71,0 @@ }

@@ -16,2 +16,2 @@ export var ActivityUpdateType;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-client.js","sourceRoot":"","sources":["../../src/service-client.ts"],"names":[],"mappings":"AA0KA,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,yCAAmB,CAAA;IACnB,yCAAmB,CAAA;IACnB,6CAAuB,CAAA;AACzB,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAyBD,MAAM,UAAU,4BAA4B,CAC1C,OAA8B;IAE9B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,8BAA8B,CAC5C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,SAAS,CAAC;AACvD,CAAC","sourcesContent":["import { EventEnvelope } from \"./event.js\";\nimport { Execution, ExecutionHandle, ExecutionStatus } from \"./execution.js\";\nimport { SendSignalRequest } from \"./runtime/clients/workflow-client.js\";\nimport { HistoryStateEvent, WorkflowEvent } from \"./workflow-events.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"./workflow.js\";\n\n/**\n * Top level Eventual Client used by systems outside of an Eventual Service to interact with it.\n */\nexport interface EventualServiceClient {\n  getWorkflows(): Promise<GetWorkflowResponse>;\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   */\n  startExecution<W extends Workflow>(\n    request: StartExecutionRequest<W>\n  ): Promise<ExecutionHandle<W>>;\n\n  /**\n   * Retrieves one or more workflow execution.\n   */\n  getExecutions(request: GetExecutionsRequest): Promise<GetExecutionsResponse>;\n\n  /**\n   * Retrieves a single workflow execution.\n   */\n  getExecution(executionId: string): Promise<Execution | undefined>;\n\n  /**\n   * Retrieves the workflow events for an execution.\n   */\n  getExecutionHistory(\n    request: ExecutionEventsRequest\n  ): Promise<ExecutionEventsResponse>;\n\n  /**\n   * Retrieves the workflow history events for an execution.\n   *\n   * @deprecated use {@link EventualServiceClient.getExecutionHistory}. This API will be removed in the future.\n   *\n   * TODO: Support the mixed use case of retrieving events and history events from\n   *       the {@link EventualServiceClient.getExecutionHistory} API.\n   */\n  getExecutionWorkflowHistory(\n    executionId: string\n  ): Promise<ExecutionHistoryResponse>;\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  sendSignal(request: SendSignalRequest): Promise<void>;\n\n  /**\n   * Publishes one or more events to the service.\n   */\n  publishEvents(request: PublishEventsRequest): Promise<void>;\n\n  /**\n   * Successfully Completes an async activity with the given value.\n   */\n  sendActivitySuccess(\n    request: Omit<SendActivitySuccessRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\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  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n}\n\nexport interface StartExecutionResponse {\n  executionId: string;\n}\n\nexport interface GetExecutionsRequest {\n  statuses?: ExecutionStatus[];\n  workflowName?: string;\n  nextToken?: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface GetExecutionsResponse {\n  executions: Execution[];\n  /**\n   * A token returned when there may be more executions to retrieve.\n   */\n  nextToken?: string;\n}\n\nexport interface PublishEventsRequest {\n  events: EventEnvelope<any>[];\n}\n\nexport interface ExecutionEventsRequest {\n  executionId: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  nextToken?: string;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface ExecutionEventsResponse {\n  events: WorkflowEvent[];\n  nextToken?: string;\n}\n\nexport interface ExecutionHistoryResponse {\n  events: HistoryStateEvent[];\n}\n\nexport type SortOrder = \"Asc\" | \"Desc\";\n\nexport interface StartExecutionRequest<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  workflow: string | W;\n  /**\n   * Input payload for the workflow function.\n   */\n  input: WorkflowInput<W>;\n}\n\nexport interface WorkflowReference {\n  name: string;\n}\n\nexport interface GetWorkflowResponse {\n  workflows: WorkflowReference[];\n}\n\nexport enum ActivityUpdateType {\n  Success = \"Success\",\n  Failure = \"Failure\",\n  Heartbeat = \"Heartbeat\",\n}\n\nexport type SendActivityUpdate<T = any> =\n  | SendActivitySuccessRequest<T>\n  | SendActivityFailureRequest\n  | SendActivityHeartbeatRequest;\n\nexport interface SendActivitySuccessRequest<T = any> {\n  type: ActivityUpdateType.Success;\n  activityToken: string;\n  result: T;\n}\n\nexport interface SendActivityFailureRequest {\n  type: ActivityUpdateType.Failure;\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface SendActivityHeartbeatRequest {\n  type: ActivityUpdateType.Heartbeat;\n  activityToken: string;\n}\n\nexport function isSendActivitySuccessRequest<T = any>(\n  request: SendActivityUpdate<T>\n): request is SendActivitySuccessRequest<T> {\n  return request.type === ActivityUpdateType.Success;\n}\n\nexport function isSendActivityFailureRequest(\n  request: SendActivityUpdate\n): request is SendActivityFailureRequest {\n  return request.type === ActivityUpdateType.Failure;\n}\n\nexport function isSendActivityHeartbeatRequest(\n  request: SendActivityUpdate\n): request is SendActivityHeartbeatRequest {\n  return request.type === ActivityUpdateType.Heartbeat;\n}\n\nexport type SendActivityUpdateResponse = SendActivityHeartbeatResponse | void;\n\nexport interface SendActivityHeartbeatResponse {\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 cancelled.\n   */\n  cancelled: boolean;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"service-client.js","sourceRoot":"","sources":["../../src/service-client.ts"],"names":[],"mappings":"AA6KA,MAAM,CAAN,IAAY,kBAIX;AAJD,WAAY,kBAAkB;IAC5B,yCAAmB,CAAA;IACnB,yCAAmB,CAAA;IACnB,6CAAuB,CAAA;AACzB,CAAC,EAJW,kBAAkB,KAAlB,kBAAkB,QAI7B;AAyBD,MAAM,UAAU,4BAA4B,CAC1C,OAA8B;IAE9B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,4BAA4B,CAC1C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,OAAO,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,8BAA8B,CAC5C,OAA2B;IAE3B,OAAO,OAAO,CAAC,IAAI,KAAK,kBAAkB,CAAC,SAAS,CAAC;AACvD,CAAC","sourcesContent":["import { EventEnvelope } from \"./event.js\";\nimport { Execution, ExecutionHandle, ExecutionStatus } from \"./execution.js\";\nimport { SendSignalRequest } from \"./runtime/clients/workflow-client.js\";\nimport { HistoryStateEvent, WorkflowEvent } from \"./workflow-events.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"./workflow.js\";\n\n/**\n * Top level Eventual Client used by systems outside of an Eventual Service to interact with it.\n */\nexport interface EventualServiceClient {\n  getWorkflows(): Promise<GetWorkflowResponse>;\n\n  /**\n   * Start a workflow execution\n   * @param name Suffix of execution id\n   * @param input Workflow parameters\n   */\n  startExecution<W extends Workflow>(\n    request: StartExecutionRequest<W>\n  ): Promise<ExecutionHandle<W>>;\n\n  /**\n   * Retrieves one or more workflow execution.\n   */\n  getExecutions(request: GetExecutionsRequest): Promise<GetExecutionsResponse>;\n\n  /**\n   * Retrieves a single workflow execution.\n   */\n  getExecution(executionId: string): Promise<Execution | undefined>;\n\n  /**\n   * Retrieves the workflow events for an execution.\n   */\n  getExecutionHistory(\n    request: ExecutionEventsRequest\n  ): Promise<ExecutionEventsResponse>;\n\n  /**\n   * Retrieves the workflow history events for an execution.\n   *\n   * @deprecated use {@link EventualServiceClient.getExecutionHistory}. This API will be removed in the future.\n   *\n   * TODO: Support the mixed use case of retrieving events and history events from\n   *       the {@link EventualServiceClient.getExecutionHistory} API.\n   */\n  getExecutionWorkflowHistory(\n    executionId: string\n  ): Promise<ExecutionHistoryResponse>;\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  sendSignal(request: SendSignalRequest): Promise<void>;\n\n  /**\n   * Publishes one or more events to the service.\n   */\n  publishEvents(request: PublishEventsRequest): Promise<void>;\n\n  /**\n   * Succeeds an async activity with the given value.\n   */\n  sendActivitySuccess(\n    request: Omit<SendActivitySuccessRequest, \"type\">\n  ): Promise<void>;\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  sendActivityFailure(\n    request: Omit<SendActivityFailureRequest, \"type\">\n  ): Promise<void>;\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  sendActivityHeartbeat(\n    request: Omit<SendActivityHeartbeatRequest, \"type\">\n  ): Promise<SendActivityHeartbeatResponse>;\n}\n\nexport interface StartExecutionResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface GetExecutionsRequest {\n  statuses?: ExecutionStatus[];\n  workflowName?: string;\n  nextToken?: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface GetExecutionsResponse {\n  executions: Execution[];\n  /**\n   * A token returned when there may be more executions to retrieve.\n   */\n  nextToken?: string;\n}\n\nexport interface PublishEventsRequest {\n  events: EventEnvelope<any>[];\n}\n\nexport interface ExecutionEventsRequest {\n  executionId: string;\n  /**\n   * @default \"Asc\"\n   */\n  sortDirection?: SortOrder;\n  nextToken?: string;\n  /**\n   * @default: 100\n   */\n  maxResults?: number;\n}\n\nexport interface ExecutionEventsResponse {\n  events: WorkflowEvent[];\n  nextToken?: string;\n}\n\nexport interface ExecutionHistoryResponse {\n  events: HistoryStateEvent[];\n}\n\nexport type SortOrder = \"Asc\" | \"Desc\";\n\nexport interface StartExecutionRequest<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  workflow: string | W;\n  /**\n   * Input payload for the workflow function.\n   */\n  input: WorkflowInput<W>;\n}\n\nexport interface WorkflowReference {\n  name: string;\n}\n\nexport interface GetWorkflowResponse {\n  workflows: WorkflowReference[];\n}\n\nexport enum ActivityUpdateType {\n  Success = \"Success\",\n  Failure = \"Failure\",\n  Heartbeat = \"Heartbeat\",\n}\n\nexport type SendActivityUpdate<T = any> =\n  | SendActivitySuccessRequest<T>\n  | SendActivityFailureRequest\n  | SendActivityHeartbeatRequest;\n\nexport interface SendActivitySuccessRequest<T = any> {\n  type: ActivityUpdateType.Success;\n  activityToken: string;\n  result: T;\n}\n\nexport interface SendActivityFailureRequest {\n  type: ActivityUpdateType.Failure;\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface SendActivityHeartbeatRequest {\n  type: ActivityUpdateType.Heartbeat;\n  activityToken: string;\n}\n\nexport function isSendActivitySuccessRequest<T = any>(\n  request: SendActivityUpdate<T>\n): request is SendActivitySuccessRequest<T> {\n  return request.type === ActivityUpdateType.Success;\n}\n\nexport function isSendActivityFailureRequest(\n  request: SendActivityUpdate\n): request is SendActivityFailureRequest {\n  return request.type === ActivityUpdateType.Failure;\n}\n\nexport function isSendActivityHeartbeatRequest(\n  request: SendActivityUpdate\n): request is SendActivityHeartbeatRequest {\n  return request.type === ActivityUpdateType.Heartbeat;\n}\n\nexport type SendActivityUpdateResponse = SendActivityHeartbeatResponse | void;\n\nexport interface SendActivityHeartbeatResponse {\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 cancelled.\n   */\n  cancelled: boolean;\n}\n"]}

@@ -29,3 +29,3 @@ /**

* let done = false;
* mySignal.on(async () => {
* mySignal.onSignal(async () => {
* await sleepFor(10);

@@ -42,3 +42,3 @@ * done = true;

* ```ts
* const handler = mySignal.on(() => {});
* const handler = mySignal.onSignal(() => {});
*

@@ -50,3 +50,3 @@ * await sleepFor(10);

*/
on(handler: SignalHandlerFunction<Payload>): SignalsHandler;
onSignal(handler: SignalHandlerFunction<Payload>): SignalsHandler;
/**

@@ -60,3 +60,3 @@ * Waits for a signal to be received by the workflow.

* workflow("wf", async () => {
* const payload = await mySignal.expect();
* const payload = await mySignal.expectSignal();
*

@@ -74,3 +74,3 @@ * return payload;

* try {
* const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });
* const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });
*

@@ -84,3 +84,3 @@ * return payload;

*/
expect(opts?: ExpectSignalOptions): Promise<Payload>;
expectSignal(opts?: ExpectSignalOptions): Promise<Payload>;
/**

@@ -92,7 +92,7 @@ * Allows a {@link workflow} to send this signal to any workflow {@link Execution} by executionId.

* workflow("wf", async () => {
* mySignal.send("payload");
* mySignal.sendSignal("payload");
* })
* ```
*/
send(executionId: string, ...args: SendSignalProps<Payload>): Promise<void>;
sendSignal(executionId: string, ...args: SendSignalProps<Payload>): Promise<void>;
}

@@ -124,4 +124,3 @@ export type SignalPayload<E extends Signal<any>> = E extends Signal<infer P> ? P : never;

*/
export declare function expectSignal<SignalPayload = any>(signalId: string, opts?: ExpectSignalOptions): Promise<SignalPayload>;
export declare function expectSignal<E extends Signal<any>>(signal: E, opts?: ExpectSignalOptions): Promise<SignalPayload<E>>;
export declare function expectSignal<SignalPayload = any>(signal: Signal<SignalPayload> | string, opts?: ExpectSignalOptions): Promise<SignalPayload>;
/**

@@ -156,5 +155,4 @@ * Listens for a signal matching the signalId provided.

*/
export declare function onSignal<E extends Signal<any>>(signal: E, handler: SignalHandlerFunction<SignalPayload<E>>): SignalsHandler;
export declare function onSignal<Payload = void>(signalId: string, handler: SignalHandlerFunction<Payload>): SignalsHandler;
export type SendSignalProps<SignalPayload> = [SignalPayload] extends [undefined] | [void] ? [id?: string] : [payload: SignalPayload, id?: string];
export declare function onSignal<Payload>(signal: Signal<Payload> | string, handler: SignalHandlerFunction<Payload>): SignalsHandler;
export type SendSignalProps<SignalPayload> = [SignalPayload] extends [undefined] | [void] ? [] : [payload: SignalPayload];
/**

@@ -173,4 +171,3 @@ * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.

*/
export declare function sendSignal<S extends Signal<any>>(executionId: string, signal: S, ...args: SendSignalProps<SignalPayload<S>>): Promise<void>;
export declare function sendSignal<Payload = any>(executionId: string, signalId: string, ...args: SendSignalProps<Payload>): Promise<void>;
export declare function sendSignal<Payload = any>(executionId: string, signal: string | Signal<Payload>, ...args: SendSignalProps<Payload>): Promise<void>;
export type SignalTarget = ExecutionTarget | ChildExecutionTarget;

@@ -177,0 +174,0 @@ export declare enum SignalTargetType {

@@ -26,3 +26,3 @@ import { createSendSignalCall } from "./calls/send-signal-call.js";

* let done = false;
* mySignal.on(async () => {
* mySignal.onSignal(async () => {
* await sleepFor(10);

@@ -39,3 +39,3 @@ * done = true;

* ```ts
* const handler = mySignal.on(() => {});
* const handler = mySignal.onSignal(() => {});
*

@@ -47,3 +47,3 @@ * await sleepFor(10);

*/
on(handler) {
onSignal(handler) {
return onSignal(this, handler);

@@ -59,3 +59,3 @@ }

* workflow("wf", async () => {
* const payload = await mySignal.expect();
* const payload = await mySignal.expectSignal();
*

@@ -73,3 +73,3 @@ * return payload;

* try {
* const payload = await mySignal.expect({ timeoutSecond: 10 * 60 });
* const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });
*

@@ -83,3 +83,3 @@ * return payload;

*/
expect(opts) {
expectSignal(opts) {
return expectSignal(this, opts);

@@ -93,10 +93,26 @@ }

* workflow("wf", async () => {
* mySignal.send("payload");
* mySignal.sendSignal("payload");
* })
* ```
*/
send(executionId, ...args) {
sendSignal(executionId, ...args) {
return sendSignal(executionId, this, ...args);
}
}
/**
* Waits for a signal to be received by the workflow.
*
* The first signal received will resolve the Promise with the payload of the promise.
*
* ```ts
* workflow("wf", () => {
* const payload = await expectSignal("MySignal");
*
* return payload;
* });
* ```
*
* Use `opts.timeoutSeconds` to stop waiting after the provided time. The Promise will reject
* when the provided time has elapsed.
*/
export function expectSignal(signal, opts) {

@@ -108,2 +124,31 @@ if (!isOrchestratorWorker()) {

}
/**
* Listens for a signal matching the signalId provided.
*
* When the signal is received, the handler is invoked.
* If the handler return a promise, the handler is added as a {@link Chain}
* and progressed until completion.
*
* ```ts
* workflow("wf", () => {
* let done = false;
* onSignal("MySignal", async () => {
* await sleepFor(10);
* done = true;
* });
*
* await condition(() => done);
* });
* ```
*
* To remove the handler, call the dispose method.
*
* ```ts
* const handler = onSignal("MySignal", () => {});
*
* await sleepFor(10);
*
* handler.dispose();
* ```
*/
export function onSignal(signal, handler) {

@@ -115,3 +160,17 @@ if (!isOrchestratorWorker()) {

}
export function sendSignal(executionId, signal, payload, id) {
/**
* Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.
*
* ```ts
* const mySignal = signal<string>("MySignal");
* workflow("wf", async () => {
* sendSignal("mySignal", "payload");
* sendSignal(mySignal, "payload");
* })
* ```
*
* @param id an optional, execution unique ID, will be used to de-dupe the signal at the target execution.
*/
export function sendSignal(executionId, signal, ...args) {
const [payload] = args;
if (isOrchestratorWorker()) {

@@ -124,3 +183,3 @@ return createSendSignalCall({ type: SignalTargetType.Execution, executionId }, typeof signal === "string" ? signal : signal.id, payload);

signal,
id: id ?? ulid(),
id: ulid(),
payload,

@@ -141,2 +200,2 @@ });

}
//# 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 { getServiceClient } 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 = 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 = 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 = 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 = 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 = 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 getServiceClient().sendSignal({\n      execution: 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 { getServiceClient } 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 = signal(\"MySignal\");\n   *\n   * workflow(\"wf\", () => {\n   *    let done = false;\n   *    mySignal.onSignal(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.onSignal(() => {});\n   *\n   * await sleepFor(10);\n   *\n   * handler.dispose();\n   * ```\n   */\n  public onSignal(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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    const payload = await mySignal.expectSignal();\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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    try {\n   *       const payload = await mySignal.expectSignal({ timeoutSecond: 10 * 60 });\n   *\n   *       return payload;\n   *    } catch {\n   *       return \"nothing!\";\n   *    }\n   * });\n   * ```\n   */\n  public expectSignal(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 = signal<string>(\"MySignal\");\n   * workflow(\"wf\", async () => {\n   *    mySignal.sendSignal(\"payload\");\n   * })\n   * ```\n   */\n  public sendSignal(\n    executionId: string,\n    ...args: SendSignalProps<Payload>\n  ): Promise<void> {\n    return sendSignal(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  signal: Signal<SignalPayload> | string,\n  opts?: ExpectSignalOptions\n): Promise<SignalPayload> {\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<Payload>(\n  signal: Signal<Payload> | string,\n  handler: SignalHandlerFunction<Payload>\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  ? []\n  : [payload: SignalPayload];\n\n/**\n * Allows a {@link workflow} to send a signal to any workflow {@link Execution} by executionId.\n *\n * ```ts\n * const mySignal = 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<Payload = any>(\n  executionId: string,\n  signal: string | Signal<Payload>,\n  ...args: SendSignalProps<Payload>\n): Promise<void> {\n  const [payload] = args;\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 getServiceClient().sendSignal({\n      execution: executionId,\n      signal,\n      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"]}

@@ -15,3 +15,3 @@ import { ExecutionContext } from "./context.js";

export declare enum WorkflowEventType {
ActivityCompleted = "ActivityCompleted",
ActivitySucceeded = "ActivitySucceeded",
ActivityFailed = "ActivityFailed",

@@ -21,3 +21,3 @@ ActivityHeartbeatTimedOut = "ActivityHeartbeatTimedOut",

ActivityTimedOut = "ActivityTimedOut",
ChildWorkflowCompleted = "ChildWorkflowCompleted",
ChildWorkflowSucceeded = "ChildWorkflowSucceeded",
ChildWorkflowFailed = "ChildWorkflowFailed",

@@ -34,7 +34,7 @@ ChildWorkflowScheduled = "ChildWorkflowScheduled",

SleepScheduled = "SleepScheduled",
WorkflowCompleted = "WorkflowCompleted",
WorkflowSucceeded = "WorkflowSucceeded",
WorkflowFailed = "WorkflowFailed",
WorkflowStarted = "WorkflowStarted",
WorkflowTaskCompleted = "TaskCompleted",
WorkflowTaskStarted = "TaskStarted",
WorkflowRunCompleted = "WorkflowRunCompleted",
WorkflowRunStarted = "WorkflowRunStarted",
WorkflowTimedOut = "WorkflowTimedOut"

@@ -45,5 +45,5 @@ }

*/
export type WorkflowEvent = HistoryEvent | WorkflowTaskCompleted | WorkflowTaskStarted | WorkflowCompleted | WorkflowFailed | WorkflowStarted;
export type WorkflowEvent = HistoryEvent | WorkflowRunCompleted | WorkflowRunStarted | WorkflowSucceeded | WorkflowFailed | WorkflowStarted;
export type ScheduledEvent = ActivityScheduled | ChildWorkflowScheduled | ConditionStarted | EventsPublished | ExpectSignalStarted | SignalSent | SleepScheduled;
export type CompletedEvent = ActivityCompleted | ChildWorkflowCompleted | SleepCompleted;
export type SucceededEvent = ActivitySucceeded | ChildWorkflowSucceeded | SleepCompleted;
export type FailedEvent = ActivityFailed | ActivityHeartbeatTimedOut | ActivityTimedOut | ChildWorkflowFailed | ConditionTimedOut | ExpectSignalTimedOut;

@@ -53,3 +53,3 @@ /**

*/
export type HistoryEvent = CompletedEvent | FailedEvent | ScheduledEvent | SignalReceived | WorkflowTimedOut;
export type HistoryEvent = SucceededEvent | FailedEvent | ScheduledEvent | SignalReceived | WorkflowTimedOut;
export declare function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent;

@@ -76,4 +76,4 @@ /**

}
export interface WorkflowTaskStarted extends BaseEvent {
type: WorkflowEventType.WorkflowTaskStarted;
export interface WorkflowRunStarted extends BaseEvent {
type: WorkflowEventType.WorkflowRunStarted;
/**

@@ -89,4 +89,4 @@ * An execution ID of the parent workflow execution that

}
export interface ActivityCompleted extends HistoryEventBase {
type: WorkflowEventType.ActivityCompleted;
export interface ActivitySucceeded extends HistoryEventBase {
type: WorkflowEventType.ActivitySucceeded;
result: any;

@@ -102,7 +102,7 @@ }

}
export interface WorkflowTaskCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowTaskCompleted;
export interface WorkflowRunCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowRunCompleted;
}
export interface WorkflowCompleted extends BaseEvent {
type: WorkflowEventType.WorkflowCompleted;
export interface WorkflowSucceeded extends BaseEvent {
type: WorkflowEventType.WorkflowSucceeded;
output: any;

@@ -120,4 +120,4 @@ }

}
export interface ChildWorkflowCompleted extends HistoryEventBase {
type: WorkflowEventType.ChildWorkflowCompleted;
export interface ChildWorkflowSucceeded extends HistoryEventBase {
type: WorkflowEventType.ChildWorkflowSucceeded;
result: any;

@@ -131,5 +131,5 @@ }

export declare function isWorkflowStarted(event: WorkflowEvent): event is WorkflowStarted;
export declare function isTaskStarted(event: WorkflowEvent): event is WorkflowTaskStarted;
export declare function isWorkflowRunStarted(event: WorkflowEvent): event is WorkflowRunStarted;
export declare function isActivityScheduled(event: WorkflowEvent): event is ActivityScheduled;
export declare function isActivityCompleted(event: WorkflowEvent): event is ActivityCompleted;
export declare function isActivitySucceeded(event: WorkflowEvent): event is ActivitySucceeded;
export declare function isActivityFailed(event: WorkflowEvent): event is ActivityFailed;

@@ -146,7 +146,7 @@ export declare function isActivityHeartbeatTimedOut(event: WorkflowEvent): event is ActivityHeartbeatTimedOut;

}
export declare function isTaskCompleted(event: WorkflowEvent): event is WorkflowTaskCompleted;
export declare function isWorkflowCompleted(event: WorkflowEvent): event is WorkflowCompleted;
export declare function isWorkflowRunCompleted(event: WorkflowEvent): event is WorkflowRunCompleted;
export declare function isWorkflowSucceeded(event: WorkflowEvent): event is WorkflowSucceeded;
export declare function isWorkflowFailed(event: WorkflowEvent): event is WorkflowFailed;
export declare function isChildWorkflowScheduled(event: WorkflowEvent): event is ChildWorkflowScheduled;
export declare function isChildWorkflowCompleted(event: WorkflowEvent): event is ChildWorkflowCompleted;
export declare function isChildWorkflowSucceeded(event: WorkflowEvent): event is ChildWorkflowSucceeded;
export declare function isChildWorkflowFailed(event: WorkflowEvent): event is ChildWorkflowFailed;

@@ -200,3 +200,3 @@ export declare function isSleepCompleted(event: WorkflowEvent): event is SleepCompleted;

export declare const isScheduledEvent: (a: any) => a is ActivityScheduled | ChildWorkflowScheduled | ConditionStarted | EventsPublished | ExpectSignalStarted | SignalSent | SleepScheduled;
export declare const isCompletedEvent: (a: any) => a is ActivityCompleted | ChildWorkflowCompleted | SleepCompleted;
export declare const isSucceededEvent: (a: any) => a is ActivitySucceeded | ChildWorkflowSucceeded | SleepCompleted;
export declare const isFailedEvent: (a: any) => a is ActivityFailed | ActivityHeartbeatTimedOut | ActivityTimedOut | ChildWorkflowFailed | ConditionTimedOut | ExpectSignalTimedOut | WorkflowTimedOut;

@@ -203,0 +203,0 @@ export declare function assertEventType<T extends WorkflowEvent>(event: any, type: T["type"]): asserts event is T;

@@ -5,3 +5,3 @@ import { ulid } from "ulidx";

(function (WorkflowEventType) {
WorkflowEventType["ActivityCompleted"] = "ActivityCompleted";
WorkflowEventType["ActivitySucceeded"] = "ActivitySucceeded";
WorkflowEventType["ActivityFailed"] = "ActivityFailed";

@@ -11,3 +11,3 @@ WorkflowEventType["ActivityHeartbeatTimedOut"] = "ActivityHeartbeatTimedOut";

WorkflowEventType["ActivityTimedOut"] = "ActivityTimedOut";
WorkflowEventType["ChildWorkflowCompleted"] = "ChildWorkflowCompleted";
WorkflowEventType["ChildWorkflowSucceeded"] = "ChildWorkflowSucceeded";
WorkflowEventType["ChildWorkflowFailed"] = "ChildWorkflowFailed";

@@ -24,11 +24,11 @@ WorkflowEventType["ChildWorkflowScheduled"] = "ChildWorkflowScheduled";

WorkflowEventType["SleepScheduled"] = "SleepScheduled";
WorkflowEventType["WorkflowCompleted"] = "WorkflowCompleted";
WorkflowEventType["WorkflowSucceeded"] = "WorkflowSucceeded";
WorkflowEventType["WorkflowFailed"] = "WorkflowFailed";
WorkflowEventType["WorkflowStarted"] = "WorkflowStarted";
WorkflowEventType["WorkflowTaskCompleted"] = "TaskCompleted";
WorkflowEventType["WorkflowTaskStarted"] = "TaskStarted";
WorkflowEventType["WorkflowRunCompleted"] = "WorkflowRunCompleted";
WorkflowEventType["WorkflowRunStarted"] = "WorkflowRunStarted";
WorkflowEventType["WorkflowTimedOut"] = "WorkflowTimedOut";
})(WorkflowEventType || (WorkflowEventType = {}));
export function isHistoryEvent(event) {
return (isCompletedEvent(event) ||
return (isSucceededEvent(event) ||
isFailedEvent(event) ||

@@ -42,4 +42,4 @@ isScheduledEvent(event) ||

}
export function isTaskStarted(event) {
return event.type === WorkflowEventType.WorkflowTaskStarted;
export function isWorkflowRunStarted(event) {
return event.type === WorkflowEventType.WorkflowRunStarted;
}

@@ -49,4 +49,4 @@ export function isActivityScheduled(event) {

}
export function isActivityCompleted(event) {
return event.type === WorkflowEventType.ActivityCompleted;
export function isActivitySucceeded(event) {
return event.type === WorkflowEventType.ActivitySucceeded;
}

@@ -62,7 +62,7 @@ export function isActivityFailed(event) {

}
export function isTaskCompleted(event) {
return event.type === WorkflowEventType.WorkflowTaskCompleted;
export function isWorkflowRunCompleted(event) {
return event.type === WorkflowEventType.WorkflowRunCompleted;
}
export function isWorkflowCompleted(event) {
return event.type === WorkflowEventType.WorkflowCompleted;
export function isWorkflowSucceeded(event) {
return event.type === WorkflowEventType.WorkflowSucceeded;
}

@@ -75,4 +75,4 @@ export function isWorkflowFailed(event) {

}
export function isChildWorkflowCompleted(event) {
return event.type === WorkflowEventType.ChildWorkflowCompleted;
export function isChildWorkflowSucceeded(event) {
return event.type === WorkflowEventType.ChildWorkflowSucceeded;
}

@@ -113,3 +113,3 @@ export function isChildWorkflowFailed(event) {

export const isScheduledEvent = or(isActivityScheduled, isChildWorkflowScheduled, isConditionStarted, isEventsPublished, isExpectSignalStarted, isSignalSent, isSleepScheduled);
export const isCompletedEvent = or(isActivityCompleted, isChildWorkflowCompleted, isSleepCompleted);
export const isSucceededEvent = or(isActivitySucceeded, isChildWorkflowSucceeded, isSleepCompleted);
export const isFailedEvent = or(isActivityFailed, isActivityTimedOut, isActivityHeartbeatTimedOut, isChildWorkflowFailed, isConditionTimedOut, isExpectSignalTimedOut, isWorkflowTimedOut);

@@ -161,2 +161,2 @@ export function assertEventType(event, type) {

}
//# 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,\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  ActivitySucceeded = \"ActivitySucceeded\",\n  ActivityFailed = \"ActivityFailed\",\n  ActivityHeartbeatTimedOut = \"ActivityHeartbeatTimedOut\",\n  ActivityScheduled = \"ActivityScheduled\",\n  ActivityTimedOut = \"ActivityTimedOut\",\n  ChildWorkflowSucceeded = \"ChildWorkflowSucceeded\",\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  WorkflowSucceeded = \"WorkflowSucceeded\",\n  WorkflowFailed = \"WorkflowFailed\",\n  WorkflowStarted = \"WorkflowStarted\",\n  WorkflowRunCompleted = \"WorkflowRunCompleted\",\n  WorkflowRunStarted = \"WorkflowRunStarted\",\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  | WorkflowRunCompleted\n  | WorkflowRunStarted\n  | WorkflowSucceeded\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 SucceededEvent =\n  | ActivitySucceeded\n  | ChildWorkflowSucceeded\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  | SucceededEvent\n  | FailedEvent\n  | ScheduledEvent\n  | SignalReceived\n  | WorkflowTimedOut;\n\nexport function isHistoryEvent(event: WorkflowEvent): event is HistoryEvent {\n  return (\n    isSucceededEvent(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 WorkflowRunStarted extends BaseEvent {\n  type: WorkflowEventType.WorkflowRunStarted;\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 ActivitySucceeded extends HistoryEventBase {\n  type: WorkflowEventType.ActivitySucceeded;\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 WorkflowRunCompleted extends BaseEvent {\n  type: WorkflowEventType.WorkflowRunCompleted;\n}\n\nexport interface WorkflowSucceeded extends BaseEvent {\n  type: WorkflowEventType.WorkflowSucceeded;\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 ChildWorkflowSucceeded extends HistoryEventBase {\n  type: WorkflowEventType.ChildWorkflowSucceeded;\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 isWorkflowRunStarted(\n  event: WorkflowEvent\n): event is WorkflowRunStarted {\n  return event.type === WorkflowEventType.WorkflowRunStarted;\n}\n\nexport function isActivityScheduled(\n  event: WorkflowEvent\n): event is ActivityScheduled {\n  return event.type === WorkflowEventType.ActivityScheduled;\n}\n\nexport function isActivitySucceeded(\n  event: WorkflowEvent\n): event is ActivitySucceeded {\n  return event.type === WorkflowEventType.ActivitySucceeded;\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 isWorkflowRunCompleted(\n  event: WorkflowEvent\n): event is WorkflowRunCompleted {\n  return event.type === WorkflowEventType.WorkflowRunCompleted;\n}\n\nexport function isWorkflowSucceeded(\n  event: WorkflowEvent\n): event is WorkflowSucceeded {\n  return event.type === WorkflowEventType.WorkflowSucceeded;\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 isChildWorkflowSucceeded(\n  event: WorkflowEvent\n): event is ChildWorkflowSucceeded {\n  return event.type === WorkflowEventType.ChildWorkflowSucceeded;\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 isSucceededEvent = or(\n  isActivitySucceeded,\n  isChildWorkflowSucceeded,\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,\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.5.1",
"version": "0.5.2",
"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 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 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

SocketSocket SOC 2 Logo

Product

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

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc