@lobehub/lobehub 2.0.0-next.26 → 2.0.0-next.28
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/package.json +1 -1
- package/packages/types/src/discover/mcp.ts +6 -0
- package/packages/types/src/plugins/mcp.ts +4 -1
- package/packages/types/src/topic/topic.ts +14 -0
- package/renovate.json +4 -30
- package/src/features/MCP/utils.test.ts +91 -0
- package/src/features/MCP/utils.ts +20 -2
- package/src/features/PluginStore/Content.tsx +2 -3
- package/src/features/PluginStore/McpList/index.tsx +6 -2
- package/src/server/routers/lambda/market/index.ts +4 -2
- 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/mcp.ts +40 -6
- 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/tool/slices/mcpStore/action.test.ts +95 -3
- package/src/store/tool/slices/mcpStore/action.ts +177 -53
- package/src/store/tool/slices/oldStore/initialState.ts +1 -2
- 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,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
|
-
}
|