@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,132 +1,132 @@
|
|
|
1
|
-
import Joi from 'joi';
|
|
2
|
-
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
3
|
-
import { Logger } from '@sre/helpers/Log.helper';
|
|
4
|
-
import { performTypeInference } from '@sre/helpers/TypeChecker.helper';
|
|
5
|
-
import { hookAsync } from '@sre/Core/HookService';
|
|
6
|
-
|
|
7
|
-
export type ComponentSchema = {
|
|
8
|
-
name: string;
|
|
9
|
-
settings?: Record<string, any>;
|
|
10
|
-
inputs?: Record<string, any>;
|
|
11
|
-
outputs?: Record<string, any>;
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
export class Component {
|
|
15
|
-
public hasReadOutput = false;
|
|
16
|
-
public hasPostProcess = true;
|
|
17
|
-
public alwaysActive = false; //for components like readable memories
|
|
18
|
-
public exclusive = false; //for components like writable memories : when exclusive components are active, they are processed in a run cycle bofore other components
|
|
19
|
-
protected schema: ComponentSchema = {
|
|
20
|
-
name: 'Component',
|
|
21
|
-
settings: {},
|
|
22
|
-
inputs: {},
|
|
23
|
-
//outputs: {},
|
|
24
|
-
};
|
|
25
|
-
protected configSchema;
|
|
26
|
-
constructor() {}
|
|
27
|
-
init() {}
|
|
28
|
-
|
|
29
|
-
createComponentLogger(agent: Agent, configuration: any) {
|
|
30
|
-
const logger = Logger((configuration.name || this.constructor.name) + `,agent<${agent.id}>`, agent?.agentRuntime?.debug);
|
|
31
|
-
|
|
32
|
-
logger.on('logged', (info: { level: string; message: string }) => {
|
|
33
|
-
if (agent.sse && configuration.eventId) {
|
|
34
|
-
agent.sse.send('component', {
|
|
35
|
-
eventId: configuration.eventId,
|
|
36
|
-
action: 'log',
|
|
37
|
-
name: configuration.name || this.constructor.name,
|
|
38
|
-
title: configuration.title,
|
|
39
|
-
logs: [{ level: info.level, message: info.message }],
|
|
40
|
-
});
|
|
41
|
-
}
|
|
42
|
-
});
|
|
43
|
-
return logger;
|
|
44
|
-
}
|
|
45
|
-
|
|
46
|
-
/**
|
|
47
|
-
* Filters config data to only include properties that are defined in the schema
|
|
48
|
-
*/
|
|
49
|
-
private filterConfigBySchema(data: any, schema: any): any {
|
|
50
|
-
if (!schema || !data) return data;
|
|
51
|
-
|
|
52
|
-
const schemaDescription = schema.describe();
|
|
53
|
-
|
|
54
|
-
// If it's not an object schema, return data as-is
|
|
55
|
-
if (schemaDescription.type !== 'object' || !schemaDescription.keys) {
|
|
56
|
-
return data;
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
const allowedKeys = Object.keys(schemaDescription.keys);
|
|
60
|
-
const filteredData: any = {};
|
|
61
|
-
|
|
62
|
-
// Only include properties that are defined in the schema
|
|
63
|
-
for (const key of allowedKeys) {
|
|
64
|
-
if (key in data) {
|
|
65
|
-
filteredData[key] = data[key];
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
// Preserve _templateVars if it exists (special case)
|
|
70
|
-
if (data._templateVars) {
|
|
71
|
-
filteredData._templateVars = data._templateVars;
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
return filteredData;
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
async validateConfig(config) {
|
|
78
|
-
if (!this.configSchema) return {};
|
|
79
|
-
|
|
80
|
-
let workingSchema = this.configSchema;
|
|
81
|
-
|
|
82
|
-
if (config.data._templateVars) {
|
|
83
|
-
//Accept dynamically added template data
|
|
84
|
-
for (let tplVar in config.data._templateVars) {
|
|
85
|
-
workingSchema = workingSchema.append({ [tplVar]: Joi.any() });
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
|
|
89
|
-
// Filter config.data to only include properties defined in the schema
|
|
90
|
-
const filteredData = this.filterConfigBySchema(config.data, workingSchema);
|
|
91
|
-
|
|
92
|
-
const valid = await workingSchema.validate(filteredData);
|
|
93
|
-
if (valid.error) {
|
|
94
|
-
return {
|
|
95
|
-
id: config.id,
|
|
96
|
-
name: config.name,
|
|
97
|
-
_error: `Schema Validation error: ${valid?.error?.message} on component ${config.displayName}:${config.title}`,
|
|
98
|
-
_debug: `Schema Validation error: ${valid?.error?.message} on component ${config.displayName}:${config.title}`,
|
|
99
|
-
};
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
return {};
|
|
103
|
-
}
|
|
104
|
-
|
|
105
|
-
@hookAsync('Component.process')
|
|
106
|
-
async process(input, config, agent: Agent): Promise<any> {
|
|
107
|
-
if (agent.isKilled()) {
|
|
108
|
-
throw new Error('Agent killed');
|
|
109
|
-
}
|
|
110
|
-
const _input = await performTypeInference(input, config?.inputs, agent);
|
|
111
|
-
|
|
112
|
-
// modify the input object for component's process method
|
|
113
|
-
for (const [key, value] of Object.entries(_input)) {
|
|
114
|
-
input[key] = value;
|
|
115
|
-
}
|
|
116
|
-
}
|
|
117
|
-
async postProcess(output, config, agent: Agent): Promise<any> {
|
|
118
|
-
if (output?.result) {
|
|
119
|
-
delete output?.result?._debug;
|
|
120
|
-
if (!output?.result?._error) delete output?.result?._error;
|
|
121
|
-
}
|
|
122
|
-
return output;
|
|
123
|
-
}
|
|
124
|
-
async enable(config, agent: Agent): Promise<any> {}
|
|
125
|
-
async disable(config, agent: Agent): Promise<any> {}
|
|
126
|
-
readOutput(id, config, agent: Agent): any {
|
|
127
|
-
return null;
|
|
128
|
-
}
|
|
129
|
-
hasOutput(id, config, agent: Agent): any {
|
|
130
|
-
return false;
|
|
131
|
-
}
|
|
132
|
-
}
|
|
1
|
+
import Joi from 'joi';
|
|
2
|
+
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
3
|
+
import { Logger } from '@sre/helpers/Log.helper';
|
|
4
|
+
import { performTypeInference } from '@sre/helpers/TypeChecker.helper';
|
|
5
|
+
import { hookAsync } from '@sre/Core/HookService';
|
|
6
|
+
|
|
7
|
+
export type ComponentSchema = {
|
|
8
|
+
name: string;
|
|
9
|
+
settings?: Record<string, any>;
|
|
10
|
+
inputs?: Record<string, any>;
|
|
11
|
+
outputs?: Record<string, any>;
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
export class Component {
|
|
15
|
+
public hasReadOutput = false;
|
|
16
|
+
public hasPostProcess = true;
|
|
17
|
+
public alwaysActive = false; //for components like readable memories
|
|
18
|
+
public exclusive = false; //for components like writable memories : when exclusive components are active, they are processed in a run cycle bofore other components
|
|
19
|
+
protected schema: ComponentSchema = {
|
|
20
|
+
name: 'Component',
|
|
21
|
+
settings: {},
|
|
22
|
+
inputs: {},
|
|
23
|
+
//outputs: {},
|
|
24
|
+
};
|
|
25
|
+
protected configSchema;
|
|
26
|
+
constructor() {}
|
|
27
|
+
init() {}
|
|
28
|
+
|
|
29
|
+
createComponentLogger(agent: Agent, configuration: any) {
|
|
30
|
+
const logger = Logger((configuration.name || this.constructor.name) + `,agent<${agent.id}>`, agent?.agentRuntime?.debug);
|
|
31
|
+
|
|
32
|
+
logger.on('logged', (info: { level: string; message: string }) => {
|
|
33
|
+
if (agent.sse && configuration.eventId) {
|
|
34
|
+
agent.sse.send('component', {
|
|
35
|
+
eventId: configuration.eventId,
|
|
36
|
+
action: 'log',
|
|
37
|
+
name: configuration.name || this.constructor.name,
|
|
38
|
+
title: configuration.title,
|
|
39
|
+
logs: [{ level: info.level, message: info.message }],
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
});
|
|
43
|
+
return logger;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Filters config data to only include properties that are defined in the schema
|
|
48
|
+
*/
|
|
49
|
+
private filterConfigBySchema(data: any, schema: any): any {
|
|
50
|
+
if (!schema || !data) return data;
|
|
51
|
+
|
|
52
|
+
const schemaDescription = schema.describe();
|
|
53
|
+
|
|
54
|
+
// If it's not an object schema, return data as-is
|
|
55
|
+
if (schemaDescription.type !== 'object' || !schemaDescription.keys) {
|
|
56
|
+
return data;
|
|
57
|
+
}
|
|
58
|
+
|
|
59
|
+
const allowedKeys = Object.keys(schemaDescription.keys);
|
|
60
|
+
const filteredData: any = {};
|
|
61
|
+
|
|
62
|
+
// Only include properties that are defined in the schema
|
|
63
|
+
for (const key of allowedKeys) {
|
|
64
|
+
if (key in data) {
|
|
65
|
+
filteredData[key] = data[key];
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
// Preserve _templateVars if it exists (special case)
|
|
70
|
+
if (data._templateVars) {
|
|
71
|
+
filteredData._templateVars = data._templateVars;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
return filteredData;
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
async validateConfig(config) {
|
|
78
|
+
if (!this.configSchema) return {};
|
|
79
|
+
|
|
80
|
+
let workingSchema = this.configSchema;
|
|
81
|
+
|
|
82
|
+
if (config.data._templateVars) {
|
|
83
|
+
//Accept dynamically added template data
|
|
84
|
+
for (let tplVar in config.data._templateVars) {
|
|
85
|
+
workingSchema = workingSchema.append({ [tplVar]: Joi.any() });
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
// Filter config.data to only include properties defined in the schema
|
|
90
|
+
const filteredData = this.filterConfigBySchema(config.data, workingSchema);
|
|
91
|
+
|
|
92
|
+
const valid = await workingSchema.validate(filteredData);
|
|
93
|
+
if (valid.error) {
|
|
94
|
+
return {
|
|
95
|
+
id: config.id,
|
|
96
|
+
name: config.name,
|
|
97
|
+
_error: `Schema Validation error: ${valid?.error?.message} on component ${config.displayName}:${config.title}`,
|
|
98
|
+
_debug: `Schema Validation error: ${valid?.error?.message} on component ${config.displayName}:${config.title}`,
|
|
99
|
+
};
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
return {};
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
@hookAsync('Component.process')
|
|
106
|
+
async process(input, config, agent: Agent): Promise<any> {
|
|
107
|
+
if (agent.isKilled()) {
|
|
108
|
+
throw new Error('Agent killed');
|
|
109
|
+
}
|
|
110
|
+
const _input = await performTypeInference(input, config?.inputs, agent);
|
|
111
|
+
|
|
112
|
+
// modify the input object for component's process method
|
|
113
|
+
for (const [key, value] of Object.entries(_input)) {
|
|
114
|
+
input[key] = value;
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
async postProcess(output, config, agent: Agent): Promise<any> {
|
|
118
|
+
if (output?.result) {
|
|
119
|
+
delete output?.result?._debug;
|
|
120
|
+
if (!output?.result?._error) delete output?.result?._error;
|
|
121
|
+
}
|
|
122
|
+
return output;
|
|
123
|
+
}
|
|
124
|
+
async enable(config, agent: Agent): Promise<any> {}
|
|
125
|
+
async disable(config, agent: Agent): Promise<any> {}
|
|
126
|
+
readOutput(id, config, agent: Agent): any {
|
|
127
|
+
return null;
|
|
128
|
+
}
|
|
129
|
+
hasOutput(id, config, agent: Agent): any {
|
|
130
|
+
return false;
|
|
131
|
+
}
|
|
132
|
+
}
|
|
@@ -1,38 +1,38 @@
|
|
|
1
|
-
import { Component } from './Component.class';
|
|
2
|
-
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
3
|
-
import { ConnectorService } from '@sre/Core/ConnectorsService';
|
|
4
|
-
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
5
|
-
|
|
6
|
-
/**
|
|
7
|
-
* This component allows running components that are not natively shiped with SRE
|
|
8
|
-
* it can be used to extend SRE components by registering custom component using ComponentService
|
|
9
|
-
*/
|
|
10
|
-
export class ComponentHost extends Component {
|
|
11
|
-
protected configSchema = null;
|
|
12
|
-
constructor() {
|
|
13
|
-
super();
|
|
14
|
-
}
|
|
15
|
-
init() {}
|
|
16
|
-
|
|
17
|
-
async process(input, config, agent: Agent) {
|
|
18
|
-
await super.process(input, config, agent);
|
|
19
|
-
//let debugLog = agent.agentRuntime?.debug ? [] : undefined;
|
|
20
|
-
const logger = this.createComponentLogger(agent, config);
|
|
21
|
-
|
|
22
|
-
try {
|
|
23
|
-
const componentName = config.data._component;
|
|
24
|
-
const componentConnector = ConnectorService.getComponentConnector();
|
|
25
|
-
|
|
26
|
-
const component = await componentConnector.requester(AccessCandidate.agent(agent.id)).get(componentName);
|
|
27
|
-
|
|
28
|
-
if (!component) {
|
|
29
|
-
logger.debug(`Component ${componentName} not found`);
|
|
30
|
-
return { _error: `Component ${componentName} not found`, _debug: logger.output };
|
|
31
|
-
}
|
|
32
|
-
|
|
33
|
-
return await component.process(input, config, agent);
|
|
34
|
-
} catch (error) {
|
|
35
|
-
return { _error: error.message, _debug: logger.output };
|
|
36
|
-
}
|
|
37
|
-
}
|
|
38
|
-
}
|
|
1
|
+
import { Component } from './Component.class';
|
|
2
|
+
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
3
|
+
import { ConnectorService } from '@sre/Core/ConnectorsService';
|
|
4
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* This component allows running components that are not natively shiped with SRE
|
|
8
|
+
* it can be used to extend SRE components by registering custom component using ComponentService
|
|
9
|
+
*/
|
|
10
|
+
export class ComponentHost extends Component {
|
|
11
|
+
protected configSchema = null;
|
|
12
|
+
constructor() {
|
|
13
|
+
super();
|
|
14
|
+
}
|
|
15
|
+
init() {}
|
|
16
|
+
|
|
17
|
+
async process(input, config, agent: Agent) {
|
|
18
|
+
await super.process(input, config, agent);
|
|
19
|
+
//let debugLog = agent.agentRuntime?.debug ? [] : undefined;
|
|
20
|
+
const logger = this.createComponentLogger(agent, config);
|
|
21
|
+
|
|
22
|
+
try {
|
|
23
|
+
const componentName = config.data._component;
|
|
24
|
+
const componentConnector = ConnectorService.getComponentConnector();
|
|
25
|
+
|
|
26
|
+
const component = await componentConnector.requester(AccessCandidate.agent(agent.id)).get(componentName);
|
|
27
|
+
|
|
28
|
+
if (!component) {
|
|
29
|
+
logger.debug(`Component ${componentName} not found`);
|
|
30
|
+
return { _error: `Component ${componentName} not found`, _debug: logger.output };
|
|
31
|
+
}
|
|
32
|
+
|
|
33
|
+
return await component.process(input, config, agent);
|
|
34
|
+
} catch (error) {
|
|
35
|
+
return { _error: error.message, _debug: logger.output };
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
}
|
|
@@ -1,92 +1,92 @@
|
|
|
1
|
-
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
2
|
-
import { Component } from './Component.class';
|
|
3
|
-
import { TemplateString } from '@sre/helpers/TemplateString.helper';
|
|
4
|
-
import Joi from 'joi';
|
|
5
|
-
import { validateCharacterSet } from '../utils';
|
|
6
|
-
import { ConnectorService } from '@sre/Core/ConnectorsService';
|
|
7
|
-
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
8
|
-
|
|
9
|
-
import { DataSourceIndexer } from './DataSourceIndexer.class';
|
|
10
|
-
|
|
11
|
-
export class DataSourceCleaner extends Component {
|
|
12
|
-
protected configSchema = Joi.object({
|
|
13
|
-
namespaceId: Joi.string().max(50).allow('').label('namespace'),
|
|
14
|
-
id: Joi.string().custom(validateCharacterSet, 'custom validation characterSet').allow('').label('source identifier'),
|
|
15
|
-
});
|
|
16
|
-
constructor() {
|
|
17
|
-
super();
|
|
18
|
-
}
|
|
19
|
-
init() {}
|
|
20
|
-
async process(input, config, agent: Agent) {
|
|
21
|
-
await super.process(input, config, agent);
|
|
22
|
-
const teamId = agent.teamId;
|
|
23
|
-
const agentId = agent.id;
|
|
24
|
-
let debugOutput = agent.agentRuntime?.debug ? '== Source Indexer Log ==\n' : null;
|
|
25
|
-
|
|
26
|
-
try {
|
|
27
|
-
const configSchema = this.validateConfigData(config.data);
|
|
28
|
-
if (configSchema.error) {
|
|
29
|
-
throw new Error(`Config data validation error: ${configSchema.error}\n EXITING...`);
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const outputs = {};
|
|
33
|
-
for (let con of config.outputs) {
|
|
34
|
-
if (con.default) continue;
|
|
35
|
-
outputs[con.name] = con?.description ? `<${con?.description}>` : '';
|
|
36
|
-
}
|
|
37
|
-
|
|
38
|
-
const inputSchema = this.validateInput(input);
|
|
39
|
-
if (inputSchema.error) {
|
|
40
|
-
throw new Error(`Input validation error: ${inputSchema.error}\n EXITING...`);
|
|
41
|
-
}
|
|
42
|
-
|
|
43
|
-
const namespaceId = configSchema.value.namespaceId.split('_')?.slice(1).join('_') || configSchema.value.namespaceId;
|
|
44
|
-
|
|
45
|
-
let vectorDbConnector = ConnectorService.getVectorDBConnector();
|
|
46
|
-
|
|
47
|
-
let existingnamespace = await vectorDbConnector.requester(AccessCandidate.team(teamId)).namespaceExists(namespaceId);
|
|
48
|
-
if (!existingnamespace) {
|
|
49
|
-
throw new Error(`Namespace ${namespaceId} does not exist`);
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
const providedId = TemplateString(config.data.id).parse(input).result;
|
|
53
|
-
const idRegex = /^[a-zA-Z0-9\-\_\.]+$/;
|
|
54
|
-
if (!idRegex.test(providedId)) {
|
|
55
|
-
throw new Error(`Invalid id. Accepted characters: 'a-z', 'A-Z', '0-9', '-', '_', '.'`);
|
|
56
|
-
}
|
|
57
|
-
debugOutput += `Searching for data source with id: ${providedId}\n`;
|
|
58
|
-
|
|
59
|
-
const dsId = DataSourceIndexer.genDsId(providedId, teamId, namespaceId);
|
|
60
|
-
|
|
61
|
-
await vectorDbConnector.requester(AccessCandidate.team(teamId)).deleteDatasource(namespaceId, dsId);
|
|
62
|
-
|
|
63
|
-
debugOutput += `Deleted data source with id: ${providedId}\n`;
|
|
64
|
-
|
|
65
|
-
return {
|
|
66
|
-
_debug: debugOutput,
|
|
67
|
-
Success: true,
|
|
68
|
-
// _error,
|
|
69
|
-
};
|
|
70
|
-
} catch (err: any) {
|
|
71
|
-
debugOutput += `Failed to delete data source: \n Error: ${err?.message}\n`;
|
|
72
|
-
|
|
73
|
-
return {
|
|
74
|
-
_debug: debugOutput,
|
|
75
|
-
_error: err?.message || "Couldn't delete data source",
|
|
76
|
-
};
|
|
77
|
-
}
|
|
78
|
-
}
|
|
79
|
-
|
|
80
|
-
validateInput(input: any) {
|
|
81
|
-
return Joi.object({}).unknown(true).validate(input);
|
|
82
|
-
}
|
|
83
|
-
|
|
84
|
-
validateConfigData(data: any) {
|
|
85
|
-
return Joi.object({
|
|
86
|
-
namespaceId: Joi.string().required(),
|
|
87
|
-
id: Joi.string().optional().allow('').allow(null),
|
|
88
|
-
})
|
|
89
|
-
.unknown(true)
|
|
90
|
-
.validate(data);
|
|
91
|
-
}
|
|
92
|
-
}
|
|
1
|
+
import { IAgent as Agent } from '@sre/types/Agent.types';
|
|
2
|
+
import { Component } from './Component.class';
|
|
3
|
+
import { TemplateString } from '@sre/helpers/TemplateString.helper';
|
|
4
|
+
import Joi from 'joi';
|
|
5
|
+
import { validateCharacterSet } from '../utils';
|
|
6
|
+
import { ConnectorService } from '@sre/Core/ConnectorsService';
|
|
7
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
8
|
+
|
|
9
|
+
import { DataSourceIndexer } from './DataSourceIndexer.class';
|
|
10
|
+
|
|
11
|
+
export class DataSourceCleaner extends Component {
|
|
12
|
+
protected configSchema = Joi.object({
|
|
13
|
+
namespaceId: Joi.string().max(50).allow('').label('namespace'),
|
|
14
|
+
id: Joi.string().custom(validateCharacterSet, 'custom validation characterSet').allow('').label('source identifier'),
|
|
15
|
+
});
|
|
16
|
+
constructor() {
|
|
17
|
+
super();
|
|
18
|
+
}
|
|
19
|
+
init() {}
|
|
20
|
+
async process(input, config, agent: Agent) {
|
|
21
|
+
await super.process(input, config, agent);
|
|
22
|
+
const teamId = agent.teamId;
|
|
23
|
+
const agentId = agent.id;
|
|
24
|
+
let debugOutput = agent.agentRuntime?.debug ? '== Source Indexer Log ==\n' : null;
|
|
25
|
+
|
|
26
|
+
try {
|
|
27
|
+
const configSchema = this.validateConfigData(config.data);
|
|
28
|
+
if (configSchema.error) {
|
|
29
|
+
throw new Error(`Config data validation error: ${configSchema.error}\n EXITING...`);
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const outputs = {};
|
|
33
|
+
for (let con of config.outputs) {
|
|
34
|
+
if (con.default) continue;
|
|
35
|
+
outputs[con.name] = con?.description ? `<${con?.description}>` : '';
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
const inputSchema = this.validateInput(input);
|
|
39
|
+
if (inputSchema.error) {
|
|
40
|
+
throw new Error(`Input validation error: ${inputSchema.error}\n EXITING...`);
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
const namespaceId = configSchema.value.namespaceId.split('_')?.slice(1).join('_') || configSchema.value.namespaceId;
|
|
44
|
+
|
|
45
|
+
let vectorDbConnector = ConnectorService.getVectorDBConnector();
|
|
46
|
+
|
|
47
|
+
let existingnamespace = await vectorDbConnector.requester(AccessCandidate.team(teamId)).namespaceExists(namespaceId);
|
|
48
|
+
if (!existingnamespace) {
|
|
49
|
+
throw new Error(`Namespace ${namespaceId} does not exist`);
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
const providedId = TemplateString(config.data.id).parse(input).result;
|
|
53
|
+
const idRegex = /^[a-zA-Z0-9\-\_\.]+$/;
|
|
54
|
+
if (!idRegex.test(providedId)) {
|
|
55
|
+
throw new Error(`Invalid id. Accepted characters: 'a-z', 'A-Z', '0-9', '-', '_', '.'`);
|
|
56
|
+
}
|
|
57
|
+
debugOutput += `Searching for data source with id: ${providedId}\n`;
|
|
58
|
+
|
|
59
|
+
const dsId = DataSourceIndexer.genDsId(providedId, teamId, namespaceId);
|
|
60
|
+
|
|
61
|
+
await vectorDbConnector.requester(AccessCandidate.team(teamId)).deleteDatasource(namespaceId, dsId);
|
|
62
|
+
|
|
63
|
+
debugOutput += `Deleted data source with id: ${providedId}\n`;
|
|
64
|
+
|
|
65
|
+
return {
|
|
66
|
+
_debug: debugOutput,
|
|
67
|
+
Success: true,
|
|
68
|
+
// _error,
|
|
69
|
+
};
|
|
70
|
+
} catch (err: any) {
|
|
71
|
+
debugOutput += `Failed to delete data source: \n Error: ${err?.message}\n`;
|
|
72
|
+
|
|
73
|
+
return {
|
|
74
|
+
_debug: debugOutput,
|
|
75
|
+
_error: err?.message || "Couldn't delete data source",
|
|
76
|
+
};
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
|
|
80
|
+
validateInput(input: any) {
|
|
81
|
+
return Joi.object({}).unknown(true).validate(input);
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
validateConfigData(data: any) {
|
|
85
|
+
return Joi.object({
|
|
86
|
+
namespaceId: Joi.string().required(),
|
|
87
|
+
id: Joi.string().optional().allow('').allow(null),
|
|
88
|
+
})
|
|
89
|
+
.unknown(true)
|
|
90
|
+
.validate(data);
|
|
91
|
+
}
|
|
92
|
+
}
|