@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,235 +1,235 @@
|
|
|
1
|
-
import { boot } from './boot';
|
|
2
|
-
|
|
3
|
-
import { SREConfig, TConnectorService } from '@sre/types/SRE.types';
|
|
4
|
-
import { Logger } from '../helpers/Log.helper';
|
|
5
|
-
import { ConnectorService } from './ConnectorsService';
|
|
6
|
-
import { SystemEvents } from './SystemEvents';
|
|
7
|
-
import { findSmythPath } from '../helpers/Sysconfig.helper';
|
|
8
|
-
|
|
9
|
-
const logger = Logger('SRE');
|
|
10
|
-
|
|
11
|
-
export class SmythRuntime {
|
|
12
|
-
public started = false;
|
|
13
|
-
|
|
14
|
-
private _smythDir: string;
|
|
15
|
-
public get smythDir() {
|
|
16
|
-
return this._smythDir;
|
|
17
|
-
}
|
|
18
|
-
private _readyPromise: Promise<boolean>;
|
|
19
|
-
private _readyResolve: (value: boolean) => void;
|
|
20
|
-
|
|
21
|
-
private defaultConfig: SREConfig = {
|
|
22
|
-
Vault: {
|
|
23
|
-
Connector: 'JSONFileVault',
|
|
24
|
-
Settings: {
|
|
25
|
-
shared: 'default', //default team shares its secrets with all other teams
|
|
26
|
-
},
|
|
27
|
-
},
|
|
28
|
-
Account: {
|
|
29
|
-
Connector: 'DummyAccount',
|
|
30
|
-
},
|
|
31
|
-
Cache: {
|
|
32
|
-
Connector: 'RAM',
|
|
33
|
-
},
|
|
34
|
-
Storage: {
|
|
35
|
-
Connector: 'LocalStorage',
|
|
36
|
-
},
|
|
37
|
-
Code: {
|
|
38
|
-
Connector: 'DummyConnector',
|
|
39
|
-
},
|
|
40
|
-
//NKV should be loaded before VectorDB
|
|
41
|
-
NKV: {
|
|
42
|
-
Connector: 'LocalStorage',
|
|
43
|
-
},
|
|
44
|
-
VectorDB: {
|
|
45
|
-
Connector: 'RAMVec',
|
|
46
|
-
},
|
|
47
|
-
ModelsProvider: {
|
|
48
|
-
Connector: 'JSONModelsProvider',
|
|
49
|
-
},
|
|
50
|
-
AgentData: {
|
|
51
|
-
Connector: 'NullAgentData',
|
|
52
|
-
},
|
|
53
|
-
Component: {
|
|
54
|
-
Connector: 'LocalComponent',
|
|
55
|
-
},
|
|
56
|
-
ManagedVault: {
|
|
57
|
-
Connector: 'NullManagedVault',
|
|
58
|
-
},
|
|
59
|
-
Log: {
|
|
60
|
-
Connector: 'ConsoleLog',
|
|
61
|
-
},
|
|
62
|
-
Router: {
|
|
63
|
-
Connector: 'NullRouter',
|
|
64
|
-
},
|
|
65
|
-
};
|
|
66
|
-
|
|
67
|
-
protected constructor() {
|
|
68
|
-
this.started = true;
|
|
69
|
-
this._readyPromise = new Promise((resolve) => {
|
|
70
|
-
this._readyResolve = resolve;
|
|
71
|
-
});
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
protected static instance?: SmythRuntime;
|
|
75
|
-
public static get Instance(): SmythRuntime {
|
|
76
|
-
if (!SmythRuntime.instance) {
|
|
77
|
-
SmythRuntime.instance = new SmythRuntime();
|
|
78
|
-
}
|
|
79
|
-
return SmythRuntime.instance;
|
|
80
|
-
}
|
|
81
|
-
|
|
82
|
-
private _initializing = false;
|
|
83
|
-
|
|
84
|
-
public get initializing() {
|
|
85
|
-
return this._initializing;
|
|
86
|
-
}
|
|
87
|
-
|
|
88
|
-
private _initialized = false;
|
|
89
|
-
|
|
90
|
-
public init(_config?: SREConfig): SmythRuntime {
|
|
91
|
-
if (!_config || JSON.stringify(_config) === '{}') {
|
|
92
|
-
this._smythDir = findSmythPath();
|
|
93
|
-
logger.info('.smyth directory found in:', this._smythDir);
|
|
94
|
-
}
|
|
95
|
-
|
|
96
|
-
if (this._initializing) {
|
|
97
|
-
console.warn('You tried to initialize SRE while it is already initializing ... skipping');
|
|
98
|
-
return;
|
|
99
|
-
}
|
|
100
|
-
if (this._initialized) {
|
|
101
|
-
throw new Error('SRE already initialized');
|
|
102
|
-
}
|
|
103
|
-
this._initializing = true;
|
|
104
|
-
SystemEvents.on('SRE:Booted', () => {
|
|
105
|
-
this._readyResolve(true);
|
|
106
|
-
});
|
|
107
|
-
boot();
|
|
108
|
-
|
|
109
|
-
const config = this.autoConf(_config);
|
|
110
|
-
|
|
111
|
-
for (let connectorType in config) {
|
|
112
|
-
for (let configEntry of config[connectorType]) {
|
|
113
|
-
const connector = ConnectorService.init(
|
|
114
|
-
connectorType as TConnectorService,
|
|
115
|
-
configEntry.Connector,
|
|
116
|
-
configEntry.Id,
|
|
117
|
-
configEntry.Settings,
|
|
118
|
-
configEntry.Default
|
|
119
|
-
);
|
|
120
|
-
if (!connector) {
|
|
121
|
-
logger.warn(`Failed to initialize connector ${connectorType}:${configEntry.Id || configEntry.Connector}`);
|
|
122
|
-
}
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
|
|
126
|
-
this._initialized = true;
|
|
127
|
-
SystemEvents.emit('SRE:Initialized', SmythRuntime.Instance);
|
|
128
|
-
|
|
129
|
-
return SmythRuntime.Instance as SmythRuntime;
|
|
130
|
-
}
|
|
131
|
-
|
|
132
|
-
/**
|
|
133
|
-
* This function tries to auto configure, or fixes the provided configuration
|
|
134
|
-
*
|
|
135
|
-
* FIXME: The current version does not actually auto configure SRE, it just fixes the provided configuration for now
|
|
136
|
-
* TODO: Implement auto configuration based on present environment variables and auto-detected configs
|
|
137
|
-
* @param config
|
|
138
|
-
*/
|
|
139
|
-
private autoConf(config: SREConfig = {}) {
|
|
140
|
-
// default config for missing connectors
|
|
141
|
-
const defaultConfig = JSON.parse(JSON.stringify(this.defaultConfig));
|
|
142
|
-
|
|
143
|
-
// for (let connectorType in defaultConfig) {
|
|
144
|
-
// if (!config[connectorType]) {
|
|
145
|
-
// config[connectorType] = defaultConfig[connectorType];
|
|
146
|
-
// }
|
|
147
|
-
// }
|
|
148
|
-
|
|
149
|
-
const keys = Object.keys({ ...defaultConfig, ...config });
|
|
150
|
-
|
|
151
|
-
const newConfig: SREConfig = {};
|
|
152
|
-
for (let connectorType of keys) {
|
|
153
|
-
newConfig[connectorType] = [];
|
|
154
|
-
|
|
155
|
-
let entry = config[connectorType] || defaultConfig[connectorType];
|
|
156
|
-
if (!Array.isArray(entry)) {
|
|
157
|
-
entry = [entry];
|
|
158
|
-
}
|
|
159
|
-
|
|
160
|
-
let hasDefault = false;
|
|
161
|
-
for (let connector of entry) {
|
|
162
|
-
if (!connector.Connector) {
|
|
163
|
-
logger.warn(`Missing Connector Name in ${connectorType} entry ... it will be ignored`);
|
|
164
|
-
continue;
|
|
165
|
-
}
|
|
166
|
-
if (connector.Default) {
|
|
167
|
-
if (hasDefault) {
|
|
168
|
-
logger.warn(`Entry ${connectorType} has more than one default Connector ... only the first one will be used`);
|
|
169
|
-
}
|
|
170
|
-
hasDefault = true;
|
|
171
|
-
}
|
|
172
|
-
newConfig[connectorType].push(connector);
|
|
173
|
-
}
|
|
174
|
-
|
|
175
|
-
if (!hasDefault && newConfig[connectorType].length > 0) {
|
|
176
|
-
newConfig[connectorType][0].Default = true;
|
|
177
|
-
}
|
|
178
|
-
}
|
|
179
|
-
|
|
180
|
-
return newConfig;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
public ready(): Promise<boolean> {
|
|
184
|
-
return this._readyPromise;
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
private _stopping = false;
|
|
188
|
-
public async _stop() {
|
|
189
|
-
if (this._stopping) {
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
this._stopping = true;
|
|
193
|
-
logger.info('Sending Shutdown Signals To All Subsystems...');
|
|
194
|
-
await ConnectorService._stop();
|
|
195
|
-
SmythRuntime.instance = undefined;
|
|
196
|
-
this.started = false;
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
|
|
200
|
-
export const SRE = SmythRuntime.Instance;
|
|
201
|
-
let shuttingDown = false;
|
|
202
|
-
|
|
203
|
-
async function shutdown(reason) {
|
|
204
|
-
if (!SmythRuntime.Instance.started) return;
|
|
205
|
-
if (shuttingDown) return;
|
|
206
|
-
shuttingDown = true;
|
|
207
|
-
|
|
208
|
-
logger.info(`Caught ${reason} ... Attempting graceful shutdown`);
|
|
209
|
-
if (SmythRuntime.Instance) {
|
|
210
|
-
try {
|
|
211
|
-
await SmythRuntime.Instance._stop();
|
|
212
|
-
} catch (err) {
|
|
213
|
-
logger.error('Shutdown error:', err);
|
|
214
|
-
}
|
|
215
|
-
}
|
|
216
|
-
}
|
|
217
|
-
|
|
218
|
-
['SIGINT', 'SIGTERM'].forEach((signal) => {
|
|
219
|
-
process.on(signal, async () => {
|
|
220
|
-
await shutdown(signal);
|
|
221
|
-
process.exit(0); // Required after async
|
|
222
|
-
});
|
|
223
|
-
});
|
|
224
|
-
|
|
225
|
-
process.on('beforeExit', (code) => {
|
|
226
|
-
shutdown('beforeExit');
|
|
227
|
-
});
|
|
228
|
-
|
|
229
|
-
process.on('exit', (code) => {
|
|
230
|
-
logger.info(`Goodbye!`);
|
|
231
|
-
});
|
|
232
|
-
|
|
233
|
-
// process.on('uncaughtException', (err) => {
|
|
234
|
-
|
|
235
|
-
// });
|
|
1
|
+
import { boot } from './boot';
|
|
2
|
+
|
|
3
|
+
import { SREConfig, TConnectorService } from '@sre/types/SRE.types';
|
|
4
|
+
import { Logger } from '../helpers/Log.helper';
|
|
5
|
+
import { ConnectorService } from './ConnectorsService';
|
|
6
|
+
import { SystemEvents } from './SystemEvents';
|
|
7
|
+
import { findSmythPath } from '../helpers/Sysconfig.helper';
|
|
8
|
+
|
|
9
|
+
const logger = Logger('SRE');
|
|
10
|
+
|
|
11
|
+
export class SmythRuntime {
|
|
12
|
+
public started = false;
|
|
13
|
+
|
|
14
|
+
private _smythDir: string;
|
|
15
|
+
public get smythDir() {
|
|
16
|
+
return this._smythDir;
|
|
17
|
+
}
|
|
18
|
+
private _readyPromise: Promise<boolean>;
|
|
19
|
+
private _readyResolve: (value: boolean) => void;
|
|
20
|
+
|
|
21
|
+
private defaultConfig: SREConfig = {
|
|
22
|
+
Vault: {
|
|
23
|
+
Connector: 'JSONFileVault',
|
|
24
|
+
Settings: {
|
|
25
|
+
shared: 'default', //default team shares its secrets with all other teams
|
|
26
|
+
},
|
|
27
|
+
},
|
|
28
|
+
Account: {
|
|
29
|
+
Connector: 'DummyAccount',
|
|
30
|
+
},
|
|
31
|
+
Cache: {
|
|
32
|
+
Connector: 'RAM',
|
|
33
|
+
},
|
|
34
|
+
Storage: {
|
|
35
|
+
Connector: 'LocalStorage',
|
|
36
|
+
},
|
|
37
|
+
Code: {
|
|
38
|
+
Connector: 'DummyConnector',
|
|
39
|
+
},
|
|
40
|
+
//NKV should be loaded before VectorDB
|
|
41
|
+
NKV: {
|
|
42
|
+
Connector: 'LocalStorage',
|
|
43
|
+
},
|
|
44
|
+
VectorDB: {
|
|
45
|
+
Connector: 'RAMVec',
|
|
46
|
+
},
|
|
47
|
+
ModelsProvider: {
|
|
48
|
+
Connector: 'JSONModelsProvider',
|
|
49
|
+
},
|
|
50
|
+
AgentData: {
|
|
51
|
+
Connector: 'NullAgentData',
|
|
52
|
+
},
|
|
53
|
+
Component: {
|
|
54
|
+
Connector: 'LocalComponent',
|
|
55
|
+
},
|
|
56
|
+
ManagedVault: {
|
|
57
|
+
Connector: 'NullManagedVault',
|
|
58
|
+
},
|
|
59
|
+
Log: {
|
|
60
|
+
Connector: 'ConsoleLog',
|
|
61
|
+
},
|
|
62
|
+
Router: {
|
|
63
|
+
Connector: 'NullRouter',
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
|
|
67
|
+
protected constructor() {
|
|
68
|
+
this.started = true;
|
|
69
|
+
this._readyPromise = new Promise((resolve) => {
|
|
70
|
+
this._readyResolve = resolve;
|
|
71
|
+
});
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
protected static instance?: SmythRuntime;
|
|
75
|
+
public static get Instance(): SmythRuntime {
|
|
76
|
+
if (!SmythRuntime.instance) {
|
|
77
|
+
SmythRuntime.instance = new SmythRuntime();
|
|
78
|
+
}
|
|
79
|
+
return SmythRuntime.instance;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
private _initializing = false;
|
|
83
|
+
|
|
84
|
+
public get initializing() {
|
|
85
|
+
return this._initializing;
|
|
86
|
+
}
|
|
87
|
+
|
|
88
|
+
private _initialized = false;
|
|
89
|
+
|
|
90
|
+
public init(_config?: SREConfig): SmythRuntime {
|
|
91
|
+
if (!_config || JSON.stringify(_config) === '{}') {
|
|
92
|
+
this._smythDir = findSmythPath();
|
|
93
|
+
logger.info('.smyth directory found in:', this._smythDir);
|
|
94
|
+
}
|
|
95
|
+
|
|
96
|
+
if (this._initializing) {
|
|
97
|
+
console.warn('You tried to initialize SRE while it is already initializing ... skipping');
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
if (this._initialized) {
|
|
101
|
+
throw new Error('SRE already initialized');
|
|
102
|
+
}
|
|
103
|
+
this._initializing = true;
|
|
104
|
+
SystemEvents.on('SRE:Booted', () => {
|
|
105
|
+
this._readyResolve(true);
|
|
106
|
+
});
|
|
107
|
+
boot();
|
|
108
|
+
|
|
109
|
+
const config = this.autoConf(_config);
|
|
110
|
+
|
|
111
|
+
for (let connectorType in config) {
|
|
112
|
+
for (let configEntry of config[connectorType]) {
|
|
113
|
+
const connector = ConnectorService.init(
|
|
114
|
+
connectorType as TConnectorService,
|
|
115
|
+
configEntry.Connector,
|
|
116
|
+
configEntry.Id,
|
|
117
|
+
configEntry.Settings,
|
|
118
|
+
configEntry.Default
|
|
119
|
+
);
|
|
120
|
+
if (!connector) {
|
|
121
|
+
logger.warn(`Failed to initialize connector ${connectorType}:${configEntry.Id || configEntry.Connector}`);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
this._initialized = true;
|
|
127
|
+
SystemEvents.emit('SRE:Initialized', SmythRuntime.Instance);
|
|
128
|
+
|
|
129
|
+
return SmythRuntime.Instance as SmythRuntime;
|
|
130
|
+
}
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* This function tries to auto configure, or fixes the provided configuration
|
|
134
|
+
*
|
|
135
|
+
* FIXME: The current version does not actually auto configure SRE, it just fixes the provided configuration for now
|
|
136
|
+
* TODO: Implement auto configuration based on present environment variables and auto-detected configs
|
|
137
|
+
* @param config
|
|
138
|
+
*/
|
|
139
|
+
private autoConf(config: SREConfig = {}) {
|
|
140
|
+
// default config for missing connectors
|
|
141
|
+
const defaultConfig = JSON.parse(JSON.stringify(this.defaultConfig));
|
|
142
|
+
|
|
143
|
+
// for (let connectorType in defaultConfig) {
|
|
144
|
+
// if (!config[connectorType]) {
|
|
145
|
+
// config[connectorType] = defaultConfig[connectorType];
|
|
146
|
+
// }
|
|
147
|
+
// }
|
|
148
|
+
|
|
149
|
+
const keys = Object.keys({ ...defaultConfig, ...config });
|
|
150
|
+
|
|
151
|
+
const newConfig: SREConfig = {};
|
|
152
|
+
for (let connectorType of keys) {
|
|
153
|
+
newConfig[connectorType] = [];
|
|
154
|
+
|
|
155
|
+
let entry = config[connectorType] || defaultConfig[connectorType];
|
|
156
|
+
if (!Array.isArray(entry)) {
|
|
157
|
+
entry = [entry];
|
|
158
|
+
}
|
|
159
|
+
|
|
160
|
+
let hasDefault = false;
|
|
161
|
+
for (let connector of entry) {
|
|
162
|
+
if (!connector.Connector) {
|
|
163
|
+
logger.warn(`Missing Connector Name in ${connectorType} entry ... it will be ignored`);
|
|
164
|
+
continue;
|
|
165
|
+
}
|
|
166
|
+
if (connector.Default) {
|
|
167
|
+
if (hasDefault) {
|
|
168
|
+
logger.warn(`Entry ${connectorType} has more than one default Connector ... only the first one will be used`);
|
|
169
|
+
}
|
|
170
|
+
hasDefault = true;
|
|
171
|
+
}
|
|
172
|
+
newConfig[connectorType].push(connector);
|
|
173
|
+
}
|
|
174
|
+
|
|
175
|
+
if (!hasDefault && newConfig[connectorType].length > 0) {
|
|
176
|
+
newConfig[connectorType][0].Default = true;
|
|
177
|
+
}
|
|
178
|
+
}
|
|
179
|
+
|
|
180
|
+
return newConfig;
|
|
181
|
+
}
|
|
182
|
+
|
|
183
|
+
public ready(): Promise<boolean> {
|
|
184
|
+
return this._readyPromise;
|
|
185
|
+
}
|
|
186
|
+
|
|
187
|
+
private _stopping = false;
|
|
188
|
+
public async _stop() {
|
|
189
|
+
if (this._stopping) {
|
|
190
|
+
return;
|
|
191
|
+
}
|
|
192
|
+
this._stopping = true;
|
|
193
|
+
logger.info('Sending Shutdown Signals To All Subsystems...');
|
|
194
|
+
await ConnectorService._stop();
|
|
195
|
+
SmythRuntime.instance = undefined;
|
|
196
|
+
this.started = false;
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
|
|
200
|
+
export const SRE = SmythRuntime.Instance;
|
|
201
|
+
let shuttingDown = false;
|
|
202
|
+
|
|
203
|
+
async function shutdown(reason) {
|
|
204
|
+
if (!SmythRuntime.Instance.started) return;
|
|
205
|
+
if (shuttingDown) return;
|
|
206
|
+
shuttingDown = true;
|
|
207
|
+
|
|
208
|
+
logger.info(`Caught ${reason} ... Attempting graceful shutdown`);
|
|
209
|
+
if (SmythRuntime.Instance) {
|
|
210
|
+
try {
|
|
211
|
+
await SmythRuntime.Instance._stop();
|
|
212
|
+
} catch (err) {
|
|
213
|
+
logger.error('Shutdown error:', err);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
|
|
218
|
+
['SIGINT', 'SIGTERM'].forEach((signal) => {
|
|
219
|
+
process.on(signal, async () => {
|
|
220
|
+
await shutdown(signal);
|
|
221
|
+
process.exit(0); // Required after async
|
|
222
|
+
});
|
|
223
|
+
});
|
|
224
|
+
|
|
225
|
+
process.on('beforeExit', (code) => {
|
|
226
|
+
shutdown('beforeExit');
|
|
227
|
+
});
|
|
228
|
+
|
|
229
|
+
process.on('exit', (code) => {
|
|
230
|
+
logger.info(`Goodbye!`);
|
|
231
|
+
});
|
|
232
|
+
|
|
233
|
+
// process.on('uncaughtException', (err) => {
|
|
234
|
+
|
|
235
|
+
// });
|
package/src/Core/SystemEvents.ts
CHANGED
|
@@ -1,16 +1,16 @@
|
|
|
1
|
-
import { SmythLLMUsage, SmythTaskUsage } from '@sre/types/LLM.types';
|
|
2
|
-
import { TServiceRegistry } from '@sre/types/SRE.types';
|
|
3
|
-
import { EventEmitter } from 'events';
|
|
4
|
-
|
|
5
|
-
export type SystemEventMap = {
|
|
6
|
-
'SRE:BootStart': [];
|
|
7
|
-
'SRE:Booted': [TServiceRegistry];
|
|
8
|
-
'SRE:Initialized': [any?];
|
|
9
|
-
'USAGE:LLM': [SmythLLMUsage];
|
|
10
|
-
'USAGE:API': any;
|
|
11
|
-
'USAGE:TASK': [SmythTaskUsage];
|
|
12
|
-
};
|
|
13
|
-
|
|
14
|
-
const SystemEvents = new EventEmitter<SystemEventMap>();
|
|
15
|
-
|
|
16
|
-
export { SystemEvents };
|
|
1
|
+
import { SmythLLMUsage, SmythTaskUsage } from '@sre/types/LLM.types';
|
|
2
|
+
import { TServiceRegistry } from '@sre/types/SRE.types';
|
|
3
|
+
import { EventEmitter } from 'events';
|
|
4
|
+
|
|
5
|
+
export type SystemEventMap = {
|
|
6
|
+
'SRE:BootStart': [];
|
|
7
|
+
'SRE:Booted': [TServiceRegistry];
|
|
8
|
+
'SRE:Initialized': [any?];
|
|
9
|
+
'USAGE:LLM': [SmythLLMUsage];
|
|
10
|
+
'USAGE:API': any;
|
|
11
|
+
'USAGE:TASK': [SmythTaskUsage];
|
|
12
|
+
};
|
|
13
|
+
|
|
14
|
+
const SystemEvents = new EventEmitter<SystemEventMap>();
|
|
15
|
+
|
|
16
|
+
export { SystemEvents };
|
package/src/Core/boot.ts
CHANGED
|
@@ -1,56 +1,56 @@
|
|
|
1
|
-
import { StorageService } from '@sre/IO/Storage.service';
|
|
2
|
-
import { LLMService } from '@sre/LLMManager/LLM.service';
|
|
3
|
-
import { SystemEvents } from './SystemEvents';
|
|
4
|
-
import { CacheService } from '@sre/MemoryManager/Cache.service';
|
|
5
|
-
import { Logger } from '../helpers/Log.helper';
|
|
6
|
-
import { TServiceRegistry } from '@sre/types/SRE.types';
|
|
7
|
-
import { VaultService } from '@sre/Security/Vault.service';
|
|
8
|
-
import { AccountService } from '@sre/Security/Account.service';
|
|
9
|
-
import { AgentDataService } from '@sre/AgentManager/AgentData.service';
|
|
10
|
-
import { VectorDBService } from '@sre/IO/VectorDB.service';
|
|
11
|
-
import { CLIService } from '@sre/IO/CLI.service';
|
|
12
|
-
import { NKVService } from '@sre/IO/NKV.service';
|
|
13
|
-
import { RouterService } from '@sre/IO/Router.service';
|
|
14
|
-
import { ManagedVaultService } from '@sre/Security/ManagedVault.service';
|
|
15
|
-
import { LogService } from '@sre/IO/Log.service';
|
|
16
|
-
import { ComponentService } from '@sre/AgentManager/Component.service';
|
|
17
|
-
import { ModelsProviderService } from '@sre/LLMManager/ModelsProvider.service';
|
|
18
|
-
import { CodeService } from '@sre/ComputeManager/Code.service';
|
|
19
|
-
const console = Logger('Boot');
|
|
20
|
-
let _booted = false;
|
|
21
|
-
export function boot() {
|
|
22
|
-
if (_booted) {
|
|
23
|
-
console.warn('SRE already booted');
|
|
24
|
-
return;
|
|
25
|
-
}
|
|
26
|
-
_booted = true;
|
|
27
|
-
SystemEvents.emit('SRE:BootStart');
|
|
28
|
-
console.debug('SRE Boot sequence started');
|
|
29
|
-
const service: TServiceRegistry = {};
|
|
30
|
-
service.NKV = new NKVService();
|
|
31
|
-
service.Account = new AccountService();
|
|
32
|
-
service.Vault = new VaultService();
|
|
33
|
-
service.ManagedVault = new ManagedVaultService();
|
|
34
|
-
service.Cache = new CacheService();
|
|
35
|
-
service.Storage = new StorageService();
|
|
36
|
-
service.ModelsProvider = new ModelsProviderService();
|
|
37
|
-
service.LLM = new LLMService();
|
|
38
|
-
service.AgentData = new AgentDataService();
|
|
39
|
-
service.CLI = new CLIService();
|
|
40
|
-
service.VectorDB = new VectorDBService();
|
|
41
|
-
service.Router = new RouterService();
|
|
42
|
-
service.Log = new LogService();
|
|
43
|
-
service.Component = new ComponentService();
|
|
44
|
-
service.Code = new CodeService();
|
|
45
|
-
|
|
46
|
-
SystemEvents.on('SRE:Initialized', () => {
|
|
47
|
-
console.debug('SRE Initialized');
|
|
48
|
-
for (let key in service) {
|
|
49
|
-
service[key].init();
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
SystemEvents.emit('SRE:Booted', service);
|
|
53
|
-
|
|
54
|
-
console.debug('SRE Boot sequence completed');
|
|
55
|
-
});
|
|
56
|
-
}
|
|
1
|
+
import { StorageService } from '@sre/IO/Storage.service';
|
|
2
|
+
import { LLMService } from '@sre/LLMManager/LLM.service';
|
|
3
|
+
import { SystemEvents } from './SystemEvents';
|
|
4
|
+
import { CacheService } from '@sre/MemoryManager/Cache.service';
|
|
5
|
+
import { Logger } from '../helpers/Log.helper';
|
|
6
|
+
import { TServiceRegistry } from '@sre/types/SRE.types';
|
|
7
|
+
import { VaultService } from '@sre/Security/Vault.service';
|
|
8
|
+
import { AccountService } from '@sre/Security/Account.service';
|
|
9
|
+
import { AgentDataService } from '@sre/AgentManager/AgentData.service';
|
|
10
|
+
import { VectorDBService } from '@sre/IO/VectorDB.service';
|
|
11
|
+
import { CLIService } from '@sre/IO/CLI.service';
|
|
12
|
+
import { NKVService } from '@sre/IO/NKV.service';
|
|
13
|
+
import { RouterService } from '@sre/IO/Router.service';
|
|
14
|
+
import { ManagedVaultService } from '@sre/Security/ManagedVault.service';
|
|
15
|
+
import { LogService } from '@sre/IO/Log.service';
|
|
16
|
+
import { ComponentService } from '@sre/AgentManager/Component.service';
|
|
17
|
+
import { ModelsProviderService } from '@sre/LLMManager/ModelsProvider.service';
|
|
18
|
+
import { CodeService } from '@sre/ComputeManager/Code.service';
|
|
19
|
+
const console = Logger('Boot');
|
|
20
|
+
let _booted = false;
|
|
21
|
+
export function boot() {
|
|
22
|
+
if (_booted) {
|
|
23
|
+
console.warn('SRE already booted');
|
|
24
|
+
return;
|
|
25
|
+
}
|
|
26
|
+
_booted = true;
|
|
27
|
+
SystemEvents.emit('SRE:BootStart');
|
|
28
|
+
console.debug('SRE Boot sequence started');
|
|
29
|
+
const service: TServiceRegistry = {};
|
|
30
|
+
service.NKV = new NKVService();
|
|
31
|
+
service.Account = new AccountService();
|
|
32
|
+
service.Vault = new VaultService();
|
|
33
|
+
service.ManagedVault = new ManagedVaultService();
|
|
34
|
+
service.Cache = new CacheService();
|
|
35
|
+
service.Storage = new StorageService();
|
|
36
|
+
service.ModelsProvider = new ModelsProviderService();
|
|
37
|
+
service.LLM = new LLMService();
|
|
38
|
+
service.AgentData = new AgentDataService();
|
|
39
|
+
service.CLI = new CLIService();
|
|
40
|
+
service.VectorDB = new VectorDBService();
|
|
41
|
+
service.Router = new RouterService();
|
|
42
|
+
service.Log = new LogService();
|
|
43
|
+
service.Component = new ComponentService();
|
|
44
|
+
service.Code = new CodeService();
|
|
45
|
+
|
|
46
|
+
SystemEvents.on('SRE:Initialized', () => {
|
|
47
|
+
console.debug('SRE Initialized');
|
|
48
|
+
for (let key in service) {
|
|
49
|
+
service[key].init();
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
SystemEvents.emit('SRE:Booted', service);
|
|
53
|
+
|
|
54
|
+
console.debug('SRE Boot sequence completed');
|
|
55
|
+
});
|
|
56
|
+
}
|
package/src/config.ts
CHANGED
|
@@ -1,15 +1,15 @@
|
|
|
1
|
-
import dotenv from 'dotenv';
|
|
2
|
-
dotenv.config();
|
|
3
|
-
//FIXME : this is a legacy structure from Smyth SaaS we need to convert it to a Service/Connector structure
|
|
4
|
-
const config = {
|
|
5
|
-
env: {
|
|
6
|
-
LOG_LEVEL: process.env.LOG_LEVEL || 'none',
|
|
7
|
-
LOG_FILTER: process.env.LOG_FILTER || '',
|
|
8
|
-
NODE_ENV: process.env?.NODE_ENV,
|
|
9
|
-
},
|
|
10
|
-
agent: {
|
|
11
|
-
ENDPOINT_PREFIX: '/api',
|
|
12
|
-
},
|
|
13
|
-
};
|
|
14
|
-
|
|
15
|
-
export default config;
|
|
1
|
+
import dotenv from 'dotenv';
|
|
2
|
+
dotenv.config();
|
|
3
|
+
//FIXME : this is a legacy structure from Smyth SaaS we need to convert it to a Service/Connector structure
|
|
4
|
+
const config = {
|
|
5
|
+
env: {
|
|
6
|
+
LOG_LEVEL: process.env.LOG_LEVEL || 'none',
|
|
7
|
+
LOG_FILTER: process.env.LOG_FILTER || '',
|
|
8
|
+
NODE_ENV: process.env?.NODE_ENV,
|
|
9
|
+
},
|
|
10
|
+
agent: {
|
|
11
|
+
ENDPOINT_PREFIX: '/api',
|
|
12
|
+
},
|
|
13
|
+
};
|
|
14
|
+
|
|
15
|
+
export default config;
|