@alpic-ai/api 0.0.0-staging.f279b42 → 0.0.0-staging.f357770

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,10 @@ 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;
156
+ deploymentPageUrl: z.ZodNullable<z.ZodURL>;
137
157
  }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
138
158
  NOT_FOUND: {};
139
159
  }>, Record<never, never>>;
@@ -218,12 +238,104 @@ declare const contract: {
218
238
  authorAvatarUrl: z.ZodNullable<z.ZodString>;
219
239
  startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
220
240
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
241
+ environmentId: z.ZodString;
242
+ environmentName: z.ZodString;
243
+ isCurrent: z.ZodBoolean;
244
+ deploymentPageUrl: z.ZodNullable<z.ZodURL>;
245
+ }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
246
+ NOT_FOUND: {};
247
+ BAD_REQUEST: {};
248
+ }>, Record<never, never>>;
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>;
221
281
  }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
222
282
  NOT_FOUND: {};
223
283
  BAD_REQUEST: {};
224
284
  }>, Record<never, never>>;
225
285
  };
226
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
+ };
338
+ };
227
339
  projects: {
228
340
  update: {
229
341
  v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
@@ -256,6 +368,15 @@ declare const contract: {
256
368
  id: z.ZodString;
257
369
  name: z.ZodString;
258
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>>;
259
380
  latestDeployment: z.ZodNullable<z.ZodObject<{
260
381
  id: z.ZodString;
261
382
  status: z.ZodEnum<{
@@ -323,6 +444,15 @@ declare const contract: {
323
444
  id: z.ZodString;
324
445
  name: z.ZodString;
325
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>>;
326
456
  latestDeployment: z.ZodNullable<z.ZodObject<{
327
457
  id: z.ZodString;
328
458
  status: z.ZodEnum<{
@@ -361,7 +491,9 @@ declare const contract: {
361
491
  }>, Record<never, never>>;
362
492
  };
363
493
  list: {
364
- 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<{
365
497
  id: z.ZodString;
366
498
  name: z.ZodString;
367
499
  teamId: z.ZodString;
@@ -387,6 +519,15 @@ declare const contract: {
387
519
  id: z.ZodString;
388
520
  name: z.ZodString;
389
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>>;
390
531
  latestDeployment: z.ZodNullable<z.ZodObject<{
391
532
  id: z.ZodString;
392
533
  status: z.ZodEnum<{
@@ -496,6 +637,15 @@ declare const contract: {
496
637
  }>, Record<never, never>>;
497
638
  };
498
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
+ };
499
649
  };
500
650
  type RouterInput = InferContractRouterInputs<typeof contract>;
501
651
  type RouterOutput = InferContractRouterOutputs<typeof contract>;
@@ -531,4 +681,4 @@ declare const transportSchema: z.ZodEnum<{
531
681
  }>;
532
682
  type Transport = z.infer<typeof transportSchema>;
533
683
  //#endregion
534
- 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,8 +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
  });
93
+ const isValidLogTimeInput = (value) => {
94
+ if (ms(value) !== void 0) return true;
95
+ return !Number.isNaN(new Date(value).getTime());
96
+ };
85
97
  const createEnvironmentContractV1 = oc.route({
86
98
  path: "/v1/environments",
87
99
  method: "POST",
@@ -121,10 +133,20 @@ const getEnvironmentContractV1 = oc.route({
121
133
  createdAt: z.coerce.date(),
122
134
  projectId: z.string()
123
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
+ });
124
145
  const productionEnvironmentSchema = z.object({
125
146
  id: z.string(),
126
147
  name: z.string(),
127
148
  mcpServerUrl: z.string(),
149
+ domains: z.array(domainSchema),
128
150
  latestDeployment: latestDeploymentSchema.nullable()
129
151
  });
130
152
  const environmentSchema = z.object({
@@ -167,7 +189,7 @@ const listProjectsContractV1 = oc.route({
167
189
  description: "List all projects for a team",
168
190
  tags: ["projects"],
169
191
  successDescription: "The list of projects"
170
- }).output(z.array(projectOutputSchema));
192
+ }).input(z.object({ teamId: z.string().optional() }).optional()).output(z.array(projectOutputSchema));
171
193
  const createProjectContractV1 = oc.route({
172
194
  path: "/v1/projects",
173
195
  method: "POST",
@@ -180,7 +202,7 @@ const createProjectContractV1 = oc.route({
180
202
  BAD_REQUEST: {}
181
203
  }).input(z.object({
182
204
  teamId: z.string().optional(),
183
- name: z.string().min(1).max(100),
205
+ name: z.string().trim().min(1).max(100),
184
206
  sourceRepository: z.string().optional(),
185
207
  branchName: z.string().min(1).optional(),
186
208
  runtime: runtimeSchema,
@@ -210,6 +232,59 @@ const createProjectContractV1 = oc.route({
210
232
  startCommand: z.string().nullable(),
211
233
  createdAt: z.coerce.date()
212
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) }));
213
288
  const deleteProjectContractV1 = oc.route({
214
289
  path: "/v1/projects/:projectId",
215
290
  method: "DELETE",
@@ -259,17 +334,18 @@ const uploadDeploymentArtifactContractV1 = oc.route({
259
334
  token: z.string().describe("Token to identify the source archive"),
260
335
  expiresAt: z.coerce.date().describe("Expiration date of the presigned URL")
261
336
  }));
262
- const listProjectDeploymentsContractV1 = oc.route({
337
+ const listDeploymentsContractV1 = oc.route({
263
338
  path: "/v1/projects/{projectId}/deployments",
264
339
  method: "GET",
265
340
  summary: "List project deployments",
266
341
  description: "List all deployments for a project",
267
342
  tags: ["deployments"],
268
343
  successDescription: "The list of deployments"
269
- }).errors({ NOT_FOUND: {} }).input(z.object({ projectId: z.string().describe("The ID of the project") })).output(z.array(deploymentSchema.extend({
270
- isCurrent: z.boolean(),
271
- environmentId: z.string()
272
- })));
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));
273
349
  const getDeploymentContractV1 = oc.route({
274
350
  path: "/v1/deployments/{deploymentId}",
275
351
  method: "GET",
@@ -278,6 +354,47 @@ const getDeploymentContractV1 = oc.route({
278
354
  tags: ["deployments"],
279
355
  successDescription: "The deployment details"
280
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
+ }));
281
398
  const getDeploymentLogsContractV1 = oc.route({
282
399
  path: "/v1/deployments/{deploymentId}/logs",
283
400
  method: "GET",
@@ -341,14 +458,25 @@ const listTeamsContractV1 = oc.route({
341
458
  id: z.string(),
342
459
  name: z.string(),
343
460
  createdAt: z.coerce.date(),
344
- hasStripeAccount: z.boolean(),
345
- hasActiveSubscription: z.boolean()
461
+ hasStripeAccount: z.boolean()
346
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
+ }));
347
475
  const contract = {
348
476
  teams: { list: { v1: listTeamsContractV1 } },
349
477
  analytics: { get: { v1: getProjectAnalyticsContractV1 } },
350
478
  deployments: {
351
- list: { v1: listProjectDeploymentsContractV1 },
479
+ list: { v1: listDeploymentsContractV1 },
352
480
  get: { v1: getDeploymentContractV1 },
353
481
  uploadArtifact: { v1: uploadDeploymentArtifactContractV1 },
354
482
  getLogs: { v1: getDeploymentLogsContractV1 }
@@ -356,7 +484,14 @@ const contract = {
356
484
  environments: {
357
485
  create: { v1: createEnvironmentContractV1 },
358
486
  get: { v1: getEnvironmentContractV1 },
359
- 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 }
360
495
  },
361
496
  projects: {
362
497
  update: { v1: updateProjectContractV1 },
@@ -364,8 +499,8 @@ const contract = {
364
499
  list: { v1: listProjectsContractV1 },
365
500
  create: { v1: createProjectContractV1 },
366
501
  delete: { v1: deleteProjectContractV1 }
367
- }
502
+ },
503
+ tunnels: { getTicket: { v1: getTunnelTicketContractV1 } }
368
504
  };
369
-
370
505
  //#endregion
371
- 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.f279b42",
3
+ "version": "0.0.0-staging.f357770",
4
4
  "description": "Contract for the Alpic API",
5
5
  "type": "module",
6
6
  "main": "./dist/index.mjs",
@@ -17,16 +17,17 @@
17
17
  "author": "Alpic",
18
18
  "license": "ISC",
19
19
  "dependencies": {
20
- "@orpc/contract": "^1.13.4",
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",
25
- "biome": "^0.3.3",
26
+ "@types/ms": "^2.1.0",
26
27
  "shx": "^0.4.0",
27
- "tsdown": "^0.20.3",
28
+ "tsdown": "^0.21.3",
28
29
  "typescript": "^5.9.3",
29
- "vitest": "^4.0.18"
30
+ "vitest": "^4.1.0"
30
31
  },
31
32
  "scripts": {
32
33
  "build": "shx rm -rf dist && tsdown",
@@ -34,6 +35,7 @@
34
35
  "test": "pnpm run test:unit && pnpm run test:type && pnpm run test:format",
35
36
  "test:unit": "vitest run",
36
37
  "test:format": "prettier --check .",
37
- "test:type": "tsc --noEmit"
38
+ "test:type": "tsc --noEmit",
39
+ "publish:npm": "pnpm publish --tag \"${NPM_TAG}\" --access public --no-git-checks"
38
40
  }
39
41
  }