@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,52 +1,52 @@
|
|
|
1
|
-
import { IAccessCandidate, IAccessRequest, TAccessLevel } from '@sre/types/ACL.types';
|
|
2
|
-
import { uid } from '@sre/utils/index';
|
|
3
|
-
|
|
4
|
-
export class AccessRequest implements IAccessRequest {
|
|
5
|
-
public id: string;
|
|
6
|
-
public resourceId: string;
|
|
7
|
-
|
|
8
|
-
public level: TAccessLevel[] = [];
|
|
9
|
-
public candidate: IAccessCandidate;
|
|
10
|
-
|
|
11
|
-
constructor(object?: IAccessRequest | IAccessCandidate) {
|
|
12
|
-
if (!object) {
|
|
13
|
-
this.id = 'aclR:' + uid();
|
|
14
|
-
}
|
|
15
|
-
if (['role', 'id'].every((k) => k in object)) {
|
|
16
|
-
//this is a candidate
|
|
17
|
-
this.id = 'aclR:' + uid();
|
|
18
|
-
this.candidate = object as IAccessCandidate;
|
|
19
|
-
} else {
|
|
20
|
-
const acReq: AccessRequest = object as AccessRequest;
|
|
21
|
-
this.id = acReq.id;
|
|
22
|
-
//this.resourceId = acReq.resourceId;
|
|
23
|
-
this.level = acReq.level;
|
|
24
|
-
this.candidate = acReq.candidate;
|
|
25
|
-
}
|
|
26
|
-
|
|
27
|
-
this.resourceId = undefined;
|
|
28
|
-
}
|
|
29
|
-
|
|
30
|
-
public static clone(request: IAccessRequest): AccessRequest {
|
|
31
|
-
return new AccessRequest(request);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
public setLevel(level: TAccessLevel | TAccessLevel[]): AccessRequest {
|
|
35
|
-
this.level = Array.isArray(level) ? level : [level];
|
|
36
|
-
return this;
|
|
37
|
-
}
|
|
38
|
-
public addLevel(level: TAccessLevel | TAccessLevel[]): AccessRequest {
|
|
39
|
-
this.level = [...this.level, ...(Array.isArray(level) ? level : [level])];
|
|
40
|
-
return this;
|
|
41
|
-
}
|
|
42
|
-
public resource(resourceId: string): AccessRequest {
|
|
43
|
-
this.resourceId = resourceId;
|
|
44
|
-
|
|
45
|
-
return this;
|
|
46
|
-
}
|
|
47
|
-
public setCandidate(candidate: IAccessCandidate): AccessRequest {
|
|
48
|
-
this.candidate = candidate;
|
|
49
|
-
|
|
50
|
-
return this;
|
|
51
|
-
}
|
|
52
|
-
}
|
|
1
|
+
import { IAccessCandidate, IAccessRequest, TAccessLevel } from '@sre/types/ACL.types';
|
|
2
|
+
import { uid } from '@sre/utils/index';
|
|
3
|
+
|
|
4
|
+
export class AccessRequest implements IAccessRequest {
|
|
5
|
+
public id: string;
|
|
6
|
+
public resourceId: string;
|
|
7
|
+
|
|
8
|
+
public level: TAccessLevel[] = [];
|
|
9
|
+
public candidate: IAccessCandidate;
|
|
10
|
+
|
|
11
|
+
constructor(object?: IAccessRequest | IAccessCandidate) {
|
|
12
|
+
if (!object) {
|
|
13
|
+
this.id = 'aclR:' + uid();
|
|
14
|
+
}
|
|
15
|
+
if (['role', 'id'].every((k) => k in object)) {
|
|
16
|
+
//this is a candidate
|
|
17
|
+
this.id = 'aclR:' + uid();
|
|
18
|
+
this.candidate = object as IAccessCandidate;
|
|
19
|
+
} else {
|
|
20
|
+
const acReq: AccessRequest = object as AccessRequest;
|
|
21
|
+
this.id = acReq.id;
|
|
22
|
+
//this.resourceId = acReq.resourceId;
|
|
23
|
+
this.level = acReq.level;
|
|
24
|
+
this.candidate = acReq.candidate;
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
this.resourceId = undefined;
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
public static clone(request: IAccessRequest): AccessRequest {
|
|
31
|
+
return new AccessRequest(request);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
public setLevel(level: TAccessLevel | TAccessLevel[]): AccessRequest {
|
|
35
|
+
this.level = Array.isArray(level) ? level : [level];
|
|
36
|
+
return this;
|
|
37
|
+
}
|
|
38
|
+
public addLevel(level: TAccessLevel | TAccessLevel[]): AccessRequest {
|
|
39
|
+
this.level = [...this.level, ...(Array.isArray(level) ? level : [level])];
|
|
40
|
+
return this;
|
|
41
|
+
}
|
|
42
|
+
public resource(resourceId: string): AccessRequest {
|
|
43
|
+
this.resourceId = resourceId;
|
|
44
|
+
|
|
45
|
+
return this;
|
|
46
|
+
}
|
|
47
|
+
public setCandidate(candidate: IAccessCandidate): AccessRequest {
|
|
48
|
+
this.candidate = candidate;
|
|
49
|
+
|
|
50
|
+
return this;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
@@ -1,44 +1,44 @@
|
|
|
1
|
-
import { Connector } from '@sre/Core/Connector.class';
|
|
2
|
-
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
3
|
-
import { IAccessCandidate, TAccessRole } from '@sre/types/ACL.types';
|
|
4
|
-
import { AccessCandidate } from '../AccessControl/AccessCandidate.class';
|
|
5
|
-
import { KeyValueObject } from '@sre/types/Common.types';
|
|
6
|
-
import { ACL } from '../AccessControl/ACL.class';
|
|
7
|
-
|
|
8
|
-
export interface ISmythAccountRequest {
|
|
9
|
-
isTeamMember(teamId: string): Promise<boolean>;
|
|
10
|
-
getCandidateTeam(): Promise<string | undefined>;
|
|
11
|
-
getAllTeamSettings(): Promise<KeyValueObject>;
|
|
12
|
-
getAllUserSettings(): Promise<KeyValueObject>;
|
|
13
|
-
getTeamSetting(settingKey: string): Promise<string>;
|
|
14
|
-
getUserSetting(settingKey: string): Promise<string>;
|
|
15
|
-
getAgentSetting(settingKey: string): Promise<string>;
|
|
16
|
-
getTeam(): Promise<string>;
|
|
17
|
-
}
|
|
18
|
-
|
|
19
|
-
export abstract class AccountConnector extends Connector {
|
|
20
|
-
constructor(protected _settings?: any) {
|
|
21
|
-
super(_settings);
|
|
22
|
-
}
|
|
23
|
-
public requester(candidate: AccessCandidate): ISmythAccountRequest {
|
|
24
|
-
return {
|
|
25
|
-
getAllUserSettings: async () => this.getAllUserSettings(candidate.readRequest, candidate.id),
|
|
26
|
-
getUserSetting: async (settingKey: string) => this.getUserSetting(candidate.readRequest, candidate.id, settingKey),
|
|
27
|
-
getAllTeamSettings: async () => this.getAllTeamSettings(candidate.readRequest, candidate.id),
|
|
28
|
-
getTeamSetting: async (settingKey: string) => this.getTeamSetting(candidate.readRequest, candidate.id, settingKey),
|
|
29
|
-
isTeamMember: async (teamId: string) => this.isTeamMember(teamId, candidate),
|
|
30
|
-
getCandidateTeam: async () => this.getCandidateTeam(candidate),
|
|
31
|
-
getTeam: async () => this.getCandidateTeam(candidate),
|
|
32
|
-
getAgentSetting: async (settingKey: string) => this.getAgentSetting(candidate.readRequest, candidate.id, settingKey),
|
|
33
|
-
};
|
|
34
|
-
}
|
|
35
|
-
public abstract getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL>;
|
|
36
|
-
|
|
37
|
-
public abstract isTeamMember(teamId: string, candidate: IAccessCandidate): Promise<boolean>;
|
|
38
|
-
public abstract getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined>;
|
|
39
|
-
public abstract getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject>;
|
|
40
|
-
public abstract getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject>;
|
|
41
|
-
public abstract getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string>;
|
|
42
|
-
public abstract getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string>;
|
|
43
|
-
public abstract getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string>;
|
|
44
|
-
}
|
|
1
|
+
import { Connector } from '@sre/Core/Connector.class';
|
|
2
|
+
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
3
|
+
import { IAccessCandidate, TAccessRole } from '@sre/types/ACL.types';
|
|
4
|
+
import { AccessCandidate } from '../AccessControl/AccessCandidate.class';
|
|
5
|
+
import { KeyValueObject } from '@sre/types/Common.types';
|
|
6
|
+
import { ACL } from '../AccessControl/ACL.class';
|
|
7
|
+
|
|
8
|
+
export interface ISmythAccountRequest {
|
|
9
|
+
isTeamMember(teamId: string): Promise<boolean>;
|
|
10
|
+
getCandidateTeam(): Promise<string | undefined>;
|
|
11
|
+
getAllTeamSettings(): Promise<KeyValueObject>;
|
|
12
|
+
getAllUserSettings(): Promise<KeyValueObject>;
|
|
13
|
+
getTeamSetting(settingKey: string): Promise<string>;
|
|
14
|
+
getUserSetting(settingKey: string): Promise<string>;
|
|
15
|
+
getAgentSetting(settingKey: string): Promise<string>;
|
|
16
|
+
getTeam(): Promise<string>;
|
|
17
|
+
}
|
|
18
|
+
|
|
19
|
+
export abstract class AccountConnector extends Connector {
|
|
20
|
+
constructor(protected _settings?: any) {
|
|
21
|
+
super(_settings);
|
|
22
|
+
}
|
|
23
|
+
public requester(candidate: AccessCandidate): ISmythAccountRequest {
|
|
24
|
+
return {
|
|
25
|
+
getAllUserSettings: async () => this.getAllUserSettings(candidate.readRequest, candidate.id),
|
|
26
|
+
getUserSetting: async (settingKey: string) => this.getUserSetting(candidate.readRequest, candidate.id, settingKey),
|
|
27
|
+
getAllTeamSettings: async () => this.getAllTeamSettings(candidate.readRequest, candidate.id),
|
|
28
|
+
getTeamSetting: async (settingKey: string) => this.getTeamSetting(candidate.readRequest, candidate.id, settingKey),
|
|
29
|
+
isTeamMember: async (teamId: string) => this.isTeamMember(teamId, candidate),
|
|
30
|
+
getCandidateTeam: async () => this.getCandidateTeam(candidate),
|
|
31
|
+
getTeam: async () => this.getCandidateTeam(candidate),
|
|
32
|
+
getAgentSetting: async (settingKey: string) => this.getAgentSetting(candidate.readRequest, candidate.id, settingKey),
|
|
33
|
+
};
|
|
34
|
+
}
|
|
35
|
+
public abstract getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL>;
|
|
36
|
+
|
|
37
|
+
public abstract isTeamMember(teamId: string, candidate: IAccessCandidate): Promise<boolean>;
|
|
38
|
+
public abstract getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined>;
|
|
39
|
+
public abstract getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject>;
|
|
40
|
+
public abstract getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject>;
|
|
41
|
+
public abstract getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string>;
|
|
42
|
+
public abstract getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string>;
|
|
43
|
+
public abstract getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string>;
|
|
44
|
+
}
|
|
@@ -1,76 +1,76 @@
|
|
|
1
|
-
import mysql from 'mysql2/promise';
|
|
2
|
-
import { ACL } from '@sre/Security/AccessControl/ACL.class';
|
|
3
|
-
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
4
|
-
import { DEFAULT_TEAM_ID, IAccessCandidate, IACL, TAccessRole } from '@sre/types/ACL.types';
|
|
5
|
-
import { AccountConnector } from '../AccountConnector';
|
|
6
|
-
import { KeyValueObject } from '@sre/types/Common.types';
|
|
7
|
-
|
|
8
|
-
export class AWSAccount extends AccountConnector {
|
|
9
|
-
public name = 'AWSAccount';
|
|
10
|
-
|
|
11
|
-
private pool: mysql.Pool;
|
|
12
|
-
|
|
13
|
-
constructor(protected _settings: any) {
|
|
14
|
-
super(_settings);
|
|
15
|
-
|
|
16
|
-
this.pool = mysql.createPool({
|
|
17
|
-
host: _settings.host,
|
|
18
|
-
database: _settings.database || 'app',
|
|
19
|
-
user: _settings.user || 'app',
|
|
20
|
-
password: _settings.password,
|
|
21
|
-
connectionLimit: 10,
|
|
22
|
-
});
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
public isTeamMember(team: string, candidate: IAccessCandidate): Promise<boolean> {
|
|
26
|
-
return Promise.resolve(true);
|
|
27
|
-
}
|
|
28
|
-
|
|
29
|
-
public getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined> {
|
|
30
|
-
if (candidate.role === TAccessRole.Team) {
|
|
31
|
-
return Promise.resolve(candidate.id);
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
return Promise.resolve(DEFAULT_TEAM_ID);
|
|
35
|
-
}
|
|
36
|
-
|
|
37
|
-
public async getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject[]> {
|
|
38
|
-
try {
|
|
39
|
-
const [rows] = await this.pool.execute('SELECT `key`, `value` FROM TeamSettings');
|
|
40
|
-
const settings: KeyValueObject[] = [];
|
|
41
|
-
if (Array.isArray(rows) && rows.length > 0) {
|
|
42
|
-
settings.push(...rows.map((row) => ({ key: row.key, value: row.value })));
|
|
43
|
-
}
|
|
44
|
-
return settings;
|
|
45
|
-
} catch (error) {
|
|
46
|
-
console.error('Error in getTeamSetting:', error);
|
|
47
|
-
return [] as KeyValueObject[];
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
|
|
51
|
-
public async getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string> {
|
|
52
|
-
try {
|
|
53
|
-
const [rows] = await this.pool.execute('SELECT `value` FROM TeamSettings WHERE `key` = ? LIMIT 1', [settingKey]);
|
|
54
|
-
if (Array.isArray(rows) && rows.length > 0 && 'value' in rows[0]) return rows[0].value;
|
|
55
|
-
return '';
|
|
56
|
-
} catch (error) {
|
|
57
|
-
console.error('Error in getTeamSetting:', error);
|
|
58
|
-
return '';
|
|
59
|
-
}
|
|
60
|
-
}
|
|
61
|
-
|
|
62
|
-
// TODO: Implement this
|
|
63
|
-
public getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL> {
|
|
64
|
-
throw new Error('getResourceACL Method not implemented.');
|
|
65
|
-
}
|
|
66
|
-
public getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject[]> {
|
|
67
|
-
throw new Error('getAllUserSettings Method not implemented.');
|
|
68
|
-
}
|
|
69
|
-
public getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string> {
|
|
70
|
-
throw new Error('getUserSetting Method not implemented.');
|
|
71
|
-
}
|
|
72
|
-
|
|
73
|
-
public getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string> {
|
|
74
|
-
throw new Error('getAgentSetting Method not implemented.');
|
|
75
|
-
}
|
|
76
|
-
}
|
|
1
|
+
import mysql from 'mysql2/promise';
|
|
2
|
+
import { ACL } from '@sre/Security/AccessControl/ACL.class';
|
|
3
|
+
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
4
|
+
import { DEFAULT_TEAM_ID, IAccessCandidate, IACL, TAccessRole } from '@sre/types/ACL.types';
|
|
5
|
+
import { AccountConnector } from '../AccountConnector';
|
|
6
|
+
import { KeyValueObject } from '@sre/types/Common.types';
|
|
7
|
+
|
|
8
|
+
export class AWSAccount extends AccountConnector {
|
|
9
|
+
public name = 'AWSAccount';
|
|
10
|
+
|
|
11
|
+
private pool: mysql.Pool;
|
|
12
|
+
|
|
13
|
+
constructor(protected _settings: any) {
|
|
14
|
+
super(_settings);
|
|
15
|
+
|
|
16
|
+
this.pool = mysql.createPool({
|
|
17
|
+
host: _settings.host,
|
|
18
|
+
database: _settings.database || 'app',
|
|
19
|
+
user: _settings.user || 'app',
|
|
20
|
+
password: _settings.password,
|
|
21
|
+
connectionLimit: 10,
|
|
22
|
+
});
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
public isTeamMember(team: string, candidate: IAccessCandidate): Promise<boolean> {
|
|
26
|
+
return Promise.resolve(true);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
public getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined> {
|
|
30
|
+
if (candidate.role === TAccessRole.Team) {
|
|
31
|
+
return Promise.resolve(candidate.id);
|
|
32
|
+
}
|
|
33
|
+
|
|
34
|
+
return Promise.resolve(DEFAULT_TEAM_ID);
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
public async getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject[]> {
|
|
38
|
+
try {
|
|
39
|
+
const [rows] = await this.pool.execute('SELECT `key`, `value` FROM TeamSettings');
|
|
40
|
+
const settings: KeyValueObject[] = [];
|
|
41
|
+
if (Array.isArray(rows) && rows.length > 0) {
|
|
42
|
+
settings.push(...rows.map((row) => ({ key: row.key, value: row.value })));
|
|
43
|
+
}
|
|
44
|
+
return settings;
|
|
45
|
+
} catch (error) {
|
|
46
|
+
console.error('Error in getTeamSetting:', error);
|
|
47
|
+
return [] as KeyValueObject[];
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
public async getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string> {
|
|
52
|
+
try {
|
|
53
|
+
const [rows] = await this.pool.execute('SELECT `value` FROM TeamSettings WHERE `key` = ? LIMIT 1', [settingKey]);
|
|
54
|
+
if (Array.isArray(rows) && rows.length > 0 && 'value' in rows[0]) return rows[0].value;
|
|
55
|
+
return '';
|
|
56
|
+
} catch (error) {
|
|
57
|
+
console.error('Error in getTeamSetting:', error);
|
|
58
|
+
return '';
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
// TODO: Implement this
|
|
63
|
+
public getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL> {
|
|
64
|
+
throw new Error('getResourceACL Method not implemented.');
|
|
65
|
+
}
|
|
66
|
+
public getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject[]> {
|
|
67
|
+
throw new Error('getAllUserSettings Method not implemented.');
|
|
68
|
+
}
|
|
69
|
+
public getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string> {
|
|
70
|
+
throw new Error('getUserSetting Method not implemented.');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
public getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string> {
|
|
74
|
+
throw new Error('getAgentSetting Method not implemented.');
|
|
75
|
+
}
|
|
76
|
+
}
|
|
@@ -1,130 +1,130 @@
|
|
|
1
|
-
import { Connector } from '@sre/Core/Connector.class';
|
|
2
|
-
import { ACL } from '@sre/Security/AccessControl/ACL.class';
|
|
3
|
-
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
4
|
-
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
5
|
-
import { SecureConnector } from '@sre/Security/SecureConnector.class';
|
|
6
|
-
import { DEFAULT_TEAM_ID, IAccessCandidate, IACL, TAccessRole } from '@sre/types/ACL.types';
|
|
7
|
-
import { StorageData, StorageMetadata } from '@sre/types/Storage.types';
|
|
8
|
-
import { AccountConnector } from '../AccountConnector';
|
|
9
|
-
import { KeyValueObject } from '@sre/types/Common.types';
|
|
10
|
-
import { Logger } from '@sre/helpers/Log.helper';
|
|
11
|
-
|
|
12
|
-
const console = Logger('DummyAccount');
|
|
13
|
-
|
|
14
|
-
/*
|
|
15
|
-
data format
|
|
16
|
-
|
|
17
|
-
{
|
|
18
|
-
"team1": {
|
|
19
|
-
users: {
|
|
20
|
-
"user1": {
|
|
21
|
-
"settings": {
|
|
22
|
-
"setting1": "value1",
|
|
23
|
-
"setting2": "value2"
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
|
-
"agents": {
|
|
28
|
-
"agent1": {
|
|
29
|
-
"settings": {
|
|
30
|
-
"setting1": "value1",
|
|
31
|
-
"setting2": "value2"
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
},
|
|
35
|
-
"settings": {
|
|
36
|
-
"setting1": "value1",
|
|
37
|
-
"setting2": "value2"
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
*/
|
|
43
|
-
|
|
44
|
-
export class DummyAccount extends AccountConnector {
|
|
45
|
-
public name = 'DummyAccount';
|
|
46
|
-
public data: any = {};
|
|
47
|
-
|
|
48
|
-
constructor(protected _settings?: any) {
|
|
49
|
-
super(_settings);
|
|
50
|
-
this.data = _settings?.data || {};
|
|
51
|
-
if (!this.data[DEFAULT_TEAM_ID]) {
|
|
52
|
-
this.data[DEFAULT_TEAM_ID] = {
|
|
53
|
-
users: {},
|
|
54
|
-
agents: { 'FAKE-AGENT-ID': {} },
|
|
55
|
-
settings: {},
|
|
56
|
-
};
|
|
57
|
-
}
|
|
58
|
-
if (!this.data[DEFAULT_TEAM_ID])
|
|
59
|
-
console.warn(
|
|
60
|
-
'You are using the DummyAccount connector. This is a development tool and should not be used in production if you have security concerns.'
|
|
61
|
-
);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
public isTeamMember(team: string, candidate: IAccessCandidate): Promise<boolean> {
|
|
65
|
-
if (team === DEFAULT_TEAM_ID) {
|
|
66
|
-
return Promise.resolve(true);
|
|
67
|
-
}
|
|
68
|
-
|
|
69
|
-
switch (candidate.role) {
|
|
70
|
-
case TAccessRole.Team:
|
|
71
|
-
return Promise.resolve(team === candidate.id);
|
|
72
|
-
case TAccessRole.User:
|
|
73
|
-
return Promise.resolve(this.data[team]?.users?.[candidate.id]);
|
|
74
|
-
case TAccessRole.Agent:
|
|
75
|
-
return Promise.resolve(this.data[team]?.agents?.[candidate.id]);
|
|
76
|
-
default:
|
|
77
|
-
return Promise.resolve(false);
|
|
78
|
-
}
|
|
79
|
-
}
|
|
80
|
-
public getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined> {
|
|
81
|
-
if (candidate.role === TAccessRole.Team) {
|
|
82
|
-
return Promise.resolve(candidate.id);
|
|
83
|
-
}
|
|
84
|
-
|
|
85
|
-
//lookup the team id for the user or agent
|
|
86
|
-
for (const team in this.data) {
|
|
87
|
-
if (candidate.role === TAccessRole.User && this.data[team]?.users?.[candidate.id]) {
|
|
88
|
-
return Promise.resolve(team);
|
|
89
|
-
}
|
|
90
|
-
if (candidate.role === TAccessRole.Agent && this.data[team]?.agents?.[candidate.id]) {
|
|
91
|
-
return Promise.resolve(team);
|
|
92
|
-
}
|
|
93
|
-
}
|
|
94
|
-
return Promise.resolve(DEFAULT_TEAM_ID);
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
public getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL> {
|
|
98
|
-
throw new Error('getResourceACL Method not implemented.');
|
|
99
|
-
}
|
|
100
|
-
public getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject[]> {
|
|
101
|
-
return Promise.resolve(this.data[teamId]?.settings);
|
|
102
|
-
}
|
|
103
|
-
public getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject[]> {
|
|
104
|
-
for (const team in this.data) {
|
|
105
|
-
if (this.data[team]?.users?.[accountId]) {
|
|
106
|
-
return Promise.resolve(this.data[team]?.users?.[accountId]?.settings);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
|
-
return Promise.resolve([]);
|
|
110
|
-
}
|
|
111
|
-
public getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string> {
|
|
112
|
-
return Promise.resolve(this.data[teamId]?.settings?.[settingKey]);
|
|
113
|
-
}
|
|
114
|
-
public getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string> {
|
|
115
|
-
for (const team in this.data) {
|
|
116
|
-
if (this.data[team]?.users?.[accountId]) {
|
|
117
|
-
return Promise.resolve(this.data[team]?.users?.[accountId]?.settings?.[settingKey]);
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
return Promise.resolve(undefined);
|
|
121
|
-
}
|
|
122
|
-
public getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string> {
|
|
123
|
-
for (const team in this.data) {
|
|
124
|
-
if (this.data[team]?.agents?.[agentId]) {
|
|
125
|
-
return Promise.resolve(this.data[team]?.agents?.[agentId]?.settings?.[settingKey]);
|
|
126
|
-
}
|
|
127
|
-
}
|
|
128
|
-
return Promise.resolve(undefined);
|
|
129
|
-
}
|
|
130
|
-
}
|
|
1
|
+
import { Connector } from '@sre/Core/Connector.class';
|
|
2
|
+
import { ACL } from '@sre/Security/AccessControl/ACL.class';
|
|
3
|
+
import { AccessCandidate } from '@sre/Security/AccessControl/AccessCandidate.class';
|
|
4
|
+
import { AccessRequest } from '@sre/Security/AccessControl/AccessRequest.class';
|
|
5
|
+
import { SecureConnector } from '@sre/Security/SecureConnector.class';
|
|
6
|
+
import { DEFAULT_TEAM_ID, IAccessCandidate, IACL, TAccessRole } from '@sre/types/ACL.types';
|
|
7
|
+
import { StorageData, StorageMetadata } from '@sre/types/Storage.types';
|
|
8
|
+
import { AccountConnector } from '../AccountConnector';
|
|
9
|
+
import { KeyValueObject } from '@sre/types/Common.types';
|
|
10
|
+
import { Logger } from '@sre/helpers/Log.helper';
|
|
11
|
+
|
|
12
|
+
const console = Logger('DummyAccount');
|
|
13
|
+
|
|
14
|
+
/*
|
|
15
|
+
data format
|
|
16
|
+
|
|
17
|
+
{
|
|
18
|
+
"team1": {
|
|
19
|
+
users: {
|
|
20
|
+
"user1": {
|
|
21
|
+
"settings": {
|
|
22
|
+
"setting1": "value1",
|
|
23
|
+
"setting2": "value2"
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
},
|
|
27
|
+
"agents": {
|
|
28
|
+
"agent1": {
|
|
29
|
+
"settings": {
|
|
30
|
+
"setting1": "value1",
|
|
31
|
+
"setting2": "value2"
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
"settings": {
|
|
36
|
+
"setting1": "value1",
|
|
37
|
+
"setting2": "value2"
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
*/
|
|
43
|
+
|
|
44
|
+
export class DummyAccount extends AccountConnector {
|
|
45
|
+
public name = 'DummyAccount';
|
|
46
|
+
public data: any = {};
|
|
47
|
+
|
|
48
|
+
constructor(protected _settings?: any) {
|
|
49
|
+
super(_settings);
|
|
50
|
+
this.data = _settings?.data || {};
|
|
51
|
+
if (!this.data[DEFAULT_TEAM_ID]) {
|
|
52
|
+
this.data[DEFAULT_TEAM_ID] = {
|
|
53
|
+
users: {},
|
|
54
|
+
agents: { 'FAKE-AGENT-ID': {} },
|
|
55
|
+
settings: {},
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
if (!this.data[DEFAULT_TEAM_ID])
|
|
59
|
+
console.warn(
|
|
60
|
+
'You are using the DummyAccount connector. This is a development tool and should not be used in production if you have security concerns.'
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
public isTeamMember(team: string, candidate: IAccessCandidate): Promise<boolean> {
|
|
65
|
+
if (team === DEFAULT_TEAM_ID) {
|
|
66
|
+
return Promise.resolve(true);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
switch (candidate.role) {
|
|
70
|
+
case TAccessRole.Team:
|
|
71
|
+
return Promise.resolve(team === candidate.id);
|
|
72
|
+
case TAccessRole.User:
|
|
73
|
+
return Promise.resolve(this.data[team]?.users?.[candidate.id]);
|
|
74
|
+
case TAccessRole.Agent:
|
|
75
|
+
return Promise.resolve(this.data[team]?.agents?.[candidate.id]);
|
|
76
|
+
default:
|
|
77
|
+
return Promise.resolve(false);
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
public getCandidateTeam(candidate: IAccessCandidate): Promise<string | undefined> {
|
|
81
|
+
if (candidate.role === TAccessRole.Team) {
|
|
82
|
+
return Promise.resolve(candidate.id);
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
//lookup the team id for the user or agent
|
|
86
|
+
for (const team in this.data) {
|
|
87
|
+
if (candidate.role === TAccessRole.User && this.data[team]?.users?.[candidate.id]) {
|
|
88
|
+
return Promise.resolve(team);
|
|
89
|
+
}
|
|
90
|
+
if (candidate.role === TAccessRole.Agent && this.data[team]?.agents?.[candidate.id]) {
|
|
91
|
+
return Promise.resolve(team);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
return Promise.resolve(DEFAULT_TEAM_ID);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
public getResourceACL(resourceId: string, candidate: IAccessCandidate): Promise<ACL> {
|
|
98
|
+
throw new Error('getResourceACL Method not implemented.');
|
|
99
|
+
}
|
|
100
|
+
public getAllTeamSettings(acRequest: AccessRequest, teamId: string): Promise<KeyValueObject[]> {
|
|
101
|
+
return Promise.resolve(this.data[teamId]?.settings);
|
|
102
|
+
}
|
|
103
|
+
public getAllUserSettings(acRequest: AccessRequest, accountId: string): Promise<KeyValueObject[]> {
|
|
104
|
+
for (const team in this.data) {
|
|
105
|
+
if (this.data[team]?.users?.[accountId]) {
|
|
106
|
+
return Promise.resolve(this.data[team]?.users?.[accountId]?.settings);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
return Promise.resolve([]);
|
|
110
|
+
}
|
|
111
|
+
public getTeamSetting(acRequest: AccessRequest, teamId: string, settingKey: string): Promise<string> {
|
|
112
|
+
return Promise.resolve(this.data[teamId]?.settings?.[settingKey]);
|
|
113
|
+
}
|
|
114
|
+
public getUserSetting(acRequest: AccessRequest, accountId: string, settingKey: string): Promise<string> {
|
|
115
|
+
for (const team in this.data) {
|
|
116
|
+
if (this.data[team]?.users?.[accountId]) {
|
|
117
|
+
return Promise.resolve(this.data[team]?.users?.[accountId]?.settings?.[settingKey]);
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
return Promise.resolve(undefined);
|
|
121
|
+
}
|
|
122
|
+
public getAgentSetting(acRequest: AccessRequest, agentId: string, settingKey: string): Promise<string> {
|
|
123
|
+
for (const team in this.data) {
|
|
124
|
+
if (this.data[team]?.agents?.[agentId]) {
|
|
125
|
+
return Promise.resolve(this.data[team]?.agents?.[agentId]?.settings?.[settingKey]);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
return Promise.resolve(undefined);
|
|
129
|
+
}
|
|
130
|
+
}
|