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

@eventual/core

Package Overview
Dependencies
Maintainers
2
Versions
164
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@eventual/core - npm Package Compare versions

Comparing version 0.4.3 to 0.5.0

lib/cjs/runtime/clients/runtime-service-clients.d.ts

6

lib/cjs/activity.d.ts

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

import { CompleteActivityRequest } from "./runtime/clients/workflow-client.js";
import { SendActivitySuccessRequest } from "./service-client.js";
export interface ActivityOptions {

@@ -24,3 +24,3 @@ /**

/**
* Complete an activity request by its {@link CompleteActivityRequest.activityToken}.
* Complete an activity request by its {@link SendActivitySuccessRequest.activityToken}.
*

@@ -45,3 +45,3 @@ * This method is used in conjunction with {@link asyncResult} in an activity

*/
complete(request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>): Promise<void>;
complete(request: Omit<SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>, "type">): Promise<void>;
activityID: string;

@@ -48,0 +48,0 @@ }

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

func.complete = async function (request) {
return (0, global_js_1.getWorkflowClient)().completeActivity(request);
return (0, global_js_1.getServiceClient)().sendActivitySuccess(request);
};

@@ -80,2 +80,2 @@ func.activityID = activityID;

exports.getCallableActivityNames = getCallableActivityNames;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":";;;AAAA,+DAA8D;AAC9D,2CAIqB;AAErB,iDAA4E;AAuE5E,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,6BAAiB,GAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,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  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<Arguments extends any[], Output = any> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n\n  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 getWorkflowClient().completeActivity(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;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"]}

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

else {
return (0, global_js_1.getEventClient)().publish(...envelopes);
return (0, index_js_1.getServiceClient)().publishEvents({ events: envelopes });
}

@@ -79,2 +79,2 @@ },

exports.event = event;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXNFO0FBQ3RFLDJDQUF5RTtBQUN6RSx5Q0FBa0Q7QUFnR2xEOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsU0FBZ0IsS0FBSyxDQUF5QixJQUFZO0lBQ3hELElBQUksSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLElBQUksa0JBQWtCLENBQUMsQ0FBQztLQUM3RDtJQUNELE1BQU0sS0FBSyxHQUFhO1FBQ3RCLElBQUk7UUFDSixFQUFFLENBQUMsT0FBTztZQUNSLElBQUEsOEJBQWtCLEdBQUUsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLGFBQWEsRUFBRTtvQkFDYjt3QkFDRSxJQUFJO3FCQUNMO2lCQUNGO2dCQUNELE9BQU8sRUFBRSxPQUFxQzthQUMvQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxDQUFDLEdBQUcsTUFBTTtZQUNmLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3ZDLElBQUk7Z0JBQ0osS0FBSzthQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0osSUFBSSxJQUFBLCtCQUFvQixHQUFFLEVBQUU7Z0JBQzFCLE9BQU8sSUFBQSw2Q0FBdUIsRUFBQyxTQUFTLENBQVEsQ0FBQzthQUNsRDtpQkFBTTtnQkFDTCxPQUFPLElBQUEsMEJBQWMsR0FBRSxDQUFDLE9BQU8sQ0FBQyxHQUFHLFNBQVMsQ0FBQyxDQUFDO2FBQy9DO1FBQ0gsQ0FBQztLQUNGLENBQUM7SUFDRixJQUFBLGtCQUFNLEdBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzFCLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQztBQTlCRCxzQkE4QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBjcmVhdGVQdWJsaXNoRXZlbnRzQ2FsbCB9IGZyb20gXCIuL2NhbGxzL3NlbmQtZXZlbnRzLWNhbGwuanNcIjtcbmltcG9ydCB7IGV2ZW50cywgZXZlbnRTdWJzY3JpcHRpb25zLCBnZXRFdmVudENsaWVudCB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9pbmRleC5qc1wiO1xuXG4vKipcbiAqIEFuIEV2ZW50UGF5bG9hZCBpcyB0aGUgZGF0YSBzZW50IGFzIGFuIGV2ZW50LlxuICpcbiAqIEl0IG11c3QgYmUgYW4gb2JqZWN0LiBQcm9wZXJ0aWVzIGNhbiBiZSBhbnkgdHlwZSBzZXJpYWxpemFibGUgYXMgSlNPTi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFBheWxvYWQge1xuICBbcHJvcE5hbWU6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IHR5cGUgRXZlbnRQYXlsb2FkVHlwZTxFIGV4dGVuZHMgRXZlbnQ8YW55Pj4gPSBFIGV4dGVuZHMgRXZlbnQ8XG4gIGluZmVyIFBheWxvYWRcbj5cbiAgPyBQYXlsb2FkXG4gIDogbmV2ZXI7XG5cbi8qKlxuICogQW4gZW52ZWxvcGUgb2JqZWN0IGNvbnRhaW5pbmcgdGhlIHtAbGluayBldmVudH0gcGF5bG9hZCBhc3NvY2lhdGVkXG4gKiB3aXRoIGl0cyB1bmlxdWUge0BsaW5rIG5hbWV9LlxuICpcbiAqIFRoaXMgZW52ZWxvcGUgZGVjb3VwbGVzIHRoZSB7QGxpbmsgbmFtZX0gZnJvIHRoZSBwYXlsb2FkIHNvIHRoYXRcbiAqIHRoZXJlIGFyZSBubyBpbXBvc2l0aW9ucyBvbiB0aGUgc3RydWN0dXJlIG9mIGFuIGV2ZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50RW52ZWxvcGU8RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogVW5pcXVlIG5hbWUgaWRlbnRpZnlpbmcgdGhlIHR5cGUgb2YgdGhlIHtAbGluayBldmVudH0uXG4gICAqL1xuICBuYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50UGF5bG9hZH0uXG4gICAqL1xuICBldmVudDogRTtcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnR9IGlzIGFuIG9iamVjdCByZXByZXNlbnRpbmcgdGhlIGRlY2xhcmF0aW9uIG9mIGFuIGV2ZW50XG4gKiB0aGF0IGJlbG9uZ3Mgd2l0aGluIHRoZSBzZXJ2aWNlLiBBbiB7QGxpbmsgRXZlbnR9IGhhcyBhIHVuaXF1ZSB7QGxpbmsgbmFtZX0sXG4gKiBtYXkgYmUge0BsaW5rIHB1Ymxpc2h9ZWQgYW5kIHtAbGluayBvbn1kIHRvLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFRoZSBFdmVudCdzIGdsb2JhbGx5IHVuaXF1ZSBuYW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3Vic2NyaWJlIHRvIHRoaXMgZXZlbnQuIFRoZSB7QGxpbmsgaGFuZGxlcn0gd2lsbCBiZSBpbnZva2VkIGV2ZXJ5XG4gICAqIHRpbWUgYW4gZXZlbnQgd2l0aCB0aGlzIG5hbWUgaXMgcHVibGlzaGVkIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICpcbiAgICogQHBhcmFtIGhhbmRsZXIgdGhlIGhhbmRsZXIgZnVuY3Rpb24gdGhhdCB3aWxsIHByb2Nlc3MgdGhlIGV2ZW50LlxuICAgKi9cbiAgb24oaGFuZGxlcjogKGV2ZW50OiBFKSA9PiBQcm9taXNlPHZvaWQ+KTogdm9pZDtcbiAgLyoqXG4gICAqIFB1Ymxpc2ggZXZlbnRzIG9mIHRoaXMgdHlwZSB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudHMgYSBsaXN0IG9mIGV2ZW50cyB0byBwdWJsaXNoLlxuICAgKi9cbiAgcHVibGlzaCguLi5ldmVudHM6IEVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU3Vic2NyaXB0aW9ufSBpcyBhbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgaG93IHRvIHNlbGVjdCBldmVudHMgZnJvbVxuICogd2l0aGluIGEgc2VydmljZSBib3VuZGFyeSB0byByb3V0ZSB0byBhIHtAbGluayBFdmVudEhhbmRsZXJ9LlxuICpcbiAqIEZvciBub3csIHdlIG9ubHkgc3VwcG9ydCBtYXRjaGluZyBvbiBhIHNpbmdsZSBuYW1lLCBidXQgdGhpcyBvYmplY3QgY2FuIGJlXG4gKiBleHRlbmRlZCB3aXRoIG90aGVyIHByb3BlcnRpZXMgc3VjaCBhcyBzZWxlY3Rpb24gcHJlZGljYXRlcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb24ge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgZXZlbnQgdG8gc3Vic2NyaWJlIHRvLlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFuIHtAbGluayBFdmVudFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgYXNzb2NpYXRlcyBhIHtAbGluayBoYW5kbGVyfVxuICogZnVuY3Rpb24gd2l0aCBhIGxpc3Qgb2Yge0BsaW5rIHN1YnNjcmlwdGlvbnN9LiBUaGUge0BsaW5rIHN1YnNjcmlwdGlvbnN9XG4gKiBkZWZpbmUgd2hpY2ggZXZlbnRzIHRoaXMge0BsaW5rIGhhbmRsZXJ9IHNob3VsZCBiZSBpbnZva2VkIGZvci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBBIGxpc3Qgb2Yge0BsaW5rIFN1YnNjcmlwdGlvbn1zIHRoYXQgc2hvdWxkIGludm9rZSB0aGlzIHtAbGluayBoYW5kbGVyfS5cbiAgICovXG4gIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudEhhbmRsZXJ9IHRvIGludm9rZSBmb3IgYW55IGV2ZW50IHRoYXQgbWF0Y2hlcyBvbmUgb2ZcbiAgICogdGhlIHtAbGluayBzdWJzY3JpcHRpb25zfS5cbiAgICovXG4gIGhhbmRsZXI6IEV2ZW50SGFuZGxlcjxFPjtcbn1cblxuLyoqXG4gKiBBIEZ1bmN0aW9uIHRoYXQgcHJvY2Vzc2VzIGFuIHtAbGluayBldmVudH0gb2YgdHlwZSB7QGxpbmsgRX0uXG4gKi9cbmV4cG9ydCB0eXBlIEV2ZW50SGFuZGxlcjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPiA9IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPjtcblxuLyoqXG4gKiBEZWNsYXJlcyBhbiBldmVudCB0aGF0IGNhbiBiZSBwdWJsaXNoZWQgYW5kIHN1YnNjcmliZWQgdG8uXG4gKlxuICogVG8gZGVjbGFyZSBhbiB7QGxpbmsgRXZlbnR9LCBkZWZpbmUgYW4gaW50ZXJmYWNlIGRlc2NyaWJpbmcgdGhlIHR5cGVcbiAqIG9mIHRoZSBwYXlsb2FkIGFuZCB0aGVuIGRlY2xhcmUgYW4gZXZlbnQgb2JqZWN0IGdpdmluZyBpdCBhIHVuaXF1ZSBuYW1lLlxuICogYGBgdHNcbiAqIGludGVyZmFjZSBDaGVja291dEV2ZW50IHtcbiAqICAgY3VzdG9tZXJJZDogc3RyaW5nO1xuICogICBjYXJ0SWQ6IHN0cmluZztcbiAqICAgdGltZXN0YW1wOiBzdHJpbmc7XG4gKiB9XG4gKlxuICogY29uc3QgY2hlY2tvdXRFdmVudCA9IGV2ZW50PENoZWNrb3V0RXZlbnQ+KFwiQ2hlY2tvdXRcIik7XG4gKiBgYGBcbiAqXG4gKiBUbyBwdWJsaXNoIGV2ZW50cywgY2FsbCB0aGUgYHB1Ymxpc2hgIG1ldGhvZDpcbiAqIGBgYHRzXG4gKiBjb25zdCBjaGVja291dFdvcmtmbG93ID0gd29ya2Zsb3coXCJjaGVja291dFdvcmtmbG93XCIsIGFzeW5jIChyZXF1ZXN0KSA9PiB7XG4gKiAgIGF3YWl0IGNoZWNrb3V0RXZlbnQucHVibGlzaCh7XG4gKiAgICAgY3VzdG9tZXJJZDogcmVxdWVzdC5jdXN0b21lcklkLFxuICogICAgIGNhcnRJZDogcmVxdWVzdC5jYXJ0SWQsXG4gKiAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvVGltZVN0cmluZygpXG4gKiAgIH0pO1xuICogfSlcbiAqIGBgYFxuICpcbiAqIFRvIHN1YnNjcmliZSB0byBldmVudHMsIGNhbGwgdGhlIGBvbmAgbWV0aG9kLiBUaGlzIHdpbGwgcmVnaXN0ZXIgYVxuICogaGFuZGxlciB0aGF0IHdpbCBsYmUgaW52b2tlZCBmb3IgZXZlcnkgZXZlbnQgb2YgdGhpcyB0eXBlIHRoYXQgaXMgcmVjZWl2ZWQuXG4gKlxuICogYGBgdHNcbiAqIGNoZWNrb3V0RXZlbnQub24oYXN5bmMgKGNoZWNrb3V0KSA9PiB7XG4gKiAgIGNvbnNvbGUubG9nKGNoZWNrb3V0KTtcbiAqIH0pO1xuICogYGBgXG4gKlxuICogQHBhcmFtIG5hbWUgYSB1bmlxdWUgbmFtZSB0aGF0IGlkZW50aWZpZXMgdGhpcyBldmVudCB0eXBlIHdpdGhpbiB0aGUgU2VydmljZS5cbiAqIEByZXR1cm5zIGFuIHtAbGluayBFdmVudH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQ+KG5hbWU6IHN0cmluZyk6IEV2ZW50PEU+IHtcbiAgaWYgKGV2ZW50cygpLmhhcyhuYW1lKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgZXZlbnQgd2l0aCBuYW1lICcke25hbWV9JyBhbHJlYWR5IGV4aXN0c2ApO1xuICB9XG4gIGNvbnN0IGV2ZW50OiBFdmVudDxFPiA9IHtcbiAgICBuYW1lLFxuICAgIG9uKGhhbmRsZXIpIHtcbiAgICAgIGV2ZW50U3Vic2NyaXB0aW9ucygpLnB1c2goe1xuICAgICAgICBzdWJzY3JpcHRpb25zOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZSxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgICBoYW5kbGVyOiBoYW5kbGVyIGFzIEV2ZW50SGFuZGxlcjxFdmVudFBheWxvYWQ+LFxuICAgICAgfSk7XG4gICAgfSxcbiAgICBwdWJsaXNoKC4uLmV2ZW50cykge1xuICAgICAgY29uc3QgZW52ZWxvcGVzID0gZXZlbnRzLm1hcCgoZXZlbnQpID0+ICh7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIGV2ZW50LFxuICAgICAgfSkpO1xuICAgICAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICAgICAgcmV0dXJuIGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsKGVudmVsb3BlcykgYXMgYW55O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGdldEV2ZW50Q2xpZW50KCkucHVibGlzaCguLi5lbnZlbG9wZXMpO1xuICAgICAgfVxuICAgIH0sXG4gIH07XG4gIGV2ZW50cygpLnNldChuYW1lLCBldmVudCk7XG4gIHJldHVybiBldmVudDtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEscUVBQXNFO0FBQ3RFLDJDQUF5RDtBQUN6RCx5Q0FBb0U7QUFnR3BFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsU0FBZ0IsS0FBSyxDQUF5QixJQUFZO0lBQ3hELElBQUksSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxFQUFFO1FBQ3RCLE1BQU0sSUFBSSxLQUFLLENBQUMsb0JBQW9CLElBQUksa0JBQWtCLENBQUMsQ0FBQztLQUM3RDtJQUNELE1BQU0sS0FBSyxHQUFhO1FBQ3RCLElBQUk7UUFDSixFQUFFLENBQUMsT0FBTztZQUNSLElBQUEsOEJBQWtCLEdBQUUsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLGFBQWEsRUFBRTtvQkFDYjt3QkFDRSxJQUFJO3FCQUNMO2lCQUNGO2dCQUNELE9BQU8sRUFBRSxPQUFxQzthQUMvQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxDQUFDLEdBQUcsTUFBTTtZQUNmLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3ZDLElBQUk7Z0JBQ0osS0FBSzthQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0osSUFBSSxJQUFBLCtCQUFvQixHQUFFLEVBQUU7Z0JBQzFCLE9BQU8sSUFBQSw2Q0FBdUIsRUFBQyxTQUFTLENBQVEsQ0FBQzthQUNsRDtpQkFBTTtnQkFDTCxPQUFPLElBQUEsMkJBQWdCLEdBQUUsQ0FBQyxhQUFhLENBQUMsRUFBRSxNQUFNLEVBQUUsU0FBUyxFQUFFLENBQUMsQ0FBQzthQUNoRTtRQUNILENBQUM7S0FDRixDQUFDO0lBQ0YsSUFBQSxrQkFBTSxHQUFFLENBQUMsR0FBRyxDQUFDLElBQUksRUFBRSxLQUFLLENBQUMsQ0FBQztJQUMxQixPQUFPLEtBQUssQ0FBQztBQUNmLENBQUM7QUE5QkQsc0JBOEJDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlUHVibGlzaEV2ZW50c0NhbGwgfSBmcm9tIFwiLi9jYWxscy9zZW5kLWV2ZW50cy1jYWxsLmpzXCI7XG5pbXBvcnQgeyBldmVudHMsIGV2ZW50U3Vic2NyaXB0aW9ucyB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgZ2V0U2VydmljZUNsaWVudCwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9pbmRleC5qc1wiO1xuXG4vKipcbiAqIEFuIEV2ZW50UGF5bG9hZCBpcyB0aGUgZGF0YSBzZW50IGFzIGFuIGV2ZW50LlxuICpcbiAqIEl0IG11c3QgYmUgYW4gb2JqZWN0LiBQcm9wZXJ0aWVzIGNhbiBiZSBhbnkgdHlwZSBzZXJpYWxpemFibGUgYXMgSlNPTi5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFBheWxvYWQge1xuICBbcHJvcE5hbWU6IHN0cmluZ106IGFueTtcbn1cblxuZXhwb3J0IHR5cGUgRXZlbnRQYXlsb2FkVHlwZTxFIGV4dGVuZHMgRXZlbnQ8YW55Pj4gPSBFIGV4dGVuZHMgRXZlbnQ8XG4gIGluZmVyIFBheWxvYWRcbj5cbiAgPyBQYXlsb2FkXG4gIDogbmV2ZXI7XG5cbi8qKlxuICogQW4gZW52ZWxvcGUgb2JqZWN0IGNvbnRhaW5pbmcgdGhlIHtAbGluayBldmVudH0gcGF5bG9hZCBhc3NvY2lhdGVkXG4gKiB3aXRoIGl0cyB1bmlxdWUge0BsaW5rIG5hbWV9LlxuICpcbiAqIFRoaXMgZW52ZWxvcGUgZGVjb3VwbGVzIHRoZSB7QGxpbmsgbmFtZX0gZnJvIHRoZSBwYXlsb2FkIHNvIHRoYXRcbiAqIHRoZXJlIGFyZSBubyBpbXBvc2l0aW9ucyBvbiB0aGUgc3RydWN0dXJlIG9mIGFuIGV2ZW50LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50RW52ZWxvcGU8RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogVW5pcXVlIG5hbWUgaWRlbnRpZnlpbmcgdGhlIHR5cGUgb2YgdGhlIHtAbGluayBldmVudH0uXG4gICAqL1xuICBuYW1lOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50UGF5bG9hZH0uXG4gICAqL1xuICBldmVudDogRTtcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnR9IGlzIGFuIG9iamVjdCByZXByZXNlbnRpbmcgdGhlIGRlY2xhcmF0aW9uIG9mIGFuIGV2ZW50XG4gKiB0aGF0IGJlbG9uZ3Mgd2l0aGluIHRoZSBzZXJ2aWNlLiBBbiB7QGxpbmsgRXZlbnR9IGhhcyBhIHVuaXF1ZSB7QGxpbmsgbmFtZX0sXG4gKiBtYXkgYmUge0BsaW5rIHB1Ymxpc2h9ZWQgYW5kIHtAbGluayBvbn1kIHRvLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFRoZSBFdmVudCdzIGdsb2JhbGx5IHVuaXF1ZSBuYW1lLlxuICAgKi9cbiAgcmVhZG9ubHkgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogU3Vic2NyaWJlIHRvIHRoaXMgZXZlbnQuIFRoZSB7QGxpbmsgaGFuZGxlcn0gd2lsbCBiZSBpbnZva2VkIGV2ZXJ5XG4gICAqIHRpbWUgYW4gZXZlbnQgd2l0aCB0aGlzIG5hbWUgaXMgcHVibGlzaGVkIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICpcbiAgICogQHBhcmFtIGhhbmRsZXIgdGhlIGhhbmRsZXIgZnVuY3Rpb24gdGhhdCB3aWxsIHByb2Nlc3MgdGhlIGV2ZW50LlxuICAgKi9cbiAgb24oaGFuZGxlcjogKGV2ZW50OiBFKSA9PiBQcm9taXNlPHZvaWQ+KTogdm9pZDtcbiAgLyoqXG4gICAqIFB1Ymxpc2ggZXZlbnRzIG9mIHRoaXMgdHlwZSB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBldmVudHMgYSBsaXN0IG9mIGV2ZW50cyB0byBwdWJsaXNoLlxuICAgKi9cbiAgcHVibGlzaCguLi5ldmVudHM6IEVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQSB7QGxpbmsgU3Vic2NyaXB0aW9ufSBpcyBhbiBvYmplY3QgdGhhdCBkZXNjcmliZXMgaG93IHRvIHNlbGVjdCBldmVudHMgZnJvbVxuICogd2l0aGluIGEgc2VydmljZSBib3VuZGFyeSB0byByb3V0ZSB0byBhIHtAbGluayBFdmVudEhhbmRsZXJ9LlxuICpcbiAqIEZvciBub3csIHdlIG9ubHkgc3VwcG9ydCBtYXRjaGluZyBvbiBhIHNpbmdsZSBuYW1lLCBidXQgdGhpcyBvYmplY3QgY2FuIGJlXG4gKiBleHRlbmRlZCB3aXRoIG90aGVyIHByb3BlcnRpZXMgc3VjaCBhcyBzZWxlY3Rpb24gcHJlZGljYXRlcy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBTdWJzY3JpcHRpb24ge1xuICAvKipcbiAgICogTmFtZSBvZiB0aGUgZXZlbnQgdG8gc3Vic2NyaWJlIHRvLlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xufVxuXG4vKipcbiAqIEFuIHtAbGluayBFdmVudFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgYXNzb2NpYXRlcyBhIHtAbGluayBoYW5kbGVyfVxuICogZnVuY3Rpb24gd2l0aCBhIGxpc3Qgb2Yge0BsaW5rIHN1YnNjcmlwdGlvbnN9LiBUaGUge0BsaW5rIHN1YnNjcmlwdGlvbnN9XG4gKiBkZWZpbmUgd2hpY2ggZXZlbnRzIHRoaXMge0BsaW5rIGhhbmRsZXJ9IHNob3VsZCBiZSBpbnZva2VkIGZvci5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudFN1YnNjcmlwdGlvbjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBBIGxpc3Qgb2Yge0BsaW5rIFN1YnNjcmlwdGlvbn1zIHRoYXQgc2hvdWxkIGludm9rZSB0aGlzIHtAbGluayBoYW5kbGVyfS5cbiAgICovXG4gIHN1YnNjcmlwdGlvbnM6IFN1YnNjcmlwdGlvbltdO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudEhhbmRsZXJ9IHRvIGludm9rZSBmb3IgYW55IGV2ZW50IHRoYXQgbWF0Y2hlcyBvbmUgb2ZcbiAgICogdGhlIHtAbGluayBzdWJzY3JpcHRpb25zfS5cbiAgICovXG4gIGhhbmRsZXI6IEV2ZW50SGFuZGxlcjxFPjtcbn1cblxuLyoqXG4gKiBBIEZ1bmN0aW9uIHRoYXQgcHJvY2Vzc2VzIGFuIHtAbGluayBldmVudH0gb2YgdHlwZSB7QGxpbmsgRX0uXG4gKi9cbmV4cG9ydCB0eXBlIEV2ZW50SGFuZGxlcjxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPiA9IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPjtcblxuLyoqXG4gKiBEZWNsYXJlcyBhbiBldmVudCB0aGF0IGNhbiBiZSBwdWJsaXNoZWQgYW5kIHN1YnNjcmliZWQgdG8uXG4gKlxuICogVG8gZGVjbGFyZSBhbiB7QGxpbmsgRXZlbnR9LCBkZWZpbmUgYW4gaW50ZXJmYWNlIGRlc2NyaWJpbmcgdGhlIHR5cGVcbiAqIG9mIHRoZSBwYXlsb2FkIGFuZCB0aGVuIGRlY2xhcmUgYW4gZXZlbnQgb2JqZWN0IGdpdmluZyBpdCBhIHVuaXF1ZSBuYW1lLlxuICogYGBgdHNcbiAqIGludGVyZmFjZSBDaGVja291dEV2ZW50IHtcbiAqICAgY3VzdG9tZXJJZDogc3RyaW5nO1xuICogICBjYXJ0SWQ6IHN0cmluZztcbiAqICAgdGltZXN0YW1wOiBzdHJpbmc7XG4gKiB9XG4gKlxuICogY29uc3QgY2hlY2tvdXRFdmVudCA9IGV2ZW50PENoZWNrb3V0RXZlbnQ+KFwiQ2hlY2tvdXRcIik7XG4gKiBgYGBcbiAqXG4gKiBUbyBwdWJsaXNoIGV2ZW50cywgY2FsbCB0aGUgYHB1Ymxpc2hgIG1ldGhvZDpcbiAqIGBgYHRzXG4gKiBjb25zdCBjaGVja291dFdvcmtmbG93ID0gd29ya2Zsb3coXCJjaGVja291dFdvcmtmbG93XCIsIGFzeW5jIChyZXF1ZXN0KSA9PiB7XG4gKiAgIGF3YWl0IGNoZWNrb3V0RXZlbnQucHVibGlzaCh7XG4gKiAgICAgY3VzdG9tZXJJZDogcmVxdWVzdC5jdXN0b21lcklkLFxuICogICAgIGNhcnRJZDogcmVxdWVzdC5jYXJ0SWQsXG4gKiAgICAgdGltZXN0YW1wOiBuZXcgRGF0ZSgpLnRvVGltZVN0cmluZygpXG4gKiAgIH0pO1xuICogfSlcbiAqIGBgYFxuICpcbiAqIFRvIHN1YnNjcmliZSB0byBldmVudHMsIGNhbGwgdGhlIGBvbmAgbWV0aG9kLiBUaGlzIHdpbGwgcmVnaXN0ZXIgYVxuICogaGFuZGxlciB0aGF0IHdpbCBsYmUgaW52b2tlZCBmb3IgZXZlcnkgZXZlbnQgb2YgdGhpcyB0eXBlIHRoYXQgaXMgcmVjZWl2ZWQuXG4gKlxuICogYGBgdHNcbiAqIGNoZWNrb3V0RXZlbnQub24oYXN5bmMgKGNoZWNrb3V0KSA9PiB7XG4gKiAgIGNvbnNvbGUubG9nKGNoZWNrb3V0KTtcbiAqIH0pO1xuICogYGBgXG4gKlxuICogQHBhcmFtIG5hbWUgYSB1bmlxdWUgbmFtZSB0aGF0IGlkZW50aWZpZXMgdGhpcyBldmVudCB0eXBlIHdpdGhpbiB0aGUgU2VydmljZS5cbiAqIEByZXR1cm5zIGFuIHtAbGluayBFdmVudH1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGV2ZW50PEUgZXh0ZW5kcyBFdmVudFBheWxvYWQ+KG5hbWU6IHN0cmluZyk6IEV2ZW50PEU+IHtcbiAgaWYgKGV2ZW50cygpLmhhcyhuYW1lKSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgZXZlbnQgd2l0aCBuYW1lICcke25hbWV9JyBhbHJlYWR5IGV4aXN0c2ApO1xuICB9XG4gIGNvbnN0IGV2ZW50OiBFdmVudDxFPiA9IHtcbiAgICBuYW1lLFxuICAgIG9uKGhhbmRsZXIpIHtcbiAgICAgIGV2ZW50U3Vic2NyaXB0aW9ucygpLnB1c2goe1xuICAgICAgICBzdWJzY3JpcHRpb25zOiBbXG4gICAgICAgICAge1xuICAgICAgICAgICAgbmFtZSxcbiAgICAgICAgICB9LFxuICAgICAgICBdLFxuICAgICAgICBoYW5kbGVyOiBoYW5kbGVyIGFzIEV2ZW50SGFuZGxlcjxFdmVudFBheWxvYWQ+LFxuICAgICAgfSk7XG4gICAgfSxcbiAgICBwdWJsaXNoKC4uLmV2ZW50cykge1xuICAgICAgY29uc3QgZW52ZWxvcGVzID0gZXZlbnRzLm1hcCgoZXZlbnQpID0+ICh7XG4gICAgICAgIG5hbWUsXG4gICAgICAgIGV2ZW50LFxuICAgICAgfSkpO1xuICAgICAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICAgICAgcmV0dXJuIGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsKGVudmVsb3BlcykgYXMgYW55O1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgcmV0dXJuIGdldFNlcnZpY2VDbGllbnQoKS5wdWJsaXNoRXZlbnRzKHsgZXZlbnRzOiBlbnZlbG9wZXMgfSk7XG4gICAgICB9XG4gICAgfSxcbiAgfTtcbiAgZXZlbnRzKCkuc2V0KG5hbWUsIGV2ZW50KTtcbiAgcmV0dXJuIGV2ZW50O1xufVxuIl19

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

import { SendSignalProps, Signal, SignalPayload, Workflow, WorkflowClient, WorkflowOutput } from "./index.js";
import { EventualServiceClient } from "./service-client.js";
import { Signal, SendSignalProps, SignalPayload } from "./signals.js";
import { Workflow, WorkflowOutput } from "./workflow.js";
export declare enum ExecutionStatus {

@@ -11,2 +13,3 @@ IN_PROGRESS = "IN_PROGRESS",

startTime: string;
workflowName: string;
parent?: {

@@ -43,6 +46,6 @@ /**

*/
export declare class ExecutionHandle<W extends Workflow<any, any>> {
export declare class ExecutionHandle<W extends Workflow> {
executionId: string;
private workflowClient;
constructor(executionId: string, workflowClient: WorkflowClient);
private serviceClient;
constructor(executionId: string, serviceClient: EventualServiceClient);
/**

@@ -49,0 +52,0 @@ * @return the {@link Execution} with the status, result, error, and other data based on the current status.

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

class ExecutionHandle {
constructor(executionId, workflowClient) {
constructor(executionId, serviceClient) {
this.executionId = executionId;
this.workflowClient = workflowClient;
this.serviceClient = serviceClient;
}

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

async getStatus() {
return (await this.workflowClient.getExecution(this.executionId));
return (await this.serviceClient.getExecution(this.executionId));
}

@@ -38,4 +38,4 @@ /**

async signal(signal, payload) {
return this.workflowClient.sendSignal({
executionId: this.executionId,
return this.serviceClient.sendSignal({
execution: this.executionId,
signal: typeof signal === "string" ? signal : signal.id,

@@ -47,2 +47,2 @@ payload,

exports.ExecutionHandle = ExecutionHandle;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFTQSxJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsOENBQTJCLENBQUE7SUFDM0Isd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLGVBQWUsR0FBZix1QkFBZSxLQUFmLHVCQUFlLFFBSTFCO0FBd0NELFNBQWdCLGlCQUFpQixDQUMvQixTQUFvQjtJQUVwQixPQUFPLFNBQVMsQ0FBQyxNQUFNLEtBQUssZUFBZSxDQUFDLE1BQU0sQ0FBQztBQUNyRCxDQUFDO0FBSkQsOENBSUM7QUFFRCxTQUFnQixtQkFBbUIsQ0FDakMsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUM7QUFDdkQsQ0FBQztBQUpELGtEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLGVBQWU7SUFDMUIsWUFDUyxXQUFtQixFQUNsQixjQUE4QjtRQUQvQixnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUNsQixtQkFBYyxHQUFkLGNBQWMsQ0FBZ0I7SUFDckMsQ0FBQztJQUVKOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLGNBQWMsQ0FBQyxZQUFZLENBQzVDLElBQUksQ0FBQyxXQUFXLENBQ2pCLENBQWlDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLE1BQU0sQ0FDakIsTUFBZ0MsRUFDaEMsT0FBZ0I7UUFFaEIsT0FBTyxJQUFJLENBQUMsY0FBYyxDQUFDLFVBQVUsQ0FBQztZQUNwQyxXQUFXLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDN0IsTUFBTSxFQUFFLE9BQU8sTUFBTSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN2RCxPQUFPO1NBQ1IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBNUJELDBDQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFNlbmRTaWduYWxQcm9wcyxcbiAgU2lnbmFsLFxuICBTaWduYWxQYXlsb2FkLFxuICBXb3JrZmxvdyxcbiAgV29ya2Zsb3dDbGllbnQsXG4gIFdvcmtmbG93T3V0cHV0LFxufSBmcm9tIFwiLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgZW51bSBFeGVjdXRpb25TdGF0dXMge1xuICBJTl9QUk9HUkVTUyA9IFwiSU5fUFJPR1JFU1NcIixcbiAgQ09NUExFVEUgPSBcIkNPTVBMRVRFXCIsXG4gIEZBSUxFRCA9IFwiRkFJTEVEXCIsXG59XG5cbmludGVyZmFjZSBFeGVjdXRpb25CYXNlIHtcbiAgaWQ6IHN0cmluZztcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXM7XG4gIHN0YXJ0VGltZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PGFueSwgYW55Pj4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZXhlY3V0aW9uSWQ6IHN0cmluZyxcbiAgICBwcml2YXRlIHdvcmtmbG93Q2xpZW50OiBXb3JrZmxvd0NsaWVudFxuICApIHt9XG5cbiAgLyoqXG4gICAqIEByZXR1cm4gdGhlIHtAbGluayBFeGVjdXRpb259IHdpdGggdGhlIHN0YXR1cywgcmVzdWx0LCBlcnJvciwgYW5kIG90aGVyIGRhdGEgYmFzZWQgb24gdGhlIGN1cnJlbnQgc3RhdHVzLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldFN0YXR1cygpOiBQcm9taXNlPEV4ZWN1dGlvbjxXb3JrZmxvd091dHB1dDxXPj4+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMud29ya2Zsb3dDbGllbnQuZ2V0RXhlY3V0aW9uKFxuICAgICAgdGhpcy5leGVjdXRpb25JZFxuICAgICkpIGFzIEV4ZWN1dGlvbjxXb3JrZmxvd091dHB1dDxXPj47XG4gIH1cblxuICAvKipcbiAgICogU2VuZCBhIHtAbGluayBzaWduYWx9IHRvIHRoaXMgZXhlY3V0aW9uLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIHNpZ25hbDxQYXlsb2FkID0gYW55PihcbiAgICBzaWduYWw6IHN0cmluZyB8IFNpZ25hbDxQYXlsb2FkPixcbiAgICBwYXlsb2FkOiBQYXlsb2FkXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLndvcmtmbG93Q2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uSWQ6IHRoaXMuZXhlY3V0aW9uSWQsXG4gICAgICBzaWduYWw6IHR5cGVvZiBzaWduYWwgPT09IFwic3RyaW5nXCIgPyBzaWduYWwgOiBzaWduYWwuaWQsXG4gICAgICBwYXlsb2FkLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQSByZWZlcmVuY2UgdG8gYW4gZXhlY3V0aW9uIHN0YXJ0ZWQgYnkgYW5vdGhlciB3b3JrZmxvdy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDaGlsZEV4ZWN1dGlvbiB7XG4gIC8qKlxuICAgKiBBbGxvd3MgYSB7QGxpbmsgd29ya2Zsb3d9IHRvIHNlbmQgYSBzaWduYWwgdG8gdGhlIHdvcmtmbG93IHtAbGluayBFeGVjdXRpb259LlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiBjb25zdCBteVNpZ25hbCA9IHNpZ25hbDxzdHJpbmc+KFwiTXlTaWduYWxcIik7XG4gICAqIGNvbnN0IGNoaWxkV2YgPSB3b3JrZmxvdyguLi4pO1xuICAgKiB3b3JrZmxvdyhcIndmXCIsIGFzeW5jICgpID0+IHtcbiAgICogICAgY29uc3QgY2hpbGQgPSBjaGlsZFdmKCk7XG4gICAqICAgIGNoaWxkLnNpZ25hbChteVNpZ25hbCk7XG4gICAqICAgIGF3YWl0IGNoaWxkO1xuICAgKiB9KVxuICAgKiBgYGBcbiAgICpcbiAgICogQHBhcmFtIGlkIGFuIG9wdGlvbmFsLCBleGVjdXRpb24gdW5pcXVlIElELCB3aWxsIGJlIHVzZWQgdG8gZGUtZHVwZSB0aGUgc2lnbmFsIGF0IHRoZSB0YXJnZXQgZXhlY3V0aW9uLlxuICAgKi9cbiAgc2lnbmFsPFMgZXh0ZW5kcyBTaWduYWw8YW55Pj4oXG4gICAgc2lnbmFsOiBTLFxuICAgIC4uLmFyZ3M6IFNlbmRTaWduYWxQcm9wczxTaWduYWxQYXlsb2FkPFM+PlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFJQSxJQUFZLGVBSVg7QUFKRCxXQUFZLGVBQWU7SUFDekIsOENBQTJCLENBQUE7SUFDM0Isd0NBQXFCLENBQUE7SUFDckIsb0NBQWlCLENBQUE7QUFDbkIsQ0FBQyxFQUpXLGVBQWUsR0FBZix1QkFBZSxLQUFmLHVCQUFlLFFBSTFCO0FBeUNELFNBQWdCLGlCQUFpQixDQUMvQixTQUFvQjtJQUVwQixPQUFPLFNBQVMsQ0FBQyxNQUFNLEtBQUssZUFBZSxDQUFDLE1BQU0sQ0FBQztBQUNyRCxDQUFDO0FBSkQsOENBSUM7QUFFRCxTQUFnQixtQkFBbUIsQ0FDakMsU0FBb0I7SUFFcEIsT0FBTyxTQUFTLENBQUMsTUFBTSxLQUFLLGVBQWUsQ0FBQyxRQUFRLENBQUM7QUFDdkQsQ0FBQztBQUpELGtEQUlDO0FBRUQ7O0dBRUc7QUFDSCxNQUFhLGVBQWU7SUFDMUIsWUFDUyxXQUFtQixFQUNsQixhQUFvQztRQURyQyxnQkFBVyxHQUFYLFdBQVcsQ0FBUTtRQUNsQixrQkFBYSxHQUFiLGFBQWEsQ0FBdUI7SUFDM0MsQ0FBQztJQUVKOztPQUVHO0lBQ0ksS0FBSyxDQUFDLFNBQVM7UUFDcEIsT0FBTyxDQUFDLE1BQU0sSUFBSSxDQUFDLGFBQWEsQ0FBQyxZQUFZLENBQzNDLElBQUksQ0FBQyxXQUFXLENBQ2pCLENBQWlDLENBQUM7SUFDckMsQ0FBQztJQUVEOztPQUVHO0lBQ0ksS0FBSyxDQUFDLE1BQU0sQ0FDakIsTUFBZ0MsRUFDaEMsT0FBZ0I7UUFFaEIsT0FBTyxJQUFJLENBQUMsYUFBYSxDQUFDLFVBQVUsQ0FBQztZQUNuQyxTQUFTLEVBQUUsSUFBSSxDQUFDLFdBQVc7WUFDM0IsTUFBTSxFQUFFLE9BQU8sTUFBTSxLQUFLLFFBQVEsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUN2RCxPQUFPO1NBQ1IsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztDQUNGO0FBNUJELDBDQTRCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTaWduYWwsIFNlbmRTaWduYWxQcm9wcywgU2lnbmFsUGF5bG9hZCB9IGZyb20gXCIuL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd091dHB1dCB9IGZyb20gXCIuL3dvcmtmbG93LmpzXCI7XG5cbmV4cG9ydCBlbnVtIEV4ZWN1dGlvblN0YXR1cyB7XG4gIElOX1BST0dSRVNTID0gXCJJTl9QUk9HUkVTU1wiLFxuICBDT01QTEVURSA9IFwiQ09NUExFVEVcIixcbiAgRkFJTEVEID0gXCJGQUlMRURcIixcbn1cblxuaW50ZXJmYWNlIEV4ZWN1dGlvbkJhc2Uge1xuICBpZDogc3RyaW5nO1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cztcbiAgc3RhcnRUaW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93TmFtZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50XG4gICkge31cblxuICAvKipcbiAgICogQHJldHVybiB0aGUge0BsaW5rIEV4ZWN1dGlvbn0gd2l0aCB0aGUgc3RhdHVzLCByZXN1bHQsIGVycm9yLCBhbmQgb3RoZXIgZGF0YSBiYXNlZCBvbiB0aGUgY3VycmVudCBzdGF0dXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U3RhdHVzKCk6IFByb21pc2U8RXhlY3V0aW9uPFdvcmtmbG93T3V0cHV0PFc+Pj4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5zZXJ2aWNlQ2xpZW50LmdldEV4ZWN1dGlvbihcbiAgICAgIHRoaXMuZXhlY3V0aW9uSWRcbiAgICApKSBhcyBFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+O1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSB7QGxpbmsgc2lnbmFsfSB0byB0aGlzIGV4ZWN1dGlvbi5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBzaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgcGF5bG9hZDogUGF5bG9hZFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5zZXJ2aWNlQ2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uOiB0aGlzLmV4ZWN1dGlvbklkLFxuICAgICAgc2lnbmFsOiB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkLFxuICAgICAgcGF5bG9hZCxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGFuIGV4ZWN1dGlvbiBzdGFydGVkIGJ5IGFub3RoZXIgd29ya2Zsb3cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2hpbGRFeGVjdXRpb24ge1xuICAvKipcbiAgICogQWxsb3dzIGEge0BsaW5rIHdvcmtmbG93fSB0byBzZW5kIGEgc2lnbmFsIHRvIHRoZSB3b3JrZmxvdyB7QGxpbmsgRXhlY3V0aW9ufS5cbiAgICpcbiAgICogYGBgdHNcbiAgICogY29uc3QgbXlTaWduYWwgPSBzaWduYWw8c3RyaW5nPihcIk15U2lnbmFsXCIpO1xuICAgKiBjb25zdCBjaGlsZFdmID0gd29ya2Zsb3coLi4uKTtcbiAgICogd29ya2Zsb3coXCJ3ZlwiLCBhc3luYyAoKSA9PiB7XG4gICAqICAgIGNvbnN0IGNoaWxkID0gY2hpbGRXZigpO1xuICAgKiAgICBjaGlsZC5zaWduYWwobXlTaWduYWwpO1xuICAgKiAgICBhd2FpdCBjaGlsZDtcbiAgICogfSlcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBpZCBhbiBvcHRpb25hbCwgZXhlY3V0aW9uIHVuaXF1ZSBJRCwgd2lsbCBiZSB1c2VkIHRvIGRlLWR1cGUgdGhlIHNpZ25hbCBhdCB0aGUgdGFyZ2V0IGV4ZWN1dGlvbi5cbiAgICovXG4gIHNpZ25hbDxTIGV4dGVuZHMgU2lnbmFsPGFueT4+KFxuICAgIHNpZ25hbDogUyxcbiAgICAuLi5hcmdzOiBTZW5kU2lnbmFsUHJvcHM8U2lnbmFsUGF5bG9hZDxTPj5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
import { Event, EventSubscription } from "./event.js";
import { ActivityContext, ActivityHandler } from "./activity.js";
import type { Eventual, EventualCallCollector } from "./eventual.js";
import { EventClient } from "./runtime/clients/event-client.js";
import type { WorkflowClient } from "./runtime/clients/workflow-client.js";
import type { Workflow } from "./workflow.js";
import { EventualServiceClient } from "./service-client.js";
declare global {

@@ -34,3 +33,3 @@ var _eventual: {

*/
workflowClient?: WorkflowClient;
serviceClient?: EventualServiceClient;
/**

@@ -46,8 +45,2 @@ * A global variable storing a map of event name (which is globally unique)

eventSubscriptions?: EventSubscription[];
/**
* A global variable for storing the {@link EventClient}
*
* This is initialized by Eventual's harness functions
*/
eventClient?: EventClient;
};

@@ -64,22 +57,13 @@ }

/**
* Register the global workflow client used by workflow functions
* Register the global service client used by workflow functions
* to start workflows within an eventual-controlled environment.
*/
export declare function registerWorkflowClient(client: WorkflowClient): void;
export declare function registerServiceClient(client: EventualServiceClient): void;
/**
* Get the global workflow client.
* Get the global service client.
*/
export declare function getWorkflowClient(): WorkflowClient;
export declare function getServiceClient(): EventualServiceClient;
export declare function setActivityContext(context: ActivityContext): void;
export declare function clearActivityContext(): void;
export declare function getActivityContext(): ActivityContext;
/**
* Register the global event client sued by the event emit functions
* to emit events within an eventual-controlled environment.
*/
export declare function registerEventClient(client: EventClient): void;
/**
* Get the global event client.
*/
export declare function getEventClient(): EventClient;
//# sourceMappingURL=global.d.ts.map
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.getEventClient = exports.registerEventClient = exports.getActivityContext = exports.clearActivityContext = exports.setActivityContext = exports.getWorkflowClient = exports.registerWorkflowClient = exports.clearEventualCollector = exports.setEventualCollector = exports.registerEventual = exports.callableActivities = exports.clearEventSubscriptions = exports.eventSubscriptions = exports.events = exports.workflows = void 0;
exports.getActivityContext = exports.clearActivityContext = exports.setActivityContext = exports.getServiceClient = exports.registerServiceClient = exports.clearEventualCollector = exports.setEventualCollector = exports.registerEventual = exports.callableActivities = exports.clearEventSubscriptions = exports.eventSubscriptions = exports.events = exports.workflows = void 0;
globalThis._eventual = {};

@@ -37,19 +37,19 @@ const workflows = () => (globalThis._eventual.workflows ??= new Map());

/**
* Register the global workflow client used by workflow functions
* Register the global service client used by workflow functions
* to start workflows within an eventual-controlled environment.
*/
function registerWorkflowClient(client) {
globalThis._eventual.workflowClient = client;
function registerServiceClient(client) {
globalThis._eventual.serviceClient = client;
}
exports.registerWorkflowClient = registerWorkflowClient;
exports.registerServiceClient = registerServiceClient;
/**
* Get the global workflow client.
* Get the global service client.
*/
function getWorkflowClient() {
if (globalThis._eventual.workflowClient === undefined) {
function getServiceClient() {
if (globalThis._eventual.serviceClient === undefined) {
throw new Error(`WorkflowClient is not registered`);
}
return globalThis._eventual.workflowClient;
return globalThis._eventual.serviceClient;
}
exports.getWorkflowClient = getWorkflowClient;
exports.getServiceClient = getServiceClient;
function setActivityContext(context) {

@@ -71,20 +71,2 @@ globalThis._eventual.activityContext = context;

exports.getActivityContext = getActivityContext;
/**
* Register the global event client sued by the event emit functions
* to emit events within an eventual-controlled environment.
*/
function registerEventClient(client) {
globalThis._eventual.eventClient = client;
}
exports.registerEventClient = registerEventClient;
/**
* Get the global event client.
*/
function getEventClient() {
if (globalThis._eventual.eventClient === undefined) {
throw new Error(`EventClient is not registered`);
}
return globalThis._eventual.eventClient;
}
exports.getEventClient = getEventClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":"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","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport function clearEventSubscriptions() {\n  globalThis._eventual.eventSubscriptions = [];\n}\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function clearActivityContext() {\n  globalThis._eventual.activityContext = undefined;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2xvYmFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2dsb2JhbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFnREEsVUFBVSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7QUFFbkIsTUFBTSxTQUFTLEdBQUcsR0FBMEIsRUFBRSxDQUNuRCxDQUFDLFVBQVUsQ0FBQyxTQUFTLENBQUMsU0FBUyxLQUFLLElBQUksR0FBRyxFQUFvQixDQUFDLENBQUM7QUFEdEQsUUFBQSxTQUFTLGFBQzZDO0FBRTVELE1BQU0sTUFBTSxHQUFHLEdBQXVCLEVBQUUsQ0FDN0MsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLE1BQU0sS0FBSyxJQUFJLEdBQUcsRUFBaUIsQ0FBQyxDQUFDO0FBRGhELFFBQUEsTUFBTSxVQUMwQztBQUV0RCxNQUFNLGtCQUFrQixHQUFHLEdBQXdCLEVBQUUsQ0FDMUQsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLGtCQUFrQixLQUFLLEVBQUUsQ0FBQyxDQUFDO0FBRHRDLFFBQUEsa0JBQWtCLHNCQUNvQjtBQUVuRCxTQUFnQix1QkFBdUI7SUFDckMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsR0FBRyxFQUFFLENBQUM7QUFDL0MsQ0FBQztBQUZELDBEQUVDO0FBRU0sTUFBTSxrQkFBa0IsR0FBRyxHQUF5QyxFQUFFLENBQzNFLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUR0QyxRQUFBLGtCQUFrQixzQkFDb0I7QUFFbkQsTUFBTSxpQkFBaUIsR0FBRyxHQUEwQixFQUFFO0lBQ3BELE1BQU0sU0FBUyxHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQUMsaUJBQWlCLENBQUM7SUFDekQsSUFBSSxDQUFDLFNBQVMsRUFBRTtRQUNkLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLENBQUMsQ0FBQztLQUNuRDtJQUNELE9BQU8sU0FBUyxDQUFDO0FBQ25CLENBQUMsQ0FBQztBQUVGLFNBQWdCLGdCQUFnQixDQUFxQixRQUFXO0lBQzlELE9BQU8saUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUZELDRDQUVDO0FBRUQsU0FBZ0Isb0JBQW9CLENBQUMsU0FBZ0M7SUFDbkUsVUFBVSxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUM7QUFDckQsQ0FBQztBQUZELG9EQUVDO0FBRUQsU0FBZ0Isc0JBQXNCO0lBQ3BDLFVBQVUsQ0FBQyxTQUFTLENBQUMsaUJBQWlCLEdBQUcsU0FBUyxDQUFDO0FBQ3JELENBQUM7QUFGRCx3REFFQztBQUVEOzs7R0FHRztBQUNILFNBQWdCLHFCQUFxQixDQUFDLE1BQTZCO0lBQ2pFLFVBQVUsQ0FBQyxTQUFTLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUM5QyxDQUFDO0FBRkQsc0RBRUM7QUFFRDs7R0FFRztBQUNILFNBQWdCLGdCQUFnQjtJQUM5QixJQUFJLFVBQVUsQ0FBQyxTQUFTLENBQUMsYUFBYSxLQUFLLFNBQVMsRUFBRTtRQUNwRCxNQUFNLElBQUksS0FBSyxDQUFDLGtDQUFrQyxDQUFDLENBQUM7S0FDckQ7SUFDRCxPQUFPLFVBQVUsQ0FBQyxTQUFTLENBQUMsYUFBYSxDQUFDO0FBQzVDLENBQUM7QUFMRCw0Q0FLQztBQUVELFNBQWdCLGtCQUFrQixDQUFDLE9BQXdCO0lBQ3pELFVBQVUsQ0FBQyxTQUFTLENBQUMsZUFBZSxHQUFHLE9BQU8sQ0FBQztBQUNqRCxDQUFDO0FBRkQsZ0RBRUM7QUFFRCxTQUFnQixvQkFBb0I7SUFDbEMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDO0FBQ25ELENBQUM7QUFGRCxvREFFQztBQUVELFNBQWdCLGtCQUFrQjtJQUNoQyxNQUFNLE9BQU8sR0FBRyxVQUFVLENBQUMsU0FBUyxDQUFDLGVBQWUsQ0FBQztJQUVyRCxJQUFJLENBQUMsT0FBTyxFQUFFO1FBQ1osTUFBTSxJQUFJLEtBQUssQ0FDYixrRkFBa0YsQ0FDbkYsQ0FBQztLQUNIO0lBQ0QsT0FBTyxPQUFPLENBQUM7QUFDakIsQ0FBQztBQVRELGdEQVNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnQsIEV2ZW50U3Vic2NyaXB0aW9uIH0gZnJvbSBcIi4vZXZlbnQuanNcIjtcbmltcG9ydCB7IEFjdGl2aXR5Q29udGV4dCwgQWN0aXZpdHlIYW5kbGVyIH0gZnJvbSBcIi4vYWN0aXZpdHkuanNcIjtcbmltcG9ydCB0eXBlIHsgRXZlbnR1YWwsIEV2ZW50dWFsQ2FsbENvbGxlY3RvciB9IGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFdvcmtmbG93IH0gZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcbmltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXZhclxuICB2YXIgX2V2ZW50dWFsOiB7XG4gICAgLyoqXG4gICAgICogRGF0YSBhYm91dCB0aGUgY3VycmVudCBhY3Rpdml0eSBhc3NpZ25lZCBiZWZvcmUgcnVubmluZyBhbiBhY3Rpdml0eSBvbiBhbiB0aGUgYWN0aXZpdHkgd29ya2VyLlxuICAgICAqL1xuICAgIGFjdGl2aXR5Q29udGV4dD86IEFjdGl2aXR5Q29udGV4dDtcbiAgICAvKipcbiAgICAgKiBBbiBvYmplY3QgdXNlZCBieSB0aGUgaW50ZXJwcmV0ZXIgdG8gY29sbGVjdCB7QGxpbmsgRXZlbnR1YWx9cyB3aGlsZSBydW5uaW5nIGEgd29ya2Zsb3cgY29kZS5cbiAgICAgKlxuICAgICAqIFNldCBieSB0aGUgaW50ZXJwcmV0ZXIgb25seSB3aGVuIG5lZWRlZC5cbiAgICAgKi9cbiAgICBldmVudHVhbENvbGxlY3Rvcj86IEV2ZW50dWFsQ2FsbENvbGxlY3RvcjtcbiAgICAvKipcbiAgICAgKiBDYWxsYWJsZSBhY3Rpdml0aWVzIHdoaWNoIHJlZ2lzdGVyIHRoZW1zZWx2ZXMgaW4gYW4gYWN0aXZpdHkgd29ya2VyLlxuICAgICAqL1xuICAgIGNhbGxhYmxlQWN0aXZpdGllcz86IFJlY29yZDxzdHJpbmcsIEFjdGl2aXR5SGFuZGxlcjxhbnk+PjtcbiAgICAvKipcbiAgICAgKiBBdmFpbGFibGUgd29ya2Zsb3dzIHdoaWNoIGhhdmUgcmVnaXN0ZXJlZCB0aGVtc2VsdmVzLlxuICAgICAqXG4gICAgICogVXNlZCBieSB0aGUgb3JjaGVzdHJhdG9yLCBhY3Rpdml0eSB3b3JrZXIsIGFuZCBvdGhlciBzY29wZXMgdG8gaW50ZXJhY3Qgd2l0aCB3b3JrZmxvd3MgaW5cbiAgICAgKiBhIHNlcnZpY2UuXG4gICAgICovXG4gICAgd29ya2Zsb3dzPzogTWFwPHN0cmluZywgV29ya2Zsb3c+O1xuICAgIC8qKlxuICAgICAqIEEgZ2xvYmFsIHZhcmlhYmxlIGZvciBzdG9yaW5nIHRoZSBXb3JrZmxvd0NsaWVudFxuICAgICAqIHRoaXMgaXMgaW5pdGlhbGl6ZWQgYnkgRXZlbnR1YWwncyBoYXJuZXNzIGxhbWJkYSBmdW5jdGlvbnNcbiAgICAgKi9cbiAgICBzZXJ2aWNlQ2xpZW50PzogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50O1xuICAgIC8qKlxuICAgICAqIEEgZ2xvYmFsIHZhcmlhYmxlIHN0b3JpbmcgYSBtYXAgb2YgZXZlbnQgbmFtZSAod2hpY2ggaXMgZ2xvYmFsbHkgdW5pcXVlKVxuICAgICAqIHRvIHRoZSB7QGxpbmsgRXZlbnR9IGRlY2xhcmF0aW9uIGluc3RhbmNlLlxuICAgICAqL1xuICAgIGV2ZW50cz86IE1hcDxzdHJpbmcsIEV2ZW50PjtcbiAgICAvKipcbiAgICAgKiBBIGdsb2JhbCB2YXJpYWJsZSBzdG9yaW5nIGEgbGlzdCBvZiBhbGwge0BsaW5rIEV2ZW50U3Vic2NyaXB0aW9ufXMgZGVjbGFyZWRcbiAgICAgKiB3aXRoaW4gdGhpcyBhcHBsaWNhdGlvbi5cbiAgICAgKi9cbiAgICBldmVudFN1YnNjcmlwdGlvbnM/OiBFdmVudFN1YnNjcmlwdGlvbltdO1xuICB9O1xufVxuXG5nbG9iYWxUaGlzLl9ldmVudHVhbCA9IHt9O1xuXG5leHBvcnQgY29uc3Qgd29ya2Zsb3dzID0gKCk6IE1hcDxzdHJpbmcsIFdvcmtmbG93PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwud29ya2Zsb3dzID8/PSBuZXcgTWFwPHN0cmluZywgV29ya2Zsb3c+KCkpO1xuXG5leHBvcnQgY29uc3QgZXZlbnRzID0gKCk6IE1hcDxzdHJpbmcsIEV2ZW50PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwuZXZlbnRzID8/PSBuZXcgTWFwPHN0cmluZywgRXZlbnQ+KCkpO1xuXG5leHBvcnQgY29uc3QgZXZlbnRTdWJzY3JpcHRpb25zID0gKCk6IEV2ZW50U3Vic2NyaXB0aW9uW10gPT5cbiAgKGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50U3Vic2NyaXB0aW9ucyA/Pz0gW10pO1xuXG5leHBvcnQgZnVuY3Rpb24gY2xlYXJFdmVudFN1YnNjcmlwdGlvbnMoKSB7XG4gIGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50U3Vic2NyaXB0aW9ucyA9IFtdO1xufVxuXG5leHBvcnQgY29uc3QgY2FsbGFibGVBY3Rpdml0aWVzID0gKCk6IFJlY29yZDxzdHJpbmcsIEFjdGl2aXR5SGFuZGxlcjxhbnk+PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwuY2FsbGFibGVBY3Rpdml0aWVzID8/PSB7fSk7XG5cbmNvbnN0IGV2ZW50dWFsQ29sbGVjdG9yID0gKCk6IEV2ZW50dWFsQ2FsbENvbGxlY3RvciA9PiB7XG4gIGNvbnN0IGNvbGxlY3RvciA9IGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50dWFsQ29sbGVjdG9yO1xuICBpZiAoIWNvbGxlY3Rvcikge1xuICAgIHRocm93IG5ldyBFcnJvcihcIk5vIEV2ZW50dWFsIENvbGxlY3RvciBQcm92aWRlZFwiKTtcbiAgfVxuICByZXR1cm4gY29sbGVjdG9yO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyRXZlbnR1YWw8QSBleHRlbmRzIEV2ZW50dWFsPihldmVudHVhbDogQSk6IEEge1xuICByZXR1cm4gZXZlbnR1YWxDb2xsZWN0b3IoKS5wdXNoRXZlbnR1YWwoZXZlbnR1YWwpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0RXZlbnR1YWxDb2xsZWN0b3IoY29sbGVjdG9yOiBFdmVudHVhbENhbGxDb2xsZWN0b3IpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuZXZlbnR1YWxDb2xsZWN0b3IgPSBjb2xsZWN0b3I7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjbGVhckV2ZW50dWFsQ29sbGVjdG9yKCkge1xuICBnbG9iYWxUaGlzLl9ldmVudHVhbC5ldmVudHVhbENvbGxlY3RvciA9IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBSZWdpc3RlciB0aGUgZ2xvYmFsIHNlcnZpY2UgY2xpZW50IHVzZWQgYnkgd29ya2Zsb3cgZnVuY3Rpb25zXG4gKiB0byBzdGFydCB3b3JrZmxvd3Mgd2l0aGluIGFuIGV2ZW50dWFsLWNvbnRyb2xsZWQgZW52aXJvbm1lbnQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlclNlcnZpY2VDbGllbnQoY2xpZW50OiBFdmVudHVhbFNlcnZpY2VDbGllbnQpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuc2VydmljZUNsaWVudCA9IGNsaWVudDtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGdsb2JhbCBzZXJ2aWNlIGNsaWVudC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFNlcnZpY2VDbGllbnQoKTogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IHtcbiAgaWYgKGdsb2JhbFRoaXMuX2V2ZW50dWFsLnNlcnZpY2VDbGllbnQgPT09IHVuZGVmaW5lZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihgV29ya2Zsb3dDbGllbnQgaXMgbm90IHJlZ2lzdGVyZWRgKTtcbiAgfVxuICByZXR1cm4gZ2xvYmFsVGhpcy5fZXZlbnR1YWwuc2VydmljZUNsaWVudDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNldEFjdGl2aXR5Q29udGV4dChjb250ZXh0OiBBY3Rpdml0eUNvbnRleHQpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuYWN0aXZpdHlDb250ZXh0ID0gY29udGV4dDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyQWN0aXZpdHlDb250ZXh0KCkge1xuICBnbG9iYWxUaGlzLl9ldmVudHVhbC5hY3Rpdml0eUNvbnRleHQgPSB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBY3Rpdml0eUNvbnRleHQoKTogQWN0aXZpdHlDb250ZXh0IHtcbiAgY29uc3QgY29udGV4dCA9IGdsb2JhbFRoaXMuX2V2ZW50dWFsLmFjdGl2aXR5Q29udGV4dDtcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkFjdGl2aXR5IENvbnRleHQgaGFzIG5vdCBiZWVuIHJlZ2lzdGVyZWQgeWV0IG9yIHRoaXMgaXMgbm90IHRoZSBhY3Rpdml0eSB3b3JrZXIuXCJcbiAgICApO1xuICB9XG4gIHJldHVybiBjb250ZXh0O1xufVxuIl19

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

import { HeartbeatResponse } from "./runtime/clients/workflow-client.js";
import { SendActivityHeartbeatResponse } from "./service-client.js";
/**

@@ -12,3 +12,3 @@ * Sends a heartbeat for the current activity or to the provided activity token.

*/
export declare function heartbeat(activityToken?: string): Promise<HeartbeatResponse>;
export declare function heartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
//# sourceMappingURL=heartbeat.d.ts.map

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

else if (activityToken) {
return await (0, global_js_1.getWorkflowClient)().heartbeatActivity({
return await (0, global_js_1.getServiceClient)().sendActivityHeartbeat({
activityToken,

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

const token = (0, global_js_1.getActivityContext)().activityToken;
return await (0, global_js_1.getWorkflowClient)().heartbeatActivity({
return await (0, global_js_1.getServiceClient)().sendActivityHeartbeat({
activityToken: token,

@@ -38,2 +38,2 @@ });

exports.heartbeat = heartbeat;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBb0U7QUFFcEUsaURBQTRFO0FBRTVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxJQUFBLDZCQUFpQixHQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYTtTQUNkLENBQUMsQ0FBQztLQUNKO1NBQU0sSUFBSSxJQUFBLDJCQUFnQixHQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsSUFBQSw4QkFBa0IsR0FBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0sSUFBQSw2QkFBaUIsR0FBRSxDQUFDLGlCQUFpQixDQUFDO1lBQ2pELGFBQWEsRUFBRSxLQUFLO1NBQ3JCLENBQUMsQ0FBQztLQUNKO1NBQU07UUFDTCxNQUFNLElBQUksS0FBSyxDQUNiLDhEQUE4RCxDQUMvRCxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBckJELDhCQXFCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0V29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IEhlYXJ0YmVhdFJlc3BvbnNlIH0gZnJvbSBcIi4vcnVudGltZS9jbGllbnRzL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBjb21wbGV0ZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBoZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFdvcmtmbG93Q2xpZW50KCkuaGVhcnRiZWF0QWN0aXZpdHkoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSwyQ0FBbUU7QUFDbkUsaURBQTRFO0FBRzVFOzs7Ozs7Ozs7R0FTRztBQUNJLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksSUFBQSwrQkFBb0IsR0FBRSxFQUFFO1FBQzFCLE1BQU0sSUFBSSxLQUFLLENBQ2Isa0dBQWtHLENBQ25HLENBQUM7S0FDSDtTQUFNLElBQUksYUFBYSxFQUFFO1FBQ3hCLE9BQU8sTUFBTSxJQUFBLDRCQUFnQixHQUFFLENBQUMscUJBQXFCLENBQUM7WUFDcEQsYUFBYTtTQUNkLENBQUMsQ0FBQztLQUNKO1NBQU0sSUFBSSxJQUFBLDJCQUFnQixHQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsSUFBQSw4QkFBa0IsR0FBRSxDQUFDLGFBQWEsQ0FBQztRQUNqRCxPQUFPLE1BQU0sSUFBQSw0QkFBZ0IsR0FBRSxDQUFDLHFCQUFxQixDQUFDO1lBQ3BELGFBQWEsRUFBRSxLQUFLO1NBQ3JCLENBQUMsQ0FBQztLQUNKO1NBQU07UUFDTCxNQUFNLElBQUksS0FBSyxDQUNiLDhEQUE4RCxDQUMvRCxDQUFDO0tBQ0g7QUFDSCxDQUFDO0FBckJELDhCQXFCQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGdldEFjdGl2aXR5Q29udGV4dCwgZ2V0U2VydmljZUNsaWVudCB9IGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgaXNBY3Rpdml0eVdvcmtlciwgaXNPcmNoZXN0cmF0b3JXb3JrZXIgfSBmcm9tIFwiLi9ydW50aW1lL2ZsYWdzLmpzXCI7XG5pbXBvcnQgeyBTZW5kQWN0aXZpdHlIZWFydGJlYXRSZXNwb25zZSB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbi8qKlxuICogU2VuZHMgYSBoZWFydGJlYXQgZm9yIHRoZSBjdXJyZW50IGFjdGl2aXR5IG9yIHRvIHRoZSBwcm92aWRlZCBhY3Rpdml0eSB0b2tlbi5cbiAqXG4gKiBJZiBjYWxsZWQgZnJvbSBvdXRzaWRlIG9mIGFuIHtAbGluayBhY3Rpdml0eX0sIHRoZSBhY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkLlxuICpcbiAqIElmIHRoZSBhY3Rpdml0eSBoYXMgYSBoZWFydGJlYXRUaW1lb3V0IHNldCBhbmQgdGhlIHdvcmtmbG93IGhhcyBub3QgcmVjZWl2ZWQgYSBoZWFydGJlYXQgaW4gaGVhcnRiZWF0VGltZW91dFNlY29uZHMsXG4gKiB0aGUgd29ya2Zsb3cgd2lsbCB0aHJvdyBhIHtAbGluayBIZWFydGJlYXRUaW1lb3V0fSBhbmQgY2FuY2VsIHRoZSBhY3Rpdml0eS5cbiAqXG4gKiBAcmV0dXJucyB7QGxpbmsgSGVhcnRiZWF0UmVzcG9uc2V9IHdoaWNoIGhhcyByZXNwb25zZS5jYW5jZWxsZWQgaWYgdGhlIGFjdGl2aXR5IHdhcyBjYW5jZWxsZWQgZm9yIGFueSByZWFzb24gKGV4OiB3b3JrZmxvdyBjb21wbGV0ZWQsIGZhaWxlZCwgb3IgdGhlIGFjdGl2aXR5IHRpbWVkIG91dCkuXG4gKi9cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBoZWFydGJlYXQoXG4gIGFjdGl2aXR5VG9rZW4/OiBzdHJpbmdcbik6IFByb21pc2U8U2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2U+IHtcbiAgaWYgKGlzT3JjaGVzdHJhdG9yV29ya2VyKCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkhlYXJ0YmVhdCBpcyBub3QgY3VycmVudGx5IHN1cHBvcnRlZCBmcm9tIHdpdGhpbiBhIHdvcmtmbG93LiBVc2UgYW4gYWN0aXZpdHkgd2l0aCBgaGVhcnRiZWF0KClgLlwiXG4gICAgKTtcbiAgfSBlbHNlIGlmIChhY3Rpdml0eVRva2VuKSB7XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbixcbiAgICB9KTtcbiAgfSBlbHNlIGlmIChpc0FjdGl2aXR5V29ya2VyKCkpIHtcbiAgICBjb25zdCB0b2tlbiA9IGdldEFjdGl2aXR5Q29udGV4dCgpLmFjdGl2aXR5VG9rZW47XG4gICAgcmV0dXJuIGF3YWl0IGdldFNlcnZpY2VDbGllbnQoKS5zZW5kQWN0aXZpdHlIZWFydGJlYXQoe1xuICAgICAgYWN0aXZpdHlUb2tlbjogdG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJBY3Rpdml0eSB0b2tlbiBtdXN0IGJlIHByb3ZpZGVkIHdoZW4gbm90IHdpdGhpbiBhbiBBY3Rpdml0eS5cIlxuICAgICk7XG4gIH1cbn1cbiJdfQ==

@@ -19,2 +19,3 @@ export * from "./activity.js";

export * from "./secret.js";
export * from "./service-client.js";
export * from "./service-type.js";

@@ -21,0 +22,0 @@ export * from "./signals.js";

@@ -35,2 +35,3 @@ "use strict";

__exportStar(require("./secret.js"), exports);
__exportStar(require("./service-client.js"), exports);
__exportStar(require("./service-type.js"), exports);

@@ -43,2 +44,2 @@ __exportStar(require("./signals.js"), exports);

__exportStar(require("./workflow.js"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUE4QjtBQUM5QiwyQ0FBeUI7QUFDekIsZ0RBQThCO0FBQzlCLGlEQUErQjtBQUMvQiw2Q0FBMkI7QUFDM0IsK0NBQTZCO0FBQzdCLGlEQUErQjtBQUMvQiwrQ0FBNkI7QUFDN0IsNkNBQTJCO0FBQzNCLDZDQUEyQjtBQUMzQixnREFBOEI7QUFDOUIsaURBQStCO0FBQy9CLDhDQUE0QjtBQUM1QixpREFBK0I7QUFDL0IsaURBQStCO0FBQy9CLDhDQUE0QjtBQUM1QixxREFBbUM7QUFDbkMsOENBQTRCO0FBQzVCLG9EQUFrQztBQUNsQywrQ0FBNkI7QUFDN0IsNkNBQTJCO0FBQzNCLDZDQUEyQjtBQUMzQiw0Q0FBMEI7QUFDMUIsdURBQXFDO0FBQ3JDLGdEQUE4QiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2FjdGl2aXR5LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hcGkuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2FwcC1zcGVjLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hd2FpdC1hbGwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NoYWluLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb21tYW5kLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb25kaXRpb24uanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbnRleHQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2Vycm9yLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ldmVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnR1YWwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V4ZWN1dGlvbi5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZ2xvYmFsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9oZWFydGJlYXQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2ludGVycHJldC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcmVzdWx0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW50aW1lL2luZGV4LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zZWNyZXQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3NlcnZpY2UtdHlwZS5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2lnbmFscy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2xlZXAuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Rhc2tzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi91dGlsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi93b3JrZmxvdy1ldmVudHMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LmpzXCI7XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUE4QjtBQUM5QiwyQ0FBeUI7QUFDekIsZ0RBQThCO0FBQzlCLGlEQUErQjtBQUMvQiw2Q0FBMkI7QUFDM0IsK0NBQTZCO0FBQzdCLGlEQUErQjtBQUMvQiwrQ0FBNkI7QUFDN0IsNkNBQTJCO0FBQzNCLDZDQUEyQjtBQUMzQixnREFBOEI7QUFDOUIsaURBQStCO0FBQy9CLDhDQUE0QjtBQUM1QixpREFBK0I7QUFDL0IsaURBQStCO0FBQy9CLDhDQUE0QjtBQUM1QixxREFBbUM7QUFDbkMsOENBQTRCO0FBQzVCLHNEQUFvQztBQUNwQyxvREFBa0M7QUFDbEMsK0NBQTZCO0FBQzdCLDZDQUEyQjtBQUMzQiw2Q0FBMkI7QUFDM0IsNENBQTBCO0FBQzFCLHVEQUFxQztBQUNyQyxnREFBOEIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hY3Rpdml0eS5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXBpLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hcHAtc3BlYy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXdhaXQtYWxsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jaGFpbi5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29tbWFuZC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uZGl0aW9uLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb250ZXh0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9lcnJvci5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9leGVjdXRpb24uanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vaGVhcnRiZWF0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcnByZXQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Jlc3VsdC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVudGltZS9pbmRleC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VjcmV0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VydmljZS10eXBlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zaWduYWxzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zbGVlcC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGFza3MuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcbiJdfQ==

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

import { ExecutionEventsRequest, ExecutionEventsResponse } from "../../service-client.js";
import { WorkflowEvent } from "../../workflow-events.js";

@@ -12,4 +13,4 @@ export type UnresolvedEvent<T extends WorkflowEvent> = Omit<T, "id" | "timestamp">;

*/
abstract getEvents(executionId: string): Promise<WorkflowEvent[]>;
abstract getEvents(request: ExecutionEventsRequest): Promise<ExecutionEventsResponse>;
}
//# sourceMappingURL=execution-history-client.d.ts.map

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

exports.ExecutionHistoryClient = ExecutionHistoryClient;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWhpc3RvcnktY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9leGVjdXRpb24taGlzdG9yeS1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBT0EsTUFBc0Isc0JBQXNCO0NBa0IzQztBQWxCRCx3REFrQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXb3JrZmxvd0V2ZW50IH0gZnJvbSBcIi4uLy4uL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuXG5leHBvcnQgdHlwZSBVbnJlc29sdmVkRXZlbnQ8VCBleHRlbmRzIFdvcmtmbG93RXZlbnQ+ID0gT21pdDxcbiAgVCxcbiAgXCJpZFwiIHwgXCJ0aW1lc3RhbXBcIlxuPjtcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQge1xuICBwdWJsaWMgYWJzdHJhY3QgcHV0RXZlbnQ8VCBleHRlbmRzIFdvcmtmbG93RXZlbnQ+KFxuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gICAgZXZlbnQ6IFRcbiAgKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogV3JpdGVzIGV2ZW50cyBhcyBhIGJhdGNoIGludG8gdGhlIGV4ZWN1dGlvbiBoaXN0b3J5IHRhYmxlLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHB1dEV2ZW50cyhcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGV2ZW50czogV29ya2Zsb3dFdmVudFtdXG4gICk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFJlYWQgYW4gZXhlY3V0aW9uJ3MgZXZlbnRzIGZyb20gdGhlIGV4ZWN1dGlvbiBoaXN0b3J5IHRhYmxlIHRhYmxlXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0RXZlbnRzKGV4ZWN1dGlvbklkOiBzdHJpbmcpOiBQcm9taXNlPFdvcmtmbG93RXZlbnRbXT47XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWhpc3RvcnktY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9leGVjdXRpb24taGlzdG9yeS1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBV0EsTUFBc0Isc0JBQXNCO0NBb0IzQztBQXBCRCx3REFvQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICBFeGVjdXRpb25FdmVudHNSZXF1ZXN0LFxuICBFeGVjdXRpb25FdmVudHNSZXNwb25zZSxcbn0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBXb3JrZmxvd0V2ZW50IH0gZnJvbSBcIi4uLy4uL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuXG5leHBvcnQgdHlwZSBVbnJlc29sdmVkRXZlbnQ8VCBleHRlbmRzIFdvcmtmbG93RXZlbnQ+ID0gT21pdDxcbiAgVCxcbiAgXCJpZFwiIHwgXCJ0aW1lc3RhbXBcIlxuPjtcblxuZXhwb3J0IGFic3RyYWN0IGNsYXNzIEV4ZWN1dGlvbkhpc3RvcnlDbGllbnQge1xuICBwdWJsaWMgYWJzdHJhY3QgcHV0RXZlbnQ8VCBleHRlbmRzIFdvcmtmbG93RXZlbnQ+KFxuICAgIGV4ZWN1dGlvbklkOiBzdHJpbmcsXG4gICAgZXZlbnQ6IFRcbiAgKTogUHJvbWlzZTx2b2lkPjtcblxuICAvKipcbiAgICogV3JpdGVzIGV2ZW50cyBhcyBhIGJhdGNoIGludG8gdGhlIGV4ZWN1dGlvbiBoaXN0b3J5IHRhYmxlLlxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IHB1dEV2ZW50cyhcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGV2ZW50czogV29ya2Zsb3dFdmVudFtdXG4gICk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFJlYWQgYW4gZXhlY3V0aW9uJ3MgZXZlbnRzIGZyb20gdGhlIGV4ZWN1dGlvbiBoaXN0b3J5IHRhYmxlIHRhYmxlXG4gICAqL1xuICBwdWJsaWMgYWJzdHJhY3QgZ2V0RXZlbnRzKFxuICAgIHJlcXVlc3Q6IEV4ZWN1dGlvbkV2ZW50c1JlcXVlc3RcbiAgKTogUHJvbWlzZTxFeGVjdXRpb25FdmVudHNSZXNwb25zZT47XG59XG4iXX0=

@@ -8,2 +8,3 @@ export * from "./activity-runtime-client.js";

export * from "./workflow-runtime-client.js";
export * from "./runtime-service-clients.js";
//# sourceMappingURL=index.d.ts.map

@@ -24,2 +24,3 @@ "use strict";

__exportStar(require("./workflow-runtime-client.js"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrREFBNkM7QUFDN0Msb0RBQWtDO0FBQ2xDLGdFQUE4QztBQUM5QyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBQ2xDLHVEQUFxQztBQUNyQywrREFBNkMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hY3Rpdml0eS1ydW50aW1lLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnQtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9leGVjdXRpb24taGlzdG9yeS1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21ldHJpY3MtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90aW1lci1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3ctcnVudGltZS1jbGllbnQuanNcIjtcbiJdfQ==
__exportStar(require("./runtime-service-clients.js"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7QUFBQSwrREFBNkM7QUFDN0Msb0RBQWtDO0FBQ2xDLGdFQUE4QztBQUM5QyxzREFBb0M7QUFDcEMsb0RBQWtDO0FBQ2xDLHVEQUFxQztBQUNyQywrREFBNkM7QUFDN0MsK0RBQTZDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYWN0aXZpdHktcnVudGltZS1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50LWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXhlY3V0aW9uLWhpc3RvcnktY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9tZXRyaWNzLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGltZXItY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi93b3JrZmxvdy1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LXJ1bnRpbWUtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ydW50aW1lLXNlcnZpY2UtY2xpZW50cy5qc1wiO1xuIl19
import { HistoryStateEvent } from "../../workflow-events.js";
import { Execution, ExecutionStatus } from "../../execution.js";
import { Execution, ExecutionHandle } from "../../execution.js";
import { Signal } from "../../signals.js";
import { Workflow, WorkflowInput, WorkflowOptions } from "../../workflow.js";
import { Workflow, WorkflowOptions } from "../../workflow.js";
import { ActivityRuntimeClient } from "./activity-runtime-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse } from "../../service-client.js";
export declare abstract class WorkflowClient {

@@ -24,6 +25,3 @@ private activityRuntimeClient;

abstract submitWorkflowTask(executionId: string, ...events: HistoryStateEvent[]): Promise<void>;
abstract getExecutions(props: {
statuses?: ExecutionStatus[];
workflowName?: string;
}): Promise<Execution[]>;
abstract getExecutions(props: GetExecutionsRequest): Promise<GetExecutionsResponse>;
abstract getExecution(executionId: string): Promise<Execution | undefined>;

@@ -40,7 +38,7 @@ /**

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

@@ -51,9 +49,9 @@ * Submits a "heartbeat" for the given activityToken.

*/
heartbeatActivity(request: HeartbeatRequest): Promise<HeartbeatResponse>;
heartbeatActivity(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
private sendActivityResult;
}
export interface SendSignalRequest {
executionId: string;
signal: string | Signal;
payload?: any;
export interface SendSignalRequest<Payload = any> {
execution: ExecutionHandle<any> | string;
signal: string | Signal<Payload>;
payload?: Payload;
/**

@@ -64,23 +62,3 @@ * Execution scoped unique event id. Duplicates will be deduplicated.

}
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends WorkflowOptions {
/**
* Name of the workflow execution.
*
* Only one workflow can exist for an ID. Requests to start a workflow
* with the name of an existing workflow will fail.
*
* @default - a unique name is generated.
*/
executionName?: string;
/**
* Name of the workflow to execute.
*/
workflowName: string;
/**
* Input payload for the workflow function.
*/
input?: WorkflowInput<W>;
/**
* ID of the parent execution if this is a child workflow
*/
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId?: string;

@@ -98,22 +76,2 @@ /**

}
export interface CompleteActivityRequest<T = any> {
activityToken: string;
result: T;
}
export interface FailActivityRequest {
activityToken: string;
error: string;
message?: string;
}
export interface HeartbeatRequest {
activityToken: string;
}
export interface HeartbeatResponse {
/**
* True when the activity has been cancelled.
*
* This is the only way for a long running activity to know it was canelled.
*/
cancelled: boolean;
}
//# sourceMappingURL=workflow-client.d.ts.map

@@ -19,3 +19,6 @@ "use strict";

async sendSignal(request) {
await this.submitWorkflowTask(request.executionId, (0, workflow_events_js_1.createEvent)({
const executionId = typeof request.execution === "string"
? request.execution
: request.execution.executionId;
await this.submitWorkflowTask(executionId, (0, workflow_events_js_1.createEvent)({
type: workflow_events_js_1.WorkflowEventType.SignalReceived,

@@ -69,2 +72,2 @@ payload: request.payload,

exports.WorkflowClient = WorkflowClient;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":";;;AAAA,iEAOkC;AAClC,qDAAgE;AAGhE,4DAA2D;AAG3D,MAAsB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IAgCJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,IAAA,gCAAW,EACT;YACE,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,sCAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EACb,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,sCAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,IAAA,uCAAmB,EAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,8BAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,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;AA9HD,wCA8HC","sourcesContent":["import {\n  ActivityCompleted,\n  ActivityFailed,\n  createEvent,\n  HistoryStateEvent,\n  SignalReceived,\n  WorkflowEventType,\n} from \"../../workflow-events.js\";\nimport { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\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(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        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  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      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 {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id?: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":";;;AAAA,iEAOkC;AAClC,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"]}

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

await this.props.workflowClient.startWorkflow({
workflowName: command.name,
workflow: command.name,
input: command.input,

@@ -133,3 +133,3 @@ parentExecutionId: executionId,

signal: command.signalId,
executionId: childExecutionId,
execution: childExecutionId,
id: `${executionId}/${command.seq}`,

@@ -172,2 +172,2 @@ payload: command.payload,

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      workflowName: command.name,\n      input: command.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, command.seq),\n      seq: command.seq,\n      ...command.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\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      executionId: 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.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"]}

@@ -5,3 +5,3 @@ import { ScheduleActivityCommand } from "../../command.js";

import { WorkflowClient } from "../clients/workflow-client.js";
import { TimerClient } from "../index.js";
import { RuntimeServiceClient, TimerClient } from "../index.js";
import { Logger } from "../logger.js";

@@ -18,2 +18,3 @@ import type { EventClient } from "../index.js";

activityProvider: ActivityProvider;
serviceClient?: RuntimeServiceClient;
}

@@ -40,3 +41,3 @@ export interface ActivityWorkerRequest {

*/
export declare function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, eventClient, activityProvider, }: CreateActivityWorkerProps): ActivityWorker;
export declare function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, activityProvider, serviceClient, }: CreateActivityWorkerProps): ActivityWorker;
//# sourceMappingURL=activity-worker.d.ts.map

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

*/
function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, eventClient, activityProvider, }) {
// make the workflow client available to all activity code
(0, global_js_1.registerWorkflowClient)(workflowClient);
// make the event client available to all activity code
(0, global_js_1.registerEventClient)(eventClient);
function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, activityProvider, serviceClient, }) {
// make the service client available to all activity code
if (serviceClient) {
(0, global_js_1.registerServiceClient)(serviceClient);
}
return metricsClient.metricScope((metrics) => async (request, baseTime, getEndTime = () => new Date()) => {

@@ -130,2 +130,2 @@ logger.addPersistentLogAttributes({

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  registerEventClient,\n  registerWorkflowClient,\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 { Schedule, TimerClient, TimerRequestType } 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}\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  eventClient,\n  activityProvider,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the workflow client available to all activity code\n  registerWorkflowClient(workflowClient);\n  // make the event client available to all activity code\n  registerEventClient(eventClient);\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  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"]}

@@ -1,6 +0,4 @@

import type { WorkflowClient } from "../clients/workflow-client.js";
import type { EventClient } from "../index.js";
import { EventualServiceClient } from "../../service-client.js";
export interface ApiHandlerDependencies {
workflowClient: WorkflowClient;
eventClient: EventClient;
serviceClient: EventualServiceClient;
}

@@ -13,3 +11,3 @@ /**

*/
export declare function createApiHandler({ workflowClient, eventClient, }: ApiHandlerDependencies): (request: Request) => Promise<Response>;
export declare function createApiHandler({ serviceClient }: ApiHandlerDependencies): (request: Request) => Promise<Response>;
//# sourceMappingURL=api-handler.d.ts.map

@@ -12,6 +12,5 @@ "use strict";

*/
function createApiHandler({ workflowClient, eventClient, }) {
// make the workflow client available to web hooks
(0, global_js_1.registerWorkflowClient)(workflowClient);
(0, global_js_1.registerEventClient)(eventClient);
function createApiHandler({ serviceClient }) {
// make the service client available to web hooks
(0, global_js_1.registerServiceClient)(serviceClient);
api_js_1.api.all("*", () => new Response("Not Found.", { status: 404 }));

@@ -37,2 +36,2 @@ /**

exports.createApiHandler = createApiHandler;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9oYW5kbGVycy9hcGktaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5Q0FBbUM7QUFDbkMsK0NBQThFO0FBUzlFOzs7OztHQUtHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsRUFDL0IsY0FBYyxFQUNkLFdBQVcsR0FDWTtJQUN2QixrREFBa0Q7SUFDbEQsSUFBQSxrQ0FBc0IsRUFBQyxjQUFjLENBQUMsQ0FBQztJQUN2QyxJQUFBLCtCQUFtQixFQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRWpDLFlBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksUUFBUSxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFFaEU7Ozs7O09BS0c7SUFDSCxPQUFPLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBZ0I7UUFDbkQsSUFBSTtZQUNGLE9BQU8sWUFBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM1QjtRQUFDLE9BQU8sR0FBRyxFQUFFO1lBQ1osT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixPQUFPLElBQUksUUFBUSxDQUFDLHVCQUF1QixFQUFFO2dCQUMzQyxNQUFNLEVBQUUsR0FBRzthQUNaLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQTFCRCw0Q0EwQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhcGkgfSBmcm9tIFwiLi4vLi4vYXBpLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlckV2ZW50Q2xpZW50LCByZWdpc3RlcldvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4uLy4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBXb3JrZmxvd0NsaWVudCB9IGZyb20gXCIuLi9jbGllbnRzL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuaW1wb3J0IHR5cGUgeyBFdmVudENsaWVudCB9IGZyb20gXCIuLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgaW50ZXJmYWNlIEFwaUhhbmRsZXJEZXBlbmRlbmNpZXMge1xuICB3b3JrZmxvd0NsaWVudDogV29ya2Zsb3dDbGllbnQ7XG4gIGV2ZW50Q2xpZW50OiBFdmVudENsaWVudDtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgZ2VuZXJpYyBmdW5jdGlvbiBmb3IgaGFuZGxpbmcgaW5ib3VuZCBBUEkgcmVxdWVzdHNcbiAqIHRoYXQgY2FuIGJlIHVzZWQgaW4gcnVudGltZSBpbXBsZW1lbnRhdGlvbnMuIFRoaXMgaW1wbGVtZW50YXRpb24gaXNcbiAqIGRlY291cGxlZCBmcm9tIGEgcnVudGltZSdzIHNwZWNpZmljcyBieSB0aGUgY2xpZW50cy4gQSBydW50aW1lIG11c3RcbiAqIGluamVjdCBpdHMgb3duIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZGVzaWduZWQgZm9yIHRoYXQgcGxhdGZvcm0uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBcGlIYW5kbGVyKHtcbiAgd29ya2Zsb3dDbGllbnQsXG4gIGV2ZW50Q2xpZW50LFxufTogQXBpSGFuZGxlckRlcGVuZGVuY2llcykge1xuICAvLyBtYWtlIHRoZSB3b3JrZmxvdyBjbGllbnQgYXZhaWxhYmxlIHRvIHdlYiBob29rc1xuICByZWdpc3RlcldvcmtmbG93Q2xpZW50KHdvcmtmbG93Q2xpZW50KTtcbiAgcmVnaXN0ZXJFdmVudENsaWVudChldmVudENsaWVudCk7XG5cbiAgYXBpLmFsbChcIipcIiwgKCkgPT4gbmV3IFJlc3BvbnNlKFwiTm90IEZvdW5kLlwiLCB7IHN0YXR1czogNDA0IH0pKTtcblxuICAvKipcbiAgICogSGFuZGxlIGluYm91bmQgd2ViaG9vayBBUEkgcmVxdWVzdHMuXG4gICAqXG4gICAqIEVhY2ggd2ViaG9vayByZWdpc3RlcnMgcm91dGVzIG9uIHRoZSBjZW50cmFsIHtAbGluayByb3V0ZXJ9IHdoaWNoXG4gICAqIHRoZW4gaGFuZGxlcyB0aGUgcmVxdWVzdC5cbiAgICovXG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiBwcm9jZXNzUmVxdWVzdChyZXF1ZXN0OiBSZXF1ZXN0KTogUHJvbWlzZTxSZXNwb25zZT4ge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4gYXBpLmhhbmRsZShyZXF1ZXN0KTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoZXJyKTtcbiAgICAgIHJldHVybiBuZXcgUmVzcG9uc2UoXCJJbnRlcm5hbCBTZXJ2ZXIgRXJyb3JcIiwge1xuICAgICAgICBzdGF0dXM6IDUwMCxcbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9oYW5kbGVycy9hcGktaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQSx5Q0FBbUM7QUFDbkMsK0NBQXdEO0FBT3hEOzs7OztHQUtHO0FBQ0gsU0FBZ0IsZ0JBQWdCLENBQUMsRUFBRSxhQUFhLEVBQTBCO0lBQ3hFLGlEQUFpRDtJQUNqRCxJQUFBLGlDQUFxQixFQUFDLGFBQWEsQ0FBQyxDQUFDO0lBRXJDLFlBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksUUFBUSxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFFaEU7Ozs7O09BS0c7SUFDSCxPQUFPLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBZ0I7UUFDbkQsSUFBSTtZQUNGLE9BQU8sWUFBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM1QjtRQUFDLE9BQU8sR0FBRyxFQUFFO1lBQ1osT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixPQUFPLElBQUksUUFBUSxDQUFDLHVCQUF1QixFQUFFO2dCQUMzQyxNQUFNLEVBQUUsR0FBRzthQUNaLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQXRCRCw0Q0FzQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBhcGkgfSBmcm9tIFwiLi4vLi4vYXBpLmpzXCI7XG5pbXBvcnQgeyByZWdpc3RlclNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBFdmVudHVhbFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vc2VydmljZS1jbGllbnQuanNcIjtcblxuZXhwb3J0IGludGVyZmFjZSBBcGlIYW5kbGVyRGVwZW5kZW5jaWVzIHtcbiAgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBnZW5lcmljIGZ1bmN0aW9uIGZvciBoYW5kbGluZyBpbmJvdW5kIEFQSSByZXF1ZXN0c1xuICogdGhhdCBjYW4gYmUgdXNlZCBpbiBydW50aW1lIGltcGxlbWVudGF0aW9ucy4gVGhpcyBpbXBsZW1lbnRhdGlvbiBpc1xuICogZGVjb3VwbGVkIGZyb20gYSBydW50aW1lJ3Mgc3BlY2lmaWNzIGJ5IHRoZSBjbGllbnRzLiBBIHJ1bnRpbWUgbXVzdFxuICogaW5qZWN0IGl0cyBvd24gY2xpZW50IGltcGxlbWVudGF0aW9ucyBkZXNpZ25lZCBmb3IgdGhhdCBwbGF0Zm9ybS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFwaUhhbmRsZXIoeyBzZXJ2aWNlQ2xpZW50IH06IEFwaUhhbmRsZXJEZXBlbmRlbmNpZXMpIHtcbiAgLy8gbWFrZSB0aGUgc2VydmljZSBjbGllbnQgYXZhaWxhYmxlIHRvIHdlYiBob29rc1xuICByZWdpc3RlclNlcnZpY2VDbGllbnQoc2VydmljZUNsaWVudCk7XG5cbiAgYXBpLmFsbChcIipcIiwgKCkgPT4gbmV3IFJlc3BvbnNlKFwiTm90IEZvdW5kLlwiLCB7IHN0YXR1czogNDA0IH0pKTtcblxuICAvKipcbiAgICogSGFuZGxlIGluYm91bmQgd2ViaG9vayBBUEkgcmVxdWVzdHMuXG4gICAqXG4gICAqIEVhY2ggd2ViaG9vayByZWdpc3RlcnMgcm91dGVzIG9uIHRoZSBjZW50cmFsIHtAbGluayByb3V0ZXJ9IHdoaWNoXG4gICAqIHRoZW4gaGFuZGxlcyB0aGUgcmVxdWVzdC5cbiAgICovXG4gIHJldHVybiBhc3luYyBmdW5jdGlvbiBwcm9jZXNzUmVxdWVzdChyZXF1ZXN0OiBSZXF1ZXN0KTogUHJvbWlzZTxSZXNwb25zZT4ge1xuICAgIHRyeSB7XG4gICAgICByZXR1cm4gYXBpLmhhbmRsZShyZXF1ZXN0KTtcbiAgICB9IGNhdGNoIChlcnIpIHtcbiAgICAgIGNvbnNvbGUuZXJyb3IoZXJyKTtcbiAgICAgIHJldHVybiBuZXcgUmVzcG9uc2UoXCJJbnRlcm5hbCBTZXJ2ZXIgRXJyb3JcIiwge1xuICAgICAgICBzdGF0dXM6IDUwMCxcbiAgICAgIH0pO1xuICAgIH1cbiAgfTtcbn1cbiJdfQ==

@@ -1,5 +0,4 @@

import type { WorkflowClient } from "../clients/workflow-client.js";
import type { EventClient } from "../clients/event-client.js";
import type { EventEnvelope } from "../../event.js";
import { EventHandlerProvider } from "../providers/event-handler-provider.js";
import { EventualServiceClient } from "../../service-client.js";
/**

@@ -10,11 +9,7 @@ * The dependencies of {@link createEventHandlerWorker}.

/**
* The {@link WorkflowClient} for interacting with workflows contained
* The {@link EventualServiceClient} for interacting with workflows contained
* within the service boundary.
*/
workflowClient?: WorkflowClient;
serviceClient?: EventualServiceClient;
/**
* The {@link EventClient} for publishing events to the service's event bus.
*/
eventClient?: EventClient;
/**
* Returns event handlers

@@ -33,3 +28,3 @@ */

*/
export declare function createEventHandlerWorker({ workflowClient, eventClient, eventHandlerProvider, }: EventHandlerDependencies): EventHandlerWorker;
export declare function createEventHandlerWorker({ serviceClient, eventHandlerProvider, }: EventHandlerDependencies): EventHandlerWorker;
//# sourceMappingURL=event-handler.d.ts.map

@@ -11,10 +11,7 @@ "use strict";

*/
function createEventHandlerWorker({ workflowClient, eventClient, eventHandlerProvider, }) {
function createEventHandlerWorker({ serviceClient, eventHandlerProvider, }) {
// make the workflow client available to web hooks
if (workflowClient) {
(0, global_js_1.registerWorkflowClient)(workflowClient);
if (serviceClient) {
(0, global_js_1.registerServiceClient)(serviceClient);
}
if (eventClient) {
(0, global_js_1.registerEventClient)(eventClient);
}
return async function (events) {

@@ -27,2 +24,2 @@ await Promise.allSettled(events.map((event) => Promise.allSettled(eventHandlerProvider

exports.createEventHandlerWorker = createEventHandlerWorker;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ydW50aW1lL2hhbmRsZXJzL2V2ZW50LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQThFO0FBNkI5RTs7Ozs7R0FLRztBQUNILFNBQWdCLHdCQUF3QixDQUFDLEVBQ3ZDLGNBQWMsRUFDZCxXQUFXLEVBQ1gsb0JBQW9CLEdBQ0s7SUFDekIsa0RBQWtEO0lBQ2xELElBQUksY0FBYyxFQUFFO1FBQ2xCLElBQUEsa0NBQXNCLEVBQUMsY0FBYyxDQUFDLENBQUM7S0FDeEM7SUFDRCxJQUFJLFdBQVcsRUFBRTtRQUNmLElBQUEsK0JBQW1CLEVBQUMsV0FBVyxDQUFDLENBQUM7S0FDbEM7SUFFRCxPQUFPLEtBQUssV0FBVyxNQUFNO1FBQzNCLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FDdEIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQ25CLE9BQU8sQ0FBQyxVQUFVLENBQ2hCLG9CQUFvQjthQUNqQix3QkFBd0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO2FBQ3BDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUMxQyxDQUNGLENBQ0YsQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUM7QUF4QkQsNERBd0JDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcmVnaXN0ZXJXb3JrZmxvd0NsaWVudCwgcmVnaXN0ZXJFdmVudENsaWVudCB9IGZyb20gXCIuLi8uLi9nbG9iYWwuanNcIjtcbmltcG9ydCB0eXBlIHsgV29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi4vY2xpZW50cy93b3JrZmxvdy1jbGllbnQuanNcIjtcbmltcG9ydCB0eXBlIHsgRXZlbnRDbGllbnQgfSBmcm9tIFwiLi4vY2xpZW50cy9ldmVudC1jbGllbnQuanNcIjtcbmltcG9ydCB0eXBlIHsgRXZlbnRFbnZlbG9wZSB9IGZyb20gXCIuLi8uLi9ldmVudC5qc1wiO1xuaW1wb3J0IHsgRXZlbnRIYW5kbGVyUHJvdmlkZXIgfSBmcm9tIFwiLi4vcHJvdmlkZXJzL2V2ZW50LWhhbmRsZXItcHJvdmlkZXIuanNcIjtcblxuLyoqXG4gKiBUaGUgZGVwZW5kZW5jaWVzIG9mIHtAbGluayBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXJ9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyB7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIFdvcmtmbG93Q2xpZW50fSBmb3IgaW50ZXJhY3Rpbmcgd2l0aCB3b3JrZmxvd3MgY29udGFpbmVkXG4gICAqIHdpdGhpbiB0aGUgc2VydmljZSBib3VuZGFyeS5cbiAgICovXG4gIHdvcmtmbG93Q2xpZW50PzogV29ya2Zsb3dDbGllbnQ7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50Q2xpZW50fSBmb3IgcHVibGlzaGluZyBldmVudHMgdG8gdGhlIHNlcnZpY2UncyBldmVudCBidXMuXG4gICAqL1xuICBldmVudENsaWVudD86IEV2ZW50Q2xpZW50O1xuICAvKipcbiAgICogUmV0dXJucyBldmVudCBoYW5kbGVyc1xuICAgKi9cbiAgZXZlbnRIYW5kbGVyUHJvdmlkZXI6IEV2ZW50SGFuZGxlclByb3ZpZGVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIChldmVudHM6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGdlbmVyaWMgZnVuY3Rpb24gZm9yIGhhbmRsaW5nIGluYm91bmQgZXZlbnQgcmVxdWVzdHNcbiAqIHRoYXQgY2FuIGJlIHVzZWQgaW4gcnVudGltZSBpbXBsZW1lbnRhdGlvbnMuIFRoaXMgaW1wbGVtZW50YXRpb24gaXNcbiAqIGRlY291cGxlZCBmcm9tIGEgcnVudGltZSdzIHNwZWNpZmljcyBieSB0aGUgY2xpZW50cy4gQSBydW50aW1lIG11c3RcbiAqIGluamVjdCBpdHMgb3duIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZGVzaWduZWQgZm9yIHRoYXQgcGxhdGZvcm0uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXIoe1xuICB3b3JrZmxvd0NsaWVudCxcbiAgZXZlbnRDbGllbnQsXG4gIGV2ZW50SGFuZGxlclByb3ZpZGVyLFxufTogRXZlbnRIYW5kbGVyRGVwZW5kZW5jaWVzKTogRXZlbnRIYW5kbGVyV29ya2VyIHtcbiAgLy8gbWFrZSB0aGUgd29ya2Zsb3cgY2xpZW50IGF2YWlsYWJsZSB0byB3ZWIgaG9va3NcbiAgaWYgKHdvcmtmbG93Q2xpZW50KSB7XG4gICAgcmVnaXN0ZXJXb3JrZmxvd0NsaWVudCh3b3JrZmxvd0NsaWVudCk7XG4gIH1cbiAgaWYgKGV2ZW50Q2xpZW50KSB7XG4gICAgcmVnaXN0ZXJFdmVudENsaWVudChldmVudENsaWVudCk7XG4gIH1cblxuICByZXR1cm4gYXN5bmMgZnVuY3Rpb24gKGV2ZW50cykge1xuICAgIGF3YWl0IFByb21pc2UuYWxsU2V0dGxlZChcbiAgICAgIGV2ZW50cy5tYXAoKGV2ZW50KSA9PlxuICAgICAgICBQcm9taXNlLmFsbFNldHRsZWQoXG4gICAgICAgICAgZXZlbnRIYW5kbGVyUHJvdmlkZXJcbiAgICAgICAgICAgIC5nZXRFdmVudEhhbmRsZXJzRm9yRXZlbnQoZXZlbnQubmFtZSlcbiAgICAgICAgICAgIC5tYXAoKGhhbmRsZXIpID0+IGhhbmRsZXIoZXZlbnQuZXZlbnQpKVxuICAgICAgICApXG4gICAgICApXG4gICAgKTtcbiAgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ydW50aW1lL2hhbmRsZXJzL2V2ZW50LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsK0NBQXdEO0FBd0J4RDs7Ozs7R0FLRztBQUNILFNBQWdCLHdCQUF3QixDQUFDLEVBQ3ZDLGFBQWEsRUFDYixvQkFBb0IsR0FDSztJQUN6QixrREFBa0Q7SUFDbEQsSUFBSSxhQUFhLEVBQUU7UUFDakIsSUFBQSxpQ0FBcUIsRUFBQyxhQUFhLENBQUMsQ0FBQztLQUN0QztJQUVELE9BQU8sS0FBSyxXQUFXLE1BQU07UUFDM0IsTUFBTSxPQUFPLENBQUMsVUFBVSxDQUN0QixNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FDbkIsT0FBTyxDQUFDLFVBQVUsQ0FDaEIsb0JBQW9CO2FBQ2pCLHdCQUF3QixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7YUFDcEMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQzFDLENBQ0YsQ0FDRixDQUFDO0lBQ0osQ0FBQyxDQUFDO0FBQ0osQ0FBQztBQXBCRCw0REFvQkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZWdpc3RlclNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcbmltcG9ydCB7IEV2ZW50SGFuZGxlclByb3ZpZGVyIH0gZnJvbSBcIi4uL3Byb3ZpZGVycy9ldmVudC1oYW5kbGVyLXByb3ZpZGVyLmpzXCI7XG5pbXBvcnQgeyBFdmVudHVhbFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vc2VydmljZS1jbGllbnQuanNcIjtcblxuLyoqXG4gKiBUaGUgZGVwZW5kZW5jaWVzIG9mIHtAbGluayBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXJ9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyB7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50dWFsU2VydmljZUNsaWVudH0gZm9yIGludGVyYWN0aW5nIHdpdGggd29ya2Zsb3dzIGNvbnRhaW5lZFxuICAgKiB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqL1xuICBzZXJ2aWNlQ2xpZW50PzogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50O1xuICAvKipcbiAgICogUmV0dXJucyBldmVudCBoYW5kbGVyc1xuICAgKi9cbiAgZXZlbnRIYW5kbGVyUHJvdmlkZXI6IEV2ZW50SGFuZGxlclByb3ZpZGVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIChldmVudHM6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGdlbmVyaWMgZnVuY3Rpb24gZm9yIGhhbmRsaW5nIGluYm91bmQgZXZlbnQgcmVxdWVzdHNcbiAqIHRoYXQgY2FuIGJlIHVzZWQgaW4gcnVudGltZSBpbXBsZW1lbnRhdGlvbnMuIFRoaXMgaW1wbGVtZW50YXRpb24gaXNcbiAqIGRlY291cGxlZCBmcm9tIGEgcnVudGltZSdzIHNwZWNpZmljcyBieSB0aGUgY2xpZW50cy4gQSBydW50aW1lIG11c3RcbiAqIGluamVjdCBpdHMgb3duIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZGVzaWduZWQgZm9yIHRoYXQgcGxhdGZvcm0uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXIoe1xuICBzZXJ2aWNlQ2xpZW50LFxuICBldmVudEhhbmRsZXJQcm92aWRlcixcbn06IEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyk6IEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIC8vIG1ha2UgdGhlIHdvcmtmbG93IGNsaWVudCBhdmFpbGFibGUgdG8gd2ViIGhvb2tzXG4gIGlmIChzZXJ2aWNlQ2xpZW50KSB7XG4gICAgcmVnaXN0ZXJTZXJ2aWNlQ2xpZW50KHNlcnZpY2VDbGllbnQpO1xuICB9XG5cbiAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uIChldmVudHMpIHtcbiAgICBhd2FpdCBQcm9taXNlLmFsbFNldHRsZWQoXG4gICAgICBldmVudHMubWFwKChldmVudCkgPT5cbiAgICAgICAgUHJvbWlzZS5hbGxTZXR0bGVkKFxuICAgICAgICAgIGV2ZW50SGFuZGxlclByb3ZpZGVyXG4gICAgICAgICAgICAuZ2V0RXZlbnRIYW5kbGVyc0ZvckV2ZW50KGV2ZW50Lm5hbWUpXG4gICAgICAgICAgICAubWFwKChoYW5kbGVyKSA9PiBoYW5kbGVyKGV2ZW50LmV2ZW50KSlcbiAgICAgICAgKVxuICAgICAgKVxuICAgICk7XG4gIH07XG59XG4iXX0=

@@ -119,4 +119,4 @@ "use strict";

else {
return (0, global_js_1.getWorkflowClient)().sendSignal({
executionId,
return (0, global_js_1.getServiceClient)().sendSignal({
execution: executionId,
signal,

@@ -142,2 +142,2 @@ id: id ?? (0, ulidx_1.ulid)(),

exports.isExecutionTarget = isExecutionTarget;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":";;;AAAA,qEAAmE;AACnE,2EAAiF;AACjF,yEAAuE;AACvE,iDAA0D;AAC1D,2CAAgD;AAChD,iCAA6B;AAkB7B,SAAgB,MAAM,CAAiB,IAAY;IACjD,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAFD,wBAEC;AAED,MAAa,MAAM;IACjB,YAAqB,EAAU;QAAV,OAAE,GAAF,EAAE,CAAQ;IAAG,CAAC;IACnC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA8BG;IACI,EAAE,CAAC,OAAuC;QAC/C,OAAO,QAAQ,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;IACjC,CAAC;IAED;;;;;;;;;;;;;;;;;;;;;;;;;;;;;OA6BG;IACI,MAAM,CAAC,IAA0B;QACtC,OAAO,YAAY,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IAClC,CAAC;IAED;;;;;;;;;OASG;IACI,IAAI,CACT,WAAmB,EACnB,GAAG,IAA8B;QAEjC,OAAO,UAAU,CAAkB,WAAW,EAAE,IAAI,EAAE,GAAG,IAAI,CAAC,CAAC;IACjE,CAAC;CACF;AAvFD,wBAuFC;AAuCD,SAAgB,YAAY,CAC1B,MAA4B,EAC5B,IAA0B;IAE1B,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;KAC7D;IAED,OAAO,IAAA,8CAAsB,EAC3B,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,IAAI,EAAE,cAAc,CACd,CAAC;AACX,CAAC;AAZD,oCAYC;AAuCD,SAAgB,QAAQ,CACtB,MAA4B,EAC5B,OAAmC;IAEnC,IAAI,CAAC,IAAA,+BAAoB,GAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IAED,OAAO,IAAA,wDAA+B,EACpC,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAc,CACf,CAAC;AACJ,CAAC;AAZD,4BAYC;AA+BD,SAAgB,UAAU,CACxB,WAAmB,EACnB,MAA4B,EAC5B,OAAa,EACb,EAAW;IAEX,IAAI,IAAA,+BAAoB,GAAE,EAAE;QAC1B,OAAO,IAAA,0CAAoB,EACzB,EAAE,IAAI,EAAE,gBAAgB,CAAC,SAAS,EAAE,WAAW,EAAE,EACjD,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAO,CACU,CAAC;KACrB;SAAM;QACL,OAAO,IAAA,6BAAiB,GAAE,CAAC,UAAU,CAAC;YACpC,WAAW;YACX,MAAM;YACN,EAAE,EAAE,EAAE,IAAI,IAAA,YAAI,GAAE;YAChB,OAAO;SACR,CAAC,CAAC;KACJ;AACH,CAAC;AApBD,gCAoBC;AAID,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,iEAAS,CAAA;IACT,2EAAc,CAAA;AAChB,CAAC,EAHW,gBAAgB,GAAhB,wBAAgB,KAAhB,wBAAgB,QAG3B;AAaD,SAAgB,sBAAsB,CACpC,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,cAAc,CAAC;AACzD,CAAC;AAJD,wDAIC;AAED,SAAgB,iBAAiB,CAC/B,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,CAAC;AACpD,CAAC;AAJD,8CAIC","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = 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 getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":";;;AAAA,qEAAmE;AACnE,2EAAiF;AACjF,yEAAuE;AACvE,iDAA0D;AAC1D,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"]}

@@ -6,15 +6,4 @@ import type { Program } from "./interpret.js";

import { ChildExecution, ExecutionHandle } from "./execution.js";
import { StartExecutionRequest } from "./service-client.js";
export type WorkflowHandler<Input = any, Output = any> = (input: Input, context: Context) => Promise<Output> | Program<Output>;
export interface StartExecutionRequest<Input> extends WorkflowOptions {
/**
* Input payload for the workflow.
*/
input: Input;
/**
* Optional name of the workflow to start - used to determine the unique ID and enforce idempotency.
*
* @default - a unique ID is generated.
*/
name?: string;
}
/**

@@ -33,4 +22,4 @@ * Options which determine how a workflow operates.

}
export type WorkflowOutput<W extends Workflow<any, any>> = W extends Workflow<any, infer Out> ? Out : never;
export type WorkflowInput<W extends Workflow<any, any>> = W extends Workflow<infer In, any> ? In : never;
export type WorkflowOutput<W extends Workflow> = W extends Workflow<any, infer Out> ? Out : never;
export type WorkflowInput<W extends Workflow> = W extends Workflow<infer In, any> ? In : undefined;
/**

@@ -40,3 +29,3 @@ * A {@link Workflow} is a long-running process that orchestrates calls

*/
export interface Workflow<Input = any, Output = any> {
export interface Workflow<in Input = any, Output = any> {
/**

@@ -60,3 +49,3 @@ * Globally unique ID of this {@link Workflow}.

*/
startExecution(request: StartExecutionRequest<Input>): Promise<ExecutionHandle<Workflow<Input, Output>>>;
startExecution(request: Omit<StartExecutionRequest<Workflow<Input, Output>>, "workflow">): Promise<ExecutionHandle<Workflow<Input, Output>>>;
}

@@ -63,0 +52,0 @@ export declare function lookupWorkflow(name: string): Workflow | undefined;

@@ -11,3 +11,2 @@ "use strict";

const chain_js_1 = require("./chain.js");
const execution_js_1 = require("./execution.js");
function lookupWorkflow(name) {

@@ -30,6 +29,6 @@ return (0, global_js_1.workflows)().get(name);

workflow.startExecution = async function (input) {
const workflowClient = (0, global_js_1.getWorkflowClient)();
const executionId = await workflowClient.startWorkflow({
workflowName: name,
executionName: input.name,
const serviceClient = (0, global_js_1.getServiceClient)();
return await serviceClient.startExecution({
workflow: name,
executionName: input.executionName,
input: input.input,

@@ -39,3 +38,2 @@ timeoutSeconds: input.timeoutSeconds,

});
return new execution_js_1.ExecutionHandle(executionId, workflowClient);
};

@@ -116,2 +114,2 @@ workflow.definition = ((0, chain_js_1.isChain)(definition)

exports.generateSyntheticEvents = generateSyntheticEvents;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  workflows,\n  clearEventualCollector,\n  getWorkflowClient,\n} from \"./global.js\";\nimport type { Program } from \"./interpret.js\";\nimport type { Context, WorkflowContext } from \"./context.js\";\nimport { DeterminismError } from \"./error.js\";\nimport {\n  filterEvents,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isSleepScheduled,\n  isWorkflowStarted,\n  SleepCompleted,\n  SleepScheduled,\n  WorkflowEventType,\n} from \"./workflow-events.js\";\nimport { interpret, WorkflowResult } from \"./interpret.js\";\nimport { createWorkflowCall } from \"./calls/workflow-call.js\";\nimport { AwaitedEventual } from \"./eventual.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { isChain } from \"./chain.js\";\nimport { ChildExecution, ExecutionHandle } from \"./execution.js\";\n\nexport type WorkflowHandler<Input = any, Output = any> = (\n  input: Input,\n  context: Context\n) => Promise<Output> | Program<Output>;\n\nexport interface StartExecutionRequest<Input> extends WorkflowOptions {\n  /**\n   * Input payload for the workflow.\n   */\n  input: Input;\n  /**\n   * Optional name of the workflow to start - used to determine the unique ID and enforce idempotency.\n   *\n   * @default - a unique ID is generated.\n   */\n  name?: string;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeoutSeconds?: number;\n}\n\nexport type WorkflowOutput<W extends Workflow<any, any>> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow<any, any>> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : never;\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  workflowName: string;\n\n  options?: WorkflowOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (input: Input): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: StartExecutionRequest<Input>\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n\n  /**\n   * @internal - this is the internal DSL representation that produces a {@link Program} instead of a Promise.\n   */\n  definition: (\n    input: Input,\n    context: Context\n  ) => Program<AwaitedEventual<Output>>;\n}\n\nexport function lookupWorkflow(name: string): Workflow | undefined {\n  return workflows().get(name);\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [opts: WorkflowOptions, definition: WorkflowHandler<Input, Output>]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((input?: any) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    return createWorkflowCall(name, input, opts);\n  }) as any;\n\n  workflow.workflowName = name;\n\n  workflow.startExecution = async function (input) {\n    const workflowClient = getWorkflowClient();\n    const executionId = await workflowClient.startWorkflow({\n      workflowName: name,\n      executionName: input.name,\n      input: input.input,\n      timeoutSeconds: input.timeoutSeconds,\n      ...opts,\n    });\n\n    return new ExecutionHandle(executionId, workflowClient);\n  };\n\n  workflow.definition = (\n    isChain(definition)\n      ? definition\n      : function* (input, context): any {\n          return yield definition(input, context);\n        }\n  ) as Workflow<Input, Output>[\"definition\"]; // safe to cast because we rely on transformer (it is always the generator API)\n  workflows().set(name, workflow);\n  return workflow;\n}\n\nexport interface ProgressWorkflowResult extends WorkflowResult {\n  history: HistoryStateEvent[];\n}\n\n/**\n * Advance a workflow using previous history, new events, and a program.\n */\nexport function progressWorkflow(\n  program: Workflow,\n  historyEvents: HistoryStateEvent[],\n  taskEvents: HistoryStateEvent[],\n  workflowContext: WorkflowContext,\n  executionId: string,\n  baseTime: Date = new Date()\n): ProgressWorkflowResult {\n  // historical events and incoming events will be fed into the workflow to resume/progress state\n  const uniqueTaskEvents = filterEvents<HistoryStateEvent>(\n    historyEvents,\n    taskEvents\n  );\n\n  const inputEvents = [...historyEvents, ...uniqueTaskEvents];\n\n  // Generates events that are time sensitive, like sleep completed events.\n  const syntheticEvents = generateSyntheticEvents(inputEvents, baseTime);\n\n  const allEvents = [...inputEvents, ...syntheticEvents];\n\n  const startEvent = inputEvents.find(isWorkflowStarted);\n\n  if (!startEvent) {\n    throw new DeterminismError(\n      `No ${WorkflowEventType.WorkflowStarted} found.`\n    );\n  }\n\n  const context: Context = {\n    workflow: workflowContext,\n    execution: {\n      ...startEvent.context,\n      id: executionId,\n      startTime: startEvent.timestamp,\n    },\n  };\n\n  // execute workflow\n  const interpretEvents = allEvents.filter(isHistoryEvent);\n\n  console.debug(\"history events\", JSON.stringify(historyEvents));\n  console.debug(\"task events\", JSON.stringify(taskEvents));\n  console.debug(\"synthetic events\", JSON.stringify(syntheticEvents));\n  console.debug(\"interpret events\", JSON.stringify(interpretEvents));\n\n  try {\n    return {\n      ...interpret(\n        program.definition(startEvent.input, context),\n        interpretEvents\n      ),\n      history: allEvents,\n    };\n  } catch (err) {\n    // temporary fix when the interpreter fails, but the activities are not cleared.\n    clearEventualCollector();\n    throw err;\n  }\n}\n\n/**\n * Generates synthetic events, for example, {@link SleepCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): SleepCompleted[] {\n  const unresolvedSleep: Record<number, SleepScheduled> = {};\n\n  const sleepEvents = events.filter(\n    (event): event is SleepScheduled | SleepCompleted =>\n      isSleepScheduled(event) || isSleepCompleted(event)\n  );\n\n  for (const event of sleepEvents) {\n    if (isSleepScheduled(event)) {\n      unresolvedSleep[event.seq] = event;\n    } else {\n      delete unresolvedSleep[event.seq];\n    }\n  }\n\n  const syntheticSleepComplete: SleepCompleted[] = Object.values(\n    unresolvedSleep\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.SleepCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies SleepCompleted)\n    );\n\n  return syntheticSleepComplete;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  workflows,\n  clearEventualCollector,\n  getServiceClient,\n} from \"./global.js\";\nimport type { Program } from \"./interpret.js\";\nimport type { Context, WorkflowContext } from \"./context.js\";\nimport { DeterminismError } from \"./error.js\";\nimport {\n  filterEvents,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isSleepScheduled,\n  isWorkflowStarted,\n  SleepCompleted,\n  SleepScheduled,\n  WorkflowEventType,\n} from \"./workflow-events.js\";\nimport { interpret, WorkflowResult } from \"./interpret.js\";\nimport { createWorkflowCall } from \"./calls/workflow-call.js\";\nimport { AwaitedEventual } from \"./eventual.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { isChain } from \"./chain.js\";\nimport { ChildExecution, ExecutionHandle } from \"./execution.js\";\nimport { StartExecutionRequest } from \"./service-client.js\";\n\nexport type WorkflowHandler<Input = any, Output = any> = (\n  input: Input,\n  context: Context\n) => Promise<Output> | Program<Output>;\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeoutSeconds?: number;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  workflowName: string;\n\n  options?: WorkflowOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (input: Input): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n\n  /**\n   * @internal - this is the internal DSL representation that produces a {@link Program} instead of a Promise.\n   */\n  definition: (\n    input: Input,\n    context: Context\n  ) => Program<AwaitedEventual<Output>>;\n}\n\nexport function lookupWorkflow(name: string): Workflow | undefined {\n  return workflows().get(name);\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [opts: WorkflowOptions, definition: WorkflowHandler<Input, Output>]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((input?: any) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    return createWorkflowCall(name, input, opts);\n  }) as any;\n\n  workflow.workflowName = name;\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeoutSeconds: input.timeoutSeconds,\n      ...opts,\n    });\n  };\n\n  workflow.definition = (\n    isChain(definition)\n      ? definition\n      : function* (input, context): any {\n          return yield definition(input, context);\n        }\n  ) as Workflow<Input, Output>[\"definition\"]; // safe to cast because we rely on transformer (it is always the generator API)\n  workflows().set(name, workflow);\n  return workflow;\n}\n\nexport interface ProgressWorkflowResult extends WorkflowResult {\n  history: HistoryStateEvent[];\n}\n\n/**\n * Advance a workflow using previous history, new events, and a program.\n */\nexport function progressWorkflow(\n  program: Workflow,\n  historyEvents: HistoryStateEvent[],\n  taskEvents: HistoryStateEvent[],\n  workflowContext: WorkflowContext,\n  executionId: string,\n  baseTime: Date = new Date()\n): ProgressWorkflowResult {\n  // historical events and incoming events will be fed into the workflow to resume/progress state\n  const uniqueTaskEvents = filterEvents<HistoryStateEvent>(\n    historyEvents,\n    taskEvents\n  );\n\n  const inputEvents = [...historyEvents, ...uniqueTaskEvents];\n\n  // Generates events that are time sensitive, like sleep completed events.\n  const syntheticEvents = generateSyntheticEvents(inputEvents, baseTime);\n\n  const allEvents = [...inputEvents, ...syntheticEvents];\n\n  const startEvent = inputEvents.find(isWorkflowStarted);\n\n  if (!startEvent) {\n    throw new DeterminismError(\n      `No ${WorkflowEventType.WorkflowStarted} found.`\n    );\n  }\n\n  const context: Context = {\n    workflow: workflowContext,\n    execution: {\n      ...startEvent.context,\n      id: executionId,\n      startTime: startEvent.timestamp,\n    },\n  };\n\n  // execute workflow\n  const interpretEvents = allEvents.filter(isHistoryEvent);\n\n  console.debug(\"history events\", JSON.stringify(historyEvents));\n  console.debug(\"task events\", JSON.stringify(taskEvents));\n  console.debug(\"synthetic events\", JSON.stringify(syntheticEvents));\n  console.debug(\"interpret events\", JSON.stringify(interpretEvents));\n\n  try {\n    return {\n      ...interpret(\n        program.definition(startEvent.input, context),\n        interpretEvents\n      ),\n      history: allEvents,\n    };\n  } catch (err) {\n    // temporary fix when the interpreter fails, but the activities are not cleared.\n    clearEventualCollector();\n    throw err;\n  }\n}\n\n/**\n * Generates synthetic events, for example, {@link SleepCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): SleepCompleted[] {\n  const unresolvedSleep: Record<number, SleepScheduled> = {};\n\n  const sleepEvents = events.filter(\n    (event): event is SleepScheduled | SleepCompleted =>\n      isSleepScheduled(event) || isSleepCompleted(event)\n  );\n\n  for (const event of sleepEvents) {\n    if (isSleepScheduled(event)) {\n      unresolvedSleep[event.seq] = event;\n    } else {\n      delete unresolvedSleep[event.seq];\n    }\n  }\n\n  const syntheticSleepComplete: SleepCompleted[] = Object.values(\n    unresolvedSleep\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.SleepCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies SleepCompleted)\n    );\n\n  return syntheticSleepComplete;\n}\n"]}

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

import { CompleteActivityRequest } from "./runtime/clients/workflow-client.js";
import { SendActivitySuccessRequest } from "./service-client.js";
export interface ActivityOptions {

@@ -24,3 +24,3 @@ /**

/**
* Complete an activity request by its {@link CompleteActivityRequest.activityToken}.
* Complete an activity request by its {@link SendActivitySuccessRequest.activityToken}.
*

@@ -45,3 +45,3 @@ * This method is used in conjunction with {@link asyncResult} in an activity

*/
complete(request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>): Promise<void>;
complete(request: Omit<SendActivitySuccessRequest<UnwrapAsync<Awaited<Output>>>, "type">): Promise<void>;
activityID: string;

@@ -48,0 +48,0 @@ }

import { createActivityCall } from "./calls/activity-call.js";
import { callableActivities, getActivityContext, getWorkflowClient, } from "./global.js";
import { callableActivities, getActivityContext, getServiceClient, } from "./global.js";
import { isActivityWorker, isOrchestratorWorker } from "./runtime/flags.js";

@@ -57,3 +57,3 @@ const AsyncTokenSymbol = Symbol.for("eventual:AsyncToken");

func.complete = async function (request) {
return getWorkflowClient().completeActivity(request);
return getServiceClient().sendActivitySuccess(request);
};

@@ -72,2 +72,2 @@ func.activityID = activityID;

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"activity.js","sourceRoot":"","sources":["../../src/activity.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,kBAAkB,EAAE,MAAM,0BAA0B,CAAC;AAC9D,OAAO,EACL,kBAAkB,EAClB,kBAAkB,EAClB,iBAAiB,GAClB,MAAM,aAAa,CAAC;AAErB,OAAO,EAAE,gBAAgB,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAuE5E,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,iBAAiB,EAAE,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;IACvD,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  getWorkflowClient,\n} from \"./global.js\";\nimport { CompleteActivityRequest } from \"./runtime/clients/workflow-client.js\";\nimport { isActivityWorker, isOrchestratorWorker } from \"./runtime/flags.js\";\n\nexport interface ActivityOptions {\n  /**\n   * How long the workflow will wait for the activity to complete or fail.\n   *\n   * @default - workflow will run forever.\n   */\n  timeoutSeconds?: number;\n  /**\n   * For long running activities, it is suggested that they report back that they\n   * are still in progress to avoid waiting forever or until a long timeout when\n   * something goes wrong.\n   *\n   * When set to a positive number, the activity must call {@link heartbeat} or\n   * {@link WorkflowClient.heartbeatActivity} at least every heartbeatSeconds.\n   *\n   * If it fails to do so, the workflow will cancel the activity and throw an error.\n   */\n  heartbeatSeconds?: number;\n}\n\nexport interface ActivityFunction<Arguments extends any[], Output = any> {\n  (...args: Arguments): Promise<Awaited<UnwrapAsync<Output>>>;\n\n  /**\n   * Complete an activity request by its {@link CompleteActivityRequest.activityToken}.\n   *\n   * This method is used in conjunction with {@link asyncResult} in an activity\n   * to perform asynchronous, long-running computations. For example:\n   *\n   * ```ts\n   * const tokenEvent = event(\"token\");\n   *\n   * const asyncActivity = activity(\"async\", () => {\n   *   return asyncResult<string>(token => tokenEvent.publish({ token }));\n   * });\n   *\n   * tokenEvent.on(async ({token}) => {\n   *   await asyncActivity.complete({\n   *     activityToken: token,\n   *     result: \"done\"\n   *   });\n   * })\n   * ```\n   */\n  complete(\n    request: CompleteActivityRequest<UnwrapAsync<Awaited<Output>>>\n  ): Promise<void>;\n\n  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 getWorkflowClient().completeActivity(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;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"]}
import { createPublishEventsCall } from "./calls/send-events-call.js";
import { events, eventSubscriptions, getEventClient } from "./global.js";
import { isOrchestratorWorker } from "./index.js";
import { events, eventSubscriptions } from "./global.js";
import { getServiceClient, isOrchestratorWorker } from "./index.js";
/**

@@ -67,3 +67,3 @@ * Declares an event that can be published and subscribed to.

else {
return getEventClient().publish(...envelopes);
return getServiceClient().publishEvents({ events: envelopes });
}

@@ -75,2 +75,2 @@ },

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDdEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxjQUFjLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDekUsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sWUFBWSxDQUFDO0FBZ0dsRDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFDRztBQUNILE1BQU0sVUFBVSxLQUFLLENBQXlCLElBQVk7SUFDeEQsSUFBSSxNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLEVBQUU7UUFDdEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxvQkFBb0IsSUFBSSxrQkFBa0IsQ0FBQyxDQUFDO0tBQzdEO0lBQ0QsTUFBTSxLQUFLLEdBQWE7UUFDdEIsSUFBSTtRQUNKLEVBQUUsQ0FBQyxPQUFPO1lBQ1Isa0JBQWtCLEVBQUUsQ0FBQyxJQUFJLENBQUM7Z0JBQ3hCLGFBQWEsRUFBRTtvQkFDYjt3QkFDRSxJQUFJO3FCQUNMO2lCQUNGO2dCQUNELE9BQU8sRUFBRSxPQUFxQzthQUMvQyxDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsT0FBTyxDQUFDLEdBQUcsTUFBTTtZQUNmLE1BQU0sU0FBUyxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRSxDQUFDLENBQUM7Z0JBQ3ZDLElBQUk7Z0JBQ0osS0FBSzthQUNOLENBQUMsQ0FBQyxDQUFDO1lBQ0osSUFBSSxvQkFBb0IsRUFBRSxFQUFFO2dCQUMxQixPQUFPLHVCQUF1QixDQUFDLFNBQVMsQ0FBUSxDQUFDO2FBQ2xEO2lCQUFNO2dCQUNMLE9BQU8sY0FBYyxFQUFFLENBQUMsT0FBTyxDQUFDLEdBQUcsU0FBUyxDQUFDLENBQUM7YUFDL0M7UUFDSCxDQUFDO0tBQ0YsQ0FBQztJQUNGLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEVBQUUsS0FBSyxDQUFDLENBQUM7SUFDMUIsT0FBTyxLQUFLLENBQUM7QUFDZixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgY3JlYXRlUHVibGlzaEV2ZW50c0NhbGwgfSBmcm9tIFwiLi9jYWxscy9zZW5kLWV2ZW50cy1jYWxsLmpzXCI7XG5pbXBvcnQgeyBldmVudHMsIGV2ZW50U3Vic2NyaXB0aW9ucywgZ2V0RXZlbnRDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vaW5kZXguanNcIjtcblxuLyoqXG4gKiBBbiBFdmVudFBheWxvYWQgaXMgdGhlIGRhdGEgc2VudCBhcyBhbiBldmVudC5cbiAqXG4gKiBJdCBtdXN0IGJlIGFuIG9iamVjdC4gUHJvcGVydGllcyBjYW4gYmUgYW55IHR5cGUgc2VyaWFsaXphYmxlIGFzIEpTT04uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRQYXlsb2FkIHtcbiAgW3Byb3BOYW1lOiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIEV2ZW50UGF5bG9hZFR5cGU8RSBleHRlbmRzIEV2ZW50PGFueT4+ID0gRSBleHRlbmRzIEV2ZW50PFxuICBpbmZlciBQYXlsb2FkXG4+XG4gID8gUGF5bG9hZFxuICA6IG5ldmVyO1xuXG4vKipcbiAqIEFuIGVudmVsb3BlIG9iamVjdCBjb250YWluaW5nIHRoZSB7QGxpbmsgZXZlbnR9IHBheWxvYWQgYXNzb2NpYXRlZFxuICogd2l0aCBpdHMgdW5pcXVlIHtAbGluayBuYW1lfS5cbiAqXG4gKiBUaGlzIGVudmVsb3BlIGRlY291cGxlcyB0aGUge0BsaW5rIG5hbWV9IGZybyB0aGUgcGF5bG9hZCBzbyB0aGF0XG4gKiB0aGVyZSBhcmUgbm8gaW1wb3NpdGlvbnMgb24gdGhlIHN0cnVjdHVyZSBvZiBhbiBldmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudEVudmVsb3BlPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFVuaXF1ZSBuYW1lIGlkZW50aWZ5aW5nIHRoZSB0eXBlIG9mIHRoZSB7QGxpbmsgZXZlbnR9LlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudFBheWxvYWR9LlxuICAgKi9cbiAgZXZlbnQ6IEU7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50fSBpcyBhbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBkZWNsYXJhdGlvbiBvZiBhbiBldmVudFxuICogdGhhdCBiZWxvbmdzIHdpdGhpbiB0aGUgc2VydmljZS4gQW4ge0BsaW5rIEV2ZW50fSBoYXMgYSB1bmlxdWUge0BsaW5rIG5hbWV9LFxuICogbWF5IGJlIHtAbGluayBwdWJsaXNofWVkIGFuZCB7QGxpbmsgb259ZCB0by5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBUaGUgRXZlbnQncyBnbG9iYWxseSB1bmlxdWUgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIFN1YnNjcmliZSB0byB0aGlzIGV2ZW50LiBUaGUge0BsaW5rIGhhbmRsZXJ9IHdpbGwgYmUgaW52b2tlZCBldmVyeVxuICAgKiB0aW1lIGFuIGV2ZW50IHdpdGggdGhpcyBuYW1lIGlzIHB1Ymxpc2hlZCB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBoYW5kbGVyIHRoZSBoYW5kbGVyIGZ1bmN0aW9uIHRoYXQgd2lsbCBwcm9jZXNzIHRoZSBldmVudC5cbiAgICovXG4gIG9uKGhhbmRsZXI6IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPik6IHZvaWQ7XG4gIC8qKlxuICAgKiBQdWJsaXNoIGV2ZW50cyBvZiB0aGlzIHR5cGUgd2l0aGluIHRoZSBzZXJ2aWNlIGJvdW5kYXJ5LlxuICAgKlxuICAgKiBAcGFyYW0gZXZlbnRzIGEgbGlzdCBvZiBldmVudHMgdG8gcHVibGlzaC5cbiAgICovXG4gIHB1Ymxpc2goLi4uZXZlbnRzOiBFW10pOiBQcm9taXNlPHZvaWQ+O1xufVxuXG4vKipcbiAqIEEge0BsaW5rIFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGhvdyB0byBzZWxlY3QgZXZlbnRzIGZyb21cbiAqIHdpdGhpbiBhIHNlcnZpY2UgYm91bmRhcnkgdG8gcm91dGUgdG8gYSB7QGxpbmsgRXZlbnRIYW5kbGVyfS5cbiAqXG4gKiBGb3Igbm93LCB3ZSBvbmx5IHN1cHBvcnQgbWF0Y2hpbmcgb24gYSBzaW5nbGUgbmFtZSwgYnV0IHRoaXMgb2JqZWN0IGNhbiBiZVxuICogZXh0ZW5kZWQgd2l0aCBvdGhlciBwcm9wZXJ0aWVzIHN1Y2ggYXMgc2VsZWN0aW9uIHByZWRpY2F0ZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIGV2ZW50IHRvIHN1YnNjcmliZSB0by5cbiAgICovXG4gIG5hbWU6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnRTdWJzY3JpcHRpb259IGlzIGFuIG9iamVjdCB0aGF0IGFzc29jaWF0ZXMgYSB7QGxpbmsgaGFuZGxlcn1cbiAqIGZ1bmN0aW9uIHdpdGggYSBsaXN0IG9mIHtAbGluayBzdWJzY3JpcHRpb25zfS4gVGhlIHtAbGluayBzdWJzY3JpcHRpb25zfVxuICogZGVmaW5lIHdoaWNoIGV2ZW50cyB0aGlzIHtAbGluayBoYW5kbGVyfSBzaG91bGQgYmUgaW52b2tlZCBmb3IuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRTdWJzY3JpcHRpb248RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogQSBsaXN0IG9mIHtAbGluayBTdWJzY3JpcHRpb259cyB0aGF0IHNob3VsZCBpbnZva2UgdGhpcyB7QGxpbmsgaGFuZGxlcn0uXG4gICAqL1xuICBzdWJzY3JpcHRpb25zOiBTdWJzY3JpcHRpb25bXTtcbiAgLyoqXG4gICAqIFRoZSB7QGxpbmsgRXZlbnRIYW5kbGVyfSB0byBpbnZva2UgZm9yIGFueSBldmVudCB0aGF0IG1hdGNoZXMgb25lIG9mXG4gICAqIHRoZSB7QGxpbmsgc3Vic2NyaXB0aW9uc30uXG4gICAqL1xuICBoYW5kbGVyOiBFdmVudEhhbmRsZXI8RT47XG59XG5cbi8qKlxuICogQSBGdW5jdGlvbiB0aGF0IHByb2Nlc3NlcyBhbiB7QGxpbmsgZXZlbnR9IG9mIHR5cGUge0BsaW5rIEV9LlxuICovXG5leHBvcnQgdHlwZSBFdmVudEhhbmRsZXI8RSBleHRlbmRzIEV2ZW50UGF5bG9hZD4gPSAoZXZlbnQ6IEUpID0+IFByb21pc2U8dm9pZD47XG5cbi8qKlxuICogRGVjbGFyZXMgYW4gZXZlbnQgdGhhdCBjYW4gYmUgcHVibGlzaGVkIGFuZCBzdWJzY3JpYmVkIHRvLlxuICpcbiAqIFRvIGRlY2xhcmUgYW4ge0BsaW5rIEV2ZW50fSwgZGVmaW5lIGFuIGludGVyZmFjZSBkZXNjcmliaW5nIHRoZSB0eXBlXG4gKiBvZiB0aGUgcGF5bG9hZCBhbmQgdGhlbiBkZWNsYXJlIGFuIGV2ZW50IG9iamVjdCBnaXZpbmcgaXQgYSB1bmlxdWUgbmFtZS5cbiAqIGBgYHRzXG4gKiBpbnRlcmZhY2UgQ2hlY2tvdXRFdmVudCB7XG4gKiAgIGN1c3RvbWVySWQ6IHN0cmluZztcbiAqICAgY2FydElkOiBzdHJpbmc7XG4gKiAgIHRpbWVzdGFtcDogc3RyaW5nO1xuICogfVxuICpcbiAqIGNvbnN0IGNoZWNrb3V0RXZlbnQgPSBldmVudDxDaGVja291dEV2ZW50PihcIkNoZWNrb3V0XCIpO1xuICogYGBgXG4gKlxuICogVG8gcHVibGlzaCBldmVudHMsIGNhbGwgdGhlIGBwdWJsaXNoYCBtZXRob2Q6XG4gKiBgYGB0c1xuICogY29uc3QgY2hlY2tvdXRXb3JrZmxvdyA9IHdvcmtmbG93KFwiY2hlY2tvdXRXb3JrZmxvd1wiLCBhc3luYyAocmVxdWVzdCkgPT4ge1xuICogICBhd2FpdCBjaGVja291dEV2ZW50LnB1Ymxpc2goe1xuICogICAgIGN1c3RvbWVySWQ6IHJlcXVlc3QuY3VzdG9tZXJJZCxcbiAqICAgICBjYXJ0SWQ6IHJlcXVlc3QuY2FydElkLFxuICogICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b1RpbWVTdHJpbmcoKVxuICogICB9KTtcbiAqIH0pXG4gKiBgYGBcbiAqXG4gKiBUbyBzdWJzY3JpYmUgdG8gZXZlbnRzLCBjYWxsIHRoZSBgb25gIG1ldGhvZC4gVGhpcyB3aWxsIHJlZ2lzdGVyIGFcbiAqIGhhbmRsZXIgdGhhdCB3aWwgbGJlIGludm9rZWQgZm9yIGV2ZXJ5IGV2ZW50IG9mIHRoaXMgdHlwZSB0aGF0IGlzIHJlY2VpdmVkLlxuICpcbiAqIGBgYHRzXG4gKiBjaGVja291dEV2ZW50Lm9uKGFzeW5jIChjaGVja291dCkgPT4ge1xuICogICBjb25zb2xlLmxvZyhjaGVja291dCk7XG4gKiB9KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBuYW1lIGEgdW5pcXVlIG5hbWUgdGhhdCBpZGVudGlmaWVzIHRoaXMgZXZlbnQgdHlwZSB3aXRoaW4gdGhlIFNlcnZpY2UuXG4gKiBAcmV0dXJucyBhbiB7QGxpbmsgRXZlbnR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPihuYW1lOiBzdHJpbmcpOiBFdmVudDxFPiB7XG4gIGlmIChldmVudHMoKS5oYXMobmFtZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGV2ZW50IHdpdGggbmFtZSAnJHtuYW1lfScgYWxyZWFkeSBleGlzdHNgKTtcbiAgfVxuICBjb25zdCBldmVudDogRXZlbnQ8RT4gPSB7XG4gICAgbmFtZSxcbiAgICBvbihoYW5kbGVyKSB7XG4gICAgICBldmVudFN1YnNjcmlwdGlvbnMoKS5wdXNoKHtcbiAgICAgICAgc3Vic2NyaXB0aW9uczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgICAgaGFuZGxlcjogaGFuZGxlciBhcyBFdmVudEhhbmRsZXI8RXZlbnRQYXlsb2FkPixcbiAgICAgIH0pO1xuICAgIH0sXG4gICAgcHVibGlzaCguLi5ldmVudHMpIHtcbiAgICAgIGNvbnN0IGVudmVsb3BlcyA9IGV2ZW50cy5tYXAoKGV2ZW50KSA9PiAoe1xuICAgICAgICBuYW1lLFxuICAgICAgICBldmVudCxcbiAgICAgIH0pKTtcbiAgICAgIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgICAgIHJldHVybiBjcmVhdGVQdWJsaXNoRXZlbnRzQ2FsbChlbnZlbG9wZXMpIGFzIGFueTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBnZXRFdmVudENsaWVudCgpLnB1Ymxpc2goLi4uZW52ZWxvcGVzKTtcbiAgICAgIH1cbiAgICB9LFxuICB9O1xuICBldmVudHMoKS5zZXQobmFtZSwgZXZlbnQpO1xuICByZXR1cm4gZXZlbnQ7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvZXZlbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sNkJBQTZCLENBQUM7QUFDdEUsT0FBTyxFQUFFLE1BQU0sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxZQUFZLENBQUM7QUFnR3BFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBcUNHO0FBQ0gsTUFBTSxVQUFVLEtBQUssQ0FBeUIsSUFBWTtJQUN4RCxJQUFJLE1BQU0sRUFBRSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsRUFBRTtRQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLG9CQUFvQixJQUFJLGtCQUFrQixDQUFDLENBQUM7S0FDN0Q7SUFDRCxNQUFNLEtBQUssR0FBYTtRQUN0QixJQUFJO1FBQ0osRUFBRSxDQUFDLE9BQU87WUFDUixrQkFBa0IsRUFBRSxDQUFDLElBQUksQ0FBQztnQkFDeEIsYUFBYSxFQUFFO29CQUNiO3dCQUNFLElBQUk7cUJBQ0w7aUJBQ0Y7Z0JBQ0QsT0FBTyxFQUFFLE9BQXFDO2FBQy9DLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxPQUFPLENBQUMsR0FBRyxNQUFNO1lBQ2YsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQztnQkFDdkMsSUFBSTtnQkFDSixLQUFLO2FBQ04sQ0FBQyxDQUFDLENBQUM7WUFDSixJQUFJLG9CQUFvQixFQUFFLEVBQUU7Z0JBQzFCLE9BQU8sdUJBQXVCLENBQUMsU0FBUyxDQUFRLENBQUM7YUFDbEQ7aUJBQU07Z0JBQ0wsT0FBTyxnQkFBZ0IsRUFBRSxDQUFDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsQ0FBQyxDQUFDO2FBQ2hFO1FBQ0gsQ0FBQztLQUNGLENBQUM7SUFDRixNQUFNLEVBQUUsQ0FBQyxHQUFHLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDO0lBQzFCLE9BQU8sS0FBSyxDQUFDO0FBQ2YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNyZWF0ZVB1Ymxpc2hFdmVudHNDYWxsIH0gZnJvbSBcIi4vY2FsbHMvc2VuZC1ldmVudHMtY2FsbC5qc1wiO1xuaW1wb3J0IHsgZXZlbnRzLCBldmVudFN1YnNjcmlwdGlvbnMgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGdldFNlcnZpY2VDbGllbnQsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vaW5kZXguanNcIjtcblxuLyoqXG4gKiBBbiBFdmVudFBheWxvYWQgaXMgdGhlIGRhdGEgc2VudCBhcyBhbiBldmVudC5cbiAqXG4gKiBJdCBtdXN0IGJlIGFuIG9iamVjdC4gUHJvcGVydGllcyBjYW4gYmUgYW55IHR5cGUgc2VyaWFsaXphYmxlIGFzIEpTT04uXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRQYXlsb2FkIHtcbiAgW3Byb3BOYW1lOiBzdHJpbmddOiBhbnk7XG59XG5cbmV4cG9ydCB0eXBlIEV2ZW50UGF5bG9hZFR5cGU8RSBleHRlbmRzIEV2ZW50PGFueT4+ID0gRSBleHRlbmRzIEV2ZW50PFxuICBpbmZlciBQYXlsb2FkXG4+XG4gID8gUGF5bG9hZFxuICA6IG5ldmVyO1xuXG4vKipcbiAqIEFuIGVudmVsb3BlIG9iamVjdCBjb250YWluaW5nIHRoZSB7QGxpbmsgZXZlbnR9IHBheWxvYWQgYXNzb2NpYXRlZFxuICogd2l0aCBpdHMgdW5pcXVlIHtAbGluayBuYW1lfS5cbiAqXG4gKiBUaGlzIGVudmVsb3BlIGRlY291cGxlcyB0aGUge0BsaW5rIG5hbWV9IGZybyB0aGUgcGF5bG9hZCBzbyB0aGF0XG4gKiB0aGVyZSBhcmUgbm8gaW1wb3NpdGlvbnMgb24gdGhlIHN0cnVjdHVyZSBvZiBhbiBldmVudC5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudEVudmVsb3BlPEUgZXh0ZW5kcyBFdmVudFBheWxvYWQgPSBFdmVudFBheWxvYWQ+IHtcbiAgLyoqXG4gICAqIFVuaXF1ZSBuYW1lIGlkZW50aWZ5aW5nIHRoZSB0eXBlIG9mIHRoZSB7QGxpbmsgZXZlbnR9LlxuICAgKi9cbiAgbmFtZTogc3RyaW5nO1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudFBheWxvYWR9LlxuICAgKi9cbiAgZXZlbnQ6IEU7XG59XG5cbi8qKlxuICogQW4ge0BsaW5rIEV2ZW50fSBpcyBhbiBvYmplY3QgcmVwcmVzZW50aW5nIHRoZSBkZWNsYXJhdGlvbiBvZiBhbiBldmVudFxuICogdGhhdCBiZWxvbmdzIHdpdGhpbiB0aGUgc2VydmljZS4gQW4ge0BsaW5rIEV2ZW50fSBoYXMgYSB1bmlxdWUge0BsaW5rIG5hbWV9LFxuICogbWF5IGJlIHtAbGluayBwdWJsaXNofWVkIGFuZCB7QGxpbmsgb259ZCB0by5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkID0gRXZlbnRQYXlsb2FkPiB7XG4gIC8qKlxuICAgKiBUaGUgRXZlbnQncyBnbG9iYWxseSB1bmlxdWUgbmFtZS5cbiAgICovXG4gIHJlYWRvbmx5IG5hbWU6IHN0cmluZztcbiAgLyoqXG4gICAqIFN1YnNjcmliZSB0byB0aGlzIGV2ZW50LiBUaGUge0BsaW5rIGhhbmRsZXJ9IHdpbGwgYmUgaW52b2tlZCBldmVyeVxuICAgKiB0aW1lIGFuIGV2ZW50IHdpdGggdGhpcyBuYW1lIGlzIHB1Ymxpc2hlZCB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqXG4gICAqIEBwYXJhbSBoYW5kbGVyIHRoZSBoYW5kbGVyIGZ1bmN0aW9uIHRoYXQgd2lsbCBwcm9jZXNzIHRoZSBldmVudC5cbiAgICovXG4gIG9uKGhhbmRsZXI6IChldmVudDogRSkgPT4gUHJvbWlzZTx2b2lkPik6IHZvaWQ7XG4gIC8qKlxuICAgKiBQdWJsaXNoIGV2ZW50cyBvZiB0aGlzIHR5cGUgd2l0aGluIHRoZSBzZXJ2aWNlIGJvdW5kYXJ5LlxuICAgKlxuICAgKiBAcGFyYW0gZXZlbnRzIGEgbGlzdCBvZiBldmVudHMgdG8gcHVibGlzaC5cbiAgICovXG4gIHB1Ymxpc2goLi4uZXZlbnRzOiBFW10pOiBQcm9taXNlPHZvaWQ+O1xufVxuXG4vKipcbiAqIEEge0BsaW5rIFN1YnNjcmlwdGlvbn0gaXMgYW4gb2JqZWN0IHRoYXQgZGVzY3JpYmVzIGhvdyB0byBzZWxlY3QgZXZlbnRzIGZyb21cbiAqIHdpdGhpbiBhIHNlcnZpY2UgYm91bmRhcnkgdG8gcm91dGUgdG8gYSB7QGxpbmsgRXZlbnRIYW5kbGVyfS5cbiAqXG4gKiBGb3Igbm93LCB3ZSBvbmx5IHN1cHBvcnQgbWF0Y2hpbmcgb24gYSBzaW5nbGUgbmFtZSwgYnV0IHRoaXMgb2JqZWN0IGNhbiBiZVxuICogZXh0ZW5kZWQgd2l0aCBvdGhlciBwcm9wZXJ0aWVzIHN1Y2ggYXMgc2VsZWN0aW9uIHByZWRpY2F0ZXMuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgU3Vic2NyaXB0aW9uIHtcbiAgLyoqXG4gICAqIE5hbWUgb2YgdGhlIGV2ZW50IHRvIHN1YnNjcmliZSB0by5cbiAgICovXG4gIG5hbWU6IHN0cmluZztcbn1cblxuLyoqXG4gKiBBbiB7QGxpbmsgRXZlbnRTdWJzY3JpcHRpb259IGlzIGFuIG9iamVjdCB0aGF0IGFzc29jaWF0ZXMgYSB7QGxpbmsgaGFuZGxlcn1cbiAqIGZ1bmN0aW9uIHdpdGggYSBsaXN0IG9mIHtAbGluayBzdWJzY3JpcHRpb25zfS4gVGhlIHtAbGluayBzdWJzY3JpcHRpb25zfVxuICogZGVmaW5lIHdoaWNoIGV2ZW50cyB0aGlzIHtAbGluayBoYW5kbGVyfSBzaG91bGQgYmUgaW52b2tlZCBmb3IuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgRXZlbnRTdWJzY3JpcHRpb248RSBleHRlbmRzIEV2ZW50UGF5bG9hZCA9IEV2ZW50UGF5bG9hZD4ge1xuICAvKipcbiAgICogQSBsaXN0IG9mIHtAbGluayBTdWJzY3JpcHRpb259cyB0aGF0IHNob3VsZCBpbnZva2UgdGhpcyB7QGxpbmsgaGFuZGxlcn0uXG4gICAqL1xuICBzdWJzY3JpcHRpb25zOiBTdWJzY3JpcHRpb25bXTtcbiAgLyoqXG4gICAqIFRoZSB7QGxpbmsgRXZlbnRIYW5kbGVyfSB0byBpbnZva2UgZm9yIGFueSBldmVudCB0aGF0IG1hdGNoZXMgb25lIG9mXG4gICAqIHRoZSB7QGxpbmsgc3Vic2NyaXB0aW9uc30uXG4gICAqL1xuICBoYW5kbGVyOiBFdmVudEhhbmRsZXI8RT47XG59XG5cbi8qKlxuICogQSBGdW5jdGlvbiB0aGF0IHByb2Nlc3NlcyBhbiB7QGxpbmsgZXZlbnR9IG9mIHR5cGUge0BsaW5rIEV9LlxuICovXG5leHBvcnQgdHlwZSBFdmVudEhhbmRsZXI8RSBleHRlbmRzIEV2ZW50UGF5bG9hZD4gPSAoZXZlbnQ6IEUpID0+IFByb21pc2U8dm9pZD47XG5cbi8qKlxuICogRGVjbGFyZXMgYW4gZXZlbnQgdGhhdCBjYW4gYmUgcHVibGlzaGVkIGFuZCBzdWJzY3JpYmVkIHRvLlxuICpcbiAqIFRvIGRlY2xhcmUgYW4ge0BsaW5rIEV2ZW50fSwgZGVmaW5lIGFuIGludGVyZmFjZSBkZXNjcmliaW5nIHRoZSB0eXBlXG4gKiBvZiB0aGUgcGF5bG9hZCBhbmQgdGhlbiBkZWNsYXJlIGFuIGV2ZW50IG9iamVjdCBnaXZpbmcgaXQgYSB1bmlxdWUgbmFtZS5cbiAqIGBgYHRzXG4gKiBpbnRlcmZhY2UgQ2hlY2tvdXRFdmVudCB7XG4gKiAgIGN1c3RvbWVySWQ6IHN0cmluZztcbiAqICAgY2FydElkOiBzdHJpbmc7XG4gKiAgIHRpbWVzdGFtcDogc3RyaW5nO1xuICogfVxuICpcbiAqIGNvbnN0IGNoZWNrb3V0RXZlbnQgPSBldmVudDxDaGVja291dEV2ZW50PihcIkNoZWNrb3V0XCIpO1xuICogYGBgXG4gKlxuICogVG8gcHVibGlzaCBldmVudHMsIGNhbGwgdGhlIGBwdWJsaXNoYCBtZXRob2Q6XG4gKiBgYGB0c1xuICogY29uc3QgY2hlY2tvdXRXb3JrZmxvdyA9IHdvcmtmbG93KFwiY2hlY2tvdXRXb3JrZmxvd1wiLCBhc3luYyAocmVxdWVzdCkgPT4ge1xuICogICBhd2FpdCBjaGVja291dEV2ZW50LnB1Ymxpc2goe1xuICogICAgIGN1c3RvbWVySWQ6IHJlcXVlc3QuY3VzdG9tZXJJZCxcbiAqICAgICBjYXJ0SWQ6IHJlcXVlc3QuY2FydElkLFxuICogICAgIHRpbWVzdGFtcDogbmV3IERhdGUoKS50b1RpbWVTdHJpbmcoKVxuICogICB9KTtcbiAqIH0pXG4gKiBgYGBcbiAqXG4gKiBUbyBzdWJzY3JpYmUgdG8gZXZlbnRzLCBjYWxsIHRoZSBgb25gIG1ldGhvZC4gVGhpcyB3aWxsIHJlZ2lzdGVyIGFcbiAqIGhhbmRsZXIgdGhhdCB3aWwgbGJlIGludm9rZWQgZm9yIGV2ZXJ5IGV2ZW50IG9mIHRoaXMgdHlwZSB0aGF0IGlzIHJlY2VpdmVkLlxuICpcbiAqIGBgYHRzXG4gKiBjaGVja291dEV2ZW50Lm9uKGFzeW5jIChjaGVja291dCkgPT4ge1xuICogICBjb25zb2xlLmxvZyhjaGVja291dCk7XG4gKiB9KTtcbiAqIGBgYFxuICpcbiAqIEBwYXJhbSBuYW1lIGEgdW5pcXVlIG5hbWUgdGhhdCBpZGVudGlmaWVzIHRoaXMgZXZlbnQgdHlwZSB3aXRoaW4gdGhlIFNlcnZpY2UuXG4gKiBAcmV0dXJucyBhbiB7QGxpbmsgRXZlbnR9XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBldmVudDxFIGV4dGVuZHMgRXZlbnRQYXlsb2FkPihuYW1lOiBzdHJpbmcpOiBFdmVudDxFPiB7XG4gIGlmIChldmVudHMoKS5oYXMobmFtZSkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGV2ZW50IHdpdGggbmFtZSAnJHtuYW1lfScgYWxyZWFkeSBleGlzdHNgKTtcbiAgfVxuICBjb25zdCBldmVudDogRXZlbnQ8RT4gPSB7XG4gICAgbmFtZSxcbiAgICBvbihoYW5kbGVyKSB7XG4gICAgICBldmVudFN1YnNjcmlwdGlvbnMoKS5wdXNoKHtcbiAgICAgICAgc3Vic2NyaXB0aW9uczogW1xuICAgICAgICAgIHtcbiAgICAgICAgICAgIG5hbWUsXG4gICAgICAgICAgfSxcbiAgICAgICAgXSxcbiAgICAgICAgaGFuZGxlcjogaGFuZGxlciBhcyBFdmVudEhhbmRsZXI8RXZlbnRQYXlsb2FkPixcbiAgICAgIH0pO1xuICAgIH0sXG4gICAgcHVibGlzaCguLi5ldmVudHMpIHtcbiAgICAgIGNvbnN0IGVudmVsb3BlcyA9IGV2ZW50cy5tYXAoKGV2ZW50KSA9PiAoe1xuICAgICAgICBuYW1lLFxuICAgICAgICBldmVudCxcbiAgICAgIH0pKTtcbiAgICAgIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgICAgIHJldHVybiBjcmVhdGVQdWJsaXNoRXZlbnRzQ2FsbChlbnZlbG9wZXMpIGFzIGFueTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHJldHVybiBnZXRTZXJ2aWNlQ2xpZW50KCkucHVibGlzaEV2ZW50cyh7IGV2ZW50czogZW52ZWxvcGVzIH0pO1xuICAgICAgfVxuICAgIH0sXG4gIH07XG4gIGV2ZW50cygpLnNldChuYW1lLCBldmVudCk7XG4gIHJldHVybiBldmVudDtcbn1cbiJdfQ==

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

import { SendSignalProps, Signal, SignalPayload, Workflow, WorkflowClient, WorkflowOutput } from "./index.js";
import { EventualServiceClient } from "./service-client.js";
import { Signal, SendSignalProps, SignalPayload } from "./signals.js";
import { Workflow, WorkflowOutput } from "./workflow.js";
export declare enum ExecutionStatus {

@@ -11,2 +13,3 @@ IN_PROGRESS = "IN_PROGRESS",

startTime: string;
workflowName: string;
parent?: {

@@ -43,6 +46,6 @@ /**

*/
export declare class ExecutionHandle<W extends Workflow<any, any>> {
export declare class ExecutionHandle<W extends Workflow> {
executionId: string;
private workflowClient;
constructor(executionId: string, workflowClient: WorkflowClient);
private serviceClient;
constructor(executionId: string, serviceClient: EventualServiceClient);
/**

@@ -49,0 +52,0 @@ * @return the {@link Execution} with the status, result, error, and other data based on the current status.

@@ -17,5 +17,5 @@ export var ExecutionStatus;

export class ExecutionHandle {
constructor(executionId, workflowClient) {
constructor(executionId, serviceClient) {
this.executionId = executionId;
this.workflowClient = workflowClient;
this.serviceClient = serviceClient;
}

@@ -26,3 +26,3 @@ /**

async getStatus() {
return (await this.workflowClient.getExecution(this.executionId));
return (await this.serviceClient.getExecution(this.executionId));
}

@@ -33,4 +33,4 @@ /**

async signal(signal, payload) {
return this.workflowClient.sendSignal({
executionId: this.executionId,
return this.serviceClient.sendSignal({
execution: this.executionId,
signal: typeof signal === "string" ? signal : signal.id,

@@ -41,2 +41,2 @@ payload,

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTQSxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3pCLDhDQUEyQixDQUFBO0lBQzNCLHdDQUFxQixDQUFBO0lBQ3JCLG9DQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKVyxlQUFlLEtBQWYsZUFBZSxRQUkxQjtBQXdDRCxNQUFNLFVBQVUsaUJBQWlCLENBQy9CLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsTUFBTSxDQUFDO0FBQ3JELENBQUM7QUFFRCxNQUFNLFVBQVUsbUJBQW1CLENBQ2pDLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDO0FBQ3ZELENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQ1MsV0FBbUIsRUFDbEIsY0FBOEI7UUFEL0IsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFDbEIsbUJBQWMsR0FBZCxjQUFjLENBQWdCO0lBQ3JDLENBQUM7SUFFSjs7T0FFRztJQUNJLEtBQUssQ0FBQyxTQUFTO1FBQ3BCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxjQUFjLENBQUMsWUFBWSxDQUM1QyxJQUFJLENBQUMsV0FBVyxDQUNqQixDQUFpQyxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxNQUFNLENBQ2pCLE1BQWdDLEVBQ2hDLE9BQWdCO1FBRWhCLE9BQU8sSUFBSSxDQUFDLGNBQWMsQ0FBQyxVQUFVLENBQUM7WUFDcEMsV0FBVyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzdCLE1BQU0sRUFBRSxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdkQsT0FBTztTQUNSLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIFNlbmRTaWduYWxQcm9wcyxcbiAgU2lnbmFsLFxuICBTaWduYWxQYXlsb2FkLFxuICBXb3JrZmxvdyxcbiAgV29ya2Zsb3dDbGllbnQsXG4gIFdvcmtmbG93T3V0cHV0LFxufSBmcm9tIFwiLi9pbmRleC5qc1wiO1xuXG5leHBvcnQgZW51bSBFeGVjdXRpb25TdGF0dXMge1xuICBJTl9QUk9HUkVTUyA9IFwiSU5fUFJPR1JFU1NcIixcbiAgQ09NUExFVEUgPSBcIkNPTVBMRVRFXCIsXG4gIEZBSUxFRCA9IFwiRkFJTEVEXCIsXG59XG5cbmludGVyZmFjZSBFeGVjdXRpb25CYXNlIHtcbiAgaWQ6IHN0cmluZztcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXM7XG4gIHN0YXJ0VGltZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PGFueSwgYW55Pj4ge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZXhlY3V0aW9uSWQ6IHN0cmluZyxcbiAgICBwcml2YXRlIHdvcmtmbG93Q2xpZW50OiBXb3JrZmxvd0NsaWVudFxuICApIHt9XG5cbiAgLyoqXG4gICAqIEByZXR1cm4gdGhlIHtAbGluayBFeGVjdXRpb259IHdpdGggdGhlIHN0YXR1cywgcmVzdWx0LCBlcnJvciwgYW5kIG90aGVyIGRhdGEgYmFzZWQgb24gdGhlIGN1cnJlbnQgc3RhdHVzLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIGdldFN0YXR1cygpOiBQcm9taXNlPEV4ZWN1dGlvbjxXb3JrZmxvd091dHB1dDxXPj4+IHtcbiAgICByZXR1cm4gKGF3YWl0IHRoaXMud29ya2Zsb3dDbGllbnQuZ2V0RXhlY3V0aW9uKFxuICAgICAgdGhpcy5leGVjdXRpb25JZFxuICAgICkpIGFzIEV4ZWN1dGlvbjxXb3JrZmxvd091dHB1dDxXPj47XG4gIH1cblxuICAvKipcbiAgICogU2VuZCBhIHtAbGluayBzaWduYWx9IHRvIHRoaXMgZXhlY3V0aW9uLlxuICAgKi9cbiAgcHVibGljIGFzeW5jIHNpZ25hbDxQYXlsb2FkID0gYW55PihcbiAgICBzaWduYWw6IHN0cmluZyB8IFNpZ25hbDxQYXlsb2FkPixcbiAgICBwYXlsb2FkOiBQYXlsb2FkXG4gICk6IFByb21pc2U8dm9pZD4ge1xuICAgIHJldHVybiB0aGlzLndvcmtmbG93Q2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uSWQ6IHRoaXMuZXhlY3V0aW9uSWQsXG4gICAgICBzaWduYWw6IHR5cGVvZiBzaWduYWwgPT09IFwic3RyaW5nXCIgPyBzaWduYWwgOiBzaWduYWwuaWQsXG4gICAgICBwYXlsb2FkLFxuICAgIH0pO1xuICB9XG59XG5cbi8qKlxuICogQSByZWZlcmVuY2UgdG8gYW4gZXhlY3V0aW9uIHN0YXJ0ZWQgYnkgYW5vdGhlciB3b3JrZmxvdy5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBDaGlsZEV4ZWN1dGlvbiB7XG4gIC8qKlxuICAgKiBBbGxvd3MgYSB7QGxpbmsgd29ya2Zsb3d9IHRvIHNlbmQgYSBzaWduYWwgdG8gdGhlIHdvcmtmbG93IHtAbGluayBFeGVjdXRpb259LlxuICAgKlxuICAgKiBgYGB0c1xuICAgKiBjb25zdCBteVNpZ25hbCA9IHNpZ25hbDxzdHJpbmc+KFwiTXlTaWduYWxcIik7XG4gICAqIGNvbnN0IGNoaWxkV2YgPSB3b3JrZmxvdyguLi4pO1xuICAgKiB3b3JrZmxvdyhcIndmXCIsIGFzeW5jICgpID0+IHtcbiAgICogICAgY29uc3QgY2hpbGQgPSBjaGlsZFdmKCk7XG4gICAqICAgIGNoaWxkLnNpZ25hbChteVNpZ25hbCk7XG4gICAqICAgIGF3YWl0IGNoaWxkO1xuICAgKiB9KVxuICAgKiBgYGBcbiAgICpcbiAgICogQHBhcmFtIGlkIGFuIG9wdGlvbmFsLCBleGVjdXRpb24gdW5pcXVlIElELCB3aWxsIGJlIHVzZWQgdG8gZGUtZHVwZSB0aGUgc2lnbmFsIGF0IHRoZSB0YXJnZXQgZXhlY3V0aW9uLlxuICAgKi9cbiAgc2lnbmFsPFMgZXh0ZW5kcyBTaWduYWw8YW55Pj4oXG4gICAgc2lnbmFsOiBTLFxuICAgIC4uLmFyZ3M6IFNlbmRTaWduYWxQcm9wczxTaWduYWxQYXlsb2FkPFM+PlxuICApOiBQcm9taXNlPHZvaWQ+O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2V4ZWN1dGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJQSxNQUFNLENBQU4sSUFBWSxlQUlYO0FBSkQsV0FBWSxlQUFlO0lBQ3pCLDhDQUEyQixDQUFBO0lBQzNCLHdDQUFxQixDQUFBO0lBQ3JCLG9DQUFpQixDQUFBO0FBQ25CLENBQUMsRUFKVyxlQUFlLEtBQWYsZUFBZSxRQUkxQjtBQXlDRCxNQUFNLFVBQVUsaUJBQWlCLENBQy9CLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsTUFBTSxDQUFDO0FBQ3JELENBQUM7QUFFRCxNQUFNLFVBQVUsbUJBQW1CLENBQ2pDLFNBQW9CO0lBRXBCLE9BQU8sU0FBUyxDQUFDLE1BQU0sS0FBSyxlQUFlLENBQUMsUUFBUSxDQUFDO0FBQ3ZELENBQUM7QUFFRDs7R0FFRztBQUNILE1BQU0sT0FBTyxlQUFlO0lBQzFCLFlBQ1MsV0FBbUIsRUFDbEIsYUFBb0M7UUFEckMsZ0JBQVcsR0FBWCxXQUFXLENBQVE7UUFDbEIsa0JBQWEsR0FBYixhQUFhLENBQXVCO0lBQzNDLENBQUM7SUFFSjs7T0FFRztJQUNJLEtBQUssQ0FBQyxTQUFTO1FBQ3BCLE9BQU8sQ0FBQyxNQUFNLElBQUksQ0FBQyxhQUFhLENBQUMsWUFBWSxDQUMzQyxJQUFJLENBQUMsV0FBVyxDQUNqQixDQUFpQyxDQUFDO0lBQ3JDLENBQUM7SUFFRDs7T0FFRztJQUNJLEtBQUssQ0FBQyxNQUFNLENBQ2pCLE1BQWdDLEVBQ2hDLE9BQWdCO1FBRWhCLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUM7WUFDbkMsU0FBUyxFQUFFLElBQUksQ0FBQyxXQUFXO1lBQzNCLE1BQU0sRUFBRSxPQUFPLE1BQU0sS0FBSyxRQUFRLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLEVBQUU7WUFDdkQsT0FBTztTQUNSLENBQUMsQ0FBQztJQUNMLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5pbXBvcnQgeyBTaWduYWwsIFNlbmRTaWduYWxQcm9wcywgU2lnbmFsUGF5bG9hZCB9IGZyb20gXCIuL3NpZ25hbHMuanNcIjtcbmltcG9ydCB7IFdvcmtmbG93LCBXb3JrZmxvd091dHB1dCB9IGZyb20gXCIuL3dvcmtmbG93LmpzXCI7XG5cbmV4cG9ydCBlbnVtIEV4ZWN1dGlvblN0YXR1cyB7XG4gIElOX1BST0dSRVNTID0gXCJJTl9QUk9HUkVTU1wiLFxuICBDT01QTEVURSA9IFwiQ09NUExFVEVcIixcbiAgRkFJTEVEID0gXCJGQUlMRURcIixcbn1cblxuaW50ZXJmYWNlIEV4ZWN1dGlvbkJhc2Uge1xuICBpZDogc3RyaW5nO1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cztcbiAgc3RhcnRUaW1lOiBzdHJpbmc7XG4gIHdvcmtmbG93TmFtZTogc3RyaW5nO1xuICBwYXJlbnQ/OiB7XG4gICAgLyoqXG4gICAgICogU2VxIG51bWJlciB3aGVuIHRoaXMgZXhlY3V0aW9uIGlzIHRoZSBjaGlsZCBvZiBhbm90aGVyIHdvcmtmbG93LlxuICAgICAqL1xuICAgIHNlcTogbnVtYmVyO1xuICAgIC8qKlxuICAgICAqIElkIG9mIHRoZSBwYXJlbnQgd29ya2Zsb3csIHdoaWxlIHByZXNlbnQuXG4gICAgICovXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZztcbiAgfTtcbn1cblxuZXhwb3J0IHR5cGUgRXhlY3V0aW9uPFJlc3VsdCA9IGFueT4gPVxuICB8IEluUHJvZ3Jlc3NFeGVjdXRpb25cbiAgfCBDb21wbGV0ZUV4ZWN1dGlvbjxSZXN1bHQ+XG4gIHwgRmFpbGVkRXhlY3V0aW9uO1xuXG5leHBvcnQgaW50ZXJmYWNlIEluUHJvZ3Jlc3NFeGVjdXRpb24gZXh0ZW5kcyBFeGVjdXRpb25CYXNlIHtcbiAgc3RhdHVzOiBFeGVjdXRpb25TdGF0dXMuSU5fUFJPR1JFU1M7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgQ29tcGxldGVFeGVjdXRpb248UmVzdWx0ID0gYW55PiBleHRlbmRzIEV4ZWN1dGlvbkJhc2Uge1xuICBzdGF0dXM6IEV4ZWN1dGlvblN0YXR1cy5DT01QTEVURTtcbiAgZW5kVGltZTogc3RyaW5nO1xuICByZXN1bHQ/OiBSZXN1bHQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRmFpbGVkRXhlY3V0aW9uIGV4dGVuZHMgRXhlY3V0aW9uQmFzZSB7XG4gIHN0YXR1czogRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbiAgZW5kVGltZTogc3RyaW5nO1xuICBlcnJvcjogc3RyaW5nO1xuICBtZXNzYWdlOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc0ZhaWxlZEV4ZWN1dGlvbihcbiAgZXhlY3V0aW9uOiBFeGVjdXRpb25cbik6IGV4ZWN1dGlvbiBpcyBGYWlsZWRFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkZBSUxFRDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGlzQ29tcGxldGVFeGVjdXRpb24oXG4gIGV4ZWN1dGlvbjogRXhlY3V0aW9uXG4pOiBleGVjdXRpb24gaXMgQ29tcGxldGVFeGVjdXRpb24ge1xuICByZXR1cm4gZXhlY3V0aW9uLnN0YXR1cyA9PT0gRXhlY3V0aW9uU3RhdHVzLkNPTVBMRVRFO1xufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGEgcnVubmluZyBleGVjdXRpb24uXG4gKi9cbmV4cG9ydCBjbGFzcyBFeGVjdXRpb25IYW5kbGU8VyBleHRlbmRzIFdvcmtmbG93PiB7XG4gIGNvbnN0cnVjdG9yKFxuICAgIHB1YmxpYyBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIHByaXZhdGUgc2VydmljZUNsaWVudDogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50XG4gICkge31cblxuICAvKipcbiAgICogQHJldHVybiB0aGUge0BsaW5rIEV4ZWN1dGlvbn0gd2l0aCB0aGUgc3RhdHVzLCByZXN1bHQsIGVycm9yLCBhbmQgb3RoZXIgZGF0YSBiYXNlZCBvbiB0aGUgY3VycmVudCBzdGF0dXMuXG4gICAqL1xuICBwdWJsaWMgYXN5bmMgZ2V0U3RhdHVzKCk6IFByb21pc2U8RXhlY3V0aW9uPFdvcmtmbG93T3V0cHV0PFc+Pj4ge1xuICAgIHJldHVybiAoYXdhaXQgdGhpcy5zZXJ2aWNlQ2xpZW50LmdldEV4ZWN1dGlvbihcbiAgICAgIHRoaXMuZXhlY3V0aW9uSWRcbiAgICApKSBhcyBFeGVjdXRpb248V29ya2Zsb3dPdXRwdXQ8Vz4+O1xuICB9XG5cbiAgLyoqXG4gICAqIFNlbmQgYSB7QGxpbmsgc2lnbmFsfSB0byB0aGlzIGV4ZWN1dGlvbi5cbiAgICovXG4gIHB1YmxpYyBhc3luYyBzaWduYWw8UGF5bG9hZCA9IGFueT4oXG4gICAgc2lnbmFsOiBzdHJpbmcgfCBTaWduYWw8UGF5bG9hZD4sXG4gICAgcGF5bG9hZDogUGF5bG9hZFxuICApOiBQcm9taXNlPHZvaWQ+IHtcbiAgICByZXR1cm4gdGhpcy5zZXJ2aWNlQ2xpZW50LnNlbmRTaWduYWwoe1xuICAgICAgZXhlY3V0aW9uOiB0aGlzLmV4ZWN1dGlvbklkLFxuICAgICAgc2lnbmFsOiB0eXBlb2Ygc2lnbmFsID09PSBcInN0cmluZ1wiID8gc2lnbmFsIDogc2lnbmFsLmlkLFxuICAgICAgcGF5bG9hZCxcbiAgICB9KTtcbiAgfVxufVxuXG4vKipcbiAqIEEgcmVmZXJlbmNlIHRvIGFuIGV4ZWN1dGlvbiBzdGFydGVkIGJ5IGFub3RoZXIgd29ya2Zsb3cuXG4gKi9cbmV4cG9ydCBpbnRlcmZhY2UgQ2hpbGRFeGVjdXRpb24ge1xuICAvKipcbiAgICogQWxsb3dzIGEge0BsaW5rIHdvcmtmbG93fSB0byBzZW5kIGEgc2lnbmFsIHRvIHRoZSB3b3JrZmxvdyB7QGxpbmsgRXhlY3V0aW9ufS5cbiAgICpcbiAgICogYGBgdHNcbiAgICogY29uc3QgbXlTaWduYWwgPSBzaWduYWw8c3RyaW5nPihcIk15U2lnbmFsXCIpO1xuICAgKiBjb25zdCBjaGlsZFdmID0gd29ya2Zsb3coLi4uKTtcbiAgICogd29ya2Zsb3coXCJ3ZlwiLCBhc3luYyAoKSA9PiB7XG4gICAqICAgIGNvbnN0IGNoaWxkID0gY2hpbGRXZigpO1xuICAgKiAgICBjaGlsZC5zaWduYWwobXlTaWduYWwpO1xuICAgKiAgICBhd2FpdCBjaGlsZDtcbiAgICogfSlcbiAgICogYGBgXG4gICAqXG4gICAqIEBwYXJhbSBpZCBhbiBvcHRpb25hbCwgZXhlY3V0aW9uIHVuaXF1ZSBJRCwgd2lsbCBiZSB1c2VkIHRvIGRlLWR1cGUgdGhlIHNpZ25hbCBhdCB0aGUgdGFyZ2V0IGV4ZWN1dGlvbi5cbiAgICovXG4gIHNpZ25hbDxTIGV4dGVuZHMgU2lnbmFsPGFueT4+KFxuICAgIHNpZ25hbDogUyxcbiAgICAuLi5hcmdzOiBTZW5kU2lnbmFsUHJvcHM8U2lnbmFsUGF5bG9hZDxTPj5cbiAgKTogUHJvbWlzZTx2b2lkPjtcbn1cbiJdfQ==
import { Event, EventSubscription } from "./event.js";
import { ActivityContext, ActivityHandler } from "./activity.js";
import type { Eventual, EventualCallCollector } from "./eventual.js";
import { EventClient } from "./runtime/clients/event-client.js";
import type { WorkflowClient } from "./runtime/clients/workflow-client.js";
import type { Workflow } from "./workflow.js";
import { EventualServiceClient } from "./service-client.js";
declare global {

@@ -34,3 +33,3 @@ var _eventual: {

*/
workflowClient?: WorkflowClient;
serviceClient?: EventualServiceClient;
/**

@@ -46,8 +45,2 @@ * A global variable storing a map of event name (which is globally unique)

eventSubscriptions?: EventSubscription[];
/**
* A global variable for storing the {@link EventClient}
*
* This is initialized by Eventual's harness functions
*/
eventClient?: EventClient;
};

@@ -64,22 +57,13 @@ }

/**
* Register the global workflow client used by workflow functions
* Register the global service client used by workflow functions
* to start workflows within an eventual-controlled environment.
*/
export declare function registerWorkflowClient(client: WorkflowClient): void;
export declare function registerServiceClient(client: EventualServiceClient): void;
/**
* Get the global workflow client.
* Get the global service client.
*/
export declare function getWorkflowClient(): WorkflowClient;
export declare function getServiceClient(): EventualServiceClient;
export declare function setActivityContext(context: ActivityContext): void;
export declare function clearActivityContext(): void;
export declare function getActivityContext(): ActivityContext;
/**
* Register the global event client sued by the event emit functions
* to emit events within an eventual-controlled environment.
*/
export declare function registerEventClient(client: EventClient): void;
/**
* Get the global event client.
*/
export declare function getEventClient(): EventClient;
//# sourceMappingURL=global.d.ts.map

@@ -26,16 +26,16 @@ globalThis._eventual = {};

/**
* Register the global workflow client used by workflow functions
* Register the global service client used by workflow functions
* to start workflows within an eventual-controlled environment.
*/
export function registerWorkflowClient(client) {
globalThis._eventual.workflowClient = client;
export function registerServiceClient(client) {
globalThis._eventual.serviceClient = client;
}
/**
* Get the global workflow client.
* Get the global service client.
*/
export function getWorkflowClient() {
if (globalThis._eventual.workflowClient === undefined) {
export function getServiceClient() {
if (globalThis._eventual.serviceClient === undefined) {
throw new Error(`WorkflowClient is not registered`);
}
return globalThis._eventual.workflowClient;
return globalThis._eventual.serviceClient;
}

@@ -55,18 +55,2 @@ export function setActivityContext(context) {

}
/**
* Register the global event client sued by the event emit functions
* to emit events within an eventual-controlled environment.
*/
export function registerEventClient(client) {
globalThis._eventual.eventClient = client;
}
/**
* Get the global event client.
*/
export function getEventClient() {
if (globalThis._eventual.eventClient === undefined) {
throw new Error(`EventClient is not registered`);
}
return globalThis._eventual.eventClient;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"global.js","sourceRoot":"","sources":["../../src/global.ts"],"names":[],"mappings":"AAwDA,UAAU,CAAC,SAAS,GAAG,EAAE,CAAC;AAE1B,MAAM,CAAC,MAAM,SAAS,GAAG,GAA0B,EAAE,CACnD,CAAC,UAAU,CAAC,SAAS,CAAC,SAAS,KAAK,IAAI,GAAG,EAAoB,CAAC,CAAC;AAEnE,MAAM,CAAC,MAAM,MAAM,GAAG,GAAuB,EAAE,CAC7C,CAAC,UAAU,CAAC,SAAS,CAAC,MAAM,KAAK,IAAI,GAAG,EAAiB,CAAC,CAAC;AAE7D,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAwB,EAAE,CAC1D,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,UAAU,uBAAuB;IACrC,UAAU,CAAC,SAAS,CAAC,kBAAkB,GAAG,EAAE,CAAC;AAC/C,CAAC;AAED,MAAM,CAAC,MAAM,kBAAkB,GAAG,GAAyC,EAAE,CAC3E,CAAC,UAAU,CAAC,SAAS,CAAC,kBAAkB,KAAK,EAAE,CAAC,CAAC;AAEnD,MAAM,iBAAiB,GAAG,GAA0B,EAAE;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,iBAAiB,CAAC;IACzD,IAAI,CAAC,SAAS,EAAE;QACd,MAAM,IAAI,KAAK,CAAC,gCAAgC,CAAC,CAAC;KACnD;IACD,OAAO,SAAS,CAAC;AACnB,CAAC,CAAC;AAEF,MAAM,UAAU,gBAAgB,CAAqB,QAAW;IAC9D,OAAO,iBAAiB,EAAE,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;AACpD,CAAC;AAED,MAAM,UAAU,oBAAoB,CAAC,SAAgC;IACnE,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,sBAAsB;IACpC,UAAU,CAAC,SAAS,CAAC,iBAAiB,GAAG,SAAS,CAAC;AACrD,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,sBAAsB,CAAC,MAAsB;IAC3D,UAAU,CAAC,SAAS,CAAC,cAAc,GAAG,MAAM,CAAC;AAC/C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,iBAAiB;IAC/B,IAAI,UAAU,CAAC,SAAS,CAAC,cAAc,KAAK,SAAS,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,kCAAkC,CAAC,CAAC;KACrD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,cAAc,CAAC;AAC7C,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,OAAwB;IACzD,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,OAAO,CAAC;AACjD,CAAC;AAED,MAAM,UAAU,oBAAoB;IAClC,UAAU,CAAC,SAAS,CAAC,eAAe,GAAG,SAAS,CAAC;AACnD,CAAC;AAED,MAAM,UAAU,kBAAkB;IAChC,MAAM,OAAO,GAAG,UAAU,CAAC,SAAS,CAAC,eAAe,CAAC;IAErD,IAAI,CAAC,OAAO,EAAE;QACZ,MAAM,IAAI,KAAK,CACb,kFAAkF,CACnF,CAAC;KACH;IACD,OAAO,OAAO,CAAC;AACjB,CAAC;AAED;;;GAGG;AACH,MAAM,UAAU,mBAAmB,CAAC,MAAmB;IACrD,UAAU,CAAC,SAAS,CAAC,WAAW,GAAG,MAAM,CAAC;AAC5C,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,cAAc;IAC5B,IAAI,UAAU,CAAC,SAAS,CAAC,WAAW,KAAK,SAAS,EAAE;QAClD,MAAM,IAAI,KAAK,CAAC,+BAA+B,CAAC,CAAC;KAClD;IACD,OAAO,UAAU,CAAC,SAAS,CAAC,WAAW,CAAC;AAC1C,CAAC","sourcesContent":["import { Event, EventSubscription } from \"./event.js\";\nimport { ActivityContext, ActivityHandler } from \"./activity.js\";\nimport type { Eventual, EventualCallCollector } from \"./eventual.js\";\nimport { EventClient } from \"./runtime/clients/event-client.js\";\nimport type { WorkflowClient } from \"./runtime/clients/workflow-client.js\";\nimport type { Workflow } from \"./workflow.js\";\n\ndeclare global {\n  // eslint-disable-next-line no-var\n  var _eventual: {\n    /**\n     * Data about the current activity assigned before running an activity on an the activity worker.\n     */\n    activityContext?: ActivityContext;\n    /**\n     * An object used by the interpreter to collect {@link Eventual}s while running a workflow code.\n     *\n     * Set by the interpreter only when needed.\n     */\n    eventualCollector?: EventualCallCollector;\n    /**\n     * Callable activities which register themselves in an activity worker.\n     */\n    callableActivities?: Record<string, ActivityHandler<any>>;\n    /**\n     * Available workflows which have registered themselves.\n     *\n     * Used by the orchestrator, activity worker, and other scopes to interact with workflows in\n     * a service.\n     */\n    workflows?: Map<string, Workflow>;\n    /**\n     * A global variable for storing the WorkflowClient\n     * this is initialized by Eventual's harness lambda functions\n     */\n    workflowClient?: WorkflowClient;\n    /**\n     * A global variable storing a map of event name (which is globally unique)\n     * to the {@link Event} declaration instance.\n     */\n    events?: Map<string, Event>;\n    /**\n     * A global variable storing a list of all {@link EventSubscription}s declared\n     * within this application.\n     */\n    eventSubscriptions?: EventSubscription[];\n\n    /**\n     * A global variable for storing the {@link EventClient}\n     *\n     * This is initialized by Eventual's harness functions\n     */\n    eventClient?: EventClient;\n  };\n}\n\nglobalThis._eventual = {};\n\nexport const workflows = (): Map<string, Workflow> =>\n  (globalThis._eventual.workflows ??= new Map<string, Workflow>());\n\nexport const events = (): Map<string, Event> =>\n  (globalThis._eventual.events ??= new Map<string, Event>());\n\nexport const eventSubscriptions = (): EventSubscription[] =>\n  (globalThis._eventual.eventSubscriptions ??= []);\n\nexport function clearEventSubscriptions() {\n  globalThis._eventual.eventSubscriptions = [];\n}\n\nexport const callableActivities = (): Record<string, ActivityHandler<any>> =>\n  (globalThis._eventual.callableActivities ??= {});\n\nconst eventualCollector = (): EventualCallCollector => {\n  const collector = globalThis._eventual.eventualCollector;\n  if (!collector) {\n    throw new Error(\"No Eventual Collector Provided\");\n  }\n  return collector;\n};\n\nexport function registerEventual<A extends Eventual>(eventual: A): A {\n  return eventualCollector().pushEventual(eventual);\n}\n\nexport function setEventualCollector(collector: EventualCallCollector) {\n  globalThis._eventual.eventualCollector = collector;\n}\n\nexport function clearEventualCollector() {\n  globalThis._eventual.eventualCollector = undefined;\n}\n\n/**\n * Register the global workflow client used by workflow functions\n * to start workflows within an eventual-controlled environment.\n */\nexport function registerWorkflowClient(client: WorkflowClient) {\n  globalThis._eventual.workflowClient = client;\n}\n\n/**\n * Get the global workflow client.\n */\nexport function getWorkflowClient(): WorkflowClient {\n  if (globalThis._eventual.workflowClient === undefined) {\n    throw new Error(`WorkflowClient is not registered`);\n  }\n  return globalThis._eventual.workflowClient;\n}\n\nexport function setActivityContext(context: ActivityContext) {\n  globalThis._eventual.activityContext = context;\n}\n\nexport function clearActivityContext() {\n  globalThis._eventual.activityContext = undefined;\n}\n\nexport function getActivityContext(): ActivityContext {\n  const context = globalThis._eventual.activityContext;\n\n  if (!context) {\n    throw new Error(\n      \"Activity Context has not been registered yet or this is not the activity worker.\"\n    );\n  }\n  return context;\n}\n\n/**\n * Register the global event client sued by the event emit functions\n * to emit events within an eventual-controlled environment.\n */\nexport function registerEventClient(client: EventClient) {\n  globalThis._eventual.eventClient = client;\n}\n\n/**\n * Get the global event client.\n */\nexport function getEventClient(): EventClient {\n  if (globalThis._eventual.eventClient === undefined) {\n    throw new Error(`EventClient is not registered`);\n  }\n  return globalThis._eventual.eventClient;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2xvYmFsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2dsb2JhbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFnREEsVUFBVSxDQUFDLFNBQVMsR0FBRyxFQUFFLENBQUM7QUFFMUIsTUFBTSxDQUFDLE1BQU0sU0FBUyxHQUFHLEdBQTBCLEVBQUUsQ0FDbkQsQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLFNBQVMsS0FBSyxJQUFJLEdBQUcsRUFBb0IsQ0FBQyxDQUFDO0FBRW5FLE1BQU0sQ0FBQyxNQUFNLE1BQU0sR0FBRyxHQUF1QixFQUFFLENBQzdDLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxNQUFNLEtBQUssSUFBSSxHQUFHLEVBQWlCLENBQUMsQ0FBQztBQUU3RCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxHQUF3QixFQUFFLENBQzFELENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUVuRCxNQUFNLFVBQVUsdUJBQXVCO0lBQ3JDLFVBQVUsQ0FBQyxTQUFTLENBQUMsa0JBQWtCLEdBQUcsRUFBRSxDQUFDO0FBQy9DLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxHQUF5QyxFQUFFLENBQzNFLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxrQkFBa0IsS0FBSyxFQUFFLENBQUMsQ0FBQztBQUVuRCxNQUFNLGlCQUFpQixHQUFHLEdBQTBCLEVBQUU7SUFDcEQsTUFBTSxTQUFTLEdBQUcsVUFBVSxDQUFDLFNBQVMsQ0FBQyxpQkFBaUIsQ0FBQztJQUN6RCxJQUFJLENBQUMsU0FBUyxFQUFFO1FBQ2QsTUFBTSxJQUFJLEtBQUssQ0FBQyxnQ0FBZ0MsQ0FBQyxDQUFDO0tBQ25EO0lBQ0QsT0FBTyxTQUFTLENBQUM7QUFDbkIsQ0FBQyxDQUFDO0FBRUYsTUFBTSxVQUFVLGdCQUFnQixDQUFxQixRQUFXO0lBQzlELE9BQU8saUJBQWlCLEVBQUUsQ0FBQyxZQUFZLENBQUMsUUFBUSxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0IsQ0FBQyxTQUFnQztJQUNuRSxVQUFVLENBQUMsU0FBUyxDQUFDLGlCQUFpQixHQUFHLFNBQVMsQ0FBQztBQUNyRCxDQUFDO0FBRUQsTUFBTSxVQUFVLHNCQUFzQjtJQUNwQyxVQUFVLENBQUMsU0FBUyxDQUFDLGlCQUFpQixHQUFHLFNBQVMsQ0FBQztBQUNyRCxDQUFDO0FBRUQ7OztHQUdHO0FBQ0gsTUFBTSxVQUFVLHFCQUFxQixDQUFDLE1BQTZCO0lBQ2pFLFVBQVUsQ0FBQyxTQUFTLENBQUMsYUFBYSxHQUFHLE1BQU0sQ0FBQztBQUM5QyxDQUFDO0FBRUQ7O0dBRUc7QUFDSCxNQUFNLFVBQVUsZ0JBQWdCO0lBQzlCLElBQUksVUFBVSxDQUFDLFNBQVMsQ0FBQyxhQUFhLEtBQUssU0FBUyxFQUFFO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsa0NBQWtDLENBQUMsQ0FBQztLQUNyRDtJQUNELE9BQU8sVUFBVSxDQUFDLFNBQVMsQ0FBQyxhQUFhLENBQUM7QUFDNUMsQ0FBQztBQUVELE1BQU0sVUFBVSxrQkFBa0IsQ0FBQyxPQUF3QjtJQUN6RCxVQUFVLENBQUMsU0FBUyxDQUFDLGVBQWUsR0FBRyxPQUFPLENBQUM7QUFDakQsQ0FBQztBQUVELE1BQU0sVUFBVSxvQkFBb0I7SUFDbEMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxlQUFlLEdBQUcsU0FBUyxDQUFDO0FBQ25ELENBQUM7QUFFRCxNQUFNLFVBQVUsa0JBQWtCO0lBQ2hDLE1BQU0sT0FBTyxHQUFHLFVBQVUsQ0FBQyxTQUFTLENBQUMsZUFBZSxDQUFDO0lBRXJELElBQUksQ0FBQyxPQUFPLEVBQUU7UUFDWixNQUFNLElBQUksS0FBSyxDQUNiLGtGQUFrRixDQUNuRixDQUFDO0tBQ0g7SUFDRCxPQUFPLE9BQU8sQ0FBQztBQUNqQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRXZlbnQsIEV2ZW50U3Vic2NyaXB0aW9uIH0gZnJvbSBcIi4vZXZlbnQuanNcIjtcbmltcG9ydCB7IEFjdGl2aXR5Q29udGV4dCwgQWN0aXZpdHlIYW5kbGVyIH0gZnJvbSBcIi4vYWN0aXZpdHkuanNcIjtcbmltcG9ydCB0eXBlIHsgRXZlbnR1YWwsIEV2ZW50dWFsQ2FsbENvbGxlY3RvciB9IGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFdvcmtmbG93IH0gZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcbmltcG9ydCB7IEV2ZW50dWFsU2VydmljZUNsaWVudCB9IGZyb20gXCIuL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIG5vLXZhclxuICB2YXIgX2V2ZW50dWFsOiB7XG4gICAgLyoqXG4gICAgICogRGF0YSBhYm91dCB0aGUgY3VycmVudCBhY3Rpdml0eSBhc3NpZ25lZCBiZWZvcmUgcnVubmluZyBhbiBhY3Rpdml0eSBvbiBhbiB0aGUgYWN0aXZpdHkgd29ya2VyLlxuICAgICAqL1xuICAgIGFjdGl2aXR5Q29udGV4dD86IEFjdGl2aXR5Q29udGV4dDtcbiAgICAvKipcbiAgICAgKiBBbiBvYmplY3QgdXNlZCBieSB0aGUgaW50ZXJwcmV0ZXIgdG8gY29sbGVjdCB7QGxpbmsgRXZlbnR1YWx9cyB3aGlsZSBydW5uaW5nIGEgd29ya2Zsb3cgY29kZS5cbiAgICAgKlxuICAgICAqIFNldCBieSB0aGUgaW50ZXJwcmV0ZXIgb25seSB3aGVuIG5lZWRlZC5cbiAgICAgKi9cbiAgICBldmVudHVhbENvbGxlY3Rvcj86IEV2ZW50dWFsQ2FsbENvbGxlY3RvcjtcbiAgICAvKipcbiAgICAgKiBDYWxsYWJsZSBhY3Rpdml0aWVzIHdoaWNoIHJlZ2lzdGVyIHRoZW1zZWx2ZXMgaW4gYW4gYWN0aXZpdHkgd29ya2VyLlxuICAgICAqL1xuICAgIGNhbGxhYmxlQWN0aXZpdGllcz86IFJlY29yZDxzdHJpbmcsIEFjdGl2aXR5SGFuZGxlcjxhbnk+PjtcbiAgICAvKipcbiAgICAgKiBBdmFpbGFibGUgd29ya2Zsb3dzIHdoaWNoIGhhdmUgcmVnaXN0ZXJlZCB0aGVtc2VsdmVzLlxuICAgICAqXG4gICAgICogVXNlZCBieSB0aGUgb3JjaGVzdHJhdG9yLCBhY3Rpdml0eSB3b3JrZXIsIGFuZCBvdGhlciBzY29wZXMgdG8gaW50ZXJhY3Qgd2l0aCB3b3JrZmxvd3MgaW5cbiAgICAgKiBhIHNlcnZpY2UuXG4gICAgICovXG4gICAgd29ya2Zsb3dzPzogTWFwPHN0cmluZywgV29ya2Zsb3c+O1xuICAgIC8qKlxuICAgICAqIEEgZ2xvYmFsIHZhcmlhYmxlIGZvciBzdG9yaW5nIHRoZSBXb3JrZmxvd0NsaWVudFxuICAgICAqIHRoaXMgaXMgaW5pdGlhbGl6ZWQgYnkgRXZlbnR1YWwncyBoYXJuZXNzIGxhbWJkYSBmdW5jdGlvbnNcbiAgICAgKi9cbiAgICBzZXJ2aWNlQ2xpZW50PzogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50O1xuICAgIC8qKlxuICAgICAqIEEgZ2xvYmFsIHZhcmlhYmxlIHN0b3JpbmcgYSBtYXAgb2YgZXZlbnQgbmFtZSAod2hpY2ggaXMgZ2xvYmFsbHkgdW5pcXVlKVxuICAgICAqIHRvIHRoZSB7QGxpbmsgRXZlbnR9IGRlY2xhcmF0aW9uIGluc3RhbmNlLlxuICAgICAqL1xuICAgIGV2ZW50cz86IE1hcDxzdHJpbmcsIEV2ZW50PjtcbiAgICAvKipcbiAgICAgKiBBIGdsb2JhbCB2YXJpYWJsZSBzdG9yaW5nIGEgbGlzdCBvZiBhbGwge0BsaW5rIEV2ZW50U3Vic2NyaXB0aW9ufXMgZGVjbGFyZWRcbiAgICAgKiB3aXRoaW4gdGhpcyBhcHBsaWNhdGlvbi5cbiAgICAgKi9cbiAgICBldmVudFN1YnNjcmlwdGlvbnM/OiBFdmVudFN1YnNjcmlwdGlvbltdO1xuICB9O1xufVxuXG5nbG9iYWxUaGlzLl9ldmVudHVhbCA9IHt9O1xuXG5leHBvcnQgY29uc3Qgd29ya2Zsb3dzID0gKCk6IE1hcDxzdHJpbmcsIFdvcmtmbG93PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwud29ya2Zsb3dzID8/PSBuZXcgTWFwPHN0cmluZywgV29ya2Zsb3c+KCkpO1xuXG5leHBvcnQgY29uc3QgZXZlbnRzID0gKCk6IE1hcDxzdHJpbmcsIEV2ZW50PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwuZXZlbnRzID8/PSBuZXcgTWFwPHN0cmluZywgRXZlbnQ+KCkpO1xuXG5leHBvcnQgY29uc3QgZXZlbnRTdWJzY3JpcHRpb25zID0gKCk6IEV2ZW50U3Vic2NyaXB0aW9uW10gPT5cbiAgKGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50U3Vic2NyaXB0aW9ucyA/Pz0gW10pO1xuXG5leHBvcnQgZnVuY3Rpb24gY2xlYXJFdmVudFN1YnNjcmlwdGlvbnMoKSB7XG4gIGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50U3Vic2NyaXB0aW9ucyA9IFtdO1xufVxuXG5leHBvcnQgY29uc3QgY2FsbGFibGVBY3Rpdml0aWVzID0gKCk6IFJlY29yZDxzdHJpbmcsIEFjdGl2aXR5SGFuZGxlcjxhbnk+PiA9PlxuICAoZ2xvYmFsVGhpcy5fZXZlbnR1YWwuY2FsbGFibGVBY3Rpdml0aWVzID8/PSB7fSk7XG5cbmNvbnN0IGV2ZW50dWFsQ29sbGVjdG9yID0gKCk6IEV2ZW50dWFsQ2FsbENvbGxlY3RvciA9PiB7XG4gIGNvbnN0IGNvbGxlY3RvciA9IGdsb2JhbFRoaXMuX2V2ZW50dWFsLmV2ZW50dWFsQ29sbGVjdG9yO1xuICBpZiAoIWNvbGxlY3Rvcikge1xuICAgIHRocm93IG5ldyBFcnJvcihcIk5vIEV2ZW50dWFsIENvbGxlY3RvciBQcm92aWRlZFwiKTtcbiAgfVxuICByZXR1cm4gY29sbGVjdG9yO1xufTtcblxuZXhwb3J0IGZ1bmN0aW9uIHJlZ2lzdGVyRXZlbnR1YWw8QSBleHRlbmRzIEV2ZW50dWFsPihldmVudHVhbDogQSk6IEEge1xuICByZXR1cm4gZXZlbnR1YWxDb2xsZWN0b3IoKS5wdXNoRXZlbnR1YWwoZXZlbnR1YWwpO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0RXZlbnR1YWxDb2xsZWN0b3IoY29sbGVjdG9yOiBFdmVudHVhbENhbGxDb2xsZWN0b3IpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuZXZlbnR1YWxDb2xsZWN0b3IgPSBjb2xsZWN0b3I7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjbGVhckV2ZW50dWFsQ29sbGVjdG9yKCkge1xuICBnbG9iYWxUaGlzLl9ldmVudHVhbC5ldmVudHVhbENvbGxlY3RvciA9IHVuZGVmaW5lZDtcbn1cblxuLyoqXG4gKiBSZWdpc3RlciB0aGUgZ2xvYmFsIHNlcnZpY2UgY2xpZW50IHVzZWQgYnkgd29ya2Zsb3cgZnVuY3Rpb25zXG4gKiB0byBzdGFydCB3b3JrZmxvd3Mgd2l0aGluIGFuIGV2ZW50dWFsLWNvbnRyb2xsZWQgZW52aXJvbm1lbnQuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiByZWdpc3RlclNlcnZpY2VDbGllbnQoY2xpZW50OiBFdmVudHVhbFNlcnZpY2VDbGllbnQpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuc2VydmljZUNsaWVudCA9IGNsaWVudDtcbn1cblxuLyoqXG4gKiBHZXQgdGhlIGdsb2JhbCBzZXJ2aWNlIGNsaWVudC5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldFNlcnZpY2VDbGllbnQoKTogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IHtcbiAgaWYgKGdsb2JhbFRoaXMuX2V2ZW50dWFsLnNlcnZpY2VDbGllbnQgPT09IHVuZGVmaW5lZCkge1xuICAgIHRocm93IG5ldyBFcnJvcihgV29ya2Zsb3dDbGllbnQgaXMgbm90IHJlZ2lzdGVyZWRgKTtcbiAgfVxuICByZXR1cm4gZ2xvYmFsVGhpcy5fZXZlbnR1YWwuc2VydmljZUNsaWVudDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNldEFjdGl2aXR5Q29udGV4dChjb250ZXh0OiBBY3Rpdml0eUNvbnRleHQpIHtcbiAgZ2xvYmFsVGhpcy5fZXZlbnR1YWwuYWN0aXZpdHlDb250ZXh0ID0gY29udGV4dDtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNsZWFyQWN0aXZpdHlDb250ZXh0KCkge1xuICBnbG9iYWxUaGlzLl9ldmVudHVhbC5hY3Rpdml0eUNvbnRleHQgPSB1bmRlZmluZWQ7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBnZXRBY3Rpdml0eUNvbnRleHQoKTogQWN0aXZpdHlDb250ZXh0IHtcbiAgY29uc3QgY29udGV4dCA9IGdsb2JhbFRoaXMuX2V2ZW50dWFsLmFjdGl2aXR5Q29udGV4dDtcblxuICBpZiAoIWNvbnRleHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoXG4gICAgICBcIkFjdGl2aXR5IENvbnRleHQgaGFzIG5vdCBiZWVuIHJlZ2lzdGVyZWQgeWV0IG9yIHRoaXMgaXMgbm90IHRoZSBhY3Rpdml0eSB3b3JrZXIuXCJcbiAgICApO1xuICB9XG4gIHJldHVybiBjb250ZXh0O1xufVxuIl19

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

import { HeartbeatResponse } from "./runtime/clients/workflow-client.js";
import { SendActivityHeartbeatResponse } from "./service-client.js";
/**

@@ -12,3 +12,3 @@ * Sends a heartbeat for the current activity or to the provided activity token.

*/
export declare function heartbeat(activityToken?: string): Promise<HeartbeatResponse>;
export declare function heartbeat(activityToken?: string): Promise<SendActivityHeartbeatResponse>;
//# sourceMappingURL=heartbeat.d.ts.map

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

import { getActivityContext, getWorkflowClient } from "./global.js";
import { getActivityContext, getServiceClient } from "./global.js";
import { isActivityWorker, isOrchestratorWorker } from "./runtime/flags.js";

@@ -18,3 +18,3 @@ /**

else if (activityToken) {
return await getWorkflowClient().heartbeatActivity({
return await getServiceClient().sendActivityHeartbeat({
activityToken,

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

const token = getActivityContext().activityToken;
return await getWorkflowClient().heartbeatActivity({
return await getServiceClient().sendActivityHeartbeat({
activityToken: token,

@@ -34,2 +34,2 @@ });

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFFcEUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFFNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksb0JBQW9CLEVBQUUsRUFBRTtRQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLGtHQUFrRyxDQUNuRyxDQUFDO0tBQ0g7U0FBTSxJQUFJLGFBQWEsRUFBRTtRQUN4QixPQUFPLE1BQU0saUJBQWlCLEVBQUUsQ0FBQyxpQkFBaUIsQ0FBQztZQUNqRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLGdCQUFnQixFQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDakQsT0FBTyxNQUFNLGlCQUFpQixFQUFFLENBQUMsaUJBQWlCLENBQUM7WUFDakQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRBY3Rpdml0eUNvbnRleHQsIGdldFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgeyBIZWFydGJlYXRSZXNwb25zZSB9IGZyb20gXCIuL3J1bnRpbWUvY2xpZW50cy93b3JrZmxvdy1jbGllbnQuanNcIjtcbmltcG9ydCB7IGlzQWN0aXZpdHlXb3JrZXIsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vcnVudGltZS9mbGFncy5qc1wiO1xuXG4vKipcbiAqIFNlbmRzIGEgaGVhcnRiZWF0IGZvciB0aGUgY3VycmVudCBhY3Rpdml0eSBvciB0byB0aGUgcHJvdmlkZWQgYWN0aXZpdHkgdG9rZW4uXG4gKlxuICogSWYgY2FsbGVkIGZyb20gb3V0c2lkZSBvZiBhbiB7QGxpbmsgYWN0aXZpdHl9LCB0aGUgYWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZC5cbiAqXG4gKiBJZiB0aGUgYWN0aXZpdHkgaGFzIGEgaGVhcnRiZWF0VGltZW91dCBzZXQgYW5kIHRoZSB3b3JrZmxvdyBoYXMgbm90IHJlY2VpdmVkIGEgaGVhcnRiZWF0IGluIGhlYXJ0YmVhdFRpbWVvdXRTZWNvbmRzLFxuICogdGhlIHdvcmtmbG93IHdpbGwgdGhyb3cgYSB7QGxpbmsgSGVhcnRiZWF0VGltZW91dH0gYW5kIGNhbmNlbCB0aGUgYWN0aXZpdHkuXG4gKlxuICogQHJldHVybnMge0BsaW5rIEhlYXJ0YmVhdFJlc3BvbnNlfSB3aGljaCBoYXMgcmVzcG9uc2UuY2FuY2VsbGVkIGlmIHRoZSBhY3Rpdml0eSB3YXMgY2FuY2VsbGVkIGZvciBhbnkgcmVhc29uIChleDogd29ya2Zsb3cgY29tcGxldGVkLCBmYWlsZWQsIG9yIHRoZSBhY3Rpdml0eSB0aW1lZCBvdXQpLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaGVhcnRiZWF0KFxuICBhY3Rpdml0eVRva2VuPzogc3RyaW5nXG4pOiBQcm9taXNlPEhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJIZWFydGJlYXQgaXMgbm90IGN1cnJlbnRseSBzdXBwb3J0ZWQgZnJvbSB3aXRoaW4gYSB3b3JrZmxvdy4gVXNlIGFuIGFjdGl2aXR5IHdpdGggYGhlYXJ0YmVhdCgpYC5cIlxuICAgICk7XG4gIH0gZWxzZSBpZiAoYWN0aXZpdHlUb2tlbikge1xuICAgIHJldHVybiBhd2FpdCBnZXRXb3JrZmxvd0NsaWVudCgpLmhlYXJ0YmVhdEFjdGl2aXR5KHtcbiAgICAgIGFjdGl2aXR5VG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSBpZiAoaXNBY3Rpdml0eVdvcmtlcigpKSB7XG4gICAgY29uc3QgdG9rZW4gPSBnZXRBY3Rpdml0eUNvbnRleHQoKS5hY3Rpdml0eVRva2VuO1xuICAgIHJldHVybiBhd2FpdCBnZXRXb3JrZmxvd0NsaWVudCgpLmhlYXJ0YmVhdEFjdGl2aXR5KHtcbiAgICAgIGFjdGl2aXR5VG9rZW46IHRva2VuLFxuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZCB3aGVuIG5vdCB3aXRoaW4gYW4gQWN0aXZpdHkuXCJcbiAgICApO1xuICB9XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaGVhcnRiZWF0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2hlYXJ0YmVhdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxhQUFhLENBQUM7QUFDbkUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLG9CQUFvQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFHNUU7Ozs7Ozs7OztHQVNHO0FBQ0gsTUFBTSxDQUFDLEtBQUssVUFBVSxTQUFTLENBQzdCLGFBQXNCO0lBRXRCLElBQUksb0JBQW9CLEVBQUUsRUFBRTtRQUMxQixNQUFNLElBQUksS0FBSyxDQUNiLGtHQUFrRyxDQUNuRyxDQUFDO0tBQ0g7U0FBTSxJQUFJLGFBQWEsRUFBRTtRQUN4QixPQUFPLE1BQU0sZ0JBQWdCLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztZQUNwRCxhQUFhO1NBQ2QsQ0FBQyxDQUFDO0tBQ0o7U0FBTSxJQUFJLGdCQUFnQixFQUFFLEVBQUU7UUFDN0IsTUFBTSxLQUFLLEdBQUcsa0JBQWtCLEVBQUUsQ0FBQyxhQUFhLENBQUM7UUFDakQsT0FBTyxNQUFNLGdCQUFnQixFQUFFLENBQUMscUJBQXFCLENBQUM7WUFDcEQsYUFBYSxFQUFFLEtBQUs7U0FDckIsQ0FBQyxDQUFDO0tBQ0o7U0FBTTtRQUNMLE1BQU0sSUFBSSxLQUFLLENBQ2IsOERBQThELENBQy9ELENBQUM7S0FDSDtBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRBY3Rpdml0eUNvbnRleHQsIGdldFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmltcG9ydCB7IGlzQWN0aXZpdHlXb3JrZXIsIGlzT3JjaGVzdHJhdG9yV29ya2VyIH0gZnJvbSBcIi4vcnVudGltZS9mbGFncy5qc1wiO1xuaW1wb3J0IHsgU2VuZEFjdGl2aXR5SGVhcnRiZWF0UmVzcG9uc2UgfSBmcm9tIFwiLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuXG4vKipcbiAqIFNlbmRzIGEgaGVhcnRiZWF0IGZvciB0aGUgY3VycmVudCBhY3Rpdml0eSBvciB0byB0aGUgcHJvdmlkZWQgYWN0aXZpdHkgdG9rZW4uXG4gKlxuICogSWYgY2FsbGVkIGZyb20gb3V0c2lkZSBvZiBhbiB7QGxpbmsgYWN0aXZpdHl9LCB0aGUgYWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZC5cbiAqXG4gKiBJZiB0aGUgYWN0aXZpdHkgaGFzIGEgaGVhcnRiZWF0VGltZW91dCBzZXQgYW5kIHRoZSB3b3JrZmxvdyBoYXMgbm90IHJlY2VpdmVkIGEgaGVhcnRiZWF0IGluIGhlYXJ0YmVhdFRpbWVvdXRTZWNvbmRzLFxuICogdGhlIHdvcmtmbG93IHdpbGwgdGhyb3cgYSB7QGxpbmsgSGVhcnRiZWF0VGltZW91dH0gYW5kIGNhbmNlbCB0aGUgYWN0aXZpdHkuXG4gKlxuICogQHJldHVybnMge0BsaW5rIEhlYXJ0YmVhdFJlc3BvbnNlfSB3aGljaCBoYXMgcmVzcG9uc2UuY2FuY2VsbGVkIGlmIHRoZSBhY3Rpdml0eSB3YXMgY2FuY2VsbGVkIGZvciBhbnkgcmVhc29uIChleDogd29ya2Zsb3cgY29tcGxldGVkLCBmYWlsZWQsIG9yIHRoZSBhY3Rpdml0eSB0aW1lZCBvdXQpLlxuICovXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gaGVhcnRiZWF0KFxuICBhY3Rpdml0eVRva2VuPzogc3RyaW5nXG4pOiBQcm9taXNlPFNlbmRBY3Rpdml0eUhlYXJ0YmVhdFJlc3BvbnNlPiB7XG4gIGlmIChpc09yY2hlc3RyYXRvcldvcmtlcigpKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKFxuICAgICAgXCJIZWFydGJlYXQgaXMgbm90IGN1cnJlbnRseSBzdXBwb3J0ZWQgZnJvbSB3aXRoaW4gYSB3b3JrZmxvdy4gVXNlIGFuIGFjdGl2aXR5IHdpdGggYGhlYXJ0YmVhdCgpYC5cIlxuICAgICk7XG4gIH0gZWxzZSBpZiAoYWN0aXZpdHlUb2tlbikge1xuICAgIHJldHVybiBhd2FpdCBnZXRTZXJ2aWNlQ2xpZW50KCkuc2VuZEFjdGl2aXR5SGVhcnRiZWF0KHtcbiAgICAgIGFjdGl2aXR5VG9rZW4sXG4gICAgfSk7XG4gIH0gZWxzZSBpZiAoaXNBY3Rpdml0eVdvcmtlcigpKSB7XG4gICAgY29uc3QgdG9rZW4gPSBnZXRBY3Rpdml0eUNvbnRleHQoKS5hY3Rpdml0eVRva2VuO1xuICAgIHJldHVybiBhd2FpdCBnZXRTZXJ2aWNlQ2xpZW50KCkuc2VuZEFjdGl2aXR5SGVhcnRiZWF0KHtcbiAgICAgIGFjdGl2aXR5VG9rZW46IHRva2VuLFxuICAgIH0pO1xuICB9IGVsc2Uge1xuICAgIHRocm93IG5ldyBFcnJvcihcbiAgICAgIFwiQWN0aXZpdHkgdG9rZW4gbXVzdCBiZSBwcm92aWRlZCB3aGVuIG5vdCB3aXRoaW4gYW4gQWN0aXZpdHkuXCJcbiAgICApO1xuICB9XG59XG4iXX0=

@@ -19,2 +19,3 @@ export * from "./activity.js";

export * from "./secret.js";
export * from "./service-client.js";
export * from "./service-type.js";

@@ -21,0 +22,0 @@ export * from "./signals.js";

@@ -19,2 +19,3 @@ export * from "./activity.js";

export * from "./secret.js";
export * from "./service-client.js";
export * from "./service-type.js";

@@ -27,2 +28,2 @@ export * from "./signals.js";

export * from "./workflow.js";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLFdBQVcsQ0FBQztBQUMxQixjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsZUFBZSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSBcIi4vYWN0aXZpdHkuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2FwaS5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXBwLXNwZWMuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2F3YWl0LWFsbC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY2hhaW4uanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbW1hbmQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2NvbmRpdGlvbi5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29udGV4dC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXJyb3IuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ldmVudHVhbC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXhlY3V0aW9uLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9nbG9iYWwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2hlYXJ0YmVhdC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vaW50ZXJwcmV0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9yZXN1bHQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3J1bnRpbWUvaW5kZXguanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3NlY3JldC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VydmljZS10eXBlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zaWduYWxzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zbGVlcC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGFza3MuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxlQUFlLENBQUM7QUFDOUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLFlBQVksQ0FBQztBQUMzQixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsZUFBZSxDQUFDO0FBQzlCLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQztBQUMvQixjQUFjLGdCQUFnQixDQUFDO0FBQy9CLGNBQWMsYUFBYSxDQUFDO0FBQzVCLGNBQWMsb0JBQW9CLENBQUM7QUFDbkMsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsY0FBYyxDQUFDO0FBQzdCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsWUFBWSxDQUFDO0FBQzNCLGNBQWMsV0FBVyxDQUFDO0FBQzFCLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxlQUFlLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hY3Rpdml0eS5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXBpLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9hcHAtc3BlYy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vYXdhaXQtYWxsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jaGFpbi5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29tbWFuZC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vY29uZGl0aW9uLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9jb250ZXh0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9lcnJvci5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V2ZW50dWFsLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9leGVjdXRpb24uanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2dsb2JhbC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vaGVhcnRiZWF0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9pbnRlcnByZXQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3Jlc3VsdC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVudGltZS9pbmRleC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VjcmV0LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vc2VydmljZS10eXBlLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zaWduYWxzLmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9zbGVlcC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vdGFza3MuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3V0aWwuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LWV2ZW50cy5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3cuanNcIjtcbiJdfQ==

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

import { ExecutionEventsRequest, ExecutionEventsResponse } from "../../service-client.js";
import { WorkflowEvent } from "../../workflow-events.js";

@@ -12,4 +13,4 @@ export type UnresolvedEvent<T extends WorkflowEvent> = Omit<T, "id" | "timestamp">;

*/
abstract getEvents(executionId: string): Promise<WorkflowEvent[]>;
abstract getEvents(request: ExecutionEventsRequest): Promise<ExecutionEventsResponse>;
}
//# sourceMappingURL=execution-history-client.d.ts.map
export class ExecutionHistoryClient {
}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWhpc3RvcnktY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9leGVjdXRpb24taGlzdG9yeS1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT0EsTUFBTSxPQUFnQixzQkFBc0I7Q0FrQjNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgV29ya2Zsb3dFdmVudCB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcblxuZXhwb3J0IHR5cGUgVW5yZXNvbHZlZEV2ZW50PFQgZXh0ZW5kcyBXb3JrZmxvd0V2ZW50PiA9IE9taXQ8XG4gIFQsXG4gIFwiaWRcIiB8IFwidGltZXN0YW1wXCJcbj47XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBFeGVjdXRpb25IaXN0b3J5Q2xpZW50IHtcbiAgcHVibGljIGFic3RyYWN0IHB1dEV2ZW50PFQgZXh0ZW5kcyBXb3JrZmxvd0V2ZW50PihcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGV2ZW50OiBUXG4gICk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFdyaXRlcyBldmVudHMgYXMgYSBiYXRjaCBpbnRvIHRoZSBleGVjdXRpb24gaGlzdG9yeSB0YWJsZS5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBwdXRFdmVudHMoXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZyxcbiAgICBldmVudHM6IFdvcmtmbG93RXZlbnRbXVxuICApOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBSZWFkIGFuIGV4ZWN1dGlvbidzIGV2ZW50cyBmcm9tIHRoZSBleGVjdXRpb24gaGlzdG9yeSB0YWJsZSB0YWJsZVxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGdldEV2ZW50cyhleGVjdXRpb25JZDogc3RyaW5nKTogUHJvbWlzZTxXb3JrZmxvd0V2ZW50W10+O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXhlY3V0aW9uLWhpc3RvcnktY2xpZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3J1bnRpbWUvY2xpZW50cy9leGVjdXRpb24taGlzdG9yeS1jbGllbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV0EsTUFBTSxPQUFnQixzQkFBc0I7Q0FvQjNDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgRXhlY3V0aW9uRXZlbnRzUmVxdWVzdCxcbiAgRXhlY3V0aW9uRXZlbnRzUmVzcG9uc2UsXG59IGZyb20gXCIuLi8uLi9zZXJ2aWNlLWNsaWVudC5qc1wiO1xuaW1wb3J0IHsgV29ya2Zsb3dFdmVudCB9IGZyb20gXCIuLi8uLi93b3JrZmxvdy1ldmVudHMuanNcIjtcblxuZXhwb3J0IHR5cGUgVW5yZXNvbHZlZEV2ZW50PFQgZXh0ZW5kcyBXb3JrZmxvd0V2ZW50PiA9IE9taXQ8XG4gIFQsXG4gIFwiaWRcIiB8IFwidGltZXN0YW1wXCJcbj47XG5cbmV4cG9ydCBhYnN0cmFjdCBjbGFzcyBFeGVjdXRpb25IaXN0b3J5Q2xpZW50IHtcbiAgcHVibGljIGFic3RyYWN0IHB1dEV2ZW50PFQgZXh0ZW5kcyBXb3JrZmxvd0V2ZW50PihcbiAgICBleGVjdXRpb25JZDogc3RyaW5nLFxuICAgIGV2ZW50OiBUXG4gICk6IFByb21pc2U8dm9pZD47XG5cbiAgLyoqXG4gICAqIFdyaXRlcyBldmVudHMgYXMgYSBiYXRjaCBpbnRvIHRoZSBleGVjdXRpb24gaGlzdG9yeSB0YWJsZS5cbiAgICovXG4gIHB1YmxpYyBhYnN0cmFjdCBwdXRFdmVudHMoXG4gICAgZXhlY3V0aW9uSWQ6IHN0cmluZyxcbiAgICBldmVudHM6IFdvcmtmbG93RXZlbnRbXVxuICApOiBQcm9taXNlPHZvaWQ+O1xuXG4gIC8qKlxuICAgKiBSZWFkIGFuIGV4ZWN1dGlvbidzIGV2ZW50cyBmcm9tIHRoZSBleGVjdXRpb24gaGlzdG9yeSB0YWJsZSB0YWJsZVxuICAgKi9cbiAgcHVibGljIGFic3RyYWN0IGdldEV2ZW50cyhcbiAgICByZXF1ZXN0OiBFeGVjdXRpb25FdmVudHNSZXF1ZXN0XG4gICk6IFByb21pc2U8RXhlY3V0aW9uRXZlbnRzUmVzcG9uc2U+O1xufVxuIl19

@@ -8,2 +8,3 @@ export * from "./activity-runtime-client.js";

export * from "./workflow-runtime-client.js";
export * from "./runtime-service-clients.js";
//# sourceMappingURL=index.d.ts.map

@@ -8,2 +8,3 @@ export * from "./activity-runtime-client.js";

export * from "./workflow-runtime-client.js";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tIFwiLi9hY3Rpdml0eS1ydW50aW1lLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vZXZlbnQtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9leGVjdXRpb24taGlzdG9yeS1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL21ldHJpY3MtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi90aW1lci1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3dvcmtmbG93LWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3ctcnVudGltZS1jbGllbnQuanNcIjtcbiJdfQ==
export * from "./runtime-service-clients.js";
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9jbGllbnRzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLCtCQUErQixDQUFDO0FBQzlDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLHNCQUFzQixDQUFDO0FBQ3JDLGNBQWMsOEJBQThCLENBQUM7QUFDN0MsY0FBYyw4QkFBOEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2FjdGl2aXR5LXJ1bnRpbWUtY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi9ldmVudC1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL2V4ZWN1dGlvbi1oaXN0b3J5LWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vbWV0cmljcy1jbGllbnQuanNcIjtcbmV4cG9ydCAqIGZyb20gXCIuL3RpbWVyLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5leHBvcnQgKiBmcm9tIFwiLi93b3JrZmxvdy1ydW50aW1lLWNsaWVudC5qc1wiO1xuZXhwb3J0ICogZnJvbSBcIi4vcnVudGltZS1zZXJ2aWNlLWNsaWVudHMuanNcIjtcbiJdfQ==
import { HistoryStateEvent } from "../../workflow-events.js";
import { Execution, ExecutionStatus } from "../../execution.js";
import { Execution, ExecutionHandle } from "../../execution.js";
import { Signal } from "../../signals.js";
import { Workflow, WorkflowInput, WorkflowOptions } from "../../workflow.js";
import { Workflow, WorkflowOptions } from "../../workflow.js";
import { ActivityRuntimeClient } from "./activity-runtime-client.js";
import { SendActivitySuccessRequest, SendActivityFailureRequest, GetExecutionsRequest, GetExecutionsResponse, SendActivityHeartbeatRequest, StartExecutionRequest, SendActivityHeartbeatResponse } from "../../service-client.js";
export declare abstract class WorkflowClient {

@@ -24,6 +25,3 @@ private activityRuntimeClient;

abstract submitWorkflowTask(executionId: string, ...events: HistoryStateEvent[]): Promise<void>;
abstract getExecutions(props: {
statuses?: ExecutionStatus[];
workflowName?: string;
}): Promise<Execution[]>;
abstract getExecutions(props: GetExecutionsRequest): Promise<GetExecutionsResponse>;
abstract getExecution(executionId: string): Promise<Execution | undefined>;

@@ -40,7 +38,7 @@ /**

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

@@ -51,9 +49,9 @@ * Submits a "heartbeat" for the given activityToken.

*/
heartbeatActivity(request: HeartbeatRequest): Promise<HeartbeatResponse>;
heartbeatActivity(request: Omit<SendActivityHeartbeatRequest, "type">): Promise<SendActivityHeartbeatResponse>;
private sendActivityResult;
}
export interface SendSignalRequest {
executionId: string;
signal: string | Signal;
payload?: any;
export interface SendSignalRequest<Payload = any> {
execution: ExecutionHandle<any> | string;
signal: string | Signal<Payload>;
payload?: Payload;
/**

@@ -64,23 +62,3 @@ * Execution scoped unique event id. Duplicates will be deduplicated.

}
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends WorkflowOptions {
/**
* Name of the workflow execution.
*
* Only one workflow can exist for an ID. Requests to start a workflow
* with the name of an existing workflow will fail.
*
* @default - a unique name is generated.
*/
executionName?: string;
/**
* Name of the workflow to execute.
*/
workflowName: string;
/**
* Input payload for the workflow function.
*/
input?: WorkflowInput<W>;
/**
* ID of the parent execution if this is a child workflow
*/
export interface StartWorkflowRequest<W extends Workflow = Workflow> extends StartExecutionRequest<W>, WorkflowOptions {
parentExecutionId?: string;

@@ -98,22 +76,2 @@ /**

}
export interface CompleteActivityRequest<T = any> {
activityToken: string;
result: T;
}
export interface FailActivityRequest {
activityToken: string;
error: string;
message?: string;
}
export interface HeartbeatRequest {
activityToken: string;
}
export interface HeartbeatResponse {
/**
* True when the activity has been cancelled.
*
* This is the only way for a long running activity to know it was canelled.
*/
cancelled: boolean;
}
//# sourceMappingURL=workflow-client.d.ts.map
import { createEvent, WorkflowEventType, } from "../../workflow-events.js";
import { ExecutionStatus } from "../../execution.js";
import { ExecutionStatus, } from "../../execution.js";
import { decodeActivityToken } from "../activity-token.js";

@@ -16,3 +16,6 @@ export class WorkflowClient {

async sendSignal(request) {
await this.submitWorkflowTask(request.executionId, createEvent({
const executionId = typeof request.execution === "string"
? request.execution
: request.execution.executionId;
await this.submitWorkflowTask(executionId, createEvent({
type: WorkflowEventType.SignalReceived,

@@ -65,2 +68,2 @@ payload: request.payload,

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAGX,iBAAiB,GAClB,MAAM,0BAA0B,CAAC;AAClC,OAAO,EAAa,eAAe,EAAE,MAAM,oBAAoB,CAAC;AAGhE,OAAO,EAAE,mBAAmB,EAAE,MAAM,sBAAsB,CAAC;AAG3D,MAAM,OAAgB,cAAc;IAClC,YACU,qBAA4C,EAC1C,QAAoB;QADtB,0BAAqB,GAArB,qBAAqB,CAAuB;QAC1C,aAAQ,GAAR,QAAQ,CAAY;IAC7B,CAAC;IAgCJ;;;;;OAKG;IACI,KAAK,CAAC,UAAU,CAAC,OAA0B;QAChD,MAAM,IAAI,CAAC,kBAAkB,CAC3B,OAAO,CAAC,WAAW,EACnB,WAAW,CACT;YACE,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,OAAO,EAAE,OAAO,CAAC,OAAO;YACxB,QAAQ,EACN,OAAO,OAAO,CAAC,MAAM,KAAK,QAAQ;gBAChC,CAAC,CAAC,OAAO,CAAC,MAAM;gBAChB,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,EAAE;SACxB,EACD,IAAI,CAAC,QAAQ,EAAE,EACf,OAAO,CAAC,EAAE,CACX,CACF,CAAC;IACJ,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,gBAAgB,CAAC,EAC5B,aAAa,EACb,MAAM,GACkB;QACxB,MAAM,IAAI,CAAC,kBAAkB,CAAoB,aAAa,EAAE;YAC9D,IAAI,EAAE,iBAAiB,CAAC,iBAAiB;YACzC,MAAM;SACP,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,KAAK,CAAC,YAAY,CAAC,EACxB,aAAa,EACb,KAAK,EACL,OAAO,GACa;QACpB,MAAM,IAAI,CAAC,kBAAkB,CAAiB,aAAa,EAAE;YAC3D,IAAI,EAAE,iBAAiB,CAAC,cAAc;YACtC,KAAK;YACL,OAAO;SACR,CAAC,CAAC;IACL,CAAC;IAED;;;;OAIG;IACI,KAAK,CAAC,iBAAiB,CAC5B,OAAyB;QAEzB,MAAM,IAAI,GAAG,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QAExD,MAAM,SAAS,GAAG,MAAM,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;QAEpE,IAAI,SAAS,EAAE,MAAM,KAAK,eAAe,CAAC,WAAW,EAAE;YACrD,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;SAC5B;QAED,OAAO,MAAM,IAAI,CAAC,qBAAqB,CAAC,iBAAiB,CACvD,IAAI,CAAC,OAAO,CAAC,WAAW,EACxB,IAAI,CAAC,OAAO,CAAC,GAAG,EAChB,IAAI,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 { Execution, ExecutionStatus } from \"../../execution.js\";\nimport { Signal } from \"../../signals.js\";\nimport { Workflow, WorkflowInput, WorkflowOptions } from \"../../workflow.js\";\nimport { decodeActivityToken } from \"../activity-token.js\";\nimport { ActivityRuntimeClient } from \"./activity-runtime-client.js\";\n\nexport abstract class WorkflowClient {\n  constructor(\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(props: {\n    statuses?: ExecutionStatus[];\n    workflowName?: string;\n  }): Promise<Execution[]>;\n\n  public abstract getExecution(\n    executionId: string\n  ): Promise<Execution | undefined>;\n\n  /**\n   * Sends a signal to the given execution.\n   *\n   * The execution may be waiting on a signal or may have a handler registered\n   * that runs when the signal is received.\n   */\n  public async sendSignal(request: SendSignalRequest): Promise<void> {\n    await this.submitWorkflowTask(\n      request.executionId,\n      createEvent<SignalReceived>(\n        {\n          type: WorkflowEventType.SignalReceived,\n          payload: request.payload,\n          signalId:\n            typeof request.signal === \"string\"\n              ? request.signal\n              : request.signal.id,\n        },\n        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  }: CompleteActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityCompleted>(activityToken, {\n      type: WorkflowEventType.ActivityCompleted,\n      result,\n    });\n  }\n\n  /**\n   * Fails an async activity causing it to throw the given error.\n   */\n  public async failActivity({\n    activityToken,\n    error,\n    message,\n  }: FailActivityRequest): Promise<void> {\n    await this.sendActivityResult<ActivityFailed>(activityToken, {\n      type: WorkflowEventType.ActivityFailed,\n      error,\n      message,\n    });\n  }\n\n  /**\n   * Submits a \"heartbeat\" for the given activityToken.\n   *\n   * @returns whether the activity has been cancelled by the calling workflow.\n   */\n  public async heartbeatActivity(\n    request: HeartbeatRequest\n  ): Promise<HeartbeatResponse> {\n    const data = decodeActivityToken(request.activityToken);\n\n    const execution = await this.getExecution(data.payload.executionId);\n\n    if (execution?.status !== ExecutionStatus.IN_PROGRESS) {\n      return { cancelled: true };\n    }\n\n    return await this.activityRuntimeClient.heartbeatActivity(\n      data.payload.executionId,\n      data.payload.seq,\n      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 {\n  executionId: string;\n  signal: string | Signal;\n  payload?: any;\n  /**\n   * Execution scoped unique event id. Duplicates will be deduplicated.\n   */\n  id?: string;\n}\n\nexport interface StartWorkflowRequest<W extends Workflow = Workflow>\n  extends WorkflowOptions {\n  /**\n   * Name of the workflow execution.\n   *\n   * Only one workflow can exist for an ID. Requests to start a workflow\n   * with the name of an existing workflow will fail.\n   *\n   * @default - a unique name is generated.\n   */\n  executionName?: string;\n  /**\n   * Name of the workflow to execute.\n   */\n  workflowName: string;\n  /**\n   * Input payload for the workflow function.\n   */\n  input?: WorkflowInput<W>;\n  /**\n   * ID of the parent execution if this is a child workflow\n   */\n  parentExecutionId?: string;\n  /**\n   * Sequence ID of this execution if this is a child workflow\n   */\n  seq?: number;\n}\n\nexport interface StartWorkflowResponse {\n  /**\n   * ID of the started workflow execution.\n   */\n  executionId: string;\n}\n\nexport interface CompleteActivityRequest<T = any> {\n  activityToken: string;\n  result: T;\n}\n\nexport interface FailActivityRequest {\n  activityToken: string;\n  error: string;\n  message?: string;\n}\n\nexport interface HeartbeatRequest {\n  activityToken: string;\n}\n\nexport interface HeartbeatResponse {\n  /**\n   * True when the activity has been cancelled.\n   *\n   * This is the only way for a long running activity to know it was canelled.\n   */\n  cancelled: boolean;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow-client.js","sourceRoot":"","sources":["../../../../src/runtime/clients/workflow-client.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,WAAW,EAGX,iBAAiB,GAClB,MAAM,0BAA0B,CAAC;AAClC,OAAO,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"]}

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

await this.props.workflowClient.startWorkflow({
workflowName: command.name,
workflow: command.name,
input: command.input,

@@ -130,3 +130,3 @@ parentExecutionId: executionId,

signal: command.signalId,
executionId: childExecutionId,
execution: childExecutionId,
id: `${executionId}/${command.seq}`,

@@ -168,2 +168,2 @@ payload: command.payload,

}
//# 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      workflowName: command.name,\n      input: command.input,\n      parentExecutionId: executionId,\n      executionName: formatChildExecutionName(executionId, command.seq),\n      seq: command.seq,\n      ...command.opts,\n    });\n\n    return createEvent<ChildWorkflowScheduled>(\n      {\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      executionId: 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.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"]}

@@ -5,3 +5,3 @@ import { ScheduleActivityCommand } from "../../command.js";

import { WorkflowClient } from "../clients/workflow-client.js";
import { TimerClient } from "../index.js";
import { RuntimeServiceClient, TimerClient } from "../index.js";
import { Logger } from "../logger.js";

@@ -18,2 +18,3 @@ import type { EventClient } from "../index.js";

activityProvider: ActivityProvider;
serviceClient?: RuntimeServiceClient;
}

@@ -40,3 +41,3 @@ export interface ActivityWorkerRequest {

*/
export declare function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, eventClient, activityProvider, }: CreateActivityWorkerProps): ActivityWorker;
export declare function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, activityProvider, serviceClient, }: CreateActivityWorkerProps): ActivityWorker;
//# sourceMappingURL=activity-worker.d.ts.map
import { isAsyncResult } from "../../activity.js";
import { createEvent, isWorkflowFailed, WorkflowEventType, } from "../../workflow-events.js";
import { clearActivityContext, registerEventClient, registerWorkflowClient, setActivityContext, } from "../../global.js";
import { clearActivityContext, registerServiceClient, setActivityContext, } from "../../global.js";
import { createActivityToken } from "../activity-token.js";
import { Schedule, TimerRequestType } from "../index.js";
import { Schedule, TimerRequestType, } from "../index.js";
import { ActivityMetrics, MetricsCommon } from "../metrics/constants.js";

@@ -17,7 +17,7 @@ import { Unit } from "../metrics/unit.js";

*/
export function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, eventClient, activityProvider, }) {
// make the workflow client available to all activity code
registerWorkflowClient(workflowClient);
// make the event client available to all activity code
registerEventClient(eventClient);
export function createActivityWorker({ activityRuntimeClient, workflowClient, timerClient, metricsClient, logger, activityProvider, serviceClient, }) {
// make the service client available to all activity code
if (serviceClient) {
registerServiceClient(serviceClient);
}
return metricsClient.metricScope((metrics) => async (request, baseTime, getEndTime = () => new Date()) => {

@@ -126,2 +126,2 @@ logger.addPersistentLogAttributes({

}
//# 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  registerEventClient,\n  registerWorkflowClient,\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 { Schedule, TimerClient, TimerRequestType } 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}\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  eventClient,\n  activityProvider,\n}: CreateActivityWorkerProps): ActivityWorker {\n  // make the workflow client available to all activity code\n  registerWorkflowClient(workflowClient);\n  // make the event client available to all activity code\n  registerEventClient(eventClient);\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  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"]}

@@ -1,6 +0,4 @@

import type { WorkflowClient } from "../clients/workflow-client.js";
import type { EventClient } from "../index.js";
import { EventualServiceClient } from "../../service-client.js";
export interface ApiHandlerDependencies {
workflowClient: WorkflowClient;
eventClient: EventClient;
serviceClient: EventualServiceClient;
}

@@ -13,3 +11,3 @@ /**

*/
export declare function createApiHandler({ workflowClient, eventClient, }: ApiHandlerDependencies): (request: Request) => Promise<Response>;
export declare function createApiHandler({ serviceClient }: ApiHandlerDependencies): (request: Request) => Promise<Response>;
//# sourceMappingURL=api-handler.d.ts.map
import { api } from "../../api.js";
import { registerEventClient, registerWorkflowClient } from "../../global.js";
import { registerServiceClient } from "../../global.js";
/**

@@ -9,6 +9,5 @@ * Creates a generic function for handling inbound API requests

*/
export function createApiHandler({ workflowClient, eventClient, }) {
// make the workflow client available to web hooks
registerWorkflowClient(workflowClient);
registerEventClient(eventClient);
export function createApiHandler({ serviceClient }) {
// make the service client available to web hooks
registerServiceClient(serviceClient);
api.all("*", () => new Response("Not Found.", { status: 404 }));

@@ -33,2 +32,2 @@ /**

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9oYW5kbGVycy9hcGktaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25DLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBUzlFOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEVBQy9CLGNBQWMsRUFDZCxXQUFXLEdBQ1k7SUFDdkIsa0RBQWtEO0lBQ2xELHNCQUFzQixDQUFDLGNBQWMsQ0FBQyxDQUFDO0lBQ3ZDLG1CQUFtQixDQUFDLFdBQVcsQ0FBQyxDQUFDO0lBRWpDLEdBQUcsQ0FBQyxHQUFHLENBQUMsR0FBRyxFQUFFLEdBQUcsRUFBRSxDQUFDLElBQUksUUFBUSxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxHQUFHLEVBQUUsQ0FBQyxDQUFDLENBQUM7SUFFaEU7Ozs7O09BS0c7SUFDSCxPQUFPLEtBQUssVUFBVSxjQUFjLENBQUMsT0FBZ0I7UUFDbkQsSUFBSTtZQUNGLE9BQU8sR0FBRyxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM1QjtRQUFDLE9BQU8sR0FBRyxFQUFFO1lBQ1osT0FBTyxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUNuQixPQUFPLElBQUksUUFBUSxDQUFDLHVCQUF1QixFQUFFO2dCQUMzQyxNQUFNLEVBQUUsR0FBRzthQUNaLENBQUMsQ0FBQztTQUNKO0lBQ0gsQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGFwaSB9IGZyb20gXCIuLi8uLi9hcGkuanNcIjtcbmltcG9ydCB7IHJlZ2lzdGVyRXZlbnRDbGllbnQsIHJlZ2lzdGVyV29ya2Zsb3dDbGllbnQgfSBmcm9tIFwiLi4vLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4uL2NsaWVudHMvd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEV2ZW50Q2xpZW50IH0gZnJvbSBcIi4uL2luZGV4LmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXBpSGFuZGxlckRlcGVuZGVuY2llcyB7XG4gIHdvcmtmbG93Q2xpZW50OiBXb3JrZmxvd0NsaWVudDtcbiAgZXZlbnRDbGllbnQ6IEV2ZW50Q2xpZW50O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBnZW5lcmljIGZ1bmN0aW9uIGZvciBoYW5kbGluZyBpbmJvdW5kIEFQSSByZXF1ZXN0c1xuICogdGhhdCBjYW4gYmUgdXNlZCBpbiBydW50aW1lIGltcGxlbWVudGF0aW9ucy4gVGhpcyBpbXBsZW1lbnRhdGlvbiBpc1xuICogZGVjb3VwbGVkIGZyb20gYSBydW50aW1lJ3Mgc3BlY2lmaWNzIGJ5IHRoZSBjbGllbnRzLiBBIHJ1bnRpbWUgbXVzdFxuICogaW5qZWN0IGl0cyBvd24gY2xpZW50IGltcGxlbWVudGF0aW9ucyBkZXNpZ25lZCBmb3IgdGhhdCBwbGF0Zm9ybS5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZUFwaUhhbmRsZXIoe1xuICB3b3JrZmxvd0NsaWVudCxcbiAgZXZlbnRDbGllbnQsXG59OiBBcGlIYW5kbGVyRGVwZW5kZW5jaWVzKSB7XG4gIC8vIG1ha2UgdGhlIHdvcmtmbG93IGNsaWVudCBhdmFpbGFibGUgdG8gd2ViIGhvb2tzXG4gIHJlZ2lzdGVyV29ya2Zsb3dDbGllbnQod29ya2Zsb3dDbGllbnQpO1xuICByZWdpc3RlckV2ZW50Q2xpZW50KGV2ZW50Q2xpZW50KTtcblxuICBhcGkuYWxsKFwiKlwiLCAoKSA9PiBuZXcgUmVzcG9uc2UoXCJOb3QgRm91bmQuXCIsIHsgc3RhdHVzOiA0MDQgfSkpO1xuXG4gIC8qKlxuICAgKiBIYW5kbGUgaW5ib3VuZCB3ZWJob29rIEFQSSByZXF1ZXN0cy5cbiAgICpcbiAgICogRWFjaCB3ZWJob29rIHJlZ2lzdGVycyByb3V0ZXMgb24gdGhlIGNlbnRyYWwge0BsaW5rIHJvdXRlcn0gd2hpY2hcbiAgICogdGhlbiBoYW5kbGVzIHRoZSByZXF1ZXN0LlxuICAgKi9cbiAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uIHByb2Nlc3NSZXF1ZXN0KHJlcXVlc3Q6IFJlcXVlc3QpOiBQcm9taXNlPFJlc3BvbnNlPiB7XG4gICAgdHJ5IHtcbiAgICAgIHJldHVybiBhcGkuaGFuZGxlKHJlcXVlc3QpO1xuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgY29uc29sZS5lcnJvcihlcnIpO1xuICAgICAgcmV0dXJuIG5ldyBSZXNwb25zZShcIkludGVybmFsIFNlcnZlciBFcnJvclwiLCB7XG4gICAgICAgIHN0YXR1czogNTAwLFxuICAgICAgfSk7XG4gICAgfVxuICB9O1xufVxuIl19
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBpLWhhbmRsZXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcnVudGltZS9oYW5kbGVycy9hcGktaGFuZGxlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sY0FBYyxDQUFDO0FBQ25DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBT3hEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLGdCQUFnQixDQUFDLEVBQUUsYUFBYSxFQUEwQjtJQUN4RSxpREFBaUQ7SUFDakQscUJBQXFCLENBQUMsYUFBYSxDQUFDLENBQUM7SUFFckMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxHQUFHLEVBQUUsR0FBRyxFQUFFLENBQUMsSUFBSSxRQUFRLENBQUMsWUFBWSxFQUFFLEVBQUUsTUFBTSxFQUFFLEdBQUcsRUFBRSxDQUFDLENBQUMsQ0FBQztJQUVoRTs7Ozs7T0FLRztJQUNILE9BQU8sS0FBSyxVQUFVLGNBQWMsQ0FBQyxPQUFnQjtRQUNuRCxJQUFJO1lBQ0YsT0FBTyxHQUFHLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQzVCO1FBQUMsT0FBTyxHQUFHLEVBQUU7WUFDWixPQUFPLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO1lBQ25CLE9BQU8sSUFBSSxRQUFRLENBQUMsdUJBQXVCLEVBQUU7Z0JBQzNDLE1BQU0sRUFBRSxHQUFHO2FBQ1osQ0FBQyxDQUFDO1NBQ0o7SUFDSCxDQUFDLENBQUM7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgYXBpIH0gZnJvbSBcIi4uLy4uL2FwaS5qc1wiO1xuaW1wb3J0IHsgcmVnaXN0ZXJTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4uLy4uL2dsb2JhbC5qc1wiO1xuaW1wb3J0IHsgRXZlbnR1YWxTZXJ2aWNlQ2xpZW50IH0gZnJvbSBcIi4uLy4uL3NlcnZpY2UtY2xpZW50LmpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQXBpSGFuZGxlckRlcGVuZGVuY2llcyB7XG4gIHNlcnZpY2VDbGllbnQ6IEV2ZW50dWFsU2VydmljZUNsaWVudDtcbn1cblxuLyoqXG4gKiBDcmVhdGVzIGEgZ2VuZXJpYyBmdW5jdGlvbiBmb3IgaGFuZGxpbmcgaW5ib3VuZCBBUEkgcmVxdWVzdHNcbiAqIHRoYXQgY2FuIGJlIHVzZWQgaW4gcnVudGltZSBpbXBsZW1lbnRhdGlvbnMuIFRoaXMgaW1wbGVtZW50YXRpb24gaXNcbiAqIGRlY291cGxlZCBmcm9tIGEgcnVudGltZSdzIHNwZWNpZmljcyBieSB0aGUgY2xpZW50cy4gQSBydW50aW1lIG11c3RcbiAqIGluamVjdCBpdHMgb3duIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZGVzaWduZWQgZm9yIHRoYXQgcGxhdGZvcm0uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVBcGlIYW5kbGVyKHsgc2VydmljZUNsaWVudCB9OiBBcGlIYW5kbGVyRGVwZW5kZW5jaWVzKSB7XG4gIC8vIG1ha2UgdGhlIHNlcnZpY2UgY2xpZW50IGF2YWlsYWJsZSB0byB3ZWIgaG9va3NcbiAgcmVnaXN0ZXJTZXJ2aWNlQ2xpZW50KHNlcnZpY2VDbGllbnQpO1xuXG4gIGFwaS5hbGwoXCIqXCIsICgpID0+IG5ldyBSZXNwb25zZShcIk5vdCBGb3VuZC5cIiwgeyBzdGF0dXM6IDQwNCB9KSk7XG5cbiAgLyoqXG4gICAqIEhhbmRsZSBpbmJvdW5kIHdlYmhvb2sgQVBJIHJlcXVlc3RzLlxuICAgKlxuICAgKiBFYWNoIHdlYmhvb2sgcmVnaXN0ZXJzIHJvdXRlcyBvbiB0aGUgY2VudHJhbCB7QGxpbmsgcm91dGVyfSB3aGljaFxuICAgKiB0aGVuIGhhbmRsZXMgdGhlIHJlcXVlc3QuXG4gICAqL1xuICByZXR1cm4gYXN5bmMgZnVuY3Rpb24gcHJvY2Vzc1JlcXVlc3QocmVxdWVzdDogUmVxdWVzdCk6IFByb21pc2U8UmVzcG9uc2U+IHtcbiAgICB0cnkge1xuICAgICAgcmV0dXJuIGFwaS5oYW5kbGUocmVxdWVzdCk7XG4gICAgfSBjYXRjaCAoZXJyKSB7XG4gICAgICBjb25zb2xlLmVycm9yKGVycik7XG4gICAgICByZXR1cm4gbmV3IFJlc3BvbnNlKFwiSW50ZXJuYWwgU2VydmVyIEVycm9yXCIsIHtcbiAgICAgICAgc3RhdHVzOiA1MDAsXG4gICAgICB9KTtcbiAgICB9XG4gIH07XG59XG4iXX0=

@@ -1,5 +0,4 @@

import type { WorkflowClient } from "../clients/workflow-client.js";
import type { EventClient } from "../clients/event-client.js";
import type { EventEnvelope } from "../../event.js";
import { EventHandlerProvider } from "../providers/event-handler-provider.js";
import { EventualServiceClient } from "../../service-client.js";
/**

@@ -10,11 +9,7 @@ * The dependencies of {@link createEventHandlerWorker}.

/**
* The {@link WorkflowClient} for interacting with workflows contained
* The {@link EventualServiceClient} for interacting with workflows contained
* within the service boundary.
*/
workflowClient?: WorkflowClient;
serviceClient?: EventualServiceClient;
/**
* The {@link EventClient} for publishing events to the service's event bus.
*/
eventClient?: EventClient;
/**
* Returns event handlers

@@ -33,3 +28,3 @@ */

*/
export declare function createEventHandlerWorker({ workflowClient, eventClient, eventHandlerProvider, }: EventHandlerDependencies): EventHandlerWorker;
export declare function createEventHandlerWorker({ serviceClient, eventHandlerProvider, }: EventHandlerDependencies): EventHandlerWorker;
//# sourceMappingURL=event-handler.d.ts.map

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

import { registerWorkflowClient, registerEventClient } from "../../global.js";
import { registerServiceClient } from "../../global.js";
/**

@@ -8,10 +8,7 @@ * Creates a generic function for handling inbound event requests

*/
export function createEventHandlerWorker({ workflowClient, eventClient, eventHandlerProvider, }) {
export function createEventHandlerWorker({ serviceClient, eventHandlerProvider, }) {
// make the workflow client available to web hooks
if (workflowClient) {
registerWorkflowClient(workflowClient);
if (serviceClient) {
registerServiceClient(serviceClient);
}
if (eventClient) {
registerEventClient(eventClient);
}
return async function (events) {

@@ -23,2 +20,2 @@ await Promise.allSettled(events.map((event) => Promise.allSettled(eventHandlerProvider

}
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ydW50aW1lL2hhbmRsZXJzL2V2ZW50LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUE2QjlFOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLHdCQUF3QixDQUFDLEVBQ3ZDLGNBQWMsRUFDZCxXQUFXLEVBQ1gsb0JBQW9CLEdBQ0s7SUFDekIsa0RBQWtEO0lBQ2xELElBQUksY0FBYyxFQUFFO1FBQ2xCLHNCQUFzQixDQUFDLGNBQWMsQ0FBQyxDQUFDO0tBQ3hDO0lBQ0QsSUFBSSxXQUFXLEVBQUU7UUFDZixtQkFBbUIsQ0FBQyxXQUFXLENBQUMsQ0FBQztLQUNsQztJQUVELE9BQU8sS0FBSyxXQUFXLE1BQU07UUFDM0IsTUFBTSxPQUFPLENBQUMsVUFBVSxDQUN0QixNQUFNLENBQUMsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FDbkIsT0FBTyxDQUFDLFVBQVUsQ0FDaEIsb0JBQW9CO2FBQ2pCLHdCQUF3QixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUM7YUFDcEMsR0FBRyxDQUFDLENBQUMsT0FBTyxFQUFFLEVBQUUsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQzFDLENBQ0YsQ0FDRixDQUFDO0lBQ0osQ0FBQyxDQUFDO0FBQ0osQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IHJlZ2lzdGVyV29ya2Zsb3dDbGllbnQsIHJlZ2lzdGVyRXZlbnRDbGllbnQgfSBmcm9tIFwiLi4vLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IFdvcmtmbG93Q2xpZW50IH0gZnJvbSBcIi4uL2NsaWVudHMvd29ya2Zsb3ctY2xpZW50LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEV2ZW50Q2xpZW50IH0gZnJvbSBcIi4uL2NsaWVudHMvZXZlbnQtY2xpZW50LmpzXCI7XG5pbXBvcnQgdHlwZSB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcbmltcG9ydCB7IEV2ZW50SGFuZGxlclByb3ZpZGVyIH0gZnJvbSBcIi4uL3Byb3ZpZGVycy9ldmVudC1oYW5kbGVyLXByb3ZpZGVyLmpzXCI7XG5cbi8qKlxuICogVGhlIGRlcGVuZGVuY2llcyBvZiB7QGxpbmsgY3JlYXRlRXZlbnRIYW5kbGVyV29ya2VyfS5cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBFdmVudEhhbmRsZXJEZXBlbmRlbmNpZXMge1xuICAvKipcbiAgICogVGhlIHtAbGluayBXb3JrZmxvd0NsaWVudH0gZm9yIGludGVyYWN0aW5nIHdpdGggd29ya2Zsb3dzIGNvbnRhaW5lZFxuICAgKiB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqL1xuICB3b3JrZmxvd0NsaWVudD86IFdvcmtmbG93Q2xpZW50O1xuICAvKipcbiAgICogVGhlIHtAbGluayBFdmVudENsaWVudH0gZm9yIHB1Ymxpc2hpbmcgZXZlbnRzIHRvIHRoZSBzZXJ2aWNlJ3MgZXZlbnQgYnVzLlxuICAgKi9cbiAgZXZlbnRDbGllbnQ/OiBFdmVudENsaWVudDtcbiAgLyoqXG4gICAqIFJldHVybnMgZXZlbnQgaGFuZGxlcnNcbiAgICovXG4gIGV2ZW50SGFuZGxlclByb3ZpZGVyOiBFdmVudEhhbmRsZXJQcm92aWRlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBFdmVudEhhbmRsZXJXb3JrZXIge1xuICAoZXZlbnRzOiBFdmVudEVudmVsb3BlW10pOiBQcm9taXNlPHZvaWQ+O1xufVxuXG4vKipcbiAqIENyZWF0ZXMgYSBnZW5lcmljIGZ1bmN0aW9uIGZvciBoYW5kbGluZyBpbmJvdW5kIGV2ZW50IHJlcXVlc3RzXG4gKiB0aGF0IGNhbiBiZSB1c2VkIGluIHJ1bnRpbWUgaW1wbGVtZW50YXRpb25zLiBUaGlzIGltcGxlbWVudGF0aW9uIGlzXG4gKiBkZWNvdXBsZWQgZnJvbSBhIHJ1bnRpbWUncyBzcGVjaWZpY3MgYnkgdGhlIGNsaWVudHMuIEEgcnVudGltZSBtdXN0XG4gKiBpbmplY3QgaXRzIG93biBjbGllbnQgaW1wbGVtZW50YXRpb25zIGRlc2lnbmVkIGZvciB0aGF0IHBsYXRmb3JtLlxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlRXZlbnRIYW5kbGVyV29ya2VyKHtcbiAgd29ya2Zsb3dDbGllbnQsXG4gIGV2ZW50Q2xpZW50LFxuICBldmVudEhhbmRsZXJQcm92aWRlcixcbn06IEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyk6IEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIC8vIG1ha2UgdGhlIHdvcmtmbG93IGNsaWVudCBhdmFpbGFibGUgdG8gd2ViIGhvb2tzXG4gIGlmICh3b3JrZmxvd0NsaWVudCkge1xuICAgIHJlZ2lzdGVyV29ya2Zsb3dDbGllbnQod29ya2Zsb3dDbGllbnQpO1xuICB9XG4gIGlmIChldmVudENsaWVudCkge1xuICAgIHJlZ2lzdGVyRXZlbnRDbGllbnQoZXZlbnRDbGllbnQpO1xuICB9XG5cbiAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uIChldmVudHMpIHtcbiAgICBhd2FpdCBQcm9taXNlLmFsbFNldHRsZWQoXG4gICAgICBldmVudHMubWFwKChldmVudCkgPT5cbiAgICAgICAgUHJvbWlzZS5hbGxTZXR0bGVkKFxuICAgICAgICAgIGV2ZW50SGFuZGxlclByb3ZpZGVyXG4gICAgICAgICAgICAuZ2V0RXZlbnRIYW5kbGVyc0ZvckV2ZW50KGV2ZW50Lm5hbWUpXG4gICAgICAgICAgICAubWFwKChoYW5kbGVyKSA9PiBoYW5kbGVyKGV2ZW50LmV2ZW50KSlcbiAgICAgICAgKVxuICAgICAgKVxuICAgICk7XG4gIH07XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZXZlbnQtaGFuZGxlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9ydW50aW1lL2hhbmRsZXJzL2V2ZW50LWhhbmRsZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHFCQUFxQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUF3QnhEOzs7OztHQUtHO0FBQ0gsTUFBTSxVQUFVLHdCQUF3QixDQUFDLEVBQ3ZDLGFBQWEsRUFDYixvQkFBb0IsR0FDSztJQUN6QixrREFBa0Q7SUFDbEQsSUFBSSxhQUFhLEVBQUU7UUFDakIscUJBQXFCLENBQUMsYUFBYSxDQUFDLENBQUM7S0FDdEM7SUFFRCxPQUFPLEtBQUssV0FBVyxNQUFNO1FBQzNCLE1BQU0sT0FBTyxDQUFDLFVBQVUsQ0FDdEIsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQ25CLE9BQU8sQ0FBQyxVQUFVLENBQ2hCLG9CQUFvQjthQUNqQix3QkFBd0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDO2FBQ3BDLEdBQUcsQ0FBQyxDQUFDLE9BQU8sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLEtBQUssQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUMxQyxDQUNGLENBQ0YsQ0FBQztJQUNKLENBQUMsQ0FBQztBQUNKLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyByZWdpc3RlclNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vZ2xvYmFsLmpzXCI7XG5pbXBvcnQgdHlwZSB7IEV2ZW50RW52ZWxvcGUgfSBmcm9tIFwiLi4vLi4vZXZlbnQuanNcIjtcbmltcG9ydCB7IEV2ZW50SGFuZGxlclByb3ZpZGVyIH0gZnJvbSBcIi4uL3Byb3ZpZGVycy9ldmVudC1oYW5kbGVyLXByb3ZpZGVyLmpzXCI7XG5pbXBvcnQgeyBFdmVudHVhbFNlcnZpY2VDbGllbnQgfSBmcm9tIFwiLi4vLi4vc2VydmljZS1jbGllbnQuanNcIjtcblxuLyoqXG4gKiBUaGUgZGVwZW5kZW5jaWVzIG9mIHtAbGluayBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXJ9LlxuICovXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyB7XG4gIC8qKlxuICAgKiBUaGUge0BsaW5rIEV2ZW50dWFsU2VydmljZUNsaWVudH0gZm9yIGludGVyYWN0aW5nIHdpdGggd29ya2Zsb3dzIGNvbnRhaW5lZFxuICAgKiB3aXRoaW4gdGhlIHNlcnZpY2UgYm91bmRhcnkuXG4gICAqL1xuICBzZXJ2aWNlQ2xpZW50PzogRXZlbnR1YWxTZXJ2aWNlQ2xpZW50O1xuICAvKipcbiAgICogUmV0dXJucyBldmVudCBoYW5kbGVyc1xuICAgKi9cbiAgZXZlbnRIYW5kbGVyUHJvdmlkZXI6IEV2ZW50SGFuZGxlclByb3ZpZGVyO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIChldmVudHM6IEV2ZW50RW52ZWxvcGVbXSk6IFByb21pc2U8dm9pZD47XG59XG5cbi8qKlxuICogQ3JlYXRlcyBhIGdlbmVyaWMgZnVuY3Rpb24gZm9yIGhhbmRsaW5nIGluYm91bmQgZXZlbnQgcmVxdWVzdHNcbiAqIHRoYXQgY2FuIGJlIHVzZWQgaW4gcnVudGltZSBpbXBsZW1lbnRhdGlvbnMuIFRoaXMgaW1wbGVtZW50YXRpb24gaXNcbiAqIGRlY291cGxlZCBmcm9tIGEgcnVudGltZSdzIHNwZWNpZmljcyBieSB0aGUgY2xpZW50cy4gQSBydW50aW1lIG11c3RcbiAqIGluamVjdCBpdHMgb3duIGNsaWVudCBpbXBsZW1lbnRhdGlvbnMgZGVzaWduZWQgZm9yIHRoYXQgcGxhdGZvcm0uXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVFdmVudEhhbmRsZXJXb3JrZXIoe1xuICBzZXJ2aWNlQ2xpZW50LFxuICBldmVudEhhbmRsZXJQcm92aWRlcixcbn06IEV2ZW50SGFuZGxlckRlcGVuZGVuY2llcyk6IEV2ZW50SGFuZGxlcldvcmtlciB7XG4gIC8vIG1ha2UgdGhlIHdvcmtmbG93IGNsaWVudCBhdmFpbGFibGUgdG8gd2ViIGhvb2tzXG4gIGlmIChzZXJ2aWNlQ2xpZW50KSB7XG4gICAgcmVnaXN0ZXJTZXJ2aWNlQ2xpZW50KHNlcnZpY2VDbGllbnQpO1xuICB9XG5cbiAgcmV0dXJuIGFzeW5jIGZ1bmN0aW9uIChldmVudHMpIHtcbiAgICBhd2FpdCBQcm9taXNlLmFsbFNldHRsZWQoXG4gICAgICBldmVudHMubWFwKChldmVudCkgPT5cbiAgICAgICAgUHJvbWlzZS5hbGxTZXR0bGVkKFxuICAgICAgICAgIGV2ZW50SGFuZGxlclByb3ZpZGVyXG4gICAgICAgICAgICAuZ2V0RXZlbnRIYW5kbGVyc0ZvckV2ZW50KGV2ZW50Lm5hbWUpXG4gICAgICAgICAgICAubWFwKChoYW5kbGVyKSA9PiBoYW5kbGVyKGV2ZW50LmV2ZW50KSlcbiAgICAgICAgKVxuICAgICAgKVxuICAgICk7XG4gIH07XG59XG4iXX0=

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

import { isOrchestratorWorker } from "./runtime/flags.js";
import { getWorkflowClient } from "./global.js";
import { getServiceClient } from "./global.js";
import { ulid } from "ulidx";

@@ -113,4 +113,4 @@ export function signal(name) {

else {
return getWorkflowClient().sendSignal({
executionId,
return getServiceClient().sendSignal({
execution: executionId,
signal,

@@ -133,2 +133,2 @@ id: id ?? ulid(),

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AACnE,OAAO,EAAE,+BAA+B,EAAE,MAAM,gCAAgC,CAAC;AACjF,OAAO,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AACvE,OAAO,EAAE,oBAAoB,EAAE,MAAM,oBAAoB,CAAC;AAC1D,OAAO,EAAE,iBAAiB,EAAE,MAAM,aAAa,CAAC;AAChD,OAAO,EAAE,IAAI,EAAE,MAAM,OAAO,CAAC;AAkB7B,MAAM,UAAU,MAAM,CAAiB,IAAY;IACjD,OAAO,IAAI,MAAM,CAAC,IAAI,CAAC,CAAC;AAC1B,CAAC;AAED,MAAM,OAAO,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;AAuCD,MAAM,UAAU,YAAY,CAC1B,MAA4B,EAC5B,IAA0B;IAE1B,IAAI,CAAC,oBAAoB,EAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,0CAA0C,CAAC,CAAC;KAC7D;IAED,OAAO,sBAAsB,CAC3B,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,IAAI,EAAE,cAAc,CACd,CAAC;AACX,CAAC;AAuCD,MAAM,UAAU,QAAQ,CACtB,MAA4B,EAC5B,OAAmC;IAEnC,IAAI,CAAC,oBAAoB,EAAE,EAAE;QAC3B,MAAM,IAAI,KAAK,CAAC,sCAAsC,CAAC,CAAC;KACzD;IAED,OAAO,+BAA+B,CACpC,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,EAC/C,OAAc,CACf,CAAC;AACJ,CAAC;AA+BD,MAAM,UAAU,UAAU,CACxB,WAAmB,EACnB,MAA4B,EAC5B,OAAa,EACb,EAAW;IAEX,IAAI,oBAAoB,EAAE,EAAE;QAC1B,OAAO,oBAAoB,CACzB,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,iBAAiB,EAAE,CAAC,UAAU,CAAC;YACpC,WAAW;YACX,MAAM;YACN,EAAE,EAAE,EAAE,IAAI,IAAI,EAAE;YAChB,OAAO;SACR,CAAC,CAAC;KACJ;AACH,CAAC;AAID,MAAM,CAAN,IAAY,gBAGX;AAHD,WAAY,gBAAgB;IAC1B,iEAAS,CAAA;IACT,2EAAc,CAAA;AAChB,CAAC,EAHW,gBAAgB,KAAhB,gBAAgB,QAG3B;AAaD,MAAM,UAAU,sBAAsB,CACpC,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,cAAc,CAAC;AACzD,CAAC;AAED,MAAM,UAAU,iBAAiB,CAC/B,MAAoB;IAEpB,OAAO,MAAM,CAAC,IAAI,KAAK,gBAAgB,CAAC,SAAS,CAAC;AACpD,CAAC","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { getWorkflowClient } from \"./global.js\";\nimport { ulid } from \"ulidx\";\n\n/**\n * A reference to a created signal handler.\n */\nexport interface SignalsHandler {\n  /**\n   * Remove the handler from the signal.\n   *\n   * Any ongoing {@link Chain}s started by the handler will continue to run to completion.\n   */\n  dispose: () => void;\n}\n\nexport type SignalHandlerFunction<Payload = void> = (\n  payload: Payload\n) => Promise<void> | void;\n\nexport function signal<Payload = void>(name: string): Signal<Payload> {\n  return new Signal(name);\n}\n\nexport class Signal<Payload = void> {\n  constructor(readonly id: string) {}\n  /**\n   * Listens for signals sent to the current workflow.\n   *\n   * When the signal is received, the handler is invoked.\n   * If the handler return a promise, the handler is added a {@link Chain}\n   * and progressed until completion.\n   *\n   * ```ts\n   * const mySignal = 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 getWorkflowClient().sendSignal({\n      executionId,\n      signal,\n      id: id ?? ulid(),\n      payload,\n    });\n  }\n}\n\nexport type SignalTarget = ExecutionTarget | ChildExecutionTarget;\n\nexport enum SignalTargetType {\n  Execution,\n  ChildExecution,\n}\n\nexport interface ExecutionTarget {\n  type: SignalTargetType.Execution;\n  executionId: string;\n}\n\nexport interface ChildExecutionTarget {\n  type: SignalTargetType.ChildExecution;\n  workflowName: string;\n  seq: number;\n}\n\nexport function isChildExecutionTarget(\n  target: SignalTarget\n): target is ChildExecutionTarget {\n  return target.type === SignalTargetType.ChildExecution;\n}\n\nexport function isExecutionTarget(\n  target: SignalTarget\n): target is ExecutionTarget {\n  return target.type === SignalTargetType.Execution;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signals.js","sourceRoot":"","sources":["../../src/signals.ts"],"names":[],"mappings":"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","sourcesContent":["import { createSendSignalCall } from \"./calls/send-signal-call.js\";\nimport { createRegisterSignalHandlerCall } from \"./calls/signal-handler-call.js\";\nimport { createExpectSignalCall } from \"./calls/expect-signal-call.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { 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"]}

@@ -6,15 +6,4 @@ import type { Program } from "./interpret.js";

import { ChildExecution, ExecutionHandle } from "./execution.js";
import { StartExecutionRequest } from "./service-client.js";
export type WorkflowHandler<Input = any, Output = any> = (input: Input, context: Context) => Promise<Output> | Program<Output>;
export interface StartExecutionRequest<Input> extends WorkflowOptions {
/**
* Input payload for the workflow.
*/
input: Input;
/**
* Optional name of the workflow to start - used to determine the unique ID and enforce idempotency.
*
* @default - a unique ID is generated.
*/
name?: string;
}
/**

@@ -33,4 +22,4 @@ * Options which determine how a workflow operates.

}
export type WorkflowOutput<W extends Workflow<any, any>> = W extends Workflow<any, infer Out> ? Out : never;
export type WorkflowInput<W extends Workflow<any, any>> = W extends Workflow<infer In, any> ? In : never;
export type WorkflowOutput<W extends Workflow> = W extends Workflow<any, infer Out> ? Out : never;
export type WorkflowInput<W extends Workflow> = W extends Workflow<infer In, any> ? In : undefined;
/**

@@ -40,3 +29,3 @@ * A {@link Workflow} is a long-running process that orchestrates calls

*/
export interface Workflow<Input = any, Output = any> {
export interface Workflow<in Input = any, Output = any> {
/**

@@ -60,3 +49,3 @@ * Globally unique ID of this {@link Workflow}.

*/
startExecution(request: StartExecutionRequest<Input>): Promise<ExecutionHandle<Workflow<Input, Output>>>;
startExecution(request: Omit<StartExecutionRequest<Workflow<Input, Output>>, "workflow">): Promise<ExecutionHandle<Workflow<Input, Output>>>;
}

@@ -63,0 +52,0 @@ export declare function lookupWorkflow(name: string): Workflow | undefined;

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

import { workflows, clearEventualCollector, getWorkflowClient, } from "./global.js";
import { workflows, clearEventualCollector, getServiceClient, } from "./global.js";
import { DeterminismError } from "./error.js";

@@ -8,3 +8,2 @@ import { filterEvents, isHistoryEvent, isSleepCompleted, isSleepScheduled, isWorkflowStarted, WorkflowEventType, } from "./workflow-events.js";

import { isChain } from "./chain.js";
import { ExecutionHandle } from "./execution.js";
export function lookupWorkflow(name) {

@@ -26,6 +25,6 @@ return workflows().get(name);

workflow.startExecution = async function (input) {
const workflowClient = getWorkflowClient();
const executionId = await workflowClient.startWorkflow({
workflowName: name,
executionName: input.name,
const serviceClient = getServiceClient();
return await serviceClient.startExecution({
workflow: name,
executionName: input.executionName,
input: input.input,

@@ -35,3 +34,2 @@ timeoutSeconds: input.timeoutSeconds,

});
return new ExecutionHandle(executionId, workflowClient);
};

@@ -109,2 +107,2 @@ workflow.definition = (isChain(definition)

}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  workflows,\n  clearEventualCollector,\n  getWorkflowClient,\n} from \"./global.js\";\nimport type { Program } from \"./interpret.js\";\nimport type { Context, WorkflowContext } from \"./context.js\";\nimport { DeterminismError } from \"./error.js\";\nimport {\n  filterEvents,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isSleepScheduled,\n  isWorkflowStarted,\n  SleepCompleted,\n  SleepScheduled,\n  WorkflowEventType,\n} from \"./workflow-events.js\";\nimport { interpret, WorkflowResult } from \"./interpret.js\";\nimport { createWorkflowCall } from \"./calls/workflow-call.js\";\nimport { AwaitedEventual } from \"./eventual.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { isChain } from \"./chain.js\";\nimport { ChildExecution, ExecutionHandle } from \"./execution.js\";\n\nexport type WorkflowHandler<Input = any, Output = any> = (\n  input: Input,\n  context: Context\n) => Promise<Output> | Program<Output>;\n\nexport interface StartExecutionRequest<Input> extends WorkflowOptions {\n  /**\n   * Input payload for the workflow.\n   */\n  input: Input;\n  /**\n   * Optional name of the workflow to start - used to determine the unique ID and enforce idempotency.\n   *\n   * @default - a unique ID is generated.\n   */\n  name?: string;\n}\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeoutSeconds?: number;\n}\n\nexport type WorkflowOutput<W extends Workflow<any, any>> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow<any, any>> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : never;\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  workflowName: string;\n\n  options?: WorkflowOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (input: Input): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: StartExecutionRequest<Input>\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n\n  /**\n   * @internal - this is the internal DSL representation that produces a {@link Program} instead of a Promise.\n   */\n  definition: (\n    input: Input,\n    context: Context\n  ) => Program<AwaitedEventual<Output>>;\n}\n\nexport function lookupWorkflow(name: string): Workflow | undefined {\n  return workflows().get(name);\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [opts: WorkflowOptions, definition: WorkflowHandler<Input, Output>]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((input?: any) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    return createWorkflowCall(name, input, opts);\n  }) as any;\n\n  workflow.workflowName = name;\n\n  workflow.startExecution = async function (input) {\n    const workflowClient = getWorkflowClient();\n    const executionId = await workflowClient.startWorkflow({\n      workflowName: name,\n      executionName: input.name,\n      input: input.input,\n      timeoutSeconds: input.timeoutSeconds,\n      ...opts,\n    });\n\n    return new ExecutionHandle(executionId, workflowClient);\n  };\n\n  workflow.definition = (\n    isChain(definition)\n      ? definition\n      : function* (input, context): any {\n          return yield definition(input, context);\n        }\n  ) as Workflow<Input, Output>[\"definition\"]; // safe to cast because we rely on transformer (it is always the generator API)\n  workflows().set(name, workflow);\n  return workflow;\n}\n\nexport interface ProgressWorkflowResult extends WorkflowResult {\n  history: HistoryStateEvent[];\n}\n\n/**\n * Advance a workflow using previous history, new events, and a program.\n */\nexport function progressWorkflow(\n  program: Workflow,\n  historyEvents: HistoryStateEvent[],\n  taskEvents: HistoryStateEvent[],\n  workflowContext: WorkflowContext,\n  executionId: string,\n  baseTime: Date = new Date()\n): ProgressWorkflowResult {\n  // historical events and incoming events will be fed into the workflow to resume/progress state\n  const uniqueTaskEvents = filterEvents<HistoryStateEvent>(\n    historyEvents,\n    taskEvents\n  );\n\n  const inputEvents = [...historyEvents, ...uniqueTaskEvents];\n\n  // Generates events that are time sensitive, like sleep completed events.\n  const syntheticEvents = generateSyntheticEvents(inputEvents, baseTime);\n\n  const allEvents = [...inputEvents, ...syntheticEvents];\n\n  const startEvent = inputEvents.find(isWorkflowStarted);\n\n  if (!startEvent) {\n    throw new DeterminismError(\n      `No ${WorkflowEventType.WorkflowStarted} found.`\n    );\n  }\n\n  const context: Context = {\n    workflow: workflowContext,\n    execution: {\n      ...startEvent.context,\n      id: executionId,\n      startTime: startEvent.timestamp,\n    },\n  };\n\n  // execute workflow\n  const interpretEvents = allEvents.filter(isHistoryEvent);\n\n  console.debug(\"history events\", JSON.stringify(historyEvents));\n  console.debug(\"task events\", JSON.stringify(taskEvents));\n  console.debug(\"synthetic events\", JSON.stringify(syntheticEvents));\n  console.debug(\"interpret events\", JSON.stringify(interpretEvents));\n\n  try {\n    return {\n      ...interpret(\n        program.definition(startEvent.input, context),\n        interpretEvents\n      ),\n      history: allEvents,\n    };\n  } catch (err) {\n    // temporary fix when the interpreter fails, but the activities are not cleared.\n    clearEventualCollector();\n    throw err;\n  }\n}\n\n/**\n * Generates synthetic events, for example, {@link SleepCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): SleepCompleted[] {\n  const unresolvedSleep: Record<number, SleepScheduled> = {};\n\n  const sleepEvents = events.filter(\n    (event): event is SleepScheduled | SleepCompleted =>\n      isSleepScheduled(event) || isSleepCompleted(event)\n  );\n\n  for (const event of sleepEvents) {\n    if (isSleepScheduled(event)) {\n      unresolvedSleep[event.seq] = event;\n    } else {\n      delete unresolvedSleep[event.seq];\n    }\n  }\n\n  const syntheticSleepComplete: SleepCompleted[] = Object.values(\n    unresolvedSleep\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.SleepCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies SleepCompleted)\n    );\n\n  return syntheticSleepComplete;\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"workflow.js","sourceRoot":"","sources":["../../src/workflow.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  workflows,\n  clearEventualCollector,\n  getServiceClient,\n} from \"./global.js\";\nimport type { Program } from \"./interpret.js\";\nimport type { Context, WorkflowContext } from \"./context.js\";\nimport { DeterminismError } from \"./error.js\";\nimport {\n  filterEvents,\n  HistoryStateEvent,\n  isHistoryEvent,\n  isSleepCompleted,\n  isSleepScheduled,\n  isWorkflowStarted,\n  SleepCompleted,\n  SleepScheduled,\n  WorkflowEventType,\n} from \"./workflow-events.js\";\nimport { interpret, WorkflowResult } from \"./interpret.js\";\nimport { createWorkflowCall } from \"./calls/workflow-call.js\";\nimport { AwaitedEventual } from \"./eventual.js\";\nimport { isOrchestratorWorker } from \"./runtime/flags.js\";\nimport { isChain } from \"./chain.js\";\nimport { ChildExecution, ExecutionHandle } from \"./execution.js\";\nimport { StartExecutionRequest } from \"./service-client.js\";\n\nexport type WorkflowHandler<Input = any, Output = any> = (\n  input: Input,\n  context: Context\n) => Promise<Output> | Program<Output>;\n\n/**\n * Options which determine how a workflow operates.\n *\n * Can be provided at workflow definition time and/or overridden by the caller of {@link WorkflowClient.startWorkflow}.\n */\nexport interface WorkflowOptions {\n  /**\n   * Number of seconds before execution times out.\n   *\n   * @default - workflow will never timeout.\n   */\n  timeoutSeconds?: number;\n}\n\nexport type WorkflowOutput<W extends Workflow> = W extends Workflow<\n  any,\n  infer Out\n>\n  ? Out\n  : never;\n\nexport type WorkflowInput<W extends Workflow> = W extends Workflow<\n  infer In,\n  any\n>\n  ? In\n  : undefined;\n\n/**\n * A {@link Workflow} is a long-running process that orchestrates calls\n * to other services in a durable and observable way.\n */\nexport interface Workflow<in Input = any, Output = any> {\n  /**\n   * Globally unique ID of this {@link Workflow}.\n   */\n  workflowName: string;\n\n  options?: WorkflowOptions;\n\n  /**\n   * Invokes the {@link Workflow} from within another workflow.\n   *\n   * This can only be called from within another workflow because it's not possible\n   * to wait for completion synchronously - it relies on the event-driven environment\n   * of a workflow execution.\n   *\n   * To start a workflow from another environment, use {@link start}.\n   */\n  (input: Input): Promise<Output> & ChildExecution;\n\n  /**\n   * Starts a workflow execution\n   */\n  startExecution(\n    request: Omit<StartExecutionRequest<Workflow<Input, Output>>, \"workflow\">\n  ): Promise<ExecutionHandle<Workflow<Input, Output>>>;\n\n  /**\n   * @internal - this is the internal DSL representation that produces a {@link Program} instead of a Promise.\n   */\n  definition: (\n    input: Input,\n    context: Context\n  ) => Program<AwaitedEventual<Output>>;\n}\n\nexport function lookupWorkflow(name: string): Workflow | undefined {\n  return workflows().get(name);\n}\n\n/**\n * Creates and registers a long-running workflow.\n *\n * Example:\n * ```ts\n * import { activity, workflow } from \"@eventual/core\";\n *\n * export default workflow(\"my-workflow\", async ({ name }: { name: string }) => {\n *   const result = await hello(name);\n *   console.log(result);\n *   return `you said ${result}`;\n * });\n *\n * const hello = activity(\"hello\", async (name: string) => {\n *   return `hello ${name}`;\n * });\n * ```\n * @param name a globally unique ID for this workflow.\n * @param definition the workflow definition.\n */\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  opts: WorkflowOptions,\n  definition: WorkflowHandler<Input, Output>\n): Workflow<Input, Output>;\nexport function workflow<Input = any, Output = any>(\n  name: string,\n  ...args:\n    | [opts: WorkflowOptions, definition: WorkflowHandler<Input, Output>]\n    | [definition: WorkflowHandler<Input, Output>]\n): Workflow<Input, Output> {\n  const [opts, definition] = args.length === 1 ? [undefined, args[0]] : args;\n  if (workflows().has(name)) {\n    throw new Error(`workflow with name '${name}' already exists`);\n  }\n\n  const workflow: Workflow<Input, Output> = ((input?: any) => {\n    if (!isOrchestratorWorker()) {\n      throw new Error(\n        \"Direct workflow invocation is only valid in a workflow, use workflow.startExecution instead.\"\n      );\n    }\n\n    return createWorkflowCall(name, input, opts);\n  }) as any;\n\n  workflow.workflowName = name;\n\n  workflow.startExecution = async function (input) {\n    const serviceClient = getServiceClient();\n    return await serviceClient.startExecution<Workflow<Input, Output>>({\n      workflow: name,\n      executionName: input.executionName,\n      input: input.input,\n      timeoutSeconds: input.timeoutSeconds,\n      ...opts,\n    });\n  };\n\n  workflow.definition = (\n    isChain(definition)\n      ? definition\n      : function* (input, context): any {\n          return yield definition(input, context);\n        }\n  ) as Workflow<Input, Output>[\"definition\"]; // safe to cast because we rely on transformer (it is always the generator API)\n  workflows().set(name, workflow);\n  return workflow;\n}\n\nexport interface ProgressWorkflowResult extends WorkflowResult {\n  history: HistoryStateEvent[];\n}\n\n/**\n * Advance a workflow using previous history, new events, and a program.\n */\nexport function progressWorkflow(\n  program: Workflow,\n  historyEvents: HistoryStateEvent[],\n  taskEvents: HistoryStateEvent[],\n  workflowContext: WorkflowContext,\n  executionId: string,\n  baseTime: Date = new Date()\n): ProgressWorkflowResult {\n  // historical events and incoming events will be fed into the workflow to resume/progress state\n  const uniqueTaskEvents = filterEvents<HistoryStateEvent>(\n    historyEvents,\n    taskEvents\n  );\n\n  const inputEvents = [...historyEvents, ...uniqueTaskEvents];\n\n  // Generates events that are time sensitive, like sleep completed events.\n  const syntheticEvents = generateSyntheticEvents(inputEvents, baseTime);\n\n  const allEvents = [...inputEvents, ...syntheticEvents];\n\n  const startEvent = inputEvents.find(isWorkflowStarted);\n\n  if (!startEvent) {\n    throw new DeterminismError(\n      `No ${WorkflowEventType.WorkflowStarted} found.`\n    );\n  }\n\n  const context: Context = {\n    workflow: workflowContext,\n    execution: {\n      ...startEvent.context,\n      id: executionId,\n      startTime: startEvent.timestamp,\n    },\n  };\n\n  // execute workflow\n  const interpretEvents = allEvents.filter(isHistoryEvent);\n\n  console.debug(\"history events\", JSON.stringify(historyEvents));\n  console.debug(\"task events\", JSON.stringify(taskEvents));\n  console.debug(\"synthetic events\", JSON.stringify(syntheticEvents));\n  console.debug(\"interpret events\", JSON.stringify(interpretEvents));\n\n  try {\n    return {\n      ...interpret(\n        program.definition(startEvent.input, context),\n        interpretEvents\n      ),\n      history: allEvents,\n    };\n  } catch (err) {\n    // temporary fix when the interpreter fails, but the activities are not cleared.\n    clearEventualCollector();\n    throw err;\n  }\n}\n\n/**\n * Generates synthetic events, for example, {@link SleepCompleted} events when the time has passed, but a real completed event has not come in yet.\n */\nexport function generateSyntheticEvents(\n  events: HistoryStateEvent[],\n  baseTime: Date\n): SleepCompleted[] {\n  const unresolvedSleep: Record<number, SleepScheduled> = {};\n\n  const sleepEvents = events.filter(\n    (event): event is SleepScheduled | SleepCompleted =>\n      isSleepScheduled(event) || isSleepCompleted(event)\n  );\n\n  for (const event of sleepEvents) {\n    if (isSleepScheduled(event)) {\n      unresolvedSleep[event.seq] = event;\n    } else {\n      delete unresolvedSleep[event.seq];\n    }\n  }\n\n  const syntheticSleepComplete: SleepCompleted[] = Object.values(\n    unresolvedSleep\n  )\n    .filter(\n      (event) => new Date(event.untilTime).getTime() <= baseTime.getTime()\n    )\n    .map(\n      (e) =>\n        ({\n          type: WorkflowEventType.SleepCompleted,\n          seq: e.seq,\n          timestamp: baseTime.toISOString(),\n        } satisfies SleepCompleted)\n    );\n\n  return syntheticSleepComplete;\n}\n"]}
{
"name": "@eventual/core",
"version": "0.4.3",
"version": "0.5.0",
"exports": {

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

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is not supported yet

Sorry, the diff of this file is 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