@kaitranntt/ccs 7.71.0-dev.7 → 7.71.0-dev.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +34 -0
- package/dist/ccs.js +31 -0
- package/dist/ccs.js.map +1 -1
- package/dist/commands/command-catalog.d.ts +1 -0
- package/dist/commands/command-catalog.d.ts.map +1 -1
- package/dist/commands/command-catalog.js +8 -1
- package/dist/commands/command-catalog.js.map +1 -1
- package/dist/commands/completion-backend.d.ts.map +1 -1
- package/dist/commands/completion-backend.js +4 -0
- package/dist/commands/completion-backend.js.map +1 -1
- package/dist/commands/help-command.d.ts.map +1 -1
- package/dist/commands/help-command.js +2 -0
- package/dist/commands/help-command.js.map +1 -1
- package/dist/commands/index.d.ts +1 -0
- package/dist/commands/index.d.ts.map +1 -1
- package/dist/commands/index.js +3 -1
- package/dist/commands/index.js.map +1 -1
- package/dist/commands/proxy-command.d.ts +2 -0
- package/dist/commands/proxy-command.d.ts.map +1 -0
- package/dist/commands/proxy-command.js +156 -0
- package/dist/commands/proxy-command.js.map +1 -0
- package/dist/commands/root-command-router.d.ts.map +1 -1
- package/dist/commands/root-command-router.js +7 -0
- package/dist/commands/root-command-router.js.map +1 -1
- package/dist/config/reserved-names.d.ts +1 -1
- package/dist/config/reserved-names.d.ts.map +1 -1
- package/dist/config/reserved-names.js +1 -0
- package/dist/config/reserved-names.js.map +1 -1
- package/dist/config/unified-config-loader.d.ts.map +1 -1
- package/dist/config/unified-config-loader.js +19 -0
- package/dist/config/unified-config-loader.js.map +1 -1
- package/dist/config/unified-config-types.d.ts +14 -0
- package/dist/config/unified-config-types.d.ts.map +1 -1
- package/dist/config/unified-config-types.js +11 -1
- package/dist/config/unified-config-types.js.map +1 -1
- package/dist/cursor/cursor-anthropic-response.d.ts +1 -6
- package/dist/cursor/cursor-anthropic-response.d.ts.map +1 -1
- package/dist/cursor/cursor-anthropic-response.js +3 -186
- package/dist/cursor/cursor-anthropic-response.js.map +1 -1
- package/dist/glmt/sse-parser.d.ts.map +1 -1
- package/dist/glmt/sse-parser.js +46 -41
- package/dist/glmt/sse-parser.js.map +1 -1
- package/dist/proxy/index.d.ts +8 -0
- package/dist/proxy/index.d.ts.map +1 -0
- package/dist/proxy/index.js +24 -0
- package/dist/proxy/index.js.map +1 -0
- package/dist/proxy/profile-router.d.ts +28 -0
- package/dist/proxy/profile-router.d.ts.map +1 -0
- package/dist/proxy/profile-router.js +43 -0
- package/dist/proxy/profile-router.js.map +1 -0
- package/dist/proxy/proxy-daemon-entry.d.ts +2 -0
- package/dist/proxy/proxy-daemon-entry.d.ts.map +1 -0
- package/dist/proxy/proxy-daemon-entry.js +68 -0
- package/dist/proxy/proxy-daemon-entry.js.map +1 -0
- package/dist/proxy/proxy-daemon-paths.d.ts +6 -0
- package/dist/proxy/proxy-daemon-paths.d.ts.map +1 -0
- package/dist/proxy/proxy-daemon-paths.js +43 -0
- package/dist/proxy/proxy-daemon-paths.js.map +1 -0
- package/dist/proxy/proxy-daemon-state.d.ts +18 -0
- package/dist/proxy/proxy-daemon-state.d.ts.map +1 -0
- package/dist/proxy/proxy-daemon-state.js +92 -0
- package/dist/proxy/proxy-daemon-state.js.map +1 -0
- package/dist/proxy/proxy-daemon.d.ts +26 -0
- package/dist/proxy/proxy-daemon.d.ts.map +1 -0
- package/dist/proxy/proxy-daemon.js +350 -0
- package/dist/proxy/proxy-daemon.js.map +1 -0
- package/dist/proxy/proxy-env.d.ts +3 -0
- package/dist/proxy/proxy-env.d.ts.map +1 -0
- package/dist/proxy/proxy-env.js +26 -0
- package/dist/proxy/proxy-env.js.map +1 -0
- package/dist/proxy/request-router.d.ts +12 -0
- package/dist/proxy/request-router.d.ts.map +1 -0
- package/dist/proxy/request-router.js +163 -0
- package/dist/proxy/request-router.js.map +1 -0
- package/dist/proxy/routing-config.d.ts +10 -0
- package/dist/proxy/routing-config.d.ts.map +1 -0
- package/dist/proxy/routing-config.js +79 -0
- package/dist/proxy/routing-config.js.map +1 -0
- package/dist/proxy/server/http-helpers.d.ts +8 -0
- package/dist/proxy/server/http-helpers.d.ts.map +1 -0
- package/dist/proxy/server/http-helpers.js +73 -0
- package/dist/proxy/server/http-helpers.js.map +1 -0
- package/dist/proxy/server/messages-route.d.ts +12 -0
- package/dist/proxy/server/messages-route.d.ts.map +1 -0
- package/dist/proxy/server/messages-route.js +208 -0
- package/dist/proxy/server/messages-route.js.map +1 -0
- package/dist/proxy/server/proxy-server.d.ts +12 -0
- package/dist/proxy/server/proxy-server.d.ts.map +1 -0
- package/dist/proxy/server/proxy-server.js +110 -0
- package/dist/proxy/server/proxy-server.js.map +1 -0
- package/dist/proxy/transformers/request-transformer.d.ts +52 -0
- package/dist/proxy/transformers/request-transformer.d.ts.map +1 -0
- package/dist/proxy/transformers/request-transformer.js +254 -0
- package/dist/proxy/transformers/request-transformer.js.map +1 -0
- package/dist/proxy/transformers/sse-stream-transformer.d.ts +11 -0
- package/dist/proxy/transformers/sse-stream-transformer.d.ts.map +1 -0
- package/dist/proxy/transformers/sse-stream-transformer.js +199 -0
- package/dist/proxy/transformers/sse-stream-transformer.js.map +1 -0
- package/dist/proxy/upstream-url.d.ts +3 -0
- package/dist/proxy/upstream-url.d.ts.map +1 -0
- package/dist/proxy/upstream-url.js +35 -0
- package/dist/proxy/upstream-url.js.map +1 -0
- package/dist/targets/droid-provider.d.ts.map +1 -1
- package/dist/targets/droid-provider.js +2 -0
- package/dist/targets/droid-provider.js.map +1 -1
- package/dist/types/config.d.ts +13 -0
- package/dist/types/config.d.ts.map +1 -1
- package/dist/types/config.js.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js.map +1 -1
- package/dist/web-server/routes/config-routes.d.ts.map +1 -1
- package/dist/web-server/routes/config-routes.js +3 -0
- package/dist/web-server/routes/config-routes.js.map +1 -1
- package/package.json +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"unified-config-types.js","sourceRoot":"","sources":["../../src/config/unified-config-types.ts"],"names":[],"mappings":";AAAA;;;;;;;;;GASG;;;AAIH,6EAA0E;AAE1E;;;;;;;;;;;;;GAaG;AACU,QAAA,sBAAsB,GAAG,EAAE,CAAC;AAEzC;;;GAGG;AACU,QAAA,4BAA4B,GAAG,6CAAqB,CAAC;AAgJlE;;GAEG;AACU,QAAA,8BAA8B,GAAyB;IAClE,sBAAsB,EAAE,KAAK;CAC9B,CAAC;AAyEW,QAAA,sBAAsB,GAAkB;IACnD,OAAO,EAAE,IAAI;IACb,KAAK,EAAE,MAAM;IACb,SAAS,EAAE,EAAE;IACb,WAAW,EAAE,CAAC;IACd,MAAM,EAAE,IAAI;IACZ,gBAAgB,EAAE,GAAG;CACtB,CAAC;
|
|
1
|
+
{"version":3,"file":"unified-config-types.js","sourceRoot":"","sources":["../../src/config/unified-config-types.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,2 @@
|
|
|
1
|
-
|
|
2
|
-
/// <reference types="node" />
|
|
3
|
-
type ResponseHeaders = Headers | Record<string, string> | Array<[string, string]>;
|
|
4
|
-
export declare function createAnthropicErrorResponse(status: number, type: string, message: string, headers?: ResponseHeaders): Response;
|
|
5
|
-
export declare function createAnthropicProxyResponse(response: Response): Promise<Response>;
|
|
6
|
-
export {};
|
|
1
|
+
export { createAnthropicErrorResponse, createAnthropicProxyResponse, } from '../proxy/transformers/sse-stream-transformer';
|
|
7
2
|
//# sourceMappingURL=cursor-anthropic-response.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cursor-anthropic-response.d.ts","sourceRoot":"","sources":["../../src/cursor/cursor-anthropic-response.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"cursor-anthropic-response.d.ts","sourceRoot":"","sources":["../../src/cursor/cursor-anthropic-response.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,4BAA4B,EAC5B,4BAA4B,GAC7B,MAAM,8CAA8C,CAAC"}
|
|
@@ -1,190 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.createAnthropicProxyResponse = exports.createAnthropicErrorResponse = void 0;
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
const JSON_TRANSLATION_ERROR_MESSAGE = 'Failed to translate Cursor JSON response';
|
|
8
|
-
const STREAM_TRANSLATION_ERROR_MESSAGE = 'Failed to translate Cursor SSE response';
|
|
9
|
-
function createAnthropicErrorPayload(type, message) {
|
|
10
|
-
return {
|
|
11
|
-
type: 'error',
|
|
12
|
-
error: {
|
|
13
|
-
type,
|
|
14
|
-
message,
|
|
15
|
-
},
|
|
16
|
-
};
|
|
17
|
-
}
|
|
18
|
-
function formatErrorForLog(error) {
|
|
19
|
-
if (error instanceof Error) {
|
|
20
|
-
return error.message;
|
|
21
|
-
}
|
|
22
|
-
try {
|
|
23
|
-
return JSON.stringify(error);
|
|
24
|
-
}
|
|
25
|
-
catch {
|
|
26
|
-
return String(error);
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
function logTranslationError(context, error) {
|
|
30
|
-
console.error(`[cursor-anthropic-response] ${context}: ${formatErrorForLog(error)}`);
|
|
31
|
-
}
|
|
32
|
-
function createAnthropicErrorResponse(status, type, message, headers) {
|
|
33
|
-
const responseHeaders = new Headers(headers);
|
|
34
|
-
responseHeaders.set('Content-Type', 'application/json');
|
|
35
|
-
responseHeaders.delete('Content-Length');
|
|
36
|
-
return new Response(JSON.stringify(createAnthropicErrorPayload(type, message)), {
|
|
37
|
-
status,
|
|
38
|
-
headers: responseHeaders,
|
|
39
|
-
});
|
|
40
|
-
}
|
|
41
|
-
exports.createAnthropicErrorResponse = createAnthropicErrorResponse;
|
|
42
|
-
function formatSseEvent(event, data) {
|
|
43
|
-
return `event: ${event}\ndata: ${JSON.stringify(data)}\n\n`;
|
|
44
|
-
}
|
|
45
|
-
function hasTranslatableChoices(value) {
|
|
46
|
-
if (typeof value !== 'object' || value === null) {
|
|
47
|
-
return false;
|
|
48
|
-
}
|
|
49
|
-
const { choices } = value;
|
|
50
|
-
if (!Array.isArray(choices) || choices.length === 0) {
|
|
51
|
-
return false;
|
|
52
|
-
}
|
|
53
|
-
const firstChoice = choices[0];
|
|
54
|
-
if (typeof firstChoice !== 'object' || firstChoice === null) {
|
|
55
|
-
return false;
|
|
56
|
-
}
|
|
57
|
-
const message = firstChoice.message;
|
|
58
|
-
return typeof message === 'object' && message !== null;
|
|
59
|
-
}
|
|
60
|
-
function isSyntheticTransformationFallback(value) {
|
|
61
|
-
return (typeof value === 'object' &&
|
|
62
|
-
value !== null &&
|
|
63
|
-
typeof value.id === 'string' &&
|
|
64
|
-
value.id.startsWith('msg_error_'));
|
|
65
|
-
}
|
|
66
|
-
async function createAnthropicErrorProxyResponse(response) {
|
|
67
|
-
const headers = new Headers(response.headers);
|
|
68
|
-
headers.delete('Content-Type');
|
|
69
|
-
headers.delete('Content-Length');
|
|
70
|
-
let type = response.status === 401
|
|
71
|
-
? 'authentication_error'
|
|
72
|
-
: response.status === 429
|
|
73
|
-
? 'rate_limit_error'
|
|
74
|
-
: response.status >= 400 && response.status < 500
|
|
75
|
-
? 'invalid_request_error'
|
|
76
|
-
: 'api_error';
|
|
77
|
-
let message = `Cursor request failed with status ${response.status}`;
|
|
78
|
-
try {
|
|
79
|
-
const contentType = (response.headers.get('content-type') || '').toLowerCase();
|
|
80
|
-
if (contentType.includes('application/json')) {
|
|
81
|
-
const payload = (await response.json());
|
|
82
|
-
if (typeof payload?.error?.type === 'string' && payload.error.type.trim().length > 0) {
|
|
83
|
-
type = payload.error.type;
|
|
84
|
-
}
|
|
85
|
-
if (typeof payload?.error?.message === 'string' && payload.error.message.trim().length > 0) {
|
|
86
|
-
message = payload.error.message;
|
|
87
|
-
}
|
|
88
|
-
else if (typeof payload?.message === 'string' && payload.message.trim().length > 0) {
|
|
89
|
-
message = payload.message;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
else {
|
|
93
|
-
const text = (await response.text()).trim();
|
|
94
|
-
if (text.length > 0) {
|
|
95
|
-
message = text;
|
|
96
|
-
}
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
catch (error) {
|
|
100
|
-
logTranslationError('Failed to parse Cursor error response', error);
|
|
101
|
-
}
|
|
102
|
-
return createAnthropicErrorResponse(response.status, type, message, headers);
|
|
103
|
-
}
|
|
104
|
-
async function createAnthropicJsonResponse(response) {
|
|
105
|
-
try {
|
|
106
|
-
const openAiResponse = await response.json();
|
|
107
|
-
if (!hasTranslatableChoices(openAiResponse)) {
|
|
108
|
-
return createAnthropicErrorResponse(502, 'api_error', JSON_TRANSLATION_ERROR_MESSAGE);
|
|
109
|
-
}
|
|
110
|
-
const anthropicResponse = new glmt_transformer_1.GlmtTransformer().transformResponse(openAiResponse);
|
|
111
|
-
if (isSyntheticTransformationFallback(anthropicResponse)) {
|
|
112
|
-
logTranslationError('Cursor JSON translation produced synthetic fallback response', anthropicResponse);
|
|
113
|
-
return createAnthropicErrorResponse(502, 'api_error', JSON_TRANSLATION_ERROR_MESSAGE);
|
|
114
|
-
}
|
|
115
|
-
return new Response(JSON.stringify(anthropicResponse), {
|
|
116
|
-
status: response.status,
|
|
117
|
-
headers: { 'Content-Type': 'application/json' },
|
|
118
|
-
});
|
|
119
|
-
}
|
|
120
|
-
catch (error) {
|
|
121
|
-
logTranslationError('Cursor JSON translation failed', error);
|
|
122
|
-
return createAnthropicErrorResponse(502, 'api_error', JSON_TRANSLATION_ERROR_MESSAGE);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
function createAnthropicStreamingResponse(response) {
|
|
126
|
-
const body = response.body;
|
|
127
|
-
if (!body) {
|
|
128
|
-
return createAnthropicErrorResponse(502, 'api_error', 'Cursor stream ended before a response body was available');
|
|
129
|
-
}
|
|
130
|
-
const parser = new sse_parser_1.SSEParser({ throwOnMalformedJson: true });
|
|
131
|
-
const transformer = new glmt_transformer_1.GlmtTransformer();
|
|
132
|
-
const accumulator = new delta_accumulator_1.DeltaAccumulator({});
|
|
133
|
-
const encoder = new TextEncoder();
|
|
134
|
-
const readable = new ReadableStream({
|
|
135
|
-
async start(controller) {
|
|
136
|
-
const reader = body.getReader();
|
|
137
|
-
try {
|
|
138
|
-
while (true) {
|
|
139
|
-
const { done, value } = await reader.read();
|
|
140
|
-
if (done) {
|
|
141
|
-
break;
|
|
142
|
-
}
|
|
143
|
-
if (!value) {
|
|
144
|
-
continue;
|
|
145
|
-
}
|
|
146
|
-
const events = parser.parse(Buffer.from(value));
|
|
147
|
-
events.forEach((event) => {
|
|
148
|
-
const anthropicEvents = transformer.transformDelta(event, accumulator);
|
|
149
|
-
anthropicEvents.forEach((anthropicEvent) => {
|
|
150
|
-
controller.enqueue(encoder.encode(formatSseEvent(anthropicEvent.event, anthropicEvent.data)));
|
|
151
|
-
});
|
|
152
|
-
});
|
|
153
|
-
}
|
|
154
|
-
if (!accumulator.isFinalized() && accumulator.isMessageStarted()) {
|
|
155
|
-
transformer.finalizeDelta(accumulator).forEach((anthropicEvent) => {
|
|
156
|
-
controller.enqueue(encoder.encode(formatSseEvent(anthropicEvent.event, anthropicEvent.data)));
|
|
157
|
-
});
|
|
158
|
-
}
|
|
159
|
-
}
|
|
160
|
-
catch (error) {
|
|
161
|
-
logTranslationError('Cursor SSE translation failed', error);
|
|
162
|
-
controller.enqueue(encoder.encode(formatSseEvent('error', createAnthropicErrorPayload('api_error', STREAM_TRANSLATION_ERROR_MESSAGE))));
|
|
163
|
-
}
|
|
164
|
-
finally {
|
|
165
|
-
reader.releaseLock();
|
|
166
|
-
controller.close();
|
|
167
|
-
}
|
|
168
|
-
},
|
|
169
|
-
});
|
|
170
|
-
return new Response(readable, {
|
|
171
|
-
status: response.status,
|
|
172
|
-
headers: {
|
|
173
|
-
'Content-Type': 'text/event-stream',
|
|
174
|
-
'Cache-Control': 'no-cache',
|
|
175
|
-
Connection: 'keep-alive',
|
|
176
|
-
},
|
|
177
|
-
});
|
|
178
|
-
}
|
|
179
|
-
async function createAnthropicProxyResponse(response) {
|
|
180
|
-
if (!response.ok) {
|
|
181
|
-
return createAnthropicErrorProxyResponse(response);
|
|
182
|
-
}
|
|
183
|
-
const contentType = (response.headers.get('content-type') || '').toLowerCase();
|
|
184
|
-
const isEventStream = contentType === 'text/event-stream' || contentType.startsWith('text/event-stream;');
|
|
185
|
-
return isEventStream
|
|
186
|
-
? createAnthropicStreamingResponse(response)
|
|
187
|
-
: createAnthropicJsonResponse(response);
|
|
188
|
-
}
|
|
189
|
-
exports.createAnthropicProxyResponse = createAnthropicProxyResponse;
|
|
4
|
+
var sse_stream_transformer_1 = require("../proxy/transformers/sse-stream-transformer");
|
|
5
|
+
Object.defineProperty(exports, "createAnthropicErrorResponse", { enumerable: true, get: function () { return sse_stream_transformer_1.createAnthropicErrorResponse; } });
|
|
6
|
+
Object.defineProperty(exports, "createAnthropicProxyResponse", { enumerable: true, get: function () { return sse_stream_transformer_1.createAnthropicProxyResponse; } });
|
|
190
7
|
//# sourceMappingURL=cursor-anthropic-response.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cursor-anthropic-response.js","sourceRoot":"","sources":["../../src/cursor/cursor-anthropic-response.ts"],"names":[],"mappings":";;;AAAA,
|
|
1
|
+
{"version":3,"file":"cursor-anthropic-response.js","sourceRoot":"","sources":["../../src/cursor/cursor-anthropic-response.ts"],"names":[],"mappings":";;;AAAA,uFAGsD;AAFpD,sIAAA,4BAA4B,OAAA;AAC5B,sIAAA,4BAA4B,OAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse-parser.d.ts","sourceRoot":"","sources":["../../src/glmt/sse-parser.ts"],"names":[],"mappings":";AAEA;;;;;;;;;;;;;;;GAeG;;;AAEH,UAAU,gBAAgB;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAED,UAAU,QAAQ;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,oBAAoB,CAAU;gBAE1B,OAAO,GAAE,gBAAqB;IAO1C;;;;OAIG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,QAAQ,EAAE;
|
|
1
|
+
{"version":3,"file":"sse-parser.d.ts","sourceRoot":"","sources":["../../src/glmt/sse-parser.ts"],"names":[],"mappings":";AAEA;;;;;;;;;;;;;;;GAeG;;;AAEH,UAAU,gBAAgB;IACxB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,oBAAoB,CAAC,EAAE,OAAO,CAAC;CAChC;AAED,UAAU,QAAQ;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,EAAE,OAAO,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,SAAS;IACpB,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,aAAa,CAAS;IAC9B,OAAO,CAAC,oBAAoB,CAAU;gBAE1B,OAAO,GAAE,gBAAqB;IAO1C;;;;OAIG;IACH,KAAK,CAAC,KAAK,EAAE,MAAM,GAAG,MAAM,GAAG,QAAQ,EAAE;IAyEzC;;OAEG;IACH,KAAK,IAAI,IAAI;CAId"}
|
package/dist/glmt/sse-parser.js
CHANGED
|
@@ -31,57 +31,62 @@ class SSEParser {
|
|
|
31
31
|
* @returns Array of parsed events
|
|
32
32
|
*/
|
|
33
33
|
parse(chunk) {
|
|
34
|
-
this.buffer += chunk.toString();
|
|
34
|
+
this.buffer += chunk.toString().replace(/\r\n?/g, '\n');
|
|
35
35
|
// C-01 Fix: Prevent unbounded buffer growth (DoS protection)
|
|
36
36
|
if (this.buffer.length > this.maxBufferSize) {
|
|
37
37
|
throw new Error(`SSE buffer exceeded ${this.maxBufferSize} bytes (DoS protection)`);
|
|
38
38
|
}
|
|
39
|
-
const lines = this.buffer.split('\n');
|
|
40
|
-
// Keep incomplete line in buffer
|
|
41
|
-
this.buffer = lines.pop() || '';
|
|
42
39
|
const events = [];
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
}
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
40
|
+
const segments = this.buffer.split('\n\n');
|
|
41
|
+
this.buffer = segments.pop() || '';
|
|
42
|
+
for (const segment of segments) {
|
|
43
|
+
const lines = segment.split('\n');
|
|
44
|
+
const currentEvent = { event: 'message', data: '' };
|
|
45
|
+
const dataLines = [];
|
|
46
|
+
for (const rawLine of lines) {
|
|
47
|
+
const line = rawLine.trimEnd();
|
|
48
|
+
if (!line || line.startsWith(':')) {
|
|
49
|
+
continue;
|
|
50
|
+
}
|
|
51
|
+
if (line.startsWith('event: ')) {
|
|
52
|
+
currentEvent.event = line.substring(7).trim();
|
|
53
|
+
continue;
|
|
54
|
+
}
|
|
55
|
+
if (line.startsWith('data:')) {
|
|
56
|
+
dataLines.push(line.substring(5).trimStart());
|
|
57
|
+
continue;
|
|
58
|
+
}
|
|
59
|
+
if (line.startsWith('id: ')) {
|
|
60
|
+
currentEvent.id = line.substring(4).trim();
|
|
61
|
+
continue;
|
|
58
62
|
}
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
currentEvent.data = JSON.parse(data);
|
|
62
|
-
this.eventCount++;
|
|
63
|
-
currentEvent.index = this.eventCount;
|
|
64
|
-
events.push({ ...currentEvent });
|
|
65
|
-
currentEvent = { event: 'message', data: '' };
|
|
66
|
-
}
|
|
67
|
-
catch (e) {
|
|
68
|
-
// H-01 Fix: Log parse errors for debugging
|
|
69
|
-
if (typeof console !== 'undefined' && console.error) {
|
|
70
|
-
console.error('[SSEParser] Malformed JSON event:', e.message, 'Data:', data.substring(0, 100));
|
|
71
|
-
}
|
|
72
|
-
if (this.throwOnMalformedJson) {
|
|
73
|
-
throw new Error(`Malformed SSE JSON event: ${e.message}`);
|
|
74
|
-
}
|
|
75
|
-
}
|
|
63
|
+
if (line.startsWith('retry: ')) {
|
|
64
|
+
currentEvent.retry = parseInt(line.substring(7), 10);
|
|
76
65
|
}
|
|
77
66
|
}
|
|
78
|
-
|
|
79
|
-
|
|
67
|
+
const data = dataLines.join('\n');
|
|
68
|
+
if (!data) {
|
|
69
|
+
continue;
|
|
80
70
|
}
|
|
81
|
-
|
|
82
|
-
|
|
71
|
+
if (data === '[DONE]') {
|
|
72
|
+
this.eventCount++;
|
|
73
|
+
events.push({ event: 'done', data: null, index: this.eventCount });
|
|
74
|
+
continue;
|
|
75
|
+
}
|
|
76
|
+
try {
|
|
77
|
+
currentEvent.data = JSON.parse(data);
|
|
78
|
+
this.eventCount++;
|
|
79
|
+
currentEvent.index = this.eventCount;
|
|
80
|
+
events.push({ ...currentEvent });
|
|
81
|
+
}
|
|
82
|
+
catch (e) {
|
|
83
|
+
if (typeof console !== 'undefined' && console.error) {
|
|
84
|
+
console.error('[SSEParser] Malformed JSON event:', e.message, 'Data:', data.substring(0, 100));
|
|
85
|
+
}
|
|
86
|
+
if (this.throwOnMalformedJson) {
|
|
87
|
+
throw new Error(`Malformed SSE JSON event: ${e.message}`);
|
|
88
|
+
}
|
|
83
89
|
}
|
|
84
|
-
// Empty lines separate events (already handled by JSON parsing)
|
|
85
90
|
}
|
|
86
91
|
return events;
|
|
87
92
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"sse-parser.js","sourceRoot":"","sources":["../../src/glmt/sse-parser.ts"],"names":[],"mappings":";;AAEA;;;;;;;;;;;;;;;GAeG;;;AAeH,MAAa,SAAS;IAMpB,YAAY,UAA4B,EAAE;QACxC,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;QACpB,IAAI,CAAC,aAAa,GAAG,OAAO,CAAC,aAAa,IAAI,IAAI,GAAG,IAAI,CAAC,CAAC,cAAc;QACzE,IAAI,CAAC,oBAAoB,GAAG,OAAO,CAAC,oBAAoB,KAAK,IAAI,CAAC;IACpE,CAAC;IAED;;;;OAIG;IACH,KAAK,CAAC,KAAsB;QAC1B,IAAI,CAAC,MAAM,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;
|
|
1
|
+
{"version":3,"file":"sse-parser.js","sourceRoot":"","sources":["../../src/glmt/sse-parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
export * from './profile-router';
|
|
2
|
+
export * from './proxy-daemon';
|
|
3
|
+
export * from './proxy-daemon-paths';
|
|
4
|
+
export * from './proxy-env';
|
|
5
|
+
export * from './upstream-url';
|
|
6
|
+
export * from './transformers/request-transformer';
|
|
7
|
+
export * from './transformers/sse-stream-transformer';
|
|
8
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,sBAAsB,CAAC;AACrC,cAAc,aAAa,CAAC;AAC5B,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oCAAoC,CAAC;AACnD,cAAc,uCAAuC,CAAC"}
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
14
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
15
|
+
};
|
|
16
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
17
|
+
__exportStar(require("./profile-router"), exports);
|
|
18
|
+
__exportStar(require("./proxy-daemon"), exports);
|
|
19
|
+
__exportStar(require("./proxy-daemon-paths"), exports);
|
|
20
|
+
__exportStar(require("./proxy-env"), exports);
|
|
21
|
+
__exportStar(require("./upstream-url"), exports);
|
|
22
|
+
__exportStar(require("./transformers/request-transformer"), exports);
|
|
23
|
+
__exportStar(require("./transformers/sse-stream-transformer"), exports);
|
|
24
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/proxy/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,mDAAiC;AACjC,iDAA+B;AAC/B,uDAAqC;AACrC,8CAA4B;AAC5B,iDAA+B;AAC/B,qEAAmD;AACnD,wEAAsD"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { type DroidProvider } from '../targets/droid-provider';
|
|
2
|
+
export interface OpenAICompatProfileConfig {
|
|
3
|
+
profileName: string;
|
|
4
|
+
settingsPath: string;
|
|
5
|
+
baseUrl: string;
|
|
6
|
+
apiKey: string;
|
|
7
|
+
provider: DroidProvider;
|
|
8
|
+
insecure?: boolean;
|
|
9
|
+
model?: string;
|
|
10
|
+
opusModel?: string;
|
|
11
|
+
sonnetModel?: string;
|
|
12
|
+
haikuModel?: string;
|
|
13
|
+
}
|
|
14
|
+
export interface OpenAICompatProfileEnv {
|
|
15
|
+
ANTHROPIC_BASE_URL?: string;
|
|
16
|
+
ANTHROPIC_AUTH_TOKEN?: string;
|
|
17
|
+
ANTHROPIC_API_KEY?: string;
|
|
18
|
+
ANTHROPIC_MODEL?: string;
|
|
19
|
+
ANTHROPIC_DEFAULT_OPUS_MODEL?: string;
|
|
20
|
+
ANTHROPIC_DEFAULT_SONNET_MODEL?: string;
|
|
21
|
+
ANTHROPIC_DEFAULT_HAIKU_MODEL?: string;
|
|
22
|
+
ANTHROPIC_SMALL_FAST_MODEL?: string;
|
|
23
|
+
CCS_DROID_PROVIDER?: string;
|
|
24
|
+
CCS_OPENAI_PROXY_INSECURE?: string;
|
|
25
|
+
}
|
|
26
|
+
export declare function isOpenAICompatProvider(provider: DroidProvider | null): provider is DroidProvider;
|
|
27
|
+
export declare function resolveOpenAICompatProfileConfig(profileName: string, settingsPath: string, env: OpenAICompatProfileEnv): OpenAICompatProfileConfig | null;
|
|
28
|
+
//# sourceMappingURL=profile-router.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile-router.d.ts","sourceRoot":"","sources":["../../src/proxy/profile-router.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,aAAa,EACnB,MAAM,2BAA2B,CAAC;AAEnC,MAAM,WAAW,yBAAyB;IACxC,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,aAAa,CAAC;IACxB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB;AAED,MAAM,WAAW,sBAAsB;IACrC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,4BAA4B,CAAC,EAAE,MAAM,CAAC;IACtC,8BAA8B,CAAC,EAAE,MAAM,CAAC;IACxC,6BAA6B,CAAC,EAAE,MAAM,CAAC;IACvC,0BAA0B,CAAC,EAAE,MAAM,CAAC;IACpC,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAC5B,yBAAyB,CAAC,EAAE,MAAM,CAAC;CACpC;AAED,wBAAgB,sBAAsB,CAAC,QAAQ,EAAE,aAAa,GAAG,IAAI,GAAG,QAAQ,IAAI,aAAa,CAEhG;AAED,wBAAgB,gCAAgC,CAC9C,WAAW,EAAE,MAAM,EACnB,YAAY,EAAE,MAAM,EACpB,GAAG,EAAE,sBAAsB,GAC1B,yBAAyB,GAAG,IAAI,CAoClC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.resolveOpenAICompatProfileConfig = exports.isOpenAICompatProvider = void 0;
|
|
4
|
+
const droid_provider_1 = require("../targets/droid-provider");
|
|
5
|
+
function isOpenAICompatProvider(provider) {
|
|
6
|
+
return provider === 'openai' || provider === 'generic-chat-completion-api';
|
|
7
|
+
}
|
|
8
|
+
exports.isOpenAICompatProvider = isOpenAICompatProvider;
|
|
9
|
+
function resolveOpenAICompatProfileConfig(profileName, settingsPath, env) {
|
|
10
|
+
const baseUrl = env.ANTHROPIC_BASE_URL?.trim() || '';
|
|
11
|
+
const apiKey = env.ANTHROPIC_AUTH_TOKEN?.trim() || env.ANTHROPIC_API_KEY?.trim() || '';
|
|
12
|
+
if (!baseUrl || !apiKey) {
|
|
13
|
+
return null;
|
|
14
|
+
}
|
|
15
|
+
const providerFromUrl = (0, droid_provider_1.inferDroidProviderFromBaseUrl)(baseUrl);
|
|
16
|
+
const provider = isOpenAICompatProvider(providerFromUrl)
|
|
17
|
+
? providerFromUrl
|
|
18
|
+
: (0, droid_provider_1.resolveDroidProvider)({
|
|
19
|
+
provider: env.CCS_DROID_PROVIDER,
|
|
20
|
+
baseUrl,
|
|
21
|
+
model: env.ANTHROPIC_MODEL,
|
|
22
|
+
});
|
|
23
|
+
if (!isOpenAICompatProvider(provider)) {
|
|
24
|
+
return null;
|
|
25
|
+
}
|
|
26
|
+
return {
|
|
27
|
+
profileName,
|
|
28
|
+
settingsPath,
|
|
29
|
+
baseUrl,
|
|
30
|
+
apiKey,
|
|
31
|
+
provider,
|
|
32
|
+
insecure: env.CCS_OPENAI_PROXY_INSECURE === '1' ||
|
|
33
|
+
env.CCS_OPENAI_PROXY_INSECURE?.toLowerCase() === 'true',
|
|
34
|
+
model: env.ANTHROPIC_MODEL?.trim() || undefined,
|
|
35
|
+
opusModel: env.ANTHROPIC_DEFAULT_OPUS_MODEL?.trim() || undefined,
|
|
36
|
+
sonnetModel: env.ANTHROPIC_DEFAULT_SONNET_MODEL?.trim() || undefined,
|
|
37
|
+
haikuModel: env.ANTHROPIC_DEFAULT_HAIKU_MODEL?.trim() ||
|
|
38
|
+
env.ANTHROPIC_SMALL_FAST_MODEL?.trim() ||
|
|
39
|
+
undefined,
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
exports.resolveOpenAICompatProfileConfig = resolveOpenAICompatProfileConfig;
|
|
43
|
+
//# sourceMappingURL=profile-router.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"profile-router.js","sourceRoot":"","sources":["../../src/proxy/profile-router.ts"],"names":[],"mappings":";;;AAAA,8DAImC;AA4BnC,SAAgB,sBAAsB,CAAC,QAA8B;IACnE,OAAO,QAAQ,KAAK,QAAQ,IAAI,QAAQ,KAAK,6BAA6B,CAAC;AAC7E,CAAC;AAFD,wDAEC;AAED,SAAgB,gCAAgC,CAC9C,WAAmB,EACnB,YAAoB,EACpB,GAA2B;IAE3B,MAAM,OAAO,GAAG,GAAG,CAAC,kBAAkB,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IACrD,MAAM,MAAM,GAAG,GAAG,CAAC,oBAAoB,EAAE,IAAI,EAAE,IAAI,GAAG,CAAC,iBAAiB,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;IACvF,IAAI,CAAC,OAAO,IAAI,CAAC,MAAM,EAAE,CAAC;QACxB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,eAAe,GAAG,IAAA,8CAA6B,EAAC,OAAO,CAAC,CAAC;IAC/D,MAAM,QAAQ,GAAG,sBAAsB,CAAC,eAAe,CAAC;QACtD,CAAC,CAAC,eAAe;QACjB,CAAC,CAAC,IAAA,qCAAoB,EAAC;YACnB,QAAQ,EAAE,GAAG,CAAC,kBAAkB;YAChC,OAAO;YACP,KAAK,EAAE,GAAG,CAAC,eAAe;SAC3B,CAAC,CAAC;IACP,IAAI,CAAC,sBAAsB,CAAC,QAAQ,CAAC,EAAE,CAAC;QACtC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,OAAO;QACL,WAAW;QACX,YAAY;QACZ,OAAO;QACP,MAAM;QACN,QAAQ;QACR,QAAQ,EACN,GAAG,CAAC,yBAAyB,KAAK,GAAG;YACrC,GAAG,CAAC,yBAAyB,EAAE,WAAW,EAAE,KAAK,MAAM;QACzD,KAAK,EAAE,GAAG,CAAC,eAAe,EAAE,IAAI,EAAE,IAAI,SAAS;QAC/C,SAAS,EAAE,GAAG,CAAC,4BAA4B,EAAE,IAAI,EAAE,IAAI,SAAS;QAChE,WAAW,EAAE,GAAG,CAAC,8BAA8B,EAAE,IAAI,EAAE,IAAI,SAAS;QACpE,UAAU,EACR,GAAG,CAAC,6BAA6B,EAAE,IAAI,EAAE;YACzC,GAAG,CAAC,0BAA0B,EAAE,IAAI,EAAE;YACtC,SAAS;KACZ,CAAC;AACJ,CAAC;AAxCD,4EAwCC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy-daemon-entry.d.ts","sourceRoot":"","sources":["../../src/proxy/proxy-daemon-entry.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const config_manager_1 = require("../utils/config-manager");
|
|
4
|
+
const profile_router_1 = require("./profile-router");
|
|
5
|
+
const proxy_server_1 = require("./server/proxy-server");
|
|
6
|
+
function parseArgs(argv) {
|
|
7
|
+
let port = 3456;
|
|
8
|
+
let host = '127.0.0.1';
|
|
9
|
+
let profileName = '';
|
|
10
|
+
let settingsPath = '';
|
|
11
|
+
let authToken = '';
|
|
12
|
+
let insecure = false;
|
|
13
|
+
for (let i = 0; i < argv.length; i++) {
|
|
14
|
+
const arg = argv[i];
|
|
15
|
+
if (arg === '--port' && argv[i + 1]) {
|
|
16
|
+
port = Number.parseInt(argv[++i] || '', 10) || port;
|
|
17
|
+
continue;
|
|
18
|
+
}
|
|
19
|
+
if (arg === '--host' && argv[i + 1]) {
|
|
20
|
+
host = argv[++i] || host;
|
|
21
|
+
continue;
|
|
22
|
+
}
|
|
23
|
+
if (arg === '--profile' && argv[i + 1]) {
|
|
24
|
+
profileName = argv[++i] || '';
|
|
25
|
+
continue;
|
|
26
|
+
}
|
|
27
|
+
if (arg === '--settings-path' && argv[i + 1]) {
|
|
28
|
+
settingsPath = argv[++i] || '';
|
|
29
|
+
continue;
|
|
30
|
+
}
|
|
31
|
+
if (arg === '--auth-token' && argv[i + 1]) {
|
|
32
|
+
authToken = argv[++i] || '';
|
|
33
|
+
continue;
|
|
34
|
+
}
|
|
35
|
+
if (arg === '--insecure') {
|
|
36
|
+
insecure = true;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
return { port, host, profileName, settingsPath, authToken, insecure };
|
|
40
|
+
}
|
|
41
|
+
function startRuntime(options) {
|
|
42
|
+
if (!options.authToken.trim()) {
|
|
43
|
+
throw new Error('Missing local proxy auth token');
|
|
44
|
+
}
|
|
45
|
+
const settings = (0, config_manager_1.loadSettings)(options.settingsPath);
|
|
46
|
+
const profile = (0, profile_router_1.resolveOpenAICompatProfileConfig)(options.profileName, options.settingsPath, settings.env || {});
|
|
47
|
+
if (!profile) {
|
|
48
|
+
throw new Error(`Profile "${options.profileName}" is not an OpenAI-compatible settings profile`);
|
|
49
|
+
}
|
|
50
|
+
const server = (0, proxy_server_1.startOpenAICompatProxyServer)({
|
|
51
|
+
profile,
|
|
52
|
+
host: options.host,
|
|
53
|
+
port: options.port,
|
|
54
|
+
authToken: options.authToken,
|
|
55
|
+
insecure: options.insecure,
|
|
56
|
+
});
|
|
57
|
+
server.once('error', (error) => {
|
|
58
|
+
console.error(error.message);
|
|
59
|
+
process.exit(1);
|
|
60
|
+
});
|
|
61
|
+
const shutdown = () => server.close();
|
|
62
|
+
process.on('SIGTERM', shutdown);
|
|
63
|
+
process.on('SIGINT', shutdown);
|
|
64
|
+
}
|
|
65
|
+
if (require.main === module) {
|
|
66
|
+
startRuntime(parseArgs(process.argv.slice(2)));
|
|
67
|
+
}
|
|
68
|
+
//# sourceMappingURL=proxy-daemon-entry.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy-daemon-entry.js","sourceRoot":"","sources":["../../src/proxy/proxy-daemon-entry.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
export declare const OPENAI_COMPAT_PROXY_DEFAULT_PORT = 3456;
|
|
2
|
+
export declare const OPENAI_COMPAT_PROXY_SERVICE_NAME = "ccs-openai-compat-proxy";
|
|
3
|
+
export declare function getOpenAICompatProxyDir(): string;
|
|
4
|
+
export declare function getOpenAICompatProxyPidPath(): string;
|
|
5
|
+
export declare function getOpenAICompatProxySessionPath(): string;
|
|
6
|
+
//# sourceMappingURL=proxy-daemon-paths.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"proxy-daemon-paths.d.ts","sourceRoot":"","sources":["../../src/proxy/proxy-daemon-paths.ts"],"names":[],"mappings":"AAGA,eAAO,MAAM,gCAAgC,OAAO,CAAC;AACrD,eAAO,MAAM,gCAAgC,4BAA4B,CAAC;AAE1E,wBAAgB,uBAAuB,IAAI,MAAM,CAEhD;AAED,wBAAgB,2BAA2B,IAAI,MAAM,CAEpD;AAED,wBAAgB,+BAA+B,IAAI,MAAM,CAExD"}
|