@lobehub/lobehub 2.0.0-next.25 → 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 (73) hide show
  1. package/CHANGELOG.md +50 -0
  2. package/changelog/v1.json +18 -0
  3. package/docs/development/database-schema.dbml +1 -0
  4. package/e2e/src/features/discover/detail-pages.feature +95 -0
  5. package/e2e/src/features/discover/interactions.feature +113 -0
  6. package/e2e/src/steps/discover/detail-pages.steps.ts +295 -0
  7. package/e2e/src/steps/discover/interactions.steps.ts +451 -0
  8. package/package.json +1 -1
  9. package/packages/database/migrations/0043_add_ai_model_settings.sql +1 -0
  10. package/packages/database/migrations/meta/0043_snapshot.json +8419 -0
  11. package/packages/database/migrations/meta/_journal.json +7 -0
  12. package/packages/database/src/core/migrations.json +10 -2
  13. package/packages/database/src/repositories/aiInfra/index.test.ts +198 -0
  14. package/packages/database/src/repositories/aiInfra/index.ts +2 -1
  15. package/packages/database/src/schemas/aiInfra.ts +2 -0
  16. package/packages/types/src/topic/topic.ts +14 -0
  17. package/src/server/routers/lambda/topic.ts +7 -1
  18. package/src/services/aiModel/index.test.ts +3 -3
  19. package/src/services/aiModel/index.ts +56 -2
  20. package/src/services/aiProvider/index.test.ts +2 -2
  21. package/src/services/aiProvider/index.ts +48 -2
  22. package/src/services/chatGroup/index.ts +66 -2
  23. package/src/services/export/index.ts +10 -2
  24. package/src/services/file/index.ts +61 -2
  25. package/src/services/import/index.ts +133 -2
  26. package/src/services/message/index.ts +176 -2
  27. package/src/services/message/{__tests__/server.test.ts → server.test.ts} +3 -3
  28. package/src/services/plugin/index.test.ts +8 -0
  29. package/src/services/plugin/index.ts +53 -2
  30. package/src/services/session/index.test.ts +8 -0
  31. package/src/services/session/index.ts +145 -2
  32. package/src/services/thread/index.test.ts +8 -0
  33. package/src/services/thread/index.ts +38 -2
  34. package/src/services/topic/index.test.ts +8 -0
  35. package/src/services/topic/index.ts +76 -2
  36. package/src/services/user/index.test.ts +8 -0
  37. package/src/services/user/index.ts +53 -2
  38. package/src/store/aiInfra/slices/aiModel/action.test.ts +17 -9
  39. package/src/store/chat/slices/aiChat/actions/__tests__/helpers.ts +4 -2
  40. package/src/store/chat/slices/topic/action.test.ts +1 -1
  41. package/src/store/chat/slices/topic/action.ts +1 -2
  42. package/src/store/chat/slices/topic/reducer.ts +1 -2
  43. package/src/store/file/slices/chat/action.ts +1 -4
  44. package/src/store/file/slices/fileManager/action.ts +2 -3
  45. package/src/store/session/slices/sessionGroup/action.test.ts +5 -5
  46. package/src/store/user/slices/common/action.test.ts +1 -1
  47. package/src/services/aiModel/server.test.ts +0 -122
  48. package/src/services/aiModel/server.ts +0 -51
  49. package/src/services/aiModel/type.ts +0 -32
  50. package/src/services/aiProvider/server.ts +0 -43
  51. package/src/services/aiProvider/type.ts +0 -27
  52. package/src/services/chatGroup/server.ts +0 -67
  53. package/src/services/chatGroup/type.ts +0 -22
  54. package/src/services/export/server.ts +0 -9
  55. package/src/services/export/type.ts +0 -5
  56. package/src/services/file/server.ts +0 -53
  57. package/src/services/file/type.ts +0 -13
  58. package/src/services/import/server.ts +0 -133
  59. package/src/services/import/type.ts +0 -17
  60. package/src/services/message/server.ts +0 -151
  61. package/src/services/message/type.ts +0 -55
  62. package/src/services/plugin/server.ts +0 -42
  63. package/src/services/plugin/type.ts +0 -23
  64. package/src/services/session/server.test.ts +0 -260
  65. package/src/services/session/server.ts +0 -125
  66. package/src/services/session/type.ts +0 -82
  67. package/src/services/thread/server.ts +0 -32
  68. package/src/services/thread/type.ts +0 -21
  69. package/src/services/topic/server.ts +0 -57
  70. package/src/services/topic/type.ts +0 -40
  71. package/src/services/user/server.test.ts +0 -149
  72. package/src/services/user/server.ts +0 -47
  73. package/src/services/user/type.ts +0 -21
@@ -1,260 +0,0 @@
1
- import { beforeEach, describe, expect, it, vi } from 'vitest';
2
-
3
- import { lambdaClient } from '@/libs/trpc/client';
4
- import { LobeSessionType } from '@/types/session';
5
-
6
- import { ServerService } from './server';
7
-
8
- vi.mock('@/libs/trpc/client', () => ({
9
- lambdaClient: {
10
- session: {
11
- createSession: { mutate: vi.fn() },
12
- batchCreateSessions: { mutate: vi.fn() },
13
- cloneSession: { mutate: vi.fn() },
14
- getGroupedSessions: { query: vi.fn() },
15
- countSessions: { query: vi.fn() },
16
- rankSessions: { query: vi.fn() },
17
- updateSession: { mutate: vi.fn() },
18
- updateSessionConfig: { mutate: vi.fn() },
19
- updateSessionChatConfig: { mutate: vi.fn() },
20
- getSessions: { query: vi.fn() },
21
- searchSessions: { query: vi.fn() },
22
- removeSession: { mutate: vi.fn() },
23
- removeAllSessions: { mutate: vi.fn() },
24
- },
25
- agent: {
26
- getAgentConfig: { query: vi.fn() },
27
- },
28
- sessionGroup: {
29
- createSessionGroup: { mutate: vi.fn() },
30
- getSessionGroup: { query: vi.fn() },
31
- removeSessionGroup: { mutate: vi.fn() },
32
- removeAllSessionGroups: { mutate: vi.fn() },
33
- updateSessionGroup: { mutate: vi.fn() },
34
- updateSessionGroupOrder: { mutate: vi.fn() },
35
- },
36
- },
37
- }));
38
-
39
- describe('ServerService', () => {
40
- let service: ServerService;
41
-
42
- beforeEach(() => {
43
- vi.clearAllMocks();
44
- service = new ServerService();
45
- });
46
-
47
- it('hasSessions should return true if count is 0', async () => {
48
- vi.mocked(lambdaClient.session.countSessions.query).mockResolvedValue(0);
49
- const result = await service.hasSessions();
50
- expect(result).toBe(true);
51
- });
52
-
53
- it('createSession should call lambdaClient with correct params', async () => {
54
- const mockData = {
55
- config: {
56
- model: 'gpt-3.5',
57
- params: {},
58
- systemRole: '',
59
- chatConfig: {
60
- autoCreateTopicThreshold: 2,
61
- compressThreshold: 10,
62
- enableAutoCreateTopic: true,
63
- enableCompressThreshold: true,
64
- maxTokens: 2000,
65
- model: 'gpt-3.5-turbo',
66
- params: {},
67
- temperature: 0.7,
68
- title: 'test',
69
- },
70
- tts: {
71
- showAllLocaleVoice: false,
72
- sttLocale: 'auto',
73
- ttsService: 'openai' as const,
74
- voice: {
75
- model: 'tts-1',
76
- name: 'alloy',
77
- type: 'tts',
78
- openai: 'voice-id',
79
- },
80
- },
81
- openingQuestions: ['Question 1', 'Question 2'],
82
- openingMessage: 'Hello, I am [LobeChat](https://github.com/lobehub/lobe-chat).',
83
- },
84
- group: 'testGroup',
85
- meta: { description: 'test' },
86
- title: 'Test Session',
87
- };
88
-
89
- await service.createSession(LobeSessionType.Agent, mockData);
90
-
91
- expect(lambdaClient.session.createSession.mutate).toBeCalledWith({
92
- config: { ...mockData.config, description: 'test' },
93
- session: { title: 'Test Session', groupId: 'testGroup' },
94
- type: LobeSessionType.Agent,
95
- });
96
- });
97
-
98
- it('batchCreateSessions should call lambdaClient', async () => {
99
- const mockSessions = [
100
- {
101
- id: '1',
102
- title: 'Test',
103
- config: {
104
- model: 'gpt-3.5',
105
- params: {},
106
- systemRole: '',
107
- chatConfig: {
108
- autoCreateTopicThreshold: 2,
109
- compressThreshold: 10,
110
- enableAutoCreateTopic: true,
111
- enableCompressThreshold: true,
112
- maxTokens: 2000,
113
- model: 'gpt-3.5-turbo',
114
- params: {},
115
- temperature: 0.7,
116
- title: 'test',
117
- },
118
- tts: {
119
- showAllLocaleVoice: false,
120
- sttLocale: 'auto',
121
- ttsService: 'openai' as const,
122
- voice: {
123
- model: 'tts-1',
124
- name: 'alloy',
125
- type: 'tts',
126
- openai: 'voice-id',
127
- },
128
- },
129
- },
130
- createdAt: new Date(),
131
- meta: { description: 'test' },
132
- model: 'gpt-3.5',
133
- type: LobeSessionType.Agent,
134
- updatedAt: new Date(),
135
- },
136
- ];
137
-
138
- await service.batchCreateSessions(mockSessions as any);
139
- expect(lambdaClient.session.batchCreateSessions.mutate).toBeCalledWith(mockSessions);
140
- });
141
-
142
- it('cloneSession should call lambdaClient', async () => {
143
- await service.cloneSession('123', 'New Title');
144
- expect(lambdaClient.session.cloneSession.mutate).toBeCalledWith({
145
- id: '123',
146
- newTitle: 'New Title',
147
- });
148
- });
149
-
150
- it('getGroupedSessions should call lambdaClient', async () => {
151
- await service.getGroupedSessions();
152
- expect(lambdaClient.session.getGroupedSessions.query).toBeCalled();
153
- });
154
-
155
- it('countSessions should call lambdaClient with params', async () => {
156
- const params = { startDate: '2023-01-01' };
157
- await service.countSessions(params);
158
- expect(lambdaClient.session.countSessions.query).toBeCalledWith(params);
159
- });
160
-
161
- it('rankSessions should call lambdaClient with limit', async () => {
162
- await service.rankSessions(10);
163
- expect(lambdaClient.session.rankSessions.query).toBeCalledWith(10);
164
- });
165
-
166
- it('updateSession should call lambdaClient with correct params', async () => {
167
- const mockData = {
168
- group: 'default',
169
- pinned: true,
170
- meta: { description: 'bar' },
171
- updatedAt: new Date(),
172
- };
173
-
174
- await service.updateSession('123', mockData);
175
-
176
- expect(lambdaClient.session.updateSession.mutate).toBeCalledWith({
177
- id: '123',
178
- value: {
179
- groupId: null,
180
- pinned: true,
181
- description: 'bar',
182
- updatedAt: mockData.updatedAt,
183
- },
184
- });
185
- });
186
-
187
- it('getSessionConfig should call lambdaClient', async () => {
188
- await service.getSessionConfig('123');
189
- expect(lambdaClient.agent.getAgentConfig.query).toBeCalledWith({ sessionId: '123' });
190
- });
191
-
192
- it('updateSessionConfig should call lambdaClient', async () => {
193
- const config = { model: 'gpt-4' };
194
- const signal = new AbortController().signal;
195
- await service.updateSessionConfig('123', config, signal);
196
- expect(lambdaClient.session.updateSessionConfig.mutate).toBeCalledWith(
197
- { id: '123', value: config },
198
- {
199
- signal,
200
- context: { showNotification: false },
201
- },
202
- );
203
- });
204
-
205
- it('getSessionsByType should call lambdaClient', async () => {
206
- await service.getSessionsByType('all');
207
- expect(lambdaClient.session.getSessions.query).toBeCalledWith({});
208
- });
209
-
210
- it('searchSessions should call lambdaClient with keywords', async () => {
211
- await service.searchSessions('test');
212
- expect(lambdaClient.session.searchSessions.query).toBeCalledWith({ keywords: 'test' });
213
- });
214
-
215
- it('removeSession should call lambdaClient', async () => {
216
- await service.removeSession('123');
217
- expect(lambdaClient.session.removeSession.mutate).toBeCalledWith({ id: '123' });
218
- });
219
-
220
- it('removeAllSessions should call lambdaClient', async () => {
221
- await service.removeAllSessions();
222
- expect(lambdaClient.session.removeAllSessions.mutate).toBeCalled();
223
- });
224
-
225
- it('createSessionGroup should call lambdaClient', async () => {
226
- await service.createSessionGroup('Test Group', 1);
227
- expect(lambdaClient.sessionGroup.createSessionGroup.mutate).toBeCalledWith({
228
- name: 'Test Group',
229
- sort: 1,
230
- });
231
- });
232
-
233
- it('getSessionGroups should call lambdaClient', async () => {
234
- await service.getSessionGroups();
235
- expect(lambdaClient.sessionGroup.getSessionGroup.query).toBeCalled();
236
- });
237
-
238
- it('removeSessionGroup should call lambdaClient', async () => {
239
- await service.removeSessionGroup('123', true);
240
- expect(lambdaClient.sessionGroup.removeSessionGroup.mutate).toBeCalledWith({
241
- id: '123',
242
- removeChildren: true,
243
- });
244
- });
245
-
246
- it('updateSessionGroup should call lambdaClient', async () => {
247
- const value = { name: 'Updated Group' };
248
- await service.updateSessionGroup('123', value);
249
- expect(lambdaClient.sessionGroup.updateSessionGroup.mutate).toBeCalledWith({
250
- id: '123',
251
- value,
252
- });
253
- });
254
-
255
- it('updateSessionGroupOrder should call lambdaClient', async () => {
256
- const sortMap = [{ id: '123', sort: 1 }];
257
- await service.updateSessionGroupOrder(sortMap);
258
- expect(lambdaClient.sessionGroup.updateSessionGroupOrder.mutate).toBeCalledWith({ sortMap });
259
- });
260
- });
@@ -1,125 +0,0 @@
1
- /* eslint-disable @typescript-eslint/no-unused-vars */
2
- import { lambdaClient } from '@/libs/trpc/client';
3
-
4
- import { ISessionService } from './type';
5
-
6
- export class ServerService implements ISessionService {
7
- hasSessions: ISessionService['hasSessions'] = async () => {
8
- const result = await this.countSessions();
9
- return result === 0;
10
- };
11
-
12
- createSession: ISessionService['createSession'] = async (type, data) => {
13
- const { config, group, meta, ...session } = data;
14
- return lambdaClient.session.createSession.mutate({
15
- config: { ...config, ...meta } as any,
16
- session: { ...session, groupId: group },
17
- type,
18
- });
19
- };
20
-
21
- batchCreateSessions: ISessionService['batchCreateSessions'] = async (importSessions) => {
22
- // TODO: remove any
23
- const data = await lambdaClient.session.batchCreateSessions.mutate(importSessions as any);
24
- console.log(data);
25
- return data;
26
- };
27
-
28
- cloneSession: ISessionService['cloneSession'] = (id, newTitle) => {
29
- return lambdaClient.session.cloneSession.mutate({ id, newTitle });
30
- };
31
-
32
- getGroupedSessions: ISessionService['getGroupedSessions'] = () => {
33
- return lambdaClient.session.getGroupedSessions.query();
34
- };
35
-
36
- countSessions: ISessionService['countSessions'] = async (params) => {
37
- return lambdaClient.session.countSessions.query(params);
38
- };
39
-
40
- rankSessions: ISessionService['rankSessions'] = async (limit) => {
41
- return lambdaClient.session.rankSessions.query(limit);
42
- };
43
-
44
- updateSession: ISessionService['updateSession'] = (id, data) => {
45
- const { group, pinned, meta, updatedAt } = data;
46
- return lambdaClient.session.updateSession.mutate({
47
- id,
48
- value: { groupId: group === 'default' ? null : group, pinned, ...meta, updatedAt },
49
- });
50
- };
51
-
52
- // TODO: Need to be fixed
53
- // @ts-ignore
54
- getSessionConfig: ISessionService['getSessionConfig'] = async (id) => {
55
- return lambdaClient.agent.getAgentConfig.query({ sessionId: id });
56
- };
57
-
58
- updateSessionConfig: ISessionService['updateSessionConfig'] = (id, config, signal) => {
59
- return lambdaClient.session.updateSessionConfig.mutate(
60
- { id, value: config },
61
- {
62
- context: { showNotification: false },
63
- signal,
64
- },
65
- );
66
- };
67
-
68
- updateSessionMeta: ISessionService['updateSessionMeta'] = (id, meta, signal) => {
69
- return lambdaClient.session.updateSessionConfig.mutate({ id, value: meta }, { signal });
70
- };
71
-
72
- updateSessionChatConfig: ISessionService['updateSessionChatConfig'] = (id, value, signal) => {
73
- return lambdaClient.session.updateSessionChatConfig.mutate({ id, value }, { signal });
74
- };
75
-
76
- // TODO: need be fixed
77
- // @ts-ignore
78
- getSessionsByType: ISessionService['getSessionsByType'] = (_type = 'all') => {
79
- return lambdaClient.session.getSessions.query({});
80
- };
81
-
82
- searchSessions: ISessionService['searchSessions'] = (keywords) => {
83
- return lambdaClient.session.searchSessions.query({ keywords });
84
- };
85
-
86
- removeSession: ISessionService['removeSession'] = (id) => {
87
- return lambdaClient.session.removeSession.mutate({ id });
88
- };
89
-
90
- removeAllSessions: ISessionService['removeAllSessions'] = () => {
91
- return lambdaClient.session.removeAllSessions.mutate();
92
- };
93
-
94
- // ************************************** //
95
- // *********** SessionGroup *********** //
96
- // ************************************** //
97
-
98
- createSessionGroup: ISessionService['createSessionGroup'] = (name, sort) => {
99
- return lambdaClient.sessionGroup.createSessionGroup.mutate({ name, sort });
100
- };
101
-
102
- getSessionGroups: ISessionService['getSessionGroups'] = () => {
103
- return lambdaClient.sessionGroup.getSessionGroup.query();
104
- };
105
-
106
- batchCreateSessionGroups: ISessionService['batchCreateSessionGroups'] = (_groups) => {
107
- return Promise.resolve({ added: 0, ids: [], skips: [], success: true });
108
- };
109
-
110
- removeSessionGroup: ISessionService['removeSessionGroup'] = (id, removeChildren) => {
111
- return lambdaClient.sessionGroup.removeSessionGroup.mutate({ id, removeChildren });
112
- };
113
-
114
- removeSessionGroups: ISessionService['removeSessionGroups'] = () => {
115
- return lambdaClient.sessionGroup.removeAllSessionGroups.mutate();
116
- };
117
-
118
- updateSessionGroup: ISessionService['updateSessionGroup'] = (id, value) => {
119
- return lambdaClient.sessionGroup.updateSessionGroup.mutate({ id, value });
120
- };
121
-
122
- updateSessionGroupOrder: ISessionService['updateSessionGroupOrder'] = (sortMap) => {
123
- return lambdaClient.sessionGroup.updateSessionGroupOrder.mutate({ sortMap });
124
- };
125
- }
@@ -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
- }