@trigger.dev/core 3.0.0-beta.34 → 3.0.0-beta.36

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 (53) hide show
  1. package/dist/catalog-XTlJQaMn.d.mts +202 -0
  2. package/dist/catalog-dRKTgwQ7.d.ts +202 -0
  3. package/dist/{manager-WNMVbgHf.d.mts → manager-JkbddlcO.d.mts} +43 -42
  4. package/dist/{manager-WNMVbgHf.d.ts → manager-JkbddlcO.d.ts} +43 -42
  5. package/dist/{messages-vq7Bk4Ap.d.mts → messages-6_-q72KG.d.mts} +5970 -2067
  6. package/dist/{messages-vq7Bk4Ap.d.ts → messages-6_-q72KG.d.ts} +5970 -2067
  7. package/dist/{catalog-tX1P4jZQ.d.ts → schemas-r4ZP9S-F.d.mts} +22 -201
  8. package/dist/{catalog-Y8FyPWvh.d.mts → schemas-r4ZP9S-F.d.ts} +22 -201
  9. package/dist/v3/dev/index.d.mts +2 -2
  10. package/dist/v3/dev/index.d.ts +2 -2
  11. package/dist/v3/dev/index.js +4 -4
  12. package/dist/v3/dev/index.js.map +1 -1
  13. package/dist/v3/dev/index.mjs +4 -4
  14. package/dist/v3/dev/index.mjs.map +1 -1
  15. package/dist/v3/index.d.mts +584 -152
  16. package/dist/v3/index.d.ts +584 -152
  17. package/dist/v3/index.js +962 -350
  18. package/dist/v3/index.js.map +1 -1
  19. package/dist/v3/index.mjs +953 -350
  20. package/dist/v3/index.mjs.map +1 -1
  21. package/dist/v3/otel/index.js +1 -1
  22. package/dist/v3/otel/index.js.map +1 -1
  23. package/dist/v3/otel/index.mjs +1 -1
  24. package/dist/v3/otel/index.mjs.map +1 -1
  25. package/dist/v3/prod/index.d.mts +3 -3
  26. package/dist/v3/prod/index.d.ts +3 -3
  27. package/dist/v3/prod/index.js +90 -15
  28. package/dist/v3/prod/index.js.map +1 -1
  29. package/dist/v3/prod/index.mjs +90 -15
  30. package/dist/v3/prod/index.mjs.map +1 -1
  31. package/dist/v3/workers/index.d.mts +6 -5
  32. package/dist/v3/workers/index.d.ts +6 -5
  33. package/dist/v3/workers/index.js +476 -53
  34. package/dist/v3/workers/index.js.map +1 -1
  35. package/dist/v3/workers/index.mjs +477 -54
  36. package/dist/v3/workers/index.mjs.map +1 -1
  37. package/dist/v3/zodMessageHandler.d.mts +1 -1
  38. package/dist/v3/zodMessageHandler.d.ts +1 -1
  39. package/dist/v3/zodNamespace.js +16 -6
  40. package/dist/v3/zodNamespace.js.map +1 -1
  41. package/dist/v3/zodNamespace.mjs +17 -7
  42. package/dist/v3/zodNamespace.mjs.map +1 -1
  43. package/dist/v3/zodSocket.js +16 -6
  44. package/dist/v3/zodSocket.js.map +1 -1
  45. package/dist/v3/zodSocket.mjs +17 -7
  46. package/dist/v3/zodSocket.mjs.map +1 -1
  47. package/dist/v3/zodfetch.d.mts +262 -0
  48. package/dist/v3/zodfetch.d.ts +262 -0
  49. package/dist/v3/zodfetch.js +744 -0
  50. package/dist/v3/zodfetch.js.map +1 -0
  51. package/dist/v3/zodfetch.mjs +716 -0
  52. package/dist/v3/zodfetch.mjs.map +1 -0
  53. package/package.json +9 -1
@@ -1,4 +1,5 @@
1
1
  import { SpanStatusCode, DiagLogLevel, diag, DiagConsoleLogger, propagation, context, SpanKind } from '@opentelemetry/api';
2
+ import { z } from 'zod';
2
3
  import { logs, SeverityNumber } from '@opentelemetry/api-logs';
3
4
  import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
4
5
  import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
@@ -7,10 +8,9 @@ import { Resource, detectResourcesSync, processDetectorSync } from '@opentelemet
7
8
  import { LoggerProvider, BatchLogRecordProcessor, SimpleLogRecordProcessor } from '@opentelemetry/sdk-logs';
8
9
  import { NodeTracerProvider, BatchSpanProcessor, SimpleSpanProcessor } from '@opentelemetry/sdk-trace-node';
9
10
  import { SemanticResourceAttributes } from '@opentelemetry/semantic-conventions';
10
- import { z } from 'zod';
11
11
  import { fromZodError } from 'zod-validation-error';
12
12
  import { FormDataEncoder } from 'form-data-encoder';
13
- import { Readable } from 'stream';
13
+ import { Readable } from 'node:stream';
14
14
  import { PreciseDate } from '@google-cloud/precise-date';
15
15
  import util from 'node:util';
16
16
 
@@ -38,8 +38,6 @@ var __privateMethod = (obj, member, method) => {
38
38
  __accessCheck(obj, member, "access private method");
39
39
  return method;
40
40
  };
41
-
42
- // src/v3/errors.ts
43
41
  function parseError(error) {
44
42
  if (error instanceof Error) {
45
43
  return {
@@ -68,6 +66,11 @@ function parseError(error) {
68
66
  }
69
67
  }
70
68
  __name(parseError, "parseError");
69
+ var SerializedError = z.object({
70
+ message: z.string(),
71
+ name: z.string().optional(),
72
+ stackTrace: z.string().optional()
73
+ });
71
74
 
72
75
  // src/v3/limits.ts
73
76
  var OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT = 256;
@@ -352,7 +355,7 @@ function getEnvVar(name) {
352
355
  __name(getEnvVar, "getEnvVar");
353
356
 
354
357
  // package.json
355
- var version = "3.0.0-beta.34";
358
+ var version = "3.0.0-beta.36";
356
359
 
357
360
  // src/v3/otel/tracingSDK.ts
358
361
  var _a;
@@ -522,6 +525,7 @@ var TaskRunErrorCodes = {
522
525
  TASK_EXECUTION_FAILED: "TASK_EXECUTION_FAILED",
523
526
  TASK_EXECUTION_ABORTED: "TASK_EXECUTION_ABORTED",
524
527
  TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE: "TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE",
528
+ TASK_PROCESS_SIGKILL_TIMEOUT: "TASK_PROCESS_SIGKILL_TIMEOUT",
525
529
  TASK_RUN_CANCELLED: "TASK_RUN_CANCELLED",
526
530
  TASK_OUTPUT_ERROR: "TASK_OUTPUT_ERROR",
527
531
  HANDLE_ERROR_ERROR: "HANDLE_ERROR_ERROR",
@@ -537,10 +541,12 @@ var TaskRunInternalError = z.object({
537
541
  "TASK_EXECUTION_FAILED",
538
542
  "TASK_EXECUTION_ABORTED",
539
543
  "TASK_PROCESS_EXITED_WITH_NON_ZERO_CODE",
544
+ "TASK_PROCESS_SIGKILL_TIMEOUT",
540
545
  "TASK_RUN_CANCELLED",
541
546
  "TASK_OUTPUT_ERROR",
542
547
  "HANDLE_ERROR_ERROR",
543
- "GRACEFUL_EXIT_TIMEOUT"
548
+ "GRACEFUL_EXIT_TIMEOUT",
549
+ "TASK_RUN_HEARTBEAT_TIMEOUT"
544
550
  ]),
545
551
  message: z.string().optional()
546
552
  });
@@ -790,7 +796,7 @@ var QueueOptions = z.object({
790
796
  /** @deprecated This feature is coming soon */
791
797
  rateLimit: RateLimitOptions.optional()
792
798
  });
793
- var TaskMetadata = z.object({
799
+ z.object({
794
800
  id: z.string(),
795
801
  packageVersion: z.string(),
796
802
  queue: QueueOptions.optional(),
@@ -798,11 +804,20 @@ var TaskMetadata = z.object({
798
804
  machine: Machine.partial().optional(),
799
805
  triggerSource: z.string().optional()
800
806
  });
801
- var TaskFileMetadata = z.object({
807
+ z.object({
808
+ filePath: z.string(),
809
+ exportName: z.string()
810
+ });
811
+ z.object({
812
+ id: z.string(),
813
+ packageVersion: z.string(),
814
+ queue: QueueOptions.optional(),
815
+ retry: RetryOptions.optional(),
816
+ machine: Machine.partial().optional(),
817
+ triggerSource: z.string().optional(),
802
818
  filePath: z.string(),
803
819
  exportName: z.string()
804
820
  });
805
- TaskMetadata.merge(TaskFileMetadata);
806
821
  z.enum([
807
822
  "index",
808
823
  "create",
@@ -843,6 +858,13 @@ z.enum([
843
858
  "WAIT_FOR_TASK",
844
859
  "WAIT_FOR_BATCH"
845
860
  ]);
861
+ z.object({
862
+ runId: z.string(),
863
+ messageId: z.string(),
864
+ isTest: z.boolean(),
865
+ traceContext: z.record(z.unknown()),
866
+ environment: z.record(z.string()).optional()
867
+ });
846
868
 
847
869
  // src/v3/schemas/resources.ts
848
870
  var TaskResource = z.object({
@@ -892,7 +914,8 @@ z.object({
892
914
  });
893
915
  z.object({
894
916
  localOnly: z.boolean(),
895
- metadata: BackgroundWorkerMetadata
917
+ metadata: BackgroundWorkerMetadata,
918
+ supportsLazyAttempts: z.boolean().optional()
896
919
  });
897
920
  z.object({
898
921
  id: z.string(),
@@ -1005,7 +1028,7 @@ var ReplayRunResponse = z.object({
1005
1028
  id: z.string()
1006
1029
  });
1007
1030
  var CanceledRunResponse = z.object({
1008
- message: z.string()
1031
+ id: z.string()
1009
1032
  });
1010
1033
  z.object({
1011
1034
  /** The schedule id associated with this run (you can have many schedules for the same task).
@@ -1054,17 +1077,18 @@ z.object({
1054
1077
  */
1055
1078
  externalId: z.string().optional()
1056
1079
  });
1080
+ var ScheduleGenerator = z.object({
1081
+ type: z.literal("CRON"),
1082
+ expression: z.string(),
1083
+ description: z.string()
1084
+ });
1057
1085
  var ScheduleObject = z.object({
1058
1086
  id: z.string(),
1059
1087
  task: z.string(),
1060
1088
  active: z.boolean(),
1061
1089
  deduplicationKey: z.string().nullish(),
1062
1090
  externalId: z.string().nullish(),
1063
- generator: z.object({
1064
- type: z.literal("CRON"),
1065
- expression: z.string(),
1066
- description: z.string()
1067
- }),
1091
+ generator: ScheduleGenerator,
1068
1092
  nextRun: z.coerce.date().nullish(),
1069
1093
  environments: z.array(z.object({
1070
1094
  id: z.string(),
@@ -1075,7 +1099,7 @@ var ScheduleObject = z.object({
1075
1099
  var DeletedScheduleObject = z.object({
1076
1100
  id: z.string()
1077
1101
  });
1078
- var ListSchedulesResult = z.object({
1102
+ z.object({
1079
1103
  data: z.array(ScheduleObject),
1080
1104
  pagination: z.object({
1081
1105
  currentPage: z.number(),
@@ -1088,12 +1112,28 @@ z.object({
1088
1112
  perPage: z.number().optional()
1089
1113
  });
1090
1114
  var RunStatus = z.enum([
1091
- "PENDING",
1115
+ /// Task hasn't been deployed yet but is waiting to be executed
1116
+ "WAITING_FOR_DEPLOY",
1117
+ /// Task is waiting to be executed by a worker
1118
+ "QUEUED",
1119
+ /// Task is currently being executed by a worker
1092
1120
  "EXECUTING",
1093
- "PAUSED",
1121
+ /// Task has failed and is waiting to be retried
1122
+ "REATTEMPTING",
1123
+ /// Task has been paused by the system, and will be resumed by the system
1124
+ "FROZEN",
1125
+ /// Task has been completed successfully
1094
1126
  "COMPLETED",
1127
+ /// Task has been canceled by the user
1128
+ "CANCELED",
1129
+ /// Task has been completed with errors
1095
1130
  "FAILED",
1096
- "CANCELED"
1131
+ /// Task has crashed and won't be retried, most likely the worker ran out of resources, e.g. memory or storage
1132
+ "CRASHED",
1133
+ /// Task was interrupted during execution, mostly this happens in development environments
1134
+ "INTERRUPTED",
1135
+ /// Task has failed to complete, due to an error in the system
1136
+ "SYSTEM_FAILURE"
1097
1137
  ]);
1098
1138
  var AttemptStatus = z.enum([
1099
1139
  "PENDING",
@@ -1103,23 +1143,61 @@ var AttemptStatus = z.enum([
1103
1143
  "FAILED",
1104
1144
  "CANCELED"
1105
1145
  ]);
1106
- var RetrieveRunResponse = z.object({
1146
+ var RunEnvironmentDetails = z.object({
1147
+ id: z.string(),
1148
+ name: z.string(),
1149
+ user: z.string().optional()
1150
+ });
1151
+ var RunScheduleDetails = z.object({
1152
+ id: z.string(),
1153
+ externalId: z.string().optional(),
1154
+ deduplicationKey: z.string().optional(),
1155
+ generator: ScheduleGenerator
1156
+ });
1157
+ var CommonRunFields = {
1107
1158
  id: z.string(),
1108
1159
  status: RunStatus,
1109
1160
  taskIdentifier: z.string(),
1110
1161
  idempotencyKey: z.string().optional(),
1111
1162
  version: z.string().optional(),
1163
+ isQueued: z.boolean(),
1164
+ isExecuting: z.boolean(),
1165
+ isCompleted: z.boolean(),
1166
+ isSuccess: z.boolean(),
1167
+ isFailed: z.boolean(),
1168
+ isCancelled: z.boolean(),
1169
+ isTest: z.boolean(),
1112
1170
  createdAt: z.coerce.date(),
1113
1171
  updatedAt: z.coerce.date(),
1172
+ startedAt: z.coerce.date().optional(),
1173
+ finishedAt: z.coerce.date().optional()
1174
+ };
1175
+ var RetrieveRunResponse = z.object({
1176
+ ...CommonRunFields,
1177
+ payload: z.any().optional(),
1178
+ output: z.any().optional(),
1179
+ schedule: RunScheduleDetails.optional(),
1114
1180
  attempts: z.array(z.object({
1115
1181
  id: z.string(),
1116
1182
  status: AttemptStatus,
1117
1183
  createdAt: z.coerce.date(),
1118
1184
  updatedAt: z.coerce.date(),
1119
1185
  startedAt: z.coerce.date().optional(),
1120
- completedAt: z.coerce.date().optional()
1186
+ completedAt: z.coerce.date().optional(),
1187
+ error: SerializedError.optional()
1121
1188
  }).optional())
1122
1189
  });
1190
+ var ListRunResponseItem = z.object({
1191
+ ...CommonRunFields,
1192
+ env: RunEnvironmentDetails
1193
+ });
1194
+ z.object({
1195
+ data: z.array(ListRunResponseItem),
1196
+ pagination: z.object({
1197
+ next: z.string().optional(),
1198
+ previous: z.string().optional()
1199
+ })
1200
+ });
1123
1201
  z.object({
1124
1202
  name: z.string(),
1125
1203
  value: z.string()
@@ -1143,10 +1221,10 @@ var EnvironmentVariable = z.object({
1143
1221
  });
1144
1222
  var EnvironmentVariables = z.array(EnvironmentVariable);
1145
1223
 
1146
- // src/v3/apiErrors.ts
1147
- var _APIError = class _APIError extends Error {
1224
+ // src/v3/apiClient/errors.ts
1225
+ var _ApiError = class _ApiError extends Error {
1148
1226
  constructor(status, error, message, headers) {
1149
- super(`${_APIError.makeMessage(status, error, message)}`);
1227
+ super(`${_ApiError.makeMessage(status, error, message)}`);
1150
1228
  this.status = status;
1151
1229
  this.headers = headers;
1152
1230
  const data = error;
@@ -1170,7 +1248,7 @@ var _APIError = class _APIError extends Error {
1170
1248
  }
1171
1249
  static generate(status, errorResponse, message, headers) {
1172
1250
  if (!status) {
1173
- return new APIConnectionError({
1251
+ return new ApiConnectionError({
1174
1252
  cause: castToError(errorResponse)
1175
1253
  });
1176
1254
  }
@@ -1199,12 +1277,12 @@ var _APIError = class _APIError extends Error {
1199
1277
  if (status >= 500) {
1200
1278
  return new InternalServerError(status, error, message, headers);
1201
1279
  }
1202
- return new _APIError(status, error, message, headers);
1280
+ return new _ApiError(status, error, message, headers);
1203
1281
  }
1204
1282
  };
1205
- __name(_APIError, "APIError");
1206
- var APIError = _APIError;
1207
- var _APIConnectionError = class _APIConnectionError extends APIError {
1283
+ __name(_ApiError, "ApiError");
1284
+ var ApiError = _ApiError;
1285
+ var _ApiConnectionError = class _ApiConnectionError extends ApiError {
1208
1286
  constructor({ message, cause }) {
1209
1287
  super(void 0, void 0, message || "Connection error.", void 0);
1210
1288
  __publicField(this, "status");
@@ -1212,9 +1290,9 @@ var _APIConnectionError = class _APIConnectionError extends APIError {
1212
1290
  this.cause = cause;
1213
1291
  }
1214
1292
  };
1215
- __name(_APIConnectionError, "APIConnectionError");
1216
- var APIConnectionError = _APIConnectionError;
1217
- var _BadRequestError = class _BadRequestError extends APIError {
1293
+ __name(_ApiConnectionError, "ApiConnectionError");
1294
+ var ApiConnectionError = _ApiConnectionError;
1295
+ var _BadRequestError = class _BadRequestError extends ApiError {
1218
1296
  constructor() {
1219
1297
  super(...arguments);
1220
1298
  __publicField(this, "status", 400);
@@ -1222,7 +1300,7 @@ var _BadRequestError = class _BadRequestError extends APIError {
1222
1300
  };
1223
1301
  __name(_BadRequestError, "BadRequestError");
1224
1302
  var BadRequestError = _BadRequestError;
1225
- var _AuthenticationError = class _AuthenticationError extends APIError {
1303
+ var _AuthenticationError = class _AuthenticationError extends ApiError {
1226
1304
  constructor() {
1227
1305
  super(...arguments);
1228
1306
  __publicField(this, "status", 401);
@@ -1230,7 +1308,7 @@ var _AuthenticationError = class _AuthenticationError extends APIError {
1230
1308
  };
1231
1309
  __name(_AuthenticationError, "AuthenticationError");
1232
1310
  var AuthenticationError = _AuthenticationError;
1233
- var _PermissionDeniedError = class _PermissionDeniedError extends APIError {
1311
+ var _PermissionDeniedError = class _PermissionDeniedError extends ApiError {
1234
1312
  constructor() {
1235
1313
  super(...arguments);
1236
1314
  __publicField(this, "status", 403);
@@ -1238,7 +1316,7 @@ var _PermissionDeniedError = class _PermissionDeniedError extends APIError {
1238
1316
  };
1239
1317
  __name(_PermissionDeniedError, "PermissionDeniedError");
1240
1318
  var PermissionDeniedError = _PermissionDeniedError;
1241
- var _NotFoundError = class _NotFoundError extends APIError {
1319
+ var _NotFoundError = class _NotFoundError extends ApiError {
1242
1320
  constructor() {
1243
1321
  super(...arguments);
1244
1322
  __publicField(this, "status", 404);
@@ -1246,7 +1324,7 @@ var _NotFoundError = class _NotFoundError extends APIError {
1246
1324
  };
1247
1325
  __name(_NotFoundError, "NotFoundError");
1248
1326
  var NotFoundError = _NotFoundError;
1249
- var _ConflictError = class _ConflictError extends APIError {
1327
+ var _ConflictError = class _ConflictError extends ApiError {
1250
1328
  constructor() {
1251
1329
  super(...arguments);
1252
1330
  __publicField(this, "status", 409);
@@ -1254,7 +1332,7 @@ var _ConflictError = class _ConflictError extends APIError {
1254
1332
  };
1255
1333
  __name(_ConflictError, "ConflictError");
1256
1334
  var ConflictError = _ConflictError;
1257
- var _UnprocessableEntityError = class _UnprocessableEntityError extends APIError {
1335
+ var _UnprocessableEntityError = class _UnprocessableEntityError extends ApiError {
1258
1336
  constructor() {
1259
1337
  super(...arguments);
1260
1338
  __publicField(this, "status", 422);
@@ -1262,7 +1340,7 @@ var _UnprocessableEntityError = class _UnprocessableEntityError extends APIError
1262
1340
  };
1263
1341
  __name(_UnprocessableEntityError, "UnprocessableEntityError");
1264
1342
  var UnprocessableEntityError = _UnprocessableEntityError;
1265
- var _RateLimitError = class _RateLimitError extends APIError {
1343
+ var _RateLimitError = class _RateLimitError extends ApiError {
1266
1344
  constructor() {
1267
1345
  super(...arguments);
1268
1346
  __publicField(this, "status", 429);
@@ -1270,7 +1348,7 @@ var _RateLimitError = class _RateLimitError extends APIError {
1270
1348
  };
1271
1349
  __name(_RateLimitError, "RateLimitError");
1272
1350
  var RateLimitError = _RateLimitError;
1273
- var _InternalServerError = class _InternalServerError extends APIError {
1351
+ var _InternalServerError = class _InternalServerError extends ApiError {
1274
1352
  };
1275
1353
  __name(_InternalServerError, "InternalServerError");
1276
1354
  var InternalServerError = _InternalServerError;
@@ -1303,6 +1381,108 @@ function calculateNextRetryDelay(options, attempt) {
1303
1381
  return Math.round(timeout);
1304
1382
  }
1305
1383
  __name(calculateNextRetryDelay, "calculateNextRetryDelay");
1384
+
1385
+ // src/v3/apiClient/pagination.ts
1386
+ var _CursorPage = class _CursorPage {
1387
+ constructor(data, pagination, pageFetcher) {
1388
+ this.pageFetcher = pageFetcher;
1389
+ this.data = data;
1390
+ this.pagination = pagination;
1391
+ }
1392
+ getPaginatedItems() {
1393
+ return this.data ?? [];
1394
+ }
1395
+ hasNextPage() {
1396
+ return !!this.pagination.next;
1397
+ }
1398
+ hasPreviousPage() {
1399
+ return !!this.pagination.previous;
1400
+ }
1401
+ getNextPage() {
1402
+ if (!this.pagination.next) {
1403
+ throw new Error("No next page available");
1404
+ }
1405
+ return this.pageFetcher({
1406
+ after: this.pagination.next
1407
+ });
1408
+ }
1409
+ getPreviousPage() {
1410
+ if (!this.pagination.previous) {
1411
+ throw new Error("No previous page available");
1412
+ }
1413
+ return this.pageFetcher({
1414
+ before: this.pagination.previous
1415
+ });
1416
+ }
1417
+ async *iterPages() {
1418
+ let page = this;
1419
+ yield page;
1420
+ while (page.hasNextPage()) {
1421
+ page = await page.getNextPage();
1422
+ yield page;
1423
+ }
1424
+ }
1425
+ async *[Symbol.asyncIterator]() {
1426
+ for await (const page of this.iterPages()) {
1427
+ for (const item of page.getPaginatedItems()) {
1428
+ yield item;
1429
+ }
1430
+ }
1431
+ }
1432
+ };
1433
+ __name(_CursorPage, "CursorPage");
1434
+ var CursorPage = _CursorPage;
1435
+ var _OffsetLimitPage = class _OffsetLimitPage {
1436
+ constructor(data, pagination, pageFetcher) {
1437
+ this.pageFetcher = pageFetcher;
1438
+ this.data = data;
1439
+ this.pagination = pagination;
1440
+ }
1441
+ getPaginatedItems() {
1442
+ return this.data ?? [];
1443
+ }
1444
+ hasNextPage() {
1445
+ return this.pagination.currentPage < this.pagination.totalPages;
1446
+ }
1447
+ hasPreviousPage() {
1448
+ return this.pagination.currentPage > 1;
1449
+ }
1450
+ getNextPage() {
1451
+ if (!this.hasNextPage()) {
1452
+ throw new Error("No next page available");
1453
+ }
1454
+ return this.pageFetcher({
1455
+ page: this.pagination.currentPage + 1
1456
+ });
1457
+ }
1458
+ getPreviousPage() {
1459
+ if (!this.hasPreviousPage()) {
1460
+ throw new Error("No previous page available");
1461
+ }
1462
+ return this.pageFetcher({
1463
+ page: this.pagination.currentPage - 1
1464
+ });
1465
+ }
1466
+ async *iterPages() {
1467
+ let page = this;
1468
+ yield page;
1469
+ while (page.hasNextPage()) {
1470
+ page = await page.getNextPage();
1471
+ yield page;
1472
+ }
1473
+ }
1474
+ async *[Symbol.asyncIterator]() {
1475
+ for await (const page of this.iterPages()) {
1476
+ for (const item of page.getPaginatedItems()) {
1477
+ yield item;
1478
+ }
1479
+ }
1480
+ }
1481
+ };
1482
+ __name(_OffsetLimitPage, "OffsetLimitPage");
1483
+ var OffsetLimitPage = _OffsetLimitPage;
1484
+
1485
+ // src/v3/apiClient/core.ts
1306
1486
  var defaultRetryOptions2 = {
1307
1487
  maxAttempts: 3,
1308
1488
  factor: 2,
@@ -1310,11 +1490,62 @@ var defaultRetryOptions2 = {
1310
1490
  maxTimeoutInMs: 6e4,
1311
1491
  randomize: false
1312
1492
  };
1313
- async function zodfetch(schema, url, requestInit, options) {
1314
- return await _doZodFetch(schema, url, requestInit, options);
1493
+ function zodfetch(schema, url, requestInit, options) {
1494
+ return new ApiPromise(_doZodFetch(schema, url, requestInit, options));
1315
1495
  }
1316
1496
  __name(zodfetch, "zodfetch");
1317
- async function zodupload(schema, url, body, requestInit, options) {
1497
+ function zodfetchCursorPage(schema, url, params, requestInit, options) {
1498
+ const query = new URLSearchParams(params.query);
1499
+ if (params.limit) {
1500
+ query.set("page[size]", String(params.limit));
1501
+ }
1502
+ if (params.after) {
1503
+ query.set("page[after]", params.after);
1504
+ }
1505
+ if (params.before) {
1506
+ query.set("page[before]", params.before);
1507
+ }
1508
+ const cursorPageSchema = z.object({
1509
+ data: z.array(schema),
1510
+ pagination: z.object({
1511
+ next: z.string().optional(),
1512
+ previous: z.string().optional()
1513
+ })
1514
+ });
1515
+ const $url = new URL(url);
1516
+ $url.search = query.toString();
1517
+ const fetchResult = _doZodFetch(cursorPageSchema, $url.href, requestInit, options);
1518
+ return new CursorPagePromise(fetchResult, schema, url, params, requestInit, options);
1519
+ }
1520
+ __name(zodfetchCursorPage, "zodfetchCursorPage");
1521
+ function zodfetchOffsetLimitPage(schema, url, params, requestInit, options) {
1522
+ const query = new URLSearchParams(params.query);
1523
+ if (params.limit) {
1524
+ query.set("perPage", String(params.limit));
1525
+ }
1526
+ if (params.page) {
1527
+ query.set("page", String(params.page));
1528
+ }
1529
+ const offsetLimitPageSchema = z.object({
1530
+ data: z.array(schema),
1531
+ pagination: z.object({
1532
+ currentPage: z.coerce.number(),
1533
+ totalPages: z.coerce.number(),
1534
+ count: z.coerce.number()
1535
+ })
1536
+ });
1537
+ const $url = new URL(url);
1538
+ $url.search = query.toString();
1539
+ const fetchResult = _doZodFetch(offsetLimitPageSchema, $url.href, requestInit, options);
1540
+ return new OffsetLimitPagePromise(fetchResult, schema, url, params, requestInit, options);
1541
+ }
1542
+ __name(zodfetchOffsetLimitPage, "zodfetchOffsetLimitPage");
1543
+ function zodupload(schema, url, body, requestInit, options) {
1544
+ const finalRequestInit = createMultipartFormRequestInit(body, requestInit);
1545
+ return new ApiPromise(_doZodFetch(schema, url, finalRequestInit, options));
1546
+ }
1547
+ __name(zodupload, "zodupload");
1548
+ async function createMultipartFormRequestInit(body, requestInit) {
1318
1549
  const form = await createForm(body);
1319
1550
  const encoder = new FormDataEncoder(form);
1320
1551
  const finalHeaders = {};
@@ -1332,9 +1563,9 @@ async function zodupload(schema, url, body, requestInit, options) {
1332
1563
  // @ts-expect-error
1333
1564
  duplex: "half"
1334
1565
  };
1335
- return await _doZodFetch(schema, url, finalRequestInit, options);
1566
+ return finalRequestInit;
1336
1567
  }
1337
- __name(zodupload, "zodupload");
1568
+ __name(createMultipartFormRequestInit, "createMultipartFormRequestInit");
1338
1569
  var createForm = /* @__PURE__ */ __name(async (body) => {
1339
1570
  const form = new FormData();
1340
1571
  await Promise.all(Object.entries(body || {}).map(([key, value]) => addFormValue(form, key, value)));
@@ -1342,7 +1573,8 @@ var createForm = /* @__PURE__ */ __name(async (body) => {
1342
1573
  }, "createForm");
1343
1574
  async function _doZodFetch(schema, url, requestInit, options, attempt = 1) {
1344
1575
  try {
1345
- const response = await fetch(url, requestInitWithCache(requestInit));
1576
+ const $requestInit = await requestInit;
1577
+ const response = await fetch(url, requestInitWithCache($requestInit));
1346
1578
  const responseHeaders = createResponseHeaders(response.headers);
1347
1579
  if (!response.ok) {
1348
1580
  const retryResult = shouldRetry(response, attempt, options?.retry);
@@ -1353,17 +1585,20 @@ async function _doZodFetch(schema, url, requestInit, options, attempt = 1) {
1353
1585
  const errText = await response.text().catch((e) => castToError2(e).message);
1354
1586
  const errJSON = safeJsonParse(errText);
1355
1587
  const errMessage = errJSON ? void 0 : errText;
1356
- throw APIError.generate(response.status, errJSON, errMessage, responseHeaders);
1588
+ throw ApiError.generate(response.status, errJSON, errMessage, responseHeaders);
1357
1589
  }
1358
1590
  }
1359
1591
  const jsonBody = await response.json();
1360
1592
  const parsedResult = schema.safeParse(jsonBody);
1361
1593
  if (parsedResult.success) {
1362
- return parsedResult.data;
1594
+ return {
1595
+ data: parsedResult.data,
1596
+ response
1597
+ };
1363
1598
  }
1364
1599
  throw fromZodError(parsedResult.error);
1365
1600
  } catch (error) {
1366
- if (error instanceof APIError) {
1601
+ if (error instanceof ApiError) {
1367
1602
  throw error;
1368
1603
  }
1369
1604
  if (options?.retry) {
@@ -1377,7 +1612,7 @@ async function _doZodFetch(schema, url, requestInit, options, attempt = 1) {
1377
1612
  return await _doZodFetch(schema, url, requestInit, options, attempt + 1);
1378
1613
  }
1379
1614
  }
1380
- throw new APIConnectionError({
1615
+ throw new ApiConnectionError({
1381
1616
  cause: castToError2(error)
1382
1617
  });
1383
1618
  }
@@ -1550,6 +1785,128 @@ var isUploadable = /* @__PURE__ */ __name((value) => {
1550
1785
  return isFileLike(value) || isResponseLike(value) || isFsReadStream(value);
1551
1786
  }, "isUploadable");
1552
1787
  var isRecordLike = /* @__PURE__ */ __name((value) => value != null && typeof value === "object" && !Array.isArray(value) && Object.keys(value).length > 0 && Object.keys(value).every((key) => typeof key === "string" && typeof value[key] === "string"), "isRecordLike");
1788
+ var _ApiPromise = class _ApiPromise extends Promise {
1789
+ constructor(responsePromise) {
1790
+ super((resolve) => {
1791
+ resolve(null);
1792
+ });
1793
+ this.responsePromise = responsePromise;
1794
+ }
1795
+ /**
1796
+ * Gets the raw `Response` instance instead of parsing the response
1797
+ * data.
1798
+ *
1799
+ * If you want to parse the response body but still get the `Response`
1800
+ * instance, you can use {@link withResponse()}.
1801
+ */
1802
+ asResponse() {
1803
+ return this.responsePromise.then((p) => p.response);
1804
+ }
1805
+ /**
1806
+ * Gets the parsed response data and the raw `Response` instance.
1807
+ *
1808
+ * If you just want to get the raw `Response` instance without parsing it,
1809
+ * you can use {@link asResponse()}.
1810
+ */
1811
+ async withResponse() {
1812
+ const [data, response] = await Promise.all([
1813
+ this.parse(),
1814
+ this.asResponse()
1815
+ ]);
1816
+ return {
1817
+ data,
1818
+ response
1819
+ };
1820
+ }
1821
+ parse() {
1822
+ return this.responsePromise.then((result) => result.data);
1823
+ }
1824
+ then(onfulfilled, onrejected) {
1825
+ return this.parse().then(onfulfilled, onrejected);
1826
+ }
1827
+ catch(onrejected) {
1828
+ return this.parse().catch(onrejected);
1829
+ }
1830
+ finally(onfinally) {
1831
+ return this.parse().finally(onfinally);
1832
+ }
1833
+ };
1834
+ __name(_ApiPromise, "ApiPromise");
1835
+ var ApiPromise = _ApiPromise;
1836
+ var _fetchPage, fetchPage_fn;
1837
+ var _CursorPagePromise = class _CursorPagePromise extends ApiPromise {
1838
+ constructor(result, schema, url, params, requestInit, options) {
1839
+ super(result.then((result2) => ({
1840
+ data: new CursorPage(result2.data.data, result2.data.pagination, __privateMethod(this, _fetchPage, fetchPage_fn).bind(this)),
1841
+ response: result2.response
1842
+ })));
1843
+ __privateAdd(this, _fetchPage);
1844
+ this.schema = schema;
1845
+ this.url = url;
1846
+ this.params = params;
1847
+ this.requestInit = requestInit;
1848
+ this.options = options;
1849
+ }
1850
+ /**
1851
+ * Allow auto-paginating iteration on an unawaited list call, eg:
1852
+ *
1853
+ * for await (const item of client.items.list()) {
1854
+ * console.log(item)
1855
+ * }
1856
+ */
1857
+ async *[Symbol.asyncIterator]() {
1858
+ const page = await this;
1859
+ for await (const item of page) {
1860
+ yield item;
1861
+ }
1862
+ }
1863
+ };
1864
+ _fetchPage = new WeakSet();
1865
+ fetchPage_fn = /* @__PURE__ */ __name(function(params) {
1866
+ return zodfetchCursorPage(this.schema, this.url, {
1867
+ ...this.params,
1868
+ ...params
1869
+ }, this.requestInit, this.options);
1870
+ }, "#fetchPage");
1871
+ __name(_CursorPagePromise, "CursorPagePromise");
1872
+ var CursorPagePromise = _CursorPagePromise;
1873
+ var _fetchPage2, fetchPage_fn2;
1874
+ var _OffsetLimitPagePromise = class _OffsetLimitPagePromise extends ApiPromise {
1875
+ constructor(result, schema, url, params, requestInit, options) {
1876
+ super(result.then((result2) => ({
1877
+ data: new OffsetLimitPage(result2.data.data, result2.data.pagination, __privateMethod(this, _fetchPage2, fetchPage_fn2).bind(this)),
1878
+ response: result2.response
1879
+ })));
1880
+ __privateAdd(this, _fetchPage2);
1881
+ this.schema = schema;
1882
+ this.url = url;
1883
+ this.params = params;
1884
+ this.requestInit = requestInit;
1885
+ this.options = options;
1886
+ }
1887
+ /**
1888
+ * Allow auto-paginating iteration on an unawaited list call, eg:
1889
+ *
1890
+ * for await (const item of client.items.list()) {
1891
+ * console.log(item)
1892
+ * }
1893
+ */
1894
+ async *[Symbol.asyncIterator]() {
1895
+ const page = await this;
1896
+ for await (const item of page) {
1897
+ yield item;
1898
+ }
1899
+ }
1900
+ };
1901
+ _fetchPage2 = new WeakSet();
1902
+ fetchPage_fn2 = /* @__PURE__ */ __name(function(params1) {
1903
+ return zodfetchOffsetLimitPage(this.schema, this.url, {
1904
+ ...this.params,
1905
+ ...params1
1906
+ }, this.requestInit, this.options);
1907
+ }, "#fetchPage");
1908
+ __name(_OffsetLimitPagePromise, "OffsetLimitPagePromise");
1909
+ var OffsetLimitPagePromise = _OffsetLimitPagePromise;
1553
1910
 
1554
1911
  // src/v3/apiClient/index.ts
1555
1912
  var zodFetchOptions = {
@@ -1575,7 +1932,7 @@ var _ApiClient = class _ApiClient {
1575
1932
  headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1576
1933
  }, zodFetchOptions);
1577
1934
  } catch (error) {
1578
- if (error instanceof APIError) {
1935
+ if (error instanceof ApiError) {
1579
1936
  if (error.status === 404) {
1580
1937
  return void 0;
1581
1938
  }
@@ -1590,14 +1947,16 @@ var _ApiClient = class _ApiClient {
1590
1947
  }, zodFetchOptions);
1591
1948
  }
1592
1949
  triggerTask(taskId, body, options) {
1593
- return zodfetch(TriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${taskId}/trigger`, {
1950
+ const encodedTaskId = encodeURIComponent(taskId);
1951
+ return zodfetch(TriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${encodedTaskId}/trigger`, {
1594
1952
  method: "POST",
1595
1953
  headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, options?.spanParentAsLink ?? false),
1596
1954
  body: JSON.stringify(body)
1597
1955
  }, zodFetchOptions);
1598
1956
  }
1599
1957
  batchTriggerTask(taskId, body, options) {
1600
- return zodfetch(BatchTriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${taskId}/batch`, {
1958
+ const encodedTaskId = encodeURIComponent(taskId);
1959
+ return zodfetch(BatchTriggerTaskResponse, `${this.baseUrl}/api/v1/tasks/${encodedTaskId}/batch`, {
1601
1960
  method: "POST",
1602
1961
  headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, options?.spanParentAsLink ?? false),
1603
1962
  body: JSON.stringify(body)
@@ -1621,6 +1980,33 @@ var _ApiClient = class _ApiClient {
1621
1980
  headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1622
1981
  }, zodFetchOptions);
1623
1982
  }
1983
+ listRuns(query) {
1984
+ const searchParams = createSearchQueryForListRuns(query);
1985
+ return zodfetchCursorPage(ListRunResponseItem, `${this.baseUrl}/api/v1/runs`, {
1986
+ query: searchParams,
1987
+ limit: query?.limit,
1988
+ after: query?.after,
1989
+ before: query?.before
1990
+ }, {
1991
+ method: "GET",
1992
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1993
+ }, zodFetchOptions);
1994
+ }
1995
+ listProjectRuns(projectRef, query) {
1996
+ const searchParams = createSearchQueryForListRuns(query);
1997
+ if (query?.env) {
1998
+ searchParams.append("filter[env]", Array.isArray(query.env) ? query.env.join(",") : query.env);
1999
+ }
2000
+ return zodfetchCursorPage(ListRunResponseItem, `${this.baseUrl}/api/v1/projects/${projectRef}/runs`, {
2001
+ query: searchParams,
2002
+ limit: query?.limit,
2003
+ after: query?.after,
2004
+ before: query?.before
2005
+ }, {
2006
+ method: "GET",
2007
+ headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
2008
+ }, zodFetchOptions);
2009
+ }
1624
2010
  replayRun(runId) {
1625
2011
  return zodfetch(ReplayRunResponse, `${this.baseUrl}/api/v1/runs/${runId}/replay`, {
1626
2012
  method: "POST",
@@ -1648,7 +2034,10 @@ var _ApiClient = class _ApiClient {
1648
2034
  if (options?.perPage) {
1649
2035
  searchParams.append("perPage", options.perPage.toString());
1650
2036
  }
1651
- return zodfetch(ListSchedulesResult, `${this.baseUrl}/api/v1/schedules${searchParams.size > 0 ? `?${searchParams}` : ""}`, {
2037
+ return zodfetchOffsetLimitPage(ScheduleObject, `${this.baseUrl}/api/v1/schedules`, {
2038
+ page: options?.page,
2039
+ limit: options?.perPage
2040
+ }, {
1652
2041
  method: "GET",
1653
2042
  headers: __privateMethod(this, _getHeaders, getHeaders_fn).call(this, false)
1654
2043
  });
@@ -1749,6 +2138,40 @@ getHeaders_fn = /* @__PURE__ */ __name(function(spanParentAsLink) {
1749
2138
  }, "#getHeaders");
1750
2139
  __name(_ApiClient, "ApiClient");
1751
2140
  var ApiClient = _ApiClient;
2141
+ function createSearchQueryForListRuns(query) {
2142
+ const searchParams = new URLSearchParams();
2143
+ if (query) {
2144
+ if (query.status) {
2145
+ searchParams.append("filter[status]", Array.isArray(query.status) ? query.status.join(",") : query.status);
2146
+ }
2147
+ if (query.taskIdentifier) {
2148
+ searchParams.append("filter[taskIdentifier]", Array.isArray(query.taskIdentifier) ? query.taskIdentifier.join(",") : query.taskIdentifier);
2149
+ }
2150
+ if (query.version) {
2151
+ searchParams.append("filter[version]", Array.isArray(query.version) ? query.version.join(",") : query.version);
2152
+ }
2153
+ if (query.bulkAction) {
2154
+ searchParams.append("filter[bulkAction]", query.bulkAction);
2155
+ }
2156
+ if (query.schedule) {
2157
+ searchParams.append("filter[schedule]", query.schedule);
2158
+ }
2159
+ if (typeof query.isTest === "boolean") {
2160
+ searchParams.append("filter[isTest]", String(query.isTest));
2161
+ }
2162
+ if (query.from) {
2163
+ searchParams.append("filter[createdAt][from]", query.from instanceof Date ? query.from.getTime().toString() : query.from.toString());
2164
+ }
2165
+ if (query.to) {
2166
+ searchParams.append("filter[createdAt][to]", query.to instanceof Date ? query.to.getTime().toString() : query.to.toString());
2167
+ }
2168
+ if (query.period) {
2169
+ searchParams.append("filter[createdAt][period]", query.period);
2170
+ }
2171
+ }
2172
+ return searchParams;
2173
+ }
2174
+ __name(createSearchQueryForListRuns, "createSearchQueryForListRuns");
1752
2175
 
1753
2176
  // src/v3/apiClientManager/index.ts
1754
2177
  var API_NAME2 = "api-client";