@multiplayer-app/ai-agent-node 0.1.0-beta.5 → 0.1.0-beta.50
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/README.md +2 -2
- package/dist/cjs/config.cjs +88 -37
- package/dist/cjs/config.cjs.map +1 -1
- package/dist/cjs/config.d.ts +57 -23
- package/dist/cjs/config.d.ts.map +1 -1
- package/dist/cjs/helpers/AIHelper.cjs +127 -65
- package/dist/cjs/helpers/AIHelper.cjs.map +1 -1
- package/dist/cjs/helpers/AIHelper.d.ts +22 -16
- package/dist/cjs/helpers/AIHelper.d.ts.map +1 -1
- package/dist/cjs/helpers/AIHelper.test.cjs +22 -15
- package/dist/cjs/helpers/AIHelper.test.cjs.map +1 -1
- package/dist/cjs/helpers/ConfigHelper.cjs +15 -6
- package/dist/cjs/helpers/ConfigHelper.cjs.map +1 -1
- package/dist/cjs/helpers/ConfigHelper.d.ts.map +1 -1
- package/dist/cjs/helpers/FileHelper.cjs +131 -151
- package/dist/cjs/helpers/FileHelper.cjs.map +1 -1
- package/dist/cjs/helpers/FileHelper.d.ts +19 -25
- package/dist/cjs/helpers/FileHelper.d.ts.map +1 -1
- package/dist/cjs/helpers/index.cjs +0 -1
- package/dist/cjs/helpers/index.cjs.map +1 -1
- package/dist/cjs/helpers/index.d.ts +0 -1
- package/dist/cjs/helpers/index.d.ts.map +1 -1
- package/dist/cjs/index.cjs +120 -28
- package/dist/cjs/index.cjs.map +1 -1
- package/dist/cjs/index.d.ts +43 -11
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/libs/index.cjs +0 -1
- package/dist/cjs/libs/index.cjs.map +1 -1
- package/dist/cjs/libs/index.d.ts +0 -1
- package/dist/cjs/libs/index.d.ts.map +1 -1
- package/dist/cjs/libs/s3/index.cjs +3 -39
- package/dist/cjs/libs/s3/index.cjs.map +1 -1
- package/dist/cjs/libs/s3/index.d.ts +1 -2
- package/dist/cjs/libs/s3/index.d.ts.map +1 -1
- package/dist/cjs/libs/s3/s3.lib.cjs +173 -186
- package/dist/cjs/libs/s3/s3.lib.cjs.map +1 -1
- package/dist/cjs/libs/s3/s3.lib.d.ts +29 -22
- package/dist/cjs/libs/s3/s3.lib.d.ts.map +1 -1
- package/dist/cjs/processors/ActivityProcessor.cjs +39 -0
- package/dist/cjs/processors/ActivityProcessor.cjs.map +1 -0
- package/dist/cjs/processors/ActivityProcessor.d.ts +32 -0
- package/dist/cjs/processors/ActivityProcessor.d.ts.map +1 -0
- package/dist/cjs/processors/ActivityProcessor.test.cjs +84 -0
- package/dist/cjs/processors/ActivityProcessor.test.cjs.map +1 -0
- package/dist/cjs/processors/ActivityProcessor.test.d.ts +2 -0
- package/dist/cjs/processors/ActivityProcessor.test.d.ts.map +1 -0
- package/dist/cjs/processors/AgentProcessor.cjs +46 -0
- package/dist/cjs/processors/AgentProcessor.cjs.map +1 -0
- package/dist/cjs/processors/AgentProcessor.d.ts +25 -0
- package/dist/cjs/processors/AgentProcessor.d.ts.map +1 -0
- package/dist/cjs/processors/AgentProcessor.test.cjs +103 -0
- package/dist/cjs/processors/AgentProcessor.test.cjs.map +1 -0
- package/dist/cjs/processors/AgentProcessor.test.d.ts +2 -0
- package/dist/cjs/processors/AgentProcessor.test.d.ts.map +1 -0
- package/dist/cjs/processors/ChatProcessor.cjs +355 -122
- package/dist/cjs/processors/ChatProcessor.cjs.map +1 -1
- package/dist/cjs/processors/ChatProcessor.d.ts +71 -11
- package/dist/cjs/processors/ChatProcessor.d.ts.map +1 -1
- package/dist/cjs/processors/ChatProcessor.test.cjs +762 -0
- package/dist/cjs/processors/ChatProcessor.test.cjs.map +1 -0
- package/dist/cjs/processors/ChatProcessor.test.d.ts +2 -0
- package/dist/cjs/processors/ChatProcessor.test.d.ts.map +1 -0
- package/dist/cjs/processors/index.cjs +2 -0
- package/dist/cjs/processors/index.cjs.map +1 -1
- package/dist/cjs/processors/index.d.ts +2 -0
- package/dist/cjs/processors/index.d.ts.map +1 -1
- package/dist/cjs/services/AIService.cjs +87 -21
- package/dist/cjs/services/AIService.cjs.map +1 -1
- package/dist/cjs/services/AIService.d.ts +19 -7
- package/dist/cjs/services/AIService.d.ts.map +1 -1
- package/dist/cjs/services/InternalEventsHandler.cjs +3 -3
- package/dist/cjs/services/InternalEventsHandler.cjs.map +1 -1
- package/dist/cjs/services/InternalEventsHandler.d.ts +3 -1
- package/dist/cjs/services/InternalEventsHandler.d.ts.map +1 -1
- package/dist/cjs/services/ModelFetcher.cjs +2 -8
- package/dist/cjs/services/ModelFetcher.cjs.map +1 -1
- package/dist/cjs/services/ModelFetcher.d.ts +2 -7
- package/dist/cjs/services/ModelFetcher.d.ts.map +1 -1
- package/dist/cjs/services/RedisService.cjs +20 -16
- package/dist/cjs/services/RedisService.cjs.map +1 -1
- package/dist/cjs/services/RedisService.d.ts +5 -2
- package/dist/cjs/services/RedisService.d.ts.map +1 -1
- package/dist/cjs/services/SocketService.cjs +8 -8
- package/dist/cjs/services/SocketService.cjs.map +1 -1
- package/dist/cjs/services/SocketService.d.ts +9 -6
- package/dist/cjs/services/SocketService.d.ts.map +1 -1
- package/dist/cjs/services/index.cjs +0 -1
- package/dist/cjs/services/index.cjs.map +1 -1
- package/dist/cjs/services/index.d.ts +0 -1
- package/dist/cjs/services/index.d.ts.map +1 -1
- package/dist/cjs/store/AgentStore.cjs +3 -4
- package/dist/cjs/store/AgentStore.cjs.map +1 -1
- package/dist/cjs/store/AgentStore.d.ts +2 -1
- package/dist/cjs/store/AgentStore.d.ts.map +1 -1
- package/dist/cjs/store/ConfigStore.cjs +7 -3
- package/dist/cjs/store/ConfigStore.cjs.map +1 -1
- package/dist/cjs/store/ConfigStore.d.ts +1 -0
- package/dist/cjs/store/ConfigStore.d.ts.map +1 -1
- package/dist/cjs/tools/generateChartTool.d.ts +2 -2
- package/dist/cjs/tools/proposeFormValuesTool.d.ts +2 -2
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/config.d.ts +57 -23
- package/dist/esm/config.d.ts.map +1 -1
- package/dist/esm/config.js +88 -35
- package/dist/esm/config.js.map +1 -1
- package/dist/esm/helpers/AIHelper.d.ts +22 -16
- package/dist/esm/helpers/AIHelper.d.ts.map +1 -1
- package/dist/esm/helpers/AIHelper.js +134 -70
- package/dist/esm/helpers/AIHelper.js.map +1 -1
- package/dist/esm/helpers/AIHelper.test.js +22 -15
- package/dist/esm/helpers/AIHelper.test.js.map +1 -1
- package/dist/esm/helpers/ConfigHelper.d.ts.map +1 -1
- package/dist/esm/helpers/ConfigHelper.js +15 -6
- package/dist/esm/helpers/ConfigHelper.js.map +1 -1
- package/dist/esm/helpers/FileHelper.d.ts +19 -25
- package/dist/esm/helpers/FileHelper.d.ts.map +1 -1
- package/dist/esm/helpers/FileHelper.js +131 -146
- package/dist/esm/helpers/FileHelper.js.map +1 -1
- package/dist/esm/helpers/index.d.ts +0 -1
- package/dist/esm/helpers/index.d.ts.map +1 -1
- package/dist/esm/helpers/index.js +0 -1
- package/dist/esm/helpers/index.js.map +1 -1
- package/dist/esm/index.d.ts +43 -11
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +92 -11
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/libs/index.d.ts +0 -1
- package/dist/esm/libs/index.d.ts.map +1 -1
- package/dist/esm/libs/index.js +0 -1
- package/dist/esm/libs/index.js.map +1 -1
- package/dist/esm/libs/s3/index.d.ts +1 -2
- package/dist/esm/libs/s3/index.d.ts.map +1 -1
- package/dist/esm/libs/s3/index.js +1 -2
- package/dist/esm/libs/s3/index.js.map +1 -1
- package/dist/esm/libs/s3/s3.lib.d.ts +29 -22
- package/dist/esm/libs/s3/s3.lib.d.ts.map +1 -1
- package/dist/esm/libs/s3/s3.lib.js +177 -172
- package/dist/esm/libs/s3/s3.lib.js.map +1 -1
- package/dist/esm/processors/ActivityProcessor.d.ts +32 -0
- package/dist/esm/processors/ActivityProcessor.d.ts.map +1 -0
- package/dist/esm/processors/ActivityProcessor.js +36 -0
- package/dist/esm/processors/ActivityProcessor.js.map +1 -0
- package/dist/esm/processors/ActivityProcessor.test.d.ts +2 -0
- package/dist/esm/processors/ActivityProcessor.test.d.ts.map +1 -0
- package/dist/esm/processors/ActivityProcessor.test.js +82 -0
- package/dist/esm/processors/ActivityProcessor.test.js.map +1 -0
- package/dist/esm/processors/AgentProcessor.d.ts +25 -0
- package/dist/esm/processors/AgentProcessor.d.ts.map +1 -0
- package/dist/esm/processors/AgentProcessor.js +43 -0
- package/dist/esm/processors/AgentProcessor.js.map +1 -0
- package/dist/esm/processors/AgentProcessor.test.d.ts +2 -0
- package/dist/esm/processors/AgentProcessor.test.d.ts.map +1 -0
- package/dist/esm/processors/AgentProcessor.test.js +101 -0
- package/dist/esm/processors/AgentProcessor.test.js.map +1 -0
- package/dist/esm/processors/ChatProcessor.d.ts +71 -11
- package/dist/esm/processors/ChatProcessor.d.ts.map +1 -1
- package/dist/esm/processors/ChatProcessor.js +366 -126
- package/dist/esm/processors/ChatProcessor.js.map +1 -1
- package/dist/esm/processors/ChatProcessor.test.d.ts +2 -0
- package/dist/esm/processors/ChatProcessor.test.d.ts.map +1 -0
- package/dist/esm/processors/ChatProcessor.test.js +760 -0
- package/dist/esm/processors/ChatProcessor.test.js.map +1 -0
- package/dist/esm/processors/index.d.ts +2 -0
- package/dist/esm/processors/index.d.ts.map +1 -1
- package/dist/esm/processors/index.js +2 -0
- package/dist/esm/processors/index.js.map +1 -1
- package/dist/esm/services/AIService.d.ts +19 -7
- package/dist/esm/services/AIService.d.ts.map +1 -1
- package/dist/esm/services/AIService.js +91 -24
- package/dist/esm/services/AIService.js.map +1 -1
- package/dist/esm/services/InternalEventsHandler.d.ts +3 -1
- package/dist/esm/services/InternalEventsHandler.d.ts.map +1 -1
- package/dist/esm/services/InternalEventsHandler.js +4 -3
- package/dist/esm/services/InternalEventsHandler.js.map +1 -1
- package/dist/esm/services/ModelFetcher.d.ts +2 -7
- package/dist/esm/services/ModelFetcher.d.ts.map +1 -1
- package/dist/esm/services/ModelFetcher.js +2 -8
- package/dist/esm/services/ModelFetcher.js.map +1 -1
- package/dist/esm/services/RedisService.d.ts +5 -2
- package/dist/esm/services/RedisService.d.ts.map +1 -1
- package/dist/esm/services/RedisService.js +21 -14
- package/dist/esm/services/RedisService.js.map +1 -1
- package/dist/esm/services/SocketService.d.ts +9 -6
- package/dist/esm/services/SocketService.d.ts.map +1 -1
- package/dist/esm/services/SocketService.js +10 -6
- package/dist/esm/services/SocketService.js.map +1 -1
- package/dist/esm/services/index.d.ts +0 -1
- package/dist/esm/services/index.d.ts.map +1 -1
- package/dist/esm/services/index.js +0 -1
- package/dist/esm/services/index.js.map +1 -1
- package/dist/esm/store/AgentStore.d.ts +2 -1
- package/dist/esm/store/AgentStore.d.ts.map +1 -1
- package/dist/esm/store/AgentStore.js +4 -2
- package/dist/esm/store/AgentStore.js.map +1 -1
- package/dist/esm/store/ConfigStore.d.ts +1 -0
- package/dist/esm/store/ConfigStore.d.ts.map +1 -1
- package/dist/esm/store/ConfigStore.js +7 -3
- package/dist/esm/store/ConfigStore.js.map +1 -1
- package/dist/esm/tools/generateChartTool.d.ts +2 -2
- package/dist/esm/tools/proposeFormValuesTool.d.ts +2 -2
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/package.json +12 -12
- package/dist/cjs/helpers/SetupHelper.cjs +0 -37
- package/dist/cjs/helpers/SetupHelper.cjs.map +0 -1
- package/dist/cjs/helpers/SetupHelper.d.ts +0 -5
- package/dist/cjs/helpers/SetupHelper.d.ts.map +0 -1
- package/dist/cjs/libs/kafka/config.cjs +0 -8
- package/dist/cjs/libs/kafka/config.cjs.map +0 -1
- package/dist/cjs/libs/kafka/config.d.ts +0 -5
- package/dist/cjs/libs/kafka/config.d.ts.map +0 -1
- package/dist/cjs/libs/kafka/consumer.cjs +0 -131
- package/dist/cjs/libs/kafka/consumer.cjs.map +0 -1
- package/dist/cjs/libs/kafka/consumer.d.ts +0 -16
- package/dist/cjs/libs/kafka/consumer.d.ts.map +0 -1
- package/dist/cjs/libs/kafka/index.cjs +0 -19
- package/dist/cjs/libs/kafka/index.cjs.map +0 -1
- package/dist/cjs/libs/kafka/index.d.ts +0 -3
- package/dist/cjs/libs/kafka/index.d.ts.map +0 -1
- package/dist/cjs/libs/kafka/kafka.cjs +0 -27
- package/dist/cjs/libs/kafka/kafka.cjs.map +0 -1
- package/dist/cjs/libs/kafka/kafka.d.ts +0 -3
- package/dist/cjs/libs/kafka/kafka.d.ts.map +0 -1
- package/dist/cjs/libs/kafka/producer.cjs +0 -48
- package/dist/cjs/libs/kafka/producer.cjs.map +0 -1
- package/dist/cjs/libs/kafka/producer.d.ts +0 -11
- package/dist/cjs/libs/kafka/producer.d.ts.map +0 -1
- package/dist/cjs/libs/logger/config.cjs +0 -8
- package/dist/cjs/libs/logger/config.cjs.map +0 -1
- package/dist/cjs/libs/logger/config.d.ts +0 -5
- package/dist/cjs/libs/logger/config.d.ts.map +0 -1
- package/dist/cjs/libs/s3/config.cjs +0 -10
- package/dist/cjs/libs/s3/config.cjs.map +0 -1
- package/dist/cjs/libs/s3/config.d.ts +0 -7
- package/dist/cjs/libs/s3/config.d.ts.map +0 -1
- package/dist/cjs/services/KafkaService.cjs +0 -122
- package/dist/cjs/services/KafkaService.cjs.map +0 -1
- package/dist/cjs/services/KafkaService.d.ts +0 -35
- package/dist/cjs/services/KafkaService.d.ts.map +0 -1
- package/dist/esm/helpers/SetupHelper.d.ts +0 -5
- package/dist/esm/helpers/SetupHelper.d.ts.map +0 -1
- package/dist/esm/helpers/SetupHelper.js +0 -32
- package/dist/esm/helpers/SetupHelper.js.map +0 -1
- package/dist/esm/libs/kafka/config.d.ts +0 -5
- package/dist/esm/libs/kafka/config.d.ts.map +0 -1
- package/dist/esm/libs/kafka/config.js +0 -5
- package/dist/esm/libs/kafka/config.js.map +0 -1
- package/dist/esm/libs/kafka/consumer.d.ts +0 -16
- package/dist/esm/libs/kafka/consumer.d.ts.map +0 -1
- package/dist/esm/libs/kafka/consumer.js +0 -125
- package/dist/esm/libs/kafka/consumer.js.map +0 -1
- package/dist/esm/libs/kafka/index.d.ts +0 -3
- package/dist/esm/libs/kafka/index.d.ts.map +0 -1
- package/dist/esm/libs/kafka/index.js +0 -3
- package/dist/esm/libs/kafka/index.js.map +0 -1
- package/dist/esm/libs/kafka/kafka.d.ts +0 -3
- package/dist/esm/libs/kafka/kafka.d.ts.map +0 -1
- package/dist/esm/libs/kafka/kafka.js +0 -24
- package/dist/esm/libs/kafka/kafka.js.map +0 -1
- package/dist/esm/libs/kafka/producer.d.ts +0 -11
- package/dist/esm/libs/kafka/producer.d.ts.map +0 -1
- package/dist/esm/libs/kafka/producer.js +0 -45
- package/dist/esm/libs/kafka/producer.js.map +0 -1
- package/dist/esm/libs/logger/config.d.ts +0 -5
- package/dist/esm/libs/logger/config.d.ts.map +0 -1
- package/dist/esm/libs/logger/config.js +0 -5
- package/dist/esm/libs/logger/config.js.map +0 -1
- package/dist/esm/libs/s3/config.d.ts +0 -7
- package/dist/esm/libs/s3/config.d.ts.map +0 -1
- package/dist/esm/libs/s3/config.js +0 -7
- package/dist/esm/libs/s3/config.js.map +0 -1
- package/dist/esm/services/KafkaService.d.ts +0 -35
- package/dist/esm/services/KafkaService.d.ts.map +0 -1
- package/dist/esm/services/KafkaService.js +0 -123
- package/dist/esm/services/KafkaService.js.map +0 -1
|
@@ -1,25 +1,32 @@
|
|
|
1
1
|
import { CompleteMultipartUploadOutput, ObjectCannedACL, GetObjectOutput, GetObjectCommandOutput, ListObjectsV2CommandOutput } from '@aws-sdk/client-s3';
|
|
2
2
|
import stream from 'stream';
|
|
3
|
-
|
|
4
|
-
export declare
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
3
|
+
import { Config } from '../../config';
|
|
4
|
+
export declare class S3Lib {
|
|
5
|
+
private readonly client;
|
|
6
|
+
private readonly signer;
|
|
7
|
+
private readonly config;
|
|
8
|
+
constructor(config: Config["s3"]);
|
|
9
|
+
uploadFile(Key: string, Bucket: string, Body: any, Expires?: Date): Promise<import("@aws-sdk/client-s3").PutObjectCommandOutput>;
|
|
10
|
+
downloadFile(Key: string, Bucket: string): Promise<GetObjectOutput>;
|
|
11
|
+
downloadFileAsString(Key: string, Bucket: string): Promise<string | undefined>;
|
|
12
|
+
downloadFileAsByteArray(Key: string, Bucket: string): Promise<Uint8Array | undefined>;
|
|
13
|
+
streamUpload(Key: string, Bucket: string, ACL?: ObjectCannedACL): {
|
|
14
|
+
writeStream: stream.PassThrough;
|
|
15
|
+
promise: Promise<CompleteMultipartUploadOutput>;
|
|
16
|
+
};
|
|
17
|
+
getPresignedUploadUrl(Key: string, Bucket: string, expiresIn?: number): Promise<string>;
|
|
18
|
+
getPresignedDownloadUrl(Key: string, Bucket: string): Promise<string>;
|
|
19
|
+
getDownloadUrl(Key: string, Bucket: string): string;
|
|
20
|
+
copy(Bucket: string, KeyFrom: string, KeyTo: string): Promise<import("@aws-sdk/client-s3").CopyObjectCommandOutput>;
|
|
21
|
+
copyBetweenBuckets(BucketFrom: string, KeyFrom: string, BucketTo: string, KeyTo: string): Promise<import("@aws-sdk/client-s3").CopyObjectCommandOutput>;
|
|
22
|
+
getObject(Bucket: string, Key: string): Promise<GetObjectCommandOutput>;
|
|
23
|
+
listObjectsByPrefix(Bucket: string, Prefix: string): Promise<ListObjectsV2CommandOutput>;
|
|
24
|
+
headObject(Bucket: string, Key: string): Promise<GetObjectCommandOutput>;
|
|
25
|
+
deleteObject(Bucket: string, Key: string): Promise<GetObjectCommandOutput>;
|
|
26
|
+
deleteObjectsByPrefix(Bucket: string, Prefix: string, ContinuationToken?: string): Promise<void>;
|
|
27
|
+
/**
|
|
28
|
+
* Ensures a bucket exists, creating it if it doesn't
|
|
29
|
+
*/
|
|
30
|
+
ensureBucketExists(Bucket: string): Promise<void>;
|
|
31
|
+
}
|
|
25
32
|
//# sourceMappingURL=s3.lib.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"s3.lib.d.ts","sourceRoot":"","sources":["../../../../src/libs/s3/s3.lib.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,6BAA6B,EAC7B,eAAe,
|
|
1
|
+
{"version":3,"file":"s3.lib.d.ts","sourceRoot":"","sources":["../../../../src/libs/s3/s3.lib.ts"],"names":[],"mappings":"AAAA,OAAO,EAIL,6BAA6B,EAC7B,eAAe,EACf,eAAe,EACf,sBAAsB,EACtB,0BAA0B,EAI3B,MAAM,oBAAoB,CAAA;AAK3B,OAAO,MAAM,MAAM,QAAQ,CAAA;AAE3B,OAAO,EAAE,MAAM,EAAE,MAAM,cAAc,CAAA;AAErC,qBAAa,KAAK;IAChB,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAI;IAC3B,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAoB;IAE3C,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAc;gBACzB,MAAM,EAAE,MAAM,CAAC,IAAI,CAAC;IAehC,UAAU,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,GAAG,EAAE,OAAO,CAAC,EAAE,IAAI;IASjE,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,eAAe,CAAC;IAS7D,oBAAoB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC;IAiB9E,uBAAuB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,UAAU,GAAG,SAAS,CAAC;IAiB3F,YAAY,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,GAAG,CAAC,EAAE,eAAe;;iBAqBjC,OAAO,CAAC,6BAA6B,CAAC;;IAI9D,qBAAqB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,CAAC,EAAE,MAAM;IAcrE,uBAAuB,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAgBzD,cAAc,CAAC,GAAG,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM;IAS1C,IAAI,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAQnD,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM;IAQjF,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAOvE,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,0BAA0B,CAAC;IASxF,UAAU,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAOxE,YAAY,CAAC,MAAM,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,CAAC;IAO1E,qBAAqB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,iBAAiB,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;IAuBtG;;OAEG;IACG,kBAAkB,CAAC,MAAM,EAAE,MAAM,GAAG,OAAO,CAAC,IAAI,CAAC;CAyBxD"}
|
|
@@ -0,0 +1,39 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ActivityProcessor = void 0;
|
|
4
|
+
class ActivityProcessor {
|
|
5
|
+
constructor(params) {
|
|
6
|
+
this.activityRepository = params.activityRepository;
|
|
7
|
+
}
|
|
8
|
+
async getActivityById(activityId, ownerId) {
|
|
9
|
+
const activity = await this.activityRepository.findById(activityId);
|
|
10
|
+
if (!activity) {
|
|
11
|
+
return null;
|
|
12
|
+
}
|
|
13
|
+
if (activity.ownerId !== ownerId) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
return activity;
|
|
17
|
+
}
|
|
18
|
+
async listActivities(params) {
|
|
19
|
+
const { ownerId, groupId, parentId, tenants, period, skip, limit, sort } = params;
|
|
20
|
+
const baseFilter = {
|
|
21
|
+
ownerId, groupId, tenants, parentId, period
|
|
22
|
+
};
|
|
23
|
+
const activities = await this.activityRepository.findByParentId(baseFilter, { skip, limit, sort });
|
|
24
|
+
const count = await this.activityRepository.countByParentId(baseFilter);
|
|
25
|
+
return {
|
|
26
|
+
data: activities,
|
|
27
|
+
cursor: {
|
|
28
|
+
total: count,
|
|
29
|
+
skip,
|
|
30
|
+
limit,
|
|
31
|
+
},
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
async getActivitySummary(params) {
|
|
35
|
+
return this.activityRepository.getActivitySummary(params);
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
exports.ActivityProcessor = ActivityProcessor;
|
|
39
|
+
//# sourceMappingURL=ActivityProcessor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActivityProcessor.js","sourceRoot":"","sources":["../../../src/processors/ActivityProcessor.ts"],"names":[],"mappings":";;;AAsBA,MAAa,iBAAiB;IAG5B,YAAY,MAAkD;QAC5D,IAAI,CAAC,kBAAkB,GAAG,MAAM,CAAC,kBAAkB,CAAC;IACtD,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,UAAkB,EAAE,OAAe;QACvD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QACpE,IAAI,CAAC,QAAQ,EAAE,CAAC;YACd,OAAO,IAAI,CAAC;QACd,CAAC;QAED,IAAI,QAAQ,CAAC,OAAO,KAAK,OAAO,EAAE,CAAC;YACjC,OAAO,IAAI,CAAC;QACd,CAAC;QAED,OAAO,QAAQ,CAAC;IAClB,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,MAA4B;QAC/C,MAAM,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,GAAG,MAAM,CAAC;QAElF,MAAM,UAAU,GAAG;YACjB,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,MAAM;SAC5C,CAAC;QAEF,MAAM,UAAU,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,cAAc,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;QACnG,MAAM,KAAK,GAAG,MAAM,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,UAAU,CAAC,CAAC;QACxE,OAAO;YACL,IAAI,EAAE,UAAU;YAChB,MAAM,EAAE;gBACN,KAAK,EAAE,KAAK;gBACZ,IAAI;gBACJ,KAAK;aACN;SACF,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,kBAAkB,CAAC,MAA8B;QACrD,OAAO,IAAI,CAAC,kBAAkB,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;IAC5D,CAAC;CACF;AA1CD,8CA0CC"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import { SortOrder, type Activity, type ActivitySummary, type ActivitySummaryParams, type DataWithCursor } from '@multiplayer-app/ai-agent-types';
|
|
2
|
+
import type { ActivityRepository } from '@multiplayer-app/ai-agent-db';
|
|
3
|
+
export type ActivityTreeNode = Activity & {
|
|
4
|
+
children: ActivityTreeNode[];
|
|
5
|
+
};
|
|
6
|
+
interface ListActivitiesParams {
|
|
7
|
+
ownerId?: string;
|
|
8
|
+
groupId?: string;
|
|
9
|
+
parentId?: string;
|
|
10
|
+
tenants?: Record<string, string>;
|
|
11
|
+
period?: {
|
|
12
|
+
from?: string | Date;
|
|
13
|
+
to?: string | Date;
|
|
14
|
+
};
|
|
15
|
+
sort?: {
|
|
16
|
+
field: string;
|
|
17
|
+
order: SortOrder;
|
|
18
|
+
};
|
|
19
|
+
skip?: number;
|
|
20
|
+
limit?: number;
|
|
21
|
+
}
|
|
22
|
+
export declare class ActivityProcessor {
|
|
23
|
+
private activityRepository;
|
|
24
|
+
constructor(params: {
|
|
25
|
+
activityRepository: ActivityRepository;
|
|
26
|
+
});
|
|
27
|
+
getActivityById(activityId: string, ownerId: string): Promise<Activity | null>;
|
|
28
|
+
listActivities(params: ListActivitiesParams): Promise<DataWithCursor<Activity>>;
|
|
29
|
+
getActivitySummary(params?: ActivitySummaryParams): Promise<ActivitySummary[]>;
|
|
30
|
+
}
|
|
31
|
+
export {};
|
|
32
|
+
//# sourceMappingURL=ActivityProcessor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActivityProcessor.d.ts","sourceRoot":"","sources":["../../../src/processors/ActivityProcessor.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,SAAS,EACT,KAAK,QAAQ,EACb,KAAK,eAAe,EACpB,KAAK,qBAAqB,EAC1B,KAAK,cAAc,EACpB,MAAM,iCAAiC,CAAC;AACzC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAEvE,MAAM,MAAM,gBAAgB,GAAG,QAAQ,GAAG;IAAE,QAAQ,EAAE,gBAAgB,EAAE,CAAA;CAAE,CAAC;AAE3E,UAAU,oBAAoB;IAC5B,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,MAAM,CAAC,EAAE;QAAE,IAAI,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;QAAC,EAAE,CAAC,EAAE,MAAM,GAAG,IAAI,CAAA;KAAE,CAAC;IACtD,IAAI,CAAC,EAAE;QAAE,KAAK,EAAE,MAAM,CAAC;QAAC,KAAK,EAAE,SAAS,CAAA;KAAE,CAAC;IAC3C,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,qBAAa,iBAAiB;IAC5B,OAAO,CAAC,kBAAkB,CAAqB;gBAEnC,MAAM,EAAE;QAAE,kBAAkB,EAAE,kBAAkB,CAAA;KAAE;IAIxD,eAAe,CAAC,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,QAAQ,GAAG,IAAI,CAAC;IAa9E,cAAc,CAAC,MAAM,EAAE,oBAAoB,GAAG,OAAO,CAAC,cAAc,CAAC,QAAQ,CAAC,CAAC;IAmB/E,kBAAkB,CAAC,MAAM,CAAC,EAAE,qBAAqB,GAAG,OAAO,CAAC,eAAe,EAAE,CAAC;CAGrF"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const ai_agent_types_1 = require("@multiplayer-app/ai-agent-types");
|
|
4
|
+
const vitest_1 = require("vitest");
|
|
5
|
+
const ActivityProcessor_1 = require("./ActivityProcessor.cjs");
|
|
6
|
+
(0, vitest_1.describe)('ActivityProcessor', () => {
|
|
7
|
+
const rootActivity = {
|
|
8
|
+
id: 'a1',
|
|
9
|
+
ownerId: 'u1',
|
|
10
|
+
groupId: 'p1',
|
|
11
|
+
name: 'root',
|
|
12
|
+
tenants: { accountId: 'acc-1', workspaceId: 'ws-1' },
|
|
13
|
+
sourceId: 'm1',
|
|
14
|
+
sourceType: 'AgentMessage',
|
|
15
|
+
metadata: {},
|
|
16
|
+
};
|
|
17
|
+
const childActivity = {
|
|
18
|
+
id: 'a2',
|
|
19
|
+
ownerId: 'u1',
|
|
20
|
+
groupId: 'p1',
|
|
21
|
+
name: 'child',
|
|
22
|
+
parentId: 'a1',
|
|
23
|
+
tenants: { accountId: 'acc-1', workspaceId: 'ws-1' },
|
|
24
|
+
sourceId: 'm2',
|
|
25
|
+
sourceType: 'AgentMessage',
|
|
26
|
+
metadata: {},
|
|
27
|
+
};
|
|
28
|
+
(0, vitest_1.it)('lists root activities with cursor metadata', async () => {
|
|
29
|
+
const repository = {
|
|
30
|
+
find: vitest_1.vi.fn().mockResolvedValue([rootActivity]),
|
|
31
|
+
count: vitest_1.vi.fn().mockResolvedValue(10),
|
|
32
|
+
};
|
|
33
|
+
const processor = new ActivityProcessor_1.ActivityProcessor({ activityRepository: repository });
|
|
34
|
+
const result = await processor.listActivities({
|
|
35
|
+
ownerId: 'u1',
|
|
36
|
+
groupId: 'p1',
|
|
37
|
+
skip: 2,
|
|
38
|
+
limit: 5,
|
|
39
|
+
});
|
|
40
|
+
(0, vitest_1.expect)(repository.find).toHaveBeenCalledWith({ ownerId: 'u1', groupId: 'p1', parentId: { $exists: false } }, { skip: 2, limit: 5, sort: undefined });
|
|
41
|
+
(0, vitest_1.expect)(repository.count).toHaveBeenCalledWith({ ownerId: 'u1', groupId: 'p1', parentId: { $exists: false } });
|
|
42
|
+
(0, vitest_1.expect)(result).toEqual({
|
|
43
|
+
data: [rootActivity],
|
|
44
|
+
cursor: {
|
|
45
|
+
total: 10,
|
|
46
|
+
skip: 2,
|
|
47
|
+
limit: 5,
|
|
48
|
+
},
|
|
49
|
+
});
|
|
50
|
+
});
|
|
51
|
+
(0, vitest_1.it)('filters by explicit parentId when provided', async () => {
|
|
52
|
+
const repository = {
|
|
53
|
+
find: vitest_1.vi.fn().mockResolvedValue([childActivity]),
|
|
54
|
+
count: vitest_1.vi.fn().mockResolvedValue(1),
|
|
55
|
+
};
|
|
56
|
+
const processor = new ActivityProcessor_1.ActivityProcessor({ activityRepository: repository });
|
|
57
|
+
const result = await processor.listActivities({
|
|
58
|
+
ownerId: 'u1',
|
|
59
|
+
parentId: 'a1',
|
|
60
|
+
sort: { field: 'name', order: ai_agent_types_1.SortOrder.Asc },
|
|
61
|
+
});
|
|
62
|
+
(0, vitest_1.expect)(repository.find).toHaveBeenCalledWith({ ownerId: 'u1', parentId: 'a1' }, { skip: undefined, limit: undefined, sort: { field: 'name', order: ai_agent_types_1.SortOrder.Asc } });
|
|
63
|
+
(0, vitest_1.expect)(repository.count).toHaveBeenCalledWith({ ownerId: 'u1', parentId: 'a1' });
|
|
64
|
+
(0, vitest_1.expect)(result).toEqual({
|
|
65
|
+
data: [childActivity],
|
|
66
|
+
cursor: {
|
|
67
|
+
total: 1,
|
|
68
|
+
skip: undefined,
|
|
69
|
+
limit: undefined,
|
|
70
|
+
},
|
|
71
|
+
});
|
|
72
|
+
});
|
|
73
|
+
(0, vitest_1.it)('filters getActivityById by owner', async () => {
|
|
74
|
+
const repository = {
|
|
75
|
+
findById: vitest_1.vi.fn().mockResolvedValue(rootActivity),
|
|
76
|
+
};
|
|
77
|
+
const processor = new ActivityProcessor_1.ActivityProcessor({ activityRepository: repository });
|
|
78
|
+
const found = await processor.getActivityById('a1', 'u1');
|
|
79
|
+
const notFound = await processor.getActivityById('a1', 'u2');
|
|
80
|
+
(0, vitest_1.expect)(found).toEqual(rootActivity);
|
|
81
|
+
(0, vitest_1.expect)(notFound).toBeNull();
|
|
82
|
+
});
|
|
83
|
+
});
|
|
84
|
+
//# sourceMappingURL=ActivityProcessor.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActivityProcessor.test.js","sourceRoot":"","sources":["../../../src/processors/ActivityProcessor.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ActivityProcessor.test.d.ts","sourceRoot":"","sources":["../../../src/processors/ActivityProcessor.test.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AgentProcessor = void 0;
|
|
4
|
+
const store_1 = require("../store/index.cjs");
|
|
5
|
+
class AgentProcessor {
|
|
6
|
+
constructor({ agentConfigRepository }) {
|
|
7
|
+
this.agentConfigRepository = agentConfigRepository;
|
|
8
|
+
}
|
|
9
|
+
getToolConfiguration(tool, userAgentPreference) {
|
|
10
|
+
const availabilityTool = tool;
|
|
11
|
+
const toolName = tool.data?.title || tool.type;
|
|
12
|
+
const userPreference = userAgentPreference?.tools?.[toolName];
|
|
13
|
+
const disabledByDefault = availabilityTool.userConfigurable && userPreference !== undefined
|
|
14
|
+
? !userPreference
|
|
15
|
+
: (availabilityTool.disabledByDefault ?? false);
|
|
16
|
+
return {
|
|
17
|
+
title: toolName,
|
|
18
|
+
description: tool.data?.description,
|
|
19
|
+
needsApproval: tool.data?.needsApproval ?? false,
|
|
20
|
+
disabledByDefault,
|
|
21
|
+
userConfigurable: availabilityTool.userConfigurable ?? false,
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
async getAgentsConfiguration(userId, contextKey) {
|
|
25
|
+
const configStore = store_1.ConfigStore.getInstance();
|
|
26
|
+
const agentsConfiguration = configStore.getAgentsConfiguration(contextKey);
|
|
27
|
+
let userAgentPreferences = [];
|
|
28
|
+
if (userId) {
|
|
29
|
+
userAgentPreferences = await this.agentConfigRepository.findByUserId(userId);
|
|
30
|
+
}
|
|
31
|
+
return agentsConfiguration.map((agent) => {
|
|
32
|
+
const userAgentPreference = userAgentPreferences.find((preference) => preference.agentName === agent.name);
|
|
33
|
+
return {
|
|
34
|
+
name: agent.name,
|
|
35
|
+
description: agent.description,
|
|
36
|
+
defaultModel: agent.defaultModel,
|
|
37
|
+
tools: (agent.tools ?? []).map((tool) => this.getToolConfiguration(tool, userAgentPreference)),
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
async upsertUserPreferences(userId, agentName, tools) {
|
|
42
|
+
return this.agentConfigRepository.upsertByUserIdAndAgentName(userId, agentName, { tools });
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
exports.AgentProcessor = AgentProcessor;
|
|
46
|
+
//# sourceMappingURL=AgentProcessor.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AgentProcessor.js","sourceRoot":"","sources":["../../../src/processors/AgentProcessor.ts"],"names":[],"mappings":";;;AAMA,oCAAuC;AAmBvC,MAAa,cAAc;IAGzB,YAAY,EAAE,qBAAqB,EAAoD;QACrF,IAAI,CAAC,qBAAqB,GAAG,qBAAqB,CAAC;IACrD,CAAC;IAEO,oBAAoB,CAAC,IAAe,EAAE,mBAA2C;QACvF,MAAM,gBAAgB,GAAG,IAAyC,CAAC;QACnE,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,EAAE,KAAK,IAAI,IAAI,CAAC,IAAI,CAAA;QAE9C,MAAM,cAAc,GAAG,mBAAmB,EAAE,KAAK,EAAE,CAAC,QAAQ,CAAC,CAAC;QAC9D,MAAM,iBAAiB,GACrB,gBAAgB,CAAC,gBAAgB,IAAI,cAAc,KAAK,SAAS;YAC/D,CAAC,CAAC,CAAC,cAAc;YACjB,CAAC,CAAC,CAAC,gBAAgB,CAAC,iBAAiB,IAAI,KAAK,CAAC,CAAC;QAEpD,OAAO;YACL,KAAK,EAAE,QAAQ;YACf,WAAW,EAAE,IAAI,CAAC,IAAI,EAAE,WAAW;YACnC,aAAa,EAAE,IAAI,CAAC,IAAI,EAAE,aAAa,IAAI,KAAK;YAChD,iBAAiB;YACjB,gBAAgB,EAAE,gBAAgB,CAAC,gBAAgB,IAAI,KAAK;SAC7D,CAAC;IACJ,CAAC;IAED,KAAK,CAAC,sBAAsB,CAAC,MAAe,EAAE,UAAmB;QAC/D,MAAM,WAAW,GAAG,mBAAW,CAAC,WAAW,EAAE,CAAC;QAC9C,MAAM,mBAAmB,GAAG,WAAW,CAAC,sBAAsB,CAAC,UAAU,CAAC,CAAC;QAC3E,IAAI,oBAAoB,GAA4B,EAAE,CAAC;QACvD,IAAI,MAAM,EAAE,CAAC;YACX,oBAAoB,GAAG,MAAM,IAAI,CAAC,qBAAqB,CAAC,YAAY,CAAC,MAAM,CAAC,CAAC;QAC/E,CAAC;QACD,OAAO,mBAAmB,CAAC,GAAG,CAAC,CAAC,KAAkB,EAAE,EAAE;YACpD,MAAM,mBAAmB,GAAG,oBAAoB,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,SAAS,KAAK,KAAK,CAAC,IAAI,CAAC,CAAC;YAC3G,OAAO;gBACL,IAAI,EAAE,KAAK,CAAC,IAAI;gBAChB,WAAW,EAAE,KAAK,CAAC,WAAW;gBAC9B,YAAY,EAAE,KAAK,CAAC,YAAY;gBAChC,KAAK,EAAE,CAAC,KAAK,CAAC,KAAK,IAAI,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,oBAAoB,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;aAC/F,CAAA;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED,KAAK,CAAC,qBAAqB,CACzB,MAAc,EACd,SAAiB,EACjB,KAA8B;QAE9B,OAAO,IAAI,CAAC,qBAAqB,CAAC,0BAA0B,CAAC,MAAM,EAAE,SAAS,EAAE,EAAE,KAAK,EAAE,CAAC,CAAC;IAC7F,CAAC;CACF;AAnDD,wCAmDC"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { AgentConfigRepository } from '@multiplayer-app/ai-agent-db';
|
|
2
|
+
import type { AgentConfigPreference } from '@multiplayer-app/ai-agent-types';
|
|
3
|
+
export interface ToolConfiguration {
|
|
4
|
+
title: string;
|
|
5
|
+
description?: string;
|
|
6
|
+
needsApproval?: boolean;
|
|
7
|
+
disabledByDefault?: boolean;
|
|
8
|
+
userConfigurable?: boolean;
|
|
9
|
+
}
|
|
10
|
+
export interface AgentConfiguration {
|
|
11
|
+
name: string;
|
|
12
|
+
description: string;
|
|
13
|
+
defaultModel?: string;
|
|
14
|
+
tools: ToolConfiguration[];
|
|
15
|
+
}
|
|
16
|
+
export declare class AgentProcessor {
|
|
17
|
+
private agentConfigRepository;
|
|
18
|
+
constructor({ agentConfigRepository }: {
|
|
19
|
+
agentConfigRepository: AgentConfigRepository;
|
|
20
|
+
});
|
|
21
|
+
private getToolConfiguration;
|
|
22
|
+
getAgentsConfiguration(userId?: string, contextKey?: string): Promise<AgentConfiguration[]>;
|
|
23
|
+
upsertUserPreferences(userId: string, agentName: string, tools: Record<string, boolean>): Promise<AgentConfigPreference>;
|
|
24
|
+
}
|
|
25
|
+
//# sourceMappingURL=AgentProcessor.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AgentProcessor.d.ts","sourceRoot":"","sources":["../../../src/processors/AgentProcessor.ts"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,8BAA8B,CAAC;AAC1E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,iCAAiC,CAAC;AAE7E,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,gBAAgB,CAAC,EAAE,OAAO,CAAC;CAC5B;AAED,MAAM,WAAW,kBAAkB;IACjC,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,EAAE,iBAAiB,EAAE,CAAC;CAC5B;AAED,qBAAa,cAAc;IAEzB,OAAO,CAAC,qBAAqB,CAAwB;gBACzC,EAAE,qBAAqB,EAAE,EAAE;QAAE,qBAAqB,EAAE,qBAAqB,CAAA;KAAE;IAIvF,OAAO,CAAC,oBAAoB;IAmBtB,sBAAsB,CAAC,MAAM,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC,kBAAkB,EAAE,CAAC;IAkB3F,qBAAqB,CACzB,MAAM,EAAE,MAAM,EACd,SAAS,EAAE,MAAM,EACjB,KAAK,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAC7B,OAAO,CAAC,qBAAqB,CAAC;CAGlC"}
|
|
@@ -0,0 +1,103 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const vitest_1 = require("vitest");
|
|
4
|
+
const ai_agent_types_1 = require("@multiplayer-app/ai-agent-types");
|
|
5
|
+
const ConfigStore_1 = require("../store/ConfigStore.cjs");
|
|
6
|
+
const AgentProcessor_1 = require("./AgentProcessor.cjs");
|
|
7
|
+
(0, vitest_1.describe)('AgentProcessor.getAgentsConfiguration', () => {
|
|
8
|
+
let processor;
|
|
9
|
+
let mockAgentConfigRepository;
|
|
10
|
+
let configStore;
|
|
11
|
+
(0, vitest_1.beforeEach)(() => {
|
|
12
|
+
vitest_1.vi.clearAllMocks();
|
|
13
|
+
mockAgentConfigRepository = {
|
|
14
|
+
findByUserId: vitest_1.vi.fn().mockResolvedValue([]),
|
|
15
|
+
};
|
|
16
|
+
configStore = ConfigStore_1.ConfigStore.getInstance();
|
|
17
|
+
configStore.clear();
|
|
18
|
+
configStore.addAgent(['support'], {
|
|
19
|
+
name: 'support-agent',
|
|
20
|
+
description: 'Support conversations',
|
|
21
|
+
defaultModel: 'openai/gpt-4o',
|
|
22
|
+
tools: [
|
|
23
|
+
{
|
|
24
|
+
type: ai_agent_types_1.AgentToolType.LOCAL_FUNCTION,
|
|
25
|
+
disabledByDefault: false,
|
|
26
|
+
userConfigurable: true,
|
|
27
|
+
data: {
|
|
28
|
+
title: 'lookupOrder',
|
|
29
|
+
description: 'Find order by id',
|
|
30
|
+
needsApproval: true,
|
|
31
|
+
},
|
|
32
|
+
},
|
|
33
|
+
{
|
|
34
|
+
type: ai_agent_types_1.AgentToolType.WEB_SEARCH,
|
|
35
|
+
userConfigurable: true,
|
|
36
|
+
},
|
|
37
|
+
],
|
|
38
|
+
});
|
|
39
|
+
configStore.addAgent(['sales'], {
|
|
40
|
+
name: 'sales-agent',
|
|
41
|
+
description: 'Sales conversations',
|
|
42
|
+
defaultModel: 'openai/gpt-4o-mini',
|
|
43
|
+
tools: [],
|
|
44
|
+
});
|
|
45
|
+
processor = new AgentProcessor_1.AgentProcessor({ agentConfigRepository: mockAgentConfigRepository });
|
|
46
|
+
});
|
|
47
|
+
(0, vitest_1.it)('returns all agent configurations when context key is not provided', async () => {
|
|
48
|
+
const agents = await processor.getAgentsConfiguration();
|
|
49
|
+
(0, vitest_1.expect)(agents).toHaveLength(2);
|
|
50
|
+
(0, vitest_1.expect)(agents.map((agent) => agent.name)).toEqual(['support-agent', 'sales-agent']);
|
|
51
|
+
(0, vitest_1.expect)(mockAgentConfigRepository.findByUserId).not.toHaveBeenCalled();
|
|
52
|
+
});
|
|
53
|
+
(0, vitest_1.it)('filters agents by context key when provided', async () => {
|
|
54
|
+
const agents = await processor.getAgentsConfiguration(undefined, 'support');
|
|
55
|
+
(0, vitest_1.expect)(agents).toHaveLength(1);
|
|
56
|
+
(0, vitest_1.expect)(agents[0].name).toBe('support-agent');
|
|
57
|
+
});
|
|
58
|
+
(0, vitest_1.it)('applies user tool preferences for configurable tools', async () => {
|
|
59
|
+
mockAgentConfigRepository.findByUserId.mockResolvedValue([
|
|
60
|
+
{
|
|
61
|
+
userId: 'user-1',
|
|
62
|
+
agentName: 'support-agent',
|
|
63
|
+
tools: {
|
|
64
|
+
lookupOrder: false,
|
|
65
|
+
},
|
|
66
|
+
},
|
|
67
|
+
]);
|
|
68
|
+
const agents = await processor.getAgentsConfiguration('user-1', 'support');
|
|
69
|
+
(0, vitest_1.expect)(mockAgentConfigRepository.findByUserId).toHaveBeenCalledWith('user-1');
|
|
70
|
+
(0, vitest_1.expect)(agents[0].tools).toEqual([
|
|
71
|
+
{
|
|
72
|
+
title: 'lookupOrder',
|
|
73
|
+
description: 'Find order by id',
|
|
74
|
+
needsApproval: true,
|
|
75
|
+
disabledByDefault: true,
|
|
76
|
+
userConfigurable: true,
|
|
77
|
+
},
|
|
78
|
+
{
|
|
79
|
+
title: ai_agent_types_1.AgentToolType.WEB_SEARCH,
|
|
80
|
+
description: undefined,
|
|
81
|
+
needsApproval: false,
|
|
82
|
+
disabledByDefault: false,
|
|
83
|
+
userConfigurable: true,
|
|
84
|
+
},
|
|
85
|
+
]);
|
|
86
|
+
});
|
|
87
|
+
(0, vitest_1.it)('does not leak one user preference into another user response', async () => {
|
|
88
|
+
mockAgentConfigRepository.findByUserId
|
|
89
|
+
.mockResolvedValueOnce([
|
|
90
|
+
{
|
|
91
|
+
userId: 'user-1',
|
|
92
|
+
agentName: 'support-agent',
|
|
93
|
+
tools: { lookupOrder: false },
|
|
94
|
+
},
|
|
95
|
+
])
|
|
96
|
+
.mockResolvedValueOnce([]);
|
|
97
|
+
const userOneAgents = await processor.getAgentsConfiguration('user-1', 'support');
|
|
98
|
+
const userTwoAgents = await processor.getAgentsConfiguration('user-2', 'support');
|
|
99
|
+
(0, vitest_1.expect)(userOneAgents[0].tools[0].disabledByDefault).toBe(true);
|
|
100
|
+
(0, vitest_1.expect)(userTwoAgents[0].tools[0].disabledByDefault).toBe(false);
|
|
101
|
+
});
|
|
102
|
+
});
|
|
103
|
+
//# sourceMappingURL=AgentProcessor.test.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AgentProcessor.test.js","sourceRoot":"","sources":["../../../src/processors/AgentProcessor.test.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AgentProcessor.test.d.ts","sourceRoot":"","sources":["../../../src/processors/AgentProcessor.test.ts"],"names":[],"mappings":""}
|