@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.
Files changed (114) hide show
  1. package/LICENSE +21 -0
  2. package/NOTICE +57 -0
  3. package/README.md +15 -0
  4. package/dist/ApiKeyPoolService-BmMkau07.d.cts +170 -0
  5. package/dist/ApiKeyPoolService-BmMkau07.d.ts +170 -0
  6. package/dist/ProviderProxy-f_8ziIhW.d.cts +120 -0
  7. package/dist/ProviderProxy-vjt8sQQk.d.ts +120 -0
  8. package/dist/SubscriptionAuthSource-Cr4fVEYY.d.cts +264 -0
  9. package/dist/SubscriptionAuthSource-D89zmiSS.d.ts +264 -0
  10. package/dist/auth/GeminiCodeAssistProjectResolver.cjs +218 -0
  11. package/dist/auth/GeminiCodeAssistProjectResolver.d.cts +68 -0
  12. package/dist/auth/GeminiCodeAssistProjectResolver.d.ts +68 -0
  13. package/dist/auth/GeminiCodeAssistProjectResolver.js +189 -0
  14. package/dist/completion/ApiKeyPoolService.cjs +331 -0
  15. package/dist/completion/ApiKeyPoolService.d.cts +2 -0
  16. package/dist/completion/ApiKeyPoolService.d.ts +2 -0
  17. package/dist/completion/ApiKeyPoolService.js +306 -0
  18. package/dist/completion.cjs +4027 -0
  19. package/dist/completion.d.cts +17 -0
  20. package/dist/completion.d.ts +17 -0
  21. package/dist/completion.js +3983 -0
  22. package/dist/index-BTSmc9Sm.d.ts +645 -0
  23. package/dist/index-DXazdTzZ.d.cts +645 -0
  24. package/dist/index.cjs +10428 -0
  25. package/dist/index.d.cts +128 -0
  26. package/dist/index.d.ts +128 -0
  27. package/dist/index.js +10339 -0
  28. package/dist/outbound-api/subscriptionRegistryPort.cjs +38 -0
  29. package/dist/outbound-api/subscriptionRegistryPort.d.cts +73 -0
  30. package/dist/outbound-api/subscriptionRegistryPort.d.ts +73 -0
  31. package/dist/outbound-api/subscriptionRegistryPort.js +12 -0
  32. package/dist/outbound-api.cjs +5264 -0
  33. package/dist/outbound-api.d.cts +320 -0
  34. package/dist/outbound-api.d.ts +320 -0
  35. package/dist/outbound-api.js +5218 -0
  36. package/dist/pipeline/SubscriptionAuthSource.cjs +131 -0
  37. package/dist/pipeline/SubscriptionAuthSource.d.cts +3 -0
  38. package/dist/pipeline/SubscriptionAuthSource.d.ts +3 -0
  39. package/dist/pipeline/SubscriptionAuthSource.js +103 -0
  40. package/dist/pipeline/SubscriptionAuthStrategy.cjs +18 -0
  41. package/dist/pipeline/SubscriptionAuthStrategy.d.cts +61 -0
  42. package/dist/pipeline/SubscriptionAuthStrategy.d.ts +61 -0
  43. package/dist/pipeline/SubscriptionAuthStrategy.js +0 -0
  44. package/dist/ports/gemini-code-assist-resolver.cjs +38 -0
  45. package/dist/ports/gemini-code-assist-resolver.d.cts +26 -0
  46. package/dist/ports/gemini-code-assist-resolver.d.ts +26 -0
  47. package/dist/ports/gemini-code-assist-resolver.js +12 -0
  48. package/dist/ports.cjs +18 -0
  49. package/dist/ports.d.cts +15 -0
  50. package/dist/ports.d.ts +15 -0
  51. package/dist/ports.js +0 -0
  52. package/dist/provider-proxy/ingress/providerProxyShared.cjs +2958 -0
  53. package/dist/provider-proxy/ingress/providerProxyShared.d.cts +77 -0
  54. package/dist/provider-proxy/ingress/providerProxyShared.d.ts +77 -0
  55. package/dist/provider-proxy/ingress/providerProxyShared.js +2925 -0
  56. package/dist/provider-proxy/matchText.cjs +73 -0
  57. package/dist/provider-proxy/matchText.d.cts +47 -0
  58. package/dist/provider-proxy/matchText.d.ts +47 -0
  59. package/dist/provider-proxy/matchText.js +45 -0
  60. package/dist/provider-proxy/types.cjs +18 -0
  61. package/dist/provider-proxy/types.d.cts +12 -0
  62. package/dist/provider-proxy/types.d.ts +12 -0
  63. package/dist/provider-proxy/types.js +0 -0
  64. package/dist/provider-proxy.cjs +4667 -0
  65. package/dist/provider-proxy.d.cts +69 -0
  66. package/dist/provider-proxy.d.ts +69 -0
  67. package/dist/provider-proxy.js +4636 -0
  68. package/dist/serializeError.cjs +82 -0
  69. package/dist/serializeError.d.cts +24 -0
  70. package/dist/serializeError.d.ts +24 -0
  71. package/dist/serializeError.js +57 -0
  72. package/dist/sse-parser.cjs +456 -0
  73. package/dist/sse-parser.d.cts +143 -0
  74. package/dist/sse-parser.d.ts +143 -0
  75. package/dist/sse-parser.js +430 -0
  76. package/dist/transformer/TransformerChainExecutor.cjs +321 -0
  77. package/dist/transformer/TransformerChainExecutor.d.cts +104 -0
  78. package/dist/transformer/TransformerChainExecutor.d.ts +104 -0
  79. package/dist/transformer/TransformerChainExecutor.js +294 -0
  80. package/dist/transformer/TransformerService.cjs +290 -0
  81. package/dist/transformer/TransformerService.d.cts +138 -0
  82. package/dist/transformer/TransformerService.d.ts +138 -0
  83. package/dist/transformer/TransformerService.js +265 -0
  84. package/dist/transformer/transformers/GeminiCodeAssistTransformer.cjs +1115 -0
  85. package/dist/transformer/transformers/GeminiCodeAssistTransformer.d.cts +102 -0
  86. package/dist/transformer/transformers/GeminiCodeAssistTransformer.d.ts +102 -0
  87. package/dist/transformer/transformers/GeminiCodeAssistTransformer.js +1085 -0
  88. package/dist/transformer/transformers/GeminiTransformer.cjs +1013 -0
  89. package/dist/transformer/transformers/GeminiTransformer.d.cts +70 -0
  90. package/dist/transformer/transformers/GeminiTransformer.d.ts +70 -0
  91. package/dist/transformer/transformers/GeminiTransformer.js +986 -0
  92. package/dist/transformer/transformers/OpenAIResponseTransformer.cjs +538 -0
  93. package/dist/transformer/transformers/OpenAIResponseTransformer.d.cts +53 -0
  94. package/dist/transformer/transformers/OpenAIResponseTransformer.d.ts +53 -0
  95. package/dist/transformer/transformers/OpenAIResponseTransformer.js +513 -0
  96. package/dist/transformer/transformers/OpenCodeGoTransformer.cjs +73 -0
  97. package/dist/transformer/transformers/OpenCodeGoTransformer.d.cts +51 -0
  98. package/dist/transformer/transformers/OpenCodeGoTransformer.d.ts +51 -0
  99. package/dist/transformer/transformers/OpenCodeGoTransformer.js +48 -0
  100. package/dist/transformer/types.cjs +18 -0
  101. package/dist/transformer/types.d.cts +405 -0
  102. package/dist/transformer/types.d.ts +405 -0
  103. package/dist/transformer/types.js +0 -0
  104. package/dist/transformer.cjs +3736 -0
  105. package/dist/transformer.d.cts +33 -0
  106. package/dist/transformer.d.ts +33 -0
  107. package/dist/transformer.js +3712 -0
  108. package/dist/types-CGGrKqC_.d.cts +142 -0
  109. package/dist/types-CbCN2NQP.d.ts +142 -0
  110. package/dist/types-DCzHkhJt.d.ts +467 -0
  111. package/dist/types-DZIQbgp0.d.cts +467 -0
  112. package/dist/usage-event-sink-BX7FE1NL.d.cts +59 -0
  113. package/dist/usage-event-sink-BX7FE1NL.d.ts +59 -0
  114. 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 };