@omnicross/core 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.
- package/LICENSE +21 -0
- package/NOTICE +57 -0
- package/README.md +15 -0
- package/dist/ApiKeyPoolService-BmMkau07.d.cts +170 -0
- package/dist/ApiKeyPoolService-BmMkau07.d.ts +170 -0
- package/dist/ProviderProxy-f_8ziIhW.d.cts +120 -0
- package/dist/ProviderProxy-vjt8sQQk.d.ts +120 -0
- package/dist/SubscriptionAuthSource-Cr4fVEYY.d.cts +264 -0
- package/dist/SubscriptionAuthSource-D89zmiSS.d.ts +264 -0
- package/dist/auth/GeminiCodeAssistProjectResolver.cjs +218 -0
- package/dist/auth/GeminiCodeAssistProjectResolver.d.cts +68 -0
- package/dist/auth/GeminiCodeAssistProjectResolver.d.ts +68 -0
- package/dist/auth/GeminiCodeAssistProjectResolver.js +189 -0
- package/dist/completion/ApiKeyPoolService.cjs +331 -0
- package/dist/completion/ApiKeyPoolService.d.cts +2 -0
- package/dist/completion/ApiKeyPoolService.d.ts +2 -0
- package/dist/completion/ApiKeyPoolService.js +306 -0
- package/dist/completion.cjs +4027 -0
- package/dist/completion.d.cts +17 -0
- package/dist/completion.d.ts +17 -0
- package/dist/completion.js +3983 -0
- package/dist/index-BTSmc9Sm.d.ts +645 -0
- package/dist/index-DXazdTzZ.d.cts +645 -0
- package/dist/index.cjs +10428 -0
- package/dist/index.d.cts +128 -0
- package/dist/index.d.ts +128 -0
- package/dist/index.js +10339 -0
- package/dist/outbound-api/subscriptionRegistryPort.cjs +38 -0
- package/dist/outbound-api/subscriptionRegistryPort.d.cts +73 -0
- package/dist/outbound-api/subscriptionRegistryPort.d.ts +73 -0
- package/dist/outbound-api/subscriptionRegistryPort.js +12 -0
- package/dist/outbound-api.cjs +5264 -0
- package/dist/outbound-api.d.cts +320 -0
- package/dist/outbound-api.d.ts +320 -0
- package/dist/outbound-api.js +5218 -0
- package/dist/pipeline/SubscriptionAuthSource.cjs +131 -0
- package/dist/pipeline/SubscriptionAuthSource.d.cts +3 -0
- package/dist/pipeline/SubscriptionAuthSource.d.ts +3 -0
- package/dist/pipeline/SubscriptionAuthSource.js +103 -0
- package/dist/pipeline/SubscriptionAuthStrategy.cjs +18 -0
- package/dist/pipeline/SubscriptionAuthStrategy.d.cts +61 -0
- package/dist/pipeline/SubscriptionAuthStrategy.d.ts +61 -0
- package/dist/pipeline/SubscriptionAuthStrategy.js +0 -0
- package/dist/ports/gemini-code-assist-resolver.cjs +38 -0
- package/dist/ports/gemini-code-assist-resolver.d.cts +26 -0
- package/dist/ports/gemini-code-assist-resolver.d.ts +26 -0
- package/dist/ports/gemini-code-assist-resolver.js +12 -0
- package/dist/ports.cjs +18 -0
- package/dist/ports.d.cts +15 -0
- package/dist/ports.d.ts +15 -0
- package/dist/ports.js +0 -0
- package/dist/provider-proxy/ingress/providerProxyShared.cjs +2958 -0
- package/dist/provider-proxy/ingress/providerProxyShared.d.cts +77 -0
- package/dist/provider-proxy/ingress/providerProxyShared.d.ts +77 -0
- package/dist/provider-proxy/ingress/providerProxyShared.js +2925 -0
- package/dist/provider-proxy/matchText.cjs +73 -0
- package/dist/provider-proxy/matchText.d.cts +47 -0
- package/dist/provider-proxy/matchText.d.ts +47 -0
- package/dist/provider-proxy/matchText.js +45 -0
- package/dist/provider-proxy/types.cjs +18 -0
- package/dist/provider-proxy/types.d.cts +12 -0
- package/dist/provider-proxy/types.d.ts +12 -0
- package/dist/provider-proxy/types.js +0 -0
- package/dist/provider-proxy.cjs +4667 -0
- package/dist/provider-proxy.d.cts +69 -0
- package/dist/provider-proxy.d.ts +69 -0
- package/dist/provider-proxy.js +4636 -0
- package/dist/serializeError.cjs +82 -0
- package/dist/serializeError.d.cts +24 -0
- package/dist/serializeError.d.ts +24 -0
- package/dist/serializeError.js +57 -0
- package/dist/sse-parser.cjs +456 -0
- package/dist/sse-parser.d.cts +143 -0
- package/dist/sse-parser.d.ts +143 -0
- package/dist/sse-parser.js +430 -0
- package/dist/transformer/TransformerChainExecutor.cjs +321 -0
- package/dist/transformer/TransformerChainExecutor.d.cts +104 -0
- package/dist/transformer/TransformerChainExecutor.d.ts +104 -0
- package/dist/transformer/TransformerChainExecutor.js +294 -0
- package/dist/transformer/TransformerService.cjs +290 -0
- package/dist/transformer/TransformerService.d.cts +138 -0
- package/dist/transformer/TransformerService.d.ts +138 -0
- package/dist/transformer/TransformerService.js +265 -0
- package/dist/transformer/transformers/GeminiCodeAssistTransformer.cjs +1115 -0
- package/dist/transformer/transformers/GeminiCodeAssistTransformer.d.cts +102 -0
- package/dist/transformer/transformers/GeminiCodeAssistTransformer.d.ts +102 -0
- package/dist/transformer/transformers/GeminiCodeAssistTransformer.js +1085 -0
- package/dist/transformer/transformers/GeminiTransformer.cjs +1013 -0
- package/dist/transformer/transformers/GeminiTransformer.d.cts +70 -0
- package/dist/transformer/transformers/GeminiTransformer.d.ts +70 -0
- package/dist/transformer/transformers/GeminiTransformer.js +986 -0
- package/dist/transformer/transformers/OpenAIResponseTransformer.cjs +538 -0
- package/dist/transformer/transformers/OpenAIResponseTransformer.d.cts +53 -0
- package/dist/transformer/transformers/OpenAIResponseTransformer.d.ts +53 -0
- package/dist/transformer/transformers/OpenAIResponseTransformer.js +513 -0
- package/dist/transformer/transformers/OpenCodeGoTransformer.cjs +73 -0
- package/dist/transformer/transformers/OpenCodeGoTransformer.d.cts +51 -0
- package/dist/transformer/transformers/OpenCodeGoTransformer.d.ts +51 -0
- package/dist/transformer/transformers/OpenCodeGoTransformer.js +48 -0
- package/dist/transformer/types.cjs +18 -0
- package/dist/transformer/types.d.cts +405 -0
- package/dist/transformer/types.d.ts +405 -0
- package/dist/transformer/types.js +0 -0
- package/dist/transformer.cjs +3736 -0
- package/dist/transformer.d.cts +33 -0
- package/dist/transformer.d.ts +33 -0
- package/dist/transformer.js +3712 -0
- package/dist/types-CGGrKqC_.d.cts +142 -0
- package/dist/types-CbCN2NQP.d.ts +142 -0
- package/dist/types-DCzHkhJt.d.ts +467 -0
- package/dist/types-DZIQbgp0.d.cts +467 -0
- package/dist/usage-event-sink-BX7FE1NL.d.cts +59 -0
- package/dist/usage-event-sink-BX7FE1NL.d.ts +59 -0
- package/package.json +62 -0
|
@@ -0,0 +1,321 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
9
|
+
};
|
|
10
|
+
var __copyProps = (to, from, except, desc) => {
|
|
11
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
12
|
+
for (let key of __getOwnPropNames(from))
|
|
13
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
14
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
15
|
+
}
|
|
16
|
+
return to;
|
|
17
|
+
};
|
|
18
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
|
+
|
|
20
|
+
// src/transformer/TransformerChainExecutor.ts
|
|
21
|
+
var TransformerChainExecutor_exports = {};
|
|
22
|
+
__export(TransformerChainExecutor_exports, {
|
|
23
|
+
TransformerChainExecutor: () => TransformerChainExecutor
|
|
24
|
+
});
|
|
25
|
+
module.exports = __toCommonJS(TransformerChainExecutor_exports);
|
|
26
|
+
|
|
27
|
+
// src/transformer/anthropicBetaInject.ts
|
|
28
|
+
var import_extended_context = require("@omnicross/contracts/extended-context");
|
|
29
|
+
var EXTENDED_CONTEXT_BETA = "context-1m-2025-08-07";
|
|
30
|
+
var ANTHROPIC_BETA_HEADER = "anthropic-beta";
|
|
31
|
+
function injectExtendedContextBeta(headers, model, useExtendedContext) {
|
|
32
|
+
if (!useExtendedContext) return;
|
|
33
|
+
if (!(0, import_extended_context.isExtendedContextCapable)(model)) return;
|
|
34
|
+
let existingValue = "";
|
|
35
|
+
for (const key of Object.keys(headers)) {
|
|
36
|
+
if (key.toLowerCase() === ANTHROPIC_BETA_HEADER) {
|
|
37
|
+
const v = headers[key];
|
|
38
|
+
if (typeof v === "string") existingValue = v;
|
|
39
|
+
if (key !== ANTHROPIC_BETA_HEADER) delete headers[key];
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
const parts = existingValue.split(",").map((s) => s.trim()).filter((s) => s.length > 0);
|
|
43
|
+
if (!parts.includes(EXTENDED_CONTEXT_BETA)) {
|
|
44
|
+
parts.push(EXTENDED_CONTEXT_BETA);
|
|
45
|
+
}
|
|
46
|
+
headers[ANTHROPIC_BETA_HEADER] = parts.join(",");
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
// src/transformer/TransformerChainExecutor.ts
|
|
50
|
+
var defaultLogger = {
|
|
51
|
+
debug: (msg, ...args) => console.debug(`[ChainExecutor] ${msg}`, ...args),
|
|
52
|
+
info: (msg, ...args) => console.info(`[ChainExecutor] ${msg}`, ...args),
|
|
53
|
+
warn: (msg, ...args) => console.warn(`[ChainExecutor] ${msg}`, ...args),
|
|
54
|
+
error: (msg, ...args) => console.error(`[ChainExecutor] ${msg}`, ...args)
|
|
55
|
+
};
|
|
56
|
+
var TransformerChainExecutor = class {
|
|
57
|
+
logger;
|
|
58
|
+
constructor(logger) {
|
|
59
|
+
this.logger = logger ?? defaultLogger;
|
|
60
|
+
}
|
|
61
|
+
/**
|
|
62
|
+
* Execute the request transformation chain
|
|
63
|
+
*
|
|
64
|
+
* @param request - Original request body
|
|
65
|
+
* @param provider - LLM provider configuration
|
|
66
|
+
* @param chain - Resolved transformer chain
|
|
67
|
+
* @param options - Execution options
|
|
68
|
+
* @returns Transformed request result
|
|
69
|
+
*/
|
|
70
|
+
async executeRequestChain(request, provider, chain, options = {}) {
|
|
71
|
+
const { endpointTransformer, headers, extendedContext } = options;
|
|
72
|
+
const context = {
|
|
73
|
+
logger: this.logger,
|
|
74
|
+
providerName: provider.name
|
|
75
|
+
};
|
|
76
|
+
let requestBody = request;
|
|
77
|
+
let config = {};
|
|
78
|
+
let bypass = false;
|
|
79
|
+
bypass = this.shouldBypassTransformers(
|
|
80
|
+
chain,
|
|
81
|
+
endpointTransformer,
|
|
82
|
+
requestBody
|
|
83
|
+
);
|
|
84
|
+
if (bypass) {
|
|
85
|
+
if (headers) {
|
|
86
|
+
const cleanHeaders = this.cleanHeaders(headers);
|
|
87
|
+
config.headers = cleanHeaders;
|
|
88
|
+
}
|
|
89
|
+
this.logger.debug("Bypass mode enabled - skipping transformations");
|
|
90
|
+
}
|
|
91
|
+
if (!bypass && endpointTransformer?.transformRequestOut) {
|
|
92
|
+
this.logger.debug("Executing transformRequestOut");
|
|
93
|
+
try {
|
|
94
|
+
const transformOut = await endpointTransformer.transformRequestOut(requestBody, context);
|
|
95
|
+
if (transformOut && typeof transformOut === "object") {
|
|
96
|
+
if ("body" in transformOut) {
|
|
97
|
+
requestBody = transformOut.body;
|
|
98
|
+
config = transformOut.config ?? {};
|
|
99
|
+
} else {
|
|
100
|
+
requestBody = transformOut;
|
|
101
|
+
}
|
|
102
|
+
}
|
|
103
|
+
} catch (error) {
|
|
104
|
+
this.logger.error(`transformRequestOut error: ${this.getErrorMessage(error)}`);
|
|
105
|
+
throw error;
|
|
106
|
+
}
|
|
107
|
+
}
|
|
108
|
+
if (!bypass && chain.providerTransformers.length > 0) {
|
|
109
|
+
this.logger.debug(`Executing ${chain.providerTransformers.length} provider transformers`);
|
|
110
|
+
for (const transformer of chain.providerTransformers) {
|
|
111
|
+
if (transformer.transformRequestIn) {
|
|
112
|
+
try {
|
|
113
|
+
const transformIn = await transformer.transformRequestIn(
|
|
114
|
+
requestBody,
|
|
115
|
+
provider,
|
|
116
|
+
context
|
|
117
|
+
);
|
|
118
|
+
if (transformIn && typeof transformIn === "object") {
|
|
119
|
+
if ("body" in transformIn) {
|
|
120
|
+
requestBody = transformIn.body;
|
|
121
|
+
config = { ...config, ...transformIn.config };
|
|
122
|
+
} else {
|
|
123
|
+
requestBody = transformIn;
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
} catch (error) {
|
|
127
|
+
this.logger.error(
|
|
128
|
+
`Provider transformer ${transformer.name} error: ${this.getErrorMessage(error)}`
|
|
129
|
+
);
|
|
130
|
+
throw error;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
}
|
|
135
|
+
if (!bypass && chain.modelTransformers.length > 0) {
|
|
136
|
+
this.logger.debug(`Executing ${chain.modelTransformers.length} model transformers`);
|
|
137
|
+
for (const transformer of chain.modelTransformers) {
|
|
138
|
+
if (transformer.transformRequestIn) {
|
|
139
|
+
try {
|
|
140
|
+
const result = await transformer.transformRequestIn(
|
|
141
|
+
requestBody,
|
|
142
|
+
provider,
|
|
143
|
+
context
|
|
144
|
+
);
|
|
145
|
+
requestBody = result;
|
|
146
|
+
} catch (error) {
|
|
147
|
+
this.logger.error(
|
|
148
|
+
`Model transformer ${transformer.name} error: ${this.getErrorMessage(error)}`
|
|
149
|
+
);
|
|
150
|
+
throw error;
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
if (extendedContext?.enabled) {
|
|
156
|
+
if (!config.headers || typeof config.headers !== "object") {
|
|
157
|
+
config.headers = {};
|
|
158
|
+
}
|
|
159
|
+
injectExtendedContextBeta(
|
|
160
|
+
config.headers,
|
|
161
|
+
extendedContext.model,
|
|
162
|
+
true
|
|
163
|
+
);
|
|
164
|
+
}
|
|
165
|
+
return { requestBody, config, bypass };
|
|
166
|
+
}
|
|
167
|
+
/**
|
|
168
|
+
* Execute the response transformation chain
|
|
169
|
+
*
|
|
170
|
+
* @param request - Original request (for context)
|
|
171
|
+
* @param response - Response from provider
|
|
172
|
+
* @param provider - LLM provider configuration
|
|
173
|
+
* @param chain - Resolved transformer chain
|
|
174
|
+
* @param options - Execution options
|
|
175
|
+
* @returns Transformed response
|
|
176
|
+
*/
|
|
177
|
+
async executeResponseChain(request, response, provider, chain, options = {}) {
|
|
178
|
+
const { endpointTransformer } = options;
|
|
179
|
+
const context = {
|
|
180
|
+
logger: this.logger,
|
|
181
|
+
providerName: provider.name
|
|
182
|
+
};
|
|
183
|
+
let finalResponse = response;
|
|
184
|
+
const bypass = this.shouldBypassTransformers(chain, endpointTransformer, request);
|
|
185
|
+
if (bypass) {
|
|
186
|
+
this.logger.debug("Bypass mode - skipping response transformations");
|
|
187
|
+
return finalResponse;
|
|
188
|
+
}
|
|
189
|
+
if (chain.modelTransformers.length > 0) {
|
|
190
|
+
const reversedModelTransformers = [...chain.modelTransformers].reverse();
|
|
191
|
+
this.logger.debug(
|
|
192
|
+
`Executing ${reversedModelTransformers.length} model response transformers (reversed)`
|
|
193
|
+
);
|
|
194
|
+
for (const transformer of reversedModelTransformers) {
|
|
195
|
+
if (transformer.transformResponseOut) {
|
|
196
|
+
try {
|
|
197
|
+
finalResponse = await transformer.transformResponseOut(finalResponse, context);
|
|
198
|
+
} catch (error) {
|
|
199
|
+
this.logger.error(
|
|
200
|
+
`Model transformer ${transformer.name} response error: ${this.getErrorMessage(error)}`
|
|
201
|
+
);
|
|
202
|
+
throw error;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
if (chain.providerTransformers.length > 0) {
|
|
208
|
+
const reversedProviderTransformers = [...chain.providerTransformers].reverse();
|
|
209
|
+
this.logger.debug(
|
|
210
|
+
`Executing ${reversedProviderTransformers.length} provider response transformers (reversed)`
|
|
211
|
+
);
|
|
212
|
+
for (const transformer of reversedProviderTransformers) {
|
|
213
|
+
if (transformer.transformResponseOut) {
|
|
214
|
+
try {
|
|
215
|
+
finalResponse = await transformer.transformResponseOut(finalResponse, context);
|
|
216
|
+
} catch (error) {
|
|
217
|
+
this.logger.error(
|
|
218
|
+
`Provider transformer ${transformer.name} response error: ${this.getErrorMessage(error)}`
|
|
219
|
+
);
|
|
220
|
+
throw error;
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
if (endpointTransformer?.transformResponseIn) {
|
|
226
|
+
this.logger.debug("Executing transformResponseIn");
|
|
227
|
+
try {
|
|
228
|
+
finalResponse = await endpointTransformer.transformResponseIn(finalResponse, context);
|
|
229
|
+
} catch (error) {
|
|
230
|
+
this.logger.error(`transformResponseIn error: ${this.getErrorMessage(error)}`);
|
|
231
|
+
throw error;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
return finalResponse;
|
|
235
|
+
}
|
|
236
|
+
/**
|
|
237
|
+
* Execute authentication handler if available
|
|
238
|
+
*
|
|
239
|
+
* @param request - Request body
|
|
240
|
+
* @param provider - LLM provider
|
|
241
|
+
* @param endpointTransformer - Endpoint transformer with auth handler
|
|
242
|
+
* @param context - Transformer context
|
|
243
|
+
* @returns Auth result with potentially modified request and config
|
|
244
|
+
*/
|
|
245
|
+
async executeAuth(request, provider, endpointTransformer, context) {
|
|
246
|
+
let requestBody = request;
|
|
247
|
+
let config = {};
|
|
248
|
+
if (endpointTransformer?.auth) {
|
|
249
|
+
this.logger.debug("Executing auth handler");
|
|
250
|
+
try {
|
|
251
|
+
const auth = await endpointTransformer.auth(requestBody, provider, context);
|
|
252
|
+
if (auth && typeof auth === "object") {
|
|
253
|
+
if ("body" in auth) {
|
|
254
|
+
requestBody = auth.body;
|
|
255
|
+
const authConfig = auth.config;
|
|
256
|
+
if (authConfig) {
|
|
257
|
+
const headers = { ...config.headers ?? {}, ...authConfig.headers ?? {} };
|
|
258
|
+
delete headers["host"];
|
|
259
|
+
config = { ...config, ...authConfig, headers };
|
|
260
|
+
}
|
|
261
|
+
} else {
|
|
262
|
+
requestBody = auth;
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
} catch (error) {
|
|
266
|
+
this.logger.error(`Auth handler error: ${this.getErrorMessage(error)}`);
|
|
267
|
+
throw error;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
return { requestBody, config };
|
|
271
|
+
}
|
|
272
|
+
/**
|
|
273
|
+
* Check if transformers should be bypassed (optimization)
|
|
274
|
+
*
|
|
275
|
+
* Bypass is enabled when:
|
|
276
|
+
* - Provider has only one transformer that matches the endpoint transformer
|
|
277
|
+
* - Model has no specific transformers or only the same endpoint transformer
|
|
278
|
+
*/
|
|
279
|
+
shouldBypassTransformers(chain, endpointTransformer, _request) {
|
|
280
|
+
if (!endpointTransformer?.name) {
|
|
281
|
+
return false;
|
|
282
|
+
}
|
|
283
|
+
const providerHasOnlyEndpoint = chain.providerTransformers.length === 1 && chain.providerTransformers[0]?.name === endpointTransformer.name;
|
|
284
|
+
const modelHasNoTransformers = chain.modelTransformers.length === 0;
|
|
285
|
+
const modelHasOnlyEndpoint = chain.modelTransformers.length === 1 && chain.modelTransformers[0]?.name === endpointTransformer.name;
|
|
286
|
+
return providerHasOnlyEndpoint && (modelHasNoTransformers || modelHasOnlyEndpoint);
|
|
287
|
+
}
|
|
288
|
+
/**
|
|
289
|
+
* Clean headers for pass-through
|
|
290
|
+
*/
|
|
291
|
+
cleanHeaders(headers) {
|
|
292
|
+
const result = {};
|
|
293
|
+
if (headers instanceof Headers) {
|
|
294
|
+
headers.forEach((value, key) => {
|
|
295
|
+
if (key.toLowerCase() !== "content-length") {
|
|
296
|
+
result[key] = value;
|
|
297
|
+
}
|
|
298
|
+
});
|
|
299
|
+
} else {
|
|
300
|
+
for (const [key, value] of Object.entries(headers)) {
|
|
301
|
+
if (key.toLowerCase() !== "content-length") {
|
|
302
|
+
result[key] = value;
|
|
303
|
+
}
|
|
304
|
+
}
|
|
305
|
+
}
|
|
306
|
+
return result;
|
|
307
|
+
}
|
|
308
|
+
/**
|
|
309
|
+
* Get error message from unknown error
|
|
310
|
+
*/
|
|
311
|
+
getErrorMessage(error) {
|
|
312
|
+
if (error instanceof Error) {
|
|
313
|
+
return error.message;
|
|
314
|
+
}
|
|
315
|
+
return String(error);
|
|
316
|
+
}
|
|
317
|
+
};
|
|
318
|
+
// Annotate the CommonJS export names for ESM import in node:
|
|
319
|
+
0 && (module.exports = {
|
|
320
|
+
TransformerChainExecutor
|
|
321
|
+
});
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Transformer, TransformerLogger, LLMProvider, ResolvedTransformerChain, TransformRequestResult, UnifiedChatRequest, TransformerContext, RequestConfig } from './types.cjs';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* TransformerChainExecutor - Executes transformer chains for requests and responses
|
|
5
|
+
*
|
|
6
|
+
* Implements the transformer pipeline:
|
|
7
|
+
* Request: transformRequestOut 鈫?Provider transformers 鈫?Model transformers 鈫?HTTP
|
|
8
|
+
* Response: Model transformers (reverse) 鈫?Provider transformers (reverse) 鈫?transformResponseIn
|
|
9
|
+
*
|
|
10
|
+
* @module transformer/TransformerChainExecutor
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Options for chain execution
|
|
15
|
+
*/
|
|
16
|
+
interface ChainExecutionOptions {
|
|
17
|
+
/** The primary/endpoint transformer */
|
|
18
|
+
endpointTransformer?: Transformer;
|
|
19
|
+
/** Request headers */
|
|
20
|
+
headers?: Record<string, string> | Headers;
|
|
21
|
+
/** Logger instance */
|
|
22
|
+
logger?: TransformerLogger;
|
|
23
|
+
/**
|
|
24
|
+
* 1M-context opt-in. When `enabled` is true and the post-chain request body
|
|
25
|
+
* looks Anthropic-shaped (has a `messages` array), the executor injects
|
|
26
|
+
* `'context-1m-2025-08-07'` into `body.anthropic_beta`. Capability gating
|
|
27
|
+
* (model id allowlist) lives inside `injectExtendedContextBeta` itself.
|
|
28
|
+
*/
|
|
29
|
+
extendedContext?: {
|
|
30
|
+
enabled: boolean;
|
|
31
|
+
model: string;
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* TransformerChainExecutor handles the execution of transformer chains.
|
|
36
|
+
*
|
|
37
|
+
* The execution flow follows the llms project pattern:
|
|
38
|
+
*
|
|
39
|
+
* Request Phase:
|
|
40
|
+
* 1. transformRequestOut (endpoint transformer) - Convert to unified format
|
|
41
|
+
* 2. Provider transformers [].transformRequestIn (forward order)
|
|
42
|
+
* 3. Model transformers [].transformRequestIn (forward order)
|
|
43
|
+
*
|
|
44
|
+
* Response Phase:
|
|
45
|
+
* 4. Model transformers [].transformResponseOut (reverse order)
|
|
46
|
+
* 5. Provider transformers [].transformResponseOut (reverse order)
|
|
47
|
+
* 6. transformResponseIn (endpoint transformer) - Convert to client format
|
|
48
|
+
*/
|
|
49
|
+
declare class TransformerChainExecutor {
|
|
50
|
+
private logger;
|
|
51
|
+
constructor(logger?: TransformerLogger);
|
|
52
|
+
/**
|
|
53
|
+
* Execute the request transformation chain
|
|
54
|
+
*
|
|
55
|
+
* @param request - Original request body
|
|
56
|
+
* @param provider - LLM provider configuration
|
|
57
|
+
* @param chain - Resolved transformer chain
|
|
58
|
+
* @param options - Execution options
|
|
59
|
+
* @returns Transformed request result
|
|
60
|
+
*/
|
|
61
|
+
executeRequestChain(request: unknown, provider: LLMProvider, chain: ResolvedTransformerChain, options?: ChainExecutionOptions): Promise<TransformRequestResult>;
|
|
62
|
+
/**
|
|
63
|
+
* Execute the response transformation chain
|
|
64
|
+
*
|
|
65
|
+
* @param request - Original request (for context)
|
|
66
|
+
* @param response - Response from provider
|
|
67
|
+
* @param provider - LLM provider configuration
|
|
68
|
+
* @param chain - Resolved transformer chain
|
|
69
|
+
* @param options - Execution options
|
|
70
|
+
* @returns Transformed response
|
|
71
|
+
*/
|
|
72
|
+
executeResponseChain(request: UnifiedChatRequest, response: Response, provider: LLMProvider, chain: ResolvedTransformerChain, options?: ChainExecutionOptions): Promise<Response>;
|
|
73
|
+
/**
|
|
74
|
+
* Execute authentication handler if available
|
|
75
|
+
*
|
|
76
|
+
* @param request - Request body
|
|
77
|
+
* @param provider - LLM provider
|
|
78
|
+
* @param endpointTransformer - Endpoint transformer with auth handler
|
|
79
|
+
* @param context - Transformer context
|
|
80
|
+
* @returns Auth result with potentially modified request and config
|
|
81
|
+
*/
|
|
82
|
+
executeAuth(request: unknown, provider: LLMProvider, endpointTransformer: Transformer | undefined, context: TransformerContext): Promise<{
|
|
83
|
+
requestBody: unknown;
|
|
84
|
+
config: RequestConfig;
|
|
85
|
+
}>;
|
|
86
|
+
/**
|
|
87
|
+
* Check if transformers should be bypassed (optimization)
|
|
88
|
+
*
|
|
89
|
+
* Bypass is enabled when:
|
|
90
|
+
* - Provider has only one transformer that matches the endpoint transformer
|
|
91
|
+
* - Model has no specific transformers or only the same endpoint transformer
|
|
92
|
+
*/
|
|
93
|
+
private shouldBypassTransformers;
|
|
94
|
+
/**
|
|
95
|
+
* Clean headers for pass-through
|
|
96
|
+
*/
|
|
97
|
+
private cleanHeaders;
|
|
98
|
+
/**
|
|
99
|
+
* Get error message from unknown error
|
|
100
|
+
*/
|
|
101
|
+
private getErrorMessage;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
export { type ChainExecutionOptions, TransformerChainExecutor };
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
import { Transformer, TransformerLogger, LLMProvider, ResolvedTransformerChain, TransformRequestResult, UnifiedChatRequest, TransformerContext, RequestConfig } from './types.js';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* TransformerChainExecutor - Executes transformer chains for requests and responses
|
|
5
|
+
*
|
|
6
|
+
* Implements the transformer pipeline:
|
|
7
|
+
* Request: transformRequestOut 鈫?Provider transformers 鈫?Model transformers 鈫?HTTP
|
|
8
|
+
* Response: Model transformers (reverse) 鈫?Provider transformers (reverse) 鈫?transformResponseIn
|
|
9
|
+
*
|
|
10
|
+
* @module transformer/TransformerChainExecutor
|
|
11
|
+
*/
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Options for chain execution
|
|
15
|
+
*/
|
|
16
|
+
interface ChainExecutionOptions {
|
|
17
|
+
/** The primary/endpoint transformer */
|
|
18
|
+
endpointTransformer?: Transformer;
|
|
19
|
+
/** Request headers */
|
|
20
|
+
headers?: Record<string, string> | Headers;
|
|
21
|
+
/** Logger instance */
|
|
22
|
+
logger?: TransformerLogger;
|
|
23
|
+
/**
|
|
24
|
+
* 1M-context opt-in. When `enabled` is true and the post-chain request body
|
|
25
|
+
* looks Anthropic-shaped (has a `messages` array), the executor injects
|
|
26
|
+
* `'context-1m-2025-08-07'` into `body.anthropic_beta`. Capability gating
|
|
27
|
+
* (model id allowlist) lives inside `injectExtendedContextBeta` itself.
|
|
28
|
+
*/
|
|
29
|
+
extendedContext?: {
|
|
30
|
+
enabled: boolean;
|
|
31
|
+
model: string;
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* TransformerChainExecutor handles the execution of transformer chains.
|
|
36
|
+
*
|
|
37
|
+
* The execution flow follows the llms project pattern:
|
|
38
|
+
*
|
|
39
|
+
* Request Phase:
|
|
40
|
+
* 1. transformRequestOut (endpoint transformer) - Convert to unified format
|
|
41
|
+
* 2. Provider transformers [].transformRequestIn (forward order)
|
|
42
|
+
* 3. Model transformers [].transformRequestIn (forward order)
|
|
43
|
+
*
|
|
44
|
+
* Response Phase:
|
|
45
|
+
* 4. Model transformers [].transformResponseOut (reverse order)
|
|
46
|
+
* 5. Provider transformers [].transformResponseOut (reverse order)
|
|
47
|
+
* 6. transformResponseIn (endpoint transformer) - Convert to client format
|
|
48
|
+
*/
|
|
49
|
+
declare class TransformerChainExecutor {
|
|
50
|
+
private logger;
|
|
51
|
+
constructor(logger?: TransformerLogger);
|
|
52
|
+
/**
|
|
53
|
+
* Execute the request transformation chain
|
|
54
|
+
*
|
|
55
|
+
* @param request - Original request body
|
|
56
|
+
* @param provider - LLM provider configuration
|
|
57
|
+
* @param chain - Resolved transformer chain
|
|
58
|
+
* @param options - Execution options
|
|
59
|
+
* @returns Transformed request result
|
|
60
|
+
*/
|
|
61
|
+
executeRequestChain(request: unknown, provider: LLMProvider, chain: ResolvedTransformerChain, options?: ChainExecutionOptions): Promise<TransformRequestResult>;
|
|
62
|
+
/**
|
|
63
|
+
* Execute the response transformation chain
|
|
64
|
+
*
|
|
65
|
+
* @param request - Original request (for context)
|
|
66
|
+
* @param response - Response from provider
|
|
67
|
+
* @param provider - LLM provider configuration
|
|
68
|
+
* @param chain - Resolved transformer chain
|
|
69
|
+
* @param options - Execution options
|
|
70
|
+
* @returns Transformed response
|
|
71
|
+
*/
|
|
72
|
+
executeResponseChain(request: UnifiedChatRequest, response: Response, provider: LLMProvider, chain: ResolvedTransformerChain, options?: ChainExecutionOptions): Promise<Response>;
|
|
73
|
+
/**
|
|
74
|
+
* Execute authentication handler if available
|
|
75
|
+
*
|
|
76
|
+
* @param request - Request body
|
|
77
|
+
* @param provider - LLM provider
|
|
78
|
+
* @param endpointTransformer - Endpoint transformer with auth handler
|
|
79
|
+
* @param context - Transformer context
|
|
80
|
+
* @returns Auth result with potentially modified request and config
|
|
81
|
+
*/
|
|
82
|
+
executeAuth(request: unknown, provider: LLMProvider, endpointTransformer: Transformer | undefined, context: TransformerContext): Promise<{
|
|
83
|
+
requestBody: unknown;
|
|
84
|
+
config: RequestConfig;
|
|
85
|
+
}>;
|
|
86
|
+
/**
|
|
87
|
+
* Check if transformers should be bypassed (optimization)
|
|
88
|
+
*
|
|
89
|
+
* Bypass is enabled when:
|
|
90
|
+
* - Provider has only one transformer that matches the endpoint transformer
|
|
91
|
+
* - Model has no specific transformers or only the same endpoint transformer
|
|
92
|
+
*/
|
|
93
|
+
private shouldBypassTransformers;
|
|
94
|
+
/**
|
|
95
|
+
* Clean headers for pass-through
|
|
96
|
+
*/
|
|
97
|
+
private cleanHeaders;
|
|
98
|
+
/**
|
|
99
|
+
* Get error message from unknown error
|
|
100
|
+
*/
|
|
101
|
+
private getErrorMessage;
|
|
102
|
+
}
|
|
103
|
+
|
|
104
|
+
export { type ChainExecutionOptions, TransformerChainExecutor };
|