@trigger.dev/core 3.0.0-beta.16 → 3.0.0-beta.18

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/dist/catalog-A-D3UC6S.d.mts +6646 -0
  2. package/dist/catalog-TAZd4-TP.d.ts +6646 -0
  3. package/dist/manager-M9GLDnhJ.d.mts +1158 -0
  4. package/dist/manager-M9GLDnhJ.d.ts +1158 -0
  5. package/dist/messages-AriaDDm0.d.mts +8696 -0
  6. package/dist/messages-AriaDDm0.d.ts +8696 -0
  7. package/dist/v3/dev/index.d.mts +28 -0
  8. package/dist/v3/dev/index.d.ts +28 -0
  9. package/dist/v3/dev/index.js +93 -0
  10. package/dist/v3/dev/index.js.map +1 -0
  11. package/dist/v3/dev/index.mjs +91 -0
  12. package/dist/v3/dev/index.mjs.map +1 -0
  13. package/dist/v3/index.d.mts +299 -17348
  14. package/dist/v3/index.d.ts +299 -17348
  15. package/dist/v3/index.js +2091 -3860
  16. package/dist/v3/index.js.map +1 -1
  17. package/dist/v3/index.mjs +2093 -3836
  18. package/dist/v3/index.mjs.map +1 -1
  19. package/dist/v3/otel/index.js +62 -38
  20. package/dist/v3/otel/index.js.map +1 -1
  21. package/dist/v3/otel/index.mjs +62 -38
  22. package/dist/v3/otel/index.mjs.map +1 -1
  23. package/dist/v3/prod/index.d.mts +45 -0
  24. package/dist/v3/prod/index.d.ts +45 -0
  25. package/dist/v3/prod/index.js +205 -0
  26. package/dist/v3/prod/index.js.map +1 -0
  27. package/dist/v3/prod/index.mjs +203 -0
  28. package/dist/v3/prod/index.mjs.map +1 -0
  29. package/dist/v3/utils/structuredLogger.d.mts +31 -0
  30. package/dist/v3/utils/structuredLogger.d.ts +31 -0
  31. package/dist/v3/utils/structuredLogger.js +88 -0
  32. package/dist/v3/utils/structuredLogger.js.map +1 -0
  33. package/dist/v3/utils/structuredLogger.mjs +86 -0
  34. package/dist/v3/utils/structuredLogger.mjs.map +1 -0
  35. package/dist/v3/workers/index.d.mts +95 -0
  36. package/dist/v3/workers/index.d.ts +95 -0
  37. package/dist/v3/workers/index.js +2663 -0
  38. package/dist/v3/workers/index.js.map +1 -0
  39. package/dist/v3/workers/index.mjs +2647 -0
  40. package/dist/v3/workers/index.mjs.map +1 -0
  41. package/dist/v3/zodIpc.d.mts +32 -0
  42. package/dist/v3/zodIpc.d.ts +32 -0
  43. package/dist/v3/zodIpc.js +268 -0
  44. package/dist/v3/zodIpc.js.map +1 -0
  45. package/dist/v3/zodIpc.mjs +266 -0
  46. package/dist/v3/zodIpc.mjs.map +1 -0
  47. package/dist/v3/zodMessageHandler.d.mts +69 -0
  48. package/dist/v3/zodMessageHandler.d.ts +69 -0
  49. package/dist/v3/zodMessageHandler.js +168 -0
  50. package/dist/v3/zodMessageHandler.js.map +1 -0
  51. package/dist/v3/zodMessageHandler.mjs +163 -0
  52. package/dist/v3/zodMessageHandler.mjs.map +1 -0
  53. package/dist/v3/zodNamespace.d.mts +3663 -0
  54. package/dist/v3/zodNamespace.d.ts +3663 -0
  55. package/dist/v3/zodNamespace.js +356 -0
  56. package/dist/v3/zodNamespace.js.map +1 -0
  57. package/dist/v3/zodNamespace.mjs +354 -0
  58. package/dist/v3/zodNamespace.mjs.map +1 -0
  59. package/dist/v3/zodSocket.d.mts +88 -0
  60. package/dist/v3/zodSocket.d.ts +88 -0
  61. package/dist/v3/zodSocket.js +309 -0
  62. package/dist/v3/zodSocket.js.map +1 -0
  63. package/dist/v3/zodSocket.mjs +305 -0
  64. package/dist/v3/zodSocket.mjs.map +1 -0
  65. package/package.json +69 -5
@@ -0,0 +1,2663 @@
1
+ 'use strict';
2
+
3
+ var api = require('@opentelemetry/api');
4
+ require('path');
5
+ var apiLogs = require('@opentelemetry/api-logs');
6
+ var exporterLogsOtlpHttp = require('@opentelemetry/exporter-logs-otlp-http');
7
+ var exporterTraceOtlpHttp = require('@opentelemetry/exporter-trace-otlp-http');
8
+ var instrumentation = require('@opentelemetry/instrumentation');
9
+ var resources = require('@opentelemetry/resources');
10
+ var sdkLogs = require('@opentelemetry/sdk-logs');
11
+ var sdkTraceNode = require('@opentelemetry/sdk-trace-node');
12
+ var semanticConventions = require('@opentelemetry/semantic-conventions');
13
+ var zod = require('zod');
14
+ var zodValidationError = require('zod-validation-error');
15
+ var async_hooks = require('async_hooks');
16
+ var preciseDate = require('@google-cloud/precise-date');
17
+ var util = require('util');
18
+
19
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
20
+
21
+ var util__default = /*#__PURE__*/_interopDefault(util);
22
+
23
+ var __defProp = Object.defineProperty;
24
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
25
+ var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
26
+ var __publicField = (obj, key, value) => {
27
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
28
+ return value;
29
+ };
30
+ var __accessCheck = (obj, member, msg) => {
31
+ if (!member.has(obj))
32
+ throw TypeError("Cannot " + msg);
33
+ };
34
+ var __privateGet = (obj, member, getter) => {
35
+ __accessCheck(obj, member, "read from private field");
36
+ return getter ? getter.call(obj) : member.get(obj);
37
+ };
38
+ var __privateAdd = (obj, member, value) => {
39
+ if (member.has(obj))
40
+ throw TypeError("Cannot add the same private member more than once");
41
+ member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
42
+ };
43
+ var __privateMethod = (obj, member, method) => {
44
+ __accessCheck(obj, member, "access private method");
45
+ return method;
46
+ };
47
+ function parseError(error) {
48
+ if (error instanceof Error) {
49
+ return {
50
+ type: "BUILT_IN_ERROR",
51
+ name: error.name,
52
+ message: error.message,
53
+ stackTrace: error.stack ?? ""
54
+ };
55
+ }
56
+ if (typeof error === "string") {
57
+ return {
58
+ type: "STRING_ERROR",
59
+ raw: error
60
+ };
61
+ }
62
+ try {
63
+ return {
64
+ type: "CUSTOM_ERROR",
65
+ raw: JSON.stringify(error)
66
+ };
67
+ } catch (e) {
68
+ return {
69
+ type: "CUSTOM_ERROR",
70
+ raw: String(error)
71
+ };
72
+ }
73
+ }
74
+ __name(parseError, "parseError");
75
+
76
+ // src/v3/limits.ts
77
+ var OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;
78
+ var OTEL_LOG_ATTRIBUTE_COUNT_LIMIT = 256;
79
+ var OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
80
+ var OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT = 1028;
81
+ var OTEL_SPAN_EVENT_COUNT_LIMIT = 10;
82
+ var OTEL_LINK_COUNT_LIMIT = 2;
83
+ var OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT = 10;
84
+ var OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT = 10;
85
+ var OFFLOAD_IO_PACKET_LENGTH_LIMIT = 128 * 1024;
86
+
87
+ // src/v3/semanticInternalAttributes.ts
88
+ var SemanticInternalAttributes = {
89
+ ENVIRONMENT_ID: "ctx.environment.id",
90
+ ENVIRONMENT_TYPE: "ctx.environment.type",
91
+ ORGANIZATION_ID: "ctx.organization.id",
92
+ ORGANIZATION_SLUG: "ctx.organization.slug",
93
+ ORGANIZATION_NAME: "ctx.organization.name",
94
+ PROJECT_ID: "ctx.project.id",
95
+ PROJECT_REF: "ctx.project.ref",
96
+ PROJECT_NAME: "ctx.project.title",
97
+ PROJECT_DIR: "project.dir",
98
+ ATTEMPT_ID: "ctx.attempt.id",
99
+ ATTEMPT_NUMBER: "ctx.attempt.number",
100
+ RUN_ID: "ctx.run.id",
101
+ RUN_IS_TEST: "ctx.run.isTest",
102
+ BATCH_ID: "ctx.batch.id",
103
+ TASK_SLUG: "ctx.task.id",
104
+ TASK_PATH: "ctx.task.filePath",
105
+ TASK_EXPORT_NAME: "ctx.task.exportName",
106
+ QUEUE_NAME: "ctx.queue.name",
107
+ QUEUE_ID: "ctx.queue.id",
108
+ SPAN_PARTIAL: "$span.partial",
109
+ SPAN_ID: "$span.span_id",
110
+ OUTPUT: "$output",
111
+ OUTPUT_TYPE: "$mime_type_output",
112
+ STYLE: "$style",
113
+ STYLE_ICON: "$style.icon",
114
+ STYLE_VARIANT: "$style.variant",
115
+ STYLE_ACCESSORY: "$style.accessory",
116
+ METADATA: "$metadata",
117
+ TRIGGER: "$trigger",
118
+ PAYLOAD: "$payload",
119
+ PAYLOAD_TYPE: "$mime_type_payload",
120
+ SHOW: "$show",
121
+ SHOW_ACTIONS: "$show.actions",
122
+ WORKER_ID: "worker.id",
123
+ WORKER_VERSION: "worker.version",
124
+ CLI_VERSION: "cli.version",
125
+ SDK_VERSION: "sdk.version",
126
+ SDK_LANGUAGE: "sdk.language",
127
+ RETRY_AT: "retry.at",
128
+ RETRY_DELAY: "retry.delay",
129
+ RETRY_COUNT: "retry.count",
130
+ LINK_TITLE: "$link.title",
131
+ IDEMPOTENCY_KEY: "ctx.run.idempotencyKey"
132
+ };
133
+
134
+ // src/v3/utils/flattenAttributes.ts
135
+ function flattenAttributes(obj, prefix) {
136
+ const result = {};
137
+ if (!obj) {
138
+ return result;
139
+ }
140
+ if (typeof obj === "string") {
141
+ result[prefix || ""] = obj;
142
+ return result;
143
+ }
144
+ if (typeof obj === "number") {
145
+ result[prefix || ""] = obj;
146
+ return result;
147
+ }
148
+ if (typeof obj === "boolean") {
149
+ result[prefix || ""] = obj;
150
+ return result;
151
+ }
152
+ for (const [key, value] of Object.entries(obj)) {
153
+ const newPrefix = `${prefix ? `${prefix}.` : ""}${key}`;
154
+ if (Array.isArray(value)) {
155
+ for (let i = 0; i < value.length; i++) {
156
+ if (typeof value[i] === "object" && value[i] !== null) {
157
+ Object.assign(result, flattenAttributes(value[i], `${newPrefix}.[${i}]`));
158
+ } else {
159
+ result[`${newPrefix}.[${i}]`] = value[i];
160
+ }
161
+ }
162
+ } else if (isRecord(value)) {
163
+ Object.assign(result, flattenAttributes(value, newPrefix));
164
+ } else {
165
+ if (typeof value === "number" || typeof value === "string" || typeof value === "boolean") {
166
+ result[newPrefix] = value;
167
+ }
168
+ }
169
+ }
170
+ return result;
171
+ }
172
+ __name(flattenAttributes, "flattenAttributes");
173
+ function isRecord(value) {
174
+ return value !== null && typeof value === "object" && !Array.isArray(value);
175
+ }
176
+ __name(isRecord, "isRecord");
177
+
178
+ // src/v3/utils/platform.ts
179
+ var _globalThis = typeof globalThis === "object" ? globalThis : global;
180
+
181
+ // src/v3/utils/globals.ts
182
+ var GLOBAL_TRIGGER_DOT_DEV_KEY = Symbol.for(`dev.trigger.ts.api`);
183
+ var _global = _globalThis;
184
+ function registerGlobal(type, instance, allowOverride = false) {
185
+ const api = _global[GLOBAL_TRIGGER_DOT_DEV_KEY] = _global[GLOBAL_TRIGGER_DOT_DEV_KEY] ?? {};
186
+ if (!allowOverride && api[type]) {
187
+ return false;
188
+ }
189
+ api[type] = instance;
190
+ return true;
191
+ }
192
+ __name(registerGlobal, "registerGlobal");
193
+ function getGlobal(type) {
194
+ return _global[GLOBAL_TRIGGER_DOT_DEV_KEY]?.[type];
195
+ }
196
+ __name(getGlobal, "getGlobal");
197
+ function unregisterGlobal(type) {
198
+ const api = _global[GLOBAL_TRIGGER_DOT_DEV_KEY];
199
+ if (api) {
200
+ delete api[type];
201
+ }
202
+ }
203
+ __name(unregisterGlobal, "unregisterGlobal");
204
+
205
+ // src/v3/taskContext/index.ts
206
+ var API_NAME = "task-context";
207
+ var _getTaskContext, getTaskContext_fn;
208
+ var _TaskContextAPI = class _TaskContextAPI {
209
+ constructor() {
210
+ __privateAdd(this, _getTaskContext);
211
+ }
212
+ static getInstance() {
213
+ if (!this._instance) {
214
+ this._instance = new _TaskContextAPI();
215
+ }
216
+ return this._instance;
217
+ }
218
+ get isInsideTask() {
219
+ return __privateMethod(this, _getTaskContext, getTaskContext_fn).call(this) !== void 0;
220
+ }
221
+ get ctx() {
222
+ return __privateMethod(this, _getTaskContext, getTaskContext_fn).call(this)?.ctx;
223
+ }
224
+ get worker() {
225
+ return __privateMethod(this, _getTaskContext, getTaskContext_fn).call(this)?.worker;
226
+ }
227
+ get attributes() {
228
+ if (this.ctx) {
229
+ return {
230
+ ...this.contextAttributes,
231
+ ...this.workerAttributes
232
+ };
233
+ }
234
+ return {};
235
+ }
236
+ get workerAttributes() {
237
+ if (this.worker) {
238
+ return {
239
+ [SemanticInternalAttributes.WORKER_ID]: this.worker.id,
240
+ [SemanticInternalAttributes.WORKER_VERSION]: this.worker.version
241
+ };
242
+ }
243
+ return {};
244
+ }
245
+ get contextAttributes() {
246
+ if (this.ctx) {
247
+ return {
248
+ [SemanticInternalAttributes.ATTEMPT_ID]: this.ctx.attempt.id,
249
+ [SemanticInternalAttributes.ATTEMPT_NUMBER]: this.ctx.attempt.number,
250
+ [SemanticInternalAttributes.TASK_SLUG]: this.ctx.task.id,
251
+ [SemanticInternalAttributes.TASK_PATH]: this.ctx.task.filePath,
252
+ [SemanticInternalAttributes.TASK_EXPORT_NAME]: this.ctx.task.exportName,
253
+ [SemanticInternalAttributes.QUEUE_NAME]: this.ctx.queue.name,
254
+ [SemanticInternalAttributes.QUEUE_ID]: this.ctx.queue.id,
255
+ [SemanticInternalAttributes.ENVIRONMENT_ID]: this.ctx.environment.id,
256
+ [SemanticInternalAttributes.ENVIRONMENT_TYPE]: this.ctx.environment.type,
257
+ [SemanticInternalAttributes.ORGANIZATION_ID]: this.ctx.organization.id,
258
+ [SemanticInternalAttributes.PROJECT_ID]: this.ctx.project.id,
259
+ [SemanticInternalAttributes.PROJECT_REF]: this.ctx.project.ref,
260
+ [SemanticInternalAttributes.PROJECT_NAME]: this.ctx.project.name,
261
+ [SemanticInternalAttributes.RUN_ID]: this.ctx.run.id,
262
+ [SemanticInternalAttributes.RUN_IS_TEST]: this.ctx.run.isTest,
263
+ [SemanticInternalAttributes.ORGANIZATION_SLUG]: this.ctx.organization.slug,
264
+ [SemanticInternalAttributes.ORGANIZATION_NAME]: this.ctx.organization.name,
265
+ [SemanticInternalAttributes.BATCH_ID]: this.ctx.batch?.id,
266
+ [SemanticInternalAttributes.IDEMPOTENCY_KEY]: this.ctx.run.idempotencyKey
267
+ };
268
+ }
269
+ return {};
270
+ }
271
+ disable() {
272
+ unregisterGlobal(API_NAME);
273
+ }
274
+ setGlobalTaskContext(taskContext2) {
275
+ return registerGlobal(API_NAME, taskContext2);
276
+ }
277
+ };
278
+ _getTaskContext = new WeakSet();
279
+ getTaskContext_fn = /* @__PURE__ */ __name(function() {
280
+ return getGlobal(API_NAME);
281
+ }, "#getTaskContext");
282
+ __name(_TaskContextAPI, "TaskContextAPI");
283
+ var TaskContextAPI = _TaskContextAPI;
284
+
285
+ // src/v3/task-context-api.ts
286
+ var taskContext = TaskContextAPI.getInstance();
287
+
288
+ // src/v3/taskContext/otelProcessors.ts
289
+ var _TaskContextSpanProcessor = class _TaskContextSpanProcessor {
290
+ constructor(innerProcessor) {
291
+ this._innerProcessor = innerProcessor;
292
+ }
293
+ // Called when a span starts
294
+ onStart(span, parentContext) {
295
+ if (taskContext.ctx) {
296
+ span.setAttributes(flattenAttributes({
297
+ [SemanticInternalAttributes.ATTEMPT_ID]: taskContext.ctx.attempt.id,
298
+ [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContext.ctx.attempt.number
299
+ }, SemanticInternalAttributes.METADATA));
300
+ }
301
+ this._innerProcessor.onStart(span, parentContext);
302
+ }
303
+ // Delegate the rest of the methods to the wrapped processor
304
+ onEnd(span) {
305
+ this._innerProcessor.onEnd(span);
306
+ }
307
+ shutdown() {
308
+ return this._innerProcessor.shutdown();
309
+ }
310
+ forceFlush() {
311
+ return this._innerProcessor.forceFlush();
312
+ }
313
+ };
314
+ __name(_TaskContextSpanProcessor, "TaskContextSpanProcessor");
315
+ var TaskContextSpanProcessor = _TaskContextSpanProcessor;
316
+ var _TaskContextLogProcessor = class _TaskContextLogProcessor {
317
+ constructor(innerProcessor) {
318
+ this._innerProcessor = innerProcessor;
319
+ }
320
+ forceFlush() {
321
+ return this._innerProcessor.forceFlush();
322
+ }
323
+ onEmit(logRecord, context2) {
324
+ if (taskContext.ctx) {
325
+ logRecord.setAttributes(flattenAttributes({
326
+ [SemanticInternalAttributes.ATTEMPT_ID]: taskContext.ctx.attempt.id,
327
+ [SemanticInternalAttributes.ATTEMPT_NUMBER]: taskContext.ctx.attempt.number
328
+ }, SemanticInternalAttributes.METADATA));
329
+ }
330
+ this._innerProcessor.onEmit(logRecord, context2);
331
+ }
332
+ shutdown() {
333
+ return this._innerProcessor.shutdown();
334
+ }
335
+ };
336
+ __name(_TaskContextLogProcessor, "TaskContextLogProcessor");
337
+ var TaskContextLogProcessor = _TaskContextLogProcessor;
338
+
339
+ // src/v3/utils/getEnv.ts
340
+ function getEnvVar(name) {
341
+ if (typeof process !== "undefined" && typeof process.env === "object" && process.env !== null) {
342
+ return process.env[name];
343
+ }
344
+ }
345
+ __name(getEnvVar, "getEnvVar");
346
+
347
+ // src/v3/otel/tracingSDK.ts
348
+ var _a;
349
+ var AsyncResourceDetector = (_a = class {
350
+ constructor() {
351
+ __publicField(this, "_resolved", false);
352
+ this._promise = new Promise((resolver) => {
353
+ this._resolver = resolver;
354
+ });
355
+ }
356
+ detect(_config) {
357
+ return new resources.Resource({}, this._promise);
358
+ }
359
+ resolveWithAttributes(attributes) {
360
+ if (!this._resolver) {
361
+ throw new Error("Resolver not available");
362
+ }
363
+ if (this._resolved) {
364
+ return;
365
+ }
366
+ this._resolved = true;
367
+ this._resolver(attributes);
368
+ }
369
+ }, __name(_a, "AsyncResourceDetector"), _a);
370
+ var _TracingSDK = class _TracingSDK {
371
+ constructor(config) {
372
+ this.config = config;
373
+ this.asyncResourceDetector = new AsyncResourceDetector();
374
+ setLogLevel(config.diagLogLevel ?? "none");
375
+ const envResourceAttributesSerialized = getEnvVar("OTEL_RESOURCE_ATTRIBUTES");
376
+ const envResourceAttributes = envResourceAttributesSerialized ? JSON.parse(envResourceAttributesSerialized) : {};
377
+ const commonResources = resources.detectResourcesSync({
378
+ detectors: [
379
+ this.asyncResourceDetector,
380
+ resources.processDetectorSync
381
+ ]
382
+ }).merge(new resources.Resource({
383
+ [semanticConventions.SemanticResourceAttributes.CLOUD_PROVIDER]: "trigger.dev",
384
+ [SemanticInternalAttributes.TRIGGER]: true
385
+ })).merge(config.resource ?? new resources.Resource({})).merge(new resources.Resource(envResourceAttributes));
386
+ const traceProvider = new sdkTraceNode.NodeTracerProvider({
387
+ forceFlushTimeoutMillis: config.forceFlushTimeoutMillis ?? 500,
388
+ resource: commonResources,
389
+ spanLimits: {
390
+ attributeCountLimit: OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT,
391
+ attributeValueLengthLimit: OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT,
392
+ eventCountLimit: OTEL_SPAN_EVENT_COUNT_LIMIT,
393
+ attributePerEventCountLimit: OTEL_ATTRIBUTE_PER_EVENT_COUNT_LIMIT,
394
+ linkCountLimit: OTEL_LINK_COUNT_LIMIT,
395
+ attributePerLinkCountLimit: OTEL_ATTRIBUTE_PER_LINK_COUNT_LIMIT
396
+ }
397
+ });
398
+ const spanExporter = new exporterTraceOtlpHttp.OTLPTraceExporter({
399
+ url: `${config.url}/v1/traces`,
400
+ timeoutMillis: config.forceFlushTimeoutMillis ?? 1e3
401
+ });
402
+ traceProvider.addSpanProcessor(new TaskContextSpanProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new sdkTraceNode.BatchSpanProcessor(spanExporter, {
403
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_SPAN_MAX_EXPORT_BATCH_SIZE") ?? "64"),
404
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_SPAN_SCHEDULED_DELAY_MILLIS") ?? "200"),
405
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_SPAN_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
406
+ maxQueueSize: parseInt(getEnvVar("OTEL_SPAN_MAX_QUEUE_SIZE") ?? "512")
407
+ }) : new sdkTraceNode.SimpleSpanProcessor(spanExporter)));
408
+ traceProvider.register();
409
+ instrumentation.registerInstrumentations({
410
+ instrumentations: config.instrumentations ?? [],
411
+ tracerProvider: traceProvider
412
+ });
413
+ const logExporter = new exporterLogsOtlpHttp.OTLPLogExporter({
414
+ url: `${config.url}/v1/logs`
415
+ });
416
+ const loggerProvider = new sdkLogs.LoggerProvider({
417
+ resource: commonResources,
418
+ logRecordLimits: {
419
+ attributeCountLimit: OTEL_LOG_ATTRIBUTE_COUNT_LIMIT,
420
+ attributeValueLengthLimit: OTEL_LOG_ATTRIBUTE_VALUE_LENGTH_LIMIT
421
+ }
422
+ });
423
+ loggerProvider.addLogRecordProcessor(new TaskContextLogProcessor(getEnvVar("OTEL_BATCH_PROCESSING_ENABLED") === "1" ? new sdkLogs.BatchLogRecordProcessor(logExporter, {
424
+ maxExportBatchSize: parseInt(getEnvVar("OTEL_LOG_MAX_EXPORT_BATCH_SIZE") ?? "64"),
425
+ scheduledDelayMillis: parseInt(getEnvVar("OTEL_LOG_SCHEDULED_DELAY_MILLIS") ?? "200"),
426
+ exportTimeoutMillis: parseInt(getEnvVar("OTEL_LOG_EXPORT_TIMEOUT_MILLIS") ?? "30000"),
427
+ maxQueueSize: parseInt(getEnvVar("OTEL_LOG_MAX_QUEUE_SIZE") ?? "512")
428
+ }) : new sdkLogs.SimpleLogRecordProcessor(logExporter)));
429
+ this._logProvider = loggerProvider;
430
+ this._spanExporter = spanExporter;
431
+ this._traceProvider = traceProvider;
432
+ apiLogs.logs.setGlobalLoggerProvider(loggerProvider);
433
+ this.getLogger = loggerProvider.getLogger.bind(loggerProvider);
434
+ this.getTracer = traceProvider.getTracer.bind(traceProvider);
435
+ }
436
+ async flush() {
437
+ await this._traceProvider.forceFlush();
438
+ await this._logProvider.forceFlush();
439
+ }
440
+ async shutdown() {
441
+ await this._traceProvider.shutdown();
442
+ await this._logProvider.shutdown();
443
+ }
444
+ };
445
+ __name(_TracingSDK, "TracingSDK");
446
+ var TracingSDK = _TracingSDK;
447
+ function setLogLevel(level) {
448
+ let diagLogLevel;
449
+ switch (level) {
450
+ case "none":
451
+ diagLogLevel = api.DiagLogLevel.NONE;
452
+ break;
453
+ case "error":
454
+ diagLogLevel = api.DiagLogLevel.ERROR;
455
+ break;
456
+ case "warn":
457
+ diagLogLevel = api.DiagLogLevel.WARN;
458
+ break;
459
+ case "info":
460
+ diagLogLevel = api.DiagLogLevel.INFO;
461
+ break;
462
+ case "debug":
463
+ diagLogLevel = api.DiagLogLevel.DEBUG;
464
+ break;
465
+ case "verbose":
466
+ diagLogLevel = api.DiagLogLevel.VERBOSE;
467
+ break;
468
+ case "all":
469
+ diagLogLevel = api.DiagLogLevel.ALL;
470
+ break;
471
+ default:
472
+ diagLogLevel = api.DiagLogLevel.NONE;
473
+ }
474
+ api.diag.setLogger(new api.DiagConsoleLogger(), diagLogLevel);
475
+ }
476
+ __name(setLogLevel, "setLogLevel");
477
+
478
+ // src/v3/otel/index.ts
479
+ function recordSpanException(span, error) {
480
+ if (error instanceof Error) {
481
+ span.recordException(error);
482
+ } else if (typeof error === "string") {
483
+ span.recordException(new Error(error));
484
+ } else {
485
+ span.recordException(new Error(JSON.stringify(error)));
486
+ }
487
+ span.setStatus({
488
+ code: api.SpanStatusCode.ERROR
489
+ });
490
+ }
491
+ __name(recordSpanException, "recordSpanException");
492
+ var TaskRunBuiltInError = zod.z.object({
493
+ type: zod.z.literal("BUILT_IN_ERROR"),
494
+ name: zod.z.string(),
495
+ message: zod.z.string(),
496
+ stackTrace: zod.z.string()
497
+ });
498
+ var TaskRunCustomErrorObject = zod.z.object({
499
+ type: zod.z.literal("CUSTOM_ERROR"),
500
+ raw: zod.z.string()
501
+ });
502
+ var TaskRunStringError = zod.z.object({
503
+ type: zod.z.literal("STRING_ERROR"),
504
+ raw: zod.z.string()
505
+ });
506
+ var TaskRunErrorCodes = {
507
+ COULD_NOT_FIND_EXECUTOR: "COULD_NOT_FIND_EXECUTOR",
508
+ COULD_NOT_FIND_TASK: "COULD_NOT_FIND_TASK",
509
+ CONFIGURED_INCORRECTLY: "CONFIGURED_INCORRECTLY",
510
+ TASK_ALREADY_RUNNING: "TASK_ALREADY_RUNNING",
511
+ TASK_EXECUTION_FAILED: "TASK_EXECUTION_FAILED",
512
+ TASK_EXECUTION_ABORTED: "TASK_EXECUTION_ABORTED",
513
+ TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE: "TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE",
514
+ TASK_RUN_CANCELLED: "TASK_RUN_CANCELLED",
515
+ TASK_OUTPUT_ERROR: "TASK_OUTPUT_ERROR",
516
+ HANDLE_ERROR_ERROR: "HANDLE_ERROR_ERROR",
517
+ GRACEFUL_EXIT_TIMEOUT: "GRACEFUL_EXIT_TIMEOUT"
518
+ };
519
+ var TaskRunInternalError = zod.z.object({
520
+ type: zod.z.literal("INTERNAL_ERROR"),
521
+ code: zod.z.enum([
522
+ "COULD_NOT_FIND_EXECUTOR",
523
+ "COULD_NOT_FIND_TASK",
524
+ "CONFIGURED_INCORRECTLY",
525
+ "TASK_ALREADY_RUNNING",
526
+ "TASK_EXECUTION_FAILED",
527
+ "TASK_EXECUTION_ABORTED",
528
+ "TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE",
529
+ "TASK_RUN_CANCELLED",
530
+ "TASK_OUTPUT_ERROR",
531
+ "HANDLE_ERROR_ERROR",
532
+ "GRACEFUL_EXIT_TIMEOUT"
533
+ ]),
534
+ message: zod.z.string().optional()
535
+ });
536
+ var TaskRunError = zod.z.discriminatedUnion("type", [
537
+ TaskRunBuiltInError,
538
+ TaskRunCustomErrorObject,
539
+ TaskRunStringError,
540
+ TaskRunInternalError
541
+ ]);
542
+ var TaskRun = zod.z.object({
543
+ id: zod.z.string(),
544
+ payload: zod.z.string(),
545
+ payloadType: zod.z.string(),
546
+ context: zod.z.any(),
547
+ tags: zod.z.array(zod.z.string()),
548
+ isTest: zod.z.boolean().default(false),
549
+ createdAt: zod.z.coerce.date(),
550
+ idempotencyKey: zod.z.string().optional()
551
+ });
552
+ var TaskRunExecutionTask = zod.z.object({
553
+ id: zod.z.string(),
554
+ filePath: zod.z.string(),
555
+ exportName: zod.z.string()
556
+ });
557
+ var TaskRunExecutionAttempt = zod.z.object({
558
+ id: zod.z.string(),
559
+ number: zod.z.number(),
560
+ startedAt: zod.z.coerce.date(),
561
+ backgroundWorkerId: zod.z.string(),
562
+ backgroundWorkerTaskId: zod.z.string(),
563
+ status: zod.z.string()
564
+ });
565
+ var TaskRunExecutionEnvironment = zod.z.object({
566
+ id: zod.z.string(),
567
+ slug: zod.z.string(),
568
+ type: zod.z.enum([
569
+ "PRODUCTION",
570
+ "STAGING",
571
+ "DEVELOPMENT",
572
+ "PREVIEW"
573
+ ])
574
+ });
575
+ var TaskRunExecutionOrganization = zod.z.object({
576
+ id: zod.z.string(),
577
+ slug: zod.z.string(),
578
+ name: zod.z.string()
579
+ });
580
+ var TaskRunExecutionProject = zod.z.object({
581
+ id: zod.z.string(),
582
+ ref: zod.z.string(),
583
+ slug: zod.z.string(),
584
+ name: zod.z.string()
585
+ });
586
+ var TaskRunExecutionQueue = zod.z.object({
587
+ id: zod.z.string(),
588
+ name: zod.z.string()
589
+ });
590
+ var TaskRunExecutionBatch = zod.z.object({
591
+ id: zod.z.string()
592
+ });
593
+ var TaskRunExecution = zod.z.object({
594
+ task: TaskRunExecutionTask,
595
+ attempt: TaskRunExecutionAttempt,
596
+ run: TaskRun,
597
+ queue: TaskRunExecutionQueue,
598
+ environment: TaskRunExecutionEnvironment,
599
+ organization: TaskRunExecutionOrganization,
600
+ project: TaskRunExecutionProject,
601
+ batch: TaskRunExecutionBatch.optional()
602
+ });
603
+ var TaskRunContext = zod.z.object({
604
+ task: TaskRunExecutionTask,
605
+ attempt: TaskRunExecutionAttempt.omit({
606
+ backgroundWorkerId: true,
607
+ backgroundWorkerTaskId: true
608
+ }),
609
+ run: TaskRun.omit({
610
+ payload: true,
611
+ payloadType: true
612
+ }),
613
+ queue: TaskRunExecutionQueue,
614
+ environment: TaskRunExecutionEnvironment,
615
+ organization: TaskRunExecutionOrganization,
616
+ project: TaskRunExecutionProject,
617
+ batch: TaskRunExecutionBatch.optional()
618
+ });
619
+ var TaskRunExecutionRetry = zod.z.object({
620
+ timestamp: zod.z.number(),
621
+ delay: zod.z.number(),
622
+ error: zod.z.unknown().optional()
623
+ });
624
+ var TaskRunFailedExecutionResult = zod.z.object({
625
+ ok: zod.z.literal(false),
626
+ id: zod.z.string(),
627
+ error: TaskRunError,
628
+ retry: TaskRunExecutionRetry.optional(),
629
+ skippedRetrying: zod.z.boolean().optional()
630
+ });
631
+ var TaskRunSuccessfulExecutionResult = zod.z.object({
632
+ ok: zod.z.literal(true),
633
+ id: zod.z.string(),
634
+ output: zod.z.string().optional(),
635
+ outputType: zod.z.string()
636
+ });
637
+ var TaskRunExecutionResult = zod.z.discriminatedUnion("ok", [
638
+ TaskRunSuccessfulExecutionResult,
639
+ TaskRunFailedExecutionResult
640
+ ]);
641
+ var BatchTaskRunExecutionResult = zod.z.object({
642
+ id: zod.z.string(),
643
+ items: TaskRunExecutionResult.array()
644
+ });
645
+
646
+ // src/v3/schemas/messages.ts
647
+ var EnvironmentType = zod.z.enum([
648
+ "PRODUCTION",
649
+ "STAGING",
650
+ "DEVELOPMENT",
651
+ "PREVIEW"
652
+ ]);
653
+ var MachineCpu = zod.z.union([
654
+ zod.z.literal(0.25),
655
+ zod.z.literal(0.5),
656
+ zod.z.literal(1),
657
+ zod.z.literal(2),
658
+ zod.z.literal(4)
659
+ ]).default(0.5);
660
+ var MachineMemory = zod.z.union([
661
+ zod.z.literal(0.25),
662
+ zod.z.literal(0.5),
663
+ zod.z.literal(1),
664
+ zod.z.literal(2),
665
+ zod.z.literal(4),
666
+ zod.z.literal(8)
667
+ ]).default(1);
668
+ var Machine = zod.z.object({
669
+ version: zod.z.literal("v1").default("v1"),
670
+ cpu: MachineCpu,
671
+ memory: MachineMemory
672
+ });
673
+ var TaskRunExecutionPayload = zod.z.object({
674
+ execution: TaskRunExecution,
675
+ traceContext: zod.z.record(zod.z.unknown()),
676
+ environment: zod.z.record(zod.z.string()).optional()
677
+ });
678
+ var ProdTaskRunExecution = TaskRunExecution.extend({
679
+ worker: zod.z.object({
680
+ id: zod.z.string(),
681
+ contentHash: zod.z.string(),
682
+ version: zod.z.string()
683
+ })
684
+ });
685
+ zod.z.object({
686
+ execution: ProdTaskRunExecution,
687
+ traceContext: zod.z.record(zod.z.unknown()),
688
+ environment: zod.z.record(zod.z.string()).optional()
689
+ });
690
+ var BackgroundWorkerServerMessages = zod.z.discriminatedUnion("type", [
691
+ zod.z.object({
692
+ type: zod.z.literal("EXECUTE_RUNS"),
693
+ payloads: zod.z.array(TaskRunExecutionPayload)
694
+ }),
695
+ zod.z.object({
696
+ type: zod.z.literal("CANCEL_ATTEMPT"),
697
+ taskAttemptId: zod.z.string(),
698
+ taskRunId: zod.z.string()
699
+ }),
700
+ zod.z.object({
701
+ type: zod.z.literal("SCHEDULE_ATTEMPT"),
702
+ image: zod.z.string(),
703
+ version: zod.z.string(),
704
+ machine: Machine,
705
+ // identifiers
706
+ id: zod.z.string(),
707
+ envId: zod.z.string(),
708
+ envType: EnvironmentType,
709
+ orgId: zod.z.string(),
710
+ projectId: zod.z.string(),
711
+ runId: zod.z.string()
712
+ })
713
+ ]);
714
+ ({
715
+ SERVER_READY: zod.z.object({
716
+ version: zod.z.literal("v1").default("v1"),
717
+ id: zod.z.string()
718
+ }),
719
+ BACKGROUND_WORKER_MESSAGE: zod.z.object({
720
+ version: zod.z.literal("v1").default("v1"),
721
+ backgroundWorkerId: zod.z.string(),
722
+ data: BackgroundWorkerServerMessages
723
+ })
724
+ });
725
+ var BackgroundWorkerClientMessages = zod.z.discriminatedUnion("type", [
726
+ zod.z.object({
727
+ version: zod.z.literal("v1").default("v1"),
728
+ type: zod.z.literal("TASK_RUN_COMPLETED"),
729
+ completion: TaskRunExecutionResult,
730
+ execution: TaskRunExecution
731
+ }),
732
+ zod.z.object({
733
+ version: zod.z.literal("v1").default("v1"),
734
+ type: zod.z.literal("TASK_HEARTBEAT"),
735
+ id: zod.z.string()
736
+ })
737
+ ]);
738
+ var BackgroundWorkerProperties = zod.z.object({
739
+ id: zod.z.string(),
740
+ version: zod.z.string(),
741
+ contentHash: zod.z.string()
742
+ });
743
+ ({
744
+ READY_FOR_TASKS: zod.z.object({
745
+ version: zod.z.literal("v1").default("v1"),
746
+ backgroundWorkerId: zod.z.string()
747
+ }),
748
+ BACKGROUND_WORKER_DEPRECATED: zod.z.object({
749
+ version: zod.z.literal("v1").default("v1"),
750
+ backgroundWorkerId: zod.z.string()
751
+ }),
752
+ BACKGROUND_WORKER_MESSAGE: zod.z.object({
753
+ version: zod.z.literal("v1").default("v1"),
754
+ backgroundWorkerId: zod.z.string(),
755
+ data: BackgroundWorkerClientMessages
756
+ })
757
+ });
758
+ ({
759
+ EXECUTE_TASK_RUN: zod.z.object({
760
+ version: zod.z.literal("v1").default("v1"),
761
+ execution: TaskRunExecution,
762
+ traceContext: zod.z.record(zod.z.unknown()),
763
+ metadata: BackgroundWorkerProperties
764
+ }),
765
+ TASK_RUN_COMPLETED_NOTIFICATION: zod.z.object({
766
+ version: zod.z.literal("v1").default("v1"),
767
+ completion: TaskRunExecutionResult,
768
+ execution: TaskRunExecution
769
+ }),
770
+ CLEANUP: zod.z.object({
771
+ version: zod.z.literal("v1").default("v1"),
772
+ flush: zod.z.boolean().default(false),
773
+ kill: zod.z.boolean().default(true)
774
+ })
775
+ });
776
+ var FixedWindowRateLimit = zod.z.object({
777
+ type: zod.z.literal("fixed-window"),
778
+ limit: zod.z.number(),
779
+ window: zod.z.union([
780
+ zod.z.object({
781
+ seconds: zod.z.number()
782
+ }),
783
+ zod.z.object({
784
+ minutes: zod.z.number()
785
+ }),
786
+ zod.z.object({
787
+ hours: zod.z.number()
788
+ })
789
+ ])
790
+ });
791
+ var SlidingWindowRateLimit = zod.z.object({
792
+ type: zod.z.literal("sliding-window"),
793
+ limit: zod.z.number(),
794
+ window: zod.z.union([
795
+ zod.z.object({
796
+ seconds: zod.z.number()
797
+ }),
798
+ zod.z.object({
799
+ minutes: zod.z.number()
800
+ }),
801
+ zod.z.object({
802
+ hours: zod.z.number()
803
+ })
804
+ ])
805
+ });
806
+ var RateLimitOptions = zod.z.discriminatedUnion("type", [
807
+ FixedWindowRateLimit,
808
+ SlidingWindowRateLimit
809
+ ]);
810
+ var RetryOptions = zod.z.object({
811
+ /** The number of attempts before giving up */
812
+ maxAttempts: zod.z.number().int().optional(),
813
+ /** The exponential factor to use when calculating the next retry time.
814
+ *
815
+ * Each subsequent retry will be calculated as `previousTimeout * factor`
816
+ */
817
+ factor: zod.z.number().optional(),
818
+ /** The minimum time to wait before retrying */
819
+ minTimeoutInMs: zod.z.number().int().optional(),
820
+ /** The maximum time to wait before retrying */
821
+ maxTimeoutInMs: zod.z.number().int().optional(),
822
+ /** Randomize the timeout between retries.
823
+ *
824
+ * This can be useful to prevent the thundering herd problem where all retries happen at the same time.
825
+ */
826
+ randomize: zod.z.boolean().optional()
827
+ });
828
+ var QueueOptions = zod.z.object({
829
+ /** You can define a shared queue and then pass the name in to your task.
830
+ *
831
+ * @example
832
+ *
833
+ * ```ts
834
+ * const myQueue = queue({
835
+ name: "my-queue",
836
+ concurrencyLimit: 1,
837
+ });
838
+
839
+ export const task1 = task({
840
+ id: "task-1",
841
+ queue: {
842
+ name: "my-queue",
843
+ },
844
+ run: async (payload: { message: string }) => {
845
+ // ...
846
+ },
847
+ });
848
+
849
+ export const task2 = task({
850
+ id: "task-2",
851
+ queue: {
852
+ name: "my-queue",
853
+ },
854
+ run: async (payload: { message: string }) => {
855
+ // ...
856
+ },
857
+ });
858
+ * ```
859
+ */
860
+ name: zod.z.string().optional(),
861
+ /** An optional property that specifies the maximum number of concurrent run executions.
862
+ *
863
+ * If this property is omitted, the task can potentially use up the full concurrency of an environment. */
864
+ concurrencyLimit: zod.z.number().int().min(0).max(1e3).optional(),
865
+ /** @deprecated This feature is coming soon */
866
+ rateLimit: RateLimitOptions.optional()
867
+ });
868
+ var TaskMetadata = zod.z.object({
869
+ id: zod.z.string(),
870
+ packageVersion: zod.z.string(),
871
+ queue: QueueOptions.optional(),
872
+ retry: RetryOptions.optional(),
873
+ machine: Machine.partial().optional(),
874
+ triggerSource: zod.z.string().optional()
875
+ });
876
+ var TaskFileMetadata = zod.z.object({
877
+ filePath: zod.z.string(),
878
+ exportName: zod.z.string()
879
+ });
880
+ var TaskMetadataWithFilePath = TaskMetadata.merge(TaskFileMetadata);
881
+ var UncaughtExceptionMessage = zod.z.object({
882
+ version: zod.z.literal("v1").default("v1"),
883
+ error: zod.z.object({
884
+ name: zod.z.string(),
885
+ message: zod.z.string(),
886
+ stack: zod.z.string().optional()
887
+ }),
888
+ origin: zod.z.enum([
889
+ "uncaughtException",
890
+ "unhandledRejection"
891
+ ])
892
+ });
893
+ var TaskMetadataFailedToParseData = zod.z.object({
894
+ version: zod.z.literal("v1").default("v1"),
895
+ tasks: zod.z.unknown(),
896
+ zodIssues: zod.z.custom((v) => {
897
+ return Array.isArray(v) && v.every((issue) => typeof issue === "object" && "message" in issue);
898
+ })
899
+ });
900
+ ({
901
+ TASK_RUN_COMPLETED: zod.z.object({
902
+ version: zod.z.literal("v1").default("v1"),
903
+ execution: TaskRunExecution,
904
+ result: TaskRunExecutionResult
905
+ }),
906
+ TASKS_READY: zod.z.object({
907
+ version: zod.z.literal("v1").default("v1"),
908
+ tasks: TaskMetadataWithFilePath.array()
909
+ }),
910
+ TASKS_FAILED_TO_PARSE: TaskMetadataFailedToParseData,
911
+ TASK_HEARTBEAT: zod.z.object({
912
+ version: zod.z.literal("v1").default("v1"),
913
+ id: zod.z.string()
914
+ }),
915
+ READY_TO_DISPOSE: zod.z.undefined(),
916
+ WAIT_FOR_DURATION: zod.z.object({
917
+ version: zod.z.literal("v1").default("v1"),
918
+ ms: zod.z.number()
919
+ }),
920
+ WAIT_FOR_TASK: zod.z.object({
921
+ version: zod.z.literal("v1").default("v1"),
922
+ id: zod.z.string()
923
+ }),
924
+ WAIT_FOR_BATCH: zod.z.object({
925
+ version: zod.z.literal("v1").default("v1"),
926
+ id: zod.z.string(),
927
+ runs: zod.z.string().array()
928
+ }),
929
+ UNCAUGHT_EXCEPTION: UncaughtExceptionMessage
930
+ });
931
+ ({
932
+ TASK_RUN_COMPLETED: {
933
+ message: zod.z.object({
934
+ version: zod.z.literal("v1").default("v1"),
935
+ execution: TaskRunExecution,
936
+ result: TaskRunExecutionResult
937
+ })
938
+ },
939
+ TASKS_READY: {
940
+ message: zod.z.object({
941
+ version: zod.z.literal("v1").default("v1"),
942
+ tasks: TaskMetadataWithFilePath.array()
943
+ })
944
+ },
945
+ TASKS_FAILED_TO_PARSE: {
946
+ message: TaskMetadataFailedToParseData
947
+ },
948
+ TASK_HEARTBEAT: {
949
+ message: zod.z.object({
950
+ version: zod.z.literal("v1").default("v1"),
951
+ id: zod.z.string()
952
+ })
953
+ },
954
+ READY_TO_DISPOSE: {
955
+ message: zod.z.undefined()
956
+ },
957
+ READY_FOR_CHECKPOINT: {
958
+ message: zod.z.object({
959
+ version: zod.z.literal("v1").default("v1")
960
+ })
961
+ },
962
+ CANCEL_CHECKPOINT: {
963
+ message: zod.z.object({
964
+ version: zod.z.literal("v1").default("v1")
965
+ })
966
+ },
967
+ WAIT_FOR_DURATION: {
968
+ message: zod.z.object({
969
+ version: zod.z.literal("v1").default("v1"),
970
+ ms: zod.z.number(),
971
+ now: zod.z.number()
972
+ }),
973
+ callback: zod.z.object({
974
+ willCheckpointAndRestore: zod.z.boolean()
975
+ })
976
+ },
977
+ WAIT_FOR_TASK: {
978
+ message: zod.z.object({
979
+ version: zod.z.literal("v1").default("v1"),
980
+ friendlyId: zod.z.string()
981
+ })
982
+ },
983
+ WAIT_FOR_BATCH: {
984
+ message: zod.z.object({
985
+ version: zod.z.literal("v1").default("v1"),
986
+ batchFriendlyId: zod.z.string(),
987
+ runFriendlyIds: zod.z.string().array()
988
+ })
989
+ },
990
+ UNCAUGHT_EXCEPTION: {
991
+ message: UncaughtExceptionMessage
992
+ }
993
+ });
994
+ ({
995
+ EXECUTE_TASK_RUN: {
996
+ message: zod.z.object({
997
+ version: zod.z.literal("v1").default("v1"),
998
+ execution: TaskRunExecution,
999
+ traceContext: zod.z.record(zod.z.unknown()),
1000
+ metadata: BackgroundWorkerProperties
1001
+ })
1002
+ },
1003
+ TASK_RUN_COMPLETED_NOTIFICATION: {
1004
+ message: zod.z.object({
1005
+ version: zod.z.literal("v1").default("v1"),
1006
+ completion: TaskRunExecutionResult,
1007
+ execution: TaskRunExecution
1008
+ })
1009
+ },
1010
+ CLEANUP: {
1011
+ message: zod.z.object({
1012
+ version: zod.z.literal("v1").default("v1"),
1013
+ flush: zod.z.boolean().default(false),
1014
+ kill: zod.z.boolean().default(true)
1015
+ }),
1016
+ callback: zod.z.void()
1017
+ },
1018
+ WAIT_COMPLETED_NOTIFICATION: {
1019
+ message: zod.z.object({
1020
+ version: zod.z.literal("v1").default("v1")
1021
+ })
1022
+ }
1023
+ });
1024
+
1025
+ // src/v3/schemas/resources.ts
1026
+ var TaskResource = zod.z.object({
1027
+ id: zod.z.string(),
1028
+ filePath: zod.z.string(),
1029
+ exportName: zod.z.string(),
1030
+ queue: QueueOptions.optional(),
1031
+ retry: RetryOptions.optional(),
1032
+ machine: Machine.partial().optional(),
1033
+ triggerSource: zod.z.string().optional()
1034
+ });
1035
+ var BackgroundWorkerMetadata = zod.z.object({
1036
+ packageVersion: zod.z.string(),
1037
+ contentHash: zod.z.string(),
1038
+ cliPackageVersion: zod.z.string().optional(),
1039
+ tasks: zod.z.array(TaskResource)
1040
+ });
1041
+ zod.z.object({
1042
+ contentHash: zod.z.string(),
1043
+ imageTag: zod.z.string()
1044
+ });
1045
+
1046
+ // src/v3/schemas/api.ts
1047
+ zod.z.object({
1048
+ userId: zod.z.string(),
1049
+ email: zod.z.string().email(),
1050
+ dashboardUrl: zod.z.string()
1051
+ });
1052
+ var GetProjectResponseBody = zod.z.object({
1053
+ id: zod.z.string(),
1054
+ externalRef: zod.z.string(),
1055
+ name: zod.z.string(),
1056
+ slug: zod.z.string(),
1057
+ createdAt: zod.z.coerce.date(),
1058
+ organization: zod.z.object({
1059
+ id: zod.z.string(),
1060
+ title: zod.z.string(),
1061
+ slug: zod.z.string(),
1062
+ createdAt: zod.z.coerce.date()
1063
+ })
1064
+ });
1065
+ zod.z.array(GetProjectResponseBody);
1066
+ zod.z.object({
1067
+ apiKey: zod.z.string(),
1068
+ name: zod.z.string(),
1069
+ apiUrl: zod.z.string()
1070
+ });
1071
+ zod.z.object({
1072
+ localOnly: zod.z.boolean(),
1073
+ metadata: BackgroundWorkerMetadata
1074
+ });
1075
+ zod.z.object({
1076
+ id: zod.z.string(),
1077
+ version: zod.z.string(),
1078
+ contentHash: zod.z.string()
1079
+ });
1080
+ var TriggerTaskRequestBody = zod.z.object({
1081
+ payload: zod.z.any(),
1082
+ context: zod.z.any(),
1083
+ options: zod.z.object({
1084
+ dependentAttempt: zod.z.string().optional(),
1085
+ dependentBatch: zod.z.string().optional(),
1086
+ lockToVersion: zod.z.string().optional(),
1087
+ queue: QueueOptions.optional(),
1088
+ concurrencyKey: zod.z.string().optional(),
1089
+ idempotencyKey: zod.z.string().optional(),
1090
+ test: zod.z.boolean().optional(),
1091
+ payloadType: zod.z.string().optional()
1092
+ }).optional()
1093
+ });
1094
+ var TriggerTaskResponse = zod.z.object({
1095
+ id: zod.z.string()
1096
+ });
1097
+ zod.z.object({
1098
+ items: TriggerTaskRequestBody.array(),
1099
+ dependentAttempt: zod.z.string().optional()
1100
+ });
1101
+ var BatchTriggerTaskResponse = zod.z.object({
1102
+ batchId: zod.z.string(),
1103
+ runs: zod.z.string().array()
1104
+ });
1105
+ zod.z.object({
1106
+ id: zod.z.string(),
1107
+ items: zod.z.array(zod.z.object({
1108
+ id: zod.z.string(),
1109
+ taskRunId: zod.z.string(),
1110
+ status: zod.z.enum([
1111
+ "PENDING",
1112
+ "CANCELED",
1113
+ "COMPLETED",
1114
+ "FAILED"
1115
+ ])
1116
+ }))
1117
+ });
1118
+ zod.z.object({
1119
+ variables: zod.z.record(zod.z.string())
1120
+ });
1121
+ zod.z.object({
1122
+ imageReference: zod.z.string()
1123
+ });
1124
+ zod.z.object({
1125
+ id: zod.z.string(),
1126
+ contentHash: zod.z.string()
1127
+ });
1128
+ var ExternalBuildData = zod.z.object({
1129
+ buildId: zod.z.string(),
1130
+ buildToken: zod.z.string(),
1131
+ projectId: zod.z.string()
1132
+ });
1133
+ zod.z.object({
1134
+ id: zod.z.string(),
1135
+ contentHash: zod.z.string(),
1136
+ shortCode: zod.z.string(),
1137
+ version: zod.z.string(),
1138
+ imageTag: zod.z.string(),
1139
+ externalBuildData: ExternalBuildData.optional().nullable(),
1140
+ registryHost: zod.z.string().optional()
1141
+ });
1142
+ zod.z.object({
1143
+ contentHash: zod.z.string(),
1144
+ userId: zod.z.string().optional()
1145
+ });
1146
+ var DeploymentErrorData = zod.z.object({
1147
+ name: zod.z.string(),
1148
+ message: zod.z.string(),
1149
+ stack: zod.z.string().optional()
1150
+ });
1151
+ zod.z.object({
1152
+ id: zod.z.string(),
1153
+ status: zod.z.enum([
1154
+ "PENDING",
1155
+ "BUILDING",
1156
+ "DEPLOYING",
1157
+ "DEPLOYED",
1158
+ "FAILED",
1159
+ "CANCELED",
1160
+ "TIMED_OUT"
1161
+ ]),
1162
+ contentHash: zod.z.string(),
1163
+ shortCode: zod.z.string(),
1164
+ version: zod.z.string(),
1165
+ imageReference: zod.z.string().optional(),
1166
+ errorData: DeploymentErrorData.optional().nullable(),
1167
+ worker: zod.z.object({
1168
+ id: zod.z.string(),
1169
+ version: zod.z.string(),
1170
+ tasks: zod.z.array(zod.z.object({
1171
+ id: zod.z.string(),
1172
+ slug: zod.z.string(),
1173
+ filePath: zod.z.string(),
1174
+ exportName: zod.z.string()
1175
+ }))
1176
+ }).optional()
1177
+ });
1178
+ var CreateUploadPayloadUrlResponseBody = zod.z.object({
1179
+ presignedUrl: zod.z.string()
1180
+ });
1181
+ var ReplayRunResponse = zod.z.object({
1182
+ id: zod.z.string()
1183
+ });
1184
+ var CanceledRunResponse = zod.z.object({
1185
+ message: zod.z.string()
1186
+ });
1187
+ zod.z.object({
1188
+ /** The schedule id associated with this run (you can have many schedules for the same task).
1189
+ You can use this to remove the schedule, update it, etc */
1190
+ scheduleId: zod.z.string(),
1191
+ /** When the task was scheduled to run.
1192
+ * Note this will be slightly different from `new Date()` because it takes a few ms to run the task. */
1193
+ timestamp: zod.z.date(),
1194
+ /** When the task was last run (it has been).
1195
+ This can be undefined if it's never been run */
1196
+ lastTimestamp: zod.z.date().optional(),
1197
+ /** You can optionally provide an external id when creating the schedule.
1198
+ Usually you would use a userId or some other unique identifier.
1199
+ This defaults to undefined if you didn't provide one. */
1200
+ externalId: zod.z.string().optional(),
1201
+ /** The next 5 dates this task is scheduled to run */
1202
+ upcoming: zod.z.array(zod.z.date())
1203
+ });
1204
+ zod.z.object({
1205
+ /** The id of the task you want to attach to. */
1206
+ task: zod.z.string(),
1207
+ /** The schedule in CRON format.
1208
+ *
1209
+ * ```txt
1210
+ * * * * * *
1211
+ ┬ ┬ ┬ ┬ ┬
1212
+ │ │ │ │ |
1213
+ │ │ │ │ └ day of week (0 - 7, 1L - 7L) (0 or 7 is Sun)
1214
+ │ │ │ └───── month (1 - 12)
1215
+ │ │ └────────── day of month (1 - 31, L)
1216
+ │ └─────────────── hour (0 - 23)
1217
+ └──────────────────── minute (0 - 59)
1218
+ * ```
1219
+
1220
+ "L" means the last. In the "day of week" field, 1L means the last Monday of the month. In the day of month field, L means the last day of the month.
1221
+
1222
+ */
1223
+ cron: zod.z.string(),
1224
+ /** (Optional) You can only create one schedule with this key. If you use it twice, the second call will update the schedule.
1225
+ *
1226
+ * This is useful if you don't want to create duplicate schedules for a user. */
1227
+ deduplicationKey: zod.z.string().optional(),
1228
+ /** Optionally, you can specify your own IDs (like a user ID) and then use it inside the run function of your task.
1229
+ *
1230
+ * This allows you to have per-user CRON tasks.
1231
+ */
1232
+ externalId: zod.z.string().optional()
1233
+ });
1234
+ var ScheduleObject = zod.z.object({
1235
+ id: zod.z.string(),
1236
+ task: zod.z.string(),
1237
+ active: zod.z.boolean(),
1238
+ deduplicationKey: zod.z.string().nullish(),
1239
+ externalId: zod.z.string().nullish(),
1240
+ generator: zod.z.object({
1241
+ type: zod.z.literal("CRON"),
1242
+ expression: zod.z.string(),
1243
+ description: zod.z.string()
1244
+ }),
1245
+ nextRun: zod.z.coerce.date().nullish(),
1246
+ environments: zod.z.array(zod.z.object({
1247
+ id: zod.z.string(),
1248
+ type: zod.z.string(),
1249
+ userName: zod.z.string().nullish()
1250
+ }))
1251
+ });
1252
+ var DeletedScheduleObject = zod.z.object({
1253
+ id: zod.z.string()
1254
+ });
1255
+ var ListSchedulesResult = zod.z.object({
1256
+ data: zod.z.array(ScheduleObject),
1257
+ pagination: zod.z.object({
1258
+ currentPage: zod.z.number(),
1259
+ totalPages: zod.z.number(),
1260
+ count: zod.z.number()
1261
+ })
1262
+ });
1263
+ zod.z.object({
1264
+ page: zod.z.number().optional(),
1265
+ perPage: zod.z.number().optional()
1266
+ });
1267
+
1268
+ // src/v3/apiErrors.ts
1269
+ var _APIError = class _APIError extends Error {
1270
+ constructor(status, error, message, headers) {
1271
+ super(`${_APIError.makeMessage(status, error, message)}`);
1272
+ this.status = status;
1273
+ this.headers = headers;
1274
+ const data = error;
1275
+ this.error = data;
1276
+ this.code = data?.["code"];
1277
+ this.param = data?.["param"];
1278
+ this.type = data?.["type"];
1279
+ }
1280
+ static makeMessage(status, error, message) {
1281
+ const msg = error?.message ? typeof error.message === "string" ? error.message : JSON.stringify(error.message) : error ? JSON.stringify(error) : message;
1282
+ if (status && msg) {
1283
+ return `${status} ${msg}`;
1284
+ }
1285
+ if (status) {
1286
+ return `${status} status code (no body)`;
1287
+ }
1288
+ if (msg) {
1289
+ return msg;
1290
+ }
1291
+ return "(no status code or body)";
1292
+ }
1293
+ static generate(status, errorResponse, message, headers) {
1294
+ if (!status) {
1295
+ return new APIConnectionError({
1296
+ cause: castToError(errorResponse)
1297
+ });
1298
+ }
1299
+ const error = errorResponse?.["error"];
1300
+ if (status === 400) {
1301
+ return new BadRequestError(status, error, message, headers);
1302
+ }
1303
+ if (status === 401) {
1304
+ return new AuthenticationError(status, error, message, headers);
1305
+ }
1306
+ if (status === 403) {
1307
+ return new PermissionDeniedError(status, error, message, headers);
1308
+ }
1309
+ if (status === 404) {
1310
+ return new NotFoundError(status, error, message, headers);
1311
+ }
1312
+ if (status === 409) {
1313
+ return new ConflictError(status, error, message, headers);
1314
+ }
1315
+ if (status === 422) {
1316
+ return new UnprocessableEntityError(status, error, message, headers);
1317
+ }
1318
+ if (status === 429) {
1319
+ return new RateLimitError(status, error, message, headers);
1320
+ }
1321
+ if (status >= 500) {
1322
+ return new InternalServerError(status, error, message, headers);
1323
+ }
1324
+ return new _APIError(status, error, message, headers);
1325
+ }
1326
+ };
1327
+ __name(_APIError, "APIError");
1328
+ var APIError = _APIError;
1329
+ var _APIConnectionError = class _APIConnectionError extends APIError {
1330
+ constructor({ message, cause }) {
1331
+ super(void 0, void 0, message || "Connection error.", void 0);
1332
+ __publicField(this, "status");
1333
+ if (cause)
1334
+ this.cause = cause;
1335
+ }
1336
+ };
1337
+ __name(_APIConnectionError, "APIConnectionError");
1338
+ var APIConnectionError = _APIConnectionError;
1339
+ var _BadRequestError = class _BadRequestError extends APIError {
1340
+ constructor() {
1341
+ super(...arguments);
1342
+ __publicField(this, "status", 400);
1343
+ }
1344
+ };
1345
+ __name(_BadRequestError, "BadRequestError");
1346
+ var BadRequestError = _BadRequestError;
1347
+ var _AuthenticationError = class _AuthenticationError extends APIError {
1348
+ constructor() {
1349
+ super(...arguments);
1350
+ __publicField(this, "status", 401);
1351
+ }
1352
+ };
1353
+ __name(_AuthenticationError, "AuthenticationError");
1354
+ var AuthenticationError = _AuthenticationError;
1355
+ var _PermissionDeniedError = class _PermissionDeniedError extends APIError {
1356
+ constructor() {
1357
+ super(...arguments);
1358
+ __publicField(this, "status", 403);
1359
+ }
1360
+ };
1361
+ __name(_PermissionDeniedError, "PermissionDeniedError");
1362
+ var PermissionDeniedError = _PermissionDeniedError;
1363
+ var _NotFoundError = class _NotFoundError extends APIError {
1364
+ constructor() {
1365
+ super(...arguments);
1366
+ __publicField(this, "status", 404);
1367
+ }
1368
+ };
1369
+ __name(_NotFoundError, "NotFoundError");
1370
+ var NotFoundError = _NotFoundError;
1371
+ var _ConflictError = class _ConflictError extends APIError {
1372
+ constructor() {
1373
+ super(...arguments);
1374
+ __publicField(this, "status", 409);
1375
+ }
1376
+ };
1377
+ __name(_ConflictError, "ConflictError");
1378
+ var ConflictError = _ConflictError;
1379
+ var _UnprocessableEntityError = class _UnprocessableEntityError extends APIError {
1380
+ constructor() {
1381
+ super(...arguments);
1382
+ __publicField(this, "status", 422);
1383
+ }
1384
+ };
1385
+ __name(_UnprocessableEntityError, "UnprocessableEntityError");
1386
+ var UnprocessableEntityError = _UnprocessableEntityError;
1387
+ var _RateLimitError = class _RateLimitError extends APIError {
1388
+ constructor() {
1389
+ super(...arguments);
1390
+ __publicField(this, "status", 429);
1391
+ }
1392
+ };
1393
+ __name(_RateLimitError, "RateLimitError");
1394
+ var RateLimitError = _RateLimitError;
1395
+ var _InternalServerError = class _InternalServerError extends APIError {
1396
+ };
1397
+ __name(_InternalServerError, "InternalServerError");
1398
+ var InternalServerError = _InternalServerError;
1399
+ function castToError(err) {
1400
+ if (err instanceof Error)
1401
+ return err;
1402
+ return new Error(err);
1403
+ }
1404
+ __name(castToError, "castToError");
1405
+
1406
+ // src/v3/utils/retries.ts
1407
+ var defaultRetryOptions = {
1408
+ maxAttempts: 3,
1409
+ factor: 2,
1410
+ minTimeoutInMs: 1e3,
1411
+ maxTimeoutInMs: 6e4,
1412
+ randomize: true
1413
+ };
1414
+ function calculateNextRetryDelay(options, attempt) {
1415
+ const opts = {
1416
+ ...defaultRetryOptions,
1417
+ ...options
1418
+ };
1419
+ if (attempt >= opts.maxAttempts) {
1420
+ return;
1421
+ }
1422
+ const { factor, minTimeoutInMs, maxTimeoutInMs, randomize } = opts;
1423
+ const random = randomize ? Math.random() + 1 : 1;
1424
+ const timeout = Math.min(maxTimeoutInMs, random * minTimeoutInMs * Math.pow(factor, attempt - 1));
1425
+ return Math.round(timeout);
1426
+ }
1427
+ __name(calculateNextRetryDelay, "calculateNextRetryDelay");
1428
+
1429
+ // src/v3/zodfetch.ts
1430
+ var defaultRetryOptions2 = {
1431
+ maxAttempts: 3,
1432
+ factor: 2,
1433
+ minTimeoutInMs: 1e3,
1434
+ maxTimeoutInMs: 6e4,
1435
+ randomize: false
1436
+ };
1437
+ async function zodfetch(schema, url, requestInit, options) {
1438
+ return await _doZodFetch(schema, url, requestInit, options);
1439
+ }
1440
+ __name(zodfetch, "zodfetch");
1441
+ async function _doZodFetch(schema, url, requestInit, options, attempt = 1) {
1442
+ try {
1443
+ const response = await fetch(url, requestInitWithCache(requestInit));
1444
+ const responseHeaders = createResponseHeaders(response.headers);
1445
+ if (!response.ok) {
1446
+ const retryResult = shouldRetry(response, attempt, options?.retry);
1447
+ if (retryResult.retry) {
1448
+ await new Promise((resolve) => setTimeout(resolve, retryResult.delay));
1449
+ return await _doZodFetch(schema, url, requestInit, options, attempt + 1);
1450
+ } else {
1451
+ const errText = await response.text().catch((e) => castToError2(e).message);
1452
+ const errJSON = safeJsonParse(errText);
1453
+ const errMessage = errJSON ? void 0 : errText;
1454
+ throw APIError.generate(response.status, errJSON, errMessage, responseHeaders);
1455
+ }
1456
+ }
1457
+ const jsonBody = await response.json();
1458
+ const parsedResult = schema.safeParse(jsonBody);
1459
+ if (parsedResult.success) {
1460
+ return parsedResult.data;
1461
+ }
1462
+ throw zodValidationError.fromZodError(parsedResult.error);
1463
+ } catch (error) {
1464
+ if (error instanceof APIError) {
1465
+ throw error;
1466
+ }
1467
+ if (options?.retry) {
1468
+ const retry = {
1469
+ ...defaultRetryOptions2,
1470
+ ...options.retry
1471
+ };
1472
+ const delay = calculateNextRetryDelay(retry, attempt);
1473
+ if (delay) {
1474
+ await new Promise((resolve) => setTimeout(resolve, delay));
1475
+ return await _doZodFetch(schema, url, requestInit, options, attempt + 1);
1476
+ }
1477
+ }
1478
+ throw new APIConnectionError({
1479
+ cause: castToError2(error)
1480
+ });
1481
+ }
1482
+ }
1483
+ __name(_doZodFetch, "_doZodFetch");
1484
+ function castToError2(err) {
1485
+ if (err instanceof Error)
1486
+ return err;
1487
+ return new Error(err);
1488
+ }
1489
+ __name(castToError2, "castToError");
1490
+ function shouldRetry(response, attempt, retryOptions) {
1491
+ function shouldRetryForOptions() {
1492
+ const retry = {
1493
+ ...defaultRetryOptions2,
1494
+ ...retryOptions
1495
+ };
1496
+ const delay = calculateNextRetryDelay(retry, attempt);
1497
+ if (delay) {
1498
+ return {
1499
+ retry: true,
1500
+ delay
1501
+ };
1502
+ } else {
1503
+ return {
1504
+ retry: false
1505
+ };
1506
+ }
1507
+ }
1508
+ __name(shouldRetryForOptions, "shouldRetryForOptions");
1509
+ const shouldRetryHeader = response.headers.get("x-should-retry");
1510
+ if (shouldRetryHeader === "true")
1511
+ return shouldRetryForOptions();
1512
+ if (shouldRetryHeader === "false")
1513
+ return {
1514
+ retry: false
1515
+ };
1516
+ if (response.status === 408)
1517
+ return shouldRetryForOptions();
1518
+ if (response.status === 409)
1519
+ return shouldRetryForOptions();
1520
+ if (response.status === 429)
1521
+ return shouldRetryForOptions();
1522
+ if (response.status >= 500)
1523
+ return shouldRetryForOptions();
1524
+ return {
1525
+ retry: false
1526
+ };
1527
+ }
1528
+ __name(shouldRetry, "shouldRetry");
1529
+ function safeJsonParse(text) {
1530
+ try {
1531
+ return JSON.parse(text);
1532
+ } catch (e) {
1533
+ return void 0;
1534
+ }
1535
+ }
1536
+ __name(safeJsonParse, "safeJsonParse");
1537
+ function createResponseHeaders(headers) {
1538
+ return new Proxy(Object.fromEntries(
1539
+ // @ts-ignore
1540
+ headers.entries()
1541
+ ), {
1542
+ get(target, name) {
1543
+ const key = name.toString();
1544
+ return target[key.toLowerCase()] || target[key];
1545
+ }
1546
+ });
1547
+ }
1548
+ __name(createResponseHeaders, "createResponseHeaders");
1549
+ function requestInitWithCache(requestInit) {
1550
+ try {
1551
+ const withCache = {
1552
+ ...requestInit,
1553
+ cache: "no-cache"
1554
+ };
1555
+ const _ = new Request("http://localhost", withCache);
1556
+ return withCache;
1557
+ } catch (error) {
1558
+ return requestInit ?? {};
1559
+ }
1560
+ }
1561
+ __name(requestInitWithCache, "requestInitWithCache");
1562
+ var _SafeAsyncLocalStorage = class _SafeAsyncLocalStorage {
1563
+ constructor() {
1564
+ this.storage = new async_hooks.AsyncLocalStorage();
1565
+ }
1566
+ runWith(context2, fn) {
1567
+ return this.storage.run(context2, fn);
1568
+ }
1569
+ getStore() {
1570
+ return this.storage.getStore();
1571
+ }
1572
+ };
1573
+ __name(_SafeAsyncLocalStorage, "SafeAsyncLocalStorage");
1574
+ var SafeAsyncLocalStorage = _SafeAsyncLocalStorage;
1575
+
1576
+ // src/v3/apiClient/index.ts
1577
+ var zodFetchOptions = {
1578
+ retry: {
1579
+ maxAttempts: 3,
1580
+ minTimeoutInMs: 1e3,
1581
+ maxTimeoutInMs: 3e4,
1582
+ factor: 2,
1583
+ randomize: false
1584
+ }
1585
+ };
1586
+ var _getHeaders, getHeaders_fn;
1587
+ var _ApiClient = class _ApiClient {
1588
+ constructor(baseUrl, accessToken) {
1589
+ __privateAdd(this, _getHeaders);
1590
+ this.accessToken = accessToken;
1591
+ this.baseUrl = baseUrl.replace(/\/$/, "");
1592
+ }
1593
+ async getRunResult(runId) {
1594
+ try {
1595
+ return await zodfetch(TaskRunExecutionResult, `${this.baseUrl}/api/v1/runs/${runId}/result`, {
1596
+ method: "GET",
1597
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1598
+ }, zodFetchOptions);
1599
+ } catch (error) {
1600
+ if (error instanceof APIError) {
1601
+ if (error.status === 404) {
1602
+ return void 0;
1603
+ }
1604
+ }
1605
+ throw error;
1606
+ }
1607
+ }
1608
+ async getBatchResults(batchId) {
1609
+ return await zodfetch(BatchTaskRunExecutionResult, `${this.baseUrl}/api/v1/batches/${batchId}/results`, {
1610
+ method: "GET",
1611
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1612
+ }, zodFetchOptions);
1613
+ }
1614
+ triggerTask(taskId, body, options) {
1615
+ return zodfetch(TriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${taskId}/trigger`, {
1616
+ method: "POST",
1617
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, options?.spanParentAsLink ?? false),
1618
+ body: JSON.stringify(body)
1619
+ }, zodFetchOptions);
1620
+ }
1621
+ batchTriggerTask(taskId, body, options) {
1622
+ return zodfetch(BatchTriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${taskId}/batch`, {
1623
+ method: "POST",
1624
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, options?.spanParentAsLink ?? false),
1625
+ body: JSON.stringify(body)
1626
+ }, zodFetchOptions);
1627
+ }
1628
+ createUploadPayloadUrl(filename) {
1629
+ return zodfetch(CreateUploadPayloadUrlResponseBody, `${this.baseUrl}/api/v1/packets/${filename}`, {
1630
+ method: "PUT",
1631
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1632
+ }, zodFetchOptions);
1633
+ }
1634
+ getPayloadUrl(filename) {
1635
+ return zodfetch(CreateUploadPayloadUrlResponseBody, `${this.baseUrl}/api/v1/packets/${filename}`, {
1636
+ method: "GET",
1637
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1638
+ }, zodFetchOptions);
1639
+ }
1640
+ replayRun(runId) {
1641
+ return zodfetch(ReplayRunResponse, `${this.baseUrl}/api/v1/runs/${runId}/replay`, {
1642
+ method: "POST",
1643
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1644
+ }, zodFetchOptions);
1645
+ }
1646
+ cancelRun(runId) {
1647
+ return zodfetch(CanceledRunResponse, `${this.baseUrl}/api/v2/runs/${runId}/cancel`, {
1648
+ method: "POST",
1649
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1650
+ }, zodFetchOptions);
1651
+ }
1652
+ createSchedule(options) {
1653
+ return zodfetch(ScheduleObject, `${this.baseUrl}/api/v1/schedules`, {
1654
+ method: "POST",
1655
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false),
1656
+ body: JSON.stringify(options)
1657
+ });
1658
+ }
1659
+ listSchedules(options) {
1660
+ const searchParams = new URLSearchParams();
1661
+ if (options?.page) {
1662
+ searchParams.append("page", options.page.toString());
1663
+ }
1664
+ if (options?.perPage) {
1665
+ searchParams.append("perPage", options.perPage.toString());
1666
+ }
1667
+ return zodfetch(ListSchedulesResult, `${this.baseUrl}/api/v1/schedules${searchParams.size > 0 ? `?${searchParams}` : ""}`, {
1668
+ method: "GET",
1669
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1670
+ });
1671
+ }
1672
+ retrieveSchedule(scheduleId) {
1673
+ return zodfetch(ScheduleObject, `${this.baseUrl}/api/v1/schedules/${scheduleId}`, {
1674
+ method: "GET",
1675
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1676
+ });
1677
+ }
1678
+ updateSchedule(scheduleId, options) {
1679
+ return zodfetch(ScheduleObject, `${this.baseUrl}/api/v1/schedules/${scheduleId}`, {
1680
+ method: "PUT",
1681
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false),
1682
+ body: JSON.stringify(options)
1683
+ });
1684
+ }
1685
+ deactivateSchedule(scheduleId) {
1686
+ return zodfetch(ScheduleObject, `${this.baseUrl}/api/v1/schedules/${scheduleId}/deactivate`, {
1687
+ method: "POST",
1688
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1689
+ });
1690
+ }
1691
+ activateSchedule(scheduleId) {
1692
+ return zodfetch(ScheduleObject, `${this.baseUrl}/api/v1/schedules/${scheduleId}/activate`, {
1693
+ method: "POST",
1694
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1695
+ });
1696
+ }
1697
+ deleteSchedule(scheduleId) {
1698
+ return zodfetch(DeletedScheduleObject, `${this.baseUrl}/api/v1/schedules/${scheduleId}`, {
1699
+ method: "DELETE",
1700
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1701
+ });
1702
+ }
1703
+ };
1704
+ _getHeaders = new WeakSet();
1705
+ getHeaders_fn = /* @__PURE__ */ __name(function(spanParentAsLink) {
1706
+ const headers = {
1707
+ "Content-Type": "application/json",
1708
+ Authorization: `Bearer ${this.accessToken}`
1709
+ };
1710
+ if (taskContext.isInsideTask) {
1711
+ api.propagation.inject(api.context.active(), headers);
1712
+ if (spanParentAsLink) {
1713
+ headers["x-trigger-span-parent-as-link"] = "1";
1714
+ }
1715
+ }
1716
+ return headers;
1717
+ }, "#getHeaders");
1718
+ __name(_ApiClient, "ApiClient");
1719
+ var ApiClient = _ApiClient;
1720
+ var _getStore, getStore_fn;
1721
+ var _ApiClientManager = class _ApiClientManager {
1722
+ constructor() {
1723
+ __privateAdd(this, _getStore);
1724
+ __publicField(this, "_storage", new SafeAsyncLocalStorage());
1725
+ }
1726
+ get baseURL() {
1727
+ const store = __privateMethod(this, _getStore, getStore_fn).call(this);
1728
+ return store?.baseURL ?? getEnvVar("TRIGGER_API_URL") ?? "https://api.trigger.dev";
1729
+ }
1730
+ get accessToken() {
1731
+ const store = __privateMethod(this, _getStore, getStore_fn).call(this);
1732
+ return store?.accessToken ?? getEnvVar("TRIGGER_SECRET_KEY");
1733
+ }
1734
+ get client() {
1735
+ if (!this.baseURL || !this.accessToken) {
1736
+ return void 0;
1737
+ }
1738
+ return new ApiClient(this.baseURL, this.accessToken);
1739
+ }
1740
+ runWith(context2, fn) {
1741
+ return this._storage.runWith(context2, fn);
1742
+ }
1743
+ };
1744
+ _getStore = new WeakSet();
1745
+ getStore_fn = /* @__PURE__ */ __name(function() {
1746
+ return this._storage.getStore();
1747
+ }, "#getStore");
1748
+ __name(_ApiClientManager, "ApiClientManager");
1749
+ var ApiClientManager = _ApiClientManager;
1750
+ var apiClientManager = new ApiClientManager();
1751
+
1752
+ // src/v3/utils/ioSerialization.ts
1753
+ async function parsePacket(value) {
1754
+ if (!value.data) {
1755
+ return void 0;
1756
+ }
1757
+ switch (value.dataType) {
1758
+ case "application/json":
1759
+ return JSON.parse(value.data);
1760
+ case "application/super+json":
1761
+ const { parse } = await loadSuperJSON();
1762
+ return parse(value.data);
1763
+ case "text/plain":
1764
+ return value.data;
1765
+ case "application/store":
1766
+ throw new Error(`Cannot parse an application/store packet (${value.data}). Needs to be imported first.`);
1767
+ default:
1768
+ return value.data;
1769
+ }
1770
+ }
1771
+ __name(parsePacket, "parsePacket");
1772
+ async function stringifyIO(value) {
1773
+ if (value === void 0) {
1774
+ return {
1775
+ dataType: "application/json"
1776
+ };
1777
+ }
1778
+ if (typeof value === "string") {
1779
+ return {
1780
+ data: value,
1781
+ dataType: "text/plain"
1782
+ };
1783
+ }
1784
+ try {
1785
+ const { stringify } = await loadSuperJSON();
1786
+ const data = stringify(value);
1787
+ return {
1788
+ data,
1789
+ dataType: "application/super+json"
1790
+ };
1791
+ } catch {
1792
+ return {
1793
+ data: value,
1794
+ dataType: "application/json"
1795
+ };
1796
+ }
1797
+ }
1798
+ __name(stringifyIO, "stringifyIO");
1799
+ async function conditionallyExportPacket(packet, pathPrefix, tracer) {
1800
+ if (apiClientManager.client) {
1801
+ const { needsOffloading, size } = packetRequiresOffloading(packet);
1802
+ if (needsOffloading) {
1803
+ if (!tracer) {
1804
+ return await exportPacket(packet, pathPrefix);
1805
+ } else {
1806
+ const result = await tracer.startActiveSpan("store.uploadOutput", async (span) => {
1807
+ return await exportPacket(packet, pathPrefix);
1808
+ }, {
1809
+ attributes: {
1810
+ byteLength: size,
1811
+ [SemanticInternalAttributes.STYLE_ICON]: "cloud-upload"
1812
+ }
1813
+ });
1814
+ return result ?? packet;
1815
+ }
1816
+ }
1817
+ }
1818
+ return packet;
1819
+ }
1820
+ __name(conditionallyExportPacket, "conditionallyExportPacket");
1821
+ function packetRequiresOffloading(packet) {
1822
+ if (!packet.data) {
1823
+ return {
1824
+ needsOffloading: false,
1825
+ size: 0
1826
+ };
1827
+ }
1828
+ const byteSize = Buffer.byteLength(packet.data, "utf8");
1829
+ return {
1830
+ needsOffloading: byteSize >= OFFLOAD_IO_PACKET_LENGTH_LIMIT,
1831
+ size: byteSize
1832
+ };
1833
+ }
1834
+ __name(packetRequiresOffloading, "packetRequiresOffloading");
1835
+ async function exportPacket(packet, pathPrefix) {
1836
+ const filename = `${pathPrefix}.${getPacketExtension(packet.dataType)}`;
1837
+ const presignedResponse = await apiClientManager.client.createUploadPayloadUrl(filename);
1838
+ const uploadResponse = await fetch(presignedResponse.presignedUrl, {
1839
+ method: "PUT",
1840
+ headers: {
1841
+ "Content-Type": packet.dataType
1842
+ },
1843
+ body: packet.data
1844
+ });
1845
+ if (!uploadResponse.ok) {
1846
+ throw new Error(`Failed to upload output to ${presignedResponse.presignedUrl}: ${uploadResponse.statusText}`);
1847
+ }
1848
+ return {
1849
+ data: filename,
1850
+ dataType: "application/store"
1851
+ };
1852
+ }
1853
+ __name(exportPacket, "exportPacket");
1854
+ async function conditionallyImportPacket(packet, tracer) {
1855
+ if (packet.dataType !== "application/store") {
1856
+ return packet;
1857
+ }
1858
+ if (!tracer) {
1859
+ return await importPacket(packet);
1860
+ } else {
1861
+ const result = await tracer.startActiveSpan("store.downloadPayload", async (span) => {
1862
+ return await importPacket(packet, span);
1863
+ }, {
1864
+ attributes: {
1865
+ [SemanticInternalAttributes.STYLE_ICON]: "cloud-download"
1866
+ }
1867
+ });
1868
+ return result ?? packet;
1869
+ }
1870
+ }
1871
+ __name(conditionallyImportPacket, "conditionallyImportPacket");
1872
+ async function importPacket(packet, span) {
1873
+ if (!packet.data) {
1874
+ return packet;
1875
+ }
1876
+ if (!apiClientManager.client) {
1877
+ return packet;
1878
+ }
1879
+ const presignedResponse = await apiClientManager.client.getPayloadUrl(packet.data);
1880
+ const response = await fetch(presignedResponse.presignedUrl);
1881
+ if (!response.ok) {
1882
+ throw new Error(`Failed to import packet ${presignedResponse.presignedUrl}: ${response.statusText}`);
1883
+ }
1884
+ const data = await response.text();
1885
+ span?.setAttribute("size", Buffer.byteLength(data, "utf8"));
1886
+ return {
1887
+ data,
1888
+ dataType: response.headers.get("content-type") ?? "application/json"
1889
+ };
1890
+ }
1891
+ __name(importPacket, "importPacket");
1892
+ async function createPacketAttributes(packet, dataKey, dataTypeKey) {
1893
+ if (!packet.data) {
1894
+ return;
1895
+ }
1896
+ switch (packet.dataType) {
1897
+ case "application/json":
1898
+ return {
1899
+ ...flattenAttributes(packet, dataKey),
1900
+ [dataTypeKey]: packet.dataType
1901
+ };
1902
+ case "application/super+json":
1903
+ const { parse } = await loadSuperJSON();
1904
+ if (typeof packet.data === "undefined" || packet.data === null) {
1905
+ return;
1906
+ }
1907
+ try {
1908
+ const parsed = parse(packet.data);
1909
+ const jsonified = JSON.parse(JSON.stringify(parsed, safeReplacer));
1910
+ return {
1911
+ ...flattenAttributes(jsonified, dataKey),
1912
+ [dataTypeKey]: "application/json"
1913
+ };
1914
+ } catch {
1915
+ return;
1916
+ }
1917
+ case "application/store":
1918
+ return {
1919
+ [dataKey]: packet.data,
1920
+ [dataTypeKey]: packet.dataType
1921
+ };
1922
+ case "text/plain":
1923
+ return {
1924
+ [dataKey]: packet.data,
1925
+ [dataTypeKey]: packet.dataType
1926
+ };
1927
+ default:
1928
+ return;
1929
+ }
1930
+ }
1931
+ __name(createPacketAttributes, "createPacketAttributes");
1932
+ function safeReplacer(key, value) {
1933
+ if (typeof value === "bigint") {
1934
+ return value.toString();
1935
+ }
1936
+ if (value instanceof RegExp) {
1937
+ return value.toString();
1938
+ }
1939
+ if (value instanceof Set) {
1940
+ return Array.from(value);
1941
+ }
1942
+ if (value instanceof Map) {
1943
+ const obj = {};
1944
+ value.forEach((v, k) => {
1945
+ obj[k] = v;
1946
+ });
1947
+ return obj;
1948
+ }
1949
+ return value;
1950
+ }
1951
+ __name(safeReplacer, "safeReplacer");
1952
+ function getPacketExtension(outputType) {
1953
+ switch (outputType) {
1954
+ case "application/json":
1955
+ return "json";
1956
+ case "application/super+json":
1957
+ return "json";
1958
+ case "text/plain":
1959
+ return "txt";
1960
+ default:
1961
+ return "txt";
1962
+ }
1963
+ }
1964
+ __name(getPacketExtension, "getPacketExtension");
1965
+ async function loadSuperJSON() {
1966
+ return await import('superjson');
1967
+ }
1968
+ __name(loadSuperJSON, "loadSuperJSON");
1969
+
1970
+ // src/v3/utils/styleAttributes.ts
1971
+ function accessoryAttributes(accessory) {
1972
+ return flattenAttributes(accessory, SemanticInternalAttributes.STYLE_ACCESSORY);
1973
+ }
1974
+ __name(accessoryAttributes, "accessoryAttributes");
1975
+
1976
+ // src/v3/workers/taskExecutor.ts
1977
+ var _callRun, callRun_fn, _callTaskInit, callTaskInit_fn, _callTaskCleanup, callTaskCleanup_fn, _handleError, handleError_fn;
1978
+ var _TaskExecutor = class _TaskExecutor {
1979
+ constructor(task, options) {
1980
+ __privateAdd(this, _callRun);
1981
+ __privateAdd(this, _callTaskInit);
1982
+ __privateAdd(this, _callTaskCleanup);
1983
+ __privateAdd(this, _handleError);
1984
+ this.task = task;
1985
+ this._tracingSDK = options.tracingSDK;
1986
+ this._tracer = options.tracer;
1987
+ this._consoleInterceptor = options.consoleInterceptor;
1988
+ this._config = options.projectConfig;
1989
+ this._importedConfig = options.importedConfig;
1990
+ this._handleErrorFn = options.handleErrorFn;
1991
+ }
1992
+ async execute(execution, worker, traceContext) {
1993
+ const ctx = TaskRunContext.parse(execution);
1994
+ const attemptMessage = `Attempt ${execution.attempt.number}`;
1995
+ const originalPacket = {
1996
+ data: execution.run.payload,
1997
+ dataType: execution.run.payloadType
1998
+ };
1999
+ taskContext.setGlobalTaskContext({
2000
+ ctx,
2001
+ worker
2002
+ });
2003
+ this._tracingSDK.asyncResourceDetector.resolveWithAttributes({
2004
+ ...taskContext.attributes,
2005
+ [SemanticInternalAttributes.SDK_VERSION]: this.task.packageVersion,
2006
+ [SemanticInternalAttributes.SDK_LANGUAGE]: "typescript"
2007
+ });
2008
+ const result = await this._tracer.startActiveSpan(attemptMessage, async (span) => {
2009
+ return await this._consoleInterceptor.intercept(console, async () => {
2010
+ let parsedPayload;
2011
+ let initOutput;
2012
+ try {
2013
+ const payloadPacket = await conditionallyImportPacket(originalPacket, this._tracer);
2014
+ parsedPayload = await parsePacket(payloadPacket);
2015
+ initOutput = await __privateMethod(this, _callTaskInit, callTaskInit_fn).call(this, parsedPayload, ctx);
2016
+ const output = await __privateMethod(this, _callRun, callRun_fn).call(this, parsedPayload, ctx, initOutput);
2017
+ try {
2018
+ const stringifiedOutput = await stringifyIO(output);
2019
+ const finalOutput = await conditionallyExportPacket(stringifiedOutput, `${execution.attempt.id}/output`, this._tracer);
2020
+ const attributes = await createPacketAttributes(finalOutput, SemanticInternalAttributes.OUTPUT, SemanticInternalAttributes.OUTPUT_TYPE);
2021
+ if (attributes) {
2022
+ span.setAttributes(attributes);
2023
+ }
2024
+ return {
2025
+ ok: true,
2026
+ id: execution.run.id,
2027
+ output: finalOutput.data,
2028
+ outputType: finalOutput.dataType
2029
+ };
2030
+ } catch (stringifyError) {
2031
+ recordSpanException(span, stringifyError);
2032
+ return {
2033
+ ok: false,
2034
+ id: execution.run.id,
2035
+ error: {
2036
+ type: "INTERNAL_ERROR",
2037
+ code: TaskRunErrorCodes.TASK_OUTPUT_ERROR,
2038
+ message: stringifyError instanceof Error ? stringifyError.message : typeof stringifyError === "string" ? stringifyError : void 0
2039
+ }
2040
+ };
2041
+ }
2042
+ } catch (runError) {
2043
+ try {
2044
+ const handleErrorResult = await __privateMethod(this, _handleError, handleError_fn).call(this, execution, runError, parsedPayload, ctx);
2045
+ recordSpanException(span, handleErrorResult.error ?? runError);
2046
+ return {
2047
+ id: execution.run.id,
2048
+ ok: false,
2049
+ error: handleErrorResult.error ? parseError(handleErrorResult.error) : parseError(runError),
2050
+ retry: handleErrorResult.status === "retry" ? handleErrorResult.retry : void 0,
2051
+ skippedRetrying: handleErrorResult.status === "skipped"
2052
+ };
2053
+ } catch (handleErrorError) {
2054
+ recordSpanException(span, handleErrorError);
2055
+ return {
2056
+ ok: false,
2057
+ id: execution.run.id,
2058
+ error: {
2059
+ type: "INTERNAL_ERROR",
2060
+ code: TaskRunErrorCodes.HANDLE_ERROR_ERROR,
2061
+ message: handleErrorError instanceof Error ? handleErrorError.message : typeof handleErrorError === "string" ? handleErrorError : void 0
2062
+ }
2063
+ };
2064
+ }
2065
+ } finally {
2066
+ await __privateMethod(this, _callTaskCleanup, callTaskCleanup_fn).call(this, parsedPayload, ctx, initOutput);
2067
+ }
2068
+ });
2069
+ }, {
2070
+ kind: api.SpanKind.CONSUMER,
2071
+ attributes: {
2072
+ [SemanticInternalAttributes.STYLE_ICON]: "attempt",
2073
+ ...accessoryAttributes({
2074
+ items: [
2075
+ {
2076
+ text: ctx.task.filePath
2077
+ },
2078
+ {
2079
+ text: `${ctx.task.exportName}.run()`
2080
+ }
2081
+ ],
2082
+ style: "codepath"
2083
+ })
2084
+ }
2085
+ }, this._tracer.extractContext(traceContext));
2086
+ return result;
2087
+ }
2088
+ };
2089
+ _callRun = new WeakSet();
2090
+ callRun_fn = /* @__PURE__ */ __name(async function(payload, ctx, init) {
2091
+ const runFn = this.task.fns.run;
2092
+ const middlewareFn = this.task.fns.middleware;
2093
+ if (!runFn) {
2094
+ throw new Error("Task does not have a run function");
2095
+ }
2096
+ if (!middlewareFn) {
2097
+ return runFn(payload, {
2098
+ ctx
2099
+ });
2100
+ }
2101
+ return middlewareFn(payload, {
2102
+ ctx,
2103
+ next: async () => runFn(payload, {
2104
+ ctx,
2105
+ init
2106
+ })
2107
+ });
2108
+ }, "#callRun");
2109
+ _callTaskInit = new WeakSet();
2110
+ callTaskInit_fn = /* @__PURE__ */ __name(async function(payload1, ctx1) {
2111
+ const initFn = this.task.fns.init;
2112
+ if (!initFn) {
2113
+ return {};
2114
+ }
2115
+ return this._tracer.startActiveSpan("init", async (span) => {
2116
+ return await initFn(payload1, {
2117
+ ctx: ctx1
2118
+ });
2119
+ });
2120
+ }, "#callTaskInit");
2121
+ _callTaskCleanup = new WeakSet();
2122
+ callTaskCleanup_fn = /* @__PURE__ */ __name(async function(payload2, ctx2, init1) {
2123
+ const cleanupFn = this.task.fns.cleanup;
2124
+ if (!cleanupFn) {
2125
+ return;
2126
+ }
2127
+ return this._tracer.startActiveSpan("cleanup", async (span) => {
2128
+ return await cleanupFn(payload2, {
2129
+ ctx: ctx2,
2130
+ init: init1
2131
+ });
2132
+ });
2133
+ }, "#callTaskCleanup");
2134
+ _handleError = new WeakSet();
2135
+ handleError_fn = /* @__PURE__ */ __name(async function(execution, error, payload3, ctx3) {
2136
+ const retriesConfig = this._importedConfig?.retries ?? this._config.retries;
2137
+ const retry = this.task.retry ?? retriesConfig?.default;
2138
+ if (!retry) {
2139
+ return {
2140
+ status: "noop"
2141
+ };
2142
+ }
2143
+ const delay = calculateNextRetryDelay(retry, execution.attempt.number);
2144
+ if (execution.environment.type === "DEVELOPMENT" && typeof retriesConfig?.enabledInDev === "boolean" && !retriesConfig.enabledInDev) {
2145
+ return {
2146
+ status: "skipped"
2147
+ };
2148
+ }
2149
+ return this._tracer.startActiveSpan("handleError()", async (span) => {
2150
+ const handleErrorResult = this.task.fns.handleError ? await this.task.fns.handleError(payload3, error, {
2151
+ ctx: ctx3,
2152
+ retry,
2153
+ retryDelayInMs: delay,
2154
+ retryAt: delay ? new Date(Date.now() + delay) : void 0
2155
+ }) : this._importedConfig ? await this._handleErrorFn?.(payload3, error, {
2156
+ ctx: ctx3,
2157
+ retry,
2158
+ retryDelayInMs: delay,
2159
+ retryAt: delay ? new Date(Date.now() + delay) : void 0
2160
+ }) : void 0;
2161
+ if (!handleErrorResult) {
2162
+ return typeof delay === "undefined" ? {
2163
+ status: "noop"
2164
+ } : {
2165
+ status: "retry",
2166
+ retry: {
2167
+ timestamp: Date.now() + delay,
2168
+ delay
2169
+ }
2170
+ };
2171
+ }
2172
+ if (handleErrorResult.skipRetrying) {
2173
+ return {
2174
+ status: "skipped",
2175
+ error: handleErrorResult.error
2176
+ };
2177
+ }
2178
+ if (typeof handleErrorResult.retryAt !== "undefined") {
2179
+ return {
2180
+ status: "retry",
2181
+ retry: {
2182
+ timestamp: handleErrorResult.retryAt.getTime(),
2183
+ delay: handleErrorResult.retryAt.getTime() - Date.now()
2184
+ },
2185
+ error: handleErrorResult.error
2186
+ };
2187
+ }
2188
+ if (typeof handleErrorResult.retryDelayInMs === "number") {
2189
+ return {
2190
+ status: "retry",
2191
+ retry: {
2192
+ timestamp: Date.now() + handleErrorResult.retryDelayInMs,
2193
+ delay: handleErrorResult.retryDelayInMs
2194
+ },
2195
+ error: handleErrorResult.error
2196
+ };
2197
+ }
2198
+ if (handleErrorResult.retry && typeof handleErrorResult.retry === "object") {
2199
+ const delay2 = calculateNextRetryDelay(handleErrorResult.retry, execution.attempt.number);
2200
+ return typeof delay2 === "undefined" ? {
2201
+ status: "noop",
2202
+ error: handleErrorResult.error
2203
+ } : {
2204
+ status: "retry",
2205
+ retry: {
2206
+ timestamp: Date.now() + delay2,
2207
+ delay: delay2
2208
+ },
2209
+ error: handleErrorResult.error
2210
+ };
2211
+ }
2212
+ return {
2213
+ status: "noop",
2214
+ error: handleErrorResult.error
2215
+ };
2216
+ }, {
2217
+ attributes: {
2218
+ [SemanticInternalAttributes.STYLE_ICON]: "exclamation-circle"
2219
+ }
2220
+ });
2221
+ }, "#handleError");
2222
+ __name(_TaskExecutor, "TaskExecutor");
2223
+ var TaskExecutor = _TaskExecutor;
2224
+ var _originClockTime, originClockTime_get, _originPreciseDate, originPreciseDate_get;
2225
+ var _PreciseWallClock = class _PreciseWallClock {
2226
+ constructor(options = {}) {
2227
+ __privateAdd(this, _originClockTime);
2228
+ __privateAdd(this, _originPreciseDate);
2229
+ this._origin = {
2230
+ clockTime: options.origin ?? process.hrtime(),
2231
+ preciseDate: options.now ?? new preciseDate.PreciseDate()
2232
+ };
2233
+ }
2234
+ preciseNow() {
2235
+ const elapsedHrTime = process.hrtime(__privateGet(this, _originClockTime, originClockTime_get));
2236
+ const elapsedNanoseconds = BigInt(elapsedHrTime[0]) * BigInt(1e9) + BigInt(elapsedHrTime[1]);
2237
+ const preciseDate$1 = new preciseDate.PreciseDate(__privateGet(this, _originPreciseDate, originPreciseDate_get).getFullTime() + elapsedNanoseconds);
2238
+ const dateStruct = preciseDate$1.toStruct();
2239
+ return [
2240
+ dateStruct.seconds,
2241
+ dateStruct.nanos
2242
+ ];
2243
+ }
2244
+ reset() {
2245
+ this._origin = {
2246
+ clockTime: process.hrtime(),
2247
+ preciseDate: new preciseDate.PreciseDate()
2248
+ };
2249
+ }
2250
+ };
2251
+ _originClockTime = new WeakSet();
2252
+ originClockTime_get = /* @__PURE__ */ __name(function() {
2253
+ return this._origin.clockTime;
2254
+ }, "#originClockTime");
2255
+ _originPreciseDate = new WeakSet();
2256
+ originPreciseDate_get = /* @__PURE__ */ __name(function() {
2257
+ return this._origin.preciseDate;
2258
+ }, "#originPreciseDate");
2259
+ __name(_PreciseWallClock, "PreciseWallClock");
2260
+ var PreciseWallClock = _PreciseWallClock;
2261
+ function iconStringForSeverity(severityNumber) {
2262
+ switch (severityNumber) {
2263
+ case apiLogs.SeverityNumber.UNSPECIFIED:
2264
+ return void 0;
2265
+ case apiLogs.SeverityNumber.TRACE:
2266
+ case apiLogs.SeverityNumber.TRACE2:
2267
+ case apiLogs.SeverityNumber.TRACE3:
2268
+ case apiLogs.SeverityNumber.TRACE4:
2269
+ return "trace";
2270
+ case apiLogs.SeverityNumber.DEBUG:
2271
+ case apiLogs.SeverityNumber.DEBUG2:
2272
+ case apiLogs.SeverityNumber.DEBUG3:
2273
+ case apiLogs.SeverityNumber.DEBUG4:
2274
+ return "debug";
2275
+ case apiLogs.SeverityNumber.INFO:
2276
+ case apiLogs.SeverityNumber.INFO2:
2277
+ case apiLogs.SeverityNumber.INFO3:
2278
+ case apiLogs.SeverityNumber.INFO4:
2279
+ return "info";
2280
+ case apiLogs.SeverityNumber.WARN:
2281
+ case apiLogs.SeverityNumber.WARN2:
2282
+ case apiLogs.SeverityNumber.WARN3:
2283
+ case apiLogs.SeverityNumber.WARN4:
2284
+ return "warn";
2285
+ case apiLogs.SeverityNumber.ERROR:
2286
+ case apiLogs.SeverityNumber.ERROR2:
2287
+ case apiLogs.SeverityNumber.ERROR3:
2288
+ case apiLogs.SeverityNumber.ERROR4:
2289
+ return "error";
2290
+ case apiLogs.SeverityNumber.FATAL:
2291
+ case apiLogs.SeverityNumber.FATAL2:
2292
+ case apiLogs.SeverityNumber.FATAL3:
2293
+ case apiLogs.SeverityNumber.FATAL4:
2294
+ return "fatal";
2295
+ }
2296
+ }
2297
+ __name(iconStringForSeverity, "iconStringForSeverity");
2298
+ var _SimpleClock = class _SimpleClock {
2299
+ preciseNow() {
2300
+ const now = new preciseDate.PreciseDate();
2301
+ const nowStruct = now.toStruct();
2302
+ return [
2303
+ nowStruct.seconds,
2304
+ nowStruct.nanos
2305
+ ];
2306
+ }
2307
+ reset() {
2308
+ }
2309
+ };
2310
+ __name(_SimpleClock, "SimpleClock");
2311
+ var SimpleClock = _SimpleClock;
2312
+
2313
+ // src/v3/clock/index.ts
2314
+ var API_NAME2 = "clock";
2315
+ var SIMPLE_CLOCK = new SimpleClock();
2316
+ var _getClock, getClock_fn;
2317
+ var _ClockAPI = class _ClockAPI {
2318
+ constructor() {
2319
+ __privateAdd(this, _getClock);
2320
+ }
2321
+ static getInstance() {
2322
+ if (!this._instance) {
2323
+ this._instance = new _ClockAPI();
2324
+ }
2325
+ return this._instance;
2326
+ }
2327
+ setGlobalClock(clock2) {
2328
+ return registerGlobal(API_NAME2, clock2);
2329
+ }
2330
+ preciseNow() {
2331
+ return __privateMethod(this, _getClock, getClock_fn).call(this).preciseNow();
2332
+ }
2333
+ reset() {
2334
+ __privateMethod(this, _getClock, getClock_fn).call(this).reset();
2335
+ }
2336
+ };
2337
+ _getClock = new WeakSet();
2338
+ getClock_fn = /* @__PURE__ */ __name(function() {
2339
+ return getGlobal(API_NAME2) ?? SIMPLE_CLOCK;
2340
+ }, "#getClock");
2341
+ __name(_ClockAPI, "ClockAPI");
2342
+ var ClockAPI = _ClockAPI;
2343
+
2344
+ // src/v3/clock-api.ts
2345
+ var clock = ClockAPI.getInstance();
2346
+
2347
+ // src/v3/logger/taskLogger.ts
2348
+ var logLevels = [
2349
+ "none",
2350
+ "error",
2351
+ "warn",
2352
+ "log",
2353
+ "info",
2354
+ "debug"
2355
+ ];
2356
+ var _emitLog, emitLog_fn, _getTimestampInHrTime, getTimestampInHrTime_fn;
2357
+ var _OtelTaskLogger = class _OtelTaskLogger {
2358
+ constructor(_config) {
2359
+ __privateAdd(this, _emitLog);
2360
+ __privateAdd(this, _getTimestampInHrTime);
2361
+ this._config = _config;
2362
+ this._level = logLevels.indexOf(_config.level);
2363
+ }
2364
+ debug(message, properties) {
2365
+ if (this._level < 5)
2366
+ return;
2367
+ __privateMethod(this, _emitLog, emitLog_fn).call(this, message, __privateMethod(this, _getTimestampInHrTime, getTimestampInHrTime_fn).call(this), "debug", apiLogs.SeverityNumber.DEBUG, properties);
2368
+ }
2369
+ log(message, properties) {
2370
+ if (this._level < 3)
2371
+ return;
2372
+ __privateMethod(this, _emitLog, emitLog_fn).call(this, message, __privateMethod(this, _getTimestampInHrTime, getTimestampInHrTime_fn).call(this), "log", apiLogs.SeverityNumber.INFO, properties);
2373
+ }
2374
+ info(message, properties) {
2375
+ if (this._level < 4)
2376
+ return;
2377
+ __privateMethod(this, _emitLog, emitLog_fn).call(this, message, __privateMethod(this, _getTimestampInHrTime, getTimestampInHrTime_fn).call(this), "info", apiLogs.SeverityNumber.INFO, properties);
2378
+ }
2379
+ warn(message, properties) {
2380
+ if (this._level < 2)
2381
+ return;
2382
+ __privateMethod(this, _emitLog, emitLog_fn).call(this, message, __privateMethod(this, _getTimestampInHrTime, getTimestampInHrTime_fn).call(this), "warn", apiLogs.SeverityNumber.WARN, properties);
2383
+ }
2384
+ error(message, properties) {
2385
+ if (this._level < 1)
2386
+ return;
2387
+ __privateMethod(this, _emitLog, emitLog_fn).call(this, message, __privateMethod(this, _getTimestampInHrTime, getTimestampInHrTime_fn).call(this), "error", apiLogs.SeverityNumber.ERROR, properties);
2388
+ }
2389
+ trace(name, fn, options) {
2390
+ return this._config.tracer.startActiveSpan(name, fn, options);
2391
+ }
2392
+ };
2393
+ _emitLog = new WeakSet();
2394
+ emitLog_fn = /* @__PURE__ */ __name(function(message, timestamp, severityText, severityNumber, properties) {
2395
+ let attributes = {
2396
+ ...flattenAttributes(safeJsonProcess(properties))
2397
+ };
2398
+ const icon = iconStringForSeverity(severityNumber);
2399
+ if (icon !== void 0) {
2400
+ attributes[SemanticInternalAttributes.STYLE_ICON] = icon;
2401
+ }
2402
+ this._config.logger.emit({
2403
+ severityNumber,
2404
+ severityText,
2405
+ body: message,
2406
+ attributes,
2407
+ timestamp
2408
+ });
2409
+ }, "#emitLog");
2410
+ _getTimestampInHrTime = new WeakSet();
2411
+ getTimestampInHrTime_fn = /* @__PURE__ */ __name(function() {
2412
+ return clock.preciseNow();
2413
+ }, "#getTimestampInHrTime");
2414
+ __name(_OtelTaskLogger, "OtelTaskLogger");
2415
+ var OtelTaskLogger = _OtelTaskLogger;
2416
+ function safeJsonProcess(value) {
2417
+ try {
2418
+ return JSON.parse(JSON.stringify(value, jsonErrorReplacer));
2419
+ } catch {
2420
+ return value;
2421
+ }
2422
+ }
2423
+ __name(safeJsonProcess, "safeJsonProcess");
2424
+ function jsonErrorReplacer(key, value) {
2425
+ if (value instanceof Error) {
2426
+ return {
2427
+ name: value.name,
2428
+ message: value.message,
2429
+ stack: value.stack
2430
+ };
2431
+ }
2432
+ return value;
2433
+ }
2434
+ __name(jsonErrorReplacer, "jsonErrorReplacer");
2435
+ var _handleLog, handleLog_fn, _getTimestampInHrTime2, getTimestampInHrTime_fn2, _getAttributes, getAttributes_fn;
2436
+ var _ConsoleInterceptor = class _ConsoleInterceptor {
2437
+ constructor(logger, sendToStdIO) {
2438
+ __privateAdd(this, _handleLog);
2439
+ __privateAdd(this, _getTimestampInHrTime2);
2440
+ __privateAdd(this, _getAttributes);
2441
+ this.logger = logger;
2442
+ this.sendToStdIO = sendToStdIO;
2443
+ }
2444
+ // Intercept the console and send logs to the OpenTelemetry logger
2445
+ // during the execution of the callback
2446
+ async intercept(console2, callback) {
2447
+ const originalConsole = {
2448
+ log: console2.log,
2449
+ info: console2.info,
2450
+ warn: console2.warn,
2451
+ error: console2.error,
2452
+ debug: console2.debug
2453
+ };
2454
+ console2.log = this.log.bind(this);
2455
+ console2.info = this.info.bind(this);
2456
+ console2.warn = this.warn.bind(this);
2457
+ console2.error = this.error.bind(this);
2458
+ console2.debug = this.debug.bind(this);
2459
+ try {
2460
+ return await callback();
2461
+ } finally {
2462
+ console2.log = originalConsole.log;
2463
+ console2.info = originalConsole.info;
2464
+ console2.warn = originalConsole.warn;
2465
+ console2.error = originalConsole.error;
2466
+ console2.debug = originalConsole.debug;
2467
+ }
2468
+ }
2469
+ debug(...args) {
2470
+ __privateMethod(this, _handleLog, handleLog_fn).call(this, apiLogs.SeverityNumber.DEBUG, __privateMethod(this, _getTimestampInHrTime2, getTimestampInHrTime_fn2).call(this), "Debug", ...args);
2471
+ }
2472
+ log(...args) {
2473
+ __privateMethod(this, _handleLog, handleLog_fn).call(this, apiLogs.SeverityNumber.INFO, __privateMethod(this, _getTimestampInHrTime2, getTimestampInHrTime_fn2).call(this), "Log", ...args);
2474
+ }
2475
+ info(...args) {
2476
+ __privateMethod(this, _handleLog, handleLog_fn).call(this, apiLogs.SeverityNumber.INFO, __privateMethod(this, _getTimestampInHrTime2, getTimestampInHrTime_fn2).call(this), "Info", ...args);
2477
+ }
2478
+ warn(...args) {
2479
+ __privateMethod(this, _handleLog, handleLog_fn).call(this, apiLogs.SeverityNumber.WARN, __privateMethod(this, _getTimestampInHrTime2, getTimestampInHrTime_fn2).call(this), "Warn", ...args);
2480
+ }
2481
+ error(...args) {
2482
+ __privateMethod(this, _handleLog, handleLog_fn).call(this, apiLogs.SeverityNumber.ERROR, __privateMethod(this, _getTimestampInHrTime2, getTimestampInHrTime_fn2).call(this), "Error", ...args);
2483
+ }
2484
+ };
2485
+ _handleLog = new WeakSet();
2486
+ handleLog_fn = /* @__PURE__ */ __name(function(severityNumber, timestamp, severityText, ...args) {
2487
+ const body = util__default.default.format(...args);
2488
+ if (this.sendToStdIO) {
2489
+ if (severityNumber === apiLogs.SeverityNumber.ERROR) {
2490
+ process.stderr.write(body);
2491
+ } else {
2492
+ process.stdout.write(body);
2493
+ }
2494
+ }
2495
+ const parsed = tryParseJSON(body);
2496
+ if (parsed.ok) {
2497
+ this.logger.emit({
2498
+ severityNumber,
2499
+ severityText,
2500
+ body: getLogMessage(parsed.value, severityText),
2501
+ attributes: {
2502
+ ...__privateMethod(this, _getAttributes, getAttributes_fn).call(this, severityNumber),
2503
+ ...flattenAttributes(parsed.value)
2504
+ },
2505
+ timestamp
2506
+ });
2507
+ return;
2508
+ }
2509
+ this.logger.emit({
2510
+ severityNumber,
2511
+ severityText,
2512
+ body,
2513
+ attributes: __privateMethod(this, _getAttributes, getAttributes_fn).call(this, severityNumber),
2514
+ timestamp
2515
+ });
2516
+ }, "#handleLog");
2517
+ _getTimestampInHrTime2 = new WeakSet();
2518
+ getTimestampInHrTime_fn2 = /* @__PURE__ */ __name(function() {
2519
+ return clock.preciseNow();
2520
+ }, "#getTimestampInHrTime");
2521
+ _getAttributes = new WeakSet();
2522
+ getAttributes_fn = /* @__PURE__ */ __name(function(severityNumber1) {
2523
+ const icon = iconStringForSeverity(severityNumber1);
2524
+ let result = {};
2525
+ if (icon !== void 0) {
2526
+ result[SemanticInternalAttributes.STYLE_ICON] = icon;
2527
+ }
2528
+ return result;
2529
+ }, "#getAttributes");
2530
+ __name(_ConsoleInterceptor, "ConsoleInterceptor");
2531
+ var ConsoleInterceptor = _ConsoleInterceptor;
2532
+ function getLogMessage(value, fallback) {
2533
+ if (typeof value["message"] === "string") {
2534
+ return value["message"];
2535
+ }
2536
+ if (typeof value["msg"] === "string") {
2537
+ return value["msg"];
2538
+ }
2539
+ if (typeof value["body"] === "string") {
2540
+ return value["body"];
2541
+ }
2542
+ if (typeof value["error"] === "string") {
2543
+ return value["error"];
2544
+ }
2545
+ return fallback;
2546
+ }
2547
+ __name(getLogMessage, "getLogMessage");
2548
+ function tryParseJSON(value) {
2549
+ try {
2550
+ const parsed = JSON.parse(value);
2551
+ if (typeof parsed === "object" && parsed !== null && !Array.isArray(parsed)) {
2552
+ return {
2553
+ ok: true,
2554
+ value: parsed
2555
+ };
2556
+ }
2557
+ return {
2558
+ ok: false,
2559
+ value
2560
+ };
2561
+ } catch (e) {
2562
+ return {
2563
+ ok: false,
2564
+ value
2565
+ };
2566
+ }
2567
+ }
2568
+ __name(tryParseJSON, "tryParseJSON");
2569
+
2570
+ // src/v3/task-catalog/standardTaskCatalog.ts
2571
+ var _StandardTaskCatalog = class _StandardTaskCatalog {
2572
+ constructor() {
2573
+ __publicField(this, "_taskMetadata", /* @__PURE__ */ new Map());
2574
+ __publicField(this, "_taskFunctions", /* @__PURE__ */ new Map());
2575
+ __publicField(this, "_taskFileMetadata", /* @__PURE__ */ new Map());
2576
+ }
2577
+ registerTaskMetadata(task) {
2578
+ const { fns, ...metadata } = task;
2579
+ this._taskMetadata.set(task.id, metadata);
2580
+ this._taskFunctions.set(task.id, fns);
2581
+ }
2582
+ updateTaskMetadata(id, updates) {
2583
+ const existingMetadata = this._taskMetadata.get(id);
2584
+ if (existingMetadata) {
2585
+ this._taskMetadata.set(id, {
2586
+ ...existingMetadata,
2587
+ ...updates
2588
+ });
2589
+ }
2590
+ if (updates.fns) {
2591
+ const existingFunctions = this._taskFunctions.get(id);
2592
+ if (existingFunctions) {
2593
+ this._taskFunctions.set(id, {
2594
+ ...existingFunctions,
2595
+ ...updates.fns
2596
+ });
2597
+ }
2598
+ }
2599
+ }
2600
+ registerTaskFileMetadata(id, metadata) {
2601
+ this._taskFileMetadata.set(id, metadata);
2602
+ }
2603
+ // Return all the tasks, without the functions
2604
+ getAllTaskMetadata() {
2605
+ const result = [];
2606
+ for (const [id, metadata] of this._taskMetadata) {
2607
+ const fileMetadata = this._taskFileMetadata.get(id);
2608
+ if (!fileMetadata) {
2609
+ continue;
2610
+ }
2611
+ result.push({
2612
+ ...metadata,
2613
+ ...fileMetadata
2614
+ });
2615
+ }
2616
+ return result;
2617
+ }
2618
+ getTaskMetadata(id) {
2619
+ const metadata = this._taskMetadata.get(id);
2620
+ const fileMetadata = this._taskFileMetadata.get(id);
2621
+ if (!metadata || !fileMetadata) {
2622
+ return void 0;
2623
+ }
2624
+ return {
2625
+ ...metadata,
2626
+ ...fileMetadata
2627
+ };
2628
+ }
2629
+ getTask(id) {
2630
+ const metadata = this._taskMetadata.get(id);
2631
+ const fileMetadata = this._taskFileMetadata.get(id);
2632
+ const fns = this._taskFunctions.get(id);
2633
+ if (!metadata || !fns || !fileMetadata) {
2634
+ return void 0;
2635
+ }
2636
+ return {
2637
+ ...metadata,
2638
+ ...fileMetadata,
2639
+ fns
2640
+ };
2641
+ }
2642
+ taskExists(id) {
2643
+ return this._taskMetadata.has(id);
2644
+ }
2645
+ disable() {
2646
+ }
2647
+ };
2648
+ __name(_StandardTaskCatalog, "StandardTaskCatalog");
2649
+ var StandardTaskCatalog = _StandardTaskCatalog;
2650
+
2651
+ exports.ConsoleInterceptor = ConsoleInterceptor;
2652
+ exports.DurableClock = PreciseWallClock;
2653
+ exports.OtelTaskLogger = OtelTaskLogger;
2654
+ exports.StandardTaskCatalog = StandardTaskCatalog;
2655
+ exports.TaskContextLogProcessor = TaskContextLogProcessor;
2656
+ exports.TaskContextSpanProcessor = TaskContextSpanProcessor;
2657
+ exports.TaskExecutor = TaskExecutor;
2658
+ exports.TracingSDK = TracingSDK;
2659
+ exports.getEnvVar = getEnvVar;
2660
+ exports.logLevels = logLevels;
2661
+ exports.recordSpanException = recordSpanException;
2662
+ //# sourceMappingURL=out.js.map
2663
+ //# sourceMappingURL=index.js.map