@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,138 @@
1
+ import { TransformerLogger, Transformer, TransformerConstructor, TransformerChainConfig, ResolvedTransformerChain, TransformerReference } from './types.cjs';
2
+
3
+ /**
4
+ * TransformerService - Core service for managing transformer lifecycle
5
+ *
6
+ * Handles transformer registration, retrieval, and initialization.
7
+ *
8
+ * Adapted from the `musistudio/llms` project (MIT, © 2025 musistudio) — the
9
+ * transformer IR upstream — for the Electron environment. See the package
10
+ * `NOTICE` for full third-party attribution.
11
+ *
12
+ * @module transformer/TransformerService
13
+ */
14
+
15
+ /**
16
+ * TransformerService manages the lifecycle of all transformers.
17
+ *
18
+ * Features:
19
+ * - Register transformers by name
20
+ * - Get transformer by name
21
+ * - Initialize default transformers
22
+ * - Resolve transformer chains from configuration
23
+ */
24
+ declare class TransformerService {
25
+ private transformers;
26
+ private logger;
27
+ private instanceCache;
28
+ private endpointTransformersCache;
29
+ private noEndpointTransformersCache;
30
+ constructor(logger?: TransformerLogger);
31
+ /**
32
+ * Clear instance caches
33
+ */
34
+ clearInstanceCache(): void;
35
+ /**
36
+ * Get cache statistics for diagnostics
37
+ */
38
+ getCacheStats(): {
39
+ instanceCacheSize: number;
40
+ hasEndpointCache: boolean;
41
+ };
42
+ /**
43
+ * Register a transformer by name
44
+ * @param name - Unique transformer name
45
+ * @param transformer - Transformer instance or constructor
46
+ */
47
+ registerTransformer(name: string, transformer: Transformer | TransformerConstructor): void;
48
+ /**
49
+ * Get a transformer by name
50
+ * @param name - Transformer name
51
+ * @returns Transformer instance/constructor or undefined
52
+ */
53
+ getTransformer(name: string): Transformer | TransformerConstructor | undefined;
54
+ /**
55
+ * Get all registered transformers
56
+ * @returns Map of all transformers
57
+ */
58
+ getAllTransformers(): Map<string, Transformer | TransformerConstructor>;
59
+ /**
60
+ * Get transformers that have an endpoint defined
61
+ * Uses cache to avoid redundant traversal
62
+ * @returns Array of transformers with endpoints
63
+ */
64
+ getTransformersWithEndpoint(): {
65
+ name: string;
66
+ transformer: Transformer;
67
+ }[];
68
+ /**
69
+ * Get transformers without endpoints
70
+ * Uses cache to avoid redundant traversal
71
+ * @returns Array of transformers without endpoints
72
+ */
73
+ getTransformersWithoutEndpoint(): {
74
+ name: string;
75
+ transformer: Transformer;
76
+ }[];
77
+ /**
78
+ * Remove a transformer by name
79
+ * @param name - Transformer name
80
+ * @returns true if removed, false if not found
81
+ */
82
+ removeTransformer(name: string): boolean;
83
+ /**
84
+ * Check if a transformer is registered
85
+ * @param name - Transformer name
86
+ * @returns true if registered
87
+ */
88
+ hasTransformer(name: string): boolean;
89
+ /**
90
+ * Initialize the service with default transformers
91
+ * @param defaultTransformers - Map or object of default transformers
92
+ */
93
+ initialize(defaultTransformers?: Record<string, Transformer | TransformerConstructor>): Promise<void>;
94
+ /**
95
+ * Register default transformers from a map
96
+ * @param transformers - Map of transformer name to transformer
97
+ */
98
+ private registerDefaultTransformers;
99
+ /**
100
+ * Resolve a transformer chain configuration to actual transformer instances
101
+ * @param chainConfig - Transformer chain configuration
102
+ * @param modelName - Model name for model-specific transformers
103
+ * @returns Resolved transformer chain with instances
104
+ */
105
+ resolveTransformerChain(chainConfig: TransformerChainConfig | undefined, modelName?: string): ResolvedTransformerChain;
106
+ /**
107
+ * Resolve an array of transformer references to instances
108
+ * @param refs - Array of transformer references
109
+ * @returns Array of transformer instances
110
+ */
111
+ resolveTransformerReferences(refs: TransformerReference[]): Transformer[];
112
+ /**
113
+ * Instantiate a transformer if it's a constructor
114
+ * Uses instance cache to avoid redundant instantiation
115
+ *
116
+ * @param transformer - Transformer instance or constructor
117
+ * @param options - Options to pass to constructor
118
+ * @returns Transformer instance
119
+ */
120
+ private instantiateIfNeeded;
121
+ /**
122
+ * Check if a value is a transformer constructor
123
+ * @param value - Value to check
124
+ * @returns true if it's a constructor
125
+ */
126
+ private isTransformerConstructor;
127
+ /**
128
+ * Get list of all registered transformer names
129
+ * @returns Array of transformer names
130
+ */
131
+ getTransformerNames(): string[];
132
+ /**
133
+ * Clear all registered transformers
134
+ */
135
+ clear(): void;
136
+ }
137
+
138
+ export { TransformerService };
@@ -0,0 +1,138 @@
1
+ import { TransformerLogger, Transformer, TransformerConstructor, TransformerChainConfig, ResolvedTransformerChain, TransformerReference } from './types.js';
2
+
3
+ /**
4
+ * TransformerService - Core service for managing transformer lifecycle
5
+ *
6
+ * Handles transformer registration, retrieval, and initialization.
7
+ *
8
+ * Adapted from the `musistudio/llms` project (MIT, © 2025 musistudio) — the
9
+ * transformer IR upstream — for the Electron environment. See the package
10
+ * `NOTICE` for full third-party attribution.
11
+ *
12
+ * @module transformer/TransformerService
13
+ */
14
+
15
+ /**
16
+ * TransformerService manages the lifecycle of all transformers.
17
+ *
18
+ * Features:
19
+ * - Register transformers by name
20
+ * - Get transformer by name
21
+ * - Initialize default transformers
22
+ * - Resolve transformer chains from configuration
23
+ */
24
+ declare class TransformerService {
25
+ private transformers;
26
+ private logger;
27
+ private instanceCache;
28
+ private endpointTransformersCache;
29
+ private noEndpointTransformersCache;
30
+ constructor(logger?: TransformerLogger);
31
+ /**
32
+ * Clear instance caches
33
+ */
34
+ clearInstanceCache(): void;
35
+ /**
36
+ * Get cache statistics for diagnostics
37
+ */
38
+ getCacheStats(): {
39
+ instanceCacheSize: number;
40
+ hasEndpointCache: boolean;
41
+ };
42
+ /**
43
+ * Register a transformer by name
44
+ * @param name - Unique transformer name
45
+ * @param transformer - Transformer instance or constructor
46
+ */
47
+ registerTransformer(name: string, transformer: Transformer | TransformerConstructor): void;
48
+ /**
49
+ * Get a transformer by name
50
+ * @param name - Transformer name
51
+ * @returns Transformer instance/constructor or undefined
52
+ */
53
+ getTransformer(name: string): Transformer | TransformerConstructor | undefined;
54
+ /**
55
+ * Get all registered transformers
56
+ * @returns Map of all transformers
57
+ */
58
+ getAllTransformers(): Map<string, Transformer | TransformerConstructor>;
59
+ /**
60
+ * Get transformers that have an endpoint defined
61
+ * Uses cache to avoid redundant traversal
62
+ * @returns Array of transformers with endpoints
63
+ */
64
+ getTransformersWithEndpoint(): {
65
+ name: string;
66
+ transformer: Transformer;
67
+ }[];
68
+ /**
69
+ * Get transformers without endpoints
70
+ * Uses cache to avoid redundant traversal
71
+ * @returns Array of transformers without endpoints
72
+ */
73
+ getTransformersWithoutEndpoint(): {
74
+ name: string;
75
+ transformer: Transformer;
76
+ }[];
77
+ /**
78
+ * Remove a transformer by name
79
+ * @param name - Transformer name
80
+ * @returns true if removed, false if not found
81
+ */
82
+ removeTransformer(name: string): boolean;
83
+ /**
84
+ * Check if a transformer is registered
85
+ * @param name - Transformer name
86
+ * @returns true if registered
87
+ */
88
+ hasTransformer(name: string): boolean;
89
+ /**
90
+ * Initialize the service with default transformers
91
+ * @param defaultTransformers - Map or object of default transformers
92
+ */
93
+ initialize(defaultTransformers?: Record<string, Transformer | TransformerConstructor>): Promise<void>;
94
+ /**
95
+ * Register default transformers from a map
96
+ * @param transformers - Map of transformer name to transformer
97
+ */
98
+ private registerDefaultTransformers;
99
+ /**
100
+ * Resolve a transformer chain configuration to actual transformer instances
101
+ * @param chainConfig - Transformer chain configuration
102
+ * @param modelName - Model name for model-specific transformers
103
+ * @returns Resolved transformer chain with instances
104
+ */
105
+ resolveTransformerChain(chainConfig: TransformerChainConfig | undefined, modelName?: string): ResolvedTransformerChain;
106
+ /**
107
+ * Resolve an array of transformer references to instances
108
+ * @param refs - Array of transformer references
109
+ * @returns Array of transformer instances
110
+ */
111
+ resolveTransformerReferences(refs: TransformerReference[]): Transformer[];
112
+ /**
113
+ * Instantiate a transformer if it's a constructor
114
+ * Uses instance cache to avoid redundant instantiation
115
+ *
116
+ * @param transformer - Transformer instance or constructor
117
+ * @param options - Options to pass to constructor
118
+ * @returns Transformer instance
119
+ */
120
+ private instantiateIfNeeded;
121
+ /**
122
+ * Check if a value is a transformer constructor
123
+ * @param value - Value to check
124
+ * @returns true if it's a constructor
125
+ */
126
+ private isTransformerConstructor;
127
+ /**
128
+ * Get list of all registered transformer names
129
+ * @returns Array of transformer names
130
+ */
131
+ getTransformerNames(): string[];
132
+ /**
133
+ * Clear all registered transformers
134
+ */
135
+ clear(): void;
136
+ }
137
+
138
+ export { TransformerService };
@@ -0,0 +1,265 @@
1
+ // src/transformer/TransformerService.ts
2
+ var defaultLogger = {
3
+ debug: (msg, ...args) => console.debug(`[TransformerService] ${msg}`, ...args),
4
+ info: (msg, ...args) => console.info(`[TransformerService] ${msg}`, ...args),
5
+ warn: (msg, ...args) => console.warn(`[TransformerService] ${msg}`, ...args),
6
+ error: (msg, ...args) => console.error(`[TransformerService] ${msg}`, ...args)
7
+ };
8
+ var TransformerService = class {
9
+ transformers = /* @__PURE__ */ new Map();
10
+ logger;
11
+ // Performance optimization: Cache instantiated transformers
12
+ instanceCache = /* @__PURE__ */ new Map();
13
+ // Performance optimization: Cache endpoint transformer results
14
+ endpointTransformersCache = null;
15
+ noEndpointTransformersCache = null;
16
+ constructor(logger) {
17
+ this.logger = logger ?? defaultLogger;
18
+ }
19
+ /**
20
+ * Clear instance caches
21
+ */
22
+ clearInstanceCache() {
23
+ this.instanceCache.clear();
24
+ this.endpointTransformersCache = null;
25
+ this.noEndpointTransformersCache = null;
26
+ }
27
+ /**
28
+ * Get cache statistics for diagnostics
29
+ */
30
+ getCacheStats() {
31
+ return {
32
+ instanceCacheSize: this.instanceCache.size,
33
+ hasEndpointCache: this.endpointTransformersCache !== null
34
+ };
35
+ }
36
+ /**
37
+ * Register a transformer by name
38
+ * @param name - Unique transformer name
39
+ * @param transformer - Transformer instance or constructor
40
+ */
41
+ registerTransformer(name, transformer) {
42
+ this.transformers.set(name, transformer);
43
+ this.clearInstanceCache();
44
+ const endpoint = "endPoint" in transformer ? transformer.endPoint : "prototype" in transformer && transformer.prototype?.endPoint ? transformer.prototype.endPoint : void 0;
45
+ this.logger.info(
46
+ `Registered transformer: ${name}${endpoint ? ` (endpoint: ${endpoint})` : " (no endpoint)"}`
47
+ );
48
+ }
49
+ /**
50
+ * Get a transformer by name
51
+ * @param name - Transformer name
52
+ * @returns Transformer instance/constructor or undefined
53
+ */
54
+ getTransformer(name) {
55
+ return this.transformers.get(name);
56
+ }
57
+ /**
58
+ * Get all registered transformers
59
+ * @returns Map of all transformers
60
+ */
61
+ getAllTransformers() {
62
+ return new Map(this.transformers);
63
+ }
64
+ /**
65
+ * Get transformers that have an endpoint defined
66
+ * Uses cache to avoid redundant traversal
67
+ * @returns Array of transformers with endpoints
68
+ */
69
+ getTransformersWithEndpoint() {
70
+ if (this.endpointTransformersCache) {
71
+ return this.endpointTransformersCache;
72
+ }
73
+ const result = [];
74
+ this.transformers.forEach((transformer, name) => {
75
+ const instance = this.instantiateIfNeeded(transformer);
76
+ if (instance?.endPoint) {
77
+ result.push({ name, transformer: instance });
78
+ }
79
+ });
80
+ this.endpointTransformersCache = result;
81
+ return result;
82
+ }
83
+ /**
84
+ * Get transformers without endpoints
85
+ * Uses cache to avoid redundant traversal
86
+ * @returns Array of transformers without endpoints
87
+ */
88
+ getTransformersWithoutEndpoint() {
89
+ if (this.noEndpointTransformersCache) {
90
+ return this.noEndpointTransformersCache;
91
+ }
92
+ const result = [];
93
+ this.transformers.forEach((transformer, name) => {
94
+ const instance = this.instantiateIfNeeded(transformer);
95
+ if (instance && !instance.endPoint) {
96
+ result.push({ name, transformer: instance });
97
+ }
98
+ });
99
+ this.noEndpointTransformersCache = result;
100
+ return result;
101
+ }
102
+ /**
103
+ * Remove a transformer by name
104
+ * @param name - Transformer name
105
+ * @returns true if removed, false if not found
106
+ */
107
+ removeTransformer(name) {
108
+ const removed = this.transformers.delete(name);
109
+ if (removed) {
110
+ this.clearInstanceCache();
111
+ }
112
+ return removed;
113
+ }
114
+ /**
115
+ * Check if a transformer is registered
116
+ * @param name - Transformer name
117
+ * @returns true if registered
118
+ */
119
+ hasTransformer(name) {
120
+ return this.transformers.has(name);
121
+ }
122
+ /**
123
+ * Initialize the service with default transformers
124
+ * @param defaultTransformers - Map or object of default transformers
125
+ */
126
+ async initialize(defaultTransformers) {
127
+ try {
128
+ if (defaultTransformers) {
129
+ await this.registerDefaultTransformers(defaultTransformers);
130
+ }
131
+ this.logger.info(
132
+ `TransformerService initialized with ${this.transformers.size} transformers`
133
+ );
134
+ } catch (error) {
135
+ const errorMessage = error instanceof Error ? error.message : String(error);
136
+ this.logger.error(`TransformerService init error: ${errorMessage}`);
137
+ throw error;
138
+ }
139
+ }
140
+ /**
141
+ * Register default transformers from a map
142
+ * @param transformers - Map of transformer name to transformer
143
+ */
144
+ async registerDefaultTransformers(transformers) {
145
+ for (const [key, TransformerClass] of Object.entries(transformers)) {
146
+ try {
147
+ if (this.isTransformerConstructor(TransformerClass)) {
148
+ const staticName = TransformerClass.TransformerName ?? key;
149
+ this.registerTransformer(staticName, TransformerClass);
150
+ } else {
151
+ const name = TransformerClass.name ?? key;
152
+ TransformerClass.logger = this.logger;
153
+ this.registerTransformer(name, TransformerClass);
154
+ }
155
+ } catch (error) {
156
+ const errorMessage = error instanceof Error ? error.message : String(error);
157
+ this.logger.error(`Failed to register transformer ${key}: ${errorMessage}`);
158
+ }
159
+ }
160
+ }
161
+ /**
162
+ * Resolve a transformer chain configuration to actual transformer instances
163
+ * @param chainConfig - Transformer chain configuration
164
+ * @param modelName - Model name for model-specific transformers
165
+ * @returns Resolved transformer chain with instances
166
+ */
167
+ resolveTransformerChain(chainConfig, modelName) {
168
+ const result = {
169
+ providerTransformers: [],
170
+ modelTransformers: []
171
+ };
172
+ if (!chainConfig) {
173
+ return result;
174
+ }
175
+ if (chainConfig.use) {
176
+ result.providerTransformers = this.resolveTransformerReferences(chainConfig.use);
177
+ }
178
+ if (modelName && chainConfig[modelName]) {
179
+ const modelConfig = chainConfig[modelName];
180
+ if (Array.isArray(modelConfig)) {
181
+ result.modelTransformers = this.resolveTransformerReferences(modelConfig);
182
+ } else if (modelConfig && typeof modelConfig === "object" && "use" in modelConfig) {
183
+ result.modelTransformers = this.resolveTransformerReferences(modelConfig.use ?? []);
184
+ }
185
+ }
186
+ return result;
187
+ }
188
+ /**
189
+ * Resolve an array of transformer references to instances
190
+ * @param refs - Array of transformer references
191
+ * @returns Array of transformer instances
192
+ */
193
+ resolveTransformerReferences(refs) {
194
+ const instances = [];
195
+ for (const ref of refs) {
196
+ const [name, options] = Array.isArray(ref) ? ref : [ref, void 0];
197
+ const transformer = this.getTransformer(name);
198
+ if (!transformer) {
199
+ this.logger.warn(`Transformer not found: ${name}`);
200
+ continue;
201
+ }
202
+ const instance = this.instantiateIfNeeded(transformer, options);
203
+ if (instance) {
204
+ instance.logger = this.logger;
205
+ instances.push(instance);
206
+ }
207
+ }
208
+ return instances;
209
+ }
210
+ /**
211
+ * Instantiate a transformer if it's a constructor
212
+ * Uses instance cache to avoid redundant instantiation
213
+ *
214
+ * @param transformer - Transformer instance or constructor
215
+ * @param options - Options to pass to constructor
216
+ * @returns Transformer instance
217
+ */
218
+ instantiateIfNeeded(transformer, options) {
219
+ if (!this.isTransformerConstructor(transformer)) {
220
+ return transformer;
221
+ }
222
+ const constructorName = transformer.TransformerName || transformer.name || "anonymous";
223
+ const optionsHash = options ? JSON.stringify(options) : "";
224
+ const cacheKey = `${constructorName}:${optionsHash}`;
225
+ if (this.instanceCache.has(cacheKey)) {
226
+ return this.instanceCache.get(cacheKey);
227
+ }
228
+ try {
229
+ const instance = new transformer(options);
230
+ instance.logger = this.logger;
231
+ this.instanceCache.set(cacheKey, instance);
232
+ return instance;
233
+ } catch (error) {
234
+ const errorMessage = error instanceof Error ? error.message : String(error);
235
+ this.logger.error(`Failed to instantiate transformer: ${errorMessage}`);
236
+ return void 0;
237
+ }
238
+ }
239
+ /**
240
+ * Check if a value is a transformer constructor
241
+ * @param value - Value to check
242
+ * @returns true if it's a constructor
243
+ */
244
+ isTransformerConstructor(value) {
245
+ return typeof value === "function" && value.prototype && (typeof value.prototype.transformRequestIn === "function" || typeof value.prototype.transformRequestOut === "function" || typeof value.prototype.transformResponseIn === "function" || typeof value.prototype.transformResponseOut === "function" || "TransformerName" in value);
246
+ }
247
+ /**
248
+ * Get list of all registered transformer names
249
+ * @returns Array of transformer names
250
+ */
251
+ getTransformerNames() {
252
+ return Array.from(this.transformers.keys());
253
+ }
254
+ /**
255
+ * Clear all registered transformers
256
+ */
257
+ clear() {
258
+ this.transformers.clear();
259
+ this.clearInstanceCache();
260
+ this.logger.info("All transformers cleared");
261
+ }
262
+ };
263
+ export {
264
+ TransformerService
265
+ };