@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.
- package/CHANGELOG.md +50 -0
- package/changelog/v1.json +18 -0
- package/docs/development/database-schema.dbml +1 -0
- package/e2e/src/features/discover/detail-pages.feature +95 -0
- package/e2e/src/features/discover/interactions.feature +113 -0
- package/e2e/src/steps/discover/detail-pages.steps.ts +295 -0
- package/e2e/src/steps/discover/interactions.steps.ts +451 -0
- package/package.json +1 -1
- package/packages/database/migrations/0043_add_ai_model_settings.sql +1 -0
- package/packages/database/migrations/meta/0043_snapshot.json +8419 -0
- package/packages/database/migrations/meta/_journal.json +7 -0
- package/packages/database/src/core/migrations.json +10 -2
- package/packages/database/src/repositories/aiInfra/index.test.ts +198 -0
- package/packages/database/src/repositories/aiInfra/index.ts +2 -1
- package/packages/database/src/schemas/aiInfra.ts +2 -0
- package/packages/types/src/topic/topic.ts +14 -0
- package/src/server/routers/lambda/topic.ts +7 -1
- package/src/services/aiModel/index.test.ts +3 -3
- package/src/services/aiModel/index.ts +56 -2
- package/src/services/aiProvider/index.test.ts +2 -2
- package/src/services/aiProvider/index.ts +48 -2
- package/src/services/chatGroup/index.ts +66 -2
- package/src/services/export/index.ts +10 -2
- package/src/services/file/index.ts +61 -2
- package/src/services/import/index.ts +133 -2
- package/src/services/message/index.ts +176 -2
- package/src/services/message/{__tests__/server.test.ts → server.test.ts} +3 -3
- package/src/services/plugin/index.test.ts +8 -0
- package/src/services/plugin/index.ts +53 -2
- package/src/services/session/index.test.ts +8 -0
- package/src/services/session/index.ts +145 -2
- package/src/services/thread/index.test.ts +8 -0
- package/src/services/thread/index.ts +38 -2
- package/src/services/topic/index.test.ts +8 -0
- package/src/services/topic/index.ts +76 -2
- package/src/services/user/index.test.ts +8 -0
- package/src/services/user/index.ts +53 -2
- package/src/store/aiInfra/slices/aiModel/action.test.ts +17 -9
- package/src/store/chat/slices/aiChat/actions/__tests__/helpers.ts +4 -2
- package/src/store/chat/slices/topic/action.test.ts +1 -1
- package/src/store/chat/slices/topic/action.ts +1 -2
- package/src/store/chat/slices/topic/reducer.ts +1 -2
- package/src/store/file/slices/chat/action.ts +1 -4
- package/src/store/file/slices/fileManager/action.ts +2 -3
- package/src/store/session/slices/sessionGroup/action.test.ts +5 -5
- package/src/store/user/slices/common/action.test.ts +1 -1
- package/src/services/aiModel/server.test.ts +0 -122
- package/src/services/aiModel/server.ts +0 -51
- package/src/services/aiModel/type.ts +0 -32
- package/src/services/aiProvider/server.ts +0 -43
- package/src/services/aiProvider/type.ts +0 -27
- package/src/services/chatGroup/server.ts +0 -67
- package/src/services/chatGroup/type.ts +0 -22
- package/src/services/export/server.ts +0 -9
- package/src/services/export/type.ts +0 -5
- package/src/services/file/server.ts +0 -53
- package/src/services/file/type.ts +0 -13
- package/src/services/import/server.ts +0 -133
- package/src/services/import/type.ts +0 -17
- package/src/services/message/server.ts +0 -151
- package/src/services/message/type.ts +0 -55
- package/src/services/plugin/server.ts +0 -42
- package/src/services/plugin/type.ts +0 -23
- package/src/services/session/server.test.ts +0 -260
- package/src/services/session/server.ts +0 -125
- package/src/services/session/type.ts +0 -82
- package/src/services/thread/server.ts +0 -32
- package/src/services/thread/type.ts +0 -21
- package/src/services/topic/server.ts +0 -57
- package/src/services/topic/type.ts +0 -40
- package/src/services/user/server.test.ts +0 -149
- package/src/services/user/server.ts +0 -47
- 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
|
-
}
|