@fr-data-fabric/chatbot-api-nest 0.0.1
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/dist/chatbot-api.module.d.ts +27 -0
- package/dist/chatbot-api.module.js +63 -0
- package/dist/chatbot-api.module.js.map +1 -0
- package/dist/domain/entities/ChatEntity.d.ts +11 -0
- package/dist/domain/entities/ChatEntity.js +3 -0
- package/dist/domain/entities/ChatEntity.js.map +1 -0
- package/dist/domain/entities/ChatSourceEntity.d.ts +6 -0
- package/dist/domain/entities/ChatSourceEntity.js +3 -0
- package/dist/domain/entities/ChatSourceEntity.js.map +1 -0
- package/dist/domain/entities/ChatTextContentEntity.d.ts +4 -0
- package/dist/domain/entities/ChatTextContentEntity.js +3 -0
- package/dist/domain/entities/ChatTextContentEntity.js.map +1 -0
- package/dist/domain/entities/ConversationEntity.d.ts +9 -0
- package/dist/domain/entities/ConversationEntity.js +3 -0
- package/dist/domain/entities/ConversationEntity.js.map +1 -0
- package/dist/domain/entities/DocumentEntity.d.ts +3 -0
- package/dist/domain/entities/DocumentEntity.js +3 -0
- package/dist/domain/entities/DocumentEntity.js.map +1 -0
- package/dist/domain/entities/ToolUseEntity.d.ts +6 -0
- package/dist/domain/entities/ToolUseEntity.js +3 -0
- package/dist/domain/entities/ToolUseEntity.js.map +1 -0
- package/dist/domain/entities/UserEntity.d.ts +3 -0
- package/dist/domain/entities/UserEntity.js +3 -0
- package/dist/domain/entities/UserEntity.js.map +1 -0
- package/dist/domain/interfaces/ChatRepository.d.ts +5 -0
- package/dist/domain/interfaces/ChatRepository.js +5 -0
- package/dist/domain/interfaces/ChatRepository.js.map +1 -0
- package/dist/domain/interfaces/ConversationRepository.d.ts +6 -0
- package/dist/domain/interfaces/ConversationRepository.js +5 -0
- package/dist/domain/interfaces/ConversationRepository.js.map +1 -0
- package/dist/domain/interfaces/LLMService.d.ts +13 -0
- package/dist/domain/interfaces/LLMService.js +5 -0
- package/dist/domain/interfaces/LLMService.js.map +1 -0
- package/dist/domain/interfaces/PromptService.d.ts +8 -0
- package/dist/domain/interfaces/PromptService.js +5 -0
- package/dist/domain/interfaces/PromptService.js.map +1 -0
- package/dist/domain/use-cases/_common.d.ts +17 -0
- package/dist/domain/use-cases/_common.js +41 -0
- package/dist/domain/use-cases/_common.js.map +1 -0
- package/dist/domain/use-cases/chats/GetChatCompletionUC.d.ts +28 -0
- package/dist/domain/use-cases/chats/GetChatCompletionUC.js +83 -0
- package/dist/domain/use-cases/chats/GetChatCompletionUC.js.map +1 -0
- package/dist/domain/use-cases/chats/SendChatUC.d.ts +35 -0
- package/dist/domain/use-cases/chats/SendChatUC.js +166 -0
- package/dist/domain/use-cases/chats/SendChatUC.js.map +1 -0
- package/dist/domain/use-cases/chats/chat.types.d.ts +54 -0
- package/dist/domain/use-cases/chats/chat.types.js +3 -0
- package/dist/domain/use-cases/chats/chat.types.js.map +1 -0
- package/dist/domain/use-cases/conversations/CreateConversationUC.d.ts +6 -0
- package/dist/domain/use-cases/conversations/CreateConversationUC.js +5 -0
- package/dist/domain/use-cases/conversations/CreateConversationUC.js.map +1 -0
- package/dist/domain/use-cases/conversations/DeleteConversationUC.d.ts +10 -0
- package/dist/domain/use-cases/conversations/DeleteConversationUC.js +41 -0
- package/dist/domain/use-cases/conversations/DeleteConversationUC.js.map +1 -0
- package/dist/domain/use-cases/conversations/GenerateConversationTitleUC.d.ts +18 -0
- package/dist/domain/use-cases/conversations/GenerateConversationTitleUC.js +80 -0
- package/dist/domain/use-cases/conversations/GenerateConversationTitleUC.js.map +1 -0
- package/dist/domain/use-cases/conversations/GetConversationUC.d.ts +10 -0
- package/dist/domain/use-cases/conversations/GetConversationUC.js +31 -0
- package/dist/domain/use-cases/conversations/GetConversationUC.js.map +1 -0
- package/dist/domain/use-cases/conversations/GetConversationsUC.d.ts +9 -0
- package/dist/domain/use-cases/conversations/GetConversationsUC.js +27 -0
- package/dist/domain/use-cases/conversations/GetConversationsUC.js.map +1 -0
- package/dist/domain/use-cases/conversations/UpdateConversationUC.d.ts +15 -0
- package/dist/domain/use-cases/conversations/UpdateConversationUC.js +74 -0
- package/dist/domain/use-cases/conversations/UpdateConversationUC.js.map +1 -0
- package/dist/index.d.ts +1 -0
- package/dist/index.js +18 -0
- package/dist/index.js.map +1 -0
- package/dist/inputs/controllers/ChatsController.d.ts +8 -0
- package/dist/inputs/controllers/ChatsController.js +62 -0
- package/dist/inputs/controllers/ChatsController.js.map +1 -0
- package/dist/inputs/controllers/_common/CurrentUserRest.d.ts +1 -0
- package/dist/inputs/controllers/_common/CurrentUserRest.js +9 -0
- package/dist/inputs/controllers/_common/CurrentUserRest.js.map +1 -0
- package/dist/inputs/resolvers/ChatsResolver.d.ts +9 -0
- package/dist/inputs/resolvers/ChatsResolver.js +57 -0
- package/dist/inputs/resolvers/ChatsResolver.js.map +1 -0
- package/dist/inputs/resolvers/ConversationsResolver.d.ts +34 -0
- package/dist/inputs/resolvers/ConversationsResolver.js +170 -0
- package/dist/inputs/resolvers/ConversationsResolver.js.map +1 -0
- package/dist/inputs/resolvers/_common/CurrentUserGql.d.ts +1 -0
- package/dist/inputs/resolvers/_common/CurrentUserGql.js +10 -0
- package/dist/inputs/resolvers/_common/CurrentUserGql.js.map +1 -0
- package/dist/inputs/resolvers/_common/GqlPaginatedOutput.d.ts +8 -0
- package/dist/inputs/resolvers/_common/GqlPaginatedOutput.js +37 -0
- package/dist/inputs/resolvers/_common/GqlPaginatedOutput.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/docs/entities.excalidraw.svg +2 -0
- package/package.json +25 -0
- package/src/chatbot-api.module.ts +90 -0
- package/src/domain/entities/ChatEntity.ts +13 -0
- package/src/domain/entities/ChatSourceEntity.ts +6 -0
- package/src/domain/entities/ChatTextContentEntity.ts +4 -0
- package/src/domain/entities/ConversationEntity.ts +10 -0
- package/src/domain/entities/DocumentEntity.ts +3 -0
- package/src/domain/entities/ToolUseEntity.ts +6 -0
- package/src/domain/entities/UserEntity.ts +3 -0
- package/src/domain/interfaces/ChatRepository.ts +7 -0
- package/src/domain/interfaces/ConversationRepository.ts +8 -0
- package/src/domain/interfaces/LLMService.ts +15 -0
- package/src/domain/interfaces/PromptService.ts +10 -0
- package/src/domain/use-cases/_common.ts +28 -0
- package/src/domain/use-cases/chats/GetChatCompletionUC.ts +126 -0
- package/src/domain/use-cases/chats/SendChatUC.ts +202 -0
- package/src/domain/use-cases/chats/chat.types.ts +51 -0
- package/src/domain/use-cases/conversations/CreateConversationUC.ts +7 -0
- package/src/domain/use-cases/conversations/DeleteConversationUC.ts +29 -0
- package/src/domain/use-cases/conversations/GenerateConversationTitleUC.ts +69 -0
- package/src/domain/use-cases/conversations/GetConversationUC.ts +18 -0
- package/src/domain/use-cases/conversations/GetConversationsUC.ts +21 -0
- package/src/domain/use-cases/conversations/UpdateConversationUC.ts +54 -0
- package/src/index.ts +1 -0
- package/src/inputs/controllers/ChatsController.ts +47 -0
- package/src/inputs/controllers/_common/CurrentUserRest.ts +10 -0
- package/src/inputs/resolvers/ChatsResolver.ts +40 -0
- package/src/inputs/resolvers/ConversationsResolver.ts +149 -0
- package/src/inputs/resolvers/_common/CurrentUserGql.ts +11 -0
- package/src/inputs/resolvers/_common/GqlPaginatedOutput.ts +25 -0
- package/tsconfig.json +28 -0
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import { ConversationRepository } from '@domain/interfaces/ConversationRepository';
|
|
2
|
+
import { SendChatUC } from '@domain/use-cases/chats/SendChatUC';
|
|
3
|
+
import { ICreateConversationUC } from '@domain/use-cases/conversations/CreateConversationUC';
|
|
4
|
+
import { IGetConversationsUC } from '@domain/use-cases/conversations/GetConversationsUC';
|
|
5
|
+
import { IGetConversationUC } from '@domain/use-cases/conversations/GetConversationUC';
|
|
6
|
+
import { DynamicModule, Type } from '@nestjs/common';
|
|
7
|
+
import { GqlTypeReference } from '@nestjs/graphql';
|
|
8
|
+
export type ChatbotApiModuleOptions = {
|
|
9
|
+
useCases: {
|
|
10
|
+
getConversation: Type<IGetConversationUC>;
|
|
11
|
+
getConversations: Type<IGetConversationsUC>;
|
|
12
|
+
createConversation: Type<ICreateConversationUC>;
|
|
13
|
+
sendChat: Type<SendChatUC<never>>;
|
|
14
|
+
};
|
|
15
|
+
conversationRepository: Type<ConversationRepository>;
|
|
16
|
+
gql: {
|
|
17
|
+
GqlConversation: GqlTypeReference;
|
|
18
|
+
GqlChat: GqlTypeReference;
|
|
19
|
+
GqlUser: GqlTypeReference;
|
|
20
|
+
GqlChatSource: GqlTypeReference;
|
|
21
|
+
GqlChatTextContent: GqlTypeReference;
|
|
22
|
+
GqlToolUse: GqlTypeReference;
|
|
23
|
+
};
|
|
24
|
+
};
|
|
25
|
+
export declare class ChatbotApiModule {
|
|
26
|
+
static register(options: ChatbotApiModuleOptions): DynamicModule;
|
|
27
|
+
}
|
|
@@ -0,0 +1,63 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var ChatbotApiModule_1;
|
|
9
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
10
|
+
exports.ChatbotApiModule = void 0;
|
|
11
|
+
const ConversationRepository_1 = require("@domain/interfaces/ConversationRepository");
|
|
12
|
+
const SendChatUC_1 = require("@domain/use-cases/chats/SendChatUC");
|
|
13
|
+
const CreateConversationUC_1 = require("@domain/use-cases/conversations/CreateConversationUC");
|
|
14
|
+
const DeleteConversationUC_1 = require("@domain/use-cases/conversations/DeleteConversationUC");
|
|
15
|
+
const GetConversationsUC_1 = require("@domain/use-cases/conversations/GetConversationsUC");
|
|
16
|
+
const GetConversationUC_1 = require("@domain/use-cases/conversations/GetConversationUC");
|
|
17
|
+
const UpdateConversationUC_1 = require("@domain/use-cases/conversations/UpdateConversationUC");
|
|
18
|
+
const common_1 = require("@nestjs/common");
|
|
19
|
+
const ChatsController_1 = require("src/inputs/controllers/ChatsController");
|
|
20
|
+
const ChatsResolver_1 = require("src/inputs/resolvers/ChatsResolver");
|
|
21
|
+
const ConversationsResolver_1 = require("src/inputs/resolvers/ConversationsResolver");
|
|
22
|
+
let ChatbotApiModule = ChatbotApiModule_1 = class ChatbotApiModule {
|
|
23
|
+
static register(options) {
|
|
24
|
+
return {
|
|
25
|
+
module: ChatbotApiModule_1,
|
|
26
|
+
providers: [
|
|
27
|
+
// Repositories
|
|
28
|
+
{
|
|
29
|
+
provide: ConversationRepository_1.CONVERSATION_REPOSITORY,
|
|
30
|
+
useClass: options.conversationRepository,
|
|
31
|
+
},
|
|
32
|
+
// Use cases
|
|
33
|
+
{
|
|
34
|
+
provide: GetConversationUC_1.GET_CONVERSATION_UC,
|
|
35
|
+
useClass: options.useCases.getConversation,
|
|
36
|
+
},
|
|
37
|
+
{
|
|
38
|
+
provide: GetConversationsUC_1.GET_CONVERSATIONS_UC,
|
|
39
|
+
useClass: options.useCases.getConversations,
|
|
40
|
+
},
|
|
41
|
+
{
|
|
42
|
+
provide: CreateConversationUC_1.CREATE_CONVERSATION_UC,
|
|
43
|
+
useClass: options.useCases.createConversation,
|
|
44
|
+
},
|
|
45
|
+
DeleteConversationUC_1.DeleteConversationUC,
|
|
46
|
+
UpdateConversationUC_1.UpdateConversationUC,
|
|
47
|
+
{
|
|
48
|
+
provide: SendChatUC_1.SEND_CHAT_UC,
|
|
49
|
+
useClass: options.useCases.sendChat,
|
|
50
|
+
},
|
|
51
|
+
// Resolvers
|
|
52
|
+
(0, ConversationsResolver_1.GetConversationsResolver)(options.gql.GqlConversation, options.gql.GqlChat, options.gql.GqlUser),
|
|
53
|
+
(0, ChatsResolver_1.GetChatsResolver)(options.gql.GqlChat, options.gql.GqlChatSource, options.gql.GqlChatTextContent, options.gql.GqlToolUse),
|
|
54
|
+
],
|
|
55
|
+
controllers: [ChatsController_1.ChatsController],
|
|
56
|
+
};
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
exports.ChatbotApiModule = ChatbotApiModule;
|
|
60
|
+
exports.ChatbotApiModule = ChatbotApiModule = ChatbotApiModule_1 = __decorate([
|
|
61
|
+
(0, common_1.Module)({})
|
|
62
|
+
], ChatbotApiModule);
|
|
63
|
+
//# sourceMappingURL=chatbot-api.module.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"chatbot-api.module.js","sourceRoot":"/","sources":["chatbot-api.module.ts"],"names":[],"mappings":";;;;;;;;;;AAAA,sFAGmD;AACnD,mEAA8E;AAC9E,+FAG8D;AAC9D,+FAA4F;AAC5F,2FAG4D;AAC5D,yFAG2D;AAC3D,+FAA4F;AAC5F,2CAA6D;AAE7D,4EAAyE;AACzE,sEAAsE;AACtE,sFAAsF;AAqB/E,IAAM,gBAAgB,wBAAtB,MAAM,gBAAgB;IAC3B,MAAM,CAAC,QAAQ,CAAC,OAAgC;QAC9C,OAAO;YACL,MAAM,EAAE,kBAAgB;YACxB,SAAS,EAAE;gBACT,eAAe;gBACf;oBACE,OAAO,EAAE,gDAAuB;oBAChC,QAAQ,EAAE,OAAO,CAAC,sBAAsB;iBACzC;gBACD,YAAY;gBACZ;oBACE,OAAO,EAAE,uCAAmB;oBAC5B,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,eAAe;iBAC3C;gBACD;oBACE,OAAO,EAAE,yCAAoB;oBAC7B,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,gBAAgB;iBAC5C;gBACD;oBACE,OAAO,EAAE,6CAAsB;oBAC/B,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,kBAAkB;iBAC9C;gBACD,2CAAoB;gBACpB,2CAAoB;gBACpB;oBACE,OAAO,EAAE,yBAAY;oBACrB,QAAQ,EAAE,OAAO,CAAC,QAAQ,CAAC,QAAQ;iBACpC;gBACD,YAAY;gBACZ,IAAA,gDAAwB,EACtB,OAAO,CAAC,GAAG,CAAC,eAAe,EAC3B,OAAO,CAAC,GAAG,CAAC,OAAO,EACnB,OAAO,CAAC,GAAG,CAAC,OAAO,CACpB;gBACD,IAAA,gCAAgB,EACd,OAAO,CAAC,GAAG,CAAC,OAAO,EACnB,OAAO,CAAC,GAAG,CAAC,aAAa,EACzB,OAAO,CAAC,GAAG,CAAC,kBAAkB,EAC9B,OAAO,CAAC,GAAG,CAAC,UAAU,CACvB;aACF;YACD,WAAW,EAAE,CAAC,iCAAe,CAAC;SAC/B,CAAC;IACJ,CAAC;CACF,CAAA;AA7CY,4CAAgB;2BAAhB,gBAAgB;IAD5B,IAAA,eAAM,EAAC,EAAE,CAAC;GACE,gBAAgB,CA6C5B"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { ChatSourceEntity } from '@domain/entities/ChatSourceEntity';
|
|
2
|
+
import { ChatTextContentEntity } from '@domain/entities/ChatTextContentEntity';
|
|
3
|
+
import { ToolUseEntity } from '@domain/entities/ToolUseEntity';
|
|
4
|
+
export interface ChatEntity {
|
|
5
|
+
id: string;
|
|
6
|
+
createdAt: Date;
|
|
7
|
+
updatedAt: Date;
|
|
8
|
+
_sources: Promise<ChatSourceEntity[]>;
|
|
9
|
+
_textContents: Promise<ChatTextContentEntity[]>;
|
|
10
|
+
_toolUses: Promise<ToolUseEntity[]>;
|
|
11
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChatEntity.js","sourceRoot":"/","sources":["domain/entities/ChatEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChatSourceEntity.js","sourceRoot":"/","sources":["domain/entities/ChatSourceEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChatTextContentEntity.js","sourceRoot":"/","sources":["domain/entities/ChatTextContentEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { ChatEntity } from '@domain/entities/ChatEntity';
|
|
2
|
+
import { UserEntity } from '@domain/entities/UserEntity';
|
|
3
|
+
export interface ConversationEntity {
|
|
4
|
+
id: string;
|
|
5
|
+
title: string;
|
|
6
|
+
shareId: string | null;
|
|
7
|
+
_chats: Promise<ChatEntity[]>;
|
|
8
|
+
_user: Promise<UserEntity>;
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConversationEntity.js","sourceRoot":"/","sources":["domain/entities/ConversationEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DocumentEntity.js","sourceRoot":"/","sources":["domain/entities/DocumentEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ToolUseEntity.js","sourceRoot":"/","sources":["domain/entities/ToolUseEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"UserEntity.js","sourceRoot":"/","sources":["domain/entities/UserEntity.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ChatRepository.js","sourceRoot":"/","sources":["domain/interfaces/ChatRepository.ts"],"names":[],"mappings":";;;AAEa,QAAA,eAAe,GAAG,gBAAgB,CAAC"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { ConversationEntity } from '@domain/entities/ConversationEntity';
|
|
2
|
+
export declare const CONVERSATION_REPOSITORY = "ConversationRepository";
|
|
3
|
+
export interface ConversationRepository {
|
|
4
|
+
save: (conversation: ConversationEntity) => Promise<ConversationEntity>;
|
|
5
|
+
remove: (conversation: ConversationEntity) => Promise<ConversationEntity>;
|
|
6
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ConversationRepository.js","sourceRoot":"/","sources":["domain/interfaces/ConversationRepository.ts"],"names":[],"mappings":";;;AAEa,QAAA,uBAAuB,GAAG,wBAAwB,CAAC"}
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import { BaseChatModel } from '@langchain/core/language_models/chat_models';
|
|
2
|
+
export declare const LLM_SERVICE = "LLMService";
|
|
3
|
+
type ProvidersOptions = {
|
|
4
|
+
temperature: number;
|
|
5
|
+
streaming: boolean;
|
|
6
|
+
model: string;
|
|
7
|
+
provider: string;
|
|
8
|
+
};
|
|
9
|
+
export type LLMOptions = ProvidersOptions;
|
|
10
|
+
export interface LLMService {
|
|
11
|
+
getLLM(options: LLMOptions): BaseChatModel;
|
|
12
|
+
}
|
|
13
|
+
export {};
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LLMService.js","sourceRoot":"/","sources":["domain/interfaces/LLMService.ts"],"names":[],"mappings":";;;AAEa,QAAA,WAAW,GAAG,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PromptService.js","sourceRoot":"/","sources":["domain/interfaces/PromptService.ts"],"names":[],"mappings":";;;AAEa,QAAA,cAAc,GAAG,eAAe,CAAC"}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import { UserEntity } from '@domain/entities/UserEntity';
|
|
2
|
+
export type UCInput<Input> = {
|
|
3
|
+
input: Input;
|
|
4
|
+
currentUser: UserEntity;
|
|
5
|
+
};
|
|
6
|
+
export declare class DeleteByIdInput {
|
|
7
|
+
id: string;
|
|
8
|
+
}
|
|
9
|
+
export type PaginatedOutput<Item> = {
|
|
10
|
+
items: Item[];
|
|
11
|
+
totalCount: number;
|
|
12
|
+
hasNextPage: boolean;
|
|
13
|
+
};
|
|
14
|
+
export declare class PaginatedInput {
|
|
15
|
+
limit: number;
|
|
16
|
+
offset: number;
|
|
17
|
+
}
|
|
@@ -0,0 +1,41 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
|
|
3
|
+
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
|
|
4
|
+
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
|
|
5
|
+
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
|
|
6
|
+
return c > 3 && r && Object.defineProperty(target, key, r), r;
|
|
7
|
+
};
|
|
8
|
+
var __metadata = (this && this.__metadata) || function (k, v) {
|
|
9
|
+
if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.PaginatedInput = exports.DeleteByIdInput = void 0;
|
|
13
|
+
const graphql_1 = require("@nestjs/graphql");
|
|
14
|
+
let DeleteByIdInput = class DeleteByIdInput {
|
|
15
|
+
id;
|
|
16
|
+
};
|
|
17
|
+
exports.DeleteByIdInput = DeleteByIdInput;
|
|
18
|
+
__decorate([
|
|
19
|
+
(0, graphql_1.Field)(() => graphql_1.ID),
|
|
20
|
+
__metadata("design:type", String)
|
|
21
|
+
], DeleteByIdInput.prototype, "id", void 0);
|
|
22
|
+
exports.DeleteByIdInput = DeleteByIdInput = __decorate([
|
|
23
|
+
(0, graphql_1.InputType)()
|
|
24
|
+
], DeleteByIdInput);
|
|
25
|
+
let PaginatedInput = class PaginatedInput {
|
|
26
|
+
limit;
|
|
27
|
+
offset;
|
|
28
|
+
};
|
|
29
|
+
exports.PaginatedInput = PaginatedInput;
|
|
30
|
+
__decorate([
|
|
31
|
+
(0, graphql_1.Field)(() => graphql_1.Int),
|
|
32
|
+
__metadata("design:type", Number)
|
|
33
|
+
], PaginatedInput.prototype, "limit", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
(0, graphql_1.Field)(() => graphql_1.Int),
|
|
36
|
+
__metadata("design:type", Number)
|
|
37
|
+
], PaginatedInput.prototype, "offset", void 0);
|
|
38
|
+
exports.PaginatedInput = PaginatedInput = __decorate([
|
|
39
|
+
(0, graphql_1.InputType)()
|
|
40
|
+
], PaginatedInput);
|
|
41
|
+
//# sourceMappingURL=_common.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_common.js","sourceRoot":"/","sources":["domain/use-cases/_common.ts"],"names":[],"mappings":";;;;;;;;;;;;AACA,6CAA4D;AAQrD,IAAM,eAAe,GAArB,MAAM,eAAe;IAE1B,EAAE,CAAU;CACb,CAAA;AAHY,0CAAe;AAE1B;IADC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,YAAE,CAAC;;2CACJ;0BAFD,eAAe;IAD3B,IAAA,mBAAS,GAAE;GACC,eAAe,CAG3B;AASM,IAAM,cAAc,GAApB,MAAM,cAAc;IAEzB,KAAK,CAAU;IAGf,MAAM,CAAU;CACjB,CAAA;AANY,wCAAc;AAEzB;IADC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,aAAG,CAAC;;6CACF;AAGf;IADC,IAAA,eAAK,EAAC,GAAG,EAAE,CAAC,aAAG,CAAC;;8CACD;yBALL,cAAc;IAD1B,IAAA,mBAAS,GAAE;GACC,cAAc,CAM1B"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
import { ConversationEntity } from '@domain/entities/ConversationEntity';
|
|
2
|
+
import { DocumentEntity } from '@domain/entities/DocumentEntity';
|
|
3
|
+
import { UserEntity } from '@domain/entities/UserEntity';
|
|
4
|
+
import { AvailableTool, StreamEvents, ToolOptions } from '@domain/use-cases/chats/chat.types';
|
|
5
|
+
import { BaseChatModel } from '@langchain/core/language_models/chat_models';
|
|
6
|
+
import { BaseMessage, DynamicStructuredTool } from 'langchain';
|
|
7
|
+
import { Observable } from 'rxjs';
|
|
8
|
+
export type GetChatCompletionInput<AvailableTools extends AvailableTool[]> = {
|
|
9
|
+
message: string;
|
|
10
|
+
previousMessages: {
|
|
11
|
+
role: 'user' | 'assistant';
|
|
12
|
+
content: string;
|
|
13
|
+
}[];
|
|
14
|
+
conversation: ConversationEntity;
|
|
15
|
+
runId: string;
|
|
16
|
+
tools?: AvailableTools;
|
|
17
|
+
documents: DocumentEntity[];
|
|
18
|
+
currentUser: UserEntity;
|
|
19
|
+
model?: string;
|
|
20
|
+
};
|
|
21
|
+
export declare abstract class GetChatCompletionUC<AvailableTools extends AvailableTool[]> {
|
|
22
|
+
abstract getTools(toolOptions: ToolOptions, selectedTools: AvailableTools): DynamicStructuredTool[];
|
|
23
|
+
abstract getLLM(options: {
|
|
24
|
+
model?: string;
|
|
25
|
+
}): BaseChatModel;
|
|
26
|
+
abstract getPrompt(question: string, documents: DocumentEntity[]): Promise<BaseMessage[]>;
|
|
27
|
+
execute(input: GetChatCompletionInput<AvailableTools>): Observable<StreamEvents<AvailableTools>>;
|
|
28
|
+
}
|
|
@@ -0,0 +1,83 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.GetChatCompletionUC = void 0;
|
|
4
|
+
const langchain_1 = require("langchain");
|
|
5
|
+
const rxjs_1 = require("rxjs");
|
|
6
|
+
class GetChatCompletionUC {
|
|
7
|
+
execute(input) {
|
|
8
|
+
return new rxjs_1.Observable((observer) => {
|
|
9
|
+
const model = this.getLLM({
|
|
10
|
+
model: input.model,
|
|
11
|
+
});
|
|
12
|
+
let sourceIndex = 0;
|
|
13
|
+
const toolOptions = {
|
|
14
|
+
getSourceIndex() {
|
|
15
|
+
return ++sourceIndex;
|
|
16
|
+
},
|
|
17
|
+
addSources(sources) {
|
|
18
|
+
observer.next({ event: 'sources_add', sources });
|
|
19
|
+
},
|
|
20
|
+
currentUser: input.currentUser,
|
|
21
|
+
};
|
|
22
|
+
const agent = (0, langchain_1.createAgent)({
|
|
23
|
+
model,
|
|
24
|
+
tools: input.tools ? this.getTools(toolOptions, input.tools) : [],
|
|
25
|
+
});
|
|
26
|
+
void (async () => {
|
|
27
|
+
const prompt = await this.getPrompt(input.message, input.documents);
|
|
28
|
+
const eventStream = agent.streamEvents({ messages: prompt }, { streamMode: 'messages', configurable: { runId: input.runId } });
|
|
29
|
+
let lastToolId = undefined;
|
|
30
|
+
for await (const event of eventStream) {
|
|
31
|
+
if (event.event === 'on_tool_end') {
|
|
32
|
+
const output = event.data.output;
|
|
33
|
+
observer.next({
|
|
34
|
+
event: 'tool_end',
|
|
35
|
+
name: event.name,
|
|
36
|
+
id: output.tool_call_id,
|
|
37
|
+
input: event.data.input.input,
|
|
38
|
+
output: output.content,
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
if (event.event === 'on_tool_start' && lastToolId) {
|
|
42
|
+
observer.next({
|
|
43
|
+
event: 'tool_start',
|
|
44
|
+
name: event.name,
|
|
45
|
+
id: lastToolId,
|
|
46
|
+
input: event.data.input.input,
|
|
47
|
+
});
|
|
48
|
+
}
|
|
49
|
+
if (event.event === 'on_chat_model_stream') {
|
|
50
|
+
const chunk = event.data.chunk;
|
|
51
|
+
if (chunk.tool_call_chunks?.length) {
|
|
52
|
+
const toolCallChunk = chunk.tool_call_chunks[0];
|
|
53
|
+
if (toolCallChunk.name && toolCallChunk.id) {
|
|
54
|
+
lastToolId = toolCallChunk.id;
|
|
55
|
+
observer.next({
|
|
56
|
+
event: 'tool_stream_start',
|
|
57
|
+
name: toolCallChunk.name,
|
|
58
|
+
id: toolCallChunk.id,
|
|
59
|
+
});
|
|
60
|
+
}
|
|
61
|
+
else if (lastToolId && toolCallChunk.args) {
|
|
62
|
+
observer.next({
|
|
63
|
+
event: 'tool_stream',
|
|
64
|
+
id: lastToolId,
|
|
65
|
+
input: toolCallChunk.args,
|
|
66
|
+
});
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
else if (chunk.content) {
|
|
70
|
+
observer.next({
|
|
71
|
+
event: 'chat_stream',
|
|
72
|
+
content: chunk.content,
|
|
73
|
+
});
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
observer.complete();
|
|
78
|
+
})();
|
|
79
|
+
});
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
exports.GetChatCompletionUC = GetChatCompletionUC;
|
|
83
|
+
//# sourceMappingURL=GetChatCompletionUC.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"GetChatCompletionUC.js","sourceRoot":"/","sources":["domain/use-cases/chats/GetChatCompletionUC.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,35 @@
|
|
|
1
|
+
import { ChatEntity } from '@domain/entities/ChatEntity';
|
|
2
|
+
import { ChatSourceEntity } from '@domain/entities/ChatSourceEntity';
|
|
3
|
+
import { ChatTextContentEntity } from '@domain/entities/ChatTextContentEntity';
|
|
4
|
+
import { ConversationEntity } from '@domain/entities/ConversationEntity';
|
|
5
|
+
import { DocumentEntity } from '@domain/entities/DocumentEntity';
|
|
6
|
+
import { ToolUseEntity } from '@domain/entities/ToolUseEntity';
|
|
7
|
+
import { UserEntity } from '@domain/entities/UserEntity';
|
|
8
|
+
import type { ChatRepository } from '@domain/interfaces/ChatRepository';
|
|
9
|
+
import { UCInput } from '@domain/use-cases/_common';
|
|
10
|
+
import { AvailableTool, ChatStreamEvents } from '@domain/use-cases/chats/chat.types';
|
|
11
|
+
import { GetChatCompletionUC } from '@domain/use-cases/chats/GetChatCompletionUC';
|
|
12
|
+
import type { IGetConversationUC } from '@domain/use-cases/conversations/GetConversationUC';
|
|
13
|
+
import { EventEmitter2 } from '@nestjs/event-emitter';
|
|
14
|
+
import { Observable } from 'rxjs';
|
|
15
|
+
export declare class SendMessageInput<AvailableTools extends AvailableTool[]> {
|
|
16
|
+
conversationId: string;
|
|
17
|
+
content: string;
|
|
18
|
+
selectedTools?: AvailableTools;
|
|
19
|
+
documentIds?: string[];
|
|
20
|
+
model?: string;
|
|
21
|
+
}
|
|
22
|
+
export declare const SEND_CHAT_UC = "SendChatUC";
|
|
23
|
+
export declare abstract class SendChatUC<AvailableTools extends AvailableTool[]> {
|
|
24
|
+
private readonly getConversationUC;
|
|
25
|
+
private readonly chatRepository;
|
|
26
|
+
private readonly eventEmitter;
|
|
27
|
+
private readonly getChatCompletionUC;
|
|
28
|
+
constructor(getConversationUC: IGetConversationUC, chatRepository: ChatRepository, eventEmitter: EventEmitter2, getChatCompletionUC: GetChatCompletionUC<AvailableTools>);
|
|
29
|
+
abstract getDocuments(documentIds: string[], currentUser: UserEntity): Promise<DocumentEntity[]>;
|
|
30
|
+
abstract createChatEntity(role: 'user' | 'assistant', content: string, conversation: ConversationEntity, documents?: DocumentEntity[]): ChatEntity;
|
|
31
|
+
execute({ input, currentUser, }: UCInput<SendMessageInput<AvailableTools>>): Promise<Observable<ChatStreamEvents<AvailableTools>>>;
|
|
32
|
+
abstract saveChatSources(sources: ChatSourceEntity[]): Promise<void>;
|
|
33
|
+
abstract saveChatTextContent(chatCompletion: ChatTextContentEntity[]): Promise<void>;
|
|
34
|
+
abstract saveToolUse(tools: ToolUseEntity[]): Promise<void>;
|
|
35
|
+
}
|