@smythos/sre 1.5.53 → 1.5.54
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/CHANGELOG +98 -98
- package/LICENSE +18 -18
- package/README.md +135 -135
- package/dist/bundle-analysis-lazy.html +4949 -0
- package/dist/bundle-analysis.html +4949 -0
- package/dist/index.js +3 -3
- package/dist/index.js.map +1 -1
- package/dist/types/subsystems/LLMManager/LLM.service/connectors/openai/OpenAIConnector.class.d.ts +1 -6
- package/dist/types/utils/package-manager.utils.d.ts +26 -0
- package/package.json +1 -1
- package/src/Components/APICall/APICall.class.ts +157 -157
- package/src/Components/APICall/AccessTokenManager.ts +166 -166
- package/src/Components/APICall/ArrayBufferResponse.helper.ts +58 -58
- package/src/Components/APICall/OAuth.helper.ts +447 -447
- package/src/Components/APICall/mimeTypeCategories.ts +46 -46
- package/src/Components/APICall/parseData.ts +167 -167
- package/src/Components/APICall/parseHeaders.ts +41 -41
- package/src/Components/APICall/parseProxy.ts +68 -68
- package/src/Components/APICall/parseUrl.ts +91 -91
- package/src/Components/APIEndpoint.class.ts +234 -234
- package/src/Components/APIOutput.class.ts +58 -58
- package/src/Components/AgentPlugin.class.ts +102 -102
- package/src/Components/Async.class.ts +155 -155
- package/src/Components/Await.class.ts +90 -90
- package/src/Components/Classifier.class.ts +158 -158
- package/src/Components/Component.class.ts +132 -132
- package/src/Components/ComponentHost.class.ts +38 -38
- package/src/Components/DataSourceCleaner.class.ts +92 -92
- package/src/Components/DataSourceIndexer.class.ts +181 -181
- package/src/Components/DataSourceLookup.class.ts +161 -161
- package/src/Components/ECMASandbox.class.ts +71 -71
- package/src/Components/FEncDec.class.ts +29 -29
- package/src/Components/FHash.class.ts +33 -33
- package/src/Components/FSign.class.ts +80 -80
- package/src/Components/FSleep.class.ts +25 -25
- package/src/Components/FTimestamp.class.ts +25 -25
- package/src/Components/FileStore.class.ts +78 -78
- package/src/Components/ForEach.class.ts +97 -97
- package/src/Components/GPTPlugin.class.ts +70 -70
- package/src/Components/GenAILLM.class.ts +586 -586
- package/src/Components/HuggingFace.class.ts +314 -314
- package/src/Components/Image/imageSettings.config.ts +70 -70
- package/src/Components/ImageGenerator.class.ts +502 -502
- package/src/Components/JSONFilter.class.ts +54 -54
- package/src/Components/LLMAssistant.class.ts +213 -213
- package/src/Components/LogicAND.class.ts +28 -28
- package/src/Components/LogicAtLeast.class.ts +85 -85
- package/src/Components/LogicAtMost.class.ts +86 -86
- package/src/Components/LogicOR.class.ts +29 -29
- package/src/Components/LogicXOR.class.ts +34 -34
- package/src/Components/MCPClient.class.ts +138 -138
- package/src/Components/MemoryDeleteKeyVal.class.ts +70 -70
- package/src/Components/MemoryReadKeyVal.class.ts +66 -66
- package/src/Components/MemoryWriteKeyVal.class.ts +62 -62
- package/src/Components/MemoryWriteObject.class.ts +97 -97
- package/src/Components/MultimodalLLM.class.ts +128 -128
- package/src/Components/OpenAPI.class.ts +72 -72
- package/src/Components/PromptGenerator.class.ts +122 -122
- package/src/Components/ScrapflyWebScrape.class.ts +159 -159
- package/src/Components/ServerlessCode.class.ts +123 -123
- package/src/Components/TavilyWebSearch.class.ts +98 -98
- package/src/Components/VisionLLM.class.ts +104 -104
- package/src/Components/ZapierAction.class.ts +127 -127
- package/src/Components/index.ts +97 -97
- package/src/Core/AgentProcess.helper.ts +240 -240
- package/src/Core/Connector.class.ts +123 -123
- package/src/Core/ConnectorsService.ts +197 -197
- package/src/Core/DummyConnector.ts +49 -49
- package/src/Core/HookService.ts +105 -105
- package/src/Core/SmythRuntime.class.ts +235 -235
- package/src/Core/SystemEvents.ts +16 -16
- package/src/Core/boot.ts +56 -56
- package/src/config.ts +15 -15
- package/src/constants.ts +126 -126
- package/src/data/hugging-face.params.json +579 -579
- package/src/helpers/AWSLambdaCode.helper.ts +590 -590
- package/src/helpers/BinaryInput.helper.ts +331 -331
- package/src/helpers/Conversation.helper.ts +1119 -1119
- package/src/helpers/ECMASandbox.helper.ts +54 -54
- package/src/helpers/JsonContent.helper.ts +97 -97
- package/src/helpers/LocalCache.helper.ts +97 -97
- package/src/helpers/Log.helper.ts +274 -274
- package/src/helpers/OpenApiParser.helper.ts +150 -150
- package/src/helpers/S3Cache.helper.ts +147 -147
- package/src/helpers/SmythURI.helper.ts +5 -5
- package/src/helpers/Sysconfig.helper.ts +77 -77
- package/src/helpers/TemplateString.helper.ts +243 -243
- package/src/helpers/TypeChecker.helper.ts +329 -329
- package/src/index.ts +3 -3
- package/src/index.ts.bak +3 -3
- package/src/subsystems/AgentManager/Agent.class.ts +1114 -1114
- package/src/subsystems/AgentManager/Agent.helper.ts +3 -3
- package/src/subsystems/AgentManager/AgentData.service/AgentDataConnector.ts +230 -230
- package/src/subsystems/AgentManager/AgentData.service/connectors/CLIAgentDataConnector.class.ts +66 -66
- package/src/subsystems/AgentManager/AgentData.service/connectors/LocalAgentDataConnector.class.ts +142 -142
- package/src/subsystems/AgentManager/AgentData.service/connectors/NullAgentData.class.ts +39 -39
- package/src/subsystems/AgentManager/AgentData.service/index.ts +18 -18
- package/src/subsystems/AgentManager/AgentLogger.class.ts +301 -297
- package/src/subsystems/AgentManager/AgentRequest.class.ts +51 -51
- package/src/subsystems/AgentManager/AgentRuntime.class.ts +559 -559
- package/src/subsystems/AgentManager/AgentSSE.class.ts +101 -101
- package/src/subsystems/AgentManager/AgentSettings.class.ts +52 -52
- package/src/subsystems/AgentManager/Component.service/ComponentConnector.ts +32 -32
- package/src/subsystems/AgentManager/Component.service/connectors/LocalComponentConnector.class.ts +60 -60
- package/src/subsystems/AgentManager/Component.service/index.ts +11 -11
- package/src/subsystems/AgentManager/EmbodimentSettings.class.ts +47 -47
- package/src/subsystems/AgentManager/ForkedAgent.class.ts +154 -154
- package/src/subsystems/AgentManager/OSResourceMonitor.ts +77 -77
- package/src/subsystems/ComputeManager/Code.service/CodeConnector.ts +98 -98
- package/src/subsystems/ComputeManager/Code.service/connectors/AWSLambdaCode.class.ts +172 -172
- package/src/subsystems/ComputeManager/Code.service/connectors/ECMASandbox.class.ts +131 -131
- package/src/subsystems/ComputeManager/Code.service/index.ts +13 -13
- package/src/subsystems/IO/CLI.service/CLIConnector.ts +47 -47
- package/src/subsystems/IO/CLI.service/index.ts +9 -9
- package/src/subsystems/IO/Log.service/LogConnector.ts +32 -32
- package/src/subsystems/IO/Log.service/connectors/ConsoleLog.class.ts +28 -28
- package/src/subsystems/IO/Log.service/index.ts +13 -13
- package/src/subsystems/IO/NKV.service/NKVConnector.ts +43 -43
- package/src/subsystems/IO/NKV.service/connectors/NKVLocalStorage.class.ts +234 -234
- package/src/subsystems/IO/NKV.service/connectors/NKVRAM.class.ts +204 -204
- package/src/subsystems/IO/NKV.service/connectors/NKVRedis.class.ts +182 -182
- package/src/subsystems/IO/NKV.service/index.ts +14 -14
- package/src/subsystems/IO/Router.service/RouterConnector.ts +21 -21
- package/src/subsystems/IO/Router.service/connectors/ExpressRouter.class.ts +48 -48
- package/src/subsystems/IO/Router.service/connectors/NullRouter.class.ts +40 -40
- package/src/subsystems/IO/Router.service/index.ts +11 -11
- package/src/subsystems/IO/Storage.service/SmythFS.class.ts +489 -489
- package/src/subsystems/IO/Storage.service/StorageConnector.ts +66 -66
- package/src/subsystems/IO/Storage.service/connectors/LocalStorage.class.ts +327 -327
- package/src/subsystems/IO/Storage.service/connectors/S3Storage.class.ts +482 -482
- package/src/subsystems/IO/Storage.service/index.ts +13 -13
- package/src/subsystems/IO/VectorDB.service/VectorDBConnector.ts +108 -108
- package/src/subsystems/IO/VectorDB.service/connectors/MilvusVectorDB.class.ts +454 -454
- package/src/subsystems/IO/VectorDB.service/connectors/PineconeVectorDB.class.ts +384 -384
- package/src/subsystems/IO/VectorDB.service/connectors/RAMVecrtorDB.class.ts +421 -421
- package/src/subsystems/IO/VectorDB.service/embed/BaseEmbedding.ts +107 -107
- package/src/subsystems/IO/VectorDB.service/embed/OpenAIEmbedding.ts +109 -109
- package/src/subsystems/IO/VectorDB.service/embed/index.ts +21 -21
- package/src/subsystems/IO/VectorDB.service/index.ts +14 -14
- package/src/subsystems/LLMManager/LLM.helper.ts +251 -251
- package/src/subsystems/LLMManager/LLM.inference.ts +339 -339
- package/src/subsystems/LLMManager/LLM.service/LLMConnector.ts +489 -489
- package/src/subsystems/LLMManager/LLM.service/LLMCredentials.helper.ts +171 -171
- package/src/subsystems/LLMManager/LLM.service/connectors/Anthropic.class.ts +659 -659
- package/src/subsystems/LLMManager/LLM.service/connectors/Bedrock.class.ts +400 -400
- package/src/subsystems/LLMManager/LLM.service/connectors/Echo.class.ts +77 -77
- package/src/subsystems/LLMManager/LLM.service/connectors/GoogleAI.class.ts +757 -757
- package/src/subsystems/LLMManager/LLM.service/connectors/Groq.class.ts +304 -304
- package/src/subsystems/LLMManager/LLM.service/connectors/Perplexity.class.ts +250 -250
- package/src/subsystems/LLMManager/LLM.service/connectors/VertexAI.class.ts +423 -423
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/OpenAIConnector.class.ts +488 -488
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/ChatCompletionsApiInterface.ts +524 -524
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/OpenAIApiInterface.ts +100 -100
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/OpenAIApiInterfaceFactory.ts +81 -81
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/ResponsesApiInterface.ts +1145 -1145
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/constants.ts +13 -13
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/index.ts +4 -4
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/apiInterfaces/utils.ts +11 -11
- package/src/subsystems/LLMManager/LLM.service/connectors/openai/types.ts +32 -32
- package/src/subsystems/LLMManager/LLM.service/connectors/xAI.class.ts +471 -471
- package/src/subsystems/LLMManager/LLM.service/index.ts +44 -44
- package/src/subsystems/LLMManager/ModelsProvider.service/ModelsProviderConnector.ts +300 -300
- package/src/subsystems/LLMManager/ModelsProvider.service/connectors/JSONModelsProvider.class.ts +252 -252
- package/src/subsystems/LLMManager/ModelsProvider.service/index.ts +11 -11
- package/src/subsystems/LLMManager/custom-models.ts +854 -854
- package/src/subsystems/LLMManager/models.ts +2540 -2540
- package/src/subsystems/LLMManager/paramMappings.ts +69 -69
- package/src/subsystems/MemoryManager/Cache.service/CacheConnector.ts +86 -86
- package/src/subsystems/MemoryManager/Cache.service/connectors/LocalStorageCache.class.ts +297 -297
- package/src/subsystems/MemoryManager/Cache.service/connectors/RAMCache.class.ts +201 -201
- package/src/subsystems/MemoryManager/Cache.service/connectors/RedisCache.class.ts +252 -252
- package/src/subsystems/MemoryManager/Cache.service/connectors/S3Cache.class.ts +373 -373
- package/src/subsystems/MemoryManager/Cache.service/index.ts +15 -15
- package/src/subsystems/MemoryManager/LLMCache.ts +72 -72
- package/src/subsystems/MemoryManager/LLMContext.ts +124 -124
- package/src/subsystems/MemoryManager/LLMMemory.service/LLMMemoryConnector.ts +26 -26
- package/src/subsystems/MemoryManager/RuntimeContext.ts +266 -266
- package/src/subsystems/Security/AccessControl/ACL.class.ts +208 -208
- package/src/subsystems/Security/AccessControl/AccessCandidate.class.ts +82 -82
- package/src/subsystems/Security/AccessControl/AccessRequest.class.ts +52 -52
- package/src/subsystems/Security/Account.service/AccountConnector.ts +44 -44
- package/src/subsystems/Security/Account.service/connectors/AWSAccount.class.ts +76 -76
- package/src/subsystems/Security/Account.service/connectors/DummyAccount.class.ts +130 -130
- package/src/subsystems/Security/Account.service/connectors/JSONFileAccount.class.ts +159 -159
- package/src/subsystems/Security/Account.service/index.ts +14 -14
- package/src/subsystems/Security/Credentials.helper.ts +62 -62
- package/src/subsystems/Security/ManagedVault.service/ManagedVaultConnector.ts +38 -38
- package/src/subsystems/Security/ManagedVault.service/connectors/NullManagedVault.class.ts +53 -53
- package/src/subsystems/Security/ManagedVault.service/connectors/SecretManagerManagedVault.ts +154 -154
- package/src/subsystems/Security/ManagedVault.service/index.ts +12 -12
- package/src/subsystems/Security/SecureConnector.class.ts +110 -110
- package/src/subsystems/Security/Vault.service/Vault.helper.ts +30 -30
- package/src/subsystems/Security/Vault.service/VaultConnector.ts +29 -29
- package/src/subsystems/Security/Vault.service/connectors/HashicorpVault.class.ts +46 -46
- package/src/subsystems/Security/Vault.service/connectors/JSONFileVault.class.ts +221 -221
- package/src/subsystems/Security/Vault.service/connectors/NullVault.class.ts +54 -54
- package/src/subsystems/Security/Vault.service/connectors/SecretsManager.class.ts +140 -140
- package/src/subsystems/Security/Vault.service/index.ts +12 -12
- package/src/types/ACL.types.ts +104 -104
- package/src/types/AWS.types.ts +10 -10
- package/src/types/Agent.types.ts +61 -61
- package/src/types/AgentLogger.types.ts +17 -17
- package/src/types/Cache.types.ts +1 -1
- package/src/types/Common.types.ts +2 -2
- package/src/types/LLM.types.ts +496 -496
- package/src/types/Redis.types.ts +8 -8
- package/src/types/SRE.types.ts +64 -64
- package/src/types/Security.types.ts +14 -14
- package/src/types/Storage.types.ts +5 -5
- package/src/types/VectorDB.types.ts +86 -86
- package/src/utils/base64.utils.ts +275 -275
- package/src/utils/cli.utils.ts +68 -68
- package/src/utils/data.utils.ts +322 -322
- package/src/utils/date-time.utils.ts +22 -22
- package/src/utils/general.utils.ts +238 -238
- package/src/utils/index.ts +12 -12
- package/src/utils/lazy-client.ts +261 -261
- package/src/utils/numbers.utils.ts +13 -13
- package/src/utils/oauth.utils.ts +35 -35
- package/src/utils/string.utils.ts +414 -414
- package/src/utils/url.utils.ts +19 -19
- package/src/utils/validation.utils.ts +74 -74
- package/dist/types/subsystems/LLMManager/ModelsProvider.service/connectors/SmythModelsProvider.class.d.ts +0 -39
|
@@ -1,123 +1,123 @@
|
|
|
1
|
-
import { LocalCache } from '@sre/helpers/LocalCache.helper';
|
|
2
|
-
import { Logger } from '../helpers/Log.helper';
|
|
3
|
-
import { createHash } from 'crypto';
|
|
4
|
-
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
5
|
-
|
|
6
|
-
const console = Logger('Connector');
|
|
7
|
-
//const lCache = new LocalCache();
|
|
8
|
-
|
|
9
|
-
export class Connector<TRequest = any> {
|
|
10
|
-
public name: string;
|
|
11
|
-
public started = false;
|
|
12
|
-
private _interactionHandler: () => void;
|
|
13
|
-
private _readyPromise: Promise<boolean>;
|
|
14
|
-
private static lCache = new LocalCache();
|
|
15
|
-
|
|
16
|
-
public get settings() {
|
|
17
|
-
return this._settings;
|
|
18
|
-
}
|
|
19
|
-
|
|
20
|
-
public get interactionHandler() {
|
|
21
|
-
return this._interactionHandler;
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
//this flag is used to check if the connector is valid
|
|
25
|
-
//when a connector fails to load, it is replaced by a DummyConnector instance which returns false for this flag
|
|
26
|
-
public get valid() {
|
|
27
|
-
return true;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
constructor(protected _settings?: any) {
|
|
31
|
-
//TODO : check if smyth runtime is initialized and throw an error if it is not
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* If the connector is interactive, The connector initializer will wait for start() method to complete before loading the next connector
|
|
36
|
-
*/
|
|
37
|
-
protected setInteraction(handler: () => void) {
|
|
38
|
-
this._interactionHandler = handler;
|
|
39
|
-
}
|
|
40
|
-
/**
|
|
41
|
-
* Creates a new instance of the current class using the provided settings.
|
|
42
|
-
* This method can be called on both Connector instances and its subclasses.
|
|
43
|
-
* This is used when we need to create a connector instance with a specific configuration (for example with user provided keys)
|
|
44
|
-
*
|
|
45
|
-
* @param settings - Configuration settings for the new instance.
|
|
46
|
-
* @returns A new instance of the current class.
|
|
47
|
-
*/
|
|
48
|
-
public instance(settings: any): this {
|
|
49
|
-
const configHash = createHash('sha256')
|
|
50
|
-
.update(JSON.stringify(settings || {}))
|
|
51
|
-
.digest('hex');
|
|
52
|
-
const key = `${this.name}-${configHash}`;
|
|
53
|
-
|
|
54
|
-
if (Connector.lCache.has(key)) {
|
|
55
|
-
return Connector.lCache.get(key) as this;
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
// if not in cache, create a new instance from the concrete class
|
|
59
|
-
const constructor = this.constructor as { new (config: any): any };
|
|
60
|
-
const instance = new constructor(settings);
|
|
61
|
-
Connector.lCache.set(key, instance, 60 * 60 * 1000); // cache for 1 hour
|
|
62
|
-
|
|
63
|
-
return instance;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
static isValid(connector: Connector): boolean {
|
|
67
|
-
return connector.name !== undefined && connector.name !== null && connector.name !== '';
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
public async start() {
|
|
71
|
-
console.info(`Starting ${this.name} connector ...`);
|
|
72
|
-
this.started = true;
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
public async stop() {
|
|
76
|
-
console.info(`Stopping ${this.name} connector ...`);
|
|
77
|
-
}
|
|
78
|
-
|
|
79
|
-
public ready() {
|
|
80
|
-
if (!this._readyPromise) {
|
|
81
|
-
this._readyPromise = new Promise((resolve) => {
|
|
82
|
-
let maxWait = 60000;
|
|
83
|
-
const tick = 100;
|
|
84
|
-
if (this.started) {
|
|
85
|
-
resolve(true);
|
|
86
|
-
} else {
|
|
87
|
-
const interval = setInterval(() => {
|
|
88
|
-
if (this.started) {
|
|
89
|
-
clearInterval(interval);
|
|
90
|
-
resolve(true);
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
maxWait -= tick;
|
|
94
|
-
if (maxWait <= 0) {
|
|
95
|
-
clearInterval(interval);
|
|
96
|
-
resolve(false);
|
|
97
|
-
}
|
|
98
|
-
}, tick);
|
|
99
|
-
}
|
|
100
|
-
});
|
|
101
|
-
}
|
|
102
|
-
return this._readyPromise;
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
public requester(candidate: AccessCandidate): TRequest {
|
|
106
|
-
return null as TRequest;
|
|
107
|
-
}
|
|
108
|
-
|
|
109
|
-
public user(candidate: AccessCandidate | string): TRequest {
|
|
110
|
-
if (typeof candidate === 'string') {
|
|
111
|
-
return this.requester(AccessCandidate.user(candidate));
|
|
112
|
-
}
|
|
113
|
-
return this.requester(candidate);
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
public team(teamId: string): TRequest {
|
|
117
|
-
return this.requester(AccessCandidate.team(teamId));
|
|
118
|
-
}
|
|
119
|
-
|
|
120
|
-
public agent(agentId: string): TRequest {
|
|
121
|
-
return this.requester(AccessCandidate.agent(agentId));
|
|
122
|
-
}
|
|
123
|
-
}
|
|
1
|
+
import { LocalCache } from '@sre/helpers/LocalCache.helper';
|
|
2
|
+
import { Logger } from '../helpers/Log.helper';
|
|
3
|
+
import { createHash } from 'crypto';
|
|
4
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
5
|
+
|
|
6
|
+
const console = Logger('Connector');
|
|
7
|
+
//const lCache = new LocalCache();
|
|
8
|
+
|
|
9
|
+
export class Connector<TRequest = any> {
|
|
10
|
+
public name: string;
|
|
11
|
+
public started = false;
|
|
12
|
+
private _interactionHandler: () => void;
|
|
13
|
+
private _readyPromise: Promise<boolean>;
|
|
14
|
+
private static lCache = new LocalCache();
|
|
15
|
+
|
|
16
|
+
public get settings() {
|
|
17
|
+
return this._settings;
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
public get interactionHandler() {
|
|
21
|
+
return this._interactionHandler;
|
|
22
|
+
}
|
|
23
|
+
|
|
24
|
+
//this flag is used to check if the connector is valid
|
|
25
|
+
//when a connector fails to load, it is replaced by a DummyConnector instance which returns false for this flag
|
|
26
|
+
public get valid() {
|
|
27
|
+
return true;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
constructor(protected _settings?: any) {
|
|
31
|
+
//TODO : check if smyth runtime is initialized and throw an error if it is not
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
/**
|
|
35
|
+
* If the connector is interactive, The connector initializer will wait for start() method to complete before loading the next connector
|
|
36
|
+
*/
|
|
37
|
+
protected setInteraction(handler: () => void) {
|
|
38
|
+
this._interactionHandler = handler;
|
|
39
|
+
}
|
|
40
|
+
/**
|
|
41
|
+
* Creates a new instance of the current class using the provided settings.
|
|
42
|
+
* This method can be called on both Connector instances and its subclasses.
|
|
43
|
+
* This is used when we need to create a connector instance with a specific configuration (for example with user provided keys)
|
|
44
|
+
*
|
|
45
|
+
* @param settings - Configuration settings for the new instance.
|
|
46
|
+
* @returns A new instance of the current class.
|
|
47
|
+
*/
|
|
48
|
+
public instance(settings: any): this {
|
|
49
|
+
const configHash = createHash('sha256')
|
|
50
|
+
.update(JSON.stringify(settings || {}))
|
|
51
|
+
.digest('hex');
|
|
52
|
+
const key = `${this.name}-${configHash}`;
|
|
53
|
+
|
|
54
|
+
if (Connector.lCache.has(key)) {
|
|
55
|
+
return Connector.lCache.get(key) as this;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
// if not in cache, create a new instance from the concrete class
|
|
59
|
+
const constructor = this.constructor as { new (config: any): any };
|
|
60
|
+
const instance = new constructor(settings);
|
|
61
|
+
Connector.lCache.set(key, instance, 60 * 60 * 1000); // cache for 1 hour
|
|
62
|
+
|
|
63
|
+
return instance;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
static isValid(connector: Connector): boolean {
|
|
67
|
+
return connector.name !== undefined && connector.name !== null && connector.name !== '';
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
public async start() {
|
|
71
|
+
console.info(`Starting ${this.name} connector ...`);
|
|
72
|
+
this.started = true;
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
public async stop() {
|
|
76
|
+
console.info(`Stopping ${this.name} connector ...`);
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
public ready() {
|
|
80
|
+
if (!this._readyPromise) {
|
|
81
|
+
this._readyPromise = new Promise((resolve) => {
|
|
82
|
+
let maxWait = 60000;
|
|
83
|
+
const tick = 100;
|
|
84
|
+
if (this.started) {
|
|
85
|
+
resolve(true);
|
|
86
|
+
} else {
|
|
87
|
+
const interval = setInterval(() => {
|
|
88
|
+
if (this.started) {
|
|
89
|
+
clearInterval(interval);
|
|
90
|
+
resolve(true);
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
maxWait -= tick;
|
|
94
|
+
if (maxWait <= 0) {
|
|
95
|
+
clearInterval(interval);
|
|
96
|
+
resolve(false);
|
|
97
|
+
}
|
|
98
|
+
}, tick);
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
}
|
|
102
|
+
return this._readyPromise;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
public requester(candidate: AccessCandidate): TRequest {
|
|
106
|
+
return null as TRequest;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
public user(candidate: AccessCandidate | string): TRequest {
|
|
110
|
+
if (typeof candidate === 'string') {
|
|
111
|
+
return this.requester(AccessCandidate.user(candidate));
|
|
112
|
+
}
|
|
113
|
+
return this.requester(candidate);
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
public team(teamId: string): TRequest {
|
|
117
|
+
return this.requester(AccessCandidate.team(teamId));
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
public agent(agentId: string): TRequest {
|
|
121
|
+
return this.requester(AccessCandidate.agent(agentId));
|
|
122
|
+
}
|
|
123
|
+
}
|
|
@@ -1,197 +1,197 @@
|
|
|
1
|
-
import { SREConnectorConfig, TConnectorService, TServiceRegistry } from '@sre/types/SRE.types';
|
|
2
|
-
import { DummyConnector } from './DummyConnector';
|
|
3
|
-
import { Logger } from '../helpers/Log.helper';
|
|
4
|
-
import { Connector } from './Connector.class';
|
|
5
|
-
import { getFormattedStackTrace, isSubclassOf, printStackTrace } from '@sre/utils';
|
|
6
|
-
import { SystemEvents } from './SystemEvents';
|
|
7
|
-
import { StorageConnector } from '@sre/IO/Storage.service/StorageConnector';
|
|
8
|
-
import { CacheConnector } from '@sre/MemoryManager/Cache.service/CacheConnector';
|
|
9
|
-
import { LLMConnector } from '@sre/LLMManager/LLM.service/LLMConnector';
|
|
10
|
-
import { VaultConnector } from '@sre/Security/Vault.service/VaultConnector';
|
|
11
|
-
import { AccountConnector } from '@sre/Security/Account.service/AccountConnector';
|
|
12
|
-
import { AgentDataConnector } from '@sre/AgentManager/AgentData.service/AgentDataConnector';
|
|
13
|
-
import { VectorDBConnector } from '@sre/IO/VectorDB.service/VectorDBConnector';
|
|
14
|
-
import { CLIConnector } from '@sre/IO/CLI.service/CLIConnector';
|
|
15
|
-
import { NKVConnector } from '@sre/IO/NKV.service/NKVConnector';
|
|
16
|
-
import { RouterConnector } from '@sre/IO/Router.service/RouterConnector';
|
|
17
|
-
import { ManagedVaultConnector } from '@sre/Security/ManagedVault.service/ManagedVaultConnector';
|
|
18
|
-
import { LogConnector } from '@sre/IO/Log.service/LogConnector';
|
|
19
|
-
import { ComponentConnector } from '@sre/AgentManager/Component.service/ComponentConnector';
|
|
20
|
-
import { ModelsProviderConnector } from '@sre/LLMManager/ModelsProvider.service/ModelsProviderConnector';
|
|
21
|
-
import { CodeConnector } from '@sre/ComputeManager/Code.service/CodeConnector';
|
|
22
|
-
const console = Logger('ConnectorService');
|
|
23
|
-
|
|
24
|
-
let ServiceRegistry: TServiceRegistry = {};
|
|
25
|
-
let _ready = false;
|
|
26
|
-
SystemEvents.on('SRE:Booted', (services) => {
|
|
27
|
-
ServiceRegistry = services;
|
|
28
|
-
_ready = true;
|
|
29
|
-
});
|
|
30
|
-
export class ConnectorService {
|
|
31
|
-
public static Connectors = {};
|
|
32
|
-
|
|
33
|
-
public static ConnectorInstances: any = {};
|
|
34
|
-
public static get ready() {
|
|
35
|
-
return _ready;
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
public static get service(): TServiceRegistry {
|
|
39
|
-
return ServiceRegistry;
|
|
40
|
-
}
|
|
41
|
-
/**
|
|
42
|
-
* Allows SRE services to register their connectors, a registered conector can then be initialized and used by SRE or its services
|
|
43
|
-
* @param connectorType
|
|
44
|
-
* @param connectorName
|
|
45
|
-
* @param connectorConstructor
|
|
46
|
-
* @returns
|
|
47
|
-
*/
|
|
48
|
-
static register(connectorType: TConnectorService, connectorName: string, connectorConstructor: any) {
|
|
49
|
-
if (typeof connectorConstructor !== 'function' || !isSubclassOf(connectorConstructor, Connector)) {
|
|
50
|
-
console.error(`Invalid Connector ${connectorType}:${connectorName}`);
|
|
51
|
-
return;
|
|
52
|
-
}
|
|
53
|
-
if (!ConnectorService.Connectors[connectorType]) {
|
|
54
|
-
ConnectorService.Connectors[connectorType] = {};
|
|
55
|
-
}
|
|
56
|
-
ConnectorService.Connectors[connectorType][connectorName] = connectorConstructor;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
/**
|
|
60
|
-
* The init method instantiates a connector and starts it, a connector cannot be used before it is initialized
|
|
61
|
-
* Usually the initialization phase happens during the SRE startup, but some connectors can be initialized later if they are not mandatory for the SRE to start
|
|
62
|
-
*
|
|
63
|
-
*
|
|
64
|
-
* @param connectorType
|
|
65
|
-
* @param connectorName
|
|
66
|
-
* @param settings
|
|
67
|
-
* @param isDefault
|
|
68
|
-
* @returns
|
|
69
|
-
*/
|
|
70
|
-
static init(connectorType: TConnectorService, connectorName: string, connectorId?: string, settings: any = {}, isDefault = false) {
|
|
71
|
-
if (ConnectorService.ConnectorInstances[connectorType]?.[connectorName]) {
|
|
72
|
-
throw new Error(`Connector ${connectorType}:${connectorName} already initialized`);
|
|
73
|
-
}
|
|
74
|
-
|
|
75
|
-
const entry = ConnectorService.Connectors[connectorType];
|
|
76
|
-
if (!entry) return;
|
|
77
|
-
const connectorConstructor = entry[connectorName];
|
|
78
|
-
|
|
79
|
-
if (connectorConstructor) {
|
|
80
|
-
const connector: Connector = new connectorConstructor(settings);
|
|
81
|
-
if (connector.interactionHandler) {
|
|
82
|
-
connector.interactionHandler();
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
connector.start();
|
|
86
|
-
if (!ConnectorService.ConnectorInstances[connectorType]) ConnectorService.ConnectorInstances[connectorType] = {};
|
|
87
|
-
const id = connectorId || connectorName;
|
|
88
|
-
ConnectorService.ConnectorInstances[connectorType][id] = connector;
|
|
89
|
-
|
|
90
|
-
if (!ConnectorService.ConnectorInstances[connectorType].default && isDefault) {
|
|
91
|
-
ConnectorService.ConnectorInstances[connectorType].default = connector;
|
|
92
|
-
}
|
|
93
|
-
|
|
94
|
-
return connector;
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
static async _stop() {
|
|
98
|
-
for (let connectorName in ConnectorService.ConnectorInstances) {
|
|
99
|
-
let allConnectors: Connector[] = Object.values(ConnectorService.ConnectorInstances[connectorName]);
|
|
100
|
-
//deduplicate
|
|
101
|
-
allConnectors = allConnectors.filter((value, index, self) => self.indexOf(value) === index);
|
|
102
|
-
for (let connector of allConnectors) {
|
|
103
|
-
connector.stop();
|
|
104
|
-
}
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
static getInstance<T>(connectorType: TConnectorService, connectorName: string = 'default'): T {
|
|
108
|
-
const instance = ConnectorService.ConnectorInstances[connectorType]?.[connectorName || 'default'] as T;
|
|
109
|
-
if (!instance) {
|
|
110
|
-
//TODO only apply the fallback below if resilient mode is enabled
|
|
111
|
-
// if (ConnectorService.ConnectorInstances[connectorType] && Object.keys(ConnectorService.ConnectorInstances[connectorType]).length > 0) {
|
|
112
|
-
// //return the first instance
|
|
113
|
-
// return ConnectorService.ConnectorInstances[connectorType][Object.keys(ConnectorService.ConnectorInstances[connectorType])[0]] as T;
|
|
114
|
-
// }
|
|
115
|
-
console.warn(`Connector ${connectorType} not initialized returning DummyConnector`);
|
|
116
|
-
//print stack trace
|
|
117
|
-
|
|
118
|
-
printStackTrace(console, 5);
|
|
119
|
-
|
|
120
|
-
return DummyConnector(connectorType) as T;
|
|
121
|
-
}
|
|
122
|
-
return instance;
|
|
123
|
-
}
|
|
124
|
-
|
|
125
|
-
static getStorageConnector(name?: string): StorageConnector {
|
|
126
|
-
return ConnectorService.getInstance<StorageConnector>(TConnectorService.Storage, name);
|
|
127
|
-
}
|
|
128
|
-
|
|
129
|
-
static getCacheConnector(name?: string): CacheConnector {
|
|
130
|
-
return ConnectorService.getInstance<any>(TConnectorService.Cache, name);
|
|
131
|
-
}
|
|
132
|
-
|
|
133
|
-
static getVectorDBConnector(name?: string): VectorDBConnector {
|
|
134
|
-
return ConnectorService.getInstance<VectorDBConnector>(TConnectorService.VectorDB, name);
|
|
135
|
-
}
|
|
136
|
-
|
|
137
|
-
static getNKVConnector(name?: string): NKVConnector {
|
|
138
|
-
return ConnectorService.getInstance<NKVConnector>(TConnectorService.NKV, name);
|
|
139
|
-
}
|
|
140
|
-
|
|
141
|
-
static getLLMConnector(name?: string): LLMConnector {
|
|
142
|
-
return ConnectorService.getInstance<LLMConnector>(TConnectorService.LLM, name);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
static getVaultConnector(name?: string): VaultConnector {
|
|
146
|
-
return ConnectorService.getInstance<VaultConnector>(TConnectorService.Vault, name);
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
static getManagedVaultConnector(name?: string): ManagedVaultConnector {
|
|
150
|
-
return ConnectorService.getInstance<ManagedVaultConnector>(TConnectorService.ManagedVault, name);
|
|
151
|
-
}
|
|
152
|
-
|
|
153
|
-
static getAccountConnector(name?: string): AccountConnector {
|
|
154
|
-
return ConnectorService.getInstance<AccountConnector>(TConnectorService.Account, name);
|
|
155
|
-
}
|
|
156
|
-
|
|
157
|
-
static getAgentDataConnector(name?: string): AgentDataConnector {
|
|
158
|
-
return ConnectorService.getInstance<AgentDataConnector>(TConnectorService.AgentData, name);
|
|
159
|
-
}
|
|
160
|
-
|
|
161
|
-
static getCLIConnector(name?: string): CLIConnector {
|
|
162
|
-
return ConnectorService.getInstance<CLIConnector>(TConnectorService.CLI, name);
|
|
163
|
-
}
|
|
164
|
-
|
|
165
|
-
static getLogConnector(name?: string): LogConnector {
|
|
166
|
-
return ConnectorService.getInstance<LogConnector>(TConnectorService.Log, name);
|
|
167
|
-
}
|
|
168
|
-
|
|
169
|
-
static getComponentConnector(name?: string): ComponentConnector {
|
|
170
|
-
return ConnectorService.getInstance<ComponentConnector>(TConnectorService.Component, name);
|
|
171
|
-
}
|
|
172
|
-
|
|
173
|
-
static getModelsProviderConnector(name?: string): ModelsProviderConnector {
|
|
174
|
-
return ConnectorService.getInstance<ModelsProviderConnector>(TConnectorService.ModelsProvider, name);
|
|
175
|
-
}
|
|
176
|
-
|
|
177
|
-
static hasInstance(connectorType: TConnectorService, connectorName: string = 'default') {
|
|
178
|
-
const instance = ConnectorService.ConnectorInstances[connectorType]?.[connectorName];
|
|
179
|
-
return instance && instance.valid;
|
|
180
|
-
}
|
|
181
|
-
|
|
182
|
-
static getRouterConnector(name?: string): RouterConnector {
|
|
183
|
-
return ConnectorService.getInstance<RouterConnector>(TConnectorService.Router, name);
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
static getCodeConnector(name?: string): CodeConnector {
|
|
187
|
-
return ConnectorService.getInstance<CodeConnector>(TConnectorService.Code, name);
|
|
188
|
-
}
|
|
189
|
-
}
|
|
190
|
-
|
|
191
|
-
export abstract class ConnectorServiceProvider {
|
|
192
|
-
public abstract register();
|
|
193
|
-
public init() {}
|
|
194
|
-
public constructor() {
|
|
195
|
-
this.register();
|
|
196
|
-
}
|
|
197
|
-
}
|
|
1
|
+
import { SREConnectorConfig, TConnectorService, TServiceRegistry } from '@sre/types/SRE.types';
|
|
2
|
+
import { DummyConnector } from './DummyConnector';
|
|
3
|
+
import { Logger } from '../helpers/Log.helper';
|
|
4
|
+
import { Connector } from './Connector.class';
|
|
5
|
+
import { getFormattedStackTrace, isSubclassOf, printStackTrace } from '@sre/utils';
|
|
6
|
+
import { SystemEvents } from './SystemEvents';
|
|
7
|
+
import { StorageConnector } from '@sre/IO/Storage.service/StorageConnector';
|
|
8
|
+
import { CacheConnector } from '@sre/MemoryManager/Cache.service/CacheConnector';
|
|
9
|
+
import { LLMConnector } from '@sre/LLMManager/LLM.service/LLMConnector';
|
|
10
|
+
import { VaultConnector } from '@sre/Security/Vault.service/VaultConnector';
|
|
11
|
+
import { AccountConnector } from '@sre/Security/Account.service/AccountConnector';
|
|
12
|
+
import { AgentDataConnector } from '@sre/AgentManager/AgentData.service/AgentDataConnector';
|
|
13
|
+
import { VectorDBConnector } from '@sre/IO/VectorDB.service/VectorDBConnector';
|
|
14
|
+
import { CLIConnector } from '@sre/IO/CLI.service/CLIConnector';
|
|
15
|
+
import { NKVConnector } from '@sre/IO/NKV.service/NKVConnector';
|
|
16
|
+
import { RouterConnector } from '@sre/IO/Router.service/RouterConnector';
|
|
17
|
+
import { ManagedVaultConnector } from '@sre/Security/ManagedVault.service/ManagedVaultConnector';
|
|
18
|
+
import { LogConnector } from '@sre/IO/Log.service/LogConnector';
|
|
19
|
+
import { ComponentConnector } from '@sre/AgentManager/Component.service/ComponentConnector';
|
|
20
|
+
import { ModelsProviderConnector } from '@sre/LLMManager/ModelsProvider.service/ModelsProviderConnector';
|
|
21
|
+
import { CodeConnector } from '@sre/ComputeManager/Code.service/CodeConnector';
|
|
22
|
+
const console = Logger('ConnectorService');
|
|
23
|
+
|
|
24
|
+
let ServiceRegistry: TServiceRegistry = {};
|
|
25
|
+
let _ready = false;
|
|
26
|
+
SystemEvents.on('SRE:Booted', (services) => {
|
|
27
|
+
ServiceRegistry = services;
|
|
28
|
+
_ready = true;
|
|
29
|
+
});
|
|
30
|
+
export class ConnectorService {
|
|
31
|
+
public static Connectors = {};
|
|
32
|
+
|
|
33
|
+
public static ConnectorInstances: any = {};
|
|
34
|
+
public static get ready() {
|
|
35
|
+
return _ready;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
public static get service(): TServiceRegistry {
|
|
39
|
+
return ServiceRegistry;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Allows SRE services to register their connectors, a registered conector can then be initialized and used by SRE or its services
|
|
43
|
+
* @param connectorType
|
|
44
|
+
* @param connectorName
|
|
45
|
+
* @param connectorConstructor
|
|
46
|
+
* @returns
|
|
47
|
+
*/
|
|
48
|
+
static register(connectorType: TConnectorService, connectorName: string, connectorConstructor: any) {
|
|
49
|
+
if (typeof connectorConstructor !== 'function' || !isSubclassOf(connectorConstructor, Connector)) {
|
|
50
|
+
console.error(`Invalid Connector ${connectorType}:${connectorName}`);
|
|
51
|
+
return;
|
|
52
|
+
}
|
|
53
|
+
if (!ConnectorService.Connectors[connectorType]) {
|
|
54
|
+
ConnectorService.Connectors[connectorType] = {};
|
|
55
|
+
}
|
|
56
|
+
ConnectorService.Connectors[connectorType][connectorName] = connectorConstructor;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
/**
|
|
60
|
+
* The init method instantiates a connector and starts it, a connector cannot be used before it is initialized
|
|
61
|
+
* Usually the initialization phase happens during the SRE startup, but some connectors can be initialized later if they are not mandatory for the SRE to start
|
|
62
|
+
*
|
|
63
|
+
*
|
|
64
|
+
* @param connectorType
|
|
65
|
+
* @param connectorName
|
|
66
|
+
* @param settings
|
|
67
|
+
* @param isDefault
|
|
68
|
+
* @returns
|
|
69
|
+
*/
|
|
70
|
+
static init(connectorType: TConnectorService, connectorName: string, connectorId?: string, settings: any = {}, isDefault = false) {
|
|
71
|
+
if (ConnectorService.ConnectorInstances[connectorType]?.[connectorName]) {
|
|
72
|
+
throw new Error(`Connector ${connectorType}:${connectorName} already initialized`);
|
|
73
|
+
}
|
|
74
|
+
|
|
75
|
+
const entry = ConnectorService.Connectors[connectorType];
|
|
76
|
+
if (!entry) return;
|
|
77
|
+
const connectorConstructor = entry[connectorName];
|
|
78
|
+
|
|
79
|
+
if (connectorConstructor) {
|
|
80
|
+
const connector: Connector = new connectorConstructor(settings);
|
|
81
|
+
if (connector.interactionHandler) {
|
|
82
|
+
connector.interactionHandler();
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
connector.start();
|
|
86
|
+
if (!ConnectorService.ConnectorInstances[connectorType]) ConnectorService.ConnectorInstances[connectorType] = {};
|
|
87
|
+
const id = connectorId || connectorName;
|
|
88
|
+
ConnectorService.ConnectorInstances[connectorType][id] = connector;
|
|
89
|
+
|
|
90
|
+
if (!ConnectorService.ConnectorInstances[connectorType].default && isDefault) {
|
|
91
|
+
ConnectorService.ConnectorInstances[connectorType].default = connector;
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
return connector;
|
|
95
|
+
}
|
|
96
|
+
}
|
|
97
|
+
static async _stop() {
|
|
98
|
+
for (let connectorName in ConnectorService.ConnectorInstances) {
|
|
99
|
+
let allConnectors: Connector[] = Object.values(ConnectorService.ConnectorInstances[connectorName]);
|
|
100
|
+
//deduplicate
|
|
101
|
+
allConnectors = allConnectors.filter((value, index, self) => self.indexOf(value) === index);
|
|
102
|
+
for (let connector of allConnectors) {
|
|
103
|
+
connector.stop();
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
static getInstance<T>(connectorType: TConnectorService, connectorName: string = 'default'): T {
|
|
108
|
+
const instance = ConnectorService.ConnectorInstances[connectorType]?.[connectorName || 'default'] as T;
|
|
109
|
+
if (!instance) {
|
|
110
|
+
//TODO only apply the fallback below if resilient mode is enabled
|
|
111
|
+
// if (ConnectorService.ConnectorInstances[connectorType] && Object.keys(ConnectorService.ConnectorInstances[connectorType]).length > 0) {
|
|
112
|
+
// //return the first instance
|
|
113
|
+
// return ConnectorService.ConnectorInstances[connectorType][Object.keys(ConnectorService.ConnectorInstances[connectorType])[0]] as T;
|
|
114
|
+
// }
|
|
115
|
+
console.warn(`Connector ${connectorType} not initialized returning DummyConnector`);
|
|
116
|
+
//print stack trace
|
|
117
|
+
|
|
118
|
+
printStackTrace(console, 5);
|
|
119
|
+
|
|
120
|
+
return DummyConnector(connectorType) as T;
|
|
121
|
+
}
|
|
122
|
+
return instance;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
static getStorageConnector(name?: string): StorageConnector {
|
|
126
|
+
return ConnectorService.getInstance<StorageConnector>(TConnectorService.Storage, name);
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
static getCacheConnector(name?: string): CacheConnector {
|
|
130
|
+
return ConnectorService.getInstance<any>(TConnectorService.Cache, name);
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
static getVectorDBConnector(name?: string): VectorDBConnector {
|
|
134
|
+
return ConnectorService.getInstance<VectorDBConnector>(TConnectorService.VectorDB, name);
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
static getNKVConnector(name?: string): NKVConnector {
|
|
138
|
+
return ConnectorService.getInstance<NKVConnector>(TConnectorService.NKV, name);
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
static getLLMConnector(name?: string): LLMConnector {
|
|
142
|
+
return ConnectorService.getInstance<LLMConnector>(TConnectorService.LLM, name);
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
static getVaultConnector(name?: string): VaultConnector {
|
|
146
|
+
return ConnectorService.getInstance<VaultConnector>(TConnectorService.Vault, name);
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
static getManagedVaultConnector(name?: string): ManagedVaultConnector {
|
|
150
|
+
return ConnectorService.getInstance<ManagedVaultConnector>(TConnectorService.ManagedVault, name);
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
static getAccountConnector(name?: string): AccountConnector {
|
|
154
|
+
return ConnectorService.getInstance<AccountConnector>(TConnectorService.Account, name);
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
static getAgentDataConnector(name?: string): AgentDataConnector {
|
|
158
|
+
return ConnectorService.getInstance<AgentDataConnector>(TConnectorService.AgentData, name);
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
static getCLIConnector(name?: string): CLIConnector {
|
|
162
|
+
return ConnectorService.getInstance<CLIConnector>(TConnectorService.CLI, name);
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
static getLogConnector(name?: string): LogConnector {
|
|
166
|
+
return ConnectorService.getInstance<LogConnector>(TConnectorService.Log, name);
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
static getComponentConnector(name?: string): ComponentConnector {
|
|
170
|
+
return ConnectorService.getInstance<ComponentConnector>(TConnectorService.Component, name);
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
static getModelsProviderConnector(name?: string): ModelsProviderConnector {
|
|
174
|
+
return ConnectorService.getInstance<ModelsProviderConnector>(TConnectorService.ModelsProvider, name);
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
static hasInstance(connectorType: TConnectorService, connectorName: string = 'default') {
|
|
178
|
+
const instance = ConnectorService.ConnectorInstances[connectorType]?.[connectorName];
|
|
179
|
+
return instance && instance.valid;
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
static getRouterConnector(name?: string): RouterConnector {
|
|
183
|
+
return ConnectorService.getInstance<RouterConnector>(TConnectorService.Router, name);
|
|
184
|
+
}
|
|
185
|
+
|
|
186
|
+
static getCodeConnector(name?: string): CodeConnector {
|
|
187
|
+
return ConnectorService.getInstance<CodeConnector>(TConnectorService.Code, name);
|
|
188
|
+
}
|
|
189
|
+
}
|
|
190
|
+
|
|
191
|
+
export abstract class ConnectorServiceProvider {
|
|
192
|
+
public abstract register();
|
|
193
|
+
public init() {}
|
|
194
|
+
public constructor() {
|
|
195
|
+
this.register();
|
|
196
|
+
}
|
|
197
|
+
}
|