@alpic-ai/api 0.0.0-staging.fc9821d → 0.0.0-staging.fee97f5

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.
package/dist/index.d.mts CHANGED
@@ -6,8 +6,16 @@ import { z } from "zod";
6
6
  type ApiContext = {
7
7
  request: Request & {
8
8
  teamIds: string[];
9
+ defaultTeamId: string | undefined;
10
+ awsCognitoUserSub: string | undefined;
9
11
  };
10
12
  };
13
+ declare const deploymentStatusSchema: z.ZodEnum<{
14
+ ongoing: "ongoing";
15
+ deployed: "deployed";
16
+ failed: "failed";
17
+ canceled: "canceled";
18
+ }>;
11
19
  declare const createEnvironmentContractV1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
12
20
  projectId: z.ZodString;
13
21
  name: z.ZodString;
@@ -36,7 +44,6 @@ declare const contract: {
36
44
  name: z.ZodString;
37
45
  createdAt: z.ZodCoercedDate<unknown>;
38
46
  hasStripeAccount: z.ZodBoolean;
39
- hasActiveSubscription: z.ZodBoolean;
40
47
  }, z.core.$strip>>, Record<never, never>, Record<never, never>>;
41
48
  };
42
49
  };
@@ -95,6 +102,13 @@ declare const contract: {
95
102
  list: {
96
103
  v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
97
104
  projectId: z.ZodString;
105
+ status: z.ZodOptional<z.ZodArray<z.ZodEnum<{
106
+ ongoing: "ongoing";
107
+ deployed: "deployed";
108
+ failed: "failed";
109
+ canceled: "canceled";
110
+ }>>>;
111
+ environmentId: z.ZodOptional<z.ZodString>;
98
112
  }, z.core.$strip>, z.ZodArray<z.ZodObject<{
99
113
  id: z.ZodString;
100
114
  status: z.ZodEnum<{
@@ -110,8 +124,10 @@ declare const contract: {
110
124
  authorAvatarUrl: z.ZodNullable<z.ZodString>;
111
125
  startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
112
126
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
113
- isCurrent: z.ZodBoolean;
114
127
  environmentId: z.ZodString;
128
+ environmentName: z.ZodString;
129
+ isCurrent: z.ZodBoolean;
130
+ deploymentPageUrl: z.ZodNullable<z.ZodURL>;
115
131
  }, z.core.$strip>>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
116
132
  NOT_FOUND: {};
117
133
  }>, Record<never, never>>;
@@ -134,6 +150,9 @@ declare const contract: {
134
150
  authorAvatarUrl: z.ZodNullable<z.ZodString>;
135
151
  startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
136
152
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
153
+ environmentId: z.ZodString;
154
+ environmentName: z.ZodString;
155
+ isCurrent: z.ZodBoolean;
137
156
  deploymentPageUrl: z.ZodNullable<z.ZodURL>;
138
157
  }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
139
158
  NOT_FOUND: {};
@@ -219,12 +238,103 @@ declare const contract: {
219
238
  authorAvatarUrl: z.ZodNullable<z.ZodString>;
220
239
  startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
221
240
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
241
+ environmentId: z.ZodString;
242
+ environmentName: z.ZodString;
243
+ isCurrent: z.ZodBoolean;
222
244
  deploymentPageUrl: z.ZodNullable<z.ZodURL>;
223
245
  }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
224
246
  NOT_FOUND: {};
225
247
  BAD_REQUEST: {};
226
248
  }>, Record<never, never>>;
227
249
  };
250
+ getLogs: {
251
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
252
+ environmentId: z.ZodString;
253
+ since: z.ZodOptional<z.ZodString>;
254
+ until: z.ZodOptional<z.ZodString>;
255
+ limit: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
256
+ level: z.ZodOptional<z.ZodArray<z.ZodEnum<{
257
+ INFO: "INFO";
258
+ ERROR: "ERROR";
259
+ WARNING: "WARNING";
260
+ DEBUG: "DEBUG";
261
+ }>>>;
262
+ search: z.ZodOptional<z.ZodString>;
263
+ nextToken: z.ZodOptional<z.ZodString>;
264
+ }, z.core.$strip>, z.ZodObject<{
265
+ logs: z.ZodArray<z.ZodObject<{
266
+ timestamp: z.ZodCoercedDate<unknown>;
267
+ type: z.ZodEnum<{
268
+ INFO: "INFO";
269
+ ERROR: "ERROR";
270
+ WARNING: "WARNING";
271
+ DEBUG: "DEBUG";
272
+ START: "START";
273
+ END: "END";
274
+ }>;
275
+ requestId: z.ZodString;
276
+ content: z.ZodOptional<z.ZodString>;
277
+ method: z.ZodOptional<z.ZodString>;
278
+ durationInMs: z.ZodOptional<z.ZodNumber>;
279
+ }, z.core.$strip>>;
280
+ nextToken: z.ZodNullable<z.ZodString>;
281
+ }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
282
+ NOT_FOUND: {};
283
+ BAD_REQUEST: {};
284
+ }>, Record<never, never>>;
285
+ };
286
+ };
287
+ environmentVariables: {
288
+ list: {
289
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
290
+ environmentId: z.ZodString;
291
+ }, z.core.$strip>, z.ZodArray<z.ZodObject<{
292
+ id: z.ZodString;
293
+ key: z.ZodString;
294
+ value: z.ZodString;
295
+ isSecret: z.ZodBoolean;
296
+ createdAt: z.ZodCoercedDate<unknown>;
297
+ }, z.core.$strip>>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
298
+ NOT_FOUND: {};
299
+ }>, Record<never, never>>;
300
+ };
301
+ create: {
302
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
303
+ environmentId: z.ZodString;
304
+ environmentVariables: z.ZodArray<z.ZodObject<{
305
+ key: z.ZodString;
306
+ value: z.ZodString;
307
+ isSecret: z.ZodDefault<z.ZodBoolean>;
308
+ }, z.core.$strip>>;
309
+ }, z.core.$strip>, z.ZodObject<{
310
+ success: z.ZodLiteral<true>;
311
+ }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
312
+ NOT_FOUND: {};
313
+ BAD_REQUEST: {};
314
+ }>, Record<never, never>>;
315
+ };
316
+ update: {
317
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
318
+ environmentVariableId: z.ZodString;
319
+ key: z.ZodString;
320
+ value: z.ZodOptional<z.ZodString>;
321
+ isSecret: z.ZodDefault<z.ZodBoolean>;
322
+ }, z.core.$strip>, z.ZodObject<{
323
+ success: z.ZodLiteral<true>;
324
+ }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
325
+ NOT_FOUND: {};
326
+ BAD_REQUEST: {};
327
+ }>, Record<never, never>>;
328
+ };
329
+ delete: {
330
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
331
+ environmentVariableId: z.ZodString;
332
+ }, z.core.$strip>, z.ZodObject<{
333
+ success: z.ZodLiteral<true>;
334
+ }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
335
+ NOT_FOUND: {};
336
+ }>, Record<never, never>>;
337
+ };
228
338
  };
229
339
  projects: {
230
340
  update: {
@@ -258,6 +368,15 @@ declare const contract: {
258
368
  id: z.ZodString;
259
369
  name: z.ZodString;
260
370
  mcpServerUrl: z.ZodString;
371
+ domains: z.ZodArray<z.ZodObject<{
372
+ domain: z.ZodString;
373
+ status: z.ZodEnum<{
374
+ ongoing: "ongoing";
375
+ deployed: "deployed";
376
+ failed: "failed";
377
+ }>;
378
+ createdAt: z.ZodCoercedDate<unknown>;
379
+ }, z.core.$strip>>;
261
380
  latestDeployment: z.ZodNullable<z.ZodObject<{
262
381
  id: z.ZodString;
263
382
  status: z.ZodEnum<{
@@ -325,6 +444,15 @@ declare const contract: {
325
444
  id: z.ZodString;
326
445
  name: z.ZodString;
327
446
  mcpServerUrl: z.ZodString;
447
+ domains: z.ZodArray<z.ZodObject<{
448
+ domain: z.ZodString;
449
+ status: z.ZodEnum<{
450
+ ongoing: "ongoing";
451
+ deployed: "deployed";
452
+ failed: "failed";
453
+ }>;
454
+ createdAt: z.ZodCoercedDate<unknown>;
455
+ }, z.core.$strip>>;
328
456
  latestDeployment: z.ZodNullable<z.ZodObject<{
329
457
  id: z.ZodString;
330
458
  status: z.ZodEnum<{
@@ -363,7 +491,9 @@ declare const contract: {
363
491
  }>, Record<never, never>>;
364
492
  };
365
493
  list: {
366
- v1: _orpc_contract0.ContractProcedureBuilderWithOutput<_orpc_contract0.Schema<unknown, unknown>, z.ZodArray<z.ZodObject<{
494
+ v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
495
+ teamId: z.ZodOptional<z.ZodString>;
496
+ }, z.core.$strip>>, z.ZodArray<z.ZodObject<{
367
497
  id: z.ZodString;
368
498
  name: z.ZodString;
369
499
  teamId: z.ZodString;
@@ -389,6 +519,15 @@ declare const contract: {
389
519
  id: z.ZodString;
390
520
  name: z.ZodString;
391
521
  mcpServerUrl: z.ZodString;
522
+ domains: z.ZodArray<z.ZodObject<{
523
+ domain: z.ZodString;
524
+ status: z.ZodEnum<{
525
+ ongoing: "ongoing";
526
+ deployed: "deployed";
527
+ failed: "failed";
528
+ }>;
529
+ createdAt: z.ZodCoercedDate<unknown>;
530
+ }, z.core.$strip>>;
392
531
  latestDeployment: z.ZodNullable<z.ZodObject<{
393
532
  id: z.ZodString;
394
533
  status: z.ZodEnum<{
@@ -498,6 +637,15 @@ declare const contract: {
498
637
  }>, Record<never, never>>;
499
638
  };
500
639
  };
640
+ tunnels: {
641
+ getTicket: {
642
+ v1: _orpc_contract0.ContractProcedureBuilderWithOutput<_orpc_contract0.Schema<unknown, unknown>, z.ZodObject<{
643
+ subdomain: z.ZodString;
644
+ ticket: z.ZodString;
645
+ tunnelHost: z.ZodString;
646
+ }, z.core.$strip>, Record<never, never>, Record<never, never>>;
647
+ };
648
+ };
501
649
  };
502
650
  type RouterInput = InferContractRouterInputs<typeof contract>;
503
651
  type RouterOutput = InferContractRouterOutputs<typeof contract>;
@@ -533,4 +681,4 @@ declare const transportSchema: z.ZodEnum<{
533
681
  }>;
534
682
  type Transport = z.infer<typeof transportSchema>;
535
683
  //#endregion
536
- export { ApiContext, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
684
+ export { ApiContext, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
package/dist/index.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  import { oc } from "@orpc/contract";
2
+ import ms from "ms";
2
3
  import { z } from "zod";
3
-
4
4
  //#region src/schemas.ts
5
5
  const RESERVED_KEYS = [
6
6
  "_HANDLER",
@@ -13,7 +13,11 @@ const RESERVED_KEYS = [
13
13
  "AWS_LAMBDA_FUNCTION_VERSION",
14
14
  "AWS_LAMBDA_INITIALIZATION_TYPE",
15
15
  "AWS_LAMBDA_LOG_GROUP_NAME",
16
+ "AWS_LAMBDA_LOG_STREAM_NAME",
16
17
  "AWS_ACCESS_KEY",
18
+ "AWS_ACCESS_KEY_ID",
19
+ "AWS_SECRET_ACCESS_KEY",
20
+ "AWS_SESSION_TOKEN",
17
21
  "AWS_LAMBDA_RUNTIME_API",
18
22
  "LAMBDA_TASK_ROOT",
19
23
  "LAMBDA_RUNTIME_DIR",
@@ -30,7 +34,8 @@ const RESERVED_KEYS = [
30
34
  "BUILD_ARG_BUILD_COMMAND",
31
35
  "BUILD_ARG_BUILD_OUTPUT_DIR",
32
36
  "BUILD_ARG_START_COMMAND",
33
- "ALPIC_HOST"
37
+ "ALPIC_HOST",
38
+ "ALPIC_CUSTOM_DOMAINS"
34
39
  ];
35
40
  const environmentVariableSchema = z.object({
36
41
  key: z.string().min(2, "Key must be at least 2 characters").regex(/^[a-zA-Z]([a-zA-Z0-9_])+$/, "Key must start with a letter and contain only letters, numbers, and underscores").refine((key) => !RESERVED_KEYS.includes(key), "This key is reserved and cannot be used as an environment variable key"),
@@ -55,7 +60,6 @@ const transportSchema = z.enum([
55
60
  "sse",
56
61
  "streamablehttp"
57
62
  ]);
58
-
59
63
  //#endregion
60
64
  //#region src/api.contract.ts
61
65
  const deploymentStatusSchema = z.enum([
@@ -80,9 +84,16 @@ const deploymentSchema = z.object({
80
84
  authorUsername: z.string().nullable(),
81
85
  authorAvatarUrl: z.string().nullable(),
82
86
  startedAt: z.coerce.date().nullable(),
83
- completedAt: z.coerce.date().nullable()
87
+ completedAt: z.coerce.date().nullable(),
88
+ environmentId: z.string(),
89
+ environmentName: z.string(),
90
+ isCurrent: z.boolean(),
91
+ deploymentPageUrl: z.url().nullable()
84
92
  });
85
- const deploymentWithPageUrlSchema = deploymentSchema.extend({ deploymentPageUrl: z.url().nullable() });
93
+ const isValidLogTimeInput = (value) => {
94
+ if (ms(value) !== void 0) return true;
95
+ return !Number.isNaN(new Date(value).getTime());
96
+ };
86
97
  const createEnvironmentContractV1 = oc.route({
87
98
  path: "/v1/environments",
88
99
  method: "POST",
@@ -122,10 +133,20 @@ const getEnvironmentContractV1 = oc.route({
122
133
  createdAt: z.coerce.date(),
123
134
  projectId: z.string()
124
135
  }));
136
+ const domainSchema = z.object({
137
+ domain: z.string(),
138
+ status: z.enum([
139
+ "ongoing",
140
+ "deployed",
141
+ "failed"
142
+ ]),
143
+ createdAt: z.coerce.date()
144
+ });
125
145
  const productionEnvironmentSchema = z.object({
126
146
  id: z.string(),
127
147
  name: z.string(),
128
148
  mcpServerUrl: z.string(),
149
+ domains: z.array(domainSchema),
129
150
  latestDeployment: latestDeploymentSchema.nullable()
130
151
  });
131
152
  const environmentSchema = z.object({
@@ -168,7 +189,7 @@ const listProjectsContractV1 = oc.route({
168
189
  description: "List all projects for a team",
169
190
  tags: ["projects"],
170
191
  successDescription: "The list of projects"
171
- }).output(z.array(projectOutputSchema));
192
+ }).input(z.object({ teamId: z.string().optional() }).optional()).output(z.array(projectOutputSchema));
172
193
  const createProjectContractV1 = oc.route({
173
194
  path: "/v1/projects",
174
195
  method: "POST",
@@ -181,7 +202,7 @@ const createProjectContractV1 = oc.route({
181
202
  BAD_REQUEST: {}
182
203
  }).input(z.object({
183
204
  teamId: z.string().optional(),
184
- name: z.string().min(1).max(100),
205
+ name: z.string().trim().min(1).max(100),
185
206
  sourceRepository: z.string().optional(),
186
207
  branchName: z.string().min(1).optional(),
187
208
  runtime: runtimeSchema,
@@ -211,6 +232,59 @@ const createProjectContractV1 = oc.route({
211
232
  startCommand: z.string().nullable(),
212
233
  createdAt: z.coerce.date()
213
234
  }));
235
+ const environmentVariableOutputSchema = z.object({
236
+ id: z.string(),
237
+ key: z.string(),
238
+ value: z.string(),
239
+ isSecret: z.boolean(),
240
+ createdAt: z.coerce.date()
241
+ });
242
+ const listEnvironmentVariablesContractV1 = oc.route({
243
+ path: "/v1/environments/{environmentId}/environment-variables",
244
+ method: "GET",
245
+ summary: "List environment variables",
246
+ description: "List all environment variables for an environment",
247
+ tags: ["environments"],
248
+ successDescription: "The list of environment variables"
249
+ }).errors({ NOT_FOUND: {} }).input(z.object({ environmentId: z.string().describe("The ID of the environment") })).output(z.array(environmentVariableOutputSchema));
250
+ const createEnvironmentVariablesContractV1 = oc.route({
251
+ path: "/v1/environments/{environmentId}/environment-variables",
252
+ method: "POST",
253
+ summary: "Add environment variables",
254
+ description: "Add one or more environment variables to an environment",
255
+ tags: ["environments"],
256
+ successDescription: "The environment variables have been added successfully"
257
+ }).errors({
258
+ NOT_FOUND: {},
259
+ BAD_REQUEST: {}
260
+ }).input(z.object({
261
+ environmentId: z.string().describe("The ID of the environment"),
262
+ environmentVariables: environmentVariablesSchema
263
+ })).output(z.object({ success: z.literal(true) }));
264
+ const updateEnvironmentVariableContractV1 = oc.route({
265
+ path: "/v1/environment-variables/{environmentVariableId}",
266
+ method: "PATCH",
267
+ summary: "Update an environment variable",
268
+ description: "Update an environment variable by ID",
269
+ tags: ["environments"],
270
+ successDescription: "The environment variable has been updated successfully"
271
+ }).errors({
272
+ NOT_FOUND: {},
273
+ BAD_REQUEST: {}
274
+ }).input(z.object({
275
+ environmentVariableId: z.string().describe("The ID of the environment variable"),
276
+ key: environmentVariableSchema.shape.key,
277
+ value: environmentVariableSchema.shape.value.optional(),
278
+ isSecret: environmentVariableSchema.shape.isSecret
279
+ })).output(z.object({ success: z.literal(true) }));
280
+ const deleteEnvironmentVariableContractV1 = oc.route({
281
+ path: "/v1/environment-variables/{environmentVariableId}",
282
+ method: "DELETE",
283
+ summary: "Delete an environment variable",
284
+ description: "Delete an environment variable by ID",
285
+ tags: ["environments"],
286
+ successDescription: "The environment variable has been deleted successfully"
287
+ }).errors({ NOT_FOUND: {} }).input(z.object({ environmentVariableId: z.string().describe("The ID of the environment variable") })).output(z.object({ success: z.literal(true) }));
214
288
  const deleteProjectContractV1 = oc.route({
215
289
  path: "/v1/projects/:projectId",
216
290
  method: "DELETE",
@@ -247,7 +321,7 @@ const deployEnvironmentContractV1 = oc.route({
247
321
  }).input(z.object({
248
322
  environmentId: z.string().describe("The ID of the environment to deploy"),
249
323
  token: z.string().describe("The token to identify the source archive").optional()
250
- })).output(deploymentWithPageUrlSchema);
324
+ })).output(deploymentSchema);
251
325
  const uploadDeploymentArtifactContractV1 = oc.route({
252
326
  path: "/v1/deployments/upload",
253
327
  method: "POST",
@@ -260,17 +334,18 @@ const uploadDeploymentArtifactContractV1 = oc.route({
260
334
  token: z.string().describe("Token to identify the source archive"),
261
335
  expiresAt: z.coerce.date().describe("Expiration date of the presigned URL")
262
336
  }));
263
- const listProjectDeploymentsContractV1 = oc.route({
337
+ const listDeploymentsContractV1 = oc.route({
264
338
  path: "/v1/projects/{projectId}/deployments",
265
339
  method: "GET",
266
340
  summary: "List project deployments",
267
341
  description: "List all deployments for a project",
268
342
  tags: ["deployments"],
269
343
  successDescription: "The list of deployments"
270
- }).errors({ NOT_FOUND: {} }).input(z.object({ projectId: z.string().describe("The ID of the project") })).output(z.array(deploymentSchema.extend({
271
- isCurrent: z.boolean(),
272
- environmentId: z.string()
273
- })));
344
+ }).errors({ NOT_FOUND: {} }).input(z.object({
345
+ projectId: z.string().describe("The ID of the project"),
346
+ status: z.array(deploymentStatusSchema).optional().describe("Filter by one or more statuses"),
347
+ environmentId: z.string().optional().describe("Filter by environment ID")
348
+ })).output(z.array(deploymentSchema));
274
349
  const getDeploymentContractV1 = oc.route({
275
350
  path: "/v1/deployments/{deploymentId}",
276
351
  method: "GET",
@@ -278,7 +353,48 @@ const getDeploymentContractV1 = oc.route({
278
353
  description: "Get a deployment by ID",
279
354
  tags: ["deployments"],
280
355
  successDescription: "The deployment details"
281
- }).errors({ NOT_FOUND: {} }).input(z.object({ deploymentId: z.string().describe("The ID of the deployment") })).output(deploymentWithPageUrlSchema);
356
+ }).errors({ NOT_FOUND: {} }).input(z.object({ deploymentId: z.string().describe("The ID of the deployment") })).output(deploymentSchema);
357
+ const getLogsContractV1 = oc.route({
358
+ path: "/v1/environments/{environmentId}/logs",
359
+ method: "GET",
360
+ summary: "Get logs",
361
+ description: "Get logs for an environment",
362
+ tags: ["environments"],
363
+ successDescription: "The logs"
364
+ }).errors({
365
+ NOT_FOUND: {},
366
+ BAD_REQUEST: {}
367
+ }).input(z.object({
368
+ environmentId: z.string().describe("The ID of the environment"),
369
+ since: z.string().refine(isValidLogTimeInput, { message: "Invalid time. Use relative (1h, 30m, 2d) or ISO 8601 format." }).optional().describe("Start time — ISO 8601 (2024-01-01T00:00:00Z) or relative (1h, 30m, 2d)"),
370
+ until: z.string().refine(isValidLogTimeInput, { message: "Invalid time. Use relative (1h, 30m, 2d) or ISO 8601 format." }).optional().describe("End time — ISO 8601 or relative"),
371
+ limit: z.coerce.number().int().min(1).max(1e3).default(1e3).describe("Maximum number of log entries to return."),
372
+ level: z.array(z.enum([
373
+ "INFO",
374
+ "ERROR",
375
+ "WARNING",
376
+ "DEBUG"
377
+ ])).optional().describe("Filter by log level"),
378
+ search: z.string().optional().describe("Filter pattern to search for in log content"),
379
+ nextToken: z.string().optional().describe("Pagination token from a previous response")
380
+ })).output(z.object({
381
+ logs: z.array(z.object({
382
+ timestamp: z.coerce.date(),
383
+ type: z.enum([
384
+ "START",
385
+ "END",
386
+ "INFO",
387
+ "ERROR",
388
+ "WARNING",
389
+ "DEBUG"
390
+ ]),
391
+ requestId: z.string(),
392
+ content: z.string().optional(),
393
+ method: z.string().optional(),
394
+ durationInMs: z.number().optional()
395
+ })),
396
+ nextToken: z.string().nullable()
397
+ }));
282
398
  const getDeploymentLogsContractV1 = oc.route({
283
399
  path: "/v1/deployments/{deploymentId}/logs",
284
400
  method: "GET",
@@ -342,14 +458,25 @@ const listTeamsContractV1 = oc.route({
342
458
  id: z.string(),
343
459
  name: z.string(),
344
460
  createdAt: z.coerce.date(),
345
- hasStripeAccount: z.boolean(),
346
- hasActiveSubscription: z.boolean()
461
+ hasStripeAccount: z.boolean()
347
462
  })));
463
+ const getTunnelTicketContractV1 = oc.route({
464
+ path: "/v1/tunnels/ticket",
465
+ method: "GET",
466
+ summary: "Get a tunnel ticket",
467
+ description: "Get a signed ticket for establishing a tunnel connection. Requires user authentication (API keys are not supported).",
468
+ tags: ["tunnels"],
469
+ successDescription: "The tunnel ticket"
470
+ }).output(z.object({
471
+ subdomain: z.string().describe("The subdomain assigned to the user"),
472
+ ticket: z.string().describe("The signed tunnel ticket"),
473
+ tunnelHost: z.string().describe("The tunnel host to connect to")
474
+ }));
348
475
  const contract = {
349
476
  teams: { list: { v1: listTeamsContractV1 } },
350
477
  analytics: { get: { v1: getProjectAnalyticsContractV1 } },
351
478
  deployments: {
352
- list: { v1: listProjectDeploymentsContractV1 },
479
+ list: { v1: listDeploymentsContractV1 },
353
480
  get: { v1: getDeploymentContractV1 },
354
481
  uploadArtifact: { v1: uploadDeploymentArtifactContractV1 },
355
482
  getLogs: { v1: getDeploymentLogsContractV1 }
@@ -357,7 +484,14 @@ const contract = {
357
484
  environments: {
358
485
  create: { v1: createEnvironmentContractV1 },
359
486
  get: { v1: getEnvironmentContractV1 },
360
- deploy: { v1: deployEnvironmentContractV1 }
487
+ deploy: { v1: deployEnvironmentContractV1 },
488
+ getLogs: { v1: getLogsContractV1 }
489
+ },
490
+ environmentVariables: {
491
+ list: { v1: listEnvironmentVariablesContractV1 },
492
+ create: { v1: createEnvironmentVariablesContractV1 },
493
+ update: { v1: updateEnvironmentVariableContractV1 },
494
+ delete: { v1: deleteEnvironmentVariableContractV1 }
361
495
  },
362
496
  projects: {
363
497
  update: { v1: updateProjectContractV1 },
@@ -365,8 +499,8 @@ const contract = {
365
499
  list: { v1: listProjectsContractV1 },
366
500
  create: { v1: createProjectContractV1 },
367
501
  delete: { v1: deleteProjectContractV1 }
368
- }
502
+ },
503
+ tunnels: { getTicket: { v1: getTunnelTicketContractV1 } }
369
504
  };
370
-
371
505
  //#endregion
372
- export { buildSettingsSchema, contract, createEnvironmentContractV1, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
506
+ export { buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alpic-ai/api",
3
- "version": "0.0.0-staging.fc9821d",
3
+ "version": "0.0.0-staging.fee97f5",
4
4
  "description": "Contract for the Alpic API",
5
5
  "type": "module",
6
6
  "main": "./dist/index.mjs",
@@ -17,15 +17,17 @@
17
17
  "author": "Alpic",
18
18
  "license": "ISC",
19
19
  "dependencies": {
20
- "@orpc/contract": "^1.13.5",
20
+ "@orpc/contract": "^1.13.7",
21
+ "ms": "^2.1.3",
21
22
  "zod": "^4.3.6"
22
23
  },
23
24
  "devDependencies": {
24
25
  "@total-typescript/tsconfig": "^1.0.4",
26
+ "@types/ms": "^2.1.0",
25
27
  "shx": "^0.4.0",
26
- "tsdown": "^0.20.3",
28
+ "tsdown": "^0.21.3",
27
29
  "typescript": "^5.9.3",
28
- "vitest": "^4.0.18"
30
+ "vitest": "^4.1.0"
29
31
  },
30
32
  "scripts": {
31
33
  "build": "shx rm -rf dist && tsdown",
@@ -33,6 +35,7 @@
33
35
  "test": "pnpm run test:unit && pnpm run test:type && pnpm run test:format",
34
36
  "test:unit": "vitest run",
35
37
  "test:format": "prettier --check .",
36
- "test:type": "tsc --noEmit"
38
+ "test:type": "tsc --noEmit",
39
+ "publish:npm": "pnpm publish --tag \"${NPM_TAG}\" --access public --no-git-checks"
37
40
  }
38
41
  }