@alpic-ai/api 0.0.0-staging.ec72735 → 0.0.0-staging.ee8089b
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 +245 -4
- package/dist/index.mjs +208 -19
- package/package.json +8 -5
package/dist/index.d.mts
CHANGED
|
@@ -7,8 +7,15 @@ type ApiContext = {
|
|
|
7
7
|
request: Request & {
|
|
8
8
|
teamIds: string[];
|
|
9
9
|
defaultTeamId: string | undefined;
|
|
10
|
+
awsCognitoUserSub: string | undefined;
|
|
10
11
|
};
|
|
11
12
|
};
|
|
13
|
+
declare const deploymentStatusSchema: z.ZodEnum<{
|
|
14
|
+
ongoing: "ongoing";
|
|
15
|
+
deployed: "deployed";
|
|
16
|
+
failed: "failed";
|
|
17
|
+
canceled: "canceled";
|
|
18
|
+
}>;
|
|
12
19
|
declare const createEnvironmentContractV1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
|
|
13
20
|
projectId: z.ZodString;
|
|
14
21
|
name: z.ZodString;
|
|
@@ -37,7 +44,6 @@ declare const contract: {
|
|
|
37
44
|
name: z.ZodString;
|
|
38
45
|
createdAt: z.ZodCoercedDate<unknown>;
|
|
39
46
|
hasStripeAccount: z.ZodBoolean;
|
|
40
|
-
hasActiveSubscription: z.ZodBoolean;
|
|
41
47
|
}, z.core.$strip>>, Record<never, never>, Record<never, never>>;
|
|
42
48
|
};
|
|
43
49
|
};
|
|
@@ -96,6 +102,13 @@ declare const contract: {
|
|
|
96
102
|
list: {
|
|
97
103
|
v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
|
|
98
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>;
|
|
99
112
|
}, z.core.$strip>, z.ZodArray<z.ZodObject<{
|
|
100
113
|
id: z.ZodString;
|
|
101
114
|
status: z.ZodEnum<{
|
|
@@ -111,8 +124,10 @@ declare const contract: {
|
|
|
111
124
|
authorAvatarUrl: z.ZodNullable<z.ZodString>;
|
|
112
125
|
startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
113
126
|
completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
114
|
-
isCurrent: z.ZodBoolean;
|
|
115
127
|
environmentId: z.ZodString;
|
|
128
|
+
environmentName: z.ZodString;
|
|
129
|
+
isCurrent: z.ZodBoolean;
|
|
130
|
+
deploymentPageUrl: z.ZodNullable<z.ZodURL>;
|
|
116
131
|
}, z.core.$strip>>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
|
|
117
132
|
NOT_FOUND: {};
|
|
118
133
|
}>, Record<never, never>>;
|
|
@@ -135,6 +150,9 @@ declare const contract: {
|
|
|
135
150
|
authorAvatarUrl: z.ZodNullable<z.ZodString>;
|
|
136
151
|
startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
137
152
|
completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
153
|
+
environmentId: z.ZodString;
|
|
154
|
+
environmentName: z.ZodString;
|
|
155
|
+
isCurrent: z.ZodBoolean;
|
|
138
156
|
deploymentPageUrl: z.ZodNullable<z.ZodURL>;
|
|
139
157
|
}, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
|
|
140
158
|
NOT_FOUND: {};
|
|
@@ -144,7 +162,7 @@ declare const contract: {
|
|
|
144
162
|
v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
|
|
145
163
|
teamId: z.ZodOptional<z.ZodString>;
|
|
146
164
|
}, z.core.$strip>>, z.ZodObject<{
|
|
147
|
-
uploadUrl: z.
|
|
165
|
+
uploadUrl: z.ZodURL;
|
|
148
166
|
token: z.ZodString;
|
|
149
167
|
expiresAt: z.ZodCoercedDate<unknown>;
|
|
150
168
|
}, z.core.$strip>, Record<never, never>, Record<never, never>>;
|
|
@@ -220,12 +238,103 @@ declare const contract: {
|
|
|
220
238
|
authorAvatarUrl: z.ZodNullable<z.ZodString>;
|
|
221
239
|
startedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
222
240
|
completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
|
|
241
|
+
environmentId: z.ZodString;
|
|
242
|
+
environmentName: z.ZodString;
|
|
243
|
+
isCurrent: z.ZodBoolean;
|
|
223
244
|
deploymentPageUrl: z.ZodNullable<z.ZodURL>;
|
|
224
245
|
}, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
|
|
225
246
|
NOT_FOUND: {};
|
|
226
247
|
BAD_REQUEST: {};
|
|
227
248
|
}>, Record<never, never>>;
|
|
228
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
|
+
};
|
|
229
338
|
};
|
|
230
339
|
projects: {
|
|
231
340
|
update: {
|
|
@@ -259,6 +368,15 @@ declare const contract: {
|
|
|
259
368
|
id: z.ZodString;
|
|
260
369
|
name: z.ZodString;
|
|
261
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>>;
|
|
262
380
|
latestDeployment: z.ZodNullable<z.ZodObject<{
|
|
263
381
|
id: z.ZodString;
|
|
264
382
|
status: z.ZodEnum<{
|
|
@@ -326,6 +444,15 @@ declare const contract: {
|
|
|
326
444
|
id: z.ZodString;
|
|
327
445
|
name: z.ZodString;
|
|
328
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>>;
|
|
329
456
|
latestDeployment: z.ZodNullable<z.ZodObject<{
|
|
330
457
|
id: z.ZodString;
|
|
331
458
|
status: z.ZodEnum<{
|
|
@@ -392,6 +519,15 @@ declare const contract: {
|
|
|
392
519
|
id: z.ZodString;
|
|
393
520
|
name: z.ZodString;
|
|
394
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>>;
|
|
395
531
|
latestDeployment: z.ZodNullable<z.ZodObject<{
|
|
396
532
|
id: z.ZodString;
|
|
397
533
|
status: z.ZodEnum<{
|
|
@@ -501,6 +637,88 @@ declare const contract: {
|
|
|
501
637
|
}>, Record<never, never>>;
|
|
502
638
|
};
|
|
503
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
|
+
};
|
|
649
|
+
distribution: {
|
|
650
|
+
publish: {
|
|
651
|
+
v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
|
|
652
|
+
projectId: z.ZodString;
|
|
653
|
+
domain: z.ZodString;
|
|
654
|
+
title: z.ZodString;
|
|
655
|
+
description: z.ZodString;
|
|
656
|
+
websiteUrl: z.ZodOptional<z.ZodURL>;
|
|
657
|
+
iconSrc: z.ZodOptional<z.ZodURL>;
|
|
658
|
+
dryRun: z.ZodOptional<z.ZodBoolean>;
|
|
659
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
660
|
+
serverFields: z.ZodObject<{
|
|
661
|
+
$schema: z.ZodString;
|
|
662
|
+
name: z.ZodString;
|
|
663
|
+
description: z.ZodString;
|
|
664
|
+
version: z.ZodOptional<z.ZodString>;
|
|
665
|
+
title: z.ZodOptional<z.ZodString>;
|
|
666
|
+
websiteUrl: z.ZodOptional<z.ZodURL>;
|
|
667
|
+
icons: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
668
|
+
src: z.ZodURL;
|
|
669
|
+
mimeType: z.ZodOptional<z.ZodString>;
|
|
670
|
+
sizes: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
671
|
+
}, z.core.$strip>>>;
|
|
672
|
+
remotes: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
673
|
+
type: z.ZodString;
|
|
674
|
+
url: z.ZodOptional<z.ZodURL>;
|
|
675
|
+
headers: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
676
|
+
name: z.ZodString;
|
|
677
|
+
description: z.ZodString;
|
|
678
|
+
isRequired: z.ZodOptional<z.ZodBoolean>;
|
|
679
|
+
isSecret: z.ZodOptional<z.ZodBoolean>;
|
|
680
|
+
}, z.core.$strip>>>;
|
|
681
|
+
}, z.core.$strip>>>;
|
|
682
|
+
}, z.core.$strip>;
|
|
683
|
+
}, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
|
|
684
|
+
NOT_FOUND: {};
|
|
685
|
+
BAD_REQUEST: {};
|
|
686
|
+
}>, Record<never, never>>;
|
|
687
|
+
};
|
|
688
|
+
info: {
|
|
689
|
+
v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
|
|
690
|
+
projectId: z.ZodString;
|
|
691
|
+
domain: z.ZodString;
|
|
692
|
+
}, z.core.$strip>, z.ZodObject<{
|
|
693
|
+
serverFields: z.ZodObject<{
|
|
694
|
+
$schema: z.ZodString;
|
|
695
|
+
name: z.ZodString;
|
|
696
|
+
description: z.ZodString;
|
|
697
|
+
version: z.ZodOptional<z.ZodString>;
|
|
698
|
+
title: z.ZodOptional<z.ZodString>;
|
|
699
|
+
websiteUrl: z.ZodOptional<z.ZodURL>;
|
|
700
|
+
icons: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
701
|
+
src: z.ZodURL;
|
|
702
|
+
mimeType: z.ZodOptional<z.ZodString>;
|
|
703
|
+
sizes: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
704
|
+
}, z.core.$strip>>>;
|
|
705
|
+
remotes: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
706
|
+
type: z.ZodString;
|
|
707
|
+
url: z.ZodOptional<z.ZodURL>;
|
|
708
|
+
headers: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
709
|
+
name: z.ZodString;
|
|
710
|
+
description: z.ZodString;
|
|
711
|
+
isRequired: z.ZodOptional<z.ZodBoolean>;
|
|
712
|
+
isSecret: z.ZodOptional<z.ZodBoolean>;
|
|
713
|
+
}, z.core.$strip>>>;
|
|
714
|
+
}, z.core.$strip>>>;
|
|
715
|
+
}, z.core.$strip>;
|
|
716
|
+
}, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
|
|
717
|
+
NOT_FOUND: {};
|
|
718
|
+
BAD_REQUEST: {};
|
|
719
|
+
}>, Record<never, never>>;
|
|
720
|
+
};
|
|
721
|
+
};
|
|
504
722
|
};
|
|
505
723
|
type RouterInput = InferContractRouterInputs<typeof contract>;
|
|
506
724
|
type RouterOutput = InferContractRouterOutputs<typeof contract>;
|
|
@@ -535,5 +753,28 @@ declare const transportSchema: z.ZodEnum<{
|
|
|
535
753
|
streamablehttp: "streamablehttp";
|
|
536
754
|
}>;
|
|
537
755
|
type Transport = z.infer<typeof transportSchema>;
|
|
756
|
+
declare const serverFieldsSchema: z.ZodObject<{
|
|
757
|
+
$schema: z.ZodString;
|
|
758
|
+
name: z.ZodString;
|
|
759
|
+
description: z.ZodString;
|
|
760
|
+
version: z.ZodOptional<z.ZodString>;
|
|
761
|
+
title: z.ZodOptional<z.ZodString>;
|
|
762
|
+
websiteUrl: z.ZodOptional<z.ZodURL>;
|
|
763
|
+
icons: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
764
|
+
src: z.ZodURL;
|
|
765
|
+
mimeType: z.ZodOptional<z.ZodString>;
|
|
766
|
+
sizes: z.ZodOptional<z.ZodArray<z.ZodString>>;
|
|
767
|
+
}, z.core.$strip>>>;
|
|
768
|
+
remotes: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
769
|
+
type: z.ZodString;
|
|
770
|
+
url: z.ZodOptional<z.ZodURL>;
|
|
771
|
+
headers: z.ZodOptional<z.ZodArray<z.ZodObject<{
|
|
772
|
+
name: z.ZodString;
|
|
773
|
+
description: z.ZodString;
|
|
774
|
+
isRequired: z.ZodOptional<z.ZodBoolean>;
|
|
775
|
+
isSecret: z.ZodOptional<z.ZodBoolean>;
|
|
776
|
+
}, z.core.$strip>>>;
|
|
777
|
+
}, z.core.$strip>>>;
|
|
778
|
+
}, z.core.$strip>;
|
|
538
779
|
//#endregion
|
|
539
|
-
export { ApiContext, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
|
|
780
|
+
export { ApiContext, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, serverFieldsSchema, 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",
|
|
@@ -34,7 +34,8 @@ const RESERVED_KEYS = [
|
|
|
34
34
|
"BUILD_ARG_BUILD_COMMAND",
|
|
35
35
|
"BUILD_ARG_BUILD_OUTPUT_DIR",
|
|
36
36
|
"BUILD_ARG_START_COMMAND",
|
|
37
|
-
"ALPIC_HOST"
|
|
37
|
+
"ALPIC_HOST",
|
|
38
|
+
"ALPIC_CUSTOM_DOMAINS"
|
|
38
39
|
];
|
|
39
40
|
const environmentVariableSchema = z.object({
|
|
40
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"),
|
|
@@ -59,7 +60,29 @@ const transportSchema = z.enum([
|
|
|
59
60
|
"sse",
|
|
60
61
|
"streamablehttp"
|
|
61
62
|
]);
|
|
62
|
-
|
|
63
|
+
const serverFieldsSchema = z.object({
|
|
64
|
+
$schema: z.string(),
|
|
65
|
+
name: z.string(),
|
|
66
|
+
description: z.string(),
|
|
67
|
+
version: z.string().optional(),
|
|
68
|
+
title: z.string().optional(),
|
|
69
|
+
websiteUrl: z.url().optional(),
|
|
70
|
+
icons: z.array(z.object({
|
|
71
|
+
src: z.url(),
|
|
72
|
+
mimeType: z.string().optional(),
|
|
73
|
+
sizes: z.array(z.string()).optional()
|
|
74
|
+
})).optional(),
|
|
75
|
+
remotes: z.array(z.object({
|
|
76
|
+
type: z.string(),
|
|
77
|
+
url: z.url().optional(),
|
|
78
|
+
headers: z.array(z.object({
|
|
79
|
+
name: z.string(),
|
|
80
|
+
description: z.string(),
|
|
81
|
+
isRequired: z.boolean().optional(),
|
|
82
|
+
isSecret: z.boolean().optional()
|
|
83
|
+
})).optional()
|
|
84
|
+
})).optional()
|
|
85
|
+
});
|
|
63
86
|
//#endregion
|
|
64
87
|
//#region src/api.contract.ts
|
|
65
88
|
const deploymentStatusSchema = z.enum([
|
|
@@ -84,9 +107,16 @@ const deploymentSchema = z.object({
|
|
|
84
107
|
authorUsername: z.string().nullable(),
|
|
85
108
|
authorAvatarUrl: z.string().nullable(),
|
|
86
109
|
startedAt: z.coerce.date().nullable(),
|
|
87
|
-
completedAt: z.coerce.date().nullable()
|
|
110
|
+
completedAt: z.coerce.date().nullable(),
|
|
111
|
+
environmentId: z.string(),
|
|
112
|
+
environmentName: z.string(),
|
|
113
|
+
isCurrent: z.boolean(),
|
|
114
|
+
deploymentPageUrl: z.url().nullable()
|
|
88
115
|
});
|
|
89
|
-
const
|
|
116
|
+
const isValidLogTimeInput = (value) => {
|
|
117
|
+
if (ms(value) !== void 0) return true;
|
|
118
|
+
return !Number.isNaN(new Date(value).getTime());
|
|
119
|
+
};
|
|
90
120
|
const createEnvironmentContractV1 = oc.route({
|
|
91
121
|
path: "/v1/environments",
|
|
92
122
|
method: "POST",
|
|
@@ -126,10 +156,20 @@ const getEnvironmentContractV1 = oc.route({
|
|
|
126
156
|
createdAt: z.coerce.date(),
|
|
127
157
|
projectId: z.string()
|
|
128
158
|
}));
|
|
159
|
+
const domainSchema = z.object({
|
|
160
|
+
domain: z.string(),
|
|
161
|
+
status: z.enum([
|
|
162
|
+
"ongoing",
|
|
163
|
+
"deployed",
|
|
164
|
+
"failed"
|
|
165
|
+
]),
|
|
166
|
+
createdAt: z.coerce.date()
|
|
167
|
+
});
|
|
129
168
|
const productionEnvironmentSchema = z.object({
|
|
130
169
|
id: z.string(),
|
|
131
170
|
name: z.string(),
|
|
132
171
|
mcpServerUrl: z.string(),
|
|
172
|
+
domains: z.array(domainSchema),
|
|
133
173
|
latestDeployment: latestDeploymentSchema.nullable()
|
|
134
174
|
});
|
|
135
175
|
const environmentSchema = z.object({
|
|
@@ -215,6 +255,59 @@ const createProjectContractV1 = oc.route({
|
|
|
215
255
|
startCommand: z.string().nullable(),
|
|
216
256
|
createdAt: z.coerce.date()
|
|
217
257
|
}));
|
|
258
|
+
const environmentVariableOutputSchema = z.object({
|
|
259
|
+
id: z.string(),
|
|
260
|
+
key: z.string(),
|
|
261
|
+
value: z.string(),
|
|
262
|
+
isSecret: z.boolean(),
|
|
263
|
+
createdAt: z.coerce.date()
|
|
264
|
+
});
|
|
265
|
+
const listEnvironmentVariablesContractV1 = oc.route({
|
|
266
|
+
path: "/v1/environments/{environmentId}/environment-variables",
|
|
267
|
+
method: "GET",
|
|
268
|
+
summary: "List environment variables",
|
|
269
|
+
description: "List all environment variables for an environment",
|
|
270
|
+
tags: ["environments"],
|
|
271
|
+
successDescription: "The list of environment variables"
|
|
272
|
+
}).errors({ NOT_FOUND: {} }).input(z.object({ environmentId: z.string().describe("The ID of the environment") })).output(z.array(environmentVariableOutputSchema));
|
|
273
|
+
const createEnvironmentVariablesContractV1 = oc.route({
|
|
274
|
+
path: "/v1/environments/{environmentId}/environment-variables",
|
|
275
|
+
method: "POST",
|
|
276
|
+
summary: "Add environment variables",
|
|
277
|
+
description: "Add one or more environment variables to an environment",
|
|
278
|
+
tags: ["environments"],
|
|
279
|
+
successDescription: "The environment variables have been added successfully"
|
|
280
|
+
}).errors({
|
|
281
|
+
NOT_FOUND: {},
|
|
282
|
+
BAD_REQUEST: {}
|
|
283
|
+
}).input(z.object({
|
|
284
|
+
environmentId: z.string().describe("The ID of the environment"),
|
|
285
|
+
environmentVariables: environmentVariablesSchema
|
|
286
|
+
})).output(z.object({ success: z.literal(true) }));
|
|
287
|
+
const updateEnvironmentVariableContractV1 = oc.route({
|
|
288
|
+
path: "/v1/environment-variables/{environmentVariableId}",
|
|
289
|
+
method: "PATCH",
|
|
290
|
+
summary: "Update an environment variable",
|
|
291
|
+
description: "Update an environment variable by ID",
|
|
292
|
+
tags: ["environments"],
|
|
293
|
+
successDescription: "The environment variable has been updated successfully"
|
|
294
|
+
}).errors({
|
|
295
|
+
NOT_FOUND: {},
|
|
296
|
+
BAD_REQUEST: {}
|
|
297
|
+
}).input(z.object({
|
|
298
|
+
environmentVariableId: z.string().describe("The ID of the environment variable"),
|
|
299
|
+
key: environmentVariableSchema.shape.key,
|
|
300
|
+
value: environmentVariableSchema.shape.value.optional(),
|
|
301
|
+
isSecret: environmentVariableSchema.shape.isSecret
|
|
302
|
+
})).output(z.object({ success: z.literal(true) }));
|
|
303
|
+
const deleteEnvironmentVariableContractV1 = oc.route({
|
|
304
|
+
path: "/v1/environment-variables/{environmentVariableId}",
|
|
305
|
+
method: "DELETE",
|
|
306
|
+
summary: "Delete an environment variable",
|
|
307
|
+
description: "Delete an environment variable by ID",
|
|
308
|
+
tags: ["environments"],
|
|
309
|
+
successDescription: "The environment variable has been deleted successfully"
|
|
310
|
+
}).errors({ NOT_FOUND: {} }).input(z.object({ environmentVariableId: z.string().describe("The ID of the environment variable") })).output(z.object({ success: z.literal(true) }));
|
|
218
311
|
const deleteProjectContractV1 = oc.route({
|
|
219
312
|
path: "/v1/projects/:projectId",
|
|
220
313
|
method: "DELETE",
|
|
@@ -251,7 +344,7 @@ const deployEnvironmentContractV1 = oc.route({
|
|
|
251
344
|
}).input(z.object({
|
|
252
345
|
environmentId: z.string().describe("The ID of the environment to deploy"),
|
|
253
346
|
token: z.string().describe("The token to identify the source archive").optional()
|
|
254
|
-
})).output(
|
|
347
|
+
})).output(deploymentSchema);
|
|
255
348
|
const uploadDeploymentArtifactContractV1 = oc.route({
|
|
256
349
|
path: "/v1/deployments/upload",
|
|
257
350
|
method: "POST",
|
|
@@ -260,21 +353,22 @@ const uploadDeploymentArtifactContractV1 = oc.route({
|
|
|
260
353
|
tags: ["deployments"],
|
|
261
354
|
successDescription: "The presigned upload URL has been generated successfully"
|
|
262
355
|
}).input(z.object({ teamId: z.string().optional() }).optional()).output(z.object({
|
|
263
|
-
uploadUrl: z.
|
|
356
|
+
uploadUrl: z.url().describe("Presigned S3 URL to upload the source archive with HTTP PUT"),
|
|
264
357
|
token: z.string().describe("Token to identify the source archive"),
|
|
265
358
|
expiresAt: z.coerce.date().describe("Expiration date of the presigned URL")
|
|
266
359
|
}));
|
|
267
|
-
const
|
|
360
|
+
const listDeploymentsContractV1 = oc.route({
|
|
268
361
|
path: "/v1/projects/{projectId}/deployments",
|
|
269
362
|
method: "GET",
|
|
270
363
|
summary: "List project deployments",
|
|
271
364
|
description: "List all deployments for a project",
|
|
272
365
|
tags: ["deployments"],
|
|
273
366
|
successDescription: "The list of deployments"
|
|
274
|
-
}).errors({ NOT_FOUND: {} }).input(z.object({
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
367
|
+
}).errors({ NOT_FOUND: {} }).input(z.object({
|
|
368
|
+
projectId: z.string().describe("The ID of the project"),
|
|
369
|
+
status: z.array(deploymentStatusSchema).optional().describe("Filter by one or more statuses"),
|
|
370
|
+
environmentId: z.string().optional().describe("Filter by environment ID")
|
|
371
|
+
})).output(z.array(deploymentSchema));
|
|
278
372
|
const getDeploymentContractV1 = oc.route({
|
|
279
373
|
path: "/v1/deployments/{deploymentId}",
|
|
280
374
|
method: "GET",
|
|
@@ -282,7 +376,48 @@ const getDeploymentContractV1 = oc.route({
|
|
|
282
376
|
description: "Get a deployment by ID",
|
|
283
377
|
tags: ["deployments"],
|
|
284
378
|
successDescription: "The deployment details"
|
|
285
|
-
}).errors({ NOT_FOUND: {} }).input(z.object({ deploymentId: z.string().describe("The ID of the deployment") })).output(
|
|
379
|
+
}).errors({ NOT_FOUND: {} }).input(z.object({ deploymentId: z.string().describe("The ID of the deployment") })).output(deploymentSchema);
|
|
380
|
+
const getLogsContractV1 = oc.route({
|
|
381
|
+
path: "/v1/environments/{environmentId}/logs",
|
|
382
|
+
method: "GET",
|
|
383
|
+
summary: "Get logs",
|
|
384
|
+
description: "Get logs for an environment",
|
|
385
|
+
tags: ["environments"],
|
|
386
|
+
successDescription: "The logs"
|
|
387
|
+
}).errors({
|
|
388
|
+
NOT_FOUND: {},
|
|
389
|
+
BAD_REQUEST: {}
|
|
390
|
+
}).input(z.object({
|
|
391
|
+
environmentId: z.string().describe("The ID of the environment"),
|
|
392
|
+
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)"),
|
|
393
|
+
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"),
|
|
394
|
+
limit: z.coerce.number().int().min(1).max(1e3).default(1e3).describe("Maximum number of log entries to return."),
|
|
395
|
+
level: z.array(z.enum([
|
|
396
|
+
"INFO",
|
|
397
|
+
"ERROR",
|
|
398
|
+
"WARNING",
|
|
399
|
+
"DEBUG"
|
|
400
|
+
])).optional().describe("Filter by log level"),
|
|
401
|
+
search: z.string().optional().describe("Filter pattern to search for in log content"),
|
|
402
|
+
nextToken: z.string().optional().describe("Pagination token from a previous response")
|
|
403
|
+
})).output(z.object({
|
|
404
|
+
logs: z.array(z.object({
|
|
405
|
+
timestamp: z.coerce.date(),
|
|
406
|
+
type: z.enum([
|
|
407
|
+
"START",
|
|
408
|
+
"END",
|
|
409
|
+
"INFO",
|
|
410
|
+
"ERROR",
|
|
411
|
+
"WARNING",
|
|
412
|
+
"DEBUG"
|
|
413
|
+
]),
|
|
414
|
+
requestId: z.string(),
|
|
415
|
+
content: z.string().optional(),
|
|
416
|
+
method: z.string().optional(),
|
|
417
|
+
durationInMs: z.number().optional()
|
|
418
|
+
})),
|
|
419
|
+
nextToken: z.string().nullable()
|
|
420
|
+
}));
|
|
286
421
|
const getDeploymentLogsContractV1 = oc.route({
|
|
287
422
|
path: "/v1/deployments/{deploymentId}/logs",
|
|
288
423
|
method: "GET",
|
|
@@ -346,14 +481,57 @@ const listTeamsContractV1 = oc.route({
|
|
|
346
481
|
id: z.string(),
|
|
347
482
|
name: z.string(),
|
|
348
483
|
createdAt: z.coerce.date(),
|
|
349
|
-
hasStripeAccount: z.boolean()
|
|
350
|
-
hasActiveSubscription: z.boolean()
|
|
484
|
+
hasStripeAccount: z.boolean()
|
|
351
485
|
})));
|
|
486
|
+
const getTunnelTicketContractV1 = oc.route({
|
|
487
|
+
path: "/v1/tunnels/ticket",
|
|
488
|
+
method: "GET",
|
|
489
|
+
summary: "Get a tunnel ticket",
|
|
490
|
+
description: "Get a signed ticket for establishing a tunnel connection. Requires user authentication (API keys are not supported).",
|
|
491
|
+
tags: ["tunnels"],
|
|
492
|
+
successDescription: "The tunnel ticket"
|
|
493
|
+
}).output(z.object({
|
|
494
|
+
subdomain: z.string().describe("The subdomain assigned to the user"),
|
|
495
|
+
ticket: z.string().describe("The signed tunnel ticket"),
|
|
496
|
+
tunnelHost: z.string().describe("The tunnel host to connect to")
|
|
497
|
+
}));
|
|
498
|
+
const publishServerContractV1 = oc.route({
|
|
499
|
+
path: "/v1/distribution/publish",
|
|
500
|
+
method: "POST",
|
|
501
|
+
summary: "Publish a server to the MCP registry",
|
|
502
|
+
tags: ["distribution"],
|
|
503
|
+
successDescription: "The server has been published successfully"
|
|
504
|
+
}).errors({
|
|
505
|
+
NOT_FOUND: {},
|
|
506
|
+
BAD_REQUEST: {}
|
|
507
|
+
}).input(z.object({
|
|
508
|
+
projectId: z.string(),
|
|
509
|
+
domain: z.string(),
|
|
510
|
+
title: z.string().min(1).max(100),
|
|
511
|
+
description: z.string().min(1).max(100),
|
|
512
|
+
websiteUrl: z.url().max(255).optional(),
|
|
513
|
+
iconSrc: z.url().max(255).optional(),
|
|
514
|
+
dryRun: z.boolean().optional()
|
|
515
|
+
})).output(z.object({ serverFields: serverFieldsSchema }));
|
|
516
|
+
const getServerInfoContractV1 = oc.route({
|
|
517
|
+
path: "/v1/distribution/info",
|
|
518
|
+
method: "GET",
|
|
519
|
+
summary: "Get server info",
|
|
520
|
+
description: "Get info about a server",
|
|
521
|
+
tags: ["distribution"],
|
|
522
|
+
successDescription: "The server info"
|
|
523
|
+
}).errors({
|
|
524
|
+
NOT_FOUND: {},
|
|
525
|
+
BAD_REQUEST: {}
|
|
526
|
+
}).input(z.object({
|
|
527
|
+
projectId: z.string(),
|
|
528
|
+
domain: z.string()
|
|
529
|
+
})).output(z.object({ serverFields: serverFieldsSchema }));
|
|
352
530
|
const contract = {
|
|
353
531
|
teams: { list: { v1: listTeamsContractV1 } },
|
|
354
532
|
analytics: { get: { v1: getProjectAnalyticsContractV1 } },
|
|
355
533
|
deployments: {
|
|
356
|
-
list: { v1:
|
|
534
|
+
list: { v1: listDeploymentsContractV1 },
|
|
357
535
|
get: { v1: getDeploymentContractV1 },
|
|
358
536
|
uploadArtifact: { v1: uploadDeploymentArtifactContractV1 },
|
|
359
537
|
getLogs: { v1: getDeploymentLogsContractV1 }
|
|
@@ -361,7 +539,14 @@ const contract = {
|
|
|
361
539
|
environments: {
|
|
362
540
|
create: { v1: createEnvironmentContractV1 },
|
|
363
541
|
get: { v1: getEnvironmentContractV1 },
|
|
364
|
-
deploy: { v1: deployEnvironmentContractV1 }
|
|
542
|
+
deploy: { v1: deployEnvironmentContractV1 },
|
|
543
|
+
getLogs: { v1: getLogsContractV1 }
|
|
544
|
+
},
|
|
545
|
+
environmentVariables: {
|
|
546
|
+
list: { v1: listEnvironmentVariablesContractV1 },
|
|
547
|
+
create: { v1: createEnvironmentVariablesContractV1 },
|
|
548
|
+
update: { v1: updateEnvironmentVariableContractV1 },
|
|
549
|
+
delete: { v1: deleteEnvironmentVariableContractV1 }
|
|
365
550
|
},
|
|
366
551
|
projects: {
|
|
367
552
|
update: { v1: updateProjectContractV1 },
|
|
@@ -369,8 +554,12 @@ const contract = {
|
|
|
369
554
|
list: { v1: listProjectsContractV1 },
|
|
370
555
|
create: { v1: createProjectContractV1 },
|
|
371
556
|
delete: { v1: deleteProjectContractV1 }
|
|
557
|
+
},
|
|
558
|
+
tunnels: { getTicket: { v1: getTunnelTicketContractV1 } },
|
|
559
|
+
distribution: {
|
|
560
|
+
publish: { v1: publishServerContractV1 },
|
|
561
|
+
info: { v1: getServerInfoContractV1 }
|
|
372
562
|
}
|
|
373
563
|
};
|
|
374
|
-
|
|
375
564
|
//#endregion
|
|
376
|
-
export { buildSettingsSchema, contract, createEnvironmentContractV1, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, transportSchema };
|
|
565
|
+
export { buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, serverFieldsSchema, 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.ee8089b",
|
|
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.
|
|
20
|
+
"@orpc/contract": "^1.13.8",
|
|
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.
|
|
28
|
+
"tsdown": "^0.21.4",
|
|
27
29
|
"typescript": "^5.9.3",
|
|
28
|
-
"vitest": "^4.0
|
|
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
|
}
|