@lobehub/lobehub 2.0.0-next.26 → 2.0.0-next.27

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.
Files changed (61) hide show
  1. package/CHANGELOG.md +25 -0
  2. package/changelog/v1.json +9 -0
  3. package/package.json +1 -1
  4. package/packages/types/src/topic/topic.ts +14 -0
  5. package/src/server/routers/lambda/topic.ts +7 -1
  6. package/src/services/aiModel/index.test.ts +3 -3
  7. package/src/services/aiModel/index.ts +56 -2
  8. package/src/services/aiProvider/index.test.ts +2 -2
  9. package/src/services/aiProvider/index.ts +48 -2
  10. package/src/services/chatGroup/index.ts +66 -2
  11. package/src/services/export/index.ts +10 -2
  12. package/src/services/file/index.ts +61 -2
  13. package/src/services/import/index.ts +133 -2
  14. package/src/services/message/index.ts +176 -2
  15. package/src/services/message/{__tests__/server.test.ts → server.test.ts} +3 -3
  16. package/src/services/plugin/index.test.ts +8 -0
  17. package/src/services/plugin/index.ts +53 -2
  18. package/src/services/session/index.test.ts +8 -0
  19. package/src/services/session/index.ts +145 -2
  20. package/src/services/thread/index.test.ts +8 -0
  21. package/src/services/thread/index.ts +38 -2
  22. package/src/services/topic/index.test.ts +8 -0
  23. package/src/services/topic/index.ts +76 -2
  24. package/src/services/user/index.test.ts +8 -0
  25. package/src/services/user/index.ts +53 -2
  26. package/src/store/aiInfra/slices/aiModel/action.test.ts +17 -9
  27. package/src/store/chat/slices/aiChat/actions/__tests__/helpers.ts +4 -2
  28. package/src/store/chat/slices/topic/action.test.ts +1 -1
  29. package/src/store/chat/slices/topic/action.ts +1 -2
  30. package/src/store/chat/slices/topic/reducer.ts +1 -2
  31. package/src/store/file/slices/chat/action.ts +1 -4
  32. package/src/store/file/slices/fileManager/action.ts +2 -3
  33. package/src/store/session/slices/sessionGroup/action.test.ts +5 -5
  34. package/src/store/user/slices/common/action.test.ts +1 -1
  35. package/src/services/aiModel/server.test.ts +0 -122
  36. package/src/services/aiModel/server.ts +0 -51
  37. package/src/services/aiModel/type.ts +0 -32
  38. package/src/services/aiProvider/server.ts +0 -43
  39. package/src/services/aiProvider/type.ts +0 -27
  40. package/src/services/chatGroup/server.ts +0 -67
  41. package/src/services/chatGroup/type.ts +0 -22
  42. package/src/services/export/server.ts +0 -9
  43. package/src/services/export/type.ts +0 -5
  44. package/src/services/file/server.ts +0 -53
  45. package/src/services/file/type.ts +0 -13
  46. package/src/services/import/server.ts +0 -133
  47. package/src/services/import/type.ts +0 -17
  48. package/src/services/message/server.ts +0 -151
  49. package/src/services/message/type.ts +0 -55
  50. package/src/services/plugin/server.ts +0 -42
  51. package/src/services/plugin/type.ts +0 -23
  52. package/src/services/session/server.test.ts +0 -260
  53. package/src/services/session/server.ts +0 -125
  54. package/src/services/session/type.ts +0 -82
  55. package/src/services/thread/server.ts +0 -32
  56. package/src/services/thread/type.ts +0 -21
  57. package/src/services/topic/server.ts +0 -57
  58. package/src/services/topic/type.ts +0 -40
  59. package/src/services/user/server.test.ts +0 -149
  60. package/src/services/user/server.ts +0 -47
  61. package/src/services/user/type.ts +0 -21
@@ -1,82 +0,0 @@
1
- /* eslint-disable typescript-sort-keys/interface */
2
- import type { PartialDeep } from 'type-fest';
3
-
4
- import { LobeAgentChatConfig, LobeAgentConfig } from '@/types/agent';
5
- import { MetaData } from '@/types/meta';
6
- import { BatchTaskResult } from '@/types/service';
7
- import {
8
- ChatSessionList,
9
- LobeAgentSession,
10
- LobeSessionType,
11
- LobeSessions,
12
- SessionGroupItem,
13
- SessionGroups,
14
- SessionRankItem,
15
- UpdateSessionParams,
16
- } from '@/types/session';
17
-
18
- export interface ISessionService {
19
- hasSessions(): Promise<boolean>;
20
- createSession(type: LobeSessionType, defaultValue: Partial<LobeAgentSession>): Promise<string>;
21
-
22
- /**
23
- * 需要废弃
24
- * @deprecated
25
- */
26
- batchCreateSessions(importSessions: LobeSessions): Promise<any>;
27
- cloneSession(id: string, newTitle: string): Promise<string | undefined>;
28
-
29
- getGroupedSessions(): Promise<ChatSessionList>;
30
-
31
- /**
32
- * @deprecated
33
- */
34
- getSessionsByType(type?: 'agent' | 'group' | 'all'): Promise<LobeSessions>;
35
- countSessions(params?: {
36
- endDate?: string;
37
- range?: [string, string];
38
- startDate?: string;
39
- }): Promise<number>;
40
- rankSessions(limit?: number): Promise<SessionRankItem[]>;
41
- searchSessions(keyword: string): Promise<LobeSessions>;
42
-
43
- updateSession(id: string, data: Partial<UpdateSessionParams>): Promise<any>;
44
-
45
- getSessionConfig(id: string): Promise<LobeAgentConfig>;
46
- updateSessionConfig(
47
- id: string,
48
- config: PartialDeep<LobeAgentConfig>,
49
- signal?: AbortSignal,
50
- ): Promise<any>;
51
-
52
- updateSessionMeta(id: string, meta: Partial<MetaData>, signal?: AbortSignal): Promise<any>;
53
-
54
- updateSessionChatConfig(
55
- id: string,
56
- config: Partial<LobeAgentChatConfig>,
57
- signal?: AbortSignal,
58
- ): Promise<any>;
59
-
60
- removeSession(id: string): Promise<any>;
61
- removeAllSessions(): Promise<any>;
62
-
63
- // ************************************** //
64
- // *********** SessionGroup *********** //
65
- // ************************************** //
66
-
67
- createSessionGroup(name: string, sort?: number): Promise<string>;
68
-
69
- /**
70
- * 需要废弃
71
- * @deprecated
72
- */
73
- batchCreateSessionGroups(groups: SessionGroups): Promise<BatchTaskResult>;
74
-
75
- getSessionGroups(): Promise<SessionGroupItem[]>;
76
-
77
- updateSessionGroup(id: string, data: Partial<SessionGroupItem>): Promise<any>;
78
- updateSessionGroupOrder(sortMap: { id: string; sort: number }[]): Promise<any>;
79
-
80
- removeSessionGroup(id: string, removeChildren?: boolean): Promise<any>;
81
- removeSessionGroups(): Promise<any>;
82
- }
@@ -1,32 +0,0 @@
1
- import { INBOX_SESSION_ID } from '@/const/session';
2
- import { lambdaClient } from '@/libs/trpc/client';
3
-
4
- import { IThreadService } from './type';
5
-
6
- export class ServerService implements IThreadService {
7
- getThreads: IThreadService['getThreads'] = (topicId) => {
8
- return lambdaClient.thread.getThreads.query({ topicId });
9
- };
10
-
11
- createThreadWithMessage: IThreadService['createThreadWithMessage'] = async ({
12
- message,
13
- ...params
14
- }) => {
15
- return lambdaClient.thread.createThreadWithMessage.mutate({
16
- ...params,
17
- message: { ...message, sessionId: this.toDbSessionId(message.sessionId) },
18
- });
19
- };
20
-
21
- updateThread: IThreadService['updateThread'] = async (id, data) => {
22
- return lambdaClient.thread.updateThread.mutate({ id, value: data });
23
- };
24
-
25
- removeThread: IThreadService['removeThread'] = async (id) => {
26
- return lambdaClient.thread.removeThread.mutate({ id });
27
- };
28
-
29
- private toDbSessionId = (sessionId: string | undefined) => {
30
- return sessionId === INBOX_SESSION_ID ? null : sessionId;
31
- };
32
- }
@@ -1,21 +0,0 @@
1
- /* eslint-disable typescript-sort-keys/interface */
2
- import { CreateMessageParams } from '@lobechat/types';
3
-
4
- import { CreateThreadParams, ThreadItem } from '@/types/topic';
5
-
6
- interface CreateThreadWithMessageParams extends CreateThreadParams {
7
- message: CreateMessageParams;
8
- }
9
-
10
- export interface IThreadService {
11
- getThreads(topicId: string): Promise<ThreadItem[]>;
12
-
13
- createThreadWithMessage({
14
- message,
15
- ...params
16
- }: CreateThreadWithMessageParams): Promise<{ messageId: string; threadId: string }>;
17
-
18
- updateThread(id: string, data: Partial<ThreadItem>): Promise<any>;
19
- //
20
- removeThread(id: string): Promise<any>;
21
- }
@@ -1,57 +0,0 @@
1
- import { INBOX_SESSION_ID } from '@/const/session';
2
- import { lambdaClient } from '@/libs/trpc/client';
3
- import { ITopicService } from '@/services/topic/type';
4
-
5
- export class ServerService implements ITopicService {
6
- createTopic: ITopicService['createTopic'] = (params) =>
7
- lambdaClient.topic.createTopic.mutate({
8
- ...params,
9
- sessionId: this.toDbSessionId(params.sessionId),
10
- });
11
-
12
- batchCreateTopics: ITopicService['batchCreateTopics'] = (importTopics) =>
13
- lambdaClient.topic.batchCreateTopics.mutate(importTopics);
14
-
15
- cloneTopic: ITopicService['cloneTopic'] = (id, newTitle) =>
16
- lambdaClient.topic.cloneTopic.mutate({ id, newTitle });
17
-
18
- getTopics: ITopicService['getTopics'] = (params) =>
19
- lambdaClient.topic.getTopics.query({
20
- ...params,
21
- containerId: this.toDbSessionId(params.containerId),
22
- }) as any;
23
-
24
- getAllTopics: ITopicService['getAllTopics'] = () =>
25
- lambdaClient.topic.getAllTopics.query() as any;
26
-
27
- countTopics: ITopicService['countTopics'] = async (params) => {
28
- return lambdaClient.topic.countTopics.query(params);
29
- };
30
-
31
- rankTopics: ITopicService['rankTopics'] = async (limit) => {
32
- return lambdaClient.topic.rankTopics.query(limit);
33
- };
34
-
35
- searchTopics: ITopicService['searchTopics'] = (keywords, sessionId) =>
36
- lambdaClient.topic.searchTopics.query({
37
- keywords,
38
- sessionId: this.toDbSessionId(sessionId),
39
- }) as any;
40
-
41
- updateTopic: ITopicService['updateTopic'] = (id, data) =>
42
- lambdaClient.topic.updateTopic.mutate({ id, value: data });
43
-
44
- removeTopic: ITopicService['removeTopic'] = (id) => lambdaClient.topic.removeTopic.mutate({ id });
45
-
46
- removeTopics: ITopicService['removeTopics'] = (sessionId) =>
47
- lambdaClient.topic.batchDeleteBySessionId.mutate({ id: this.toDbSessionId(sessionId) });
48
-
49
- batchRemoveTopics: ITopicService['batchRemoveTopics'] = (topics) =>
50
- lambdaClient.topic.batchDelete.mutate({ ids: topics });
51
-
52
- removeAllTopic: ITopicService['removeAllTopic'] = () =>
53
- lambdaClient.topic.removeAllTopics.mutate();
54
-
55
- private toDbSessionId = (sessionId?: string | null) =>
56
- sessionId === INBOX_SESSION_ID ? null : sessionId;
57
- }
@@ -1,40 +0,0 @@
1
- /* eslint-disable typescript-sort-keys/interface */
2
- import { BatchTaskResult } from '@/types/service';
3
- import { ChatTopic, TopicRankItem } from '@/types/topic';
4
-
5
- export interface CreateTopicParams {
6
- favorite?: boolean;
7
- groupId?: string | null;
8
- messages?: string[];
9
- sessionId?: string | null;
10
- title: string;
11
- }
12
-
13
- export interface QueryTopicParams {
14
- current?: number;
15
- containerId?: string | null; // sessionId or groupId
16
- pageSize?: number;
17
- }
18
-
19
- export interface ITopicService {
20
- createTopic(params: CreateTopicParams): Promise<string>;
21
- batchCreateTopics(importTopics: ChatTopic[]): Promise<BatchTaskResult>;
22
- cloneTopic(id: string, newTitle?: string): Promise<string>;
23
-
24
- getTopics(params: QueryTopicParams): Promise<ChatTopic[]>;
25
- getAllTopics(): Promise<ChatTopic[]>;
26
- countTopics(params?: {
27
- endDate?: string;
28
- range?: [string, string];
29
- startDate?: string;
30
- }): Promise<number>;
31
- rankTopics(limit?: number): Promise<TopicRankItem[]>;
32
- searchTopics(keyword: string, sessionId?: string, groupId?: string): Promise<ChatTopic[]>;
33
-
34
- updateTopic(id: string, data: Partial<ChatTopic>): Promise<any>;
35
-
36
- removeTopic(id: string): Promise<any>;
37
- removeTopics(sessionId: string): Promise<any>;
38
- batchRemoveTopics(topics: string[]): Promise<any>;
39
- removeAllTopic(): Promise<any>;
40
- }
@@ -1,149 +0,0 @@
1
- import type { PartialDeep } from 'type-fest';
2
- import { describe, expect, it, vi } from 'vitest';
3
-
4
- import { lambdaClient } from '@/libs/trpc/client';
5
- import { UserInitializationState, UserPreference } from '@/types/user';
6
- import { UserSettings } from '@/types/user/settings';
7
-
8
- import { ServerService } from './server';
9
-
10
- vi.mock('@/libs/trpc/client', () => ({
11
- lambdaClient: {
12
- user: {
13
- getUserRegistrationDuration: {
14
- query: vi.fn(),
15
- },
16
- getUserState: {
17
- query: vi.fn(),
18
- },
19
- getUserSSOProviders: {
20
- query: vi.fn(),
21
- },
22
- unlinkSSOProvider: {
23
- mutate: vi.fn(),
24
- },
25
- makeUserOnboarded: {
26
- mutate: vi.fn(),
27
- },
28
- updatePreference: {
29
- mutate: vi.fn(),
30
- },
31
- updateGuide: {
32
- mutate: vi.fn(),
33
- },
34
- updateSettings: {
35
- mutate: vi.fn(),
36
- },
37
- resetSettings: {
38
- mutate: vi.fn(),
39
- },
40
- },
41
- },
42
- }));
43
-
44
- describe('ServerService', () => {
45
- const service = new ServerService();
46
-
47
- it('should get user registration duration', async () => {
48
- const mockData = {
49
- createdAt: '2023-01-01',
50
- duration: 100,
51
- updatedAt: '2023-01-02',
52
- };
53
- vi.mocked(lambdaClient.user.getUserRegistrationDuration.query).mockResolvedValue(mockData);
54
-
55
- const result = await service.getUserRegistrationDuration();
56
- expect(result).toEqual(mockData);
57
- });
58
-
59
- it('should get user state', async () => {
60
- const mockState: UserInitializationState = {
61
- isOnboard: true,
62
- preference: {
63
- telemetry: true,
64
- },
65
- settings: {},
66
- };
67
- vi.mocked(lambdaClient.user.getUserState.query).mockResolvedValue(mockState);
68
-
69
- const result = await service.getUserState();
70
- expect(result).toEqual(mockState);
71
- });
72
-
73
- it('should get user SSO providers', async () => {
74
- const mockProviders = [
75
- {
76
- provider: 'google',
77
- providerAccountId: '123',
78
- userId: 'user1',
79
- type: 'oauth' as const,
80
- access_token: 'token',
81
- token_type: 'bearer' as const,
82
- expires_at: 123,
83
- scope: 'email profile',
84
- },
85
- ];
86
- vi.mocked(lambdaClient.user.getUserSSOProviders.query).mockResolvedValue(mockProviders);
87
-
88
- const result = await service.getUserSSOProviders();
89
- expect(result).toEqual(mockProviders);
90
- });
91
-
92
- it('should unlink SSO provider', async () => {
93
- const provider = 'google';
94
- const providerAccountId = '123';
95
- await service.unlinkSSOProvider(provider, providerAccountId);
96
-
97
- expect(lambdaClient.user.unlinkSSOProvider.mutate).toHaveBeenCalledWith({
98
- provider,
99
- providerAccountId,
100
- });
101
- });
102
-
103
- it('should make user onboarded', async () => {
104
- await service.makeUserOnboarded();
105
- expect(lambdaClient.user.makeUserOnboarded.mutate).toHaveBeenCalled();
106
- });
107
-
108
- it('should update user preference', async () => {
109
- const preference: Partial<UserPreference> = {
110
- telemetry: true,
111
- useCmdEnterToSend: true,
112
- };
113
- await service.updatePreference(preference);
114
- expect(lambdaClient.user.updatePreference.mutate).toHaveBeenCalledWith(preference);
115
- });
116
-
117
- it('should update user guide', async () => {
118
- const guide = {
119
- moveSettingsToAvatar: true,
120
- topic: false,
121
- uploadFileInKnowledgeBase: true,
122
- };
123
- await service.updateGuide(guide);
124
- expect(lambdaClient.user.updateGuide.mutate).toHaveBeenCalledWith(guide);
125
- });
126
-
127
- it('should update user settings', async () => {
128
- const settings: PartialDeep<UserSettings> = {
129
- defaultAgent: {
130
- config: {
131
- model: 'gpt-4',
132
- provider: 'openai',
133
- },
134
- meta: {
135
- avatar: 'avatar',
136
- description: 'test agent',
137
- },
138
- },
139
- };
140
- const signal = new AbortController().signal;
141
- await service.updateUserSettings(settings, signal);
142
- expect(lambdaClient.user.updateSettings.mutate).toHaveBeenCalledWith(settings, { signal });
143
- });
144
-
145
- it('should reset user settings', async () => {
146
- await service.resetUserSettings();
147
- expect(lambdaClient.user.resetSettings.mutate).toHaveBeenCalled();
148
- });
149
- });
@@ -1,47 +0,0 @@
1
- import { lambdaClient } from '@/libs/trpc/client';
2
- import { IUserService } from '@/services/user/type';
3
-
4
- export class ServerService implements IUserService {
5
- getUserRegistrationDuration: IUserService['getUserRegistrationDuration'] = async () => {
6
- return lambdaClient.user.getUserRegistrationDuration.query();
7
- };
8
-
9
- getUserState: IUserService['getUserState'] = async () => {
10
- return lambdaClient.user.getUserState.query();
11
- };
12
-
13
- getUserSSOProviders: IUserService['getUserSSOProviders'] = async () => {
14
- return lambdaClient.user.getUserSSOProviders.query();
15
- };
16
-
17
- unlinkSSOProvider: IUserService['unlinkSSOProvider'] = async (
18
- provider: string,
19
- providerAccountId: string,
20
- ) => {
21
- return lambdaClient.user.unlinkSSOProvider.mutate({ provider, providerAccountId });
22
- };
23
-
24
- makeUserOnboarded = async () => {
25
- return lambdaClient.user.makeUserOnboarded.mutate();
26
- };
27
-
28
- updateAvatar: IUserService['updateAvatar'] = async (avatar) => {
29
- return lambdaClient.user.updateAvatar.mutate(avatar);
30
- };
31
-
32
- updatePreference: IUserService['updatePreference'] = async (preference) => {
33
- return lambdaClient.user.updatePreference.mutate(preference);
34
- };
35
-
36
- updateGuide: IUserService['updateGuide'] = async (guide) => {
37
- return lambdaClient.user.updateGuide.mutate(guide);
38
- };
39
-
40
- updateUserSettings: IUserService['updateUserSettings'] = async (value, signal) => {
41
- return lambdaClient.user.updateSettings.mutate(value, { signal });
42
- };
43
-
44
- resetUserSettings: IUserService['resetUserSettings'] = async () => {
45
- return lambdaClient.user.resetSettings.mutate();
46
- };
47
- }
@@ -1,21 +0,0 @@
1
- import type { AdapterAccount } from 'next-auth/adapters';
2
- import type { PartialDeep } from 'type-fest';
3
-
4
- import { UserGuide, UserInitializationState, UserPreference } from '@/types/user';
5
- import { UserSettings } from '@/types/user/settings';
6
-
7
- export interface IUserService {
8
- getUserRegistrationDuration: () => Promise<{
9
- createdAt: string;
10
- duration: number;
11
- updatedAt: string;
12
- }>;
13
- getUserSSOProviders: () => Promise<AdapterAccount[]>;
14
- getUserState: () => Promise<UserInitializationState>;
15
- resetUserSettings: () => Promise<any>;
16
- unlinkSSOProvider: (provider: string, providerAccountId: string) => Promise<any>;
17
- updateAvatar: (avatar: string) => Promise<any>;
18
- updateGuide: (guide: Partial<UserGuide>) => Promise<any>;
19
- updatePreference: (preference: Partial<UserPreference>) => Promise<any>;
20
- updateUserSettings: (value: PartialDeep<UserSettings>, signal?: AbortSignal) => Promise<any>;
21
- }