@alpic-ai/api 0.0.0-staging.fb9eb3f → 0.0.0-staging.fc7750c

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
@@ -1,6 +1,6 @@
1
- import * as _orpc_contract0 from "@orpc/contract";
2
- import { InferContractRouterInputs, InferContractRouterOutputs } from "@orpc/contract";
3
1
  import { z } from "zod";
2
+ import * as _$_orpc_contract0 from "@orpc/contract";
3
+ import { InferContractRouterInputs, InferContractRouterOutputs } from "@orpc/contract";
4
4
 
5
5
  //#region src/api.contract.d.ts
6
6
  type ApiContext = {
@@ -16,7 +16,7 @@ declare const deploymentStatusSchema: z.ZodEnum<{
16
16
  failed: "failed";
17
17
  canceled: "canceled";
18
18
  }>;
19
- declare const createEnvironmentContractV1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
19
+ declare const createEnvironmentContractV1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
20
20
  projectId: z.ZodString;
21
21
  name: z.ZodString;
22
22
  sourceBranch: z.ZodString;
@@ -32,14 +32,14 @@ declare const createEnvironmentContractV1: _orpc_contract0.ContractProcedureBuil
32
32
  urls: z.ZodArray<z.ZodString>;
33
33
  createdAt: z.ZodCoercedDate<unknown>;
34
34
  projectId: z.ZodString;
35
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
35
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
36
36
  NOT_FOUND: {};
37
37
  BAD_REQUEST: {};
38
38
  }>, Record<never, never>>;
39
39
  declare const contract: {
40
40
  teams: {
41
41
  list: {
42
- v1: _orpc_contract0.ContractProcedureBuilderWithOutput<_orpc_contract0.Schema<unknown, unknown>, z.ZodArray<z.ZodObject<{
42
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithOutput<_$_orpc_contract0.Schema<unknown, unknown>, z.ZodArray<z.ZodObject<{
43
43
  id: z.ZodString;
44
44
  name: z.ZodString;
45
45
  createdAt: z.ZodCoercedDate<unknown>;
@@ -49,7 +49,7 @@ declare const contract: {
49
49
  };
50
50
  analytics: {
51
51
  get: {
52
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
52
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
53
53
  projectId: z.ZodString;
54
54
  startTimestamp: z.ZodCoercedNumber<unknown>;
55
55
  endTimestamp: z.ZodCoercedNumber<unknown>;
@@ -92,7 +92,7 @@ declare const contract: {
92
92
  categories: z.ZodRecord<z.ZodString, z.ZodUnknown>;
93
93
  }, z.core.$strip>>;
94
94
  }, z.core.$strip>;
95
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
95
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
96
96
  NOT_FOUND: {};
97
97
  BAD_REQUEST: {};
98
98
  }>, Record<never, never>>;
@@ -100,7 +100,7 @@ declare const contract: {
100
100
  };
101
101
  deployments: {
102
102
  list: {
103
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
103
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
104
104
  projectId: z.ZodString;
105
105
  status: z.ZodOptional<z.ZodArray<z.ZodEnum<{
106
106
  ongoing: "ongoing";
@@ -128,12 +128,12 @@ declare const contract: {
128
128
  environmentName: z.ZodString;
129
129
  isCurrent: z.ZodBoolean;
130
130
  deploymentPageUrl: z.ZodNullable<z.ZodURL>;
131
- }, z.core.$strip>>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
131
+ }, z.core.$strip>>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
132
132
  NOT_FOUND: {};
133
133
  }>, Record<never, never>>;
134
134
  };
135
135
  get: {
136
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
136
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
137
137
  deploymentId: z.ZodString;
138
138
  }, z.core.$strip>, z.ZodObject<{
139
139
  id: z.ZodString;
@@ -154,12 +154,12 @@ declare const contract: {
154
154
  environmentName: z.ZodString;
155
155
  isCurrent: z.ZodBoolean;
156
156
  deploymentPageUrl: z.ZodNullable<z.ZodURL>;
157
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
157
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
158
158
  NOT_FOUND: {};
159
159
  }>, Record<never, never>>;
160
160
  };
161
161
  uploadArtifact: {
162
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
162
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
163
163
  teamId: z.ZodOptional<z.ZodString>;
164
164
  }, z.core.$strip>>, z.ZodObject<{
165
165
  uploadUrl: z.ZodURL;
@@ -168,7 +168,7 @@ declare const contract: {
168
168
  }, z.core.$strip>, Record<never, never>, Record<never, never>>;
169
169
  };
170
170
  getLogs: {
171
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
171
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
172
172
  deploymentId: z.ZodString;
173
173
  }, z.core.$strip>, z.ZodObject<{
174
174
  logs: z.ZodArray<z.ZodObject<{
@@ -176,14 +176,14 @@ declare const contract: {
176
176
  content: z.ZodOptional<z.ZodString>;
177
177
  }, z.core.$strip>>;
178
178
  hasMoreLogs: z.ZodBoolean;
179
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
179
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
180
180
  NOT_FOUND: {};
181
181
  }>, Record<never, never>>;
182
182
  };
183
183
  };
184
184
  environments: {
185
185
  create: {
186
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
186
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
187
187
  projectId: z.ZodString;
188
188
  name: z.ZodString;
189
189
  sourceBranch: z.ZodString;
@@ -199,13 +199,13 @@ declare const contract: {
199
199
  urls: z.ZodArray<z.ZodString>;
200
200
  createdAt: z.ZodCoercedDate<unknown>;
201
201
  projectId: z.ZodString;
202
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
202
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
203
203
  NOT_FOUND: {};
204
204
  BAD_REQUEST: {};
205
205
  }>, Record<never, never>>;
206
206
  };
207
207
  get: {
208
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
208
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
209
209
  environmentId: z.ZodString;
210
210
  }, z.core.$strip>, z.ZodObject<{
211
211
  id: z.ZodString;
@@ -215,12 +215,12 @@ declare const contract: {
215
215
  domains: z.ZodArray<z.ZodURL>;
216
216
  createdAt: z.ZodCoercedDate<unknown>;
217
217
  projectId: z.ZodString;
218
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
218
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
219
219
  NOT_FOUND: {};
220
220
  }>, Record<never, never>>;
221
221
  };
222
222
  deploy: {
223
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
223
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
224
224
  environmentId: z.ZodString;
225
225
  token: z.ZodOptional<z.ZodString>;
226
226
  }, z.core.$strip>, z.ZodObject<{
@@ -242,13 +242,13 @@ declare const contract: {
242
242
  environmentName: z.ZodString;
243
243
  isCurrent: z.ZodBoolean;
244
244
  deploymentPageUrl: z.ZodNullable<z.ZodURL>;
245
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
245
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
246
246
  NOT_FOUND: {};
247
247
  BAD_REQUEST: {};
248
248
  }>, Record<never, never>>;
249
249
  };
250
250
  getLogs: {
251
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
251
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
252
252
  environmentId: z.ZodString;
253
253
  since: z.ZodOptional<z.ZodString>;
254
254
  until: z.ZodOptional<z.ZodString>;
@@ -278,7 +278,39 @@ declare const contract: {
278
278
  durationInMs: z.ZodOptional<z.ZodNumber>;
279
279
  }, z.core.$strip>>;
280
280
  nextToken: z.ZodNullable<z.ZodString>;
281
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
281
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
282
+ NOT_FOUND: {};
283
+ BAD_REQUEST: {};
284
+ }>, Record<never, never>>;
285
+ };
286
+ getLatestLogs: {
287
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
288
+ environmentId: z.ZodString;
289
+ limit: z.ZodDefault<z.ZodCoercedNumber<unknown>>;
290
+ level: z.ZodOptional<z.ZodArray<z.ZodEnum<{
291
+ INFO: "INFO";
292
+ ERROR: "ERROR";
293
+ WARNING: "WARNING";
294
+ DEBUG: "DEBUG";
295
+ }>>>;
296
+ search: z.ZodOptional<z.ZodString>;
297
+ }, z.core.$strip>, z.ZodObject<{
298
+ logs: z.ZodArray<z.ZodObject<{
299
+ timestamp: z.ZodCoercedDate<unknown>;
300
+ type: z.ZodEnum<{
301
+ INFO: "INFO";
302
+ ERROR: "ERROR";
303
+ WARNING: "WARNING";
304
+ DEBUG: "DEBUG";
305
+ START: "START";
306
+ END: "END";
307
+ }>;
308
+ requestId: z.ZodString;
309
+ content: z.ZodOptional<z.ZodString>;
310
+ method: z.ZodOptional<z.ZodString>;
311
+ durationInMs: z.ZodOptional<z.ZodNumber>;
312
+ }, z.core.$strip>>;
313
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
282
314
  NOT_FOUND: {};
283
315
  BAD_REQUEST: {};
284
316
  }>, Record<never, never>>;
@@ -286,7 +318,7 @@ declare const contract: {
286
318
  };
287
319
  environmentVariables: {
288
320
  list: {
289
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
321
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
290
322
  environmentId: z.ZodString;
291
323
  }, z.core.$strip>, z.ZodArray<z.ZodObject<{
292
324
  id: z.ZodString;
@@ -294,12 +326,12 @@ declare const contract: {
294
326
  value: z.ZodString;
295
327
  isSecret: z.ZodBoolean;
296
328
  createdAt: z.ZodCoercedDate<unknown>;
297
- }, z.core.$strip>>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
329
+ }, z.core.$strip>>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
298
330
  NOT_FOUND: {};
299
331
  }>, Record<never, never>>;
300
332
  };
301
333
  create: {
302
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
334
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
303
335
  environmentId: z.ZodString;
304
336
  environmentVariables: z.ZodArray<z.ZodObject<{
305
337
  key: z.ZodString;
@@ -308,37 +340,37 @@ declare const contract: {
308
340
  }, z.core.$strip>>;
309
341
  }, z.core.$strip>, z.ZodObject<{
310
342
  success: z.ZodLiteral<true>;
311
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
343
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
312
344
  NOT_FOUND: {};
313
345
  BAD_REQUEST: {};
314
346
  }>, Record<never, never>>;
315
347
  };
316
348
  update: {
317
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
349
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
318
350
  environmentVariableId: z.ZodString;
319
351
  key: z.ZodString;
320
352
  value: z.ZodOptional<z.ZodString>;
321
- isSecret: z.ZodDefault<z.ZodBoolean>;
353
+ isSecret: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
322
354
  }, z.core.$strip>, z.ZodObject<{
323
355
  success: z.ZodLiteral<true>;
324
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
356
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
325
357
  NOT_FOUND: {};
326
358
  BAD_REQUEST: {};
327
359
  }>, Record<never, never>>;
328
360
  };
329
361
  delete: {
330
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
362
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
331
363
  environmentVariableId: z.ZodString;
332
364
  }, z.core.$strip>, z.ZodObject<{
333
365
  success: z.ZodLiteral<true>;
334
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
366
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
335
367
  NOT_FOUND: {};
336
368
  }>, Record<never, never>>;
337
369
  };
338
370
  };
339
371
  projects: {
340
372
  update: {
341
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
373
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
342
374
  projectId: z.ZodString;
343
375
  name: z.ZodOptional<z.ZodString>;
344
376
  sourceRepository: z.ZodOptional<z.ZodNullable<z.ZodString>>;
@@ -410,13 +442,13 @@ declare const contract: {
410
442
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
411
443
  }, z.core.$strip>>;
412
444
  }, z.core.$strip>>;
413
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
445
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
414
446
  NOT_FOUND: {};
415
447
  BAD_REQUEST: {};
416
448
  }>, Record<never, never>>;
417
449
  };
418
450
  get: {
419
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
451
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
420
452
  projectId: z.ZodString;
421
453
  }, z.core.$strip>, z.ZodObject<{
422
454
  id: z.ZodString;
@@ -486,12 +518,12 @@ declare const contract: {
486
518
  completedAt: z.ZodNullable<z.ZodCoercedDate<unknown>>;
487
519
  }, z.core.$strip>>;
488
520
  }, z.core.$strip>>;
489
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
521
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
490
522
  NOT_FOUND: {};
491
523
  }>, Record<never, never>>;
492
524
  };
493
525
  list: {
494
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
526
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodOptional<z.ZodObject<{
495
527
  teamId: z.ZodOptional<z.ZodString>;
496
528
  }, z.core.$strip>>, z.ZodArray<z.ZodObject<{
497
529
  id: z.ZodString;
@@ -564,7 +596,7 @@ declare const contract: {
564
596
  }, z.core.$strip>>, Record<never, never>, Record<never, never>>;
565
597
  };
566
598
  create: {
567
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
599
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
568
600
  teamId: z.ZodOptional<z.ZodString>;
569
601
  name: z.ZodString;
570
602
  sourceRepository: z.ZodOptional<z.ZodString>;
@@ -622,24 +654,86 @@ declare const contract: {
622
654
  installCommand: z.ZodNullable<z.ZodString>;
623
655
  startCommand: z.ZodNullable<z.ZodString>;
624
656
  createdAt: z.ZodCoercedDate<unknown>;
625
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
657
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
626
658
  NOT_FOUND: {};
627
659
  BAD_REQUEST: {};
628
660
  }>, Record<never, never>>;
629
661
  };
630
662
  delete: {
631
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
663
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
632
664
  projectId: z.ZodString;
633
665
  }, z.core.$strip>, z.ZodObject<{
634
666
  success: z.ZodLiteral<true>;
635
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
667
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
636
668
  NOT_FOUND: {};
637
669
  }>, Record<never, never>>;
638
670
  };
639
671
  };
672
+ playground: {
673
+ get: {
674
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
675
+ environmentId: z.ZodString;
676
+ }, z.core.$strip>, z.ZodObject<{
677
+ isPlaygroundEnabled: z.ZodBoolean;
678
+ serverMetadata: z.ZodNullable<z.ZodObject<{
679
+ name: z.ZodString;
680
+ description: z.ZodString;
681
+ headers: z.ZodArray<z.ZodObject<{
682
+ name: z.ZodString;
683
+ description: z.ZodString;
684
+ isRequired: z.ZodBoolean;
685
+ isSecret: z.ZodBoolean;
686
+ }, z.core.$strip>>;
687
+ examplePrompts: z.ZodArray<z.ZodObject<{
688
+ title: z.ZodString;
689
+ prompt: z.ZodString;
690
+ }, z.core.$strip>>;
691
+ }, z.core.$strip>>;
692
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
693
+ NOT_FOUND: {};
694
+ }>, Record<never, never>>;
695
+ };
696
+ upsert: {
697
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
698
+ environmentId: z.ZodString;
699
+ isPlaygroundEnabled: z.ZodOptional<z.ZodBoolean>;
700
+ name: z.ZodOptional<z.ZodString>;
701
+ description: z.ZodOptional<z.ZodString>;
702
+ headers: z.ZodOptional<z.ZodArray<z.ZodObject<{
703
+ name: z.ZodString;
704
+ description: z.ZodString;
705
+ isRequired: z.ZodDefault<z.ZodBoolean>;
706
+ isSecret: z.ZodDefault<z.ZodBoolean>;
707
+ }, z.core.$strip>>>;
708
+ examplePrompts: z.ZodOptional<z.ZodArray<z.ZodObject<{
709
+ title: z.ZodString;
710
+ prompt: z.ZodString;
711
+ }, z.core.$strip>>>;
712
+ }, z.core.$strip>, z.ZodObject<{
713
+ isPlaygroundEnabled: z.ZodBoolean;
714
+ serverMetadata: z.ZodNullable<z.ZodObject<{
715
+ name: z.ZodString;
716
+ description: z.ZodString;
717
+ headers: z.ZodArray<z.ZodObject<{
718
+ name: z.ZodString;
719
+ description: z.ZodString;
720
+ isRequired: z.ZodBoolean;
721
+ isSecret: z.ZodBoolean;
722
+ }, z.core.$strip>>;
723
+ examplePrompts: z.ZodArray<z.ZodObject<{
724
+ title: z.ZodString;
725
+ prompt: z.ZodString;
726
+ }, z.core.$strip>>;
727
+ }, z.core.$strip>>;
728
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
729
+ NOT_FOUND: {};
730
+ BAD_REQUEST: {};
731
+ }>, Record<never, never>>;
732
+ };
733
+ };
640
734
  tunnels: {
641
735
  getTicket: {
642
- v1: _orpc_contract0.ContractProcedureBuilderWithOutput<_orpc_contract0.Schema<unknown, unknown>, z.ZodObject<{
736
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithOutput<_$_orpc_contract0.Schema<unknown, unknown>, z.ZodObject<{
643
737
  subdomain: z.ZodString;
644
738
  ticket: z.ZodString;
645
739
  tunnelHost: z.ZodString;
@@ -648,7 +742,7 @@ declare const contract: {
648
742
  };
649
743
  distribution: {
650
744
  publish: {
651
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
745
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
652
746
  projectId: z.ZodString;
653
747
  domain: z.ZodString;
654
748
  title: z.ZodString;
@@ -680,13 +774,13 @@ declare const contract: {
680
774
  }, z.core.$strip>>>;
681
775
  }, z.core.$strip>>>;
682
776
  }, z.core.$strip>;
683
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
777
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
684
778
  NOT_FOUND: {};
685
779
  BAD_REQUEST: {};
686
780
  }>, Record<never, never>>;
687
781
  };
688
782
  get: {
689
- v1: _orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
783
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
690
784
  projectId: z.ZodString;
691
785
  domain: z.ZodString;
692
786
  }, z.core.$strip>, z.ZodObject<{
@@ -713,16 +807,134 @@ declare const contract: {
713
807
  }, z.core.$strip>>>;
714
808
  }, z.core.$strip>>>;
715
809
  }, z.core.$strip>;
716
- }, z.core.$strip>, _orpc_contract0.MergedErrorMap<Record<never, never>, {
810
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
811
+ NOT_FOUND: {};
812
+ BAD_REQUEST: {};
813
+ }>, Record<never, never>>;
814
+ };
815
+ };
816
+ beacon: {
817
+ create: {
818
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
819
+ targetUrl: z.ZodURL;
820
+ teamId: z.ZodOptional<z.ZodString>;
821
+ projectId: z.ZodOptional<z.ZodString>;
822
+ excludeCategories: z.ZodOptional<z.ZodArray<z.ZodEnum<{
823
+ connectivity: "connectivity";
824
+ "tool-metadata": "tool-metadata";
825
+ "resource-metadata": "resource-metadata";
826
+ performance: "performance";
827
+ e2e: "e2e";
828
+ }>>>;
829
+ }, z.core.$strip>, z.ZodObject<{
830
+ id: z.ZodString;
831
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
717
832
  NOT_FOUND: {};
718
833
  BAD_REQUEST: {};
719
834
  }>, Record<never, never>>;
720
835
  };
836
+ get: {
837
+ v1: _$_orpc_contract0.ContractProcedureBuilderWithInputOutput<z.ZodObject<{
838
+ auditId: z.ZodString;
839
+ }, z.core.$strip>, z.ZodObject<{
840
+ id: z.ZodString;
841
+ targetUrl: z.ZodString;
842
+ status: z.ZodEnum<{
843
+ failed: "failed";
844
+ pending: "pending";
845
+ partial: "partial";
846
+ completed: "completed";
847
+ }>;
848
+ durationMs: z.ZodNullable<z.ZodNumber>;
849
+ createdAt: z.ZodCoercedDate<unknown>;
850
+ report: z.ZodNullable<z.ZodObject<{
851
+ schemaVersion: z.ZodString;
852
+ auditId: z.ZodString;
853
+ targetUrl: z.ZodString;
854
+ startedAt: z.ZodString;
855
+ completedAt: z.ZodString;
856
+ durationMs: z.ZodNumber;
857
+ results: z.ZodArray<z.ZodObject<{
858
+ checkId: z.ZodString;
859
+ checkName: z.ZodString;
860
+ description: z.ZodString;
861
+ status: z.ZodEnum<{
862
+ pending: "pending";
863
+ pass: "pass";
864
+ fail: "fail";
865
+ skip: "skip";
866
+ }>;
867
+ message: z.ZodString;
868
+ skipReason: z.ZodOptional<z.ZodString>;
869
+ severity: z.ZodEnum<{
870
+ error: "error";
871
+ warning: "warning";
872
+ info: "info";
873
+ }>;
874
+ category: z.ZodEnum<{
875
+ connectivity: "connectivity";
876
+ "tool-metadata": "tool-metadata";
877
+ "resource-metadata": "resource-metadata";
878
+ performance: "performance";
879
+ e2e: "e2e";
880
+ }>;
881
+ scope: z.ZodEnum<{
882
+ server: "server";
883
+ view: "view";
884
+ }>;
885
+ platforms: z.ZodOptional<z.ZodReadonly<z.ZodArray<z.ZodEnum<{
886
+ chatgpt: "chatgpt";
887
+ claudeai: "claudeai";
888
+ }>>>>;
889
+ durationMs: z.ZodNumber;
890
+ details: z.ZodOptional<z.ZodArray<z.ZodObject<{
891
+ label: z.ZodString;
892
+ value: z.ZodOptional<z.ZodString>;
893
+ }, z.core.$strip>>>;
894
+ hint: z.ZodOptional<z.ZodObject<{
895
+ text: z.ZodString;
896
+ }, z.core.$strip>>;
897
+ }, z.core.$strip>>;
898
+ requiresAuth: z.ZodBoolean;
899
+ hasViewSupport: z.ZodBoolean;
900
+ viewPlatforms: z.ZodOptional<z.ZodReadonly<z.ZodArray<z.ZodEnum<{
901
+ chatgpt: "chatgpt";
902
+ claudeai: "claudeai";
903
+ }>>>>;
904
+ isReadyForPlatform: z.ZodRecord<z.ZodEnum<{
905
+ chatgpt: "chatgpt";
906
+ claudeai: "claudeai";
907
+ }>, z.ZodBoolean>;
908
+ widgetScreenshotKeys: z.ZodObject<{
909
+ chatgpt: z.ZodOptional<z.ZodString>;
910
+ claudeai: z.ZodOptional<z.ZodString>;
911
+ }, z.core.$strip>;
912
+ widgetScreenshots: z.ZodObject<{
913
+ chatgpt: z.ZodOptional<z.ZodObject<{
914
+ url: z.ZodString;
915
+ }, z.core.$strip>>;
916
+ claudeai: z.ZodOptional<z.ZodObject<{
917
+ url: z.ZodString;
918
+ }, z.core.$strip>>;
919
+ }, z.core.$strip>;
920
+ }, z.core.$strip>>;
921
+ }, z.core.$strip>, _$_orpc_contract0.MergedErrorMap<Record<never, never>, {
922
+ NOT_FOUND: {};
923
+ }>, Record<never, never>>;
924
+ };
721
925
  };
722
926
  };
723
927
  type RouterInput = InferContractRouterInputs<typeof contract>;
724
928
  type RouterOutput = InferContractRouterOutputs<typeof contract>;
725
929
  //#endregion
930
+ //#region ../domains/src/platforms/schemas.d.ts
931
+ declare const platformSchema: z.ZodEnum<{
932
+ chatgpt: "chatgpt";
933
+ claudeai: "claudeai";
934
+ }>;
935
+ type Platform = z.infer<typeof platformSchema>;
936
+ declare const PLATFORM_LABELS: Record<Platform, string>;
937
+ //#endregion
726
938
  //#region src/schemas.d.ts
727
939
  declare const environmentVariableSchema: z.ZodObject<{
728
940
  key: z.ZodString;
@@ -734,6 +946,11 @@ declare const environmentVariablesSchema: z.ZodArray<z.ZodObject<{
734
946
  value: z.ZodString;
735
947
  isSecret: z.ZodDefault<z.ZodBoolean>;
736
948
  }, z.core.$strip>>;
949
+ declare const updateEnvironmentVariableSchema: z.ZodObject<{
950
+ key: z.ZodString;
951
+ value: z.ZodOptional<z.ZodString>;
952
+ isSecret: z.ZodOptional<z.ZodDefault<z.ZodBoolean>>;
953
+ }, z.core.$strip>;
737
954
  declare const buildSettingsSchema: z.ZodObject<{
738
955
  installCommand: z.ZodOptional<z.ZodString>;
739
956
  buildCommand: z.ZodOptional<z.ZodString>;
@@ -753,6 +970,16 @@ declare const transportSchema: z.ZodEnum<{
753
970
  streamablehttp: "streamablehttp";
754
971
  }>;
755
972
  type Transport = z.infer<typeof transportSchema>;
973
+ declare const playgroundHeaderSchema: z.ZodObject<{
974
+ name: z.ZodString;
975
+ description: z.ZodString;
976
+ isRequired: z.ZodDefault<z.ZodBoolean>;
977
+ isSecret: z.ZodDefault<z.ZodBoolean>;
978
+ }, z.core.$strip>;
979
+ declare const playgroundExamplePromptSchema: z.ZodObject<{
980
+ title: z.ZodString;
981
+ prompt: z.ZodString;
982
+ }, z.core.$strip>;
756
983
  declare const serverFieldsSchema: z.ZodObject<{
757
984
  $schema: z.ZodString;
758
985
  name: z.ZodString;
@@ -777,4 +1004,4 @@ declare const serverFieldsSchema: z.ZodObject<{
777
1004
  }, z.core.$strip>>>;
778
1005
  }, z.core.$strip>;
779
1006
  //#endregion
780
- export { ApiContext, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, serverFieldsSchema, transportSchema };
1007
+ export { ApiContext, PLATFORM_LABELS, type Platform, RouterInput, RouterOutput, Runtime, Transport, buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, playgroundExamplePromptSchema, playgroundHeaderSchema, runtimeSchema, serverFieldsSchema, transportSchema, updateEnvironmentVariableSchema };
package/dist/index.mjs CHANGED
@@ -1,6 +1,278 @@
1
+ import { z } from "zod";
1
2
  import { oc } from "@orpc/contract";
2
3
  import ms from "ms";
3
- import { z } from "zod";
4
+ const platformSchema = z.enum(["chatgpt", "claudeai"]);
5
+ const PLATFORM_LABELS = {
6
+ chatgpt: "ChatGPT",
7
+ claudeai: "Claude.ai"
8
+ };
9
+ const auditStatusSchema = z.enum([
10
+ "pending",
11
+ "partial",
12
+ "completed",
13
+ "failed"
14
+ ]);
15
+ const checkSeveritySchema = z.enum([
16
+ "error",
17
+ "warning",
18
+ "info"
19
+ ]);
20
+ const checkCategorySchema = z.enum([
21
+ "connectivity",
22
+ "tool-metadata",
23
+ "resource-metadata",
24
+ "performance",
25
+ "e2e"
26
+ ]);
27
+ const checkScopeSchema = z.enum(["server", "view"]);
28
+ const checkDetailSchema = z.object({
29
+ label: z.string(),
30
+ value: z.string().optional()
31
+ });
32
+ const checkResultSchema = z.object({
33
+ checkId: z.string(),
34
+ checkName: z.string(),
35
+ description: z.string(),
36
+ status: z.enum([
37
+ "pass",
38
+ "fail",
39
+ "skip",
40
+ "pending"
41
+ ]),
42
+ message: z.string(),
43
+ skipReason: z.string().optional(),
44
+ severity: checkSeveritySchema,
45
+ category: checkCategorySchema,
46
+ scope: checkScopeSchema,
47
+ platforms: z.array(platformSchema).readonly().optional(),
48
+ durationMs: z.number(),
49
+ details: z.array(checkDetailSchema).optional(),
50
+ hint: z.object({ text: z.string() }).optional()
51
+ });
52
+ const auditReportSchema = z.object({
53
+ schemaVersion: z.string(),
54
+ auditId: z.string(),
55
+ targetUrl: z.string(),
56
+ startedAt: z.string(),
57
+ completedAt: z.string(),
58
+ durationMs: z.number(),
59
+ results: z.array(checkResultSchema),
60
+ requiresAuth: z.boolean(),
61
+ hasViewSupport: z.boolean(),
62
+ viewPlatforms: z.array(platformSchema).readonly().optional(),
63
+ isReadyForPlatform: z.record(platformSchema, z.boolean()),
64
+ widgetScreenshotKeys: z.object({
65
+ chatgpt: z.string().optional(),
66
+ claudeai: z.string().optional()
67
+ })
68
+ });
69
+ const widgetScreenshotSchema = z.object({ url: z.string() });
70
+ const auditReportWithScreenshotsSchema = auditReportSchema.extend({ widgetScreenshots: z.object({
71
+ chatgpt: widgetScreenshotSchema.optional(),
72
+ claudeai: widgetScreenshotSchema.optional()
73
+ }) });
74
+ z.object({
75
+ id: z.string(),
76
+ createdAt: z.coerce.date(),
77
+ environmentId: z.string(),
78
+ content: z.string(),
79
+ source: z.enum(["model", "user"])
80
+ });
81
+ z.object({
82
+ content: z.string(),
83
+ source: z.enum(["model", "user"])
84
+ });
85
+ const toolDefinitionSchema = z.object({
86
+ name: z.string(),
87
+ title: z.string().optional(),
88
+ description: z.string().optional(),
89
+ annotations: z.object({
90
+ readOnlyHint: z.boolean().optional(),
91
+ destructiveHint: z.boolean().optional(),
92
+ openWorldHint: z.boolean().optional(),
93
+ idempotentHint: z.boolean().optional()
94
+ }).optional()
95
+ });
96
+ const positiveTestCaseSchema = z.object({
97
+ scenario: z.string(),
98
+ userPrompt: z.string(),
99
+ toolTriggered: z.string().optional(),
100
+ expectedOutput: z.string().optional()
101
+ }).partial().describe("Each case: Scenario, User prompt, Tool triggered, Expected output.");
102
+ /** Accepts either a valid email or URL. */
103
+ const supportChannelSchema = z.string().refine((value) => z.email().safeParse(value).success || z.url().safeParse(value).success, { error: "Must be a valid email or URL" });
104
+ const chatgptCategorySchema = z.enum([
105
+ "BUSINESS",
106
+ "COLLABORATION",
107
+ "DESIGN",
108
+ "DEVELOPER_TOOLS",
109
+ "EDUCATION",
110
+ "ENTERTAINMENT",
111
+ "FINANCE",
112
+ "FOOD",
113
+ "LIFESTYLE",
114
+ "NEWS",
115
+ "PRODUCTIVITY",
116
+ "SHOPPING",
117
+ "TRAVEL"
118
+ ]);
119
+ const chatgptAuthenticationSchema = z.enum(["No auth needed", "OAuth 2.0"]);
120
+ const chatgptAllowedCountriesSchema = z.enum(["Allow all", "Restrict to specific countries"]);
121
+ const negativeTestCaseSchema = z.object({
122
+ scenario: z.string(),
123
+ userPrompt: z.string()
124
+ }).partial().describe("Each case: Scenario + User prompt (the app should NOT trigger).");
125
+ const chatgptToolJustificationSchema = z.object({
126
+ toolName: z.string(),
127
+ readOnlyJustification: z.string(),
128
+ openWorldJustification: z.string(),
129
+ destructiveJustification: z.string()
130
+ }).describe("Per-tool justification of each MCP annotation value (one sentence per hint).");
131
+ const chatgptTranslationSchema = z.object({
132
+ locale: z.string(),
133
+ tagline: z.string().optional(),
134
+ description: z.string().optional()
135
+ }).describe("Locale-scoped override for tagline + description. English (US) is the default.");
136
+ /**
137
+ * Field order mirrors the ChatGPT (OpenAI) submission spreadsheet, grouped by section.
138
+ * When adding/removing/reordering fields, keep this in sync with the sheet.
139
+ */
140
+ const chatgptSubmissionFormDataSchema = z.object({
141
+ logoLight: z.string().describe("Logo icon for light mode. Square PNG, no borders or rounded corners (clients apply circular cropping)."),
142
+ logoDark: z.string().describe("Logo icon for dark mode. Square PNG. Same specs as the light icon."),
143
+ appName: z.string().describe("The name users will see in ChatGPT and in the Apps Directory."),
144
+ tagline: z.string().max(30).describe("Plain-language phrase focused on function and user value. 30 chars max."),
145
+ description: z.string().describe("Clear, engaging description highlighting what the app does and why people will love it. Appears publicly on the directory page."),
146
+ category: chatgptCategorySchema.describe("Category from the OpenAI taxonomy."),
147
+ developerName: z.string().describe("Developer name shown publicly on the app's directory page."),
148
+ companyUrl: z.url().describe("Your company's main website URL."),
149
+ supportChannel: supportChannelSchema.describe("Customer support URL or email address."),
150
+ privacyPolicyUrl: z.url().describe("URL to your privacy policy."),
151
+ termsOfServiceUrl: z.url().describe("URL to the app's terms of service."),
152
+ demoRecordingUrl: z.url().describe("URL to a video demonstrating the app, recorded via OpenAI Developer Mode. Cover all main use cases on web, iOS, and Android."),
153
+ appCommerceAndPurchasing: z.boolean().describe("Checkbox: 'My app links or directs users out of ChatGPT to make purchases.' Defaults to false. Verify the app does not offer digital goods."),
154
+ serverUrl: z.url().describe("URL of the MCP server."),
155
+ authentication: chatgptAuthenticationSchema.describe("OAuth 2.0 or No auth. OAuth configuration is auto-discovered from the MCP server's metadata."),
156
+ tools: z.array(toolDefinitionSchema).describe("List of tools exposed by the MCP server (auto-populated from the production server's manifest)."),
157
+ toolJustifications: z.array(chatgptToolJustificationSchema).describe("Per-tool justification of `readOnlyHint`, `openWorldHint`, and `destructiveHint` annotation values."),
158
+ testCases: z.array(positiveTestCaseSchema).describe("At least 5 positive test cases. Each: Scenario, User prompt, Tool triggered, Expected output. Coverage over all major use cases."),
159
+ negativeTestCases: z.array(negativeTestCaseSchema).describe("3 negative test cases — prompts where the app should NOT trigger but the model might think it's relevant."),
160
+ screenshots: z.array(z.url()).describe("URLs of in-app screenshots. Widget apps must show the widget UI; non-widget apps show the model response. Min 1, max 4. First three are public."),
161
+ translations: z.array(chatgptTranslationSchema).describe("Per-locale translation of tagline + description. English (US) is the default."),
162
+ allowedCountries: chatgptAllowedCountriesSchema.describe("'Allow all' or restrict to a specific list. See OpenAI's supported countries list."),
163
+ releaseNotes: z.string().describe("Publicly displayed on the app details page.")
164
+ });
165
+ const claudeCategorySchema = z.enum([
166
+ "Business & Productivity",
167
+ "Communication",
168
+ "Data & Analytics",
169
+ "Development tools",
170
+ "Financial Services",
171
+ "Consumer Health",
172
+ "Health & Life Sciences",
173
+ "Media & Entertainment",
174
+ "Commerce & Shopping"
175
+ ]);
176
+ z.enum([
177
+ "No auth needed",
178
+ "OAuth 2.0",
179
+ "Custom URL"
180
+ ]);
181
+ const claudeMcpUrlTypeSchema = z.enum(["Universal URL", "Custom MCP URLs"]);
182
+ z.enum(["Static OAuth Client", "Dynamic OAuth Client (DCR / CIMD)"]);
183
+ const claudeReadWriteCapabilitiesSchema = z.enum([
184
+ "Read only",
185
+ "Write only",
186
+ "Read + write"
187
+ ]);
188
+ const claudeTransportSchema = z.enum(["Streamable HTTP", "SSE"]);
189
+ const claudeThirdPartySchema = z.enum([
190
+ "Web access (open web fetch / scraping / arbitrary URLs)",
191
+ "Third-party AI model integration",
192
+ "Third-party data retrieval (via workflow / aggregator)",
193
+ "Third-party data modification (via workflow / aggregator)",
194
+ "N/A"
195
+ ]);
196
+ const claudeDataHandlingSchema = z.enum([
197
+ "Server only accesses data explicitly requested by user",
198
+ "No data is stored beyond session requirements",
199
+ "Data transmission is encrypted (HTTPS / TLS)",
200
+ "GDPR compliant (if applicable)"
201
+ ]);
202
+ const claudeSponsoredContentSchema = z.enum([
203
+ "No, there is no sponsored content or advertisements",
204
+ "Yes, there are banner ads or other paid visual elements",
205
+ "Yes, returned content or ranking is impacted by sponsorship or ad placement"
206
+ ]);
207
+ /**
208
+ * Field order mirrors the Claude (Anthropic) submission spreadsheet, grouped by section.
209
+ * When adding/removing/reordering fields, keep this in sync with the sheet.
210
+ */
211
+ const claudeSubmissionFormDataSchema = z.object({
212
+ companyName: z.string().describe("Enter your company's legal name or the name under which your product is publicly known. This is used for internal tracking and may appear in directory listings."),
213
+ companyUrl: z.url().describe("Your company's main website URL, e.g. https://mycompany.com. Must be a valid URL with https://. This should be the root domain of the company behind this MCP server."),
214
+ primaryContactName: z.string().describe("Full name of the person Anthropic should contact about this submission. This person will receive review feedback, approval notices, and any follow-up questions."),
215
+ primaryContactEmail: z.email().describe("Business email for the primary contact. Must be a valid email address. Anthropic uses this to communicate about your submission status, required changes, and post-listing issues. Avoid using personal email addresses."),
216
+ primaryContactRole: z.string().optional().describe("The job title or role of the primary contact (e.g. 'CTO', 'Developer Relations Lead', 'Founder'). Optional but helps Anthropic route questions to the right person."),
217
+ anthropicPointOfContact: z.string().optional().describe("If you have a direct contact at Anthropic (e.g. from a partnership or sales conversation), enter their name here. This is optional but can greatly help expedite the review process. Leave blank if you don't have one."),
218
+ appName: z.string().describe(`The public display name for your connector as it will appear in the Connectors Directory.
219
+
220
+ Rules:
221
+ (1) Do NOT include the words 'MCP' or 'Server' — these are auto-rejected.
222
+ (2) Use your brand/product name, e.g. 'Notion', 'Linear', 'Slack'.
223
+ (3) You must own or have the right to use this brand name. For example, don't call it 'Google Drive Helper' if you're not Google.`),
224
+ mcpUrlType: claudeMcpUrlTypeSchema.describe("Universal URL = one URL serves all users. Custom MCP URLs = signup URL + regex matching per-user URLs."),
225
+ serverUrl: z.url().describe("Production MCP server URL (https). Derived from the project's production environment by default."),
226
+ tagline: z.string().max(55).describe("Short blurb shown below the server name. 55 chars max."),
227
+ description: z.string().describe("50–100 words describing what the server does and its key capabilities. Lives on the directory listing."),
228
+ testCases: z.array(positiveTestCaseSchema).describe("At least 3 use cases with example prompts showing the value of the connector."),
229
+ connectionRequirements: z.string().describe(`Prerequisites before connecting:
230
+ • Free/premium account
231
+ • Admin seat
232
+ • Geographic availability
233
+ • Custom instance URL
234
+
235
+ State 'No special requirements.' if none.`),
236
+ readWriteCapabilities: claudeReadWriteCapabilitiesSchema.describe("Inferred from the `readOnlyHint` annotations on the MCP tools."),
237
+ isMcpApp: z.boolean().describe("True if the server exposes interactive UI elements (widgets). Inferred from the MCP connection."),
238
+ thirdPartyConnectionsAndWebAccess: z.array(claudeThirdPartySchema).describe("Multi-select of what the server reaches out to (web, third-party AI, data aggregators)."),
239
+ dataHandling: z.array(claudeDataHandlingSchema).describe("Multi-select of data-handling practices that accurately describe the server. Cannot be inferred — user must self-declare."),
240
+ personalDataHealthAccess: z.boolean().describe("True only if the connector gives users access to their own personal health data (medical records, lab results, health metrics)."),
241
+ categories: z.array(claudeCategorySchema).describe("Multi-select of categories that best describe the server in the directory."),
242
+ sponsoredContentsOrAdvertisement: claudeSponsoredContentSchema.describe("Disclose paid promotion or sponsored content. Cannot be filled by Alpic — user must self-declare."),
243
+ transportSupport: z.array(claudeTransportSchema).describe("Multi-select of transport protocols the server supports. Anthropic recommends Streamable HTTP (SSE may be deprecated later this year)."),
244
+ serverDocumentationLink: z.url().describe("Public docs URL covering what the MCP does, setup, debugging, and self-serve support. The Alpic playground may be used."),
245
+ privacyPolicyUrl: z.url().describe("URL to your privacy policy. Mandatory and displayed alongside the directory listing."),
246
+ supportChannel: supportChannelSchema.describe("Link or email for user support (help center, GitHub issues, docs, support@…). Displayed alongside the directory listing."),
247
+ testingCredentials: z.string().describe("Credentials for reviewers to verify functionality. Required if the server uses OAuth. No 2FA. Use mcp-review@anthropic.com if an accessible email is needed."),
248
+ tools: z.array(toolDefinitionSchema).describe("List of tools exposed by the MCP server (auto-populated from the production server's manifest)."),
249
+ toolTitlesAnnotationsConfirmed: z.boolean().describe("Confirmation that all tools have user-friendly titles and accurate annotations (readOnlyHint, destructiveHint, …)."),
250
+ logoLight: z.string().describe("Server/app logo for light mode. Square 1:1 aspect ratio. SVG preferred for Claude."),
251
+ screenshots: z.array(z.url()).describe("URLs of screenshots of the connector on Claude.ai or promo material. 3–5 ideal. ≥1000px width preferred, PNG, cropped to the app response. Videos welcome.")
252
+ });
253
+ const submissionMetaFieldsSchema = z.object({
254
+ id: z.string(),
255
+ environmentId: z.string(),
256
+ createdAt: z.coerce.date(),
257
+ updatedAt: z.coerce.date()
258
+ });
259
+ const claudeSubmissionSchemaInternal = submissionMetaFieldsSchema.extend({
260
+ platform: z.literal("claudeai"),
261
+ formData: claudeSubmissionFormDataSchema.partial()
262
+ });
263
+ const chatgptSubmissionSchemaInternal = submissionMetaFieldsSchema.extend({
264
+ platform: z.literal("chatgpt"),
265
+ formData: chatgptSubmissionFormDataSchema.partial()
266
+ });
267
+ z.discriminatedUnion("platform", [claudeSubmissionSchemaInternal, chatgptSubmissionSchemaInternal]);
268
+ z.union([claudeSubmissionFormDataSchema.partial(), chatgptSubmissionFormDataSchema.partial()]);
269
+ const subscriptionPlanSchema = z.enum([
270
+ "pro",
271
+ "business",
272
+ "enterprise"
273
+ ]);
274
+ z.object({ plan: subscriptionPlanSchema.nullable() });
275
+ //#endregion
4
276
  //#region src/schemas.ts
5
277
  const RESERVED_KEYS = [
6
278
  "_HANDLER",
@@ -35,7 +307,8 @@ const RESERVED_KEYS = [
35
307
  "BUILD_ARG_BUILD_OUTPUT_DIR",
36
308
  "BUILD_ARG_START_COMMAND",
37
309
  "ALPIC_HOST",
38
- "ALPIC_CUSTOM_DOMAINS"
310
+ "ALPIC_CUSTOM_DOMAINS",
311
+ "ALPIC_INTENT_META_KEY"
39
312
  ];
40
313
  const environmentVariableSchema = z.object({
41
314
  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"),
@@ -43,6 +316,10 @@ const environmentVariableSchema = z.object({
43
316
  isSecret: z.boolean().default(false)
44
317
  });
45
318
  const environmentVariablesSchema = z.array(environmentVariableSchema);
319
+ const updateEnvironmentVariableSchema = environmentVariableSchema.partial({
320
+ value: true,
321
+ isSecret: true
322
+ });
46
323
  const buildSettingsSchema = z.object({
47
324
  installCommand: z.string().optional(),
48
325
  buildCommand: z.string().optional(),
@@ -60,6 +337,16 @@ const transportSchema = z.enum([
60
337
  "sse",
61
338
  "streamablehttp"
62
339
  ]);
340
+ const playgroundHeaderSchema = z.object({
341
+ name: z.string().min(1).max(100),
342
+ description: z.string().max(200),
343
+ isRequired: z.boolean().default(false),
344
+ isSecret: z.boolean().default(false)
345
+ });
346
+ const playgroundExamplePromptSchema = z.object({
347
+ title: z.string().min(1).max(100),
348
+ prompt: z.string().min(1).max(500)
349
+ });
63
350
  const serverFieldsSchema = z.object({
64
351
  $schema: z.string(),
65
352
  name: z.string(),
@@ -298,7 +585,7 @@ const updateEnvironmentVariableContractV1 = oc.route({
298
585
  environmentVariableId: z.string().describe("The ID of the environment variable"),
299
586
  key: environmentVariableSchema.shape.key,
300
587
  value: environmentVariableSchema.shape.value.optional(),
301
- isSecret: environmentVariableSchema.shape.isSecret
588
+ isSecret: environmentVariableSchema.shape.isSecret.optional()
302
589
  })).output(z.object({ success: z.literal(true) }));
303
590
  const deleteEnvironmentVariableContractV1 = oc.route({
304
591
  path: "/v1/environment-variables/{environmentVariableId}",
@@ -309,7 +596,7 @@ const deleteEnvironmentVariableContractV1 = oc.route({
309
596
  successDescription: "The environment variable has been deleted successfully"
310
597
  }).errors({ NOT_FOUND: {} }).input(z.object({ environmentVariableId: z.string().describe("The ID of the environment variable") })).output(z.object({ success: z.literal(true) }));
311
598
  const deleteProjectContractV1 = oc.route({
312
- path: "/v1/projects/:projectId",
599
+ path: "/v1/projects/{projectId}",
313
600
  method: "DELETE",
314
601
  summary: "Delete a project",
315
602
  description: "Delete a project and all its environments",
@@ -418,6 +705,41 @@ const getLogsContractV1 = oc.route({
418
705
  })),
419
706
  nextToken: z.string().nullable()
420
707
  }));
708
+ const getLatestLogsContractV1 = oc.route({
709
+ path: "/v1/environments/{environmentId}/latest-logs",
710
+ method: "GET",
711
+ summary: "Get latest logs",
712
+ description: "Get the N most recent logs for an environment",
713
+ tags: ["environments"],
714
+ successDescription: "The latest logs"
715
+ }).errors({
716
+ NOT_FOUND: {},
717
+ BAD_REQUEST: {}
718
+ }).input(z.object({
719
+ environmentId: z.string().describe("The ID of the environment"),
720
+ limit: z.coerce.number().int().min(1).max(1e3).default(100).describe("Number of most recent log entries to return"),
721
+ level: z.array(z.enum([
722
+ "INFO",
723
+ "ERROR",
724
+ "WARNING",
725
+ "DEBUG"
726
+ ])).optional().describe("Filter by log level"),
727
+ search: z.string().optional().describe("Filter pattern to search for in log content")
728
+ })).output(z.object({ logs: z.array(z.object({
729
+ timestamp: z.coerce.date(),
730
+ type: z.enum([
731
+ "START",
732
+ "END",
733
+ "INFO",
734
+ "ERROR",
735
+ "WARNING",
736
+ "DEBUG"
737
+ ]),
738
+ requestId: z.string(),
739
+ content: z.string().optional(),
740
+ method: z.string().optional(),
741
+ durationInMs: z.number().optional()
742
+ })) }));
421
743
  const getDeploymentLogsContractV1 = oc.route({
422
744
  path: "/v1/deployments/{deploymentId}/logs",
423
745
  method: "GET",
@@ -527,6 +849,78 @@ const getServerInfoContractV1 = oc.route({
527
849
  projectId: z.string(),
528
850
  domain: z.string()
529
851
  })).output(z.object({ serverFields: serverFieldsSchema }));
852
+ const playgroundServerMetadataOutputSchema = z.object({
853
+ name: z.string(),
854
+ description: z.string(),
855
+ headers: z.array(z.object({
856
+ name: z.string(),
857
+ description: z.string(),
858
+ isRequired: z.boolean(),
859
+ isSecret: z.boolean()
860
+ })),
861
+ examplePrompts: z.array(playgroundExamplePromptSchema)
862
+ });
863
+ const playgroundOutputSchema = z.object({
864
+ isPlaygroundEnabled: z.boolean(),
865
+ serverMetadata: playgroundServerMetadataOutputSchema.nullable()
866
+ });
867
+ const getPlaygroundContractV1 = oc.route({
868
+ path: "/v1/environments/{environmentId}/playground",
869
+ method: "GET",
870
+ summary: "Get playground configuration",
871
+ description: "Get the playground configuration for an environment",
872
+ tags: ["environments"],
873
+ successDescription: "The playground configuration"
874
+ }).errors({ NOT_FOUND: {} }).input(z.object({ environmentId: z.string().describe("The ID of the environment") })).output(playgroundOutputSchema);
875
+ const upsertPlaygroundContractV1 = oc.route({
876
+ path: "/v1/environments/{environmentId}/playground",
877
+ method: "PUT",
878
+ summary: "Update playground configuration",
879
+ description: "Update the playground configuration for an environment. All fields are optional — only provided fields are updated.",
880
+ tags: ["environments"],
881
+ successDescription: "The updated playground configuration"
882
+ }).errors({
883
+ NOT_FOUND: {},
884
+ BAD_REQUEST: {}
885
+ }).input(z.object({
886
+ environmentId: z.string().describe("The ID of the environment"),
887
+ isPlaygroundEnabled: z.boolean().optional(),
888
+ name: z.string().min(1).max(100).optional(),
889
+ description: z.string().min(1).max(500).optional(),
890
+ headers: z.array(playgroundHeaderSchema).optional(),
891
+ examplePrompts: z.array(playgroundExamplePromptSchema).max(3).optional()
892
+ })).output(playgroundOutputSchema);
893
+ const createBeaconContractV1 = oc.route({
894
+ path: "/v1/beacon/audits",
895
+ method: "POST",
896
+ summary: "Create a beacon audit",
897
+ description: "Audit an MCP server for spec compliance and AI client compatibility",
898
+ tags: ["beacon"],
899
+ successDescription: "The audit has been created"
900
+ }).errors({
901
+ NOT_FOUND: {},
902
+ BAD_REQUEST: {}
903
+ }).input(z.object({
904
+ targetUrl: z.url().describe("The HTTPS URL of the MCP server to audit"),
905
+ teamId: z.string().optional().describe("The team ID to associate the audit with"),
906
+ projectId: z.string().optional().describe("The project ID to associate the audit with"),
907
+ excludeCategories: z.array(checkCategorySchema).optional().describe("Check categories to exclude from the audit")
908
+ })).output(z.object({ id: z.string() }));
909
+ const getBeaconContractV1 = oc.route({
910
+ path: "/v1/beacon/audits/{auditId}",
911
+ method: "GET",
912
+ summary: "Get a beacon audit",
913
+ description: "Get a beacon audit by ID, including the report if completed",
914
+ tags: ["beacon"],
915
+ successDescription: "The audit details"
916
+ }).errors({ NOT_FOUND: {} }).input(z.object({ auditId: z.string().describe("The ID of the audit") })).output(z.object({
917
+ id: z.string(),
918
+ targetUrl: z.string(),
919
+ status: auditStatusSchema,
920
+ durationMs: z.number().nullable(),
921
+ createdAt: z.coerce.date(),
922
+ report: auditReportWithScreenshotsSchema.nullable()
923
+ }));
530
924
  const contract = {
531
925
  teams: { list: { v1: listTeamsContractV1 } },
532
926
  analytics: { get: { v1: getProjectAnalyticsContractV1 } },
@@ -540,7 +934,8 @@ const contract = {
540
934
  create: { v1: createEnvironmentContractV1 },
541
935
  get: { v1: getEnvironmentContractV1 },
542
936
  deploy: { v1: deployEnvironmentContractV1 },
543
- getLogs: { v1: getLogsContractV1 }
937
+ getLogs: { v1: getLogsContractV1 },
938
+ getLatestLogs: { v1: getLatestLogsContractV1 }
544
939
  },
545
940
  environmentVariables: {
546
941
  list: { v1: listEnvironmentVariablesContractV1 },
@@ -555,11 +950,19 @@ const contract = {
555
950
  create: { v1: createProjectContractV1 },
556
951
  delete: { v1: deleteProjectContractV1 }
557
952
  },
953
+ playground: {
954
+ get: { v1: getPlaygroundContractV1 },
955
+ upsert: { v1: upsertPlaygroundContractV1 }
956
+ },
558
957
  tunnels: { getTicket: { v1: getTunnelTicketContractV1 } },
559
958
  distribution: {
560
959
  publish: { v1: publishServerContractV1 },
561
960
  get: { v1: getServerInfoContractV1 }
961
+ },
962
+ beacon: {
963
+ create: { v1: createBeaconContractV1 },
964
+ get: { v1: getBeaconContractV1 }
562
965
  }
563
966
  };
564
967
  //#endregion
565
- export { buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, runtimeSchema, serverFieldsSchema, transportSchema };
968
+ export { PLATFORM_LABELS, buildSettingsSchema, contract, createEnvironmentContractV1, deploymentStatusSchema, environmentVariableSchema, environmentVariablesSchema, playgroundExamplePromptSchema, playgroundHeaderSchema, runtimeSchema, serverFieldsSchema, transportSchema, updateEnvironmentVariableSchema };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@alpic-ai/api",
3
- "version": "0.0.0-staging.fb9eb3f",
3
+ "version": "0.0.0-staging.fc7750c",
4
4
  "description": "Contract for the Alpic API",
5
5
  "type": "module",
6
6
  "main": "./dist/index.mjs",
@@ -14,20 +14,32 @@
14
14
  "files": [
15
15
  "dist"
16
16
  ],
17
+ "nx": {
18
+ "targets": {
19
+ "build": {
20
+ "dependsOn": [
21
+ "^build"
22
+ ]
23
+ }
24
+ }
25
+ },
17
26
  "author": "Alpic",
18
27
  "license": "ISC",
19
28
  "dependencies": {
20
- "@orpc/contract": "^1.13.8",
29
+ "@orpc/contract": "^1.14.3",
21
30
  "ms": "^2.1.3",
22
- "zod": "^4.3.6"
31
+ "zod": "^4.4.3"
23
32
  },
24
33
  "devDependencies": {
34
+ "@orpc/openapi": "^1.14.3",
35
+ "@orpc/zod": "^1.14.3",
25
36
  "@total-typescript/tsconfig": "^1.0.4",
26
37
  "@types/ms": "^2.1.0",
27
38
  "shx": "^0.4.0",
28
- "tsdown": "^0.21.4",
29
- "typescript": "^5.9.3",
30
- "vitest": "^4.1.0"
39
+ "tsdown": "^0.22.0",
40
+ "typescript": "^6.0.3",
41
+ "vitest": "^4.1.6",
42
+ "@alpic-ai/domains": "0.0.0"
31
43
  },
32
44
  "scripts": {
33
45
  "build": "shx rm -rf dist && tsdown",