@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 +154 -4
- package/dist/index.mjs +153 -18
- package/package.json +8 -6
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.
|
|
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
|
|
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({
|
|
270
|
-
|
|
271
|
-
|
|
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:
|
|
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.
|
|
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.
|
|
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
|
-
"
|
|
26
|
+
"@types/ms": "^2.1.0",
|
|
26
27
|
"shx": "^0.4.0",
|
|
27
|
-
"tsdown": "^0.
|
|
28
|
+
"tsdown": "^0.21.3",
|
|
28
29
|
"typescript": "^5.9.3",
|
|
29
|
-
"vitest": "^4.0
|
|
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
|
}
|