@lobehub/chat 1.62.11 → 1.63.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/CHANGELOG.md +66 -0
- package/changelog/v1.json +24 -0
- package/locales/ar/chat.json +26 -0
- package/locales/ar/models.json +21 -0
- package/locales/bg-BG/chat.json +26 -0
- package/locales/bg-BG/models.json +21 -0
- package/locales/de-DE/chat.json +26 -0
- package/locales/de-DE/models.json +21 -0
- package/locales/en-US/chat.json +26 -0
- package/locales/en-US/models.json +21 -0
- package/locales/es-ES/chat.json +26 -0
- package/locales/es-ES/models.json +21 -0
- package/locales/fa-IR/chat.json +26 -0
- package/locales/fa-IR/models.json +21 -0
- package/locales/fr-FR/chat.json +26 -0
- package/locales/fr-FR/models.json +21 -0
- package/locales/it-IT/chat.json +26 -0
- package/locales/it-IT/models.json +21 -0
- package/locales/ja-JP/chat.json +26 -0
- package/locales/ja-JP/models.json +21 -0
- package/locales/ko-KR/chat.json +26 -0
- package/locales/ko-KR/models.json +21 -0
- package/locales/nl-NL/chat.json +26 -0
- package/locales/nl-NL/models.json +21 -0
- package/locales/pl-PL/chat.json +26 -0
- package/locales/pl-PL/models.json +21 -0
- package/locales/pt-BR/chat.json +26 -0
- package/locales/pt-BR/models.json +21 -0
- package/locales/ru-RU/chat.json +26 -0
- package/locales/ru-RU/models.json +21 -0
- package/locales/tr-TR/chat.json +26 -0
- package/locales/tr-TR/models.json +21 -0
- package/locales/vi-VN/chat.json +26 -0
- package/locales/vi-VN/models.json +21 -0
- package/locales/zh-CN/chat.json +27 -1
- package/locales/zh-CN/models.json +25 -4
- package/locales/zh-TW/chat.json +26 -0
- package/locales/zh-TW/models.json +21 -0
- package/package.json +2 -2
- package/src/app/(backend)/webapi/chat/groq/route.test.ts +29 -0
- package/src/app/(backend)/webapi/chat/groq/route.ts +21 -0
- package/src/app/[variants]/(main)/chat/(workspace)/@conversation/features/ChatInput/Desktop/index.tsx +1 -0
- package/src/config/aiModels/google.ts +8 -0
- package/src/config/aiModels/groq.ts +111 -95
- package/src/config/aiModels/hunyuan.ts +36 -4
- package/src/config/aiModels/internlm.ts +4 -5
- package/src/config/aiModels/jina.ts +3 -0
- package/src/config/aiModels/mistral.ts +35 -21
- package/src/config/aiModels/novita.ts +293 -32
- package/src/config/aiModels/perplexity.ts +14 -2
- package/src/config/aiModels/qwen.ts +91 -37
- package/src/config/aiModels/sensenova.ts +70 -17
- package/src/config/aiModels/siliconcloud.ts +5 -3
- package/src/config/aiModels/stepfun.ts +19 -0
- package/src/config/aiModels/taichu.ts +4 -2
- package/src/config/aiModels/upstage.ts +24 -11
- package/src/config/modelProviders/openrouter.ts +1 -0
- package/src/config/modelProviders/qwen.ts +2 -1
- package/src/const/settings/agent.ts +1 -0
- package/src/database/repositories/aiInfra/index.test.ts +2 -5
- package/src/database/repositories/aiInfra/index.ts +6 -2
- package/src/database/schemas/message.ts +2 -1
- package/src/database/server/models/aiModel.ts +1 -1
- package/src/database/server/models/aiProvider.ts +6 -1
- package/src/features/ChatInput/ActionBar/Model/ControlsForm.tsx +38 -0
- package/src/features/ChatInput/ActionBar/Model/ExtendControls.tsx +40 -0
- package/src/features/ChatInput/ActionBar/Model/index.tsx +132 -0
- package/src/features/ChatInput/ActionBar/Params/index.tsx +2 -2
- package/src/features/ChatInput/ActionBar/Search/ExaIcon.tsx +15 -0
- package/src/features/ChatInput/ActionBar/Search/ModelBuiltinSearch.tsx +68 -0
- package/src/features/ChatInput/ActionBar/Search/SwitchPanel.tsx +167 -0
- package/src/features/ChatInput/ActionBar/Search/index.tsx +74 -0
- package/src/features/ChatInput/ActionBar/config.ts +4 -2
- package/src/features/Conversation/Error/index.tsx +1 -6
- package/src/features/Conversation/Messages/Assistant/SearchGrounding.tsx +153 -0
- package/src/features/Conversation/Messages/Assistant/Tool/Inspector/Debug.tsx +9 -6
- package/src/features/Conversation/Messages/Assistant/Tool/Inspector/PluginResultJSON.tsx +14 -9
- package/src/features/Conversation/Messages/Assistant/Tool/Inspector/Settings.tsx +1 -0
- package/src/features/Conversation/Messages/Assistant/Tool/Inspector/index.tsx +2 -1
- package/src/features/Conversation/Messages/Assistant/Tool/Render/CustomRender.tsx +4 -2
- package/src/features/Conversation/Messages/Assistant/Tool/Render/ErrorResponse.tsx +36 -0
- package/src/features/Conversation/{Error → Messages/Assistant/Tool/Render}/PluginSettings.tsx +1 -1
- package/src/features/Conversation/Messages/Assistant/Tool/Render/index.tsx +7 -1
- package/src/features/Conversation/Messages/Assistant/index.tsx +7 -1
- package/src/features/ModelSelect/index.tsx +1 -1
- package/src/features/ModelSwitchPanel/index.tsx +2 -3
- package/src/hooks/useEnabledChatModels.ts +1 -1
- package/src/libs/agent-runtime/google/index.test.ts +142 -36
- package/src/libs/agent-runtime/google/index.ts +26 -51
- package/src/libs/agent-runtime/novita/__snapshots__/index.test.ts.snap +3 -3
- package/src/libs/agent-runtime/openrouter/__snapshots__/index.test.ts.snap +3 -3
- package/src/libs/agent-runtime/openrouter/index.ts +20 -20
- package/src/libs/agent-runtime/perplexity/index.test.ts +2 -2
- package/src/libs/agent-runtime/qwen/index.ts +38 -55
- package/src/libs/agent-runtime/types/chat.ts +6 -2
- package/src/libs/agent-runtime/utils/streams/google-ai.ts +29 -4
- package/src/libs/agent-runtime/utils/streams/openai.ts +1 -1
- package/src/libs/agent-runtime/utils/streams/protocol.ts +1 -1
- package/src/locales/default/chat.ts +28 -0
- package/src/services/chat.ts +10 -0
- package/src/services/session/_deprecated.ts +2 -1
- package/src/store/agent/slices/chat/__snapshots__/selectors.test.ts.snap +1 -0
- package/src/store/agent/slices/chat/selectors.ts +6 -0
- package/src/store/aiInfra/slices/aiModel/selectors.ts +36 -0
- package/src/store/aiInfra/slices/aiProvider/initialState.ts +2 -2
- package/src/store/aiInfra/slices/aiProvider/selectors.ts +14 -0
- package/src/store/chat/slices/aiChat/actions/generateAIChat.ts +15 -5
- package/src/store/chat/slices/message/action.ts +1 -1
- package/src/store/user/slices/modelList/selectors/modelProvider.ts +1 -1
- package/src/store/user/slices/settings/selectors/__snapshots__/settings.test.ts.snap +1 -0
- package/src/types/agent/index.ts +4 -0
- package/src/types/aiModel.ts +35 -8
- package/src/types/aiProvider.ts +7 -10
- package/src/types/message/base.ts +2 -5
- package/src/types/message/chat.ts +5 -3
- package/src/types/openai/chat.ts +5 -0
- package/src/types/search.ts +29 -0
- package/src/utils/fetch/fetchSSE.ts +11 -11
- package/src/features/ChatInput/ActionBar/ModelSwitch.tsx +0 -20
@@ -38,6 +38,10 @@ export interface OpenAIChatMessage {
|
|
38
38
|
* @title Chat Stream Payload
|
39
39
|
*/
|
40
40
|
export interface ChatStreamPayload {
|
41
|
+
/**
|
42
|
+
* 是否开启搜索
|
43
|
+
*/
|
44
|
+
enabledSearch?: boolean;
|
41
45
|
/**
|
42
46
|
* @title 控制生成文本中的惩罚系数,用于减少重复性
|
43
47
|
* @default 0
|
@@ -68,11 +72,11 @@ export interface ChatStreamPayload {
|
|
68
72
|
* @default 0
|
69
73
|
*/
|
70
74
|
presence_penalty?: number;
|
75
|
+
|
71
76
|
/**
|
72
77
|
* @default openai
|
73
78
|
*/
|
74
79
|
provider?: string;
|
75
|
-
|
76
80
|
responseMode?: 'streamText' | 'json';
|
77
81
|
/**
|
78
82
|
* @title 是否开启流式请求
|
@@ -85,8 +89,8 @@ export interface ChatStreamPayload {
|
|
85
89
|
*/
|
86
90
|
temperature: number;
|
87
91
|
tool_choice?: string;
|
88
|
-
tools?: ChatCompletionTool[];
|
89
92
|
|
93
|
+
tools?: ChatCompletionTool[];
|
90
94
|
/**
|
91
95
|
* @title 控制生成文本中最高概率的单个令牌
|
92
96
|
* @default 1
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import { EnhancedGenerateContentResponse } from '@google/generative-ai';
|
2
2
|
|
3
|
+
import { GroundingSearch } from '@/types/search';
|
3
4
|
import { nanoid } from '@/utils/uuid';
|
4
5
|
|
5
6
|
import { ChatStreamCallbacks } from '../../types';
|
@@ -14,8 +15,8 @@ import {
|
|
14
15
|
|
15
16
|
const transformGoogleGenerativeAIStream = (
|
16
17
|
chunk: EnhancedGenerateContentResponse,
|
17
|
-
|
18
|
-
): StreamProtocolChunk => {
|
18
|
+
context: StreamContext,
|
19
|
+
): StreamProtocolChunk | StreamProtocolChunk[] => {
|
19
20
|
// maybe need another structure to add support for multiple choices
|
20
21
|
const functionCalls = chunk.functionCalls();
|
21
22
|
|
@@ -32,15 +33,39 @@ const transformGoogleGenerativeAIStream = (
|
|
32
33
|
type: 'function',
|
33
34
|
}),
|
34
35
|
),
|
35
|
-
id:
|
36
|
+
id: context.id,
|
36
37
|
type: 'tool_calls',
|
37
38
|
};
|
38
39
|
}
|
39
40
|
const text = chunk.text();
|
40
41
|
|
42
|
+
if (chunk.candidates && chunk.candidates[0].groundingMetadata) {
|
43
|
+
const { webSearchQueries, groundingSupports, groundingChunks } =
|
44
|
+
chunk.candidates[0].groundingMetadata;
|
45
|
+
console.log({ groundingChunks, groundingSupports, webSearchQueries });
|
46
|
+
|
47
|
+
return [
|
48
|
+
{ data: text, id: context.id, type: 'text' },
|
49
|
+
{
|
50
|
+
data: {
|
51
|
+
citations: groundingChunks?.map((chunk) => ({
|
52
|
+
// google 返回的 uri 是经过 google 自己处理过的 url,因此无法展现真实的 favicon
|
53
|
+
// 需要使用 title 作为替换
|
54
|
+
favicon: chunk.web?.title,
|
55
|
+
title: chunk.web?.title,
|
56
|
+
url: chunk.web?.uri,
|
57
|
+
})),
|
58
|
+
searchQueries: webSearchQueries,
|
59
|
+
} as GroundingSearch,
|
60
|
+
id: context.id,
|
61
|
+
type: 'grounding',
|
62
|
+
},
|
63
|
+
];
|
64
|
+
}
|
65
|
+
|
41
66
|
return {
|
42
67
|
data: text,
|
43
|
-
id:
|
68
|
+
id: context?.id,
|
44
69
|
type: 'text',
|
45
70
|
};
|
46
71
|
};
|
@@ -32,6 +32,9 @@ export default {
|
|
32
32
|
},
|
33
33
|
duplicateTitle: '{{title}} 副本',
|
34
34
|
emptyAgent: '暂无助手',
|
35
|
+
extendControls: {
|
36
|
+
title: '模型扩展功能',
|
37
|
+
},
|
35
38
|
historyRange: '历史范围',
|
36
39
|
historySummary: '历史消息总结',
|
37
40
|
inbox: {
|
@@ -86,6 +89,31 @@ export default {
|
|
86
89
|
},
|
87
90
|
regenerate: '重新生成',
|
88
91
|
roleAndArchive: '角色与记录',
|
92
|
+
search: {
|
93
|
+
grounding: {
|
94
|
+
searchQueries: '搜索关键词',
|
95
|
+
title: '已搜索到 {{count}} 个结果',
|
96
|
+
},
|
97
|
+
|
98
|
+
mode: {
|
99
|
+
auto: {
|
100
|
+
desc: '根据对话内容智能判断是否需要搜索',
|
101
|
+
title: '智能联网',
|
102
|
+
},
|
103
|
+
disable: '当前模型不支持函数调用,因此无法使用智能联网功能',
|
104
|
+
off: {
|
105
|
+
desc: '仅使用模型的基础知识,不进行网络搜索',
|
106
|
+
title: '关闭联网',
|
107
|
+
},
|
108
|
+
on: {
|
109
|
+
desc: '持续进行网络搜索,获取最新信息',
|
110
|
+
title: '始终联网',
|
111
|
+
},
|
112
|
+
useModelBuiltin: '使用模型内置搜索引擎',
|
113
|
+
},
|
114
|
+
|
115
|
+
title: '联网搜索',
|
116
|
+
},
|
89
117
|
searchAgentPlaceholder: '搜索助手...',
|
90
118
|
sendPlaceholder: '输入聊天内容...',
|
91
119
|
sessionGroup: {
|
package/src/services/chat.ts
CHANGED
@@ -18,6 +18,7 @@ import {
|
|
18
18
|
import { filesPrompts } from '@/prompts/files';
|
19
19
|
import { BuiltinSystemRolePrompts } from '@/prompts/systemRole';
|
20
20
|
import { aiModelSelectors, aiProviderSelectors, useAiInfraStore } from '@/store/aiInfra';
|
21
|
+
import { getAgentChatConfig } from '@/store/chat/slices/aiChat/actions/helpers';
|
21
22
|
import { useSessionStore } from '@/store/session';
|
22
23
|
import { sessionMetaSelectors } from '@/store/session/selectors';
|
23
24
|
import { useToolStore } from '@/store/tool';
|
@@ -224,6 +225,8 @@ class ChatService {
|
|
224
225
|
|
225
226
|
const { provider = ModelProvider.OpenAI, ...res } = params;
|
226
227
|
|
228
|
+
// =================== process model =================== //
|
229
|
+
// ===================================================== //
|
227
230
|
let model = res.model || DEFAULT_AGENT_CONFIG.model;
|
228
231
|
|
229
232
|
// if the provider is Azure, get the deployment name as the request model
|
@@ -238,6 +241,13 @@ class ChatService {
|
|
238
241
|
model = findDeploymentName(model, provider);
|
239
242
|
}
|
240
243
|
|
244
|
+
// =================== process search =================== //
|
245
|
+
// ===================================================== //
|
246
|
+
const chatConfig = getAgentChatConfig();
|
247
|
+
if (chatConfig.searchMode !== 'off') {
|
248
|
+
res.enabledSearch = true;
|
249
|
+
}
|
250
|
+
|
241
251
|
const payload = merge(
|
242
252
|
{ model: DEFAULT_AGENT_CONFIG.model, stream: true, ...DEFAULT_AGENT_CONFIG.params },
|
243
253
|
{ ...res, model },
|
@@ -1,6 +1,7 @@
|
|
1
1
|
import { DeepPartial } from 'utility-types';
|
2
2
|
|
3
3
|
import { INBOX_SESSION_ID } from '@/const/session';
|
4
|
+
import { DEFAULT_AGENT_CONFIG } from '@/const/settings';
|
4
5
|
import { SessionModel } from '@/database/_deprecated/models/session';
|
5
6
|
import { SessionGroupModel } from '@/database/_deprecated/models/sessionGroup';
|
6
7
|
import { UserModel } from '@/database/_deprecated/models/user';
|
@@ -47,7 +48,7 @@ export class ClientService implements ISessionService {
|
|
47
48
|
|
48
49
|
async getSessionConfig(id: string): Promise<LobeAgentConfig> {
|
49
50
|
if (!id || id === INBOX_SESSION_ID) {
|
50
|
-
return UserModel.getAgentConfig();
|
51
|
+
return (await UserModel.getAgentConfig()) || DEFAULT_AGENT_CONFIG;
|
51
52
|
}
|
52
53
|
|
53
54
|
const res = await SessionModel.findById(id);
|
@@ -107,6 +107,8 @@ const currentEnabledKnowledge = (s: AgentStore) => {
|
|
107
107
|
] as KnowledgeItem[];
|
108
108
|
};
|
109
109
|
|
110
|
+
const agentSearchMode = (s: AgentStore) => currentAgentChatConfig(s).searchMode || 'off';
|
111
|
+
|
110
112
|
const hasSystemRole = (s: AgentStore) => {
|
111
113
|
const config = currentAgentConfig(s);
|
112
114
|
|
@@ -140,7 +142,10 @@ const currentKnowledgeIds = (s: AgentStore) => {
|
|
140
142
|
|
141
143
|
const isAgentConfigLoading = (s: AgentStore) => !s.agentConfigInitMap[s.activeId];
|
142
144
|
|
145
|
+
const isAgentEnableSearch = (s: AgentStore) => agentSearchMode(s) !== 'off';
|
146
|
+
|
143
147
|
export const agentSelectors = {
|
148
|
+
agentSearchMode,
|
144
149
|
currentAgentChatConfig,
|
145
150
|
currentAgentConfig,
|
146
151
|
currentAgentFiles,
|
@@ -160,5 +165,6 @@ export const agentSelectors = {
|
|
160
165
|
inboxAgentConfig,
|
161
166
|
inboxAgentModel,
|
162
167
|
isAgentConfigLoading,
|
168
|
+
isAgentEnableSearch,
|
163
169
|
isInboxSession,
|
164
170
|
};
|
@@ -1,5 +1,6 @@
|
|
1
1
|
import { AIProviderStoreState } from '@/store/aiInfra/initialState';
|
2
2
|
import { AiModelSourceEnum } from '@/types/aiModel';
|
3
|
+
import { ModelSearchImplement } from '@/types/search';
|
3
4
|
|
4
5
|
const aiProviderChatModelListIds = (s: AIProviderStoreState) =>
|
5
6
|
s.aiProviderModelList.filter((item) => item.type === 'chat').map((item) => item.id);
|
@@ -69,20 +70,55 @@ const modelContextWindowTokens = (id: string, provider: string) => (s: AIProvide
|
|
69
70
|
return model?.contextWindowTokens;
|
70
71
|
};
|
71
72
|
|
73
|
+
const modelExtendControls = (id: string, provider: string) => (s: AIProviderStoreState) => {
|
74
|
+
const model = getEnabledModelById(id, provider)(s);
|
75
|
+
|
76
|
+
return model?.settings?.extendControls;
|
77
|
+
};
|
78
|
+
|
79
|
+
const isModelHasExtendControls = (id: string, provider: string) => (s: AIProviderStoreState) => {
|
80
|
+
const controls = modelExtendControls(id, provider)(s);
|
81
|
+
|
82
|
+
return !!controls && controls.length > 0;
|
83
|
+
};
|
84
|
+
|
85
|
+
const isModelHasBuiltinSearch = (id: string, provider: string) => (s: AIProviderStoreState) => {
|
86
|
+
const model = getEnabledModelById(id, provider)(s);
|
87
|
+
|
88
|
+
return !!model?.settings?.searchImpl;
|
89
|
+
};
|
90
|
+
|
91
|
+
const isModelHasBuiltinSearchConfig =
|
92
|
+
(id: string, provider: string) => (s: AIProviderStoreState) => {
|
93
|
+
const model = getEnabledModelById(id, provider)(s);
|
94
|
+
|
95
|
+
return (
|
96
|
+
!!model?.settings?.searchImpl &&
|
97
|
+
[ModelSearchImplement.Tool, ModelSearchImplement.Params].includes(
|
98
|
+
model?.settings?.searchImpl as ModelSearchImplement,
|
99
|
+
)
|
100
|
+
);
|
101
|
+
};
|
102
|
+
|
72
103
|
export const aiModelSelectors = {
|
73
104
|
aiProviderChatModelListIds,
|
74
105
|
disabledAiProviderModelList,
|
75
106
|
enabledAiProviderModelList,
|
76
107
|
filteredAiProviderModelList,
|
77
108
|
getAiModelById,
|
109
|
+
getEnabledModelById,
|
78
110
|
hasRemoteModels,
|
79
111
|
isEmptyAiProviderModelList,
|
80
112
|
isModelEnabled,
|
113
|
+
isModelHasBuiltinSearch,
|
114
|
+
isModelHasBuiltinSearchConfig,
|
81
115
|
isModelHasContextWindowToken,
|
116
|
+
isModelHasExtendControls,
|
82
117
|
isModelLoading,
|
83
118
|
isModelSupportReasoning,
|
84
119
|
isModelSupportToolUse,
|
85
120
|
isModelSupportVision,
|
86
121
|
modelContextWindowTokens,
|
122
|
+
modelExtendControls,
|
87
123
|
totalAiProviderModelList,
|
88
124
|
};
|
@@ -1,10 +1,10 @@
|
|
1
|
-
import {
|
1
|
+
import { EnabledAiModel } from '@/types/aiModel';
|
2
2
|
import {
|
3
3
|
AiProviderDetailItem,
|
4
4
|
AiProviderListItem,
|
5
5
|
AiProviderRuntimeConfig,
|
6
|
-
EnabledAiModel,
|
7
6
|
EnabledProvider,
|
7
|
+
EnabledProviderWithModels,
|
8
8
|
} from '@/types/aiProvider';
|
9
9
|
|
10
10
|
export interface AIProviderState {
|
@@ -87,6 +87,18 @@ const providerKeyVaults = (provider: string | undefined) => (s: AIProviderStoreS
|
|
87
87
|
return s.aiProviderRuntimeConfig?.[provider]?.keyVaults;
|
88
88
|
};
|
89
89
|
|
90
|
+
const isProviderHasBuiltinSearch = (provider: string) => (s: AIProviderStoreState) => {
|
91
|
+
const config = providerConfigById(provider)(s);
|
92
|
+
|
93
|
+
return !!config?.settings.searchMode;
|
94
|
+
};
|
95
|
+
|
96
|
+
const isProviderHasBuiltinSearchConfig = (id: string) => (s: AIProviderStoreState) => {
|
97
|
+
const providerCfg = providerConfigById(id)(s);
|
98
|
+
|
99
|
+
return !!providerCfg?.settings.searchMode && providerCfg?.settings.searchMode !== 'internal';
|
100
|
+
};
|
101
|
+
|
90
102
|
export const aiProviderSelectors = {
|
91
103
|
activeProviderConfig,
|
92
104
|
disabledAiProviderList,
|
@@ -97,6 +109,8 @@ export const aiProviderSelectors = {
|
|
97
109
|
isProviderConfigUpdating,
|
98
110
|
isProviderEnabled,
|
99
111
|
isProviderFetchOnClient,
|
112
|
+
isProviderHasBuiltinSearch,
|
113
|
+
isProviderHasBuiltinSearchConfig,
|
100
114
|
isProviderLoading,
|
101
115
|
providerConfigById,
|
102
116
|
providerKeyVaults,
|
@@ -455,7 +455,7 @@ export const generateAIChat: StateCreator<
|
|
455
455
|
await messageService.updateMessageError(messageId, error);
|
456
456
|
await refreshMessages();
|
457
457
|
},
|
458
|
-
onFinish: async (content, { traceId, observationId, toolCalls, reasoning,
|
458
|
+
onFinish: async (content, { traceId, observationId, toolCalls, reasoning, grounding }) => {
|
459
459
|
// if there is traceId, update it
|
460
460
|
if (traceId) {
|
461
461
|
msgTraceId = traceId;
|
@@ -473,19 +473,29 @@ export const generateAIChat: StateCreator<
|
|
473
473
|
await internal_updateMessageContent(messageId, content, {
|
474
474
|
toolCalls,
|
475
475
|
reasoning: !!reasoning ? { content: reasoning, duration } : undefined,
|
476
|
-
search: !!citations ?
|
476
|
+
search: !!grounding?.citations ? grounding : undefined,
|
477
477
|
});
|
478
478
|
},
|
479
479
|
onMessageHandle: async (chunk) => {
|
480
480
|
switch (chunk.type) {
|
481
|
-
case '
|
481
|
+
case 'grounding': {
|
482
482
|
// if there is no citations, then stop
|
483
|
-
if (
|
483
|
+
if (
|
484
|
+
!chunk.grounding ||
|
485
|
+
!chunk.grounding.citations ||
|
486
|
+
chunk.grounding.citations.length <= 0
|
487
|
+
)
|
488
|
+
return;
|
484
489
|
|
485
490
|
internal_dispatchMessage({
|
486
491
|
id: messageId,
|
487
492
|
type: 'updateMessage',
|
488
|
-
value: {
|
493
|
+
value: {
|
494
|
+
search: {
|
495
|
+
citations: chunk.grounding.citations,
|
496
|
+
searchQueries: chunk.grounding.searchQueries,
|
497
|
+
},
|
498
|
+
},
|
489
499
|
});
|
490
500
|
break;
|
491
501
|
}
|
@@ -16,10 +16,10 @@ import {
|
|
16
16
|
ChatMessage,
|
17
17
|
ChatMessageError,
|
18
18
|
CreateMessageParams,
|
19
|
-
GroundingSearch,
|
20
19
|
MessageToolCall,
|
21
20
|
ModelReasoning,
|
22
21
|
} from '@/types/message';
|
22
|
+
import { GroundingSearch } from '@/types/search';
|
23
23
|
import { TraceEventPayloads } from '@/types/trace';
|
24
24
|
import { setNamespace } from '@/utils/storeDebug';
|
25
25
|
import { nanoid } from '@/utils/uuid';
|
@@ -1,7 +1,7 @@
|
|
1
1
|
import { uniqBy } from 'lodash-es';
|
2
2
|
|
3
3
|
import { filterEnabledModels } from '@/config/modelProviders';
|
4
|
-
import { EnabledProviderWithModels } from '@/types/
|
4
|
+
import { EnabledProviderWithModels } from '@/types/aiProvider';
|
5
5
|
import { ChatModelCard, ModelProviderCard } from '@/types/llm';
|
6
6
|
import { ServerModelProviderConfig } from '@/types/serverConfig';
|
7
7
|
import { GlobalLLMProviderKey } from '@/types/user/settings';
|
package/src/types/agent/index.ts
CHANGED
@@ -3,6 +3,7 @@ import { z } from 'zod';
|
|
3
3
|
import { FileItem } from '@/types/files';
|
4
4
|
import { KnowledgeBaseItem } from '@/types/knowledgeBase';
|
5
5
|
import { FewShots, LLMParams } from '@/types/llm';
|
6
|
+
import { SearchMode } from '@/types/search';
|
6
7
|
|
7
8
|
export type TTSServer = 'openai' | 'edge' | 'microsoft';
|
8
9
|
|
@@ -78,6 +79,8 @@ export interface LobeAgentChatConfig {
|
|
78
79
|
*/
|
79
80
|
historyCount?: number;
|
80
81
|
inputTemplate?: string;
|
82
|
+
searchMode?: SearchMode;
|
83
|
+
useModelBuiltinSearch?: boolean;
|
81
84
|
}
|
82
85
|
|
83
86
|
export const AgentChatConfigSchema = z.object({
|
@@ -89,6 +92,7 @@ export const AgentChatConfigSchema = z.object({
|
|
89
92
|
enableMaxTokens: z.boolean().optional(),
|
90
93
|
enableReasoningEffort: z.boolean().optional(),
|
91
94
|
historyCount: z.number().optional(),
|
95
|
+
searchMode: z.enum(['off', 'on', 'auto']).optional(),
|
92
96
|
});
|
93
97
|
|
94
98
|
export type LobeAgentConfigKeys =
|
package/src/types/aiModel.ts
CHANGED
@@ -1,7 +1,5 @@
|
|
1
1
|
import { z } from 'zod';
|
2
2
|
|
3
|
-
import { AiProviderSourceType } from '@/types/aiProvider';
|
4
|
-
|
5
3
|
export type ModelPriceCurrency = 'CNY' | 'USD';
|
6
4
|
|
7
5
|
export const AiModelSourceEnum = {
|
@@ -133,6 +131,29 @@ export interface AiModelConfig {
|
|
133
131
|
* used in azure and doubao
|
134
132
|
*/
|
135
133
|
deploymentName?: string;
|
134
|
+
|
135
|
+
/**
|
136
|
+
* qwen series model enabled search
|
137
|
+
*/
|
138
|
+
enabledSearch?: boolean;
|
139
|
+
}
|
140
|
+
|
141
|
+
export interface ExtendedControl {
|
142
|
+
key: string;
|
143
|
+
requestParams: string | string[];
|
144
|
+
type: 'params' | 'tool';
|
145
|
+
valueType: 'boolean';
|
146
|
+
}
|
147
|
+
|
148
|
+
export type ModelSearchImplementType = 'tool' | 'params' | 'internal';
|
149
|
+
|
150
|
+
export interface AiModelSettings {
|
151
|
+
extendControls?: ExtendedControl[];
|
152
|
+
/**
|
153
|
+
* 模型层实现搜索的方式
|
154
|
+
*/
|
155
|
+
searchImpl?: ModelSearchImplementType;
|
156
|
+
searchProvider?: string;
|
136
157
|
}
|
137
158
|
|
138
159
|
export interface AIChatModelCard extends AIBaseModelCard {
|
@@ -140,6 +161,7 @@ export interface AIChatModelCard extends AIBaseModelCard {
|
|
140
161
|
config?: AiModelConfig;
|
141
162
|
maxOutput?: number;
|
142
163
|
pricing?: ChatModelPricing;
|
164
|
+
settings?: AiModelSettings;
|
143
165
|
type: 'chat';
|
144
166
|
}
|
145
167
|
|
@@ -306,17 +328,22 @@ export type ToggleAiModelEnableParams = z.infer<typeof ToggleAiModelEnableSchema
|
|
306
328
|
|
307
329
|
//
|
308
330
|
|
309
|
-
interface AiModelForSelect {
|
331
|
+
export interface AiModelForSelect {
|
310
332
|
abilities: ModelAbilities;
|
311
333
|
contextWindowTokens?: number;
|
312
334
|
displayName?: string;
|
313
335
|
id: string;
|
314
336
|
}
|
315
337
|
|
316
|
-
export interface
|
317
|
-
|
338
|
+
export interface EnabledAiModel {
|
339
|
+
abilities: ModelAbilities;
|
340
|
+
config?: AiModelConfig;
|
341
|
+
contextWindowTokens?: number;
|
342
|
+
displayName?: string;
|
343
|
+
enabled?: boolean;
|
318
344
|
id: string;
|
319
|
-
|
320
|
-
|
321
|
-
|
345
|
+
providerId: string;
|
346
|
+
settings?: AiModelSettings;
|
347
|
+
sort?: number;
|
348
|
+
type: AiModelType;
|
322
349
|
}
|
package/src/types/aiProvider.ts
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
import { z } from 'zod';
|
2
2
|
|
3
|
-
import {
|
3
|
+
import { AiModelForSelect, EnabledAiModel, ModelSearchImplementType } from '@/types/aiModel';
|
4
4
|
import { SmoothingParams } from '@/types/llm';
|
5
5
|
|
6
6
|
export const AiProviderSourceEnum = {
|
@@ -96,6 +96,7 @@ export interface AiProviderSettings {
|
|
96
96
|
* default openai
|
97
97
|
*/
|
98
98
|
sdkType?: AiProviderSDKType;
|
99
|
+
searchMode?: ModelSearchImplementType;
|
99
100
|
showAddNewModel?: boolean;
|
100
101
|
/**
|
101
102
|
* whether show api key in the provider config
|
@@ -199,16 +200,12 @@ export interface EnabledProvider {
|
|
199
200
|
source: AiProviderSourceType;
|
200
201
|
}
|
201
202
|
|
202
|
-
export interface
|
203
|
-
|
204
|
-
config?: AiModelConfig;
|
205
|
-
contextWindowTokens?: number;
|
206
|
-
displayName?: string;
|
207
|
-
enabled?: boolean;
|
203
|
+
export interface EnabledProviderWithModels {
|
204
|
+
children: AiModelForSelect[];
|
208
205
|
id: string;
|
209
|
-
|
210
|
-
|
211
|
-
|
206
|
+
logo?: string;
|
207
|
+
name: string;
|
208
|
+
source: AiProviderSourceType;
|
212
209
|
}
|
213
210
|
|
214
211
|
export interface AiProviderRuntimeConfig {
|
@@ -1,3 +1,5 @@
|
|
1
|
+
import { GroundingSearch } from '@/types/search';
|
2
|
+
|
1
3
|
export interface CitationItem {
|
2
4
|
id?: string;
|
3
5
|
onlyUrl?: boolean;
|
@@ -5,11 +7,6 @@ export interface CitationItem {
|
|
5
7
|
url: string;
|
6
8
|
}
|
7
9
|
|
8
|
-
export interface GroundingSearch {
|
9
|
-
citations?: CitationItem[];
|
10
|
-
searchQueries?: string[];
|
11
|
-
}
|
12
|
-
|
13
10
|
export interface ModelReasoning {
|
14
11
|
content?: string;
|
15
12
|
duration?: number;
|
@@ -2,11 +2,13 @@ import { IPluginErrorType } from '@lobehub/chat-plugin-sdk';
|
|
2
2
|
|
3
3
|
import { ILobeAgentRuntimeErrorType } from '@/libs/agent-runtime';
|
4
4
|
import { ErrorType } from '@/types/fetch';
|
5
|
-
import { GroundingSearch, MessageRoleType, ModelReasoning } from '@/types/message/base';
|
6
|
-
import { ChatPluginPayload, ChatToolPayload } from '@/types/message/tools';
|
7
|
-
import { Translate } from '@/types/message/translate';
|
8
5
|
import { MetaData } from '@/types/meta';
|
9
6
|
import { MessageSemanticSearchChunk } from '@/types/rag';
|
7
|
+
import { GroundingSearch } from '@/types/search';
|
8
|
+
|
9
|
+
import { MessageRoleType, ModelReasoning } from './base';
|
10
|
+
import { ChatPluginPayload, ChatToolPayload } from './tools';
|
11
|
+
import { Translate } from './translate';
|
10
12
|
|
11
13
|
/**
|
12
14
|
* 聊天消息错误对象
|
package/src/types/openai/chat.ts
CHANGED
@@ -42,6 +42,10 @@ export interface OpenAIChatMessage {
|
|
42
42
|
* @title Chat Stream Payload
|
43
43
|
*/
|
44
44
|
export interface ChatStreamPayload {
|
45
|
+
/**
|
46
|
+
* 是否开启搜索
|
47
|
+
*/
|
48
|
+
enabledSearch?: boolean;
|
45
49
|
/**
|
46
50
|
* @title 控制生成文本中的惩罚系数,用于减少重复性
|
47
51
|
* @default 0
|
@@ -64,6 +68,7 @@ export interface ChatStreamPayload {
|
|
64
68
|
*/
|
65
69
|
n?: number;
|
66
70
|
/**
|
71
|
+
* @deprecated
|
67
72
|
* 开启的插件列表
|
68
73
|
*/
|
69
74
|
plugins?: string[];
|
@@ -0,0 +1,29 @@
|
|
1
|
+
export type SearchMode = 'off' | 'auto' | 'on';
|
2
|
+
|
3
|
+
export enum ModelSearchImplement {
|
4
|
+
/**
|
5
|
+
* 模型内置了搜索功能
|
6
|
+
* 类似 Jina 、PPLX 等模型的搜索模式,让调用方无感知
|
7
|
+
*/
|
8
|
+
Internal = 'internal',
|
9
|
+
/**
|
10
|
+
* 使用参数开关的方式,例如 Qwen、Google、OpenRouter,搜索结果在
|
11
|
+
*/
|
12
|
+
Params = 'params',
|
13
|
+
/**
|
14
|
+
* 使用工具调用的方式
|
15
|
+
*/
|
16
|
+
Tool = 'tool',
|
17
|
+
}
|
18
|
+
|
19
|
+
export interface CitationItem {
|
20
|
+
favicon?: string;
|
21
|
+
id?: string;
|
22
|
+
title?: string;
|
23
|
+
url: string;
|
24
|
+
}
|
25
|
+
|
26
|
+
export interface GroundingSearch {
|
27
|
+
citations?: CitationItem[];
|
28
|
+
searchQueries?: string[];
|
29
|
+
}
|