xcode-copilot-server 2.1.0 → 3.0.0

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 (153) hide show
  1. package/README.md +94 -29
  2. package/config.json5 +13 -8
  3. package/dist/cli-validators.d.ts +6 -0
  4. package/dist/cli-validators.js +35 -0
  5. package/dist/cli-validators.js.map +1 -0
  6. package/dist/config.d.ts +3 -3
  7. package/dist/config.js +11 -10
  8. package/dist/config.js.map +1 -1
  9. package/dist/conversation-manager.d.ts +2 -1
  10. package/dist/conversation-manager.js +20 -1
  11. package/dist/conversation-manager.js.map +1 -1
  12. package/dist/handlers/responses/streaming.d.ts +6 -0
  13. package/dist/handlers/responses/streaming.js +265 -0
  14. package/dist/handlers/responses/streaming.js.map +1 -0
  15. package/dist/handlers/responses/tool-result-handler.d.ts +4 -0
  16. package/dist/handlers/responses/tool-result-handler.js +9 -0
  17. package/dist/handlers/responses/tool-result-handler.js.map +1 -0
  18. package/dist/handlers/responses.d.ts +4 -0
  19. package/dist/handlers/responses.js +164 -0
  20. package/dist/handlers/responses.js.map +1 -0
  21. package/dist/handlers/streaming-utils.d.ts +1 -0
  22. package/dist/handlers/streaming-utils.js +3 -0
  23. package/dist/handlers/streaming-utils.js.map +1 -1
  24. package/dist/index.js +51 -132
  25. package/dist/index.js.map +1 -1
  26. package/dist/logger.js +15 -4
  27. package/dist/logger.js.map +1 -1
  28. package/dist/providers/claude/count-tokens.d.ts +3 -0
  29. package/dist/providers/claude/count-tokens.js +72 -0
  30. package/dist/providers/claude/count-tokens.js.map +1 -0
  31. package/dist/providers/claude/handler.d.ts +4 -0
  32. package/dist/providers/claude/handler.js +150 -0
  33. package/dist/providers/claude/handler.js.map +1 -0
  34. package/dist/providers/claude/prompt.d.ts +2 -0
  35. package/dist/providers/claude/prompt.js +52 -0
  36. package/dist/providers/claude/prompt.js.map +1 -0
  37. package/dist/providers/claude/provider.d.ts +5 -0
  38. package/dist/providers/claude/provider.js +28 -0
  39. package/dist/providers/claude/provider.js.map +1 -0
  40. package/dist/providers/claude/schemas.d.ts +140 -0
  41. package/dist/providers/claude/schemas.js +58 -0
  42. package/dist/providers/claude/schemas.js.map +1 -0
  43. package/dist/providers/claude/streaming.d.ts +6 -0
  44. package/dist/providers/claude/streaming.js +116 -0
  45. package/dist/providers/claude/streaming.js.map +1 -0
  46. package/dist/providers/claude/tool-results.d.ts +4 -0
  47. package/dist/providers/claude/tool-results.js +19 -0
  48. package/dist/providers/claude/tool-results.js.map +1 -0
  49. package/dist/providers/codex/handler.d.ts +4 -0
  50. package/dist/providers/codex/handler.js +164 -0
  51. package/dist/providers/codex/handler.js.map +1 -0
  52. package/dist/providers/codex/prompt.d.ts +4 -0
  53. package/dist/providers/codex/prompt.js +58 -0
  54. package/dist/providers/codex/prompt.js.map +1 -0
  55. package/dist/providers/codex/provider.d.ts +5 -0
  56. package/dist/providers/codex/provider.js +24 -0
  57. package/dist/providers/codex/provider.js.map +1 -0
  58. package/dist/providers/codex/schemas.d.ts +122 -0
  59. package/dist/providers/codex/schemas.js +55 -0
  60. package/dist/providers/codex/schemas.js.map +1 -0
  61. package/dist/providers/codex/streaming.d.ts +9 -0
  62. package/dist/providers/codex/streaming.js +172 -0
  63. package/dist/providers/codex/streaming.js.map +1 -0
  64. package/dist/providers/codex/tool-results.d.ts +4 -0
  65. package/dist/providers/codex/tool-results.js +9 -0
  66. package/dist/providers/codex/tool-results.js.map +1 -0
  67. package/dist/providers/codex.d.ts +5 -0
  68. package/dist/providers/codex.js +24 -0
  69. package/dist/providers/codex.js.map +1 -0
  70. package/dist/providers/index.d.ts +6 -1
  71. package/dist/providers/index.js +5 -3
  72. package/dist/providers/index.js.map +1 -1
  73. package/dist/providers/openai/handler.d.ts +4 -0
  74. package/dist/providers/openai/handler.js +120 -0
  75. package/dist/providers/openai/handler.js.map +1 -0
  76. package/dist/providers/openai/models.d.ts +3 -0
  77. package/dist/providers/openai/models.js +28 -0
  78. package/dist/providers/openai/models.js.map +1 -0
  79. package/dist/providers/openai/prompt.d.ts +3 -0
  80. package/dist/providers/openai/prompt.js +38 -0
  81. package/dist/providers/openai/prompt.js.map +1 -0
  82. package/dist/providers/openai/provider.d.ts +5 -0
  83. package/dist/providers/openai/provider.js +25 -0
  84. package/dist/providers/openai/provider.js.map +1 -0
  85. package/dist/providers/openai/schemas.d.ts +98 -0
  86. package/dist/providers/openai/schemas.js +76 -0
  87. package/dist/providers/openai/schemas.js.map +1 -0
  88. package/dist/providers/openai/streaming.d.ts +4 -0
  89. package/dist/providers/openai/streaming.js +121 -0
  90. package/dist/providers/openai/streaming.js.map +1 -0
  91. package/dist/providers/shared/errors.d.ts +5 -0
  92. package/dist/providers/shared/errors.js +10 -0
  93. package/dist/providers/shared/errors.js.map +1 -0
  94. package/dist/providers/shared/model-resolver.d.ts +3 -0
  95. package/dist/providers/shared/model-resolver.js +45 -0
  96. package/dist/providers/shared/model-resolver.js.map +1 -0
  97. package/dist/providers/shared/prompt-utils.d.ts +1 -0
  98. package/dist/providers/shared/prompt-utils.js +15 -0
  99. package/dist/providers/shared/prompt-utils.js.map +1 -0
  100. package/dist/providers/shared/session-config.d.ts +15 -0
  101. package/dist/providers/shared/session-config.js +98 -0
  102. package/dist/providers/shared/session-config.js.map +1 -0
  103. package/dist/providers/shared/streaming-core.d.ts +19 -0
  104. package/dist/providers/shared/streaming-core.js +176 -0
  105. package/dist/providers/shared/streaming-core.js.map +1 -0
  106. package/dist/providers/shared/streaming-utils.d.ts +10 -0
  107. package/dist/providers/shared/streaming-utils.js +28 -0
  108. package/dist/providers/shared/streaming-utils.js.map +1 -0
  109. package/dist/schemas/config.d.ts +19 -1
  110. package/dist/schemas/config.js +2 -1
  111. package/dist/schemas/config.js.map +1 -1
  112. package/dist/schemas/responses.d.ts +122 -0
  113. package/dist/schemas/responses.js +54 -0
  114. package/dist/schemas/responses.js.map +1 -0
  115. package/dist/server.js +1 -2
  116. package/dist/server.js.map +1 -1
  117. package/dist/settings-patcher/anthropic.d.ts +5 -0
  118. package/dist/{settings-patcher.js → settings-patcher/anthropic.js} +3 -7
  119. package/dist/settings-patcher/anthropic.js.map +1 -0
  120. package/dist/settings-patcher/claude.d.ts +5 -0
  121. package/dist/settings-patcher/claude.js +75 -0
  122. package/dist/settings-patcher/claude.js.map +1 -0
  123. package/dist/settings-patcher/codex.d.ts +23 -0
  124. package/dist/settings-patcher/codex.js +114 -0
  125. package/dist/settings-patcher/codex.js.map +1 -0
  126. package/dist/settings-patcher/index.d.ts +15 -0
  127. package/dist/settings-patcher/index.js +9 -0
  128. package/dist/settings-patcher/index.js.map +1 -0
  129. package/dist/{settings-patcher.d.ts → settings-patcher/types.d.ts} +1 -5
  130. package/dist/settings-patcher/types.js +2 -0
  131. package/dist/settings-patcher/types.js.map +1 -0
  132. package/dist/startup.d.ts +11 -0
  133. package/dist/startup.js +154 -0
  134. package/dist/startup.js.map +1 -0
  135. package/dist/tool-bridge/constants.d.ts +2 -0
  136. package/dist/tool-bridge/constants.js +3 -0
  137. package/dist/tool-bridge/constants.js.map +1 -0
  138. package/dist/tool-bridge/index.d.ts +1 -0
  139. package/dist/tool-bridge/index.js +1 -0
  140. package/dist/tool-bridge/index.js.map +1 -1
  141. package/dist/tool-bridge/routes.js +2 -1
  142. package/dist/tool-bridge/routes.js.map +1 -1
  143. package/dist/tool-bridge/session-lifecycle.js +1 -1
  144. package/dist/tool-bridge/state.d.ts +1 -1
  145. package/dist/tool-bridge/tool-cache.d.ts +1 -1
  146. package/dist/ui.d.ts +36 -0
  147. package/dist/ui.js +71 -0
  148. package/dist/ui.js.map +1 -0
  149. package/dist/utils/responses-prompt.d.ts +4 -0
  150. package/dist/utils/responses-prompt.js +58 -0
  151. package/dist/utils/responses-prompt.js.map +1 -0
  152. package/package.json +3 -1
  153. package/dist/settings-patcher.js.map +0 -1
@@ -0,0 +1,24 @@
1
+ import { registerToolBridge } from "../../tool-bridge/index.js";
2
+ import { createResponsesHandler } from "./handler.js";
3
+ export const codexProvider = {
4
+ name: "Codex",
5
+ routes: ["POST /v1/responses"],
6
+ register(app, ctx) {
7
+ app.addHook("onRequest", (request, reply, done) => {
8
+ if (request.url.startsWith("/mcp/")) {
9
+ done();
10
+ return;
11
+ }
12
+ const ua = request.headers["user-agent"] ?? "";
13
+ if (!ua.startsWith("Xcode/")) {
14
+ ctx.logger.warn(`Rejected request from unexpected user-agent: ${ua}`);
15
+ void reply.code(403).type("application/json").send('{"error":"Forbidden"}\n');
16
+ return;
17
+ }
18
+ done();
19
+ });
20
+ const manager = registerToolBridge(app, ctx.logger);
21
+ app.post("/v1/responses", createResponsesHandler(ctx, manager));
22
+ },
23
+ };
24
+ //# sourceMappingURL=provider.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"provider.js","sourceRoot":"","sources":["../../../src/providers/codex/provider.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,4BAA4B,CAAC;AAChE,OAAO,EAAE,sBAAsB,EAAE,MAAM,cAAc,CAAC;AAEtD,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,OAAO;IACb,MAAM,EAAE,CAAC,oBAAoB,CAAC;IAE9B,QAAQ,CAAC,GAAG,EAAE,GAAG;QACf,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YAChD,IAAI,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;gBACpC,IAAI,EAAE,CAAC;gBACP,OAAO;YACT,CAAC;YACD,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YAC/C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC7B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,gDAAgD,EAAE,EAAE,CAAC,CAAC;gBACtE,KAAK,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;gBAC9E,OAAO;YACT,CAAC;YACD,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,kBAAkB,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;QACpD,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,sBAAsB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;IAClE,CAAC;CACiB,CAAC"}
@@ -0,0 +1,122 @@
1
+ import { z } from "zod";
2
+ declare const ResponsesInputMessageSchema: z.ZodObject<{
3
+ type: z.ZodOptional<z.ZodLiteral<"message">>;
4
+ role: z.ZodEnum<{
5
+ system: "system";
6
+ developer: "developer";
7
+ user: "user";
8
+ assistant: "assistant";
9
+ }>;
10
+ content: z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>>]>;
11
+ }, z.core.$strip>;
12
+ declare const FunctionCallInputSchema: z.ZodObject<{
13
+ type: z.ZodLiteral<"function_call">;
14
+ id: z.ZodOptional<z.ZodString>;
15
+ call_id: z.ZodString;
16
+ name: z.ZodString;
17
+ arguments: z.ZodString;
18
+ }, z.core.$strip>;
19
+ declare const FunctionCallOutputInputSchema: z.ZodObject<{
20
+ type: z.ZodLiteral<"function_call_output">;
21
+ call_id: z.ZodString;
22
+ output: z.ZodString;
23
+ }, z.core.$strip>;
24
+ declare const InputItemSchema: z.ZodUnion<readonly [z.ZodObject<{
25
+ type: z.ZodOptional<z.ZodLiteral<"message">>;
26
+ role: z.ZodEnum<{
27
+ system: "system";
28
+ developer: "developer";
29
+ user: "user";
30
+ assistant: "assistant";
31
+ }>;
32
+ content: z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>>]>;
33
+ }, z.core.$strip>, z.ZodObject<{
34
+ type: z.ZodLiteral<"function_call">;
35
+ id: z.ZodOptional<z.ZodString>;
36
+ call_id: z.ZodString;
37
+ name: z.ZodString;
38
+ arguments: z.ZodString;
39
+ }, z.core.$strip>, z.ZodObject<{
40
+ type: z.ZodLiteral<"function_call_output">;
41
+ call_id: z.ZodString;
42
+ output: z.ZodString;
43
+ }, z.core.$strip>]>;
44
+ export type InputItem = z.infer<typeof InputItemSchema>;
45
+ export type InputMessage = z.infer<typeof ResponsesInputMessageSchema>;
46
+ export type FunctionCallInput = z.infer<typeof FunctionCallInputSchema>;
47
+ export type FunctionCallOutputInput = z.infer<typeof FunctionCallOutputInputSchema>;
48
+ declare const FunctionToolSchema: z.ZodObject<{
49
+ type: z.ZodLiteral<"function">;
50
+ name: z.ZodString;
51
+ description: z.ZodOptional<z.ZodString>;
52
+ parameters: z.ZodOptional<z.ZodRecord<z.ZodString, z.ZodUnknown>>;
53
+ strict: z.ZodOptional<z.ZodBoolean>;
54
+ }, z.core.$strip>;
55
+ export type ResponsesTool = z.infer<typeof FunctionToolSchema>;
56
+ /** Narrow to function tools only (ignore web_search, code_interpreter, etc.) */
57
+ export declare function filterFunctionTools(tools: Record<string, unknown>[]): ResponsesTool[];
58
+ export declare const ResponsesRequestSchema: z.ZodObject<{
59
+ model: z.ZodString;
60
+ input: z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodUnion<readonly [z.ZodObject<{
61
+ type: z.ZodOptional<z.ZodLiteral<"message">>;
62
+ role: z.ZodEnum<{
63
+ system: "system";
64
+ developer: "developer";
65
+ user: "user";
66
+ assistant: "assistant";
67
+ }>;
68
+ content: z.ZodUnion<readonly [z.ZodString, z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>>]>;
69
+ }, z.core.$strip>, z.ZodObject<{
70
+ type: z.ZodLiteral<"function_call">;
71
+ id: z.ZodOptional<z.ZodString>;
72
+ call_id: z.ZodString;
73
+ name: z.ZodString;
74
+ arguments: z.ZodString;
75
+ }, z.core.$strip>, z.ZodObject<{
76
+ type: z.ZodLiteral<"function_call_output">;
77
+ call_id: z.ZodString;
78
+ output: z.ZodString;
79
+ }, z.core.$strip>]>>]>;
80
+ instructions: z.ZodOptional<z.ZodString>;
81
+ tools: z.ZodOptional<z.ZodArray<z.ZodRecord<z.ZodString, z.ZodUnknown>>>;
82
+ stream: z.ZodOptional<z.ZodBoolean>;
83
+ temperature: z.ZodOptional<z.ZodNumber>;
84
+ previous_response_id: z.ZodOptional<z.ZodString>;
85
+ }, z.core.$strip>;
86
+ export type ResponsesRequest = z.infer<typeof ResponsesRequestSchema>;
87
+ export interface MessageContent {
88
+ type: "output_text";
89
+ text: string;
90
+ annotations: unknown[];
91
+ }
92
+ export interface MessageOutputItem {
93
+ type: "message";
94
+ id: string;
95
+ status: "in_progress" | "completed";
96
+ role: "assistant";
97
+ content: MessageContent[];
98
+ }
99
+ export interface FunctionCallOutputItem {
100
+ type: "function_call";
101
+ id: string;
102
+ call_id: string;
103
+ name: string;
104
+ arguments: string;
105
+ status: "in_progress" | "completed";
106
+ }
107
+ export type OutputItem = MessageOutputItem | FunctionCallOutputItem;
108
+ export interface ResponseObject {
109
+ id: string;
110
+ object: "response";
111
+ created_at: number;
112
+ model: string;
113
+ status: "in_progress" | "completed" | "incomplete" | "failed";
114
+ output: OutputItem[];
115
+ error?: {
116
+ code: string;
117
+ message: string;
118
+ } | null;
119
+ }
120
+ export declare function currentTimestamp(): number;
121
+ export declare function genId(prefix: string): string;
122
+ export {};
@@ -0,0 +1,55 @@
1
+ import { randomUUID } from "node:crypto";
2
+ import { z } from "zod";
3
+ const ResponsesInputMessageSchema = z.object({
4
+ type: z.literal("message").optional(),
5
+ role: z.enum(["user", "assistant", "system", "developer"]),
6
+ content: z.union([z.string(), z.array(z.record(z.string(), z.unknown()))]),
7
+ });
8
+ const FunctionCallInputSchema = z.object({
9
+ type: z.literal("function_call"),
10
+ id: z.string().optional(),
11
+ call_id: z.string(),
12
+ name: z.string(),
13
+ arguments: z.string(),
14
+ });
15
+ const FunctionCallOutputInputSchema = z.object({
16
+ type: z.literal("function_call_output"),
17
+ call_id: z.string(),
18
+ output: z.string(),
19
+ });
20
+ const InputItemSchema = z.union([
21
+ ResponsesInputMessageSchema,
22
+ FunctionCallInputSchema,
23
+ FunctionCallOutputInputSchema,
24
+ ]);
25
+ /** Accept any tool shape in the request; we only process function tools. */
26
+ const RawToolSchema = z.record(z.string(), z.unknown());
27
+ const FunctionToolSchema = z.object({
28
+ type: z.literal("function"),
29
+ name: z.string(),
30
+ description: z.string().optional(),
31
+ parameters: z.record(z.string(), z.unknown()).optional(),
32
+ strict: z.boolean().optional(),
33
+ });
34
+ /** Narrow to function tools only (ignore web_search, code_interpreter, etc.) */
35
+ export function filterFunctionTools(tools) {
36
+ return tools
37
+ .filter((t) => t.type === "function")
38
+ .map((t) => FunctionToolSchema.parse(t));
39
+ }
40
+ export const ResponsesRequestSchema = z.object({
41
+ model: z.string().min(1, "Model is required"),
42
+ input: z.union([z.string(), z.array(InputItemSchema)]),
43
+ instructions: z.string().optional(),
44
+ tools: z.array(RawToolSchema).optional(),
45
+ stream: z.boolean().optional(),
46
+ temperature: z.number().optional(),
47
+ previous_response_id: z.string().optional(),
48
+ });
49
+ export function currentTimestamp() {
50
+ return Math.floor(Date.now() / 1000);
51
+ }
52
+ export function genId(prefix) {
53
+ return `${prefix}_${randomUUID()}`;
54
+ }
55
+ //# sourceMappingURL=schemas.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"schemas.js","sourceRoot":"","sources":["../../../src/providers/codex/schemas.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import type { FastifyReply } from "fastify";
2
+ import type { CopilotSession } from "@github/copilot-sdk";
3
+ import type { Logger } from "../../logger.js";
4
+ import type { ToolBridgeState } from "../../tool-bridge/state.js";
5
+ export interface SeqCounter {
6
+ value: number;
7
+ }
8
+ export declare function startResponseStream(reply: FastifyReply, responseId: string, model: string, seq?: SeqCounter): SeqCounter;
9
+ export declare function handleResponsesStreaming(state: ToolBridgeState, session: CopilotSession, prompt: string, model: string, logger: Logger, hasBridge: boolean, responseId: string): Promise<void>;
@@ -0,0 +1,172 @@
1
+ import { currentTimestamp, genId } from "./schemas.js";
2
+ import { SSE_HEADERS, sendSSEEvent as sendEvent, sendSSEComment } from "../shared/streaming-utils.js";
3
+ import { runSessionStreaming } from "../shared/streaming-core.js";
4
+ function nextSeq(counter) {
5
+ return counter.value++;
6
+ }
7
+ export function startResponseStream(reply, responseId, model, seq) {
8
+ const counter = seq ?? { value: 0 };
9
+ reply.raw.writeHead(200, SSE_HEADERS);
10
+ const response = {
11
+ id: responseId,
12
+ object: "response",
13
+ created_at: currentTimestamp(),
14
+ model,
15
+ status: "in_progress",
16
+ output: [],
17
+ };
18
+ sendEvent(reply, "response.created", { response }, nextSeq(counter));
19
+ sendEvent(reply, "response.in_progress", { response }, nextSeq(counter));
20
+ return counter;
21
+ }
22
+ function createResponsesProtocol(responseId, model, seq, getReply) {
23
+ let messageItem = null;
24
+ let messageStarted = false;
25
+ let outputIndex = 0;
26
+ const outputItems = [];
27
+ const accumulatedText = [];
28
+ // Keepalive every 15s so the client doesn't time out while
29
+ // waiting for internal tool execution to finish
30
+ const keepaliveInterval = setInterval(() => {
31
+ const r = getReply();
32
+ if (r)
33
+ sendSSEComment(r);
34
+ }, 15_000);
35
+ function ensureMessageItem(r) {
36
+ if (!messageStarted) {
37
+ messageItem = {
38
+ type: "message",
39
+ id: genId("msg"),
40
+ status: "in_progress",
41
+ role: "assistant",
42
+ content: [],
43
+ };
44
+ sendEvent(r, "response.output_item.added", {
45
+ output_index: outputIndex,
46
+ item: messageItem,
47
+ }, nextSeq(seq));
48
+ sendEvent(r, "response.content_part.added", {
49
+ item_id: messageItem.id,
50
+ output_index: outputIndex,
51
+ content_index: 0,
52
+ part: { type: "output_text", text: "", annotations: [] },
53
+ }, nextSeq(seq));
54
+ messageStarted = true;
55
+ }
56
+ }
57
+ function closeMessageItem(r) {
58
+ if (!messageStarted || !messageItem)
59
+ return;
60
+ const fullText = accumulatedText.join("");
61
+ sendEvent(r, "response.output_text.done", {
62
+ item_id: messageItem.id,
63
+ output_index: outputIndex,
64
+ content_index: 0,
65
+ text: fullText,
66
+ }, nextSeq(seq));
67
+ sendEvent(r, "response.content_part.done", {
68
+ item_id: messageItem.id,
69
+ output_index: outputIndex,
70
+ content_index: 0,
71
+ part: { type: "output_text", text: fullText, annotations: [] },
72
+ }, nextSeq(seq));
73
+ messageItem.status = "completed";
74
+ messageItem.content = [{ type: "output_text", text: fullText, annotations: [] }];
75
+ outputItems.push(messageItem);
76
+ sendEvent(r, "response.output_item.done", {
77
+ output_index: outputIndex,
78
+ item: messageItem,
79
+ }, nextSeq(seq));
80
+ outputIndex++;
81
+ messageStarted = false;
82
+ messageItem = null;
83
+ }
84
+ function emitFunctionCallItems(r, toolRequests) {
85
+ for (const tr of toolRequests) {
86
+ const callId = tr.toolCallId;
87
+ const itemId = genId("fc");
88
+ const argsJson = tr.arguments != null ? JSON.stringify(tr.arguments) : "{}";
89
+ const fcItem = {
90
+ type: "function_call",
91
+ id: itemId,
92
+ call_id: callId,
93
+ name: tr.name,
94
+ arguments: argsJson,
95
+ status: "in_progress",
96
+ };
97
+ sendEvent(r, "response.output_item.added", {
98
+ output_index: outputIndex,
99
+ item: fcItem,
100
+ }, nextSeq(seq));
101
+ const doneItem = { ...fcItem, status: "completed" };
102
+ sendEvent(r, "response.output_item.done", {
103
+ output_index: outputIndex,
104
+ item: doneItem,
105
+ }, nextSeq(seq));
106
+ outputItems.push(doneItem);
107
+ outputIndex++;
108
+ }
109
+ }
110
+ function sendResponseEnvelope(r, status) {
111
+ const response = {
112
+ id: responseId,
113
+ object: "response",
114
+ created_at: currentTimestamp(),
115
+ model,
116
+ status,
117
+ output: outputItems,
118
+ };
119
+ sendEvent(r, `response.${status}`, { response }, nextSeq(seq));
120
+ }
121
+ return {
122
+ flushDeltas(r, deltas) {
123
+ ensureMessageItem(r);
124
+ if (!messageItem)
125
+ return;
126
+ for (const text of deltas) {
127
+ sendEvent(r, "response.output_text.delta", {
128
+ item_id: messageItem.id,
129
+ output_index: outputIndex,
130
+ content_index: 0,
131
+ delta: text,
132
+ }, nextSeq(seq));
133
+ accumulatedText.push(text);
134
+ }
135
+ },
136
+ emitToolsAndFinish(r, tools) {
137
+ closeMessageItem(r);
138
+ emitFunctionCallItems(r, tools);
139
+ sendResponseEnvelope(r, "completed");
140
+ },
141
+ sendCompleted(r) {
142
+ if (!messageStarted)
143
+ ensureMessageItem(r);
144
+ closeMessageItem(r);
145
+ sendResponseEnvelope(r, "completed");
146
+ },
147
+ sendFailed(r) {
148
+ if (messageStarted)
149
+ closeMessageItem(r);
150
+ sendResponseEnvelope(r, "failed");
151
+ },
152
+ teardown() {
153
+ clearInterval(keepaliveInterval);
154
+ },
155
+ reset() {
156
+ messageStarted = false;
157
+ messageItem = null;
158
+ outputIndex = 0;
159
+ outputItems.length = 0;
160
+ accumulatedText.length = 0;
161
+ },
162
+ };
163
+ }
164
+ export async function handleResponsesStreaming(state, session, prompt, model, logger, hasBridge, responseId) {
165
+ const reply = state.currentReply;
166
+ if (!reply)
167
+ throw new Error("No reply set on bridge state");
168
+ const seq = startResponseStream(reply, responseId, model);
169
+ const protocol = createResponsesProtocol(responseId, model, seq, () => state.currentReply);
170
+ return runSessionStreaming(state, session, prompt, logger, hasBridge, protocol, reply);
171
+ }
172
+ //# sourceMappingURL=streaming.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"streaming.js","sourceRoot":"","sources":["../../../src/providers/codex/streaming.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,4 @@
1
+ import type { FunctionCallOutputInput } from "./schemas.js";
2
+ import type { ToolBridgeState } from "../../tool-bridge/state.js";
3
+ import type { Logger } from "../../logger.js";
4
+ export declare function resolveResponsesToolResults(outputs: FunctionCallOutputInput[], state: ToolBridgeState, logger: Logger): void;
@@ -0,0 +1,9 @@
1
+ export function resolveResponsesToolResults(outputs, state, logger) {
2
+ for (const item of outputs) {
3
+ logger.debug(`Resolving tool result for ${item.call_id}`);
4
+ if (!state.resolveToolCall(item.call_id, item.output)) {
5
+ logger.warn(`No pending MCP request for call_id ${item.call_id}`);
6
+ }
7
+ }
8
+ }
9
+ //# sourceMappingURL=tool-results.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tool-results.js","sourceRoot":"","sources":["../../../src/providers/codex/tool-results.ts"],"names":[],"mappings":"AAIA,MAAM,UAAU,2BAA2B,CACzC,OAAkC,EAClC,KAAsB,EACtB,MAAc;IAEd,KAAK,MAAM,IAAI,IAAI,OAAO,EAAE,CAAC;QAC3B,MAAM,CAAC,KAAK,CAAC,6BAA6B,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAC1D,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;YACtD,MAAM,CAAC,IAAI,CAAC,sCAAsC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QACpE,CAAC;IACH,CAAC;AACH,CAAC"}
@@ -0,0 +1,5 @@
1
+ export declare const codexProvider: {
2
+ name: string;
3
+ routes: string[];
4
+ register(app: import("fastify").FastifyInstance<import("fastify").RawServerDefault, import("node:http").IncomingMessage, import("node:http").ServerResponse<import("node:http").IncomingMessage>, import("fastify").FastifyBaseLogger, import("fastify").FastifyTypeProviderDefault>, ctx: import("../context.js").AppContext): void;
5
+ };
@@ -0,0 +1,24 @@
1
+ import { registerToolBridge } from "../tool-bridge/index.js";
2
+ import { createResponsesHandler } from "../handlers/responses.js";
3
+ export const codexProvider = {
4
+ name: "Codex",
5
+ routes: ["POST /v1/responses"],
6
+ register(app, ctx) {
7
+ app.addHook("onRequest", (request, reply, done) => {
8
+ if (request.url.startsWith("/mcp/")) {
9
+ done();
10
+ return;
11
+ }
12
+ const ua = request.headers["user-agent"] ?? "";
13
+ if (!ua.startsWith("Xcode/")) {
14
+ ctx.logger.warn(`Rejected request from unexpected user-agent: ${ua}`);
15
+ void reply.code(403).type("application/json").send('{"error":"Forbidden"}\n');
16
+ return;
17
+ }
18
+ done();
19
+ });
20
+ const manager = registerToolBridge(app, ctx.logger);
21
+ app.post("/v1/responses", createResponsesHandler(ctx, manager));
22
+ },
23
+ };
24
+ //# sourceMappingURL=codex.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"codex.js","sourceRoot":"","sources":["../../src/providers/codex.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,kBAAkB,EAAE,MAAM,yBAAyB,CAAC;AAC7D,OAAO,EAAE,sBAAsB,EAAE,MAAM,0BAA0B,CAAC;AAElE,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,IAAI,EAAE,OAAO;IACb,MAAM,EAAE,CAAC,oBAAoB,CAAC;IAE9B,QAAQ,CAAC,GAAG,EAAE,GAAG;QACf,GAAG,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAE;YAChD,IAAI,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,OAAO,CAAC,EAAE,CAAC;gBACpC,IAAI,EAAE,CAAC;gBACP,OAAO;YACT,CAAC;YACD,MAAM,EAAE,GAAG,OAAO,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;YAC/C,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,QAAQ,CAAC,EAAE,CAAC;gBAC7B,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,gDAAgD,EAAE,EAAE,CAAC,CAAC;gBACtE,KAAK,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,kBAAkB,CAAC,CAAC,IAAI,CAAC,yBAAyB,CAAC,CAAC;gBAC9E,OAAO;YACT,CAAC;YACD,IAAI,EAAE,CAAC;QACT,CAAC,CAAC,CAAC;QAEH,MAAM,OAAO,GAAG,kBAAkB,CAAC,GAAG,EAAE,GAAG,CAAC,MAAM,CAAC,CAAC;QACpD,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,sBAAsB,CAAC,GAAG,EAAE,OAAO,CAAC,CAAC,CAAC;IAClE,CAAC;CACiB,CAAC"}
@@ -6,7 +6,12 @@ export declare const providers: {
6
6
  routes: string[];
7
7
  register(app: import("fastify").FastifyInstance<import("fastify").RawServerDefault, import("node:http").IncomingMessage, import("node:http").ServerResponse<import("node:http").IncomingMessage>, import("fastify").FastifyBaseLogger, import("fastify").FastifyTypeProviderDefault>, ctx: import("../context.js").AppContext): void;
8
8
  };
9
- anthropic: {
9
+ claude: {
10
+ name: string;
11
+ routes: string[];
12
+ register(app: import("fastify").FastifyInstance<import("fastify").RawServerDefault, import("node:http").IncomingMessage, import("node:http").ServerResponse<import("node:http").IncomingMessage>, import("fastify").FastifyBaseLogger, import("fastify").FastifyTypeProviderDefault>, ctx: import("../context.js").AppContext): void;
13
+ };
14
+ codex: {
10
15
  name: string;
11
16
  routes: string[];
12
17
  register(app: import("fastify").FastifyInstance<import("fastify").RawServerDefault, import("node:http").IncomingMessage, import("node:http").ServerResponse<import("node:http").IncomingMessage>, import("fastify").FastifyBaseLogger, import("fastify").FastifyTypeProviderDefault>, ctx: import("../context.js").AppContext): void;
@@ -1,7 +1,9 @@
1
- import { openaiProvider } from "./openai.js";
2
- import { anthropicProvider } from "./anthropic.js";
1
+ import { openaiProvider } from "./openai/provider.js";
2
+ import { claudeProvider } from "./claude/provider.js";
3
+ import { codexProvider } from "./codex/provider.js";
3
4
  export const providers = {
4
5
  openai: openaiProvider,
5
- anthropic: anthropicProvider,
6
+ claude: claudeProvider,
7
+ codex: codexProvider,
6
8
  };
7
9
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AAKnD,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,MAAM,EAAE,cAAc;IACtB,SAAS,EAAE,iBAAiB;CACM,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAKpD,MAAM,CAAC,MAAM,SAAS,GAAG;IACvB,MAAM,EAAE,cAAc;IACtB,MAAM,EAAE,cAAc;IACtB,KAAK,EAAE,aAAa;CACc,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { FastifyRequest, FastifyReply } from "fastify";
2
+ import type { AppContext } from "../../context.js";
3
+ import type { ConversationManager } from "../../conversation-manager.js";
4
+ export declare function createCompletionsHandler({ service, logger, config }: AppContext, manager: ConversationManager): (request: FastifyRequest, reply: FastifyReply) => Promise<void>;
@@ -0,0 +1,120 @@
1
+ import { ChatCompletionRequestSchema, extractContentText } from "./schemas.js";
2
+ import { formatPrompt } from "./prompt.js";
3
+ import { createSessionConfig } from "../shared/session-config.js";
4
+ import { handleStreaming } from "./streaming.js";
5
+ import { sendOpenAIError as sendError } from "../shared/errors.js";
6
+ export function createCompletionsHandler({ service, logger, config }, manager) {
7
+ return async function handleCompletions(request, reply) {
8
+ const parseResult = ChatCompletionRequestSchema.safeParse(request.body);
9
+ if (!parseResult.success) {
10
+ const firstIssue = parseResult.error.issues[0];
11
+ sendError(reply, 400, "invalid_request_error", firstIssue?.message ?? "Invalid request body");
12
+ return;
13
+ }
14
+ const req = parseResult.data;
15
+ const messages = req.messages;
16
+ const { conversation, isReuse } = manager.findForNewRequest();
17
+ const state = conversation.state;
18
+ state.markSessionActive();
19
+ logger.info(isReuse
20
+ ? `Reusing primary conversation ${conversation.id}`
21
+ : `New conversation ${conversation.id}`);
22
+ const systemParts = [];
23
+ for (const msg of messages) {
24
+ if (msg.role === "system" || msg.role === "developer") {
25
+ try {
26
+ systemParts.push(extractContentText(msg.content));
27
+ }
28
+ catch (err) {
29
+ sendError(reply, 400, "invalid_request_error", err instanceof Error ? err.message : String(err));
30
+ if (isReuse) {
31
+ state.markSessionInactive();
32
+ }
33
+ else {
34
+ manager.remove(conversation.id);
35
+ }
36
+ return;
37
+ }
38
+ }
39
+ }
40
+ let prompt;
41
+ try {
42
+ prompt = formatPrompt(messages.slice(conversation.sentMessageCount), config.excludedFilePatterns);
43
+ }
44
+ catch (err) {
45
+ sendError(reply, 400, "invalid_request_error", err instanceof Error ? err.message : String(err));
46
+ if (isReuse) {
47
+ state.markSessionInactive();
48
+ }
49
+ else {
50
+ manager.remove(conversation.id);
51
+ }
52
+ return;
53
+ }
54
+ if (!isReuse) {
55
+ const systemMessage = systemParts.length > 0 ? systemParts.join("\n\n") : undefined;
56
+ let supportsReasoningEffort = false;
57
+ if (config.reasoningEffort) {
58
+ try {
59
+ const models = await service.listModels();
60
+ const modelInfo = models.find((m) => m.id === req.model);
61
+ supportsReasoningEffort =
62
+ modelInfo?.capabilities.supports.reasoningEffort ?? false;
63
+ if (!supportsReasoningEffort) {
64
+ logger.debug(`Model "${req.model}" does not support reasoning effort, ignoring config`);
65
+ }
66
+ }
67
+ catch (err) {
68
+ logger.warn("Failed to check model capabilities:", err);
69
+ }
70
+ }
71
+ // No resolveModel() needed here because Xcode picks from the
72
+ // /v1/models response which already has Copilot's exact IDs
73
+ const sessionConfig = createSessionConfig({
74
+ model: req.model,
75
+ systemMessage,
76
+ logger,
77
+ config,
78
+ supportsReasoningEffort,
79
+ cwd: service.cwd,
80
+ });
81
+ try {
82
+ conversation.session = await service.createSession(sessionConfig);
83
+ }
84
+ catch (err) {
85
+ logger.error("Creating session failed:", err);
86
+ sendError(reply, 500, "api_error", "Failed to create session");
87
+ manager.remove(conversation.id);
88
+ return;
89
+ }
90
+ }
91
+ if (!conversation.session) {
92
+ logger.error("Primary conversation has no session, clearing");
93
+ manager.clearPrimary();
94
+ sendError(reply, 500, "api_error", "Session lost, please retry");
95
+ return;
96
+ }
97
+ try {
98
+ logger.info("Streaming response");
99
+ const healthy = await handleStreaming(reply, conversation.session, prompt, req.model, logger);
100
+ state.markSessionInactive();
101
+ if (healthy) {
102
+ conversation.sentMessageCount = req.messages.length;
103
+ }
104
+ else if (conversation.isPrimary) {
105
+ manager.clearPrimary();
106
+ }
107
+ }
108
+ catch (err) {
109
+ logger.error("Request failed:", err);
110
+ state.markSessionInactive();
111
+ if (conversation.isPrimary) {
112
+ manager.clearPrimary();
113
+ }
114
+ if (!reply.sent) {
115
+ sendError(reply, 500, "api_error", err instanceof Error ? err.message : "Internal error");
116
+ }
117
+ }
118
+ };
119
+ }
120
+ //# sourceMappingURL=handler.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"handler.js","sourceRoot":"","sources":["../../../src/providers/openai/handler.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { FastifyRequest, FastifyReply } from "fastify";
2
+ import type { AppContext } from "../../context.js";
3
+ export declare function createModelsHandler({ service, logger }: AppContext): (_request: FastifyRequest, reply: FastifyReply) => Promise<void>;