@symbioticsec/sdk 0.0.8 → 0.0.13

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.
Files changed (73) hide show
  1. package/dist/client.d.ts +7 -0
  2. package/dist/client.js +25 -0
  3. package/dist/gen/client/client.gen.d.ts +2 -0
  4. package/dist/gen/client/client.gen.js +165 -0
  5. package/dist/gen/client/index.d.ts +7 -0
  6. package/dist/gen/client/index.js +5 -0
  7. package/dist/gen/client/types.gen.d.ts +127 -0
  8. package/dist/gen/client/types.gen.js +2 -0
  9. package/dist/gen/client/utils.gen.d.ts +38 -0
  10. package/dist/gen/client/utils.gen.js +226 -0
  11. package/dist/gen/client.gen.d.ts +12 -0
  12. package/dist/gen/client.gen.js +5 -0
  13. package/dist/gen/core/auth.gen.d.ts +18 -0
  14. package/dist/gen/core/auth.gen.js +14 -0
  15. package/dist/gen/core/bodySerializer.gen.d.ts +17 -0
  16. package/dist/gen/core/bodySerializer.gen.js +57 -0
  17. package/dist/gen/core/params.gen.d.ts +33 -0
  18. package/dist/gen/core/params.gen.js +89 -0
  19. package/dist/gen/core/pathSerializer.gen.d.ts +33 -0
  20. package/dist/gen/core/pathSerializer.gen.js +106 -0
  21. package/dist/gen/core/queryKeySerializer.gen.d.ts +18 -0
  22. package/dist/gen/core/queryKeySerializer.gen.js +93 -0
  23. package/dist/gen/core/serverSentEvents.gen.d.ts +59 -0
  24. package/dist/gen/core/serverSentEvents.gen.js +117 -0
  25. package/dist/gen/core/types.gen.d.ts +78 -0
  26. package/dist/gen/core/types.gen.js +2 -0
  27. package/dist/gen/core/utils.gen.d.ts +14 -0
  28. package/dist/gen/core/utils.gen.js +69 -0
  29. package/dist/gen/sdk.gen.d.ts +403 -0
  30. package/dist/gen/sdk.gen.js +881 -0
  31. package/dist/gen/types.gen.d.ts +3387 -0
  32. package/dist/gen/types.gen.js +2 -0
  33. package/dist/index.d.ts +10 -0
  34. package/dist/index.js +16 -0
  35. package/dist/server.d.ts +23 -0
  36. package/dist/server.js +94 -0
  37. package/dist/v2/client.d.ts +8 -0
  38. package/dist/v2/client.js +33 -0
  39. package/dist/v2/gen/client/client.gen.d.ts +2 -0
  40. package/dist/v2/gen/client/client.gen.js +232 -0
  41. package/dist/v2/gen/client/index.d.ts +8 -0
  42. package/dist/v2/gen/client/index.js +6 -0
  43. package/dist/v2/gen/client/types.gen.d.ts +117 -0
  44. package/dist/v2/gen/client/types.gen.js +2 -0
  45. package/dist/v2/gen/client/utils.gen.d.ts +33 -0
  46. package/dist/v2/gen/client/utils.gen.js +226 -0
  47. package/dist/v2/gen/client.gen.d.ts +12 -0
  48. package/dist/v2/gen/client.gen.js +3 -0
  49. package/dist/v2/gen/core/auth.gen.d.ts +18 -0
  50. package/dist/v2/gen/core/auth.gen.js +14 -0
  51. package/dist/v2/gen/core/bodySerializer.gen.d.ts +25 -0
  52. package/dist/v2/gen/core/bodySerializer.gen.js +57 -0
  53. package/dist/v2/gen/core/params.gen.d.ts +43 -0
  54. package/dist/v2/gen/core/params.gen.js +102 -0
  55. package/dist/v2/gen/core/pathSerializer.gen.d.ts +33 -0
  56. package/dist/v2/gen/core/pathSerializer.gen.js +106 -0
  57. package/dist/v2/gen/core/queryKeySerializer.gen.d.ts +18 -0
  58. package/dist/v2/gen/core/queryKeySerializer.gen.js +93 -0
  59. package/dist/v2/gen/core/serverSentEvents.gen.d.ts +71 -0
  60. package/dist/v2/gen/core/serverSentEvents.gen.js +133 -0
  61. package/dist/v2/gen/core/types.gen.d.ts +78 -0
  62. package/dist/v2/gen/core/types.gen.js +2 -0
  63. package/dist/v2/gen/core/utils.gen.d.ts +19 -0
  64. package/dist/v2/gen/core/utils.gen.js +87 -0
  65. package/dist/v2/gen/sdk.gen.d.ts +1307 -0
  66. package/dist/v2/gen/sdk.gen.js +2644 -0
  67. package/dist/v2/gen/types.gen.d.ts +4345 -0
  68. package/dist/v2/gen/types.gen.js +2 -0
  69. package/dist/v2/index.d.ts +10 -0
  70. package/dist/v2/index.js +16 -0
  71. package/dist/v2/server.d.ts +23 -0
  72. package/dist/v2/server.js +94 -0
  73. package/package.json +5 -5
@@ -0,0 +1,4345 @@
1
+ export type ClientOptions = {
2
+ baseUrl: `${string}://${string}` | (string & {});
3
+ };
4
+ export type EventInstallationUpdated = {
5
+ type: "installation.updated";
6
+ properties: {
7
+ version: string;
8
+ };
9
+ };
10
+ export type EventInstallationUpdateAvailable = {
11
+ type: "installation.update-available";
12
+ properties: {
13
+ version: string;
14
+ };
15
+ };
16
+ export type Project = {
17
+ id: string;
18
+ worktree: string;
19
+ vcs?: "git";
20
+ name?: string;
21
+ icon?: {
22
+ url?: string;
23
+ override?: string;
24
+ color?: string;
25
+ };
26
+ commands?: {
27
+ /**
28
+ * Startup script to run when creating a new workspace (worktree)
29
+ */
30
+ start?: string;
31
+ };
32
+ time: {
33
+ created: number;
34
+ updated: number;
35
+ initialized?: number;
36
+ };
37
+ sandboxes: Array<string>;
38
+ };
39
+ export type EventProjectUpdated = {
40
+ type: "project.updated";
41
+ properties: Project;
42
+ };
43
+ export type EventFileEdited = {
44
+ type: "file.edited";
45
+ properties: {
46
+ file: string;
47
+ };
48
+ };
49
+ export type EventServerInstanceDisposed = {
50
+ type: "server.instance.disposed";
51
+ properties: {
52
+ directory: string;
53
+ };
54
+ };
55
+ export type EventFileWatcherUpdated = {
56
+ type: "file.watcher.updated";
57
+ properties: {
58
+ file: string;
59
+ event: "add" | "change" | "unlink";
60
+ };
61
+ };
62
+ export type PermissionRequest = {
63
+ id: string;
64
+ sessionID: string;
65
+ permission: string;
66
+ patterns: Array<string>;
67
+ metadata: {
68
+ [key: string]: unknown;
69
+ };
70
+ always: Array<string>;
71
+ tool?: {
72
+ messageID: string;
73
+ callID: string;
74
+ };
75
+ };
76
+ export type EventPermissionAsked = {
77
+ type: "permission.asked";
78
+ properties: PermissionRequest;
79
+ };
80
+ export type EventPermissionReplied = {
81
+ type: "permission.replied";
82
+ properties: {
83
+ sessionID: string;
84
+ requestID: string;
85
+ reply: "once" | "always" | "reject";
86
+ };
87
+ };
88
+ export type EventVcsBranchUpdated = {
89
+ type: "vcs.branch.updated";
90
+ properties: {
91
+ branch?: string;
92
+ };
93
+ };
94
+ export type QuestionOption = {
95
+ /**
96
+ * Display text (1-5 words, concise)
97
+ */
98
+ label: string;
99
+ /**
100
+ * Explanation of choice
101
+ */
102
+ description: string;
103
+ };
104
+ export type QuestionInfo = {
105
+ /**
106
+ * Complete question
107
+ */
108
+ question: string;
109
+ /**
110
+ * Very short label (max 30 chars)
111
+ */
112
+ header: string;
113
+ /**
114
+ * Available choices
115
+ */
116
+ options: Array<QuestionOption>;
117
+ /**
118
+ * Allow selecting multiple choices
119
+ */
120
+ multiple?: boolean;
121
+ /**
122
+ * Allow typing a custom answer (default: true)
123
+ */
124
+ custom?: boolean;
125
+ };
126
+ export type QuestionRequest = {
127
+ id: string;
128
+ sessionID: string;
129
+ /**
130
+ * Questions to ask
131
+ */
132
+ questions: Array<QuestionInfo>;
133
+ tool?: {
134
+ messageID: string;
135
+ callID: string;
136
+ };
137
+ };
138
+ export type EventQuestionAsked = {
139
+ type: "question.asked";
140
+ properties: QuestionRequest;
141
+ };
142
+ export type QuestionAnswer = Array<string>;
143
+ export type EventQuestionReplied = {
144
+ type: "question.replied";
145
+ properties: {
146
+ sessionID: string;
147
+ requestID: string;
148
+ answers: Array<QuestionAnswer>;
149
+ };
150
+ };
151
+ export type EventQuestionRejected = {
152
+ type: "question.rejected";
153
+ properties: {
154
+ sessionID: string;
155
+ requestID: string;
156
+ };
157
+ };
158
+ export type EventServerConnected = {
159
+ type: "server.connected";
160
+ properties: {
161
+ [key: string]: unknown;
162
+ };
163
+ };
164
+ export type EventGlobalDisposed = {
165
+ type: "global.disposed";
166
+ properties: {
167
+ [key: string]: unknown;
168
+ };
169
+ };
170
+ export type EventLspClientDiagnostics = {
171
+ type: "lsp.client.diagnostics";
172
+ properties: {
173
+ serverID: string;
174
+ path: string;
175
+ };
176
+ };
177
+ export type EventLspUpdated = {
178
+ type: "lsp.updated";
179
+ properties: {
180
+ [key: string]: unknown;
181
+ };
182
+ };
183
+ export type OutputFormatText = {
184
+ type: "text";
185
+ };
186
+ export type JsonSchema = {
187
+ [key: string]: unknown;
188
+ };
189
+ export type OutputFormatJsonSchema = {
190
+ type: "json_schema";
191
+ schema: JsonSchema;
192
+ retryCount?: number;
193
+ };
194
+ export type OutputFormat = OutputFormatText | OutputFormatJsonSchema;
195
+ export type FileDiff = {
196
+ file: string;
197
+ before: string;
198
+ after: string;
199
+ additions: number;
200
+ deletions: number;
201
+ status?: "added" | "deleted" | "modified";
202
+ };
203
+ export type UserMessage = {
204
+ id: string;
205
+ sessionID: string;
206
+ role: "user";
207
+ time: {
208
+ created: number;
209
+ };
210
+ format?: OutputFormat;
211
+ summary?: {
212
+ title?: string;
213
+ body?: string;
214
+ diffs: Array<FileDiff>;
215
+ };
216
+ agent: string;
217
+ model: {
218
+ providerID: string;
219
+ modelID: string;
220
+ };
221
+ system?: string;
222
+ tools?: {
223
+ [key: string]: boolean;
224
+ };
225
+ variant?: string;
226
+ };
227
+ export type ProviderAuthError = {
228
+ name: "ProviderAuthError";
229
+ data: {
230
+ providerID: string;
231
+ message: string;
232
+ };
233
+ };
234
+ export type UnknownError = {
235
+ name: "UnknownError";
236
+ data: {
237
+ message: string;
238
+ };
239
+ };
240
+ export type MessageOutputLengthError = {
241
+ name: "MessageOutputLengthError";
242
+ data: {
243
+ [key: string]: unknown;
244
+ };
245
+ };
246
+ export type MessageAbortedError = {
247
+ name: "MessageAbortedError";
248
+ data: {
249
+ message: string;
250
+ };
251
+ };
252
+ export type StructuredOutputError = {
253
+ name: "StructuredOutputError";
254
+ data: {
255
+ message: string;
256
+ retries: number;
257
+ };
258
+ };
259
+ export type ContextOverflowError = {
260
+ name: "ContextOverflowError";
261
+ data: {
262
+ message: string;
263
+ responseBody?: string;
264
+ };
265
+ };
266
+ export type ApiError = {
267
+ name: "APIError";
268
+ data: {
269
+ message: string;
270
+ statusCode?: number;
271
+ isRetryable: boolean;
272
+ responseHeaders?: {
273
+ [key: string]: string;
274
+ };
275
+ responseBody?: string;
276
+ metadata?: {
277
+ [key: string]: string;
278
+ };
279
+ };
280
+ };
281
+ export type AssistantMessage = {
282
+ id: string;
283
+ sessionID: string;
284
+ role: "assistant";
285
+ time: {
286
+ created: number;
287
+ completed?: number;
288
+ };
289
+ error?: ProviderAuthError | UnknownError | MessageOutputLengthError | MessageAbortedError | StructuredOutputError | ContextOverflowError | ApiError;
290
+ parentID: string;
291
+ modelID: string;
292
+ providerID: string;
293
+ mode: string;
294
+ agent: string;
295
+ path: {
296
+ cwd: string;
297
+ root: string;
298
+ };
299
+ summary?: boolean;
300
+ cost: number;
301
+ tokens: {
302
+ total?: number;
303
+ input: number;
304
+ output: number;
305
+ reasoning: number;
306
+ cache: {
307
+ read: number;
308
+ write: number;
309
+ };
310
+ };
311
+ structured?: unknown;
312
+ variant?: string;
313
+ finish?: string;
314
+ };
315
+ export type Message = UserMessage | AssistantMessage;
316
+ export type EventMessageUpdated = {
317
+ type: "message.updated";
318
+ properties: {
319
+ info: Message;
320
+ };
321
+ };
322
+ export type EventMessageRemoved = {
323
+ type: "message.removed";
324
+ properties: {
325
+ sessionID: string;
326
+ messageID: string;
327
+ };
328
+ };
329
+ export type TextPart = {
330
+ id: string;
331
+ sessionID: string;
332
+ messageID: string;
333
+ type: "text";
334
+ text: string;
335
+ synthetic?: boolean;
336
+ ignored?: boolean;
337
+ time?: {
338
+ start: number;
339
+ end?: number;
340
+ };
341
+ metadata?: {
342
+ [key: string]: unknown;
343
+ };
344
+ };
345
+ export type SubtaskPart = {
346
+ id: string;
347
+ sessionID: string;
348
+ messageID: string;
349
+ type: "subtask";
350
+ prompt: string;
351
+ description: string;
352
+ agent: string;
353
+ model?: {
354
+ providerID: string;
355
+ modelID: string;
356
+ };
357
+ command?: string;
358
+ };
359
+ export type ReasoningPart = {
360
+ id: string;
361
+ sessionID: string;
362
+ messageID: string;
363
+ type: "reasoning";
364
+ text: string;
365
+ metadata?: {
366
+ [key: string]: unknown;
367
+ };
368
+ time: {
369
+ start: number;
370
+ end?: number;
371
+ };
372
+ };
373
+ export type FilePartSourceText = {
374
+ value: string;
375
+ start: number;
376
+ end: number;
377
+ };
378
+ export type FileSource = {
379
+ text: FilePartSourceText;
380
+ type: "file";
381
+ path: string;
382
+ };
383
+ export type Range = {
384
+ start: {
385
+ line: number;
386
+ character: number;
387
+ };
388
+ end: {
389
+ line: number;
390
+ character: number;
391
+ };
392
+ };
393
+ export type SymbolSource = {
394
+ text: FilePartSourceText;
395
+ type: "symbol";
396
+ path: string;
397
+ range: Range;
398
+ name: string;
399
+ kind: number;
400
+ };
401
+ export type ResourceSource = {
402
+ text: FilePartSourceText;
403
+ type: "resource";
404
+ clientName: string;
405
+ uri: string;
406
+ };
407
+ export type FilePartSource = FileSource | SymbolSource | ResourceSource;
408
+ export type FilePart = {
409
+ id: string;
410
+ sessionID: string;
411
+ messageID: string;
412
+ type: "file";
413
+ mime: string;
414
+ filename?: string;
415
+ url: string;
416
+ source?: FilePartSource;
417
+ };
418
+ export type ToolStatePending = {
419
+ status: "pending";
420
+ input: {
421
+ [key: string]: unknown;
422
+ };
423
+ raw: string;
424
+ };
425
+ export type ToolStateRunning = {
426
+ status: "running";
427
+ input: {
428
+ [key: string]: unknown;
429
+ };
430
+ title?: string;
431
+ metadata?: {
432
+ [key: string]: unknown;
433
+ };
434
+ time: {
435
+ start: number;
436
+ };
437
+ };
438
+ export type ToolStateCompleted = {
439
+ status: "completed";
440
+ input: {
441
+ [key: string]: unknown;
442
+ };
443
+ output: string;
444
+ title: string;
445
+ metadata: {
446
+ [key: string]: unknown;
447
+ };
448
+ time: {
449
+ start: number;
450
+ end: number;
451
+ compacted?: number;
452
+ };
453
+ attachments?: Array<FilePart>;
454
+ };
455
+ export type ToolStateError = {
456
+ status: "error";
457
+ input: {
458
+ [key: string]: unknown;
459
+ };
460
+ error: string;
461
+ metadata?: {
462
+ [key: string]: unknown;
463
+ };
464
+ time: {
465
+ start: number;
466
+ end: number;
467
+ };
468
+ };
469
+ export type ToolState = ToolStatePending | ToolStateRunning | ToolStateCompleted | ToolStateError;
470
+ export type ToolPart = {
471
+ id: string;
472
+ sessionID: string;
473
+ messageID: string;
474
+ type: "tool";
475
+ callID: string;
476
+ tool: string;
477
+ state: ToolState;
478
+ metadata?: {
479
+ [key: string]: unknown;
480
+ };
481
+ };
482
+ export type StepStartPart = {
483
+ id: string;
484
+ sessionID: string;
485
+ messageID: string;
486
+ type: "step-start";
487
+ snapshot?: string;
488
+ };
489
+ export type StepFinishPart = {
490
+ id: string;
491
+ sessionID: string;
492
+ messageID: string;
493
+ type: "step-finish";
494
+ reason: string;
495
+ snapshot?: string;
496
+ cost: number;
497
+ tokens: {
498
+ total?: number;
499
+ input: number;
500
+ output: number;
501
+ reasoning: number;
502
+ cache: {
503
+ read: number;
504
+ write: number;
505
+ };
506
+ };
507
+ };
508
+ export type SnapshotPart = {
509
+ id: string;
510
+ sessionID: string;
511
+ messageID: string;
512
+ type: "snapshot";
513
+ snapshot: string;
514
+ };
515
+ export type PatchPart = {
516
+ id: string;
517
+ sessionID: string;
518
+ messageID: string;
519
+ type: "patch";
520
+ hash: string;
521
+ files: Array<string>;
522
+ };
523
+ export type AgentPart = {
524
+ id: string;
525
+ sessionID: string;
526
+ messageID: string;
527
+ type: "agent";
528
+ name: string;
529
+ source?: {
530
+ value: string;
531
+ start: number;
532
+ end: number;
533
+ };
534
+ };
535
+ export type RetryPart = {
536
+ id: string;
537
+ sessionID: string;
538
+ messageID: string;
539
+ type: "retry";
540
+ attempt: number;
541
+ error: ApiError;
542
+ time: {
543
+ created: number;
544
+ };
545
+ };
546
+ export type CompactionPart = {
547
+ id: string;
548
+ sessionID: string;
549
+ messageID: string;
550
+ type: "compaction";
551
+ auto: boolean;
552
+ overflow?: boolean;
553
+ };
554
+ export type Part = TextPart | SubtaskPart | ReasoningPart | FilePart | ToolPart | StepStartPart | StepFinishPart | SnapshotPart | PatchPart | AgentPart | RetryPart | CompactionPart;
555
+ export type EventMessagePartUpdated = {
556
+ type: "message.part.updated";
557
+ properties: {
558
+ part: Part;
559
+ };
560
+ };
561
+ export type EventMessagePartDelta = {
562
+ type: "message.part.delta";
563
+ properties: {
564
+ sessionID: string;
565
+ messageID: string;
566
+ partID: string;
567
+ field: string;
568
+ delta: string;
569
+ };
570
+ };
571
+ export type EventMessagePartRemoved = {
572
+ type: "message.part.removed";
573
+ properties: {
574
+ sessionID: string;
575
+ messageID: string;
576
+ partID: string;
577
+ };
578
+ };
579
+ export type SessionStatus = {
580
+ type: "idle";
581
+ } | {
582
+ type: "retry";
583
+ attempt: number;
584
+ message: string;
585
+ next: number;
586
+ } | {
587
+ type: "busy";
588
+ };
589
+ export type EventSessionStatus = {
590
+ type: "session.status";
591
+ properties: {
592
+ sessionID: string;
593
+ status: SessionStatus;
594
+ };
595
+ };
596
+ export type EventSessionIdle = {
597
+ type: "session.idle";
598
+ properties: {
599
+ sessionID: string;
600
+ };
601
+ };
602
+ export type EventSessionCompacted = {
603
+ type: "session.compacted";
604
+ properties: {
605
+ sessionID: string;
606
+ };
607
+ };
608
+ export type Todo = {
609
+ /**
610
+ * Brief description of the task
611
+ */
612
+ content: string;
613
+ /**
614
+ * Current status of the task: pending, in_progress, completed, cancelled
615
+ */
616
+ status: string;
617
+ /**
618
+ * Priority level of the task: high, medium, low
619
+ */
620
+ priority: string;
621
+ };
622
+ export type EventTodoUpdated = {
623
+ type: "todo.updated";
624
+ properties: {
625
+ sessionID: string;
626
+ todos: Array<Todo>;
627
+ };
628
+ };
629
+ export type EventTuiPromptAppend = {
630
+ type: "tui.prompt.append";
631
+ properties: {
632
+ text: string;
633
+ };
634
+ };
635
+ export type EventTuiCommandExecute = {
636
+ type: "tui.command.execute";
637
+ properties: {
638
+ command: "session.list" | "session.new" | "session.share" | "session.interrupt" | "session.compact" | "session.page.up" | "session.page.down" | "session.line.up" | "session.line.down" | "session.half.page.up" | "session.half.page.down" | "session.first" | "session.last" | "prompt.clear" | "prompt.submit" | "agent.cycle" | string;
639
+ };
640
+ };
641
+ export type EventTuiToastShow = {
642
+ type: "tui.toast.show";
643
+ properties: {
644
+ title?: string;
645
+ message: string;
646
+ variant: "info" | "success" | "warning" | "error";
647
+ /**
648
+ * Duration in milliseconds
649
+ */
650
+ duration?: number;
651
+ };
652
+ };
653
+ export type EventTuiSessionSelect = {
654
+ type: "tui.session.select";
655
+ properties: {
656
+ /**
657
+ * Session ID to navigate to
658
+ */
659
+ sessionID: string;
660
+ };
661
+ };
662
+ export type EventMcpToolsChanged = {
663
+ type: "mcp.tools.changed";
664
+ properties: {
665
+ server: string;
666
+ };
667
+ };
668
+ export type EventMcpBrowserOpenFailed = {
669
+ type: "mcp.browser.open.failed";
670
+ properties: {
671
+ mcpName: string;
672
+ url: string;
673
+ };
674
+ };
675
+ export type EventCommandExecuted = {
676
+ type: "command.executed";
677
+ properties: {
678
+ name: string;
679
+ sessionID: string;
680
+ arguments: string;
681
+ messageID: string;
682
+ };
683
+ };
684
+ export type EventGuardrailUpdated = {
685
+ type: "guardrail.updated";
686
+ properties: {
687
+ org: string;
688
+ repo: string;
689
+ };
690
+ };
691
+ export type PermissionAction = "allow" | "deny" | "ask";
692
+ export type PermissionRule = {
693
+ permission: string;
694
+ pattern: string;
695
+ action: PermissionAction;
696
+ };
697
+ export type PermissionRuleset = Array<PermissionRule>;
698
+ export type Session = {
699
+ id: string;
700
+ slug: string;
701
+ projectID: string;
702
+ workspaceID?: string;
703
+ directory: string;
704
+ parentID?: string;
705
+ summary?: {
706
+ additions: number;
707
+ deletions: number;
708
+ files: number;
709
+ diffs?: Array<FileDiff>;
710
+ };
711
+ share?: {
712
+ url: string;
713
+ };
714
+ title: string;
715
+ version: string;
716
+ time: {
717
+ created: number;
718
+ updated: number;
719
+ compacting?: number;
720
+ archived?: number;
721
+ };
722
+ permission?: PermissionRuleset;
723
+ revert?: {
724
+ messageID: string;
725
+ partID?: string;
726
+ snapshot?: string;
727
+ diff?: string;
728
+ };
729
+ };
730
+ export type EventSessionCreated = {
731
+ type: "session.created";
732
+ properties: {
733
+ info: Session;
734
+ };
735
+ };
736
+ export type EventSessionUpdated = {
737
+ type: "session.updated";
738
+ properties: {
739
+ info: Session;
740
+ };
741
+ };
742
+ export type EventSessionDeleted = {
743
+ type: "session.deleted";
744
+ properties: {
745
+ info: Session;
746
+ };
747
+ };
748
+ export type EventSessionDiff = {
749
+ type: "session.diff";
750
+ properties: {
751
+ sessionID: string;
752
+ diff: Array<FileDiff>;
753
+ };
754
+ };
755
+ export type EventSessionError = {
756
+ type: "session.error";
757
+ properties: {
758
+ sessionID?: string;
759
+ error?: ProviderAuthError | UnknownError | MessageOutputLengthError | MessageAbortedError | StructuredOutputError | ContextOverflowError | ApiError;
760
+ };
761
+ };
762
+ export type EventWorkspaceReady = {
763
+ type: "workspace.ready";
764
+ properties: {
765
+ name: string;
766
+ };
767
+ };
768
+ export type EventWorkspaceFailed = {
769
+ type: "workspace.failed";
770
+ properties: {
771
+ message: string;
772
+ };
773
+ };
774
+ export type Pty = {
775
+ id: string;
776
+ title: string;
777
+ command: string;
778
+ args: Array<string>;
779
+ cwd: string;
780
+ status: "running" | "exited";
781
+ pid: number;
782
+ };
783
+ export type EventPtyCreated = {
784
+ type: "pty.created";
785
+ properties: {
786
+ info: Pty;
787
+ };
788
+ };
789
+ export type EventPtyUpdated = {
790
+ type: "pty.updated";
791
+ properties: {
792
+ info: Pty;
793
+ };
794
+ };
795
+ export type EventPtyExited = {
796
+ type: "pty.exited";
797
+ properties: {
798
+ id: string;
799
+ exitCode: number;
800
+ };
801
+ };
802
+ export type EventPtyDeleted = {
803
+ type: "pty.deleted";
804
+ properties: {
805
+ id: string;
806
+ };
807
+ };
808
+ export type EventWorktreeReady = {
809
+ type: "worktree.ready";
810
+ properties: {
811
+ name: string;
812
+ branch: string;
813
+ };
814
+ };
815
+ export type EventWorktreeFailed = {
816
+ type: "worktree.failed";
817
+ properties: {
818
+ message: string;
819
+ };
820
+ };
821
+ export type Event = EventInstallationUpdated | EventInstallationUpdateAvailable | EventProjectUpdated | EventFileEdited | EventServerInstanceDisposed | EventFileWatcherUpdated | EventPermissionAsked | EventPermissionReplied | EventVcsBranchUpdated | EventQuestionAsked | EventQuestionReplied | EventQuestionRejected | EventServerConnected | EventGlobalDisposed | EventLspClientDiagnostics | EventLspUpdated | EventMessageUpdated | EventMessageRemoved | EventMessagePartUpdated | EventMessagePartDelta | EventMessagePartRemoved | EventSessionStatus | EventSessionIdle | EventSessionCompacted | EventTodoUpdated | EventTuiPromptAppend | EventTuiCommandExecute | EventTuiToastShow | EventTuiSessionSelect | EventMcpToolsChanged | EventMcpBrowserOpenFailed | EventCommandExecuted | EventGuardrailUpdated | EventSessionCreated | EventSessionUpdated | EventSessionDeleted | EventSessionDiff | EventSessionError | EventWorkspaceReady | EventWorkspaceFailed | EventPtyCreated | EventPtyUpdated | EventPtyExited | EventPtyDeleted | EventWorktreeReady | EventWorktreeFailed;
822
+ export type GlobalEvent = {
823
+ directory: string;
824
+ payload: Event;
825
+ };
826
+ /**
827
+ * Log level
828
+ */
829
+ export type LogLevel = "DEBUG" | "INFO" | "WARN" | "ERROR";
830
+ /**
831
+ * Server configuration for symbioticcode serve and web commands
832
+ */
833
+ export type ServerConfig = {
834
+ /**
835
+ * Port to listen on
836
+ */
837
+ port?: number;
838
+ /**
839
+ * Hostname to listen on
840
+ */
841
+ hostname?: string;
842
+ /**
843
+ * Enable mDNS service discovery
844
+ */
845
+ mdns?: boolean;
846
+ /**
847
+ * Custom domain name for mDNS service (default: symbiotic.local)
848
+ */
849
+ mdnsDomain?: string;
850
+ /**
851
+ * Additional domains to allow for CORS
852
+ */
853
+ cors?: Array<string>;
854
+ };
855
+ export type PermissionActionConfig = "ask" | "allow" | "deny";
856
+ export type PermissionObjectConfig = {
857
+ [key: string]: PermissionActionConfig;
858
+ };
859
+ export type PermissionRuleConfig = PermissionActionConfig | PermissionObjectConfig;
860
+ export type PermissionConfig = {
861
+ __originalKeys?: Array<string>;
862
+ read?: PermissionRuleConfig;
863
+ edit?: PermissionRuleConfig;
864
+ glob?: PermissionRuleConfig;
865
+ grep?: PermissionRuleConfig;
866
+ list?: PermissionRuleConfig;
867
+ bash?: PermissionRuleConfig;
868
+ task?: PermissionRuleConfig;
869
+ external_directory?: PermissionRuleConfig;
870
+ todowrite?: PermissionActionConfig;
871
+ todoread?: PermissionActionConfig;
872
+ question?: PermissionActionConfig;
873
+ webfetch?: PermissionActionConfig;
874
+ websearch?: PermissionActionConfig;
875
+ codesearch?: PermissionActionConfig;
876
+ lsp?: PermissionRuleConfig;
877
+ doom_loop?: PermissionActionConfig;
878
+ skill?: PermissionRuleConfig;
879
+ [key: string]: PermissionRuleConfig | Array<string> | PermissionActionConfig | undefined;
880
+ } | PermissionActionConfig;
881
+ export type AgentConfig = {
882
+ model?: string;
883
+ /**
884
+ * Default model variant for this agent (applies only when using the agent's configured model).
885
+ */
886
+ variant?: string;
887
+ temperature?: number;
888
+ top_p?: number;
889
+ prompt?: string;
890
+ /**
891
+ * @deprecated Use 'permission' field instead
892
+ */
893
+ tools?: {
894
+ [key: string]: boolean;
895
+ };
896
+ disable?: boolean;
897
+ /**
898
+ * Description of when to use the agent
899
+ */
900
+ description?: string;
901
+ mode?: "subagent" | "primary" | "all";
902
+ /**
903
+ * Hide this subagent from the @ autocomplete menu (default: false, only applies to mode: subagent)
904
+ */
905
+ hidden?: boolean;
906
+ options?: {
907
+ [key: string]: unknown;
908
+ };
909
+ /**
910
+ * Hex color code (e.g., #FF5733) or theme color (e.g., primary)
911
+ */
912
+ color?: string | "primary" | "secondary" | "accent" | "success" | "warning" | "error" | "info";
913
+ /**
914
+ * Maximum number of agentic iterations before forcing text-only response
915
+ */
916
+ steps?: number;
917
+ /**
918
+ * @deprecated Use 'steps' field instead.
919
+ */
920
+ maxSteps?: number;
921
+ permission?: PermissionConfig;
922
+ [key: string]: unknown | string | number | {
923
+ [key: string]: boolean;
924
+ } | boolean | "subagent" | "primary" | "all" | {
925
+ [key: string]: unknown;
926
+ } | string | "primary" | "secondary" | "accent" | "success" | "warning" | "error" | "info" | number | PermissionConfig | undefined;
927
+ };
928
+ export type ProviderConfig = {
929
+ api?: string;
930
+ name?: string;
931
+ env?: Array<string>;
932
+ id?: string;
933
+ npm?: string;
934
+ models?: {
935
+ [key: string]: {
936
+ id?: string;
937
+ name?: string;
938
+ family?: string;
939
+ release_date?: string;
940
+ attachment?: boolean;
941
+ reasoning?: boolean;
942
+ temperature?: boolean;
943
+ tool_call?: boolean;
944
+ interleaved?: true | {
945
+ field: "reasoning_content" | "reasoning_details";
946
+ };
947
+ cost?: {
948
+ input: number;
949
+ output: number;
950
+ cache_read?: number;
951
+ cache_write?: number;
952
+ context_over_200k?: {
953
+ input: number;
954
+ output: number;
955
+ cache_read?: number;
956
+ cache_write?: number;
957
+ };
958
+ };
959
+ limit?: {
960
+ context: number;
961
+ input?: number;
962
+ output: number;
963
+ };
964
+ modalities?: {
965
+ input: Array<"text" | "audio" | "image" | "video" | "pdf">;
966
+ output: Array<"text" | "audio" | "image" | "video" | "pdf">;
967
+ };
968
+ experimental?: boolean;
969
+ status?: "alpha" | "beta" | "deprecated";
970
+ options?: {
971
+ [key: string]: unknown;
972
+ };
973
+ headers?: {
974
+ [key: string]: string;
975
+ };
976
+ provider?: {
977
+ npm?: string;
978
+ api?: string;
979
+ };
980
+ /**
981
+ * Variant-specific configuration
982
+ */
983
+ variants?: {
984
+ [key: string]: {
985
+ /**
986
+ * Disable this variant for the model
987
+ */
988
+ disabled?: boolean;
989
+ [key: string]: unknown | boolean | undefined;
990
+ };
991
+ };
992
+ };
993
+ };
994
+ whitelist?: Array<string>;
995
+ blacklist?: Array<string>;
996
+ options?: {
997
+ apiKey?: string;
998
+ baseURL?: string;
999
+ /**
1000
+ * GitHub Enterprise URL for copilot authentication
1001
+ */
1002
+ enterpriseUrl?: string;
1003
+ /**
1004
+ * Enable promptCacheKey for this provider (default false)
1005
+ */
1006
+ setCacheKey?: boolean;
1007
+ /**
1008
+ * Timeout in milliseconds for requests to this provider. Default is 300000 (5 minutes). Set to false to disable timeout.
1009
+ */
1010
+ timeout?: number | false;
1011
+ /**
1012
+ * Timeout in milliseconds between streamed SSE chunks for this provider. If no chunk arrives within this window, the request is aborted.
1013
+ */
1014
+ chunkTimeout?: number;
1015
+ [key: string]: unknown | string | boolean | number | false | number | undefined;
1016
+ };
1017
+ };
1018
+ export type McpLocalConfig = {
1019
+ /**
1020
+ * Type of MCP server connection
1021
+ */
1022
+ type: "local";
1023
+ /**
1024
+ * Command and arguments to run the MCP server
1025
+ */
1026
+ command: Array<string>;
1027
+ /**
1028
+ * Environment variables to set when running the MCP server
1029
+ */
1030
+ environment?: {
1031
+ [key: string]: string;
1032
+ };
1033
+ /**
1034
+ * Enable or disable the MCP server on startup
1035
+ */
1036
+ enabled?: boolean;
1037
+ /**
1038
+ * Timeout in ms for MCP server requests. Defaults to 5000 (5 seconds) if not specified.
1039
+ */
1040
+ timeout?: number;
1041
+ };
1042
+ export type McpOAuthConfig = {
1043
+ /**
1044
+ * OAuth client ID. If not provided, dynamic client registration (RFC 7591) will be attempted.
1045
+ */
1046
+ clientId?: string;
1047
+ /**
1048
+ * OAuth client secret (if required by the authorization server)
1049
+ */
1050
+ clientSecret?: string;
1051
+ /**
1052
+ * OAuth scopes to request during authorization
1053
+ */
1054
+ scope?: string;
1055
+ };
1056
+ export type McpRemoteConfig = {
1057
+ /**
1058
+ * Type of MCP server connection
1059
+ */
1060
+ type: "remote";
1061
+ /**
1062
+ * URL of the remote MCP server
1063
+ */
1064
+ url: string;
1065
+ /**
1066
+ * Enable or disable the MCP server on startup
1067
+ */
1068
+ enabled?: boolean;
1069
+ /**
1070
+ * Headers to send with the request
1071
+ */
1072
+ headers?: {
1073
+ [key: string]: string;
1074
+ };
1075
+ /**
1076
+ * OAuth authentication configuration for the MCP server. Set to false to disable OAuth auto-detection.
1077
+ */
1078
+ oauth?: McpOAuthConfig | false;
1079
+ /**
1080
+ * Timeout in ms for MCP server requests. Defaults to 5000 (5 seconds) if not specified.
1081
+ */
1082
+ timeout?: number;
1083
+ };
1084
+ /**
1085
+ * @deprecated Always uses stretch layout.
1086
+ */
1087
+ export type LayoutConfig = "auto" | "stretch";
1088
+ export type Config = {
1089
+ /**
1090
+ * JSON schema reference for configuration validation
1091
+ */
1092
+ $schema?: string;
1093
+ logLevel?: LogLevel;
1094
+ server?: ServerConfig;
1095
+ /**
1096
+ * Command configuration, see https://docs.symbioticsec.ai/code/commands
1097
+ */
1098
+ command?: {
1099
+ [key: string]: {
1100
+ template: string;
1101
+ description?: string;
1102
+ agent?: string;
1103
+ model?: string;
1104
+ subtask?: boolean;
1105
+ };
1106
+ };
1107
+ /**
1108
+ * Additional skill folder paths
1109
+ */
1110
+ skills?: {
1111
+ /**
1112
+ * Additional paths to skill folders
1113
+ */
1114
+ paths?: Array<string>;
1115
+ /**
1116
+ * URLs to fetch skills from (e.g., https://example.com/.well-known/skills/)
1117
+ */
1118
+ urls?: Array<string>;
1119
+ };
1120
+ watcher?: {
1121
+ ignore?: Array<string>;
1122
+ };
1123
+ plugin?: Array<string | [
1124
+ string,
1125
+ {
1126
+ [key: string]: unknown;
1127
+ }
1128
+ ]>;
1129
+ /**
1130
+ * Enable or disable snapshot tracking. When false, filesystem snapshots are not recorded and undoing or reverting will not undo/redo file changes. Defaults to true.
1131
+ */
1132
+ snapshot?: boolean;
1133
+ /**
1134
+ * Control sharing behavior:'manual' allows manual sharing via commands, 'auto' enables automatic sharing, 'disabled' disables all sharing
1135
+ */
1136
+ share?: "manual" | "auto" | "disabled";
1137
+ /**
1138
+ * @deprecated Use 'share' field instead. Share newly created sessions automatically
1139
+ */
1140
+ autoshare?: boolean;
1141
+ /**
1142
+ * Automatically update to the latest version. Set to true to auto-update, false to disable, or 'notify' to show update notifications
1143
+ */
1144
+ autoupdate?: boolean | "notify";
1145
+ /**
1146
+ * Disable providers that are loaded automatically
1147
+ */
1148
+ disabled_providers?: Array<string>;
1149
+ /**
1150
+ * When set, ONLY these providers will be enabled. All other providers will be ignored
1151
+ */
1152
+ enabled_providers?: Array<string>;
1153
+ /**
1154
+ * Model to use in the format of provider/model, eg anthropic/claude-2
1155
+ */
1156
+ model?: string;
1157
+ /**
1158
+ * Small model to use for tasks like title generation in the format of provider/model
1159
+ */
1160
+ small_model?: string;
1161
+ /**
1162
+ * Default agent to use when none is specified. Must be a primary agent. Falls back to 'build' if not set or if the specified agent is invalid.
1163
+ */
1164
+ default_agent?: string;
1165
+ /**
1166
+ * Custom username to display in conversations instead of system username
1167
+ */
1168
+ username?: string;
1169
+ /**
1170
+ * @deprecated Use `agent` field instead.
1171
+ */
1172
+ mode?: {
1173
+ build?: AgentConfig;
1174
+ plan?: AgentConfig;
1175
+ [key: string]: AgentConfig | undefined;
1176
+ };
1177
+ /**
1178
+ * Agent configuration, see https://docs.symbioticsec.ai/code/agents
1179
+ */
1180
+ agent?: {
1181
+ plan?: AgentConfig;
1182
+ build?: AgentConfig;
1183
+ general?: AgentConfig;
1184
+ explore?: AgentConfig;
1185
+ title?: AgentConfig;
1186
+ summary?: AgentConfig;
1187
+ compaction?: AgentConfig;
1188
+ [key: string]: AgentConfig | undefined;
1189
+ };
1190
+ /**
1191
+ * Custom provider configurations and model overrides
1192
+ */
1193
+ provider?: {
1194
+ [key: string]: ProviderConfig;
1195
+ };
1196
+ /**
1197
+ * MCP (Model Context Protocol) server configurations
1198
+ */
1199
+ mcp?: {
1200
+ [key: string]: McpLocalConfig | McpRemoteConfig | {
1201
+ enabled: boolean;
1202
+ };
1203
+ };
1204
+ formatter?: false | {
1205
+ [key: string]: {
1206
+ disabled?: boolean;
1207
+ command?: Array<string>;
1208
+ environment?: {
1209
+ [key: string]: string;
1210
+ };
1211
+ extensions?: Array<string>;
1212
+ };
1213
+ };
1214
+ lsp?: false | {
1215
+ [key: string]: {
1216
+ disabled: true;
1217
+ } | {
1218
+ command: Array<string>;
1219
+ extensions?: Array<string>;
1220
+ disabled?: boolean;
1221
+ env?: {
1222
+ [key: string]: string;
1223
+ };
1224
+ initialization?: {
1225
+ [key: string]: unknown;
1226
+ };
1227
+ };
1228
+ };
1229
+ /**
1230
+ * Additional instruction files or patterns to include
1231
+ */
1232
+ instructions?: Array<string>;
1233
+ layout?: LayoutConfig;
1234
+ permission?: PermissionConfig;
1235
+ tools?: {
1236
+ [key: string]: boolean;
1237
+ };
1238
+ enterprise?: {
1239
+ /**
1240
+ * Enterprise URL
1241
+ */
1242
+ url?: string;
1243
+ };
1244
+ compaction?: {
1245
+ /**
1246
+ * Enable automatic compaction when context is full (default: true)
1247
+ */
1248
+ auto?: boolean;
1249
+ /**
1250
+ * Enable pruning of old tool outputs (default: true)
1251
+ */
1252
+ prune?: boolean;
1253
+ /**
1254
+ * Token buffer for compaction. Leaves enough window to avoid overflow during compaction.
1255
+ */
1256
+ reserved?: number;
1257
+ };
1258
+ experimental?: {
1259
+ disable_paste_summary?: boolean;
1260
+ /**
1261
+ * Enable the batch tool
1262
+ */
1263
+ batch_tool?: boolean;
1264
+ /**
1265
+ * Enable OpenTelemetry spans for AI SDK calls (using the 'experimental_telemetry' flag)
1266
+ */
1267
+ openTelemetry?: boolean;
1268
+ /**
1269
+ * Tools that should only be available to primary agents.
1270
+ */
1271
+ primary_tools?: Array<string>;
1272
+ /**
1273
+ * Continue the agent loop when a tool call is denied
1274
+ */
1275
+ continue_loop_on_deny?: boolean;
1276
+ /**
1277
+ * Timeout in milliseconds for model context protocol (MCP) requests
1278
+ */
1279
+ mcp_timeout?: number;
1280
+ };
1281
+ };
1282
+ export type BadRequestError = {
1283
+ data: unknown;
1284
+ errors: Array<{
1285
+ [key: string]: unknown;
1286
+ }>;
1287
+ success: false;
1288
+ };
1289
+ export type OAuth = {
1290
+ type: "oauth";
1291
+ refresh: string;
1292
+ access: string;
1293
+ expires: number;
1294
+ accountId?: string;
1295
+ enterpriseUrl?: string;
1296
+ };
1297
+ export type ApiAuth = {
1298
+ type: "api";
1299
+ key: string;
1300
+ };
1301
+ export type WellKnownAuth = {
1302
+ type: "wellknown";
1303
+ key: string;
1304
+ token: string;
1305
+ };
1306
+ export type Auth = OAuth | ApiAuth | WellKnownAuth;
1307
+ export type NotFoundError = {
1308
+ name: "NotFoundError";
1309
+ data: {
1310
+ message: string;
1311
+ };
1312
+ };
1313
+ export type Model = {
1314
+ id: string;
1315
+ providerID: string;
1316
+ api: {
1317
+ id: string;
1318
+ url: string;
1319
+ npm: string;
1320
+ };
1321
+ name: string;
1322
+ family?: string;
1323
+ capabilities: {
1324
+ temperature: boolean;
1325
+ reasoning: boolean;
1326
+ attachment: boolean;
1327
+ toolcall: boolean;
1328
+ input: {
1329
+ text: boolean;
1330
+ audio: boolean;
1331
+ image: boolean;
1332
+ video: boolean;
1333
+ pdf: boolean;
1334
+ };
1335
+ output: {
1336
+ text: boolean;
1337
+ audio: boolean;
1338
+ image: boolean;
1339
+ video: boolean;
1340
+ pdf: boolean;
1341
+ };
1342
+ interleaved: boolean | {
1343
+ field: "reasoning_content" | "reasoning_details";
1344
+ };
1345
+ };
1346
+ cost: {
1347
+ input: number;
1348
+ output: number;
1349
+ cache: {
1350
+ read: number;
1351
+ write: number;
1352
+ };
1353
+ experimentalOver200K?: {
1354
+ input: number;
1355
+ output: number;
1356
+ cache: {
1357
+ read: number;
1358
+ write: number;
1359
+ };
1360
+ };
1361
+ };
1362
+ limit: {
1363
+ context: number;
1364
+ input?: number;
1365
+ output: number;
1366
+ };
1367
+ status: "alpha" | "beta" | "deprecated" | "active";
1368
+ options: {
1369
+ [key: string]: unknown;
1370
+ };
1371
+ headers: {
1372
+ [key: string]: string;
1373
+ };
1374
+ release_date: string;
1375
+ variants?: {
1376
+ [key: string]: {
1377
+ [key: string]: unknown;
1378
+ };
1379
+ };
1380
+ };
1381
+ export type Provider = {
1382
+ id: string;
1383
+ name: string;
1384
+ source: "env" | "config" | "custom" | "api";
1385
+ env: Array<string>;
1386
+ key?: string;
1387
+ options: {
1388
+ [key: string]: unknown;
1389
+ };
1390
+ models: {
1391
+ [key: string]: Model;
1392
+ };
1393
+ };
1394
+ export type ToolIds = Array<string>;
1395
+ export type ToolListItem = {
1396
+ id: string;
1397
+ description: string;
1398
+ parameters: unknown;
1399
+ };
1400
+ export type ToolList = Array<ToolListItem>;
1401
+ export type Workspace = {
1402
+ id: string;
1403
+ type: string;
1404
+ branch: string | null;
1405
+ name: string | null;
1406
+ directory: string | null;
1407
+ extra: unknown | null;
1408
+ projectID: string;
1409
+ };
1410
+ export type Worktree = {
1411
+ name: string;
1412
+ branch: string;
1413
+ directory: string;
1414
+ };
1415
+ export type WorktreeCreateInput = {
1416
+ name?: string;
1417
+ /**
1418
+ * Additional startup script to run after the project's start command
1419
+ */
1420
+ startCommand?: string;
1421
+ };
1422
+ export type WorktreeRemoveInput = {
1423
+ directory: string;
1424
+ };
1425
+ export type WorktreeResetInput = {
1426
+ directory: string;
1427
+ };
1428
+ export type ProjectSummary = {
1429
+ id: string;
1430
+ name?: string;
1431
+ worktree: string;
1432
+ };
1433
+ export type GlobalSession = {
1434
+ id: string;
1435
+ slug: string;
1436
+ projectID: string;
1437
+ workspaceID?: string;
1438
+ directory: string;
1439
+ parentID?: string;
1440
+ summary?: {
1441
+ additions: number;
1442
+ deletions: number;
1443
+ files: number;
1444
+ diffs?: Array<FileDiff>;
1445
+ };
1446
+ share?: {
1447
+ url: string;
1448
+ };
1449
+ title: string;
1450
+ version: string;
1451
+ time: {
1452
+ created: number;
1453
+ updated: number;
1454
+ compacting?: number;
1455
+ archived?: number;
1456
+ };
1457
+ permission?: PermissionRuleset;
1458
+ revert?: {
1459
+ messageID: string;
1460
+ partID?: string;
1461
+ snapshot?: string;
1462
+ diff?: string;
1463
+ };
1464
+ project: ProjectSummary | null;
1465
+ };
1466
+ export type McpResource = {
1467
+ name: string;
1468
+ uri: string;
1469
+ description?: string;
1470
+ mimeType?: string;
1471
+ client: string;
1472
+ };
1473
+ export type TextPartInput = {
1474
+ id?: string;
1475
+ type: "text";
1476
+ text: string;
1477
+ synthetic?: boolean;
1478
+ ignored?: boolean;
1479
+ time?: {
1480
+ start: number;
1481
+ end?: number;
1482
+ };
1483
+ metadata?: {
1484
+ [key: string]: unknown;
1485
+ };
1486
+ };
1487
+ export type FilePartInput = {
1488
+ id?: string;
1489
+ type: "file";
1490
+ mime: string;
1491
+ filename?: string;
1492
+ url: string;
1493
+ source?: FilePartSource;
1494
+ };
1495
+ export type AgentPartInput = {
1496
+ id?: string;
1497
+ type: "agent";
1498
+ name: string;
1499
+ source?: {
1500
+ value: string;
1501
+ start: number;
1502
+ end: number;
1503
+ };
1504
+ };
1505
+ export type SubtaskPartInput = {
1506
+ id?: string;
1507
+ type: "subtask";
1508
+ prompt: string;
1509
+ description: string;
1510
+ agent: string;
1511
+ model?: {
1512
+ providerID: string;
1513
+ modelID: string;
1514
+ };
1515
+ command?: string;
1516
+ };
1517
+ export type ProviderAuthMethod = {
1518
+ type: "oauth" | "api";
1519
+ label: string;
1520
+ prompts?: Array<{
1521
+ type: "text";
1522
+ key: string;
1523
+ message: string;
1524
+ placeholder?: string;
1525
+ when?: {
1526
+ key: string;
1527
+ op: "eq" | "neq";
1528
+ value: string;
1529
+ };
1530
+ } | {
1531
+ type: "select";
1532
+ key: string;
1533
+ message: string;
1534
+ options: Array<{
1535
+ label: string;
1536
+ value: string;
1537
+ hint?: string;
1538
+ }>;
1539
+ when?: {
1540
+ key: string;
1541
+ op: "eq" | "neq";
1542
+ value: string;
1543
+ };
1544
+ }>;
1545
+ };
1546
+ export type ProviderAuthAuthorization = {
1547
+ url: string;
1548
+ method: "auto" | "code";
1549
+ instructions: string;
1550
+ };
1551
+ export type Symbol = {
1552
+ name: string;
1553
+ kind: number;
1554
+ location: {
1555
+ uri: string;
1556
+ range: Range;
1557
+ };
1558
+ };
1559
+ export type FileNode = {
1560
+ name: string;
1561
+ path: string;
1562
+ absolute: string;
1563
+ type: "file" | "directory";
1564
+ ignored: boolean;
1565
+ };
1566
+ export type FileContent = {
1567
+ type: "text" | "binary";
1568
+ content: string;
1569
+ diff?: string;
1570
+ patch?: {
1571
+ oldFileName: string;
1572
+ newFileName: string;
1573
+ oldHeader?: string;
1574
+ newHeader?: string;
1575
+ hunks: Array<{
1576
+ oldStart: number;
1577
+ oldLines: number;
1578
+ newStart: number;
1579
+ newLines: number;
1580
+ lines: Array<string>;
1581
+ }>;
1582
+ index?: string;
1583
+ };
1584
+ encoding?: "base64";
1585
+ mimeType?: string;
1586
+ };
1587
+ export type File = {
1588
+ path: string;
1589
+ added: number;
1590
+ removed: number;
1591
+ status: "added" | "deleted" | "modified";
1592
+ };
1593
+ export type McpStatusConnected = {
1594
+ status: "connected";
1595
+ };
1596
+ export type McpStatusDisabled = {
1597
+ status: "disabled";
1598
+ };
1599
+ export type McpStatusFailed = {
1600
+ status: "failed";
1601
+ error: string;
1602
+ };
1603
+ export type McpStatusNeedsAuth = {
1604
+ status: "needs_auth";
1605
+ };
1606
+ export type McpStatusNeedsClientRegistration = {
1607
+ status: "needs_client_registration";
1608
+ error: string;
1609
+ };
1610
+ export type McpStatus = McpStatusConnected | McpStatusDisabled | McpStatusFailed | McpStatusNeedsAuth | McpStatusNeedsClientRegistration;
1611
+ export type Guardrail = {
1612
+ org: string;
1613
+ repo: string;
1614
+ remote?: string;
1615
+ fetched: number;
1616
+ };
1617
+ export type Path = {
1618
+ home: string;
1619
+ state: string;
1620
+ config: string;
1621
+ worktree: string;
1622
+ directory: string;
1623
+ };
1624
+ export type VcsInfo = {
1625
+ branch: string;
1626
+ };
1627
+ export type Command = {
1628
+ name: string;
1629
+ description?: string;
1630
+ agent?: string;
1631
+ model?: string;
1632
+ source?: "command" | "mcp" | "skill";
1633
+ template: string;
1634
+ subtask?: boolean;
1635
+ hints: Array<string>;
1636
+ };
1637
+ export type Agent = {
1638
+ name: string;
1639
+ description?: string;
1640
+ mode: "subagent" | "primary" | "all";
1641
+ native?: boolean;
1642
+ hidden?: boolean;
1643
+ topP?: number;
1644
+ temperature?: number;
1645
+ color?: string;
1646
+ permission: PermissionRuleset;
1647
+ model?: {
1648
+ modelID: string;
1649
+ providerID: string;
1650
+ };
1651
+ variant?: string;
1652
+ prompt?: string;
1653
+ options: {
1654
+ [key: string]: unknown;
1655
+ };
1656
+ steps?: number;
1657
+ };
1658
+ export type LspStatus = {
1659
+ id: string;
1660
+ name: string;
1661
+ root: string;
1662
+ status: "connected" | "error";
1663
+ };
1664
+ export type FormatterStatus = {
1665
+ name: string;
1666
+ extensions: Array<string>;
1667
+ enabled: boolean;
1668
+ };
1669
+ export type GlobalHealthData = {
1670
+ body?: never;
1671
+ path?: never;
1672
+ query?: never;
1673
+ url: "/global/health";
1674
+ };
1675
+ export type GlobalHealthResponses = {
1676
+ /**
1677
+ * Health information
1678
+ */
1679
+ 200: {
1680
+ healthy: true;
1681
+ version: string;
1682
+ };
1683
+ };
1684
+ export type GlobalHealthResponse = GlobalHealthResponses[keyof GlobalHealthResponses];
1685
+ export type GlobalEventData = {
1686
+ body?: never;
1687
+ path?: never;
1688
+ query?: never;
1689
+ url: "/global/event";
1690
+ };
1691
+ export type GlobalEventResponses = {
1692
+ /**
1693
+ * Event stream
1694
+ */
1695
+ 200: GlobalEvent;
1696
+ };
1697
+ export type GlobalEventResponse = GlobalEventResponses[keyof GlobalEventResponses];
1698
+ export type GlobalConfigGetData = {
1699
+ body?: never;
1700
+ path?: never;
1701
+ query?: never;
1702
+ url: "/global/config";
1703
+ };
1704
+ export type GlobalConfigGetResponses = {
1705
+ /**
1706
+ * Get global config info
1707
+ */
1708
+ 200: Config;
1709
+ };
1710
+ export type GlobalConfigGetResponse = GlobalConfigGetResponses[keyof GlobalConfigGetResponses];
1711
+ export type GlobalConfigUpdateData = {
1712
+ body?: Config;
1713
+ path?: never;
1714
+ query?: never;
1715
+ url: "/global/config";
1716
+ };
1717
+ export type GlobalConfigUpdateErrors = {
1718
+ /**
1719
+ * Bad request
1720
+ */
1721
+ 400: BadRequestError;
1722
+ };
1723
+ export type GlobalConfigUpdateError = GlobalConfigUpdateErrors[keyof GlobalConfigUpdateErrors];
1724
+ export type GlobalConfigUpdateResponses = {
1725
+ /**
1726
+ * Successfully updated global config
1727
+ */
1728
+ 200: Config;
1729
+ };
1730
+ export type GlobalConfigUpdateResponse = GlobalConfigUpdateResponses[keyof GlobalConfigUpdateResponses];
1731
+ export type GlobalDisposeData = {
1732
+ body?: never;
1733
+ path?: never;
1734
+ query?: never;
1735
+ url: "/global/dispose";
1736
+ };
1737
+ export type GlobalDisposeResponses = {
1738
+ /**
1739
+ * Global disposed
1740
+ */
1741
+ 200: boolean;
1742
+ };
1743
+ export type GlobalDisposeResponse = GlobalDisposeResponses[keyof GlobalDisposeResponses];
1744
+ export type AuthRemoveData = {
1745
+ body?: never;
1746
+ path: {
1747
+ providerID: string;
1748
+ };
1749
+ query?: never;
1750
+ url: "/auth/{providerID}";
1751
+ };
1752
+ export type AuthRemoveErrors = {
1753
+ /**
1754
+ * Bad request
1755
+ */
1756
+ 400: BadRequestError;
1757
+ };
1758
+ export type AuthRemoveError = AuthRemoveErrors[keyof AuthRemoveErrors];
1759
+ export type AuthRemoveResponses = {
1760
+ /**
1761
+ * Successfully removed authentication credentials
1762
+ */
1763
+ 200: boolean;
1764
+ };
1765
+ export type AuthRemoveResponse = AuthRemoveResponses[keyof AuthRemoveResponses];
1766
+ export type AuthSetData = {
1767
+ body?: Auth;
1768
+ path: {
1769
+ providerID: string;
1770
+ };
1771
+ query?: never;
1772
+ url: "/auth/{providerID}";
1773
+ };
1774
+ export type AuthSetErrors = {
1775
+ /**
1776
+ * Bad request
1777
+ */
1778
+ 400: BadRequestError;
1779
+ };
1780
+ export type AuthSetError = AuthSetErrors[keyof AuthSetErrors];
1781
+ export type AuthSetResponses = {
1782
+ /**
1783
+ * Successfully set authentication credentials
1784
+ */
1785
+ 200: boolean;
1786
+ };
1787
+ export type AuthSetResponse = AuthSetResponses[keyof AuthSetResponses];
1788
+ export type ProjectListData = {
1789
+ body?: never;
1790
+ path?: never;
1791
+ query?: {
1792
+ directory?: string;
1793
+ workspace?: string;
1794
+ };
1795
+ url: "/project";
1796
+ };
1797
+ export type ProjectListResponses = {
1798
+ /**
1799
+ * List of projects
1800
+ */
1801
+ 200: Array<Project>;
1802
+ };
1803
+ export type ProjectListResponse = ProjectListResponses[keyof ProjectListResponses];
1804
+ export type ProjectCurrentData = {
1805
+ body?: never;
1806
+ path?: never;
1807
+ query?: {
1808
+ directory?: string;
1809
+ workspace?: string;
1810
+ };
1811
+ url: "/project/current";
1812
+ };
1813
+ export type ProjectCurrentResponses = {
1814
+ /**
1815
+ * Current project information
1816
+ */
1817
+ 200: Project;
1818
+ };
1819
+ export type ProjectCurrentResponse = ProjectCurrentResponses[keyof ProjectCurrentResponses];
1820
+ export type ProjectInitGitData = {
1821
+ body?: never;
1822
+ path?: never;
1823
+ query?: {
1824
+ directory?: string;
1825
+ workspace?: string;
1826
+ };
1827
+ url: "/project/git/init";
1828
+ };
1829
+ export type ProjectInitGitResponses = {
1830
+ /**
1831
+ * Project information after git initialization
1832
+ */
1833
+ 200: Project;
1834
+ };
1835
+ export type ProjectInitGitResponse = ProjectInitGitResponses[keyof ProjectInitGitResponses];
1836
+ export type ProjectUpdateData = {
1837
+ body?: {
1838
+ name?: string;
1839
+ icon?: {
1840
+ url?: string;
1841
+ override?: string;
1842
+ color?: string;
1843
+ };
1844
+ commands?: {
1845
+ /**
1846
+ * Startup script to run when creating a new workspace (worktree)
1847
+ */
1848
+ start?: string;
1849
+ };
1850
+ };
1851
+ path: {
1852
+ projectID: string;
1853
+ };
1854
+ query?: {
1855
+ directory?: string;
1856
+ workspace?: string;
1857
+ };
1858
+ url: "/project/{projectID}";
1859
+ };
1860
+ export type ProjectUpdateErrors = {
1861
+ /**
1862
+ * Bad request
1863
+ */
1864
+ 400: BadRequestError;
1865
+ /**
1866
+ * Not found
1867
+ */
1868
+ 404: NotFoundError;
1869
+ };
1870
+ export type ProjectUpdateError = ProjectUpdateErrors[keyof ProjectUpdateErrors];
1871
+ export type ProjectUpdateResponses = {
1872
+ /**
1873
+ * Updated project information
1874
+ */
1875
+ 200: Project;
1876
+ };
1877
+ export type ProjectUpdateResponse = ProjectUpdateResponses[keyof ProjectUpdateResponses];
1878
+ export type PtyListData = {
1879
+ body?: never;
1880
+ path?: never;
1881
+ query?: {
1882
+ directory?: string;
1883
+ workspace?: string;
1884
+ };
1885
+ url: "/pty";
1886
+ };
1887
+ export type PtyListResponses = {
1888
+ /**
1889
+ * List of sessions
1890
+ */
1891
+ 200: Array<Pty>;
1892
+ };
1893
+ export type PtyListResponse = PtyListResponses[keyof PtyListResponses];
1894
+ export type PtyCreateData = {
1895
+ body?: {
1896
+ command?: string;
1897
+ args?: Array<string>;
1898
+ cwd?: string;
1899
+ title?: string;
1900
+ env?: {
1901
+ [key: string]: string;
1902
+ };
1903
+ };
1904
+ path?: never;
1905
+ query?: {
1906
+ directory?: string;
1907
+ workspace?: string;
1908
+ };
1909
+ url: "/pty";
1910
+ };
1911
+ export type PtyCreateErrors = {
1912
+ /**
1913
+ * Bad request
1914
+ */
1915
+ 400: BadRequestError;
1916
+ };
1917
+ export type PtyCreateError = PtyCreateErrors[keyof PtyCreateErrors];
1918
+ export type PtyCreateResponses = {
1919
+ /**
1920
+ * Created session
1921
+ */
1922
+ 200: Pty;
1923
+ };
1924
+ export type PtyCreateResponse = PtyCreateResponses[keyof PtyCreateResponses];
1925
+ export type PtyRemoveData = {
1926
+ body?: never;
1927
+ path: {
1928
+ ptyID: string;
1929
+ };
1930
+ query?: {
1931
+ directory?: string;
1932
+ workspace?: string;
1933
+ };
1934
+ url: "/pty/{ptyID}";
1935
+ };
1936
+ export type PtyRemoveErrors = {
1937
+ /**
1938
+ * Not found
1939
+ */
1940
+ 404: NotFoundError;
1941
+ };
1942
+ export type PtyRemoveError = PtyRemoveErrors[keyof PtyRemoveErrors];
1943
+ export type PtyRemoveResponses = {
1944
+ /**
1945
+ * Session removed
1946
+ */
1947
+ 200: boolean;
1948
+ };
1949
+ export type PtyRemoveResponse = PtyRemoveResponses[keyof PtyRemoveResponses];
1950
+ export type PtyGetData = {
1951
+ body?: never;
1952
+ path: {
1953
+ ptyID: string;
1954
+ };
1955
+ query?: {
1956
+ directory?: string;
1957
+ workspace?: string;
1958
+ };
1959
+ url: "/pty/{ptyID}";
1960
+ };
1961
+ export type PtyGetErrors = {
1962
+ /**
1963
+ * Not found
1964
+ */
1965
+ 404: NotFoundError;
1966
+ };
1967
+ export type PtyGetError = PtyGetErrors[keyof PtyGetErrors];
1968
+ export type PtyGetResponses = {
1969
+ /**
1970
+ * Session info
1971
+ */
1972
+ 200: Pty;
1973
+ };
1974
+ export type PtyGetResponse = PtyGetResponses[keyof PtyGetResponses];
1975
+ export type PtyUpdateData = {
1976
+ body?: {
1977
+ title?: string;
1978
+ size?: {
1979
+ rows: number;
1980
+ cols: number;
1981
+ };
1982
+ };
1983
+ path: {
1984
+ ptyID: string;
1985
+ };
1986
+ query?: {
1987
+ directory?: string;
1988
+ workspace?: string;
1989
+ };
1990
+ url: "/pty/{ptyID}";
1991
+ };
1992
+ export type PtyUpdateErrors = {
1993
+ /**
1994
+ * Bad request
1995
+ */
1996
+ 400: BadRequestError;
1997
+ };
1998
+ export type PtyUpdateError = PtyUpdateErrors[keyof PtyUpdateErrors];
1999
+ export type PtyUpdateResponses = {
2000
+ /**
2001
+ * Updated session
2002
+ */
2003
+ 200: Pty;
2004
+ };
2005
+ export type PtyUpdateResponse = PtyUpdateResponses[keyof PtyUpdateResponses];
2006
+ export type PtyConnectData = {
2007
+ body?: never;
2008
+ path: {
2009
+ ptyID: string;
2010
+ };
2011
+ query?: {
2012
+ directory?: string;
2013
+ workspace?: string;
2014
+ };
2015
+ url: "/pty/{ptyID}/connect";
2016
+ };
2017
+ export type PtyConnectErrors = {
2018
+ /**
2019
+ * Not found
2020
+ */
2021
+ 404: NotFoundError;
2022
+ };
2023
+ export type PtyConnectError = PtyConnectErrors[keyof PtyConnectErrors];
2024
+ export type PtyConnectResponses = {
2025
+ /**
2026
+ * Connected session
2027
+ */
2028
+ 200: boolean;
2029
+ };
2030
+ export type PtyConnectResponse = PtyConnectResponses[keyof PtyConnectResponses];
2031
+ export type ConfigGetData = {
2032
+ body?: never;
2033
+ path?: never;
2034
+ query?: {
2035
+ directory?: string;
2036
+ workspace?: string;
2037
+ };
2038
+ url: "/config";
2039
+ };
2040
+ export type ConfigGetResponses = {
2041
+ /**
2042
+ * Get config info
2043
+ */
2044
+ 200: Config;
2045
+ };
2046
+ export type ConfigGetResponse = ConfigGetResponses[keyof ConfigGetResponses];
2047
+ export type ConfigUpdateData = {
2048
+ body?: Config;
2049
+ path?: never;
2050
+ query?: {
2051
+ directory?: string;
2052
+ workspace?: string;
2053
+ };
2054
+ url: "/config";
2055
+ };
2056
+ export type ConfigUpdateErrors = {
2057
+ /**
2058
+ * Bad request
2059
+ */
2060
+ 400: BadRequestError;
2061
+ };
2062
+ export type ConfigUpdateError = ConfigUpdateErrors[keyof ConfigUpdateErrors];
2063
+ export type ConfigUpdateResponses = {
2064
+ /**
2065
+ * Successfully updated config
2066
+ */
2067
+ 200: Config;
2068
+ };
2069
+ export type ConfigUpdateResponse = ConfigUpdateResponses[keyof ConfigUpdateResponses];
2070
+ export type ConfigProvidersData = {
2071
+ body?: never;
2072
+ path?: never;
2073
+ query?: {
2074
+ directory?: string;
2075
+ workspace?: string;
2076
+ };
2077
+ url: "/config/providers";
2078
+ };
2079
+ export type ConfigProvidersResponses = {
2080
+ /**
2081
+ * List of providers
2082
+ */
2083
+ 200: {
2084
+ providers: Array<Provider>;
2085
+ default: {
2086
+ [key: string]: string;
2087
+ };
2088
+ };
2089
+ };
2090
+ export type ConfigProvidersResponse = ConfigProvidersResponses[keyof ConfigProvidersResponses];
2091
+ export type ToolIdsData = {
2092
+ body?: never;
2093
+ path?: never;
2094
+ query?: {
2095
+ directory?: string;
2096
+ workspace?: string;
2097
+ };
2098
+ url: "/experimental/tool/ids";
2099
+ };
2100
+ export type ToolIdsErrors = {
2101
+ /**
2102
+ * Bad request
2103
+ */
2104
+ 400: BadRequestError;
2105
+ };
2106
+ export type ToolIdsError = ToolIdsErrors[keyof ToolIdsErrors];
2107
+ export type ToolIdsResponses = {
2108
+ /**
2109
+ * Tool IDs
2110
+ */
2111
+ 200: ToolIds;
2112
+ };
2113
+ export type ToolIdsResponse = ToolIdsResponses[keyof ToolIdsResponses];
2114
+ export type ToolListData = {
2115
+ body?: never;
2116
+ path?: never;
2117
+ query: {
2118
+ directory?: string;
2119
+ workspace?: string;
2120
+ provider: string;
2121
+ model: string;
2122
+ };
2123
+ url: "/experimental/tool";
2124
+ };
2125
+ export type ToolListErrors = {
2126
+ /**
2127
+ * Bad request
2128
+ */
2129
+ 400: BadRequestError;
2130
+ };
2131
+ export type ToolListError = ToolListErrors[keyof ToolListErrors];
2132
+ export type ToolListResponses = {
2133
+ /**
2134
+ * Tools
2135
+ */
2136
+ 200: ToolList;
2137
+ };
2138
+ export type ToolListResponse = ToolListResponses[keyof ToolListResponses];
2139
+ export type ExperimentalWorkspaceListData = {
2140
+ body?: never;
2141
+ path?: never;
2142
+ query?: {
2143
+ directory?: string;
2144
+ workspace?: string;
2145
+ };
2146
+ url: "/experimental/workspace";
2147
+ };
2148
+ export type ExperimentalWorkspaceListResponses = {
2149
+ /**
2150
+ * Workspaces
2151
+ */
2152
+ 200: Array<Workspace>;
2153
+ };
2154
+ export type ExperimentalWorkspaceListResponse = ExperimentalWorkspaceListResponses[keyof ExperimentalWorkspaceListResponses];
2155
+ export type ExperimentalWorkspaceCreateData = {
2156
+ body?: {
2157
+ id?: string;
2158
+ type: string;
2159
+ branch: string | null;
2160
+ extra: unknown | null;
2161
+ };
2162
+ path?: never;
2163
+ query?: {
2164
+ directory?: string;
2165
+ workspace?: string;
2166
+ };
2167
+ url: "/experimental/workspace";
2168
+ };
2169
+ export type ExperimentalWorkspaceCreateErrors = {
2170
+ /**
2171
+ * Bad request
2172
+ */
2173
+ 400: BadRequestError;
2174
+ };
2175
+ export type ExperimentalWorkspaceCreateError = ExperimentalWorkspaceCreateErrors[keyof ExperimentalWorkspaceCreateErrors];
2176
+ export type ExperimentalWorkspaceCreateResponses = {
2177
+ /**
2178
+ * Workspace created
2179
+ */
2180
+ 200: Workspace;
2181
+ };
2182
+ export type ExperimentalWorkspaceCreateResponse = ExperimentalWorkspaceCreateResponses[keyof ExperimentalWorkspaceCreateResponses];
2183
+ export type ExperimentalWorkspaceRemoveData = {
2184
+ body?: never;
2185
+ path: {
2186
+ id: string;
2187
+ };
2188
+ query?: {
2189
+ directory?: string;
2190
+ workspace?: string;
2191
+ };
2192
+ url: "/experimental/workspace/{id}";
2193
+ };
2194
+ export type ExperimentalWorkspaceRemoveErrors = {
2195
+ /**
2196
+ * Bad request
2197
+ */
2198
+ 400: BadRequestError;
2199
+ };
2200
+ export type ExperimentalWorkspaceRemoveError = ExperimentalWorkspaceRemoveErrors[keyof ExperimentalWorkspaceRemoveErrors];
2201
+ export type ExperimentalWorkspaceRemoveResponses = {
2202
+ /**
2203
+ * Workspace removed
2204
+ */
2205
+ 200: Workspace;
2206
+ };
2207
+ export type ExperimentalWorkspaceRemoveResponse = ExperimentalWorkspaceRemoveResponses[keyof ExperimentalWorkspaceRemoveResponses];
2208
+ export type WorktreeRemoveData = {
2209
+ body?: WorktreeRemoveInput;
2210
+ path?: never;
2211
+ query?: {
2212
+ directory?: string;
2213
+ workspace?: string;
2214
+ };
2215
+ url: "/experimental/worktree";
2216
+ };
2217
+ export type WorktreeRemoveErrors = {
2218
+ /**
2219
+ * Bad request
2220
+ */
2221
+ 400: BadRequestError;
2222
+ };
2223
+ export type WorktreeRemoveError = WorktreeRemoveErrors[keyof WorktreeRemoveErrors];
2224
+ export type WorktreeRemoveResponses = {
2225
+ /**
2226
+ * Worktree removed
2227
+ */
2228
+ 200: boolean;
2229
+ };
2230
+ export type WorktreeRemoveResponse = WorktreeRemoveResponses[keyof WorktreeRemoveResponses];
2231
+ export type WorktreeListData = {
2232
+ body?: never;
2233
+ path?: never;
2234
+ query?: {
2235
+ directory?: string;
2236
+ workspace?: string;
2237
+ };
2238
+ url: "/experimental/worktree";
2239
+ };
2240
+ export type WorktreeListResponses = {
2241
+ /**
2242
+ * List of worktree directories
2243
+ */
2244
+ 200: Array<string>;
2245
+ };
2246
+ export type WorktreeListResponse = WorktreeListResponses[keyof WorktreeListResponses];
2247
+ export type WorktreeCreateData = {
2248
+ body?: WorktreeCreateInput;
2249
+ path?: never;
2250
+ query?: {
2251
+ directory?: string;
2252
+ workspace?: string;
2253
+ };
2254
+ url: "/experimental/worktree";
2255
+ };
2256
+ export type WorktreeCreateErrors = {
2257
+ /**
2258
+ * Bad request
2259
+ */
2260
+ 400: BadRequestError;
2261
+ };
2262
+ export type WorktreeCreateError = WorktreeCreateErrors[keyof WorktreeCreateErrors];
2263
+ export type WorktreeCreateResponses = {
2264
+ /**
2265
+ * Worktree created
2266
+ */
2267
+ 200: Worktree;
2268
+ };
2269
+ export type WorktreeCreateResponse = WorktreeCreateResponses[keyof WorktreeCreateResponses];
2270
+ export type WorktreeResetData = {
2271
+ body?: WorktreeResetInput;
2272
+ path?: never;
2273
+ query?: {
2274
+ directory?: string;
2275
+ workspace?: string;
2276
+ };
2277
+ url: "/experimental/worktree/reset";
2278
+ };
2279
+ export type WorktreeResetErrors = {
2280
+ /**
2281
+ * Bad request
2282
+ */
2283
+ 400: BadRequestError;
2284
+ };
2285
+ export type WorktreeResetError = WorktreeResetErrors[keyof WorktreeResetErrors];
2286
+ export type WorktreeResetResponses = {
2287
+ /**
2288
+ * Worktree reset
2289
+ */
2290
+ 200: boolean;
2291
+ };
2292
+ export type WorktreeResetResponse = WorktreeResetResponses[keyof WorktreeResetResponses];
2293
+ export type ExperimentalSessionListData = {
2294
+ body?: never;
2295
+ path?: never;
2296
+ query?: {
2297
+ /**
2298
+ * Filter sessions by project directory
2299
+ */
2300
+ directory?: string;
2301
+ workspace?: string;
2302
+ /**
2303
+ * Only return root sessions (no parentID)
2304
+ */
2305
+ roots?: boolean;
2306
+ /**
2307
+ * Filter sessions updated on or after this timestamp (milliseconds since epoch)
2308
+ */
2309
+ start?: number;
2310
+ /**
2311
+ * Return sessions updated before this timestamp (milliseconds since epoch)
2312
+ */
2313
+ cursor?: number;
2314
+ /**
2315
+ * Filter sessions by title (case-insensitive)
2316
+ */
2317
+ search?: string;
2318
+ /**
2319
+ * Maximum number of sessions to return
2320
+ */
2321
+ limit?: number;
2322
+ /**
2323
+ * Include archived sessions (default false)
2324
+ */
2325
+ archived?: boolean;
2326
+ };
2327
+ url: "/experimental/session";
2328
+ };
2329
+ export type ExperimentalSessionListResponses = {
2330
+ /**
2331
+ * List of sessions
2332
+ */
2333
+ 200: Array<GlobalSession>;
2334
+ };
2335
+ export type ExperimentalSessionListResponse = ExperimentalSessionListResponses[keyof ExperimentalSessionListResponses];
2336
+ export type ExperimentalResourceListData = {
2337
+ body?: never;
2338
+ path?: never;
2339
+ query?: {
2340
+ directory?: string;
2341
+ workspace?: string;
2342
+ };
2343
+ url: "/experimental/resource";
2344
+ };
2345
+ export type ExperimentalResourceListResponses = {
2346
+ /**
2347
+ * MCP resources
2348
+ */
2349
+ 200: {
2350
+ [key: string]: McpResource;
2351
+ };
2352
+ };
2353
+ export type ExperimentalResourceListResponse = ExperimentalResourceListResponses[keyof ExperimentalResourceListResponses];
2354
+ export type SessionListData = {
2355
+ body?: never;
2356
+ path?: never;
2357
+ query?: {
2358
+ /**
2359
+ * Filter sessions by project directory
2360
+ */
2361
+ directory?: string;
2362
+ workspace?: string;
2363
+ /**
2364
+ * Only return root sessions (no parentID)
2365
+ */
2366
+ roots?: boolean;
2367
+ /**
2368
+ * Filter sessions updated on or after this timestamp (milliseconds since epoch)
2369
+ */
2370
+ start?: number;
2371
+ /**
2372
+ * Filter sessions by title (case-insensitive)
2373
+ */
2374
+ search?: string;
2375
+ /**
2376
+ * Maximum number of sessions to return
2377
+ */
2378
+ limit?: number;
2379
+ };
2380
+ url: "/session";
2381
+ };
2382
+ export type SessionListResponses = {
2383
+ /**
2384
+ * List of sessions
2385
+ */
2386
+ 200: Array<Session>;
2387
+ };
2388
+ export type SessionListResponse = SessionListResponses[keyof SessionListResponses];
2389
+ export type SessionCreateData = {
2390
+ body?: {
2391
+ parentID?: string;
2392
+ title?: string;
2393
+ permission?: PermissionRuleset;
2394
+ workspaceID?: string;
2395
+ };
2396
+ path?: never;
2397
+ query?: {
2398
+ directory?: string;
2399
+ workspace?: string;
2400
+ };
2401
+ url: "/session";
2402
+ };
2403
+ export type SessionCreateErrors = {
2404
+ /**
2405
+ * Bad request
2406
+ */
2407
+ 400: BadRequestError;
2408
+ };
2409
+ export type SessionCreateError = SessionCreateErrors[keyof SessionCreateErrors];
2410
+ export type SessionCreateResponses = {
2411
+ /**
2412
+ * Successfully created session
2413
+ */
2414
+ 200: Session;
2415
+ };
2416
+ export type SessionCreateResponse = SessionCreateResponses[keyof SessionCreateResponses];
2417
+ export type SessionStatusData = {
2418
+ body?: never;
2419
+ path?: never;
2420
+ query?: {
2421
+ directory?: string;
2422
+ workspace?: string;
2423
+ };
2424
+ url: "/session/status";
2425
+ };
2426
+ export type SessionStatusErrors = {
2427
+ /**
2428
+ * Bad request
2429
+ */
2430
+ 400: BadRequestError;
2431
+ };
2432
+ export type SessionStatusError = SessionStatusErrors[keyof SessionStatusErrors];
2433
+ export type SessionStatusResponses = {
2434
+ /**
2435
+ * Get session status
2436
+ */
2437
+ 200: {
2438
+ [key: string]: SessionStatus;
2439
+ };
2440
+ };
2441
+ export type SessionStatusResponse = SessionStatusResponses[keyof SessionStatusResponses];
2442
+ export type SessionDeleteData = {
2443
+ body?: never;
2444
+ path: {
2445
+ sessionID: string;
2446
+ };
2447
+ query?: {
2448
+ directory?: string;
2449
+ workspace?: string;
2450
+ };
2451
+ url: "/session/{sessionID}";
2452
+ };
2453
+ export type SessionDeleteErrors = {
2454
+ /**
2455
+ * Bad request
2456
+ */
2457
+ 400: BadRequestError;
2458
+ /**
2459
+ * Not found
2460
+ */
2461
+ 404: NotFoundError;
2462
+ };
2463
+ export type SessionDeleteError = SessionDeleteErrors[keyof SessionDeleteErrors];
2464
+ export type SessionDeleteResponses = {
2465
+ /**
2466
+ * Successfully deleted session
2467
+ */
2468
+ 200: boolean;
2469
+ };
2470
+ export type SessionDeleteResponse = SessionDeleteResponses[keyof SessionDeleteResponses];
2471
+ export type SessionGetData = {
2472
+ body?: never;
2473
+ path: {
2474
+ sessionID: string;
2475
+ };
2476
+ query?: {
2477
+ directory?: string;
2478
+ workspace?: string;
2479
+ };
2480
+ url: "/session/{sessionID}";
2481
+ };
2482
+ export type SessionGetErrors = {
2483
+ /**
2484
+ * Bad request
2485
+ */
2486
+ 400: BadRequestError;
2487
+ /**
2488
+ * Not found
2489
+ */
2490
+ 404: NotFoundError;
2491
+ };
2492
+ export type SessionGetError = SessionGetErrors[keyof SessionGetErrors];
2493
+ export type SessionGetResponses = {
2494
+ /**
2495
+ * Get session
2496
+ */
2497
+ 200: Session;
2498
+ };
2499
+ export type SessionGetResponse = SessionGetResponses[keyof SessionGetResponses];
2500
+ export type SessionUpdateData = {
2501
+ body?: {
2502
+ title?: string;
2503
+ time?: {
2504
+ archived?: number;
2505
+ };
2506
+ };
2507
+ path: {
2508
+ sessionID: string;
2509
+ };
2510
+ query?: {
2511
+ directory?: string;
2512
+ workspace?: string;
2513
+ };
2514
+ url: "/session/{sessionID}";
2515
+ };
2516
+ export type SessionUpdateErrors = {
2517
+ /**
2518
+ * Bad request
2519
+ */
2520
+ 400: BadRequestError;
2521
+ /**
2522
+ * Not found
2523
+ */
2524
+ 404: NotFoundError;
2525
+ };
2526
+ export type SessionUpdateError = SessionUpdateErrors[keyof SessionUpdateErrors];
2527
+ export type SessionUpdateResponses = {
2528
+ /**
2529
+ * Successfully updated session
2530
+ */
2531
+ 200: Session;
2532
+ };
2533
+ export type SessionUpdateResponse = SessionUpdateResponses[keyof SessionUpdateResponses];
2534
+ export type SessionChildrenData = {
2535
+ body?: never;
2536
+ path: {
2537
+ sessionID: string;
2538
+ };
2539
+ query?: {
2540
+ directory?: string;
2541
+ workspace?: string;
2542
+ };
2543
+ url: "/session/{sessionID}/children";
2544
+ };
2545
+ export type SessionChildrenErrors = {
2546
+ /**
2547
+ * Bad request
2548
+ */
2549
+ 400: BadRequestError;
2550
+ /**
2551
+ * Not found
2552
+ */
2553
+ 404: NotFoundError;
2554
+ };
2555
+ export type SessionChildrenError = SessionChildrenErrors[keyof SessionChildrenErrors];
2556
+ export type SessionChildrenResponses = {
2557
+ /**
2558
+ * List of children
2559
+ */
2560
+ 200: Array<Session>;
2561
+ };
2562
+ export type SessionChildrenResponse = SessionChildrenResponses[keyof SessionChildrenResponses];
2563
+ export type SessionTodoData = {
2564
+ body?: never;
2565
+ path: {
2566
+ sessionID: string;
2567
+ };
2568
+ query?: {
2569
+ directory?: string;
2570
+ workspace?: string;
2571
+ };
2572
+ url: "/session/{sessionID}/todo";
2573
+ };
2574
+ export type SessionTodoErrors = {
2575
+ /**
2576
+ * Bad request
2577
+ */
2578
+ 400: BadRequestError;
2579
+ /**
2580
+ * Not found
2581
+ */
2582
+ 404: NotFoundError;
2583
+ };
2584
+ export type SessionTodoError = SessionTodoErrors[keyof SessionTodoErrors];
2585
+ export type SessionTodoResponses = {
2586
+ /**
2587
+ * Todo list
2588
+ */
2589
+ 200: Array<Todo>;
2590
+ };
2591
+ export type SessionTodoResponse = SessionTodoResponses[keyof SessionTodoResponses];
2592
+ export type SessionInitData = {
2593
+ body?: {
2594
+ modelID: string;
2595
+ providerID: string;
2596
+ messageID: string;
2597
+ };
2598
+ path: {
2599
+ sessionID: string;
2600
+ };
2601
+ query?: {
2602
+ directory?: string;
2603
+ workspace?: string;
2604
+ };
2605
+ url: "/session/{sessionID}/init";
2606
+ };
2607
+ export type SessionInitErrors = {
2608
+ /**
2609
+ * Bad request
2610
+ */
2611
+ 400: BadRequestError;
2612
+ /**
2613
+ * Not found
2614
+ */
2615
+ 404: NotFoundError;
2616
+ };
2617
+ export type SessionInitError = SessionInitErrors[keyof SessionInitErrors];
2618
+ export type SessionInitResponses = {
2619
+ /**
2620
+ * 200
2621
+ */
2622
+ 200: boolean;
2623
+ };
2624
+ export type SessionInitResponse = SessionInitResponses[keyof SessionInitResponses];
2625
+ export type SessionForkData = {
2626
+ body?: {
2627
+ messageID?: string;
2628
+ };
2629
+ path: {
2630
+ sessionID: string;
2631
+ };
2632
+ query?: {
2633
+ directory?: string;
2634
+ workspace?: string;
2635
+ };
2636
+ url: "/session/{sessionID}/fork";
2637
+ };
2638
+ export type SessionForkResponses = {
2639
+ /**
2640
+ * 200
2641
+ */
2642
+ 200: Session;
2643
+ };
2644
+ export type SessionForkResponse = SessionForkResponses[keyof SessionForkResponses];
2645
+ export type SessionAbortData = {
2646
+ body?: never;
2647
+ path: {
2648
+ sessionID: string;
2649
+ };
2650
+ query?: {
2651
+ directory?: string;
2652
+ workspace?: string;
2653
+ };
2654
+ url: "/session/{sessionID}/abort";
2655
+ };
2656
+ export type SessionAbortErrors = {
2657
+ /**
2658
+ * Bad request
2659
+ */
2660
+ 400: BadRequestError;
2661
+ /**
2662
+ * Not found
2663
+ */
2664
+ 404: NotFoundError;
2665
+ };
2666
+ export type SessionAbortError = SessionAbortErrors[keyof SessionAbortErrors];
2667
+ export type SessionAbortResponses = {
2668
+ /**
2669
+ * Aborted session
2670
+ */
2671
+ 200: boolean;
2672
+ };
2673
+ export type SessionAbortResponse = SessionAbortResponses[keyof SessionAbortResponses];
2674
+ export type SessionUnshareData = {
2675
+ body?: never;
2676
+ path: {
2677
+ sessionID: string;
2678
+ };
2679
+ query?: {
2680
+ directory?: string;
2681
+ workspace?: string;
2682
+ };
2683
+ url: "/session/{sessionID}/share";
2684
+ };
2685
+ export type SessionUnshareErrors = {
2686
+ /**
2687
+ * Bad request
2688
+ */
2689
+ 400: BadRequestError;
2690
+ /**
2691
+ * Not found
2692
+ */
2693
+ 404: NotFoundError;
2694
+ };
2695
+ export type SessionUnshareError = SessionUnshareErrors[keyof SessionUnshareErrors];
2696
+ export type SessionUnshareResponses = {
2697
+ /**
2698
+ * Successfully unshared session
2699
+ */
2700
+ 200: Session;
2701
+ };
2702
+ export type SessionUnshareResponse = SessionUnshareResponses[keyof SessionUnshareResponses];
2703
+ export type SessionShareData = {
2704
+ body?: never;
2705
+ path: {
2706
+ sessionID: string;
2707
+ };
2708
+ query?: {
2709
+ directory?: string;
2710
+ workspace?: string;
2711
+ };
2712
+ url: "/session/{sessionID}/share";
2713
+ };
2714
+ export type SessionShareErrors = {
2715
+ /**
2716
+ * Bad request
2717
+ */
2718
+ 400: BadRequestError;
2719
+ /**
2720
+ * Not found
2721
+ */
2722
+ 404: NotFoundError;
2723
+ };
2724
+ export type SessionShareError = SessionShareErrors[keyof SessionShareErrors];
2725
+ export type SessionShareResponses = {
2726
+ /**
2727
+ * Successfully shared session
2728
+ */
2729
+ 200: Session;
2730
+ };
2731
+ export type SessionShareResponse = SessionShareResponses[keyof SessionShareResponses];
2732
+ export type SessionDiffData = {
2733
+ body?: never;
2734
+ path: {
2735
+ sessionID: string;
2736
+ };
2737
+ query?: {
2738
+ directory?: string;
2739
+ workspace?: string;
2740
+ messageID?: string;
2741
+ };
2742
+ url: "/session/{sessionID}/diff";
2743
+ };
2744
+ export type SessionDiffResponses = {
2745
+ /**
2746
+ * Successfully retrieved diff
2747
+ */
2748
+ 200: Array<FileDiff>;
2749
+ };
2750
+ export type SessionDiffResponse = SessionDiffResponses[keyof SessionDiffResponses];
2751
+ export type SessionSummarizeData = {
2752
+ body?: {
2753
+ providerID: string;
2754
+ modelID: string;
2755
+ auto?: boolean;
2756
+ };
2757
+ path: {
2758
+ sessionID: string;
2759
+ };
2760
+ query?: {
2761
+ directory?: string;
2762
+ workspace?: string;
2763
+ };
2764
+ url: "/session/{sessionID}/summarize";
2765
+ };
2766
+ export type SessionSummarizeErrors = {
2767
+ /**
2768
+ * Bad request
2769
+ */
2770
+ 400: BadRequestError;
2771
+ /**
2772
+ * Not found
2773
+ */
2774
+ 404: NotFoundError;
2775
+ };
2776
+ export type SessionSummarizeError = SessionSummarizeErrors[keyof SessionSummarizeErrors];
2777
+ export type SessionSummarizeResponses = {
2778
+ /**
2779
+ * Summarized session
2780
+ */
2781
+ 200: boolean;
2782
+ };
2783
+ export type SessionSummarizeResponse = SessionSummarizeResponses[keyof SessionSummarizeResponses];
2784
+ export type SessionMessagesData = {
2785
+ body?: never;
2786
+ path: {
2787
+ sessionID: string;
2788
+ };
2789
+ query?: {
2790
+ directory?: string;
2791
+ workspace?: string;
2792
+ /**
2793
+ * Maximum number of messages to return
2794
+ */
2795
+ limit?: number;
2796
+ before?: string;
2797
+ };
2798
+ url: "/session/{sessionID}/message";
2799
+ };
2800
+ export type SessionMessagesErrors = {
2801
+ /**
2802
+ * Bad request
2803
+ */
2804
+ 400: BadRequestError;
2805
+ /**
2806
+ * Not found
2807
+ */
2808
+ 404: NotFoundError;
2809
+ };
2810
+ export type SessionMessagesError = SessionMessagesErrors[keyof SessionMessagesErrors];
2811
+ export type SessionMessagesResponses = {
2812
+ /**
2813
+ * List of messages
2814
+ */
2815
+ 200: Array<{
2816
+ info: Message;
2817
+ parts: Array<Part>;
2818
+ }>;
2819
+ };
2820
+ export type SessionMessagesResponse = SessionMessagesResponses[keyof SessionMessagesResponses];
2821
+ export type SessionPromptData = {
2822
+ body?: {
2823
+ messageID?: string;
2824
+ model?: {
2825
+ providerID: string;
2826
+ modelID: string;
2827
+ };
2828
+ agent?: string;
2829
+ noReply?: boolean;
2830
+ /**
2831
+ * @deprecated tools and permissions have been merged, you can set permissions on the session itself now
2832
+ */
2833
+ tools?: {
2834
+ [key: string]: boolean;
2835
+ };
2836
+ format?: OutputFormat;
2837
+ system?: string;
2838
+ variant?: string;
2839
+ parts: Array<TextPartInput | FilePartInput | AgentPartInput | SubtaskPartInput>;
2840
+ };
2841
+ path: {
2842
+ sessionID: string;
2843
+ };
2844
+ query?: {
2845
+ directory?: string;
2846
+ workspace?: string;
2847
+ };
2848
+ url: "/session/{sessionID}/message";
2849
+ };
2850
+ export type SessionPromptErrors = {
2851
+ /**
2852
+ * Bad request
2853
+ */
2854
+ 400: BadRequestError;
2855
+ /**
2856
+ * Not found
2857
+ */
2858
+ 404: NotFoundError;
2859
+ };
2860
+ export type SessionPromptError = SessionPromptErrors[keyof SessionPromptErrors];
2861
+ export type SessionPromptResponses = {
2862
+ /**
2863
+ * Created message
2864
+ */
2865
+ 200: {
2866
+ info: AssistantMessage;
2867
+ parts: Array<Part>;
2868
+ };
2869
+ };
2870
+ export type SessionPromptResponse = SessionPromptResponses[keyof SessionPromptResponses];
2871
+ export type SessionDeleteMessageData = {
2872
+ body?: never;
2873
+ path: {
2874
+ sessionID: string;
2875
+ messageID: string;
2876
+ };
2877
+ query?: {
2878
+ directory?: string;
2879
+ workspace?: string;
2880
+ };
2881
+ url: "/session/{sessionID}/message/{messageID}";
2882
+ };
2883
+ export type SessionDeleteMessageErrors = {
2884
+ /**
2885
+ * Bad request
2886
+ */
2887
+ 400: BadRequestError;
2888
+ /**
2889
+ * Not found
2890
+ */
2891
+ 404: NotFoundError;
2892
+ };
2893
+ export type SessionDeleteMessageError = SessionDeleteMessageErrors[keyof SessionDeleteMessageErrors];
2894
+ export type SessionDeleteMessageResponses = {
2895
+ /**
2896
+ * Successfully deleted message
2897
+ */
2898
+ 200: boolean;
2899
+ };
2900
+ export type SessionDeleteMessageResponse = SessionDeleteMessageResponses[keyof SessionDeleteMessageResponses];
2901
+ export type SessionMessageData = {
2902
+ body?: never;
2903
+ path: {
2904
+ sessionID: string;
2905
+ messageID: string;
2906
+ };
2907
+ query?: {
2908
+ directory?: string;
2909
+ workspace?: string;
2910
+ };
2911
+ url: "/session/{sessionID}/message/{messageID}";
2912
+ };
2913
+ export type SessionMessageErrors = {
2914
+ /**
2915
+ * Bad request
2916
+ */
2917
+ 400: BadRequestError;
2918
+ /**
2919
+ * Not found
2920
+ */
2921
+ 404: NotFoundError;
2922
+ };
2923
+ export type SessionMessageError = SessionMessageErrors[keyof SessionMessageErrors];
2924
+ export type SessionMessageResponses = {
2925
+ /**
2926
+ * Message
2927
+ */
2928
+ 200: {
2929
+ info: Message;
2930
+ parts: Array<Part>;
2931
+ };
2932
+ };
2933
+ export type SessionMessageResponse = SessionMessageResponses[keyof SessionMessageResponses];
2934
+ export type PartDeleteData = {
2935
+ body?: never;
2936
+ path: {
2937
+ sessionID: string;
2938
+ messageID: string;
2939
+ partID: string;
2940
+ };
2941
+ query?: {
2942
+ directory?: string;
2943
+ workspace?: string;
2944
+ };
2945
+ url: "/session/{sessionID}/message/{messageID}/part/{partID}";
2946
+ };
2947
+ export type PartDeleteErrors = {
2948
+ /**
2949
+ * Bad request
2950
+ */
2951
+ 400: BadRequestError;
2952
+ /**
2953
+ * Not found
2954
+ */
2955
+ 404: NotFoundError;
2956
+ };
2957
+ export type PartDeleteError = PartDeleteErrors[keyof PartDeleteErrors];
2958
+ export type PartDeleteResponses = {
2959
+ /**
2960
+ * Successfully deleted part
2961
+ */
2962
+ 200: boolean;
2963
+ };
2964
+ export type PartDeleteResponse = PartDeleteResponses[keyof PartDeleteResponses];
2965
+ export type PartUpdateData = {
2966
+ body?: Part;
2967
+ path: {
2968
+ sessionID: string;
2969
+ messageID: string;
2970
+ partID: string;
2971
+ };
2972
+ query?: {
2973
+ directory?: string;
2974
+ workspace?: string;
2975
+ };
2976
+ url: "/session/{sessionID}/message/{messageID}/part/{partID}";
2977
+ };
2978
+ export type PartUpdateErrors = {
2979
+ /**
2980
+ * Bad request
2981
+ */
2982
+ 400: BadRequestError;
2983
+ /**
2984
+ * Not found
2985
+ */
2986
+ 404: NotFoundError;
2987
+ };
2988
+ export type PartUpdateError = PartUpdateErrors[keyof PartUpdateErrors];
2989
+ export type PartUpdateResponses = {
2990
+ /**
2991
+ * Successfully updated part
2992
+ */
2993
+ 200: Part;
2994
+ };
2995
+ export type PartUpdateResponse = PartUpdateResponses[keyof PartUpdateResponses];
2996
+ export type SessionPromptAsyncData = {
2997
+ body?: {
2998
+ messageID?: string;
2999
+ model?: {
3000
+ providerID: string;
3001
+ modelID: string;
3002
+ };
3003
+ agent?: string;
3004
+ noReply?: boolean;
3005
+ /**
3006
+ * @deprecated tools and permissions have been merged, you can set permissions on the session itself now
3007
+ */
3008
+ tools?: {
3009
+ [key: string]: boolean;
3010
+ };
3011
+ format?: OutputFormat;
3012
+ system?: string;
3013
+ variant?: string;
3014
+ parts: Array<TextPartInput | FilePartInput | AgentPartInput | SubtaskPartInput>;
3015
+ };
3016
+ path: {
3017
+ sessionID: string;
3018
+ };
3019
+ query?: {
3020
+ directory?: string;
3021
+ workspace?: string;
3022
+ };
3023
+ url: "/session/{sessionID}/prompt_async";
3024
+ };
3025
+ export type SessionPromptAsyncErrors = {
3026
+ /**
3027
+ * Bad request
3028
+ */
3029
+ 400: BadRequestError;
3030
+ /**
3031
+ * Not found
3032
+ */
3033
+ 404: NotFoundError;
3034
+ };
3035
+ export type SessionPromptAsyncError = SessionPromptAsyncErrors[keyof SessionPromptAsyncErrors];
3036
+ export type SessionPromptAsyncResponses = {
3037
+ /**
3038
+ * Prompt accepted
3039
+ */
3040
+ 204: void;
3041
+ };
3042
+ export type SessionPromptAsyncResponse = SessionPromptAsyncResponses[keyof SessionPromptAsyncResponses];
3043
+ export type SessionCommandData = {
3044
+ body?: {
3045
+ messageID?: string;
3046
+ agent?: string;
3047
+ model?: string;
3048
+ arguments: string;
3049
+ command: string;
3050
+ variant?: string;
3051
+ parts?: Array<{
3052
+ id?: string;
3053
+ type: "file";
3054
+ mime: string;
3055
+ filename?: string;
3056
+ url: string;
3057
+ source?: FilePartSource;
3058
+ }>;
3059
+ };
3060
+ path: {
3061
+ sessionID: string;
3062
+ };
3063
+ query?: {
3064
+ directory?: string;
3065
+ workspace?: string;
3066
+ };
3067
+ url: "/session/{sessionID}/command";
3068
+ };
3069
+ export type SessionCommandErrors = {
3070
+ /**
3071
+ * Bad request
3072
+ */
3073
+ 400: BadRequestError;
3074
+ /**
3075
+ * Not found
3076
+ */
3077
+ 404: NotFoundError;
3078
+ };
3079
+ export type SessionCommandError = SessionCommandErrors[keyof SessionCommandErrors];
3080
+ export type SessionCommandResponses = {
3081
+ /**
3082
+ * Created message
3083
+ */
3084
+ 200: {
3085
+ info: AssistantMessage;
3086
+ parts: Array<Part>;
3087
+ };
3088
+ };
3089
+ export type SessionCommandResponse = SessionCommandResponses[keyof SessionCommandResponses];
3090
+ export type SessionShellData = {
3091
+ body?: {
3092
+ agent: string;
3093
+ model?: {
3094
+ providerID: string;
3095
+ modelID: string;
3096
+ };
3097
+ command: string;
3098
+ };
3099
+ path: {
3100
+ sessionID: string;
3101
+ };
3102
+ query?: {
3103
+ directory?: string;
3104
+ workspace?: string;
3105
+ };
3106
+ url: "/session/{sessionID}/shell";
3107
+ };
3108
+ export type SessionShellErrors = {
3109
+ /**
3110
+ * Bad request
3111
+ */
3112
+ 400: BadRequestError;
3113
+ /**
3114
+ * Not found
3115
+ */
3116
+ 404: NotFoundError;
3117
+ };
3118
+ export type SessionShellError = SessionShellErrors[keyof SessionShellErrors];
3119
+ export type SessionShellResponses = {
3120
+ /**
3121
+ * Created message
3122
+ */
3123
+ 200: AssistantMessage;
3124
+ };
3125
+ export type SessionShellResponse = SessionShellResponses[keyof SessionShellResponses];
3126
+ export type SessionRevertData = {
3127
+ body?: {
3128
+ messageID: string;
3129
+ partID?: string;
3130
+ };
3131
+ path: {
3132
+ sessionID: string;
3133
+ };
3134
+ query?: {
3135
+ directory?: string;
3136
+ workspace?: string;
3137
+ };
3138
+ url: "/session/{sessionID}/revert";
3139
+ };
3140
+ export type SessionRevertErrors = {
3141
+ /**
3142
+ * Bad request
3143
+ */
3144
+ 400: BadRequestError;
3145
+ /**
3146
+ * Not found
3147
+ */
3148
+ 404: NotFoundError;
3149
+ };
3150
+ export type SessionRevertError = SessionRevertErrors[keyof SessionRevertErrors];
3151
+ export type SessionRevertResponses = {
3152
+ /**
3153
+ * Updated session
3154
+ */
3155
+ 200: Session;
3156
+ };
3157
+ export type SessionRevertResponse = SessionRevertResponses[keyof SessionRevertResponses];
3158
+ export type SessionUnrevertData = {
3159
+ body?: never;
3160
+ path: {
3161
+ sessionID: string;
3162
+ };
3163
+ query?: {
3164
+ directory?: string;
3165
+ workspace?: string;
3166
+ };
3167
+ url: "/session/{sessionID}/unrevert";
3168
+ };
3169
+ export type SessionUnrevertErrors = {
3170
+ /**
3171
+ * Bad request
3172
+ */
3173
+ 400: BadRequestError;
3174
+ /**
3175
+ * Not found
3176
+ */
3177
+ 404: NotFoundError;
3178
+ };
3179
+ export type SessionUnrevertError = SessionUnrevertErrors[keyof SessionUnrevertErrors];
3180
+ export type SessionUnrevertResponses = {
3181
+ /**
3182
+ * Updated session
3183
+ */
3184
+ 200: Session;
3185
+ };
3186
+ export type SessionUnrevertResponse = SessionUnrevertResponses[keyof SessionUnrevertResponses];
3187
+ export type PermissionRespondData = {
3188
+ body?: {
3189
+ response: "once" | "always" | "reject";
3190
+ };
3191
+ path: {
3192
+ sessionID: string;
3193
+ permissionID: string;
3194
+ };
3195
+ query?: {
3196
+ directory?: string;
3197
+ workspace?: string;
3198
+ };
3199
+ url: "/session/{sessionID}/permissions/{permissionID}";
3200
+ };
3201
+ export type PermissionRespondErrors = {
3202
+ /**
3203
+ * Bad request
3204
+ */
3205
+ 400: BadRequestError;
3206
+ /**
3207
+ * Not found
3208
+ */
3209
+ 404: NotFoundError;
3210
+ };
3211
+ export type PermissionRespondError = PermissionRespondErrors[keyof PermissionRespondErrors];
3212
+ export type PermissionRespondResponses = {
3213
+ /**
3214
+ * Permission processed successfully
3215
+ */
3216
+ 200: boolean;
3217
+ };
3218
+ export type PermissionRespondResponse = PermissionRespondResponses[keyof PermissionRespondResponses];
3219
+ export type PermissionReplyData = {
3220
+ body?: {
3221
+ reply: "once" | "always" | "reject";
3222
+ message?: string;
3223
+ };
3224
+ path: {
3225
+ requestID: string;
3226
+ };
3227
+ query?: {
3228
+ directory?: string;
3229
+ workspace?: string;
3230
+ };
3231
+ url: "/permission/{requestID}/reply";
3232
+ };
3233
+ export type PermissionReplyErrors = {
3234
+ /**
3235
+ * Bad request
3236
+ */
3237
+ 400: BadRequestError;
3238
+ /**
3239
+ * Not found
3240
+ */
3241
+ 404: NotFoundError;
3242
+ };
3243
+ export type PermissionReplyError = PermissionReplyErrors[keyof PermissionReplyErrors];
3244
+ export type PermissionReplyResponses = {
3245
+ /**
3246
+ * Permission processed successfully
3247
+ */
3248
+ 200: boolean;
3249
+ };
3250
+ export type PermissionReplyResponse = PermissionReplyResponses[keyof PermissionReplyResponses];
3251
+ export type PermissionListData = {
3252
+ body?: never;
3253
+ path?: never;
3254
+ query?: {
3255
+ directory?: string;
3256
+ workspace?: string;
3257
+ };
3258
+ url: "/permission";
3259
+ };
3260
+ export type PermissionListResponses = {
3261
+ /**
3262
+ * List of pending permissions
3263
+ */
3264
+ 200: Array<PermissionRequest>;
3265
+ };
3266
+ export type PermissionListResponse = PermissionListResponses[keyof PermissionListResponses];
3267
+ export type QuestionListData = {
3268
+ body?: never;
3269
+ path?: never;
3270
+ query?: {
3271
+ directory?: string;
3272
+ workspace?: string;
3273
+ };
3274
+ url: "/question";
3275
+ };
3276
+ export type QuestionListResponses = {
3277
+ /**
3278
+ * List of pending questions
3279
+ */
3280
+ 200: Array<QuestionRequest>;
3281
+ };
3282
+ export type QuestionListResponse = QuestionListResponses[keyof QuestionListResponses];
3283
+ export type QuestionReplyData = {
3284
+ body?: {
3285
+ /**
3286
+ * User answers in order of questions (each answer is an array of selected labels)
3287
+ */
3288
+ answers: Array<QuestionAnswer>;
3289
+ };
3290
+ path: {
3291
+ requestID: string;
3292
+ };
3293
+ query?: {
3294
+ directory?: string;
3295
+ workspace?: string;
3296
+ };
3297
+ url: "/question/{requestID}/reply";
3298
+ };
3299
+ export type QuestionReplyErrors = {
3300
+ /**
3301
+ * Bad request
3302
+ */
3303
+ 400: BadRequestError;
3304
+ /**
3305
+ * Not found
3306
+ */
3307
+ 404: NotFoundError;
3308
+ };
3309
+ export type QuestionReplyError = QuestionReplyErrors[keyof QuestionReplyErrors];
3310
+ export type QuestionReplyResponses = {
3311
+ /**
3312
+ * Question answered successfully
3313
+ */
3314
+ 200: boolean;
3315
+ };
3316
+ export type QuestionReplyResponse = QuestionReplyResponses[keyof QuestionReplyResponses];
3317
+ export type QuestionRejectData = {
3318
+ body?: never;
3319
+ path: {
3320
+ requestID: string;
3321
+ };
3322
+ query?: {
3323
+ directory?: string;
3324
+ workspace?: string;
3325
+ };
3326
+ url: "/question/{requestID}/reject";
3327
+ };
3328
+ export type QuestionRejectErrors = {
3329
+ /**
3330
+ * Bad request
3331
+ */
3332
+ 400: BadRequestError;
3333
+ /**
3334
+ * Not found
3335
+ */
3336
+ 404: NotFoundError;
3337
+ };
3338
+ export type QuestionRejectError = QuestionRejectErrors[keyof QuestionRejectErrors];
3339
+ export type QuestionRejectResponses = {
3340
+ /**
3341
+ * Question rejected successfully
3342
+ */
3343
+ 200: boolean;
3344
+ };
3345
+ export type QuestionRejectResponse = QuestionRejectResponses[keyof QuestionRejectResponses];
3346
+ export type ProviderListData = {
3347
+ body?: never;
3348
+ path?: never;
3349
+ query?: {
3350
+ directory?: string;
3351
+ workspace?: string;
3352
+ };
3353
+ url: "/provider";
3354
+ };
3355
+ export type ProviderListResponses = {
3356
+ /**
3357
+ * List of providers
3358
+ */
3359
+ 200: {
3360
+ all: Array<{
3361
+ api?: string;
3362
+ name: string;
3363
+ env: Array<string>;
3364
+ id: string;
3365
+ npm?: string;
3366
+ models: {
3367
+ [key: string]: {
3368
+ id: string;
3369
+ name: string;
3370
+ family?: string;
3371
+ release_date: string;
3372
+ attachment: boolean;
3373
+ reasoning: boolean;
3374
+ temperature: boolean;
3375
+ tool_call: boolean;
3376
+ interleaved?: true | {
3377
+ field: "reasoning_content" | "reasoning_details";
3378
+ };
3379
+ cost?: {
3380
+ input: number;
3381
+ output: number;
3382
+ cache_read?: number;
3383
+ cache_write?: number;
3384
+ context_over_200k?: {
3385
+ input: number;
3386
+ output: number;
3387
+ cache_read?: number;
3388
+ cache_write?: number;
3389
+ };
3390
+ };
3391
+ limit: {
3392
+ context: number;
3393
+ input?: number;
3394
+ output: number;
3395
+ };
3396
+ modalities?: {
3397
+ input: Array<"text" | "audio" | "image" | "video" | "pdf">;
3398
+ output: Array<"text" | "audio" | "image" | "video" | "pdf">;
3399
+ };
3400
+ experimental?: boolean;
3401
+ status?: "alpha" | "beta" | "deprecated";
3402
+ options: {
3403
+ [key: string]: unknown;
3404
+ };
3405
+ headers?: {
3406
+ [key: string]: string;
3407
+ };
3408
+ provider?: {
3409
+ npm?: string;
3410
+ api?: string;
3411
+ };
3412
+ variants?: {
3413
+ [key: string]: {
3414
+ [key: string]: unknown;
3415
+ };
3416
+ };
3417
+ };
3418
+ };
3419
+ }>;
3420
+ default: {
3421
+ [key: string]: string;
3422
+ };
3423
+ connected: Array<string>;
3424
+ };
3425
+ };
3426
+ export type ProviderListResponse = ProviderListResponses[keyof ProviderListResponses];
3427
+ export type ProviderAuthData = {
3428
+ body?: never;
3429
+ path?: never;
3430
+ query?: {
3431
+ directory?: string;
3432
+ workspace?: string;
3433
+ };
3434
+ url: "/provider/auth";
3435
+ };
3436
+ export type ProviderAuthResponses = {
3437
+ /**
3438
+ * Provider auth methods
3439
+ */
3440
+ 200: {
3441
+ [key: string]: Array<ProviderAuthMethod>;
3442
+ };
3443
+ };
3444
+ export type ProviderAuthResponse = ProviderAuthResponses[keyof ProviderAuthResponses];
3445
+ export type ProviderOauthAuthorizeData = {
3446
+ body?: {
3447
+ /**
3448
+ * Auth method index
3449
+ */
3450
+ method: number;
3451
+ /**
3452
+ * Prompt inputs
3453
+ */
3454
+ inputs?: {
3455
+ [key: string]: string;
3456
+ };
3457
+ };
3458
+ path: {
3459
+ /**
3460
+ * Provider ID
3461
+ */
3462
+ providerID: string;
3463
+ };
3464
+ query?: {
3465
+ directory?: string;
3466
+ workspace?: string;
3467
+ };
3468
+ url: "/provider/{providerID}/oauth/authorize";
3469
+ };
3470
+ export type ProviderOauthAuthorizeErrors = {
3471
+ /**
3472
+ * Bad request
3473
+ */
3474
+ 400: BadRequestError;
3475
+ };
3476
+ export type ProviderOauthAuthorizeError = ProviderOauthAuthorizeErrors[keyof ProviderOauthAuthorizeErrors];
3477
+ export type ProviderOauthAuthorizeResponses = {
3478
+ /**
3479
+ * Authorization URL and method
3480
+ */
3481
+ 200: ProviderAuthAuthorization;
3482
+ };
3483
+ export type ProviderOauthAuthorizeResponse = ProviderOauthAuthorizeResponses[keyof ProviderOauthAuthorizeResponses];
3484
+ export type ProviderOauthCallbackData = {
3485
+ body?: {
3486
+ /**
3487
+ * Auth method index
3488
+ */
3489
+ method: number;
3490
+ /**
3491
+ * OAuth authorization code
3492
+ */
3493
+ code?: string;
3494
+ };
3495
+ path: {
3496
+ /**
3497
+ * Provider ID
3498
+ */
3499
+ providerID: string;
3500
+ };
3501
+ query?: {
3502
+ directory?: string;
3503
+ workspace?: string;
3504
+ };
3505
+ url: "/provider/{providerID}/oauth/callback";
3506
+ };
3507
+ export type ProviderOauthCallbackErrors = {
3508
+ /**
3509
+ * Bad request
3510
+ */
3511
+ 400: BadRequestError;
3512
+ };
3513
+ export type ProviderOauthCallbackError = ProviderOauthCallbackErrors[keyof ProviderOauthCallbackErrors];
3514
+ export type ProviderOauthCallbackResponses = {
3515
+ /**
3516
+ * OAuth callback processed successfully
3517
+ */
3518
+ 200: boolean;
3519
+ };
3520
+ export type ProviderOauthCallbackResponse = ProviderOauthCallbackResponses[keyof ProviderOauthCallbackResponses];
3521
+ export type FindTextData = {
3522
+ body?: never;
3523
+ path?: never;
3524
+ query: {
3525
+ directory?: string;
3526
+ workspace?: string;
3527
+ pattern: string;
3528
+ };
3529
+ url: "/find";
3530
+ };
3531
+ export type FindTextResponses = {
3532
+ /**
3533
+ * Matches
3534
+ */
3535
+ 200: Array<{
3536
+ path: {
3537
+ text: string;
3538
+ };
3539
+ lines: {
3540
+ text: string;
3541
+ };
3542
+ line_number: number;
3543
+ absolute_offset: number;
3544
+ submatches: Array<{
3545
+ match: {
3546
+ text: string;
3547
+ };
3548
+ start: number;
3549
+ end: number;
3550
+ }>;
3551
+ }>;
3552
+ };
3553
+ export type FindTextResponse = FindTextResponses[keyof FindTextResponses];
3554
+ export type FindFilesData = {
3555
+ body?: never;
3556
+ path?: never;
3557
+ query: {
3558
+ directory?: string;
3559
+ workspace?: string;
3560
+ query: string;
3561
+ dirs?: "true" | "false";
3562
+ type?: "file" | "directory";
3563
+ limit?: number;
3564
+ };
3565
+ url: "/find/file";
3566
+ };
3567
+ export type FindFilesResponses = {
3568
+ /**
3569
+ * File paths
3570
+ */
3571
+ 200: Array<string>;
3572
+ };
3573
+ export type FindFilesResponse = FindFilesResponses[keyof FindFilesResponses];
3574
+ export type FindSymbolsData = {
3575
+ body?: never;
3576
+ path?: never;
3577
+ query: {
3578
+ directory?: string;
3579
+ workspace?: string;
3580
+ query: string;
3581
+ };
3582
+ url: "/find/symbol";
3583
+ };
3584
+ export type FindSymbolsResponses = {
3585
+ /**
3586
+ * Symbols
3587
+ */
3588
+ 200: Array<Symbol>;
3589
+ };
3590
+ export type FindSymbolsResponse = FindSymbolsResponses[keyof FindSymbolsResponses];
3591
+ export type FileListData = {
3592
+ body?: never;
3593
+ path?: never;
3594
+ query: {
3595
+ directory?: string;
3596
+ workspace?: string;
3597
+ path: string;
3598
+ };
3599
+ url: "/file";
3600
+ };
3601
+ export type FileListResponses = {
3602
+ /**
3603
+ * Files and directories
3604
+ */
3605
+ 200: Array<FileNode>;
3606
+ };
3607
+ export type FileListResponse = FileListResponses[keyof FileListResponses];
3608
+ export type FileReadData = {
3609
+ body?: never;
3610
+ path?: never;
3611
+ query: {
3612
+ directory?: string;
3613
+ workspace?: string;
3614
+ path: string;
3615
+ };
3616
+ url: "/file/content";
3617
+ };
3618
+ export type FileReadResponses = {
3619
+ /**
3620
+ * File content
3621
+ */
3622
+ 200: FileContent;
3623
+ };
3624
+ export type FileReadResponse = FileReadResponses[keyof FileReadResponses];
3625
+ export type FileStatusData = {
3626
+ body?: never;
3627
+ path?: never;
3628
+ query?: {
3629
+ directory?: string;
3630
+ workspace?: string;
3631
+ };
3632
+ url: "/file/status";
3633
+ };
3634
+ export type FileStatusResponses = {
3635
+ /**
3636
+ * File status
3637
+ */
3638
+ 200: Array<File>;
3639
+ };
3640
+ export type FileStatusResponse = FileStatusResponses[keyof FileStatusResponses];
3641
+ export type McpStatusData = {
3642
+ body?: never;
3643
+ path?: never;
3644
+ query?: {
3645
+ directory?: string;
3646
+ workspace?: string;
3647
+ };
3648
+ url: "/mcp";
3649
+ };
3650
+ export type McpStatusResponses = {
3651
+ /**
3652
+ * MCP server status
3653
+ */
3654
+ 200: {
3655
+ [key: string]: McpStatus;
3656
+ };
3657
+ };
3658
+ export type McpStatusResponse = McpStatusResponses[keyof McpStatusResponses];
3659
+ export type McpAddData = {
3660
+ body?: {
3661
+ name: string;
3662
+ config: McpLocalConfig | McpRemoteConfig;
3663
+ };
3664
+ path?: never;
3665
+ query?: {
3666
+ directory?: string;
3667
+ workspace?: string;
3668
+ };
3669
+ url: "/mcp";
3670
+ };
3671
+ export type McpAddErrors = {
3672
+ /**
3673
+ * Bad request
3674
+ */
3675
+ 400: BadRequestError;
3676
+ };
3677
+ export type McpAddError = McpAddErrors[keyof McpAddErrors];
3678
+ export type McpAddResponses = {
3679
+ /**
3680
+ * MCP server added successfully
3681
+ */
3682
+ 200: {
3683
+ [key: string]: McpStatus;
3684
+ };
3685
+ };
3686
+ export type McpAddResponse = McpAddResponses[keyof McpAddResponses];
3687
+ export type McpAuthRemoveData = {
3688
+ body?: never;
3689
+ path: {
3690
+ name: string;
3691
+ };
3692
+ query?: {
3693
+ directory?: string;
3694
+ workspace?: string;
3695
+ };
3696
+ url: "/mcp/{name}/auth";
3697
+ };
3698
+ export type McpAuthRemoveErrors = {
3699
+ /**
3700
+ * Not found
3701
+ */
3702
+ 404: NotFoundError;
3703
+ };
3704
+ export type McpAuthRemoveError = McpAuthRemoveErrors[keyof McpAuthRemoveErrors];
3705
+ export type McpAuthRemoveResponses = {
3706
+ /**
3707
+ * OAuth credentials removed
3708
+ */
3709
+ 200: {
3710
+ success: true;
3711
+ };
3712
+ };
3713
+ export type McpAuthRemoveResponse = McpAuthRemoveResponses[keyof McpAuthRemoveResponses];
3714
+ export type McpAuthStartData = {
3715
+ body?: never;
3716
+ path: {
3717
+ name: string;
3718
+ };
3719
+ query?: {
3720
+ directory?: string;
3721
+ workspace?: string;
3722
+ };
3723
+ url: "/mcp/{name}/auth";
3724
+ };
3725
+ export type McpAuthStartErrors = {
3726
+ /**
3727
+ * Bad request
3728
+ */
3729
+ 400: BadRequestError;
3730
+ /**
3731
+ * Not found
3732
+ */
3733
+ 404: NotFoundError;
3734
+ };
3735
+ export type McpAuthStartError = McpAuthStartErrors[keyof McpAuthStartErrors];
3736
+ export type McpAuthStartResponses = {
3737
+ /**
3738
+ * OAuth flow started
3739
+ */
3740
+ 200: {
3741
+ /**
3742
+ * URL to open in browser for authorization
3743
+ */
3744
+ authorizationUrl: string;
3745
+ };
3746
+ };
3747
+ export type McpAuthStartResponse = McpAuthStartResponses[keyof McpAuthStartResponses];
3748
+ export type McpAuthCallbackData = {
3749
+ body?: {
3750
+ /**
3751
+ * Authorization code from OAuth callback
3752
+ */
3753
+ code: string;
3754
+ };
3755
+ path: {
3756
+ name: string;
3757
+ };
3758
+ query?: {
3759
+ directory?: string;
3760
+ workspace?: string;
3761
+ };
3762
+ url: "/mcp/{name}/auth/callback";
3763
+ };
3764
+ export type McpAuthCallbackErrors = {
3765
+ /**
3766
+ * Bad request
3767
+ */
3768
+ 400: BadRequestError;
3769
+ /**
3770
+ * Not found
3771
+ */
3772
+ 404: NotFoundError;
3773
+ };
3774
+ export type McpAuthCallbackError = McpAuthCallbackErrors[keyof McpAuthCallbackErrors];
3775
+ export type McpAuthCallbackResponses = {
3776
+ /**
3777
+ * OAuth authentication completed
3778
+ */
3779
+ 200: McpStatus;
3780
+ };
3781
+ export type McpAuthCallbackResponse = McpAuthCallbackResponses[keyof McpAuthCallbackResponses];
3782
+ export type McpAuthAuthenticateData = {
3783
+ body?: never;
3784
+ path: {
3785
+ name: string;
3786
+ };
3787
+ query?: {
3788
+ directory?: string;
3789
+ workspace?: string;
3790
+ };
3791
+ url: "/mcp/{name}/auth/authenticate";
3792
+ };
3793
+ export type McpAuthAuthenticateErrors = {
3794
+ /**
3795
+ * Bad request
3796
+ */
3797
+ 400: BadRequestError;
3798
+ /**
3799
+ * Not found
3800
+ */
3801
+ 404: NotFoundError;
3802
+ };
3803
+ export type McpAuthAuthenticateError = McpAuthAuthenticateErrors[keyof McpAuthAuthenticateErrors];
3804
+ export type McpAuthAuthenticateResponses = {
3805
+ /**
3806
+ * OAuth authentication completed
3807
+ */
3808
+ 200: McpStatus;
3809
+ };
3810
+ export type McpAuthAuthenticateResponse = McpAuthAuthenticateResponses[keyof McpAuthAuthenticateResponses];
3811
+ export type McpConnectData = {
3812
+ body?: never;
3813
+ path: {
3814
+ name: string;
3815
+ };
3816
+ query?: {
3817
+ directory?: string;
3818
+ workspace?: string;
3819
+ };
3820
+ url: "/mcp/{name}/connect";
3821
+ };
3822
+ export type McpConnectResponses = {
3823
+ /**
3824
+ * MCP server connected successfully
3825
+ */
3826
+ 200: boolean;
3827
+ };
3828
+ export type McpConnectResponse = McpConnectResponses[keyof McpConnectResponses];
3829
+ export type McpDisconnectData = {
3830
+ body?: never;
3831
+ path: {
3832
+ name: string;
3833
+ };
3834
+ query?: {
3835
+ directory?: string;
3836
+ workspace?: string;
3837
+ };
3838
+ url: "/mcp/{name}/disconnect";
3839
+ };
3840
+ export type McpDisconnectResponses = {
3841
+ /**
3842
+ * MCP server disconnected successfully
3843
+ */
3844
+ 200: boolean;
3845
+ };
3846
+ export type McpDisconnectResponse = McpDisconnectResponses[keyof McpDisconnectResponses];
3847
+ export type TuiAppendPromptData = {
3848
+ body?: {
3849
+ text: string;
3850
+ };
3851
+ path?: never;
3852
+ query?: {
3853
+ directory?: string;
3854
+ workspace?: string;
3855
+ };
3856
+ url: "/tui/append-prompt";
3857
+ };
3858
+ export type TuiAppendPromptErrors = {
3859
+ /**
3860
+ * Bad request
3861
+ */
3862
+ 400: BadRequestError;
3863
+ };
3864
+ export type TuiAppendPromptError = TuiAppendPromptErrors[keyof TuiAppendPromptErrors];
3865
+ export type TuiAppendPromptResponses = {
3866
+ /**
3867
+ * Prompt processed successfully
3868
+ */
3869
+ 200: boolean;
3870
+ };
3871
+ export type TuiAppendPromptResponse = TuiAppendPromptResponses[keyof TuiAppendPromptResponses];
3872
+ export type TuiOpenHelpData = {
3873
+ body?: never;
3874
+ path?: never;
3875
+ query?: {
3876
+ directory?: string;
3877
+ workspace?: string;
3878
+ };
3879
+ url: "/tui/open-help";
3880
+ };
3881
+ export type TuiOpenHelpResponses = {
3882
+ /**
3883
+ * Help dialog opened successfully
3884
+ */
3885
+ 200: boolean;
3886
+ };
3887
+ export type TuiOpenHelpResponse = TuiOpenHelpResponses[keyof TuiOpenHelpResponses];
3888
+ export type TuiOpenSessionsData = {
3889
+ body?: never;
3890
+ path?: never;
3891
+ query?: {
3892
+ directory?: string;
3893
+ workspace?: string;
3894
+ };
3895
+ url: "/tui/open-sessions";
3896
+ };
3897
+ export type TuiOpenSessionsResponses = {
3898
+ /**
3899
+ * Session dialog opened successfully
3900
+ */
3901
+ 200: boolean;
3902
+ };
3903
+ export type TuiOpenSessionsResponse = TuiOpenSessionsResponses[keyof TuiOpenSessionsResponses];
3904
+ export type TuiOpenThemesData = {
3905
+ body?: never;
3906
+ path?: never;
3907
+ query?: {
3908
+ directory?: string;
3909
+ workspace?: string;
3910
+ };
3911
+ url: "/tui/open-themes";
3912
+ };
3913
+ export type TuiOpenThemesResponses = {
3914
+ /**
3915
+ * Theme dialog opened successfully
3916
+ */
3917
+ 200: boolean;
3918
+ };
3919
+ export type TuiOpenThemesResponse = TuiOpenThemesResponses[keyof TuiOpenThemesResponses];
3920
+ export type TuiOpenModelsData = {
3921
+ body?: never;
3922
+ path?: never;
3923
+ query?: {
3924
+ directory?: string;
3925
+ workspace?: string;
3926
+ };
3927
+ url: "/tui/open-models";
3928
+ };
3929
+ export type TuiOpenModelsResponses = {
3930
+ /**
3931
+ * Model dialog opened successfully
3932
+ */
3933
+ 200: boolean;
3934
+ };
3935
+ export type TuiOpenModelsResponse = TuiOpenModelsResponses[keyof TuiOpenModelsResponses];
3936
+ export type TuiSubmitPromptData = {
3937
+ body?: never;
3938
+ path?: never;
3939
+ query?: {
3940
+ directory?: string;
3941
+ workspace?: string;
3942
+ };
3943
+ url: "/tui/submit-prompt";
3944
+ };
3945
+ export type TuiSubmitPromptResponses = {
3946
+ /**
3947
+ * Prompt submitted successfully
3948
+ */
3949
+ 200: boolean;
3950
+ };
3951
+ export type TuiSubmitPromptResponse = TuiSubmitPromptResponses[keyof TuiSubmitPromptResponses];
3952
+ export type TuiClearPromptData = {
3953
+ body?: never;
3954
+ path?: never;
3955
+ query?: {
3956
+ directory?: string;
3957
+ workspace?: string;
3958
+ };
3959
+ url: "/tui/clear-prompt";
3960
+ };
3961
+ export type TuiClearPromptResponses = {
3962
+ /**
3963
+ * Prompt cleared successfully
3964
+ */
3965
+ 200: boolean;
3966
+ };
3967
+ export type TuiClearPromptResponse = TuiClearPromptResponses[keyof TuiClearPromptResponses];
3968
+ export type TuiExecuteCommandData = {
3969
+ body?: {
3970
+ command: string;
3971
+ };
3972
+ path?: never;
3973
+ query?: {
3974
+ directory?: string;
3975
+ workspace?: string;
3976
+ };
3977
+ url: "/tui/execute-command";
3978
+ };
3979
+ export type TuiExecuteCommandErrors = {
3980
+ /**
3981
+ * Bad request
3982
+ */
3983
+ 400: BadRequestError;
3984
+ };
3985
+ export type TuiExecuteCommandError = TuiExecuteCommandErrors[keyof TuiExecuteCommandErrors];
3986
+ export type TuiExecuteCommandResponses = {
3987
+ /**
3988
+ * Command executed successfully
3989
+ */
3990
+ 200: boolean;
3991
+ };
3992
+ export type TuiExecuteCommandResponse = TuiExecuteCommandResponses[keyof TuiExecuteCommandResponses];
3993
+ export type TuiShowToastData = {
3994
+ body?: {
3995
+ title?: string;
3996
+ message: string;
3997
+ variant: "info" | "success" | "warning" | "error";
3998
+ /**
3999
+ * Duration in milliseconds
4000
+ */
4001
+ duration?: number;
4002
+ };
4003
+ path?: never;
4004
+ query?: {
4005
+ directory?: string;
4006
+ workspace?: string;
4007
+ };
4008
+ url: "/tui/show-toast";
4009
+ };
4010
+ export type TuiShowToastResponses = {
4011
+ /**
4012
+ * Toast notification shown successfully
4013
+ */
4014
+ 200: boolean;
4015
+ };
4016
+ export type TuiShowToastResponse = TuiShowToastResponses[keyof TuiShowToastResponses];
4017
+ export type TuiPublishData = {
4018
+ body?: EventTuiPromptAppend | EventTuiCommandExecute | EventTuiToastShow | EventTuiSessionSelect;
4019
+ path?: never;
4020
+ query?: {
4021
+ directory?: string;
4022
+ workspace?: string;
4023
+ };
4024
+ url: "/tui/publish";
4025
+ };
4026
+ export type TuiPublishErrors = {
4027
+ /**
4028
+ * Bad request
4029
+ */
4030
+ 400: BadRequestError;
4031
+ };
4032
+ export type TuiPublishError = TuiPublishErrors[keyof TuiPublishErrors];
4033
+ export type TuiPublishResponses = {
4034
+ /**
4035
+ * Event published successfully
4036
+ */
4037
+ 200: boolean;
4038
+ };
4039
+ export type TuiPublishResponse = TuiPublishResponses[keyof TuiPublishResponses];
4040
+ export type TuiSelectSessionData = {
4041
+ body?: {
4042
+ /**
4043
+ * Session ID to navigate to
4044
+ */
4045
+ sessionID: string;
4046
+ };
4047
+ path?: never;
4048
+ query?: {
4049
+ directory?: string;
4050
+ workspace?: string;
4051
+ };
4052
+ url: "/tui/select-session";
4053
+ };
4054
+ export type TuiSelectSessionErrors = {
4055
+ /**
4056
+ * Bad request
4057
+ */
4058
+ 400: BadRequestError;
4059
+ /**
4060
+ * Not found
4061
+ */
4062
+ 404: NotFoundError;
4063
+ };
4064
+ export type TuiSelectSessionError = TuiSelectSessionErrors[keyof TuiSelectSessionErrors];
4065
+ export type TuiSelectSessionResponses = {
4066
+ /**
4067
+ * Session selected successfully
4068
+ */
4069
+ 200: boolean;
4070
+ };
4071
+ export type TuiSelectSessionResponse = TuiSelectSessionResponses[keyof TuiSelectSessionResponses];
4072
+ export type TuiControlNextData = {
4073
+ body?: never;
4074
+ path?: never;
4075
+ query?: {
4076
+ directory?: string;
4077
+ workspace?: string;
4078
+ };
4079
+ url: "/tui/control/next";
4080
+ };
4081
+ export type TuiControlNextResponses = {
4082
+ /**
4083
+ * Next TUI request
4084
+ */
4085
+ 200: {
4086
+ path: string;
4087
+ body: unknown;
4088
+ };
4089
+ };
4090
+ export type TuiControlNextResponse = TuiControlNextResponses[keyof TuiControlNextResponses];
4091
+ export type TuiControlResponseData = {
4092
+ body?: unknown;
4093
+ path?: never;
4094
+ query?: {
4095
+ directory?: string;
4096
+ workspace?: string;
4097
+ };
4098
+ url: "/tui/control/response";
4099
+ };
4100
+ export type TuiControlResponseResponses = {
4101
+ /**
4102
+ * Response submitted successfully
4103
+ */
4104
+ 200: boolean;
4105
+ };
4106
+ export type TuiControlResponseResponse = TuiControlResponseResponses[keyof TuiControlResponseResponses];
4107
+ export type GuardrailGetData = {
4108
+ body?: never;
4109
+ path?: never;
4110
+ query?: {
4111
+ directory?: string;
4112
+ workspace?: string;
4113
+ };
4114
+ url: "/guardrail";
4115
+ };
4116
+ export type GuardrailGetResponses = {
4117
+ /**
4118
+ * Current guardrail state
4119
+ */
4120
+ 200: Guardrail;
4121
+ };
4122
+ export type GuardrailGetResponse = GuardrailGetResponses[keyof GuardrailGetResponses];
4123
+ export type GuardrailRefreshData = {
4124
+ body?: never;
4125
+ path?: never;
4126
+ query?: {
4127
+ directory?: string;
4128
+ workspace?: string;
4129
+ };
4130
+ url: "/guardrail/refresh";
4131
+ };
4132
+ export type GuardrailRefreshResponses = {
4133
+ /**
4134
+ * Guardrails refreshed
4135
+ */
4136
+ 200: Guardrail;
4137
+ };
4138
+ export type GuardrailRefreshResponse = GuardrailRefreshResponses[keyof GuardrailRefreshResponses];
4139
+ export type GuardrailClearData = {
4140
+ body?: never;
4141
+ path?: never;
4142
+ query?: {
4143
+ directory?: string;
4144
+ workspace?: string;
4145
+ };
4146
+ url: "/guardrail/clear";
4147
+ };
4148
+ export type GuardrailClearResponses = {
4149
+ /**
4150
+ * Guardrails cleared
4151
+ */
4152
+ 200: boolean;
4153
+ };
4154
+ export type GuardrailClearResponse = GuardrailClearResponses[keyof GuardrailClearResponses];
4155
+ export type InstanceDisposeData = {
4156
+ body?: never;
4157
+ path?: never;
4158
+ query?: {
4159
+ directory?: string;
4160
+ workspace?: string;
4161
+ };
4162
+ url: "/instance/dispose";
4163
+ };
4164
+ export type InstanceDisposeResponses = {
4165
+ /**
4166
+ * Instance disposed
4167
+ */
4168
+ 200: boolean;
4169
+ };
4170
+ export type InstanceDisposeResponse = InstanceDisposeResponses[keyof InstanceDisposeResponses];
4171
+ export type PathGetData = {
4172
+ body?: never;
4173
+ path?: never;
4174
+ query?: {
4175
+ directory?: string;
4176
+ workspace?: string;
4177
+ };
4178
+ url: "/path";
4179
+ };
4180
+ export type PathGetResponses = {
4181
+ /**
4182
+ * Path
4183
+ */
4184
+ 200: Path;
4185
+ };
4186
+ export type PathGetResponse = PathGetResponses[keyof PathGetResponses];
4187
+ export type VcsGetData = {
4188
+ body?: never;
4189
+ path?: never;
4190
+ query?: {
4191
+ directory?: string;
4192
+ workspace?: string;
4193
+ };
4194
+ url: "/vcs";
4195
+ };
4196
+ export type VcsGetResponses = {
4197
+ /**
4198
+ * VCS info
4199
+ */
4200
+ 200: VcsInfo;
4201
+ };
4202
+ export type VcsGetResponse = VcsGetResponses[keyof VcsGetResponses];
4203
+ export type CommandListData = {
4204
+ body?: never;
4205
+ path?: never;
4206
+ query?: {
4207
+ directory?: string;
4208
+ workspace?: string;
4209
+ };
4210
+ url: "/command";
4211
+ };
4212
+ export type CommandListResponses = {
4213
+ /**
4214
+ * List of commands
4215
+ */
4216
+ 200: Array<Command>;
4217
+ };
4218
+ export type CommandListResponse = CommandListResponses[keyof CommandListResponses];
4219
+ export type AppLogData = {
4220
+ body?: {
4221
+ /**
4222
+ * Service name for the log entry
4223
+ */
4224
+ service: string;
4225
+ /**
4226
+ * Log level
4227
+ */
4228
+ level: "debug" | "info" | "error" | "warn";
4229
+ /**
4230
+ * Log message
4231
+ */
4232
+ message: string;
4233
+ /**
4234
+ * Additional metadata for the log entry
4235
+ */
4236
+ extra?: {
4237
+ [key: string]: unknown;
4238
+ };
4239
+ };
4240
+ path?: never;
4241
+ query?: {
4242
+ directory?: string;
4243
+ workspace?: string;
4244
+ };
4245
+ url: "/log";
4246
+ };
4247
+ export type AppLogErrors = {
4248
+ /**
4249
+ * Bad request
4250
+ */
4251
+ 400: BadRequestError;
4252
+ };
4253
+ export type AppLogError = AppLogErrors[keyof AppLogErrors];
4254
+ export type AppLogResponses = {
4255
+ /**
4256
+ * Log entry written successfully
4257
+ */
4258
+ 200: boolean;
4259
+ };
4260
+ export type AppLogResponse = AppLogResponses[keyof AppLogResponses];
4261
+ export type AppAgentsData = {
4262
+ body?: never;
4263
+ path?: never;
4264
+ query?: {
4265
+ directory?: string;
4266
+ workspace?: string;
4267
+ };
4268
+ url: "/agent";
4269
+ };
4270
+ export type AppAgentsResponses = {
4271
+ /**
4272
+ * List of agents
4273
+ */
4274
+ 200: Array<Agent>;
4275
+ };
4276
+ export type AppAgentsResponse = AppAgentsResponses[keyof AppAgentsResponses];
4277
+ export type AppSkillsData = {
4278
+ body?: never;
4279
+ path?: never;
4280
+ query?: {
4281
+ directory?: string;
4282
+ workspace?: string;
4283
+ };
4284
+ url: "/skill";
4285
+ };
4286
+ export type AppSkillsResponses = {
4287
+ /**
4288
+ * List of skills
4289
+ */
4290
+ 200: Array<{
4291
+ name: string;
4292
+ description: string;
4293
+ location: string;
4294
+ content: string;
4295
+ }>;
4296
+ };
4297
+ export type AppSkillsResponse = AppSkillsResponses[keyof AppSkillsResponses];
4298
+ export type LspStatusData = {
4299
+ body?: never;
4300
+ path?: never;
4301
+ query?: {
4302
+ directory?: string;
4303
+ workspace?: string;
4304
+ };
4305
+ url: "/lsp";
4306
+ };
4307
+ export type LspStatusResponses = {
4308
+ /**
4309
+ * LSP server status
4310
+ */
4311
+ 200: Array<LspStatus>;
4312
+ };
4313
+ export type LspStatusResponse = LspStatusResponses[keyof LspStatusResponses];
4314
+ export type FormatterStatusData = {
4315
+ body?: never;
4316
+ path?: never;
4317
+ query?: {
4318
+ directory?: string;
4319
+ workspace?: string;
4320
+ };
4321
+ url: "/formatter";
4322
+ };
4323
+ export type FormatterStatusResponses = {
4324
+ /**
4325
+ * Formatter status
4326
+ */
4327
+ 200: Array<FormatterStatus>;
4328
+ };
4329
+ export type FormatterStatusResponse = FormatterStatusResponses[keyof FormatterStatusResponses];
4330
+ export type EventSubscribeData = {
4331
+ body?: never;
4332
+ path?: never;
4333
+ query?: {
4334
+ directory?: string;
4335
+ workspace?: string;
4336
+ };
4337
+ url: "/event";
4338
+ };
4339
+ export type EventSubscribeResponses = {
4340
+ /**
4341
+ * Event stream
4342
+ */
4343
+ 200: Event;
4344
+ };
4345
+ export type EventSubscribeResponse = EventSubscribeResponses[keyof EventSubscribeResponses];