@himanshu806/ccproxy 0.1.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 (47) hide show
  1. package/LICENSE +28 -0
  2. package/README.md +33 -0
  3. package/dist/cli.d.ts +3 -0
  4. package/dist/cli.d.ts.map +1 -0
  5. package/dist/cli.js +202 -0
  6. package/dist/cli.js.map +1 -0
  7. package/dist/config.d.ts +43 -0
  8. package/dist/config.d.ts.map +1 -0
  9. package/dist/config.js +138 -0
  10. package/dist/config.js.map +1 -0
  11. package/dist/converter.d.ts +21 -0
  12. package/dist/converter.d.ts.map +1 -0
  13. package/dist/converter.js +159 -0
  14. package/dist/converter.js.map +1 -0
  15. package/dist/logger.d.ts +5 -0
  16. package/dist/logger.d.ts.map +1 -0
  17. package/dist/logger.js +73 -0
  18. package/dist/logger.js.map +1 -0
  19. package/dist/providers/gemini.d.ts +22 -0
  20. package/dist/providers/gemini.d.ts.map +1 -0
  21. package/dist/providers/gemini.js +45 -0
  22. package/dist/providers/gemini.js.map +1 -0
  23. package/dist/providers/index.d.ts +4 -0
  24. package/dist/providers/index.d.ts.map +1 -0
  25. package/dist/providers/index.js +4 -0
  26. package/dist/providers/index.js.map +1 -0
  27. package/dist/providers/ollama.d.ts +22 -0
  28. package/dist/providers/ollama.d.ts.map +1 -0
  29. package/dist/providers/ollama.js +44 -0
  30. package/dist/providers/ollama.js.map +1 -0
  31. package/dist/providers/openai.d.ts +22 -0
  32. package/dist/providers/openai.d.ts.map +1 -0
  33. package/dist/providers/openai.js +38 -0
  34. package/dist/providers/openai.js.map +1 -0
  35. package/dist/server.d.ts +3 -0
  36. package/dist/server.d.ts.map +1 -0
  37. package/dist/server.js +73 -0
  38. package/dist/server.js.map +1 -0
  39. package/dist/translator.d.ts +3 -0
  40. package/dist/translator.d.ts.map +1 -0
  41. package/dist/translator.js +155 -0
  42. package/dist/translator.js.map +1 -0
  43. package/dist/types.d.ts +108 -0
  44. package/dist/types.d.ts.map +1 -0
  45. package/dist/types.js +3 -0
  46. package/dist/types.js.map +1 -0
  47. package/package.json +59 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"converter.js","sourceRoot":"","sources":["../src/converter.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export declare function logRequestStart(requestId: string, claudeModel: string, targetModel: string, provider: string, numMessages: number, numTools: number): void;
2
+ export declare function logRequest(requestId: string, claudeModel: string, targetModel: string, provider: string, numMessages: number, numTools: number, statusCode: number, durationMs: number): void;
3
+ export declare function logVerbose(requestId: string, type: "PROMPT" | "RESPONSE", data: any): void;
4
+ export declare function logInfo(requestId: string, message: string): void;
5
+ //# sourceMappingURL=logger.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"AA+CA,wBAAgB,eAAe,CAC7B,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,QAYjB;AAED,wBAAgB,UAAU,CACxB,SAAS,EAAE,MAAM,EACjB,WAAW,EAAE,MAAM,EACnB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,WAAW,EAAE,MAAM,EACnB,QAAQ,EAAE,MAAM,EAChB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,MAAM,QAgBnB;AAED,wBAAgB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,GAAG,UAAU,EAAE,IAAI,EAAE,GAAG,QAWnF;AAED,wBAAgB,OAAO,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,QAQzD"}
package/dist/logger.js ADDED
@@ -0,0 +1,73 @@
1
+ import { config } from "./config.js";
2
+ const RESET = "\x1b[0m";
3
+ const BOLD = "\x1b[1m";
4
+ const DIM = "\x1b[2m";
5
+ const CYAN = "\x1b[36m";
6
+ const GREEN = "\x1b[32m";
7
+ const YELLOW = "\x1b[33m";
8
+ const MAGENTA = "\x1b[35m";
9
+ const BLUE = "\x1b[34m";
10
+ const RED = "\x1b[31m";
11
+ const PROVIDER_COLORS = {
12
+ openai: GREEN,
13
+ gemini: BLUE,
14
+ ollama: MAGENTA,
15
+ };
16
+ function getLogLine(requestId, claudeModel, targetModel, provider, numMessages, numTools, statusCode, durationMs) {
17
+ const providerColor = PROVIDER_COLORS[provider] ?? CYAN;
18
+ const statusStr = statusCode === undefined
19
+ ? `${YELLOW}processing...${RESET}`
20
+ : (statusCode >= 400 ? `${RED}${statusCode}${RESET}` : `${GREEN}${statusCode}${RESET}`);
21
+ const durationStr = durationMs === undefined
22
+ ? ""
23
+ : (durationMs > 2000 ? `${YELLOW}${durationMs}ms${RESET}` : `${DIM}${durationMs}ms${RESET}`);
24
+ return (`${DIM}[${new Date().toISOString()}]${RESET} ` +
25
+ `${BOLD}${requestId}${RESET} ` +
26
+ `${CYAN}${claudeModel}${RESET} ${DIM}→${RESET} ` +
27
+ `${providerColor}${BOLD}${provider}/${targetModel}${RESET} ` +
28
+ `${DIM}msgs:${numMessages} tools:${numTools}${RESET} ` +
29
+ `${statusStr} ${durationStr}`);
30
+ }
31
+ export function logRequestStart(requestId, claudeModel, targetModel, provider, numMessages, numTools) {
32
+ if (config.verbose > 0) {
33
+ console.log(`${DIM}[${new Date().toISOString()}]${RESET} ` +
34
+ `${BOLD}${requestId}${RESET} ` +
35
+ `${YELLOW}${BOLD}[REQUEST RECEIVED]${RESET} ` +
36
+ `${CYAN}${claudeModel}${RESET} → ${BOLD}${provider}/${targetModel}${RESET}`);
37
+ return;
38
+ }
39
+ process.stdout.write(getLogLine(requestId, claudeModel, targetModel, provider, numMessages, numTools) + "\r");
40
+ }
41
+ export function logRequest(requestId, claudeModel, targetModel, provider, numMessages, numTools, statusCode, durationMs) {
42
+ const line = getLogLine(requestId, claudeModel, targetModel, provider, numMessages, numTools, statusCode, durationMs);
43
+ if (config.verbose > 0) {
44
+ console.log(`${DIM}[${new Date().toISOString()}]${RESET} ` +
45
+ `${BOLD}${requestId}${RESET} ` +
46
+ `${GREEN}${BOLD}[RESPONSE COMPLETE]${RESET} ` +
47
+ `${statusCode} in ${durationMs}ms`);
48
+ // Also print the standard line for consistency
49
+ console.log(line);
50
+ }
51
+ else {
52
+ // Clear line and write final
53
+ process.stdout.write("\x1b[2K\r" + line + "\n");
54
+ }
55
+ }
56
+ export function logVerbose(requestId, type, data) {
57
+ // Only log JSON if verbose level is 2
58
+ if (config.verbose < 2)
59
+ return;
60
+ const color = type === "PROMPT" ? YELLOW : GREEN;
61
+ console.log(`${DIM}[${new Date().toISOString()}]${RESET} ` +
62
+ `${BOLD}${requestId}${RESET} ` +
63
+ `${color}${BOLD}[${type} JSON]${RESET}`);
64
+ console.log(`${DIM}${JSON.stringify(data, null, 2)}${RESET}\n`);
65
+ }
66
+ export function logInfo(requestId, message) {
67
+ if (config.verbose > 0) {
68
+ console.log(`${DIM}[${new Date().toISOString()}]${RESET} ` +
69
+ `${BOLD}${requestId}${RESET} ` +
70
+ `${BLUE}${BOLD}[INFO]${RESET} ${message}`);
71
+ }
72
+ }
73
+ //# sourceMappingURL=logger.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logger.js","sourceRoot":"","sources":["../src/logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,22 @@
1
+ import type { OpenAIRequest } from "../types.js";
2
+ import type { FastifyReply } from "fastify";
3
+ export declare function forwardToGemini(req: OpenAIRequest, model: string, reply: FastifyReply, requestId?: string): Promise<{
4
+ id: any;
5
+ type: string;
6
+ role: string;
7
+ content: {
8
+ type: string;
9
+ text?: string;
10
+ id?: string;
11
+ name?: string;
12
+ input?: Record<string, unknown>;
13
+ }[];
14
+ model: string;
15
+ stop_reason: string;
16
+ stop_sequence: null;
17
+ usage: {
18
+ input_tokens: any;
19
+ output_tokens: any;
20
+ };
21
+ }>;
22
+ //# sourceMappingURL=gemini.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gemini.d.ts","sourceRoot":"","sources":["../../src/providers/gemini.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAe5C,wBAAsB,eAAe,CAAC,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,CAAC,EAAE,MAAM;;;;;;;;;;;;;;;;;;GAkC/G"}
@@ -0,0 +1,45 @@
1
+ import OpenAI from "openai";
2
+ import { config } from "../config.js";
3
+ import { convertNonStreaming, convertStream } from "../converter.js";
4
+ import { logVerbose } from "../logger.js";
5
+ let client = null;
6
+ function getClient() {
7
+ if (!client) {
8
+ client = new OpenAI({
9
+ apiKey: config.geminiApiKey,
10
+ baseURL: "https://generativelanguage.googleapis.com/v1beta/openai/",
11
+ });
12
+ }
13
+ return client;
14
+ }
15
+ export async function forwardToGemini(req, model, reply, requestId) {
16
+ const client = getClient();
17
+ // Gemini doesn't support top_p in the same way, strip it if 1
18
+ const cleanReq = { ...req };
19
+ if (cleanReq.top_p === 1)
20
+ delete cleanReq.top_p;
21
+ if (cleanReq.stream) {
22
+ reply.raw.setHeader("Content-Type", "text/event-stream");
23
+ reply.raw.setHeader("Cache-Control", "no-cache");
24
+ reply.raw.setHeader("Connection", "keep-alive");
25
+ const stream = await client.chat.completions.create({ ...cleanReq, stream: true });
26
+ async function* lines() {
27
+ for await (const chunk of stream) {
28
+ if (config.verbose >= 2 && requestId) {
29
+ logVerbose(requestId, "RESPONSE", chunk);
30
+ }
31
+ yield `data: ${JSON.stringify(chunk)}\n`;
32
+ }
33
+ yield "data: [DONE]\n";
34
+ }
35
+ const msgId = `msg_${Date.now()}`;
36
+ for await (const sseEvent of convertStream(lines(), model, msgId)) {
37
+ reply.raw.write(sseEvent);
38
+ }
39
+ reply.raw.end();
40
+ return reply;
41
+ }
42
+ const response = await client.chat.completions.create({ ...cleanReq, stream: false });
43
+ return convertNonStreaming(response, model);
44
+ }
45
+ //# sourceMappingURL=gemini.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gemini.js","sourceRoot":"","sources":["../../src/providers/gemini.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAGrE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,IAAI,MAAM,GAAkB,IAAI,CAAC;AAEjC,SAAS,SAAS;IAChB,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,GAAG,IAAI,MAAM,CAAC;YAClB,MAAM,EAAE,MAAM,CAAC,YAAY;YAC3B,OAAO,EAAE,0DAA0D;SACpE,CAAC,CAAC;IACL,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAkB,EAAE,KAAa,EAAE,KAAmB,EAAE,SAAkB;IAC9G,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,8DAA8D;IAC9D,MAAM,QAAQ,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;IAC5B,IAAI,QAAQ,CAAC,KAAK,KAAK,CAAC;QAAE,OAAO,QAAQ,CAAC,KAAK,CAAC;IAEhD,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;QACzD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACjD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAEhD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAS,CAAQ,CAAC;QAEjG,KAAK,SAAS,CAAC,CAAC,KAAK;YACnB,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBACjC,IAAI,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,SAAS,EAAE,CAAC;oBACrC,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;gBAC3C,CAAC;gBACD,MAAM,SAAS,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC;YAC3C,CAAC;YACD,MAAM,gBAAgB,CAAC;QACzB,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAClC,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC;YAClE,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC;QACD,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;QAChB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAS,CAAC,CAAC;IAC7F,OAAO,mBAAmB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { forwardToOpenAI } from "./openai.js";
2
+ export { forwardToGemini } from "./gemini.js";
3
+ export { forwardToOllama } from "./ollama.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,4 @@
1
+ export { forwardToOpenAI } from "./openai.js";
2
+ export { forwardToGemini } from "./gemini.js";
3
+ export { forwardToOllama } from "./ollama.js";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/providers/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC;AAC9C,OAAO,EAAE,eAAe,EAAE,MAAM,aAAa,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { OpenAIRequest } from "../types.js";
2
+ import type { FastifyReply } from "fastify";
3
+ export declare function forwardToOllama(req: OpenAIRequest, model: string, reply: FastifyReply, requestId?: string): Promise<{
4
+ id: any;
5
+ type: string;
6
+ role: string;
7
+ content: {
8
+ type: string;
9
+ text?: string;
10
+ id?: string;
11
+ name?: string;
12
+ input?: Record<string, unknown>;
13
+ }[];
14
+ model: string;
15
+ stop_reason: string;
16
+ stop_sequence: null;
17
+ usage: {
18
+ input_tokens: any;
19
+ output_tokens: any;
20
+ };
21
+ }>;
22
+ //# sourceMappingURL=ollama.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama.d.ts","sourceRoot":"","sources":["../../src/providers/ollama.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAe5C,wBAAsB,eAAe,CAAC,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,CAAC,EAAE,MAAM;;;;;;;;;;;;;;;;;;GAkC/G"}
@@ -0,0 +1,44 @@
1
+ import OpenAI from "openai";
2
+ import { config } from "../config.js";
3
+ import { convertNonStreaming, convertStream } from "../converter.js";
4
+ import { logVerbose } from "../logger.js";
5
+ let client = null;
6
+ function getClient() {
7
+ if (!client) {
8
+ client = new OpenAI({
9
+ apiKey: "ollama", // Ollama doesn't require a real key
10
+ baseURL: `${config.ollamaApiBase}/v1`,
11
+ });
12
+ }
13
+ return client;
14
+ }
15
+ export async function forwardToOllama(req, model, reply, requestId) {
16
+ const client = getClient();
17
+ const cleanReq = { ...req };
18
+ // IMP: Ollama doesn't support parallel_tool_calls — consider adding this to OpenAIRequest type instead of any-cast
19
+ delete cleanReq.parallel_tool_calls;
20
+ if (cleanReq.stream) {
21
+ reply.raw.setHeader("Content-Type", "text/event-stream");
22
+ reply.raw.setHeader("Cache-Control", "no-cache");
23
+ reply.raw.setHeader("Connection", "keep-alive");
24
+ const stream = await client.chat.completions.create({ ...cleanReq, stream: true });
25
+ async function* lines() {
26
+ for await (const chunk of stream) {
27
+ if (config.verbose >= 2 && requestId) {
28
+ logVerbose(requestId, "RESPONSE", chunk);
29
+ }
30
+ yield `data: ${JSON.stringify(chunk)}\n`;
31
+ }
32
+ yield "data: [DONE]\n";
33
+ }
34
+ const msgId = `msg_${Date.now()}`;
35
+ for await (const sseEvent of convertStream(lines(), model, msgId)) {
36
+ reply.raw.write(sseEvent);
37
+ }
38
+ reply.raw.end();
39
+ return reply;
40
+ }
41
+ const response = await client.chat.completions.create({ ...cleanReq, stream: false });
42
+ return convertNonStreaming(response, model);
43
+ }
44
+ //# sourceMappingURL=ollama.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ollama.js","sourceRoot":"","sources":["../../src/providers/ollama.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAGrE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,IAAI,MAAM,GAAkB,IAAI,CAAC;AAEjC,SAAS,SAAS;IAChB,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,GAAG,IAAI,MAAM,CAAC;YAClB,MAAM,EAAE,QAAQ,EAAE,oCAAoC;YACtD,OAAO,EAAE,GAAG,MAAM,CAAC,aAAa,KAAK;SACtC,CAAC,CAAC;IACL,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAkB,EAAE,KAAa,EAAE,KAAmB,EAAE,SAAkB;IAC9G,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,QAAQ,GAAG,EAAE,GAAG,GAAG,EAAE,CAAC;IAC5B,mHAAmH;IACnH,OAAQ,QAAgB,CAAC,mBAAmB,CAAC;IAE7C,IAAI,QAAQ,CAAC,MAAM,EAAE,CAAC;QACpB,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;QACzD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACjD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAEhD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,IAAI,EAAS,CAAQ,CAAC;QAEjG,KAAK,SAAS,CAAC,CAAC,KAAK;YACnB,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBACjC,IAAI,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,SAAS,EAAE,CAAC;oBACrC,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;gBAC3C,CAAC;gBACD,MAAM,SAAS,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC;YAC3C,CAAC;YACD,MAAM,gBAAgB,CAAC;QACzB,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAClC,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC;YAClE,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC;QACD,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;QAChB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAS,CAAC,CAAC;IAC7F,OAAO,mBAAmB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,22 @@
1
+ import type { OpenAIRequest } from "../types.js";
2
+ import type { FastifyReply } from "fastify";
3
+ export declare function forwardToOpenAI(req: OpenAIRequest, model: string, reply: FastifyReply, requestId?: string): Promise<{
4
+ id: any;
5
+ type: string;
6
+ role: string;
7
+ content: {
8
+ type: string;
9
+ text?: string;
10
+ id?: string;
11
+ name?: string;
12
+ input?: Record<string, unknown>;
13
+ }[];
14
+ model: string;
15
+ stop_reason: string;
16
+ stop_sequence: null;
17
+ usage: {
18
+ input_tokens: any;
19
+ output_tokens: any;
20
+ };
21
+ }>;
22
+ //# sourceMappingURL=openai.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.d.ts","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AACjD,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,SAAS,CAAC;AAY5C,wBAAsB,eAAe,CAAC,GAAG,EAAE,aAAa,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,YAAY,EAAE,SAAS,CAAC,EAAE,MAAM;;;;;;;;;;;;;;;;;;GA8B/G"}
@@ -0,0 +1,38 @@
1
+ import OpenAI from "openai";
2
+ import { config } from "../config.js";
3
+ import { convertNonStreaming, convertStream } from "../converter.js";
4
+ import { logVerbose } from "../logger.js";
5
+ let client = null;
6
+ function getClient() {
7
+ if (!client) {
8
+ client = new OpenAI({ apiKey: config.openaiApiKey });
9
+ }
10
+ return client;
11
+ }
12
+ export async function forwardToOpenAI(req, model, reply, requestId) {
13
+ const client = getClient();
14
+ if (req.stream) {
15
+ reply.raw.setHeader("Content-Type", "text/event-stream");
16
+ reply.raw.setHeader("Cache-Control", "no-cache");
17
+ reply.raw.setHeader("Connection", "keep-alive");
18
+ const stream = await client.chat.completions.create({ ...req, stream: true });
19
+ async function* lines() {
20
+ for await (const chunk of stream) {
21
+ if (config.verbose >= 2 && requestId) {
22
+ logVerbose(requestId, "RESPONSE", chunk);
23
+ }
24
+ yield `data: ${JSON.stringify(chunk)}\n`;
25
+ }
26
+ yield "data: [DONE]\n";
27
+ }
28
+ const msgId = `msg_${Date.now()}`;
29
+ for await (const sseEvent of convertStream(lines(), model, msgId)) {
30
+ reply.raw.write(sseEvent);
31
+ }
32
+ reply.raw.end();
33
+ return reply;
34
+ }
35
+ const response = await client.chat.completions.create({ ...req, stream: false });
36
+ return convertNonStreaming(response, model);
37
+ }
38
+ //# sourceMappingURL=openai.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openai.js","sourceRoot":"","sources":["../../src/providers/openai.ts"],"names":[],"mappings":"AAAA,OAAO,MAAM,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AACtC,OAAO,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAGrE,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,IAAI,MAAM,GAAkB,IAAI,CAAC;AAEjC,SAAS,SAAS;IAChB,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,MAAM,GAAG,IAAI,MAAM,CAAC,EAAE,MAAM,EAAE,MAAM,CAAC,YAAY,EAAE,CAAC,CAAC;IACvD,CAAC;IACD,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,eAAe,CAAC,GAAkB,EAAE,KAAa,EAAE,KAAmB,EAAE,SAAkB;IAC9G,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,IAAI,GAAG,CAAC,MAAM,EAAE,CAAC;QACf,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,cAAc,EAAE,mBAAmB,CAAC,CAAC;QACzD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,eAAe,EAAE,UAAU,CAAC,CAAC;QACjD,KAAK,CAAC,GAAG,CAAC,SAAS,CAAC,YAAY,EAAE,YAAY,CAAC,CAAC;QAEhD,MAAM,MAAM,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,EAAE,MAAM,EAAE,IAAI,EAAS,CAAQ,CAAC;QAE5F,KAAK,SAAS,CAAC,CAAC,KAAK;YACnB,IAAI,KAAK,EAAE,MAAM,KAAK,IAAI,MAAM,EAAE,CAAC;gBACjC,IAAI,MAAM,CAAC,OAAO,IAAI,CAAC,IAAI,SAAS,EAAE,CAAC;oBACrC,UAAU,CAAC,SAAS,EAAE,UAAU,EAAE,KAAK,CAAC,CAAC;gBAC3C,CAAC;gBACD,MAAM,SAAS,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,IAAI,CAAC;YAC3C,CAAC;YACD,MAAM,gBAAgB,CAAC;QACzB,CAAC;QAED,MAAM,KAAK,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC;QAClC,IAAI,KAAK,EAAE,MAAM,QAAQ,IAAI,aAAa,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC;YAClE,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC;QAC5B,CAAC;QACD,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC;QAChB,OAAO,KAAK,CAAC;IACf,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,EAAE,MAAM,EAAE,KAAK,EAAS,CAAC,CAAC;IACxF,OAAO,mBAAmB,CAAC,QAAQ,EAAE,KAAK,CAAC,CAAC;AAC9C,CAAC"}
@@ -0,0 +1,3 @@
1
+ #!/usr/bin/env node
2
+ export {};
3
+ //# sourceMappingURL=server.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.d.ts","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":""}
package/dist/server.js ADDED
@@ -0,0 +1,73 @@
1
+ #!/usr/bin/env node
2
+ import Fastify from "fastify";
3
+ import { config } from "./config.js";
4
+ import { translateRequest } from "./translator.js";
5
+ import { forwardToOpenAI, forwardToGemini, forwardToOllama } from "./providers/index.js";
6
+ import { logRequest, logVerbose, logRequestStart, logInfo } from "./logger.js";
7
+ import { randomBytes } from "node:crypto";
8
+ const fastify = Fastify({ logger: false });
9
+ function generateId() {
10
+ return randomBytes(4).toString("hex");
11
+ }
12
+ fastify.post("/v1/messages", async (request, reply) => {
13
+ const body = request.body;
14
+ const startTime = Date.now();
15
+ const requestId = generateId();
16
+ try {
17
+ const { provider, model, translatedRequest } = translateRequest(body);
18
+ logRequestStart(requestId, body.model, model, provider, body.messages?.length ?? 0, body.tools?.length ?? 0);
19
+ logInfo(requestId, `Forwarding to ${provider} as ${model}`);
20
+ if (config.verbose >= 2) {
21
+ logVerbose(requestId, "PROMPT", body);
22
+ }
23
+ let response;
24
+ if (provider === "openai") {
25
+ response = await forwardToOpenAI(translatedRequest, model, reply, requestId);
26
+ }
27
+ else if (provider === "gemini") {
28
+ response = await forwardToGemini(translatedRequest, model, reply, requestId);
29
+ }
30
+ else if (provider === "ollama") {
31
+ response = await forwardToOllama(translatedRequest, model, reply, requestId);
32
+ }
33
+ else {
34
+ reply.code(400).send({ error: `Unknown provider: ${provider}` });
35
+ return;
36
+ }
37
+ if (config.verbose >= 2 && !body.stream) {
38
+ logVerbose(requestId, "RESPONSE", response);
39
+ }
40
+ logInfo(requestId, "Request processed successfully");
41
+ logRequest(requestId, body.model, model, provider, body.messages?.length ?? 0, body.tools?.length ?? 0, reply.statusCode, Date.now() - startTime);
42
+ return response;
43
+ }
44
+ catch (err) {
45
+ console.error(`\n❌ Error processing request ${requestId}:`, err);
46
+ logRequest(requestId, body.model, "error", "unknown", body.messages?.length ?? 0, body.tools?.length ?? 0, 500, Date.now() - startTime);
47
+ reply.code(500).send({
48
+ type: "error",
49
+ error: { type: "server_error", message: err?.message ?? "Internal server error" },
50
+ });
51
+ }
52
+ });
53
+ fastify.get("/health", async () => ({ status: "ok" }));
54
+ const start = async () => {
55
+ try {
56
+ await fastify.listen({ port: config.port, host: "0.0.0.0" });
57
+ console.log(`\n🚀 claude-code-proxy running on http://localhost:${config.port}`);
58
+ console.log(` Provider : ${config.preferredProvider}`);
59
+ console.log(` Big model: ${config.bigModel}`);
60
+ console.log(` Small mdl: ${config.smallModel}`);
61
+ console.log(` Verbose : ${config.verbose}`);
62
+ if (config.preferredProvider === "ollama") {
63
+ console.log(` Ollama : ${config.ollamaApiBase}`);
64
+ }
65
+ console.log(`\n Use with: ANTHROPIC_BASE_URL=http://localhost:${config.port} claude\n`);
66
+ }
67
+ catch (err) {
68
+ fastify.log.error(err);
69
+ process.exit(1);
70
+ }
71
+ };
72
+ start();
73
+ //# sourceMappingURL=server.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server.js","sourceRoot":"","sources":["../src/server.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { AnthropicRequest, TranslatedRequest } from "./types.js";
2
+ export declare function translateRequest(req: AnthropicRequest): TranslatedRequest;
3
+ //# sourceMappingURL=translator.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"translator.d.ts","sourceRoot":"","sources":["../src/translator.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EACV,gBAAgB,EAQhB,iBAAiB,EAClB,MAAM,YAAY,CAAC;AAmJpB,wBAAgB,gBAAgB,CAAC,GAAG,EAAE,gBAAgB,GAAG,iBAAiB,CA2BzE"}
@@ -0,0 +1,155 @@
1
+ import { config } from "./config.js";
2
+ // Map Claude model names → big/small model based on provider
3
+ function resolveModel(claudeModel) {
4
+ const lc = claudeModel.toLowerCase();
5
+ // If the user explicitly passes a known model name, use it directly
6
+ if (config.isOpenAIModel(claudeModel))
7
+ return { provider: "openai", model: claudeModel };
8
+ if (config.isGeminiModel(claudeModel))
9
+ return { provider: "gemini", model: claudeModel };
10
+ if (config.isOllamaModel(claudeModel))
11
+ return { provider: "ollama", model: claudeModel };
12
+ // Map Claude haiku → small model, sonnet/opus → big model
13
+ const isSmall = lc.includes("haiku");
14
+ const targetModel = isSmall ? config.smallModel : config.bigModel;
15
+ const provider = config.resolveProvider(targetModel);
16
+ return { provider, model: targetModel };
17
+ }
18
+ function systemPromptToString(system) {
19
+ if (!system)
20
+ return undefined;
21
+ if (typeof system === "string")
22
+ return system;
23
+ return system.map((b) => b.text).join("\n");
24
+ }
25
+ function contentBlocksToOpenAI(content) {
26
+ if (typeof content === "string")
27
+ return content;
28
+ const parts = [];
29
+ for (const block of content) {
30
+ if (block.type === "text") {
31
+ parts.push({ type: "text", text: block.text });
32
+ }
33
+ else if (block.type === "image") {
34
+ const src = block.source;
35
+ const url = src.type === "base64"
36
+ ? `data:${src.media_type};base64,${src.data}`
37
+ : (src.url ?? "");
38
+ parts.push({ type: "image_url", image_url: { url } });
39
+ }
40
+ // tool_use and tool_result handled separately below
41
+ }
42
+ return parts.length > 0 ? parts : null;
43
+ }
44
+ function translateMessages(messages) {
45
+ const result = [];
46
+ for (const msg of messages) {
47
+ const content = msg.content;
48
+ if (typeof content === "string") {
49
+ result.push({ role: msg.role, content });
50
+ continue;
51
+ }
52
+ // Check if this assistant message contains tool_use blocks
53
+ const toolUseBlocks = content.filter((b) => b.type === "tool_use");
54
+ const textBlocks = content.filter((b) => b.type === "text");
55
+ if (msg.role === "assistant" && toolUseBlocks.length > 0) {
56
+ const toolCalls = toolUseBlocks.map((b) => {
57
+ if (b.type !== "tool_use")
58
+ throw new Error("unreachable");
59
+ return {
60
+ id: b.id,
61
+ type: "function",
62
+ function: {
63
+ name: b.name,
64
+ arguments: JSON.stringify(b.input),
65
+ },
66
+ };
67
+ });
68
+ const textContent = textBlocks.length > 0 ? textBlocks.map((b) => (b.type === "text" ? b.text : "")).join("") : null;
69
+ result.push({ role: "assistant", content: textContent, tool_calls: toolCalls });
70
+ continue;
71
+ }
72
+ // Check for tool_result blocks (user role)
73
+ const toolResultBlocks = content.filter((b) => b.type === "tool_result");
74
+ if (msg.role === "user" && toolResultBlocks.length > 0) {
75
+ for (const block of toolResultBlocks) {
76
+ if (block.type !== "tool_result")
77
+ continue;
78
+ const toolContent = typeof block.content === "string"
79
+ ? block.content
80
+ : Array.isArray(block.content)
81
+ ? block.content.map((b) => ("text" in b ? b.text : "")).join("")
82
+ : "";
83
+ result.push({
84
+ role: "tool",
85
+ tool_call_id: block.tool_use_id,
86
+ content: toolContent,
87
+ });
88
+ }
89
+ // Any non-tool_result content goes as a separate user message
90
+ const nonToolBlocks = content.filter((b) => b.type !== "tool_result");
91
+ if (nonToolBlocks.length > 0) {
92
+ const parts = contentBlocksToOpenAI(nonToolBlocks);
93
+ if (parts)
94
+ result.push({ role: "user", content: parts });
95
+ }
96
+ continue;
97
+ }
98
+ // Regular user/assistant message
99
+ const parts = contentBlocksToOpenAI(content);
100
+ if (parts !== null) {
101
+ result.push({ role: msg.role, content: parts });
102
+ }
103
+ }
104
+ return result;
105
+ }
106
+ function translateTools(tools) {
107
+ if (!tools || tools.length === 0)
108
+ return undefined;
109
+ return tools.map((t) => ({
110
+ type: "function",
111
+ function: {
112
+ name: t.name,
113
+ description: t.description,
114
+ parameters: t.input_schema,
115
+ },
116
+ }));
117
+ }
118
+ function translateToolChoice(toolChoice) {
119
+ if (!toolChoice)
120
+ return undefined;
121
+ if (toolChoice.type === "auto")
122
+ return "auto";
123
+ if (toolChoice.type === "any")
124
+ return "required";
125
+ if (toolChoice.type === "tool" && toolChoice.name) {
126
+ return { type: "function", function: { name: toolChoice.name } };
127
+ }
128
+ return undefined;
129
+ }
130
+ export function translateRequest(req) {
131
+ const { provider, model } = resolveModel(req.model);
132
+ const systemContent = systemPromptToString(req.system);
133
+ const messages = translateMessages(req.messages);
134
+ if (systemContent) {
135
+ messages.unshift({ role: "system", content: systemContent });
136
+ }
137
+ const openAIReq = {
138
+ model,
139
+ messages,
140
+ max_tokens: req.max_tokens,
141
+ temperature: req.temperature,
142
+ top_p: req.top_p,
143
+ stream: req.stream,
144
+ tools: translateTools(req.tools),
145
+ tool_choice: translateToolChoice(req.tool_choice),
146
+ stop: req.stop_sequences,
147
+ };
148
+ // Remove undefined keys
149
+ Object.keys(openAIReq).forEach((k) => {
150
+ if (openAIReq[k] === undefined)
151
+ delete openAIReq[k];
152
+ });
153
+ return { provider, model, translatedRequest: openAIReq };
154
+ }
155
+ //# sourceMappingURL=translator.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"translator.js","sourceRoot":"","sources":["../src/translator.ts"],"names":[],"mappings":"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"}