@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,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
|
+
};
|