@smythos/sre 1.5.1 → 1.5.2
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 +18 -0
- package/package.json +128 -127
- package/src/Components/APICall/APICall.class.ts +155 -0
- package/src/Components/APICall/AccessTokenManager.ts +130 -0
- package/src/Components/APICall/ArrayBufferResponse.helper.ts +58 -0
- package/src/Components/APICall/OAuth.helper.ts +294 -0
- package/src/Components/APICall/mimeTypeCategories.ts +46 -0
- package/src/Components/APICall/parseData.ts +167 -0
- package/src/Components/APICall/parseHeaders.ts +41 -0
- package/src/Components/APICall/parseProxy.ts +68 -0
- package/src/Components/APICall/parseUrl.ts +91 -0
- package/src/Components/APIEndpoint.class.ts +234 -0
- package/src/Components/APIOutput.class.ts +58 -0
- package/src/Components/AgentPlugin.class.ts +102 -0
- package/src/Components/Async.class.ts +155 -0
- package/src/Components/Await.class.ts +90 -0
- package/src/Components/Classifier.class.ts +158 -0
- package/src/Components/Component.class.ts +94 -0
- package/src/Components/ComponentHost.class.ts +38 -0
- package/src/Components/DataSourceCleaner.class.ts +92 -0
- package/src/Components/DataSourceIndexer.class.ts +181 -0
- package/src/Components/DataSourceLookup.class.ts +141 -0
- package/src/Components/FEncDec.class.ts +29 -0
- package/src/Components/FHash.class.ts +33 -0
- package/src/Components/FSign.class.ts +80 -0
- package/src/Components/FSleep.class.ts +25 -0
- package/src/Components/FTimestamp.class.ts +25 -0
- package/src/Components/FileStore.class.ts +75 -0
- package/src/Components/ForEach.class.ts +97 -0
- package/src/Components/GPTPlugin.class.ts +70 -0
- package/src/Components/GenAILLM.class.ts +395 -0
- package/src/Components/HuggingFace.class.ts +314 -0
- package/src/Components/Image/imageSettings.config.ts +70 -0
- package/src/Components/ImageGenerator.class.ts +407 -0
- package/src/Components/JSONFilter.class.ts +54 -0
- package/src/Components/LLMAssistant.class.ts +213 -0
- package/src/Components/LogicAND.class.ts +28 -0
- package/src/Components/LogicAtLeast.class.ts +85 -0
- package/src/Components/LogicAtMost.class.ts +86 -0
- package/src/Components/LogicOR.class.ts +29 -0
- package/src/Components/LogicXOR.class.ts +34 -0
- package/src/Components/MCPClient.class.ts +112 -0
- package/src/Components/PromptGenerator.class.ts +122 -0
- package/src/Components/ScrapflyWebScrape.class.ts +159 -0
- package/src/Components/TavilyWebSearch.class.ts +98 -0
- package/src/Components/index.ts +77 -0
- package/src/Core/AgentProcess.helper.ts +240 -0
- package/src/Core/Connector.class.ts +123 -0
- package/src/Core/ConnectorsService.ts +192 -0
- package/src/Core/DummyConnector.ts +49 -0
- package/src/Core/HookService.ts +105 -0
- package/src/Core/SmythRuntime.class.ts +292 -0
- package/src/Core/SystemEvents.ts +15 -0
- package/src/Core/boot.ts +55 -0
- package/src/config.ts +15 -0
- package/src/constants.ts +125 -0
- package/src/data/hugging-face.params.json +580 -0
- package/src/helpers/BinaryInput.helper.ts +324 -0
- package/src/helpers/Conversation.helper.ts +1094 -0
- package/src/helpers/JsonContent.helper.ts +97 -0
- package/src/helpers/LocalCache.helper.ts +97 -0
- package/src/helpers/Log.helper.ts +234 -0
- package/src/helpers/OpenApiParser.helper.ts +150 -0
- package/src/helpers/S3Cache.helper.ts +129 -0
- package/src/helpers/SmythURI.helper.ts +5 -0
- package/src/helpers/TemplateString.helper.ts +243 -0
- package/src/helpers/TypeChecker.helper.ts +329 -0
- package/src/index.ts +179 -0
- package/src/index.ts.bak +179 -0
- package/src/subsystems/AgentManager/Agent.class.ts +1108 -0
- package/src/subsystems/AgentManager/Agent.helper.ts +3 -0
- package/src/subsystems/AgentManager/AgentData.service/AgentDataConnector.ts +230 -0
- package/src/subsystems/AgentManager/AgentData.service/connectors/CLIAgentDataConnector.class.ts +66 -0
- package/src/subsystems/AgentManager/AgentData.service/connectors/LocalAgentDataConnector.class.ts +142 -0
- package/src/subsystems/AgentManager/AgentData.service/connectors/NullAgentData.class.ts +39 -0
- package/src/subsystems/AgentManager/AgentData.service/index.ts +18 -0
- package/src/subsystems/AgentManager/AgentLogger.class.ts +297 -0
- package/src/subsystems/AgentManager/AgentRequest.class.ts +51 -0
- package/src/subsystems/AgentManager/AgentRuntime.class.ts +559 -0
- package/src/subsystems/AgentManager/AgentSSE.class.ts +101 -0
- package/src/subsystems/AgentManager/AgentSettings.class.ts +52 -0
- package/src/subsystems/AgentManager/Component.service/ComponentConnector.ts +32 -0
- package/src/subsystems/AgentManager/Component.service/connectors/LocalComponentConnector.class.ts +59 -0
- package/src/subsystems/AgentManager/Component.service/index.ts +11 -0
- package/src/subsystems/AgentManager/EmbodimentSettings.class.ts +47 -0
- package/src/subsystems/AgentManager/ForkedAgent.class.ts +153 -0
- package/src/subsystems/AgentManager/OSResourceMonitor.ts +77 -0
- package/src/subsystems/ComputeManager/Code.service/CodeConnector.ts +99 -0
- package/src/subsystems/ComputeManager/Code.service/connectors/AWSLambdaCode.class.ts +63 -0
- package/src/subsystems/ComputeManager/Code.service/index.ts +11 -0
- package/src/subsystems/IO/CLI.service/CLIConnector.ts +47 -0
- package/src/subsystems/IO/CLI.service/index.ts +9 -0
- package/src/subsystems/IO/Log.service/LogConnector.ts +32 -0
- package/src/subsystems/IO/Log.service/connectors/ConsoleLog.class.ts +28 -0
- package/src/subsystems/IO/Log.service/index.ts +13 -0
- package/src/subsystems/IO/NKV.service/NKVConnector.ts +41 -0
- package/src/subsystems/IO/NKV.service/connectors/NKVRAM.class.ts +204 -0
- package/src/subsystems/IO/NKV.service/connectors/NKVRedis.class.ts +182 -0
- package/src/subsystems/IO/NKV.service/index.ts +12 -0
- package/src/subsystems/IO/Router.service/RouterConnector.ts +21 -0
- package/src/subsystems/IO/Router.service/connectors/ExpressRouter.class.ts +48 -0
- package/src/subsystems/IO/Router.service/connectors/NullRouter.class.ts +40 -0
- package/src/subsystems/IO/Router.service/index.ts +11 -0
- package/src/subsystems/IO/Storage.service/SmythFS.class.ts +472 -0
- package/src/subsystems/IO/Storage.service/StorageConnector.ts +66 -0
- package/src/subsystems/IO/Storage.service/connectors/LocalStorage.class.ts +305 -0
- package/src/subsystems/IO/Storage.service/connectors/S3Storage.class.ts +418 -0
- package/src/subsystems/IO/Storage.service/index.ts +13 -0
- package/src/subsystems/IO/VectorDB.service/VectorDBConnector.ts +108 -0
- package/src/subsystems/IO/VectorDB.service/connectors/MilvusVectorDB.class.ts +450 -0
- package/src/subsystems/IO/VectorDB.service/connectors/PineconeVectorDB.class.ts +373 -0
- package/src/subsystems/IO/VectorDB.service/connectors/RAMVecrtorDB.class.ts +420 -0
- package/src/subsystems/IO/VectorDB.service/embed/BaseEmbedding.ts +106 -0
- package/src/subsystems/IO/VectorDB.service/embed/OpenAIEmbedding.ts +109 -0
- package/src/subsystems/IO/VectorDB.service/embed/index.ts +21 -0
- package/src/subsystems/IO/VectorDB.service/index.ts +14 -0
- package/src/subsystems/LLMManager/LLM.helper.ts +221 -0
- package/src/subsystems/LLMManager/LLM.inference.ts +335 -0
- package/src/subsystems/LLMManager/LLM.service/LLMConnector.ts +374 -0
- package/src/subsystems/LLMManager/LLM.service/LLMCredentials.helper.ts +145 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/Anthropic.class.ts +632 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/Bedrock.class.ts +405 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/Echo.class.ts +81 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/GoogleAI.class.ts +689 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/Groq.class.ts +257 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/OpenAI.class.ts +848 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/Perplexity.class.ts +255 -0
- package/src/subsystems/LLMManager/LLM.service/connectors/VertexAI.class.ts +193 -0
- package/src/subsystems/LLMManager/LLM.service/index.ts +43 -0
- package/src/subsystems/LLMManager/ModelsProvider.service/ModelsProviderConnector.ts +281 -0
- package/src/subsystems/LLMManager/ModelsProvider.service/connectors/SmythModelsProvider.class.ts +229 -0
- package/src/subsystems/LLMManager/ModelsProvider.service/index.ts +11 -0
- package/src/subsystems/LLMManager/custom-models.ts +854 -0
- package/src/subsystems/LLMManager/models.ts +2539 -0
- package/src/subsystems/LLMManager/paramMappings.ts +69 -0
- package/src/subsystems/MemoryManager/Cache.service/CacheConnector.ts +86 -0
- package/src/subsystems/MemoryManager/Cache.service/connectors/LocalStorageCache.class.ts +297 -0
- package/src/subsystems/MemoryManager/Cache.service/connectors/RAMCache.class.ts +201 -0
- package/src/subsystems/MemoryManager/Cache.service/connectors/RedisCache.class.ts +252 -0
- package/src/subsystems/MemoryManager/Cache.service/connectors/S3Cache.class.ts +373 -0
- package/src/subsystems/MemoryManager/Cache.service/index.ts +15 -0
- package/src/subsystems/MemoryManager/LLMCache.ts +72 -0
- package/src/subsystems/MemoryManager/LLMContext.ts +125 -0
- package/src/subsystems/MemoryManager/RuntimeContext.ts +249 -0
- package/src/subsystems/Security/AccessControl/ACL.class.ts +208 -0
- package/src/subsystems/Security/AccessControl/AccessCandidate.class.ts +76 -0
- package/src/subsystems/Security/AccessControl/AccessRequest.class.ts +52 -0
- package/src/subsystems/Security/Account.service/AccountConnector.ts +41 -0
- package/src/subsystems/Security/Account.service/connectors/AWSAccount.class.ts +76 -0
- package/src/subsystems/Security/Account.service/connectors/DummyAccount.class.ts +130 -0
- package/src/subsystems/Security/Account.service/connectors/JSONFileAccount.class.ts +159 -0
- package/src/subsystems/Security/Account.service/index.ts +14 -0
- package/src/subsystems/Security/Credentials.helper.ts +62 -0
- package/src/subsystems/Security/ManagedVault.service/ManagedVaultConnector.ts +34 -0
- package/src/subsystems/Security/ManagedVault.service/connectors/NullManagedVault.class.ts +57 -0
- package/src/subsystems/Security/ManagedVault.service/connectors/SecretManagerManagedVault.ts +154 -0
- package/src/subsystems/Security/ManagedVault.service/index.ts +12 -0
- package/src/subsystems/Security/SecureConnector.class.ts +110 -0
- package/src/subsystems/Security/Vault.service/Vault.helper.ts +30 -0
- package/src/subsystems/Security/Vault.service/VaultConnector.ts +26 -0
- package/src/subsystems/Security/Vault.service/connectors/HashicorpVault.class.ts +46 -0
- package/src/subsystems/Security/Vault.service/connectors/JSONFileVault.class.ts +166 -0
- package/src/subsystems/Security/Vault.service/connectors/NullVault.class.ts +54 -0
- package/src/subsystems/Security/Vault.service/connectors/SecretsManager.class.ts +140 -0
- package/src/subsystems/Security/Vault.service/index.ts +12 -0
- package/src/types/ACL.types.ts +104 -0
- package/src/types/AWS.types.ts +9 -0
- package/src/types/Agent.types.ts +61 -0
- package/src/types/AgentLogger.types.ts +17 -0
- package/src/types/Cache.types.ts +1 -0
- package/src/types/Common.types.ts +3 -0
- package/src/types/LLM.types.ts +419 -0
- package/src/types/Redis.types.ts +8 -0
- package/src/types/SRE.types.ts +64 -0
- package/src/types/Security.types.ts +18 -0
- package/src/types/Storage.types.ts +5 -0
- package/src/types/VectorDB.types.ts +78 -0
- package/src/utils/base64.utils.ts +275 -0
- package/src/utils/cli.utils.ts +68 -0
- package/src/utils/data.utils.ts +263 -0
- package/src/utils/date-time.utils.ts +22 -0
- package/src/utils/general.utils.ts +238 -0
- package/src/utils/index.ts +12 -0
- package/src/utils/numbers.utils.ts +13 -0
- package/src/utils/oauth.utils.ts +35 -0
- package/src/utils/string.utils.ts +414 -0
- package/src/utils/url.utils.ts +19 -0
- package/src/utils/validation.utils.ts +74 -0
package/LICENSE
ADDED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
The MIT License
|
|
2
|
+
|
|
3
|
+
Copyright 2025, INK Content, Inc.
|
|
4
|
+
|
|
5
|
+
Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated
|
|
6
|
+
documentation files (the “Software”), to deal in the Software without restriction, including without limitation
|
|
7
|
+
the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and
|
|
8
|
+
to permit persons to whom the Software is furnished to do so, subject to the following conditions:
|
|
9
|
+
The above copyright notice and this permission notice shall be included in all copies or substantial portions
|
|
10
|
+
of the Software.
|
|
11
|
+
|
|
12
|
+
THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
13
|
+
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
14
|
+
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
15
|
+
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
16
|
+
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
17
|
+
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
|
|
18
|
+
SOFTWARE.
|
package/package.json
CHANGED
|
@@ -1,128 +1,129 @@
|
|
|
1
1
|
{
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
"
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
"
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
"
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
"
|
|
128
|
-
}
|
|
2
|
+
"name": "@smythos/sre",
|
|
3
|
+
"version": "1.5.2",
|
|
4
|
+
"description": "Smyth Runtime Environment",
|
|
5
|
+
"author": "Alaa-eddine KADDOURI",
|
|
6
|
+
"license": "MIT",
|
|
7
|
+
"main": "dist/index.js",
|
|
8
|
+
"types": "dist/types/index.d.ts",
|
|
9
|
+
"exports": {
|
|
10
|
+
".": {
|
|
11
|
+
"import": "./dist/index.js",
|
|
12
|
+
"types": "./dist/types/index.d.ts"
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
"files": [
|
|
16
|
+
"dist",
|
|
17
|
+
"src",
|
|
18
|
+
"README.md",
|
|
19
|
+
"CHANGELOG"
|
|
20
|
+
],
|
|
21
|
+
"type": "module",
|
|
22
|
+
"devDependencies": {
|
|
23
|
+
"@faker-js/faker": "^8.4.1",
|
|
24
|
+
"@istanbuljs/nyc-config-typescript": "^1.0.2",
|
|
25
|
+
"@rollup/plugin-json": "^6.1.0",
|
|
26
|
+
"@rollup/plugin-node-resolve": "^15.2.3",
|
|
27
|
+
"@rollup/pluginutils": "^5.1.0",
|
|
28
|
+
"@types/cookie-parser": "^1.4.7",
|
|
29
|
+
"@types/express": "^4.17.23",
|
|
30
|
+
"@types/express-session": "^1.18.0",
|
|
31
|
+
"@types/lodash": "^4.17.10",
|
|
32
|
+
"@types/node": "^20.19.0",
|
|
33
|
+
"cross-env": "^7.0.3",
|
|
34
|
+
"ctix": "^2.7.1",
|
|
35
|
+
"dependency-cruiser": "^16.3.3",
|
|
36
|
+
"esbuild": "^0.25.0",
|
|
37
|
+
"knip": "^5.23.1",
|
|
38
|
+
"nyc": "^17.0.0",
|
|
39
|
+
"pkg": "^5.8.1",
|
|
40
|
+
"rollup-plugin-copy": "^3.5.0",
|
|
41
|
+
"rollup-plugin-esbuild": "^6.1.1",
|
|
42
|
+
"rollup-plugin-sourcemaps": "^0.6.3",
|
|
43
|
+
"rollup-plugin-terser": "^7.0.2",
|
|
44
|
+
"rollup-plugin-typescript-paths": "^1.5.0",
|
|
45
|
+
"rollup-plugin-typescript2": "^0.36.0",
|
|
46
|
+
"source-map-support": "^0.5.21",
|
|
47
|
+
"typedoc": "^0.28.5",
|
|
48
|
+
"typedoc-github-theme": "^0.3.0",
|
|
49
|
+
"typescript": "^5.4.5"
|
|
50
|
+
},
|
|
51
|
+
"dependencies": {
|
|
52
|
+
"@anthropic-ai/sdk": "^0.39.0",
|
|
53
|
+
"@apidevtools/json-schema-ref-parser": "^11.6.4",
|
|
54
|
+
"@aws-sdk/client-bedrock-runtime": "^3.826.0",
|
|
55
|
+
"@aws-sdk/client-iam": "^3.826.0",
|
|
56
|
+
"@aws-sdk/client-lambda": "^3.826.0",
|
|
57
|
+
"@aws-sdk/client-s3": "^3.826.0",
|
|
58
|
+
"@aws-sdk/client-secrets-manager": "^3.826.0",
|
|
59
|
+
"@google-cloud/vertexai": "^1.7.0",
|
|
60
|
+
"@google/generative-ai": "^0.14.1",
|
|
61
|
+
"@huggingface/inference": "^2.8.0",
|
|
62
|
+
"@modelcontextprotocol/sdk": "^1.10.1",
|
|
63
|
+
"@pinecone-database/pinecone": "^3.0.0",
|
|
64
|
+
"@runware/sdk-js": "^1.1.36",
|
|
65
|
+
"@smithy/smithy-client": "^4.4.3",
|
|
66
|
+
"@zilliz/milvus2-sdk-node": "^2.5.11",
|
|
67
|
+
"acorn": "^8.14.1",
|
|
68
|
+
"axios": "^1.7.2",
|
|
69
|
+
"chokidar": "^4.0.3",
|
|
70
|
+
"commander": "^11.1.0",
|
|
71
|
+
"cookie-parser": "^1.4.7",
|
|
72
|
+
"cors": "^2.8.5",
|
|
73
|
+
"dayjs": "^1.11.11",
|
|
74
|
+
"dotenv": "^16.4.5",
|
|
75
|
+
"eventsource": "^3.0.2",
|
|
76
|
+
"express": "^4.21.2",
|
|
77
|
+
"express-async-handler": "^1.2.0",
|
|
78
|
+
"express-session": "^1.18.1",
|
|
79
|
+
"file-type": "^19.0.0",
|
|
80
|
+
"form-data": "^4.0.3",
|
|
81
|
+
"gpt-tokenizer": "^2.2.1",
|
|
82
|
+
"groq-sdk": "^0.6.1",
|
|
83
|
+
"image-size": "^1.1.1",
|
|
84
|
+
"ioredis": "^5.4.1",
|
|
85
|
+
"isbinaryfile": "^5.0.2",
|
|
86
|
+
"joi": "^17.13.1",
|
|
87
|
+
"js-yaml": "^4.1.0",
|
|
88
|
+
"jsonrepair": "^3.8.0",
|
|
89
|
+
"jsonwebtoken": "^9.0.2",
|
|
90
|
+
"jwks-rsa": "^3.1.0",
|
|
91
|
+
"lodash": "^4.17.21",
|
|
92
|
+
"memorystore": "^1.6.7",
|
|
93
|
+
"mime": "^4.0.3",
|
|
94
|
+
"multer": "^1.4.5-lts.1",
|
|
95
|
+
"mysql2": "^3.11.3",
|
|
96
|
+
"oauth-1.0a": "^2.2.6",
|
|
97
|
+
"openai": "^4.103.0",
|
|
98
|
+
"p-limit": "^6.1.0",
|
|
99
|
+
"pkce-challenge": "^5.0.0",
|
|
100
|
+
"qs": "^6.13.0",
|
|
101
|
+
"rate-limiter-flexible": "^5.0.3",
|
|
102
|
+
"readline-sync": "^1.4.10",
|
|
103
|
+
"socket.io-client": "^4.8.1",
|
|
104
|
+
"socks-proxy-agent": "^8.0.4",
|
|
105
|
+
"uuid": "^10.0.0",
|
|
106
|
+
"winston": "^3.13.0",
|
|
107
|
+
"winston-transport": "^4.7.0",
|
|
108
|
+
"xxhashjs": "^0.2.2",
|
|
109
|
+
"zip-lib": "^1.0.5"
|
|
110
|
+
},
|
|
111
|
+
"repository": {
|
|
112
|
+
"type": "git",
|
|
113
|
+
"url": "https://github.com/smythos/sre.git",
|
|
114
|
+
"directory": "packages/core"
|
|
115
|
+
},
|
|
116
|
+
"bugs": {
|
|
117
|
+
"url": "https://github.com/smythos/sre/issues"
|
|
118
|
+
},
|
|
119
|
+
"homepage": "https://github.com/smythos/sre/tree/main/packages/core#readme",
|
|
120
|
+
"scripts": {
|
|
121
|
+
"gen:barrel": "ctix build",
|
|
122
|
+
"build:types": "tsc --emitDeclarationOnly --declaration --outDir dist/types -p tsconfig.dts.json",
|
|
123
|
+
"build:jsbundle": "cross-env rollup -c",
|
|
124
|
+
"build": "pnpm run build:jsbundle && pnpm run build:types",
|
|
125
|
+
"doc:gen": "typedoc",
|
|
126
|
+
"doc:graphgen": "npx depcruise src --config ./doc/.dep-minimal.json --output-type dot > ./doc/dep-graph.dot && dot -Tpng ./doc/dep-graph.dot -o ./doc/dep-graph.png",
|
|
127
|
+
"knip": "knip"
|
|
128
|
+
}
|
|
129
|
+
}
|
|
@@ -0,0 +1,155 @@
|
|
|
1
|
+
import axios, { AxiosRequestConfig } from 'axios';
|
|
2
|
+
import Joi from 'joi';
|
|
3
|
+
|
|
4
|
+
import { Agent } from '@sre/AgentManager/Agent.class';
|
|
5
|
+
import { Component } from '../Component.class';
|
|
6
|
+
import { parseHeaders } from './parseHeaders';
|
|
7
|
+
import { parseUrl, parseSmythFsUrl, destroyPublicUrls } from './parseUrl';
|
|
8
|
+
import { parseData } from './parseData';
|
|
9
|
+
import { parseProxy } from './parseProxy';
|
|
10
|
+
import { parseArrayBufferResponse } from './ArrayBufferResponse.helper';
|
|
11
|
+
import { extractAdditionalParamsForOAuth1, handleOAuthHeaders as generateOAuthHeaders } from './OAuth.helper';
|
|
12
|
+
import { SocksProxyAgent } from 'socks-proxy-agent';
|
|
13
|
+
import { formatDataForDebug } from '@sre/utils/data.utils';
|
|
14
|
+
|
|
15
|
+
export class APICall extends Component {
|
|
16
|
+
protected schema = {
|
|
17
|
+
name: 'APICall',
|
|
18
|
+
description: 'Use this component to make an API call',
|
|
19
|
+
inputs: {},
|
|
20
|
+
outputs: {
|
|
21
|
+
Headers: {
|
|
22
|
+
description: 'The headers of the API call response',
|
|
23
|
+
default: true,
|
|
24
|
+
},
|
|
25
|
+
Response: {
|
|
26
|
+
description: 'The response of the API call',
|
|
27
|
+
default: true,
|
|
28
|
+
},
|
|
29
|
+
},
|
|
30
|
+
};
|
|
31
|
+
|
|
32
|
+
protected configSchema = Joi.object({
|
|
33
|
+
method: Joi.string().valid('GET', 'POST', 'PUT', 'PATCH', 'DELETE', 'HEAD', 'OPTIONS').required().label('Method'),
|
|
34
|
+
url: Joi.string()
|
|
35
|
+
.max(8192) /*.custom(isUrlValid, 'URL validation')*/
|
|
36
|
+
.required()
|
|
37
|
+
.label('URL'),
|
|
38
|
+
headers: Joi.any().allow('').label('Headers'),
|
|
39
|
+
contentType: Joi.string()
|
|
40
|
+
.valid('none', 'application/json', 'multipart/form-data', 'binary', 'application/x-www-form-urlencoded', 'text/plain', 'application/xml')
|
|
41
|
+
.label('Content-Type'),
|
|
42
|
+
body: Joi.any().allow('').label('Body'),
|
|
43
|
+
_templateSettings: Joi.object().allow(null).label('Template Settings'),
|
|
44
|
+
_templateVars: Joi.object().allow(null).label('Template Variables'),
|
|
45
|
+
proxy: Joi.string().allow('').label('Proxy'),
|
|
46
|
+
oauthService: Joi.string().allow('').label('OAuth Service'),
|
|
47
|
+
scope: Joi.string().allow('').label('Scope'),
|
|
48
|
+
authorizationURL: Joi.string().allow('').label('Authorization URL'),
|
|
49
|
+
tokenURL: Joi.string().allow('').label('Token URL'),
|
|
50
|
+
clientID: Joi.string().allow('').label('Client ID'),
|
|
51
|
+
clientSecret: Joi.string().allow('').label('Client Secret'),
|
|
52
|
+
oauth2CallbackURL: Joi.string().allow('').label('OAuth2 Callback URL'),
|
|
53
|
+
callbackURL: Joi.string().allow('').label('Callback URL'), // !TEMP: prevent validation error
|
|
54
|
+
requestTokenURL: Joi.string().allow('').label('Request Token URL'),
|
|
55
|
+
accessTokenURL: Joi.string().allow('').label('Access Token URL'),
|
|
56
|
+
userAuthorizationURL: Joi.string().allow('').label('User Authorization URL'),
|
|
57
|
+
consumerKey: Joi.string().allow('').label('Consumer Key'),
|
|
58
|
+
consumerSecret: Joi.string().allow('').label('Consumer Secret'),
|
|
59
|
+
oauth1CallbackURL: Joi.string().allow('').label('OAuth1 Callback URL'),
|
|
60
|
+
authenticate: Joi.string().allow('').label('Authenticate'),
|
|
61
|
+
});
|
|
62
|
+
constructor() {
|
|
63
|
+
super();
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
init() {}
|
|
67
|
+
|
|
68
|
+
async process(input, config, agent: Agent) {
|
|
69
|
+
await super.process(input, config, agent);
|
|
70
|
+
|
|
71
|
+
const logger = this.createComponentLogger(agent, config);
|
|
72
|
+
|
|
73
|
+
let publicUrls: string[] = [];
|
|
74
|
+
|
|
75
|
+
try {
|
|
76
|
+
logger.debug(`=== API Call Log ===`);
|
|
77
|
+
|
|
78
|
+
const method = config?.data?.method || 'get';
|
|
79
|
+
|
|
80
|
+
const reqConfig: AxiosRequestConfig = {};
|
|
81
|
+
reqConfig.method = method;
|
|
82
|
+
|
|
83
|
+
reqConfig.url = await parseUrl(input, config, agent);
|
|
84
|
+
|
|
85
|
+
// We generate public URLs for any resources specified with the smythfs protocol in the request URL.
|
|
86
|
+
({ url: reqConfig.url, publicUrls } = await parseSmythFsUrl(reqConfig.url, agent));
|
|
87
|
+
|
|
88
|
+
const { data, headers } = await parseData(input, config, agent);
|
|
89
|
+
|
|
90
|
+
// If the data is null, the request may fail. We encountered an issue where a request failed due to null data being provided.
|
|
91
|
+
let dataForDebug;
|
|
92
|
+
if (data) {
|
|
93
|
+
reqConfig.data = data;
|
|
94
|
+
|
|
95
|
+
dataForDebug = await formatDataForDebug(data);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
reqConfig.headers = (await parseHeaders(input, config, agent)).concat({ ...headers });
|
|
99
|
+
|
|
100
|
+
const proxyConfig = await parseProxy(input, config, agent);
|
|
101
|
+
|
|
102
|
+
if (proxyConfig) {
|
|
103
|
+
if (proxyConfig instanceof SocksProxyAgent) {
|
|
104
|
+
const isSecureEndpoint = reqConfig.url?.startsWith('https://');
|
|
105
|
+
reqConfig[isSecureEndpoint ? 'httpsAgent' : 'httpAgent'] = proxyConfig;
|
|
106
|
+
} else {
|
|
107
|
+
reqConfig.proxy = proxyConfig;
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
let Response: any = {};
|
|
112
|
+
let Headers: any = {};
|
|
113
|
+
let _error: any = undefined;
|
|
114
|
+
try {
|
|
115
|
+
if (config?.data?.oauthService && config?.data?.oauthService !== 'None') {
|
|
116
|
+
const rootUrl = new URL(reqConfig.url).origin;
|
|
117
|
+
const additionalParams = extractAdditionalParamsForOAuth1(reqConfig);
|
|
118
|
+
const oauthHeaders = await generateOAuthHeaders(agent, config, reqConfig, logger, additionalParams, rootUrl);
|
|
119
|
+
//reqConfig.headers = { ...reqConfig.headers, ...oauthHeaders };
|
|
120
|
+
reqConfig.headers = reqConfig.headers.concat({ ...oauthHeaders });
|
|
121
|
+
}
|
|
122
|
+
|
|
123
|
+
// in order to handle binary data automatically, we need to set responseType to 'arraybuffer' for all requests, then parse the response data based on content-type
|
|
124
|
+
reqConfig.responseType = 'arraybuffer';
|
|
125
|
+
|
|
126
|
+
logger.debug('Making API call', { ...reqConfig, data: dataForDebug });
|
|
127
|
+
|
|
128
|
+
const response = await axios.request(reqConfig);
|
|
129
|
+
|
|
130
|
+
const parsedRes = await parseArrayBufferResponse(response, agent);
|
|
131
|
+
|
|
132
|
+
// log response headers
|
|
133
|
+
logger.debug('API call Response Headers', response.headers);
|
|
134
|
+
Response = parsedRes;
|
|
135
|
+
|
|
136
|
+
logger.debug('API call Response\n', Response);
|
|
137
|
+
|
|
138
|
+
Headers = Object.fromEntries(Object.entries(response.headers));
|
|
139
|
+
} catch (error) {
|
|
140
|
+
logger.debug(`Error making API call: ${error.message}`);
|
|
141
|
+
Headers = error?.response?.headers ? Object.fromEntries(Object.entries(error.response.headers)) : {};
|
|
142
|
+
Response = await parseArrayBufferResponse(error.response, agent);
|
|
143
|
+
_error = error.message;
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
return { Response, Headers, _error, _debug: logger.output };
|
|
147
|
+
} catch (error) {
|
|
148
|
+
return { _error: error.message, _debug: logger.output };
|
|
149
|
+
} finally {
|
|
150
|
+
if (publicUrls.length > 0) {
|
|
151
|
+
await destroyPublicUrls(publicUrls);
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
}
|
|
@@ -0,0 +1,130 @@
|
|
|
1
|
+
// accessTokenManager.ts
|
|
2
|
+
import { Agent } from '@sre/AgentManager/Agent.class';
|
|
3
|
+
import { ConnectorService } from '@sre/Core/ConnectorsService';
|
|
4
|
+
import { SystemEvents } from '@sre/Core/SystemEvents';
|
|
5
|
+
import { Logger } from '@sre/helpers/Log.helper';
|
|
6
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
7
|
+
import axios from 'axios';
|
|
8
|
+
|
|
9
|
+
const console = Logger('AccessTokenManager');
|
|
10
|
+
let managedVault: any;
|
|
11
|
+
|
|
12
|
+
SystemEvents.on('SRE:Booted', () => {
|
|
13
|
+
managedVault = ConnectorService.getManagedVaultConnector();
|
|
14
|
+
});
|
|
15
|
+
class AccessTokenManager {
|
|
16
|
+
private clientId: string;
|
|
17
|
+
private clientSecret: string;
|
|
18
|
+
private primaryToken: string; // accessToken || token
|
|
19
|
+
private secondaryToken: string; // refreshToken || tokenSecret
|
|
20
|
+
private tokenUrl: string; // tokenURL to refresh accessToken
|
|
21
|
+
private expires_in: any;
|
|
22
|
+
private data: any; // value of key(keyId) in teamSettings that needs to be updated if required
|
|
23
|
+
private keyId: any; // key of object in teamSettings
|
|
24
|
+
private logger: any; // Use to log console in debugger
|
|
25
|
+
private agent: Agent;
|
|
26
|
+
constructor(
|
|
27
|
+
clientId: string,
|
|
28
|
+
clientSecret: string,
|
|
29
|
+
secondaryToken: string,
|
|
30
|
+
tokenUrl: string,
|
|
31
|
+
expires_in: any,
|
|
32
|
+
primaryToken: string,
|
|
33
|
+
data: any,
|
|
34
|
+
keyId: any,
|
|
35
|
+
logger: any,
|
|
36
|
+
agent: Agent,
|
|
37
|
+
) {
|
|
38
|
+
this.clientId = clientId;
|
|
39
|
+
this.clientSecret = clientSecret;
|
|
40
|
+
this.primaryToken = primaryToken;
|
|
41
|
+
this.secondaryToken = secondaryToken;
|
|
42
|
+
this.tokenUrl = tokenUrl;
|
|
43
|
+
this.expires_in = expires_in;
|
|
44
|
+
this.data = data;
|
|
45
|
+
this.keyId = keyId;
|
|
46
|
+
this.logger = logger;
|
|
47
|
+
this.agent = agent;
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
async getAccessToken(): Promise<string> {
|
|
51
|
+
try {
|
|
52
|
+
const currentTime: any = new Date().getTime();
|
|
53
|
+
|
|
54
|
+
// If there's no secondaryToken (refresh token) and no expires_in,
|
|
55
|
+
// assume it's a long-lived token and return the primaryToken directly
|
|
56
|
+
if (!this.secondaryToken && !this.expires_in) {
|
|
57
|
+
console.log('Using long-lived access token');
|
|
58
|
+
this.logger.debug('Using long-lived access token. If authentication failes, please re-authenticate and try again');
|
|
59
|
+
return this.primaryToken;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// Regular token expiration check for tokens with expiration
|
|
63
|
+
// should be alway currentTime >= Number(this.expires_in)
|
|
64
|
+
if (!this.expires_in || currentTime >= Number(this.expires_in)) {
|
|
65
|
+
if (!this.secondaryToken) {
|
|
66
|
+
this.logger.debug('Refresh token is missing. Please re authenticate');
|
|
67
|
+
console.log('Refresh token is missing. Please re authenticate...');
|
|
68
|
+
// Redirect the user to the OAuth authorization URL or initiate the reauthentication flow
|
|
69
|
+
throw new Error('Reauthentication required');
|
|
70
|
+
}
|
|
71
|
+
this.logger.debug('Access token is expired or missing. Refreshing access token...');
|
|
72
|
+
console.log('Access token is expired or missing. Refreshing access token...');
|
|
73
|
+
return await this.refreshAccessToken();
|
|
74
|
+
} else {
|
|
75
|
+
console.log('Access token is still valid');
|
|
76
|
+
this.logger.debug('Access token is still valid.');
|
|
77
|
+
return this.primaryToken;
|
|
78
|
+
}
|
|
79
|
+
} catch (error) {
|
|
80
|
+
console.error('Error fetching access token:', error);
|
|
81
|
+
this.logger.debug('Error fetching access token');
|
|
82
|
+
throw error;
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
async refreshAccessToken(): Promise<string> {
|
|
87
|
+
try {
|
|
88
|
+
const response = await axios.post(
|
|
89
|
+
this.tokenUrl,
|
|
90
|
+
new URLSearchParams({
|
|
91
|
+
client_id: this.clientId,
|
|
92
|
+
client_secret: this.clientSecret,
|
|
93
|
+
refresh_token: this.secondaryToken,
|
|
94
|
+
grant_type: 'refresh_token',
|
|
95
|
+
}).toString(),
|
|
96
|
+
{
|
|
97
|
+
headers: {
|
|
98
|
+
'Content-Type': 'application/x-www-form-urlencoded',
|
|
99
|
+
},
|
|
100
|
+
},
|
|
101
|
+
);
|
|
102
|
+
|
|
103
|
+
const newAccessToken: string = response?.data?.access_token;
|
|
104
|
+
console.log('Access token refreshed successfully.');
|
|
105
|
+
this.logger.debug('Access token refreshed successfully.');
|
|
106
|
+
const expiresInMilliseconds: number = response?.data?.expires_in ? response?.data?.expires_in * 1000 : response?.data?.expires_in;
|
|
107
|
+
const expirationTimestamp: number = expiresInMilliseconds ? new Date().getTime() + expiresInMilliseconds : expiresInMilliseconds;
|
|
108
|
+
this.data.primary = newAccessToken;
|
|
109
|
+
this.data.expires_in = expirationTimestamp ? expirationTimestamp?.toString() : expirationTimestamp;
|
|
110
|
+
//const oauthTeamSettings = new OauthTeamSettings();
|
|
111
|
+
//const save: any = await oauthTeamSettings.update({ keyId: this.keyId, data: this.data });
|
|
112
|
+
|
|
113
|
+
const save: any = await managedVault.user(AccessCandidate.agent(this.agent.id)).set(this.keyId, JSON.stringify(this.data));
|
|
114
|
+
if (save && save.status === 200) {
|
|
115
|
+
console.log('Access token value is updated successfully.');
|
|
116
|
+
this.logger.debug('Access token value is updated successfully.');
|
|
117
|
+
} else {
|
|
118
|
+
console.log('Warning: new access token value is not updated.');
|
|
119
|
+
this.logger.debug('Warning: new access token value is not updated.');
|
|
120
|
+
}
|
|
121
|
+
return newAccessToken;
|
|
122
|
+
} catch (error) {
|
|
123
|
+
console.error('Failed to refresh access token:', error);
|
|
124
|
+
this.logger.debug(`Failed to refresh access token: ${error}`);
|
|
125
|
+
throw new Error('Failed to refresh access token.');
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
|
|
130
|
+
export default AccessTokenManager;
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { Agent } from '@sre/AgentManager/Agent.class';
|
|
2
|
+
import { BinaryInput } from '@sre/helpers/BinaryInput.helper';
|
|
3
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
4
|
+
import { isBinaryData, isBinaryMimeType } from '@sre/utils/data.utils';
|
|
5
|
+
import { AxiosResponse } from 'axios';
|
|
6
|
+
import mimeTypeCategories from './mimeTypeCategories';
|
|
7
|
+
|
|
8
|
+
const contentHandlers = {
|
|
9
|
+
json: parseJson,
|
|
10
|
+
text: parseText,
|
|
11
|
+
binary: parseBinary,
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
function parseJson(data) {
|
|
15
|
+
return JSON.parse(Buffer.from(data).toString('utf8') || '{}');
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
function parseText(data) {
|
|
19
|
+
return Buffer.from(data).toString('utf8');
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
async function parseBinary(data, contentType, agentId) {
|
|
23
|
+
const binaryInput = BinaryInput.from(data, null, contentType);
|
|
24
|
+
const smythFile = await binaryInput.getJsonData(AccessCandidate.agent(agentId));
|
|
25
|
+
|
|
26
|
+
return smythFile;
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
export async function parseArrayBufferResponse(response: AxiosResponse, agent: Agent): Promise<any> {
|
|
30
|
+
if (!response?.data) {
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
const data = response.data;
|
|
34
|
+
const contentType = response.headers['content-type'];
|
|
35
|
+
const cleanContentType = contentType?.split(';')[0];
|
|
36
|
+
|
|
37
|
+
// Try to find an exact match first,
|
|
38
|
+
let handlerType = Object.keys(mimeTypeCategories).find((type) => mimeTypeCategories[type].includes(cleanContentType));
|
|
39
|
+
|
|
40
|
+
// If no exact match, try to find a match for the first part of the handlerTypes, some handlers are generic like text/ in that case we check if the handler is a substring of the contentType
|
|
41
|
+
if (!handlerType) {
|
|
42
|
+
handlerType = Object.keys(mimeTypeCategories).find((type) => mimeTypeCategories[type].some((prefix) => cleanContentType?.startsWith(prefix)));
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
const handler = contentHandlers[handlerType];
|
|
46
|
+
|
|
47
|
+
if (handler) {
|
|
48
|
+
return handler(data, contentType, agent.id);
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
// Fallback: if no content type matches then check if the data is binary
|
|
52
|
+
// If so then parse it as binary, otherwise parse it as text
|
|
53
|
+
if (isBinaryMimeType(contentType) || isBinaryData(data)) {
|
|
54
|
+
return parseBinary(data, contentType, agent.id);
|
|
55
|
+
} else {
|
|
56
|
+
return parseText(data);
|
|
57
|
+
}
|
|
58
|
+
}
|