@lobehub/lobehub 2.0.0-next.1 → 2.0.0-next.3
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 +61 -0
- package/changelog/v1.json +18 -0
- package/package.json +1 -1
- package/packages/const/src/models.ts +13 -0
- package/packages/model-bank/src/aiModels/azure.ts +155 -0
- package/packages/model-bank/src/aiModels/bedrock.ts +44 -0
- package/packages/model-runtime/src/core/openaiCompatibleFactory/createImage.ts +1 -1
- package/packages/model-runtime/src/core/openaiCompatibleFactory/index.test.ts +33 -3
- package/packages/model-runtime/src/core/parameterResolver.ts +3 -0
- package/packages/model-runtime/src/providers/azureOpenai/index.ts +2 -1
- package/src/app/(backend)/oidc/consent/route.ts +0 -1
- package/src/app/[variants]/(main)/settings/_layout/SettingsContent.tsx +0 -3
- package/src/features/AgentSetting/AgentPlugin/index.tsx +20 -12
- package/src/app/[variants]/(main)/settings/llm/ProviderList/Azure/index.tsx +0 -93
- package/src/app/[variants]/(main)/settings/llm/ProviderList/Bedrock/index.tsx +0 -70
- package/src/app/[variants]/(main)/settings/llm/ProviderList/Cloudflare/index.tsx +0 -39
- package/src/app/[variants]/(main)/settings/llm/ProviderList/Github/index.tsx +0 -52
- package/src/app/[variants]/(main)/settings/llm/ProviderList/HuggingFace/index.tsx +0 -52
- package/src/app/[variants]/(main)/settings/llm/ProviderList/Ollama/index.tsx +0 -20
- package/src/app/[variants]/(main)/settings/llm/ProviderList/OpenAI/index.tsx +0 -17
- package/src/app/[variants]/(main)/settings/llm/ProviderList/providers.tsx +0 -132
- package/src/app/[variants]/(main)/settings/llm/components/Checker.tsx +0 -118
- package/src/app/[variants]/(main)/settings/llm/components/ProviderConfig/index.tsx +0 -303
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/CustomModelOption.tsx +0 -98
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/Form.tsx +0 -104
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelConfigModal/index.tsx +0 -77
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/ModelFetcher.tsx +0 -105
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/Option.tsx +0 -68
- package/src/app/[variants]/(main)/settings/llm/components/ProviderModelList/index.tsx +0 -146
- package/src/app/[variants]/(main)/settings/llm/const.ts +0 -20
- package/src/app/[variants]/(main)/settings/llm/features/Footer.tsx +0 -35
- package/src/app/[variants]/(main)/settings/llm/index.tsx +0 -30
- package/src/app/[variants]/(main)/settings/llm/type.ts +0 -5
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,67 @@
|
|
|
2
2
|
|
|
3
3
|
# Changelog
|
|
4
4
|
|
|
5
|
+
## [Version 2.0.0-next.3](https://github.com/lobehub/lobe-chat/compare/v2.0.0-next.2...v2.0.0-next.3)
|
|
6
|
+
|
|
7
|
+
<sup>Released on **2025-10-30**</sup>
|
|
8
|
+
|
|
9
|
+
#### ♻ Code Refactoring
|
|
10
|
+
|
|
11
|
+
- **misc**: Remove llm page.
|
|
12
|
+
|
|
13
|
+
#### 💄 Styles
|
|
14
|
+
|
|
15
|
+
- **misc**: Add new bedrock model support, add pricing info for Azure GPT-5 series models.
|
|
16
|
+
|
|
17
|
+
<br/>
|
|
18
|
+
|
|
19
|
+
<details>
|
|
20
|
+
<summary><kbd>Improvements and Fixes</kbd></summary>
|
|
21
|
+
|
|
22
|
+
#### Code refactoring
|
|
23
|
+
|
|
24
|
+
- **misc**: Remove llm page, closes [#9940](https://github.com/lobehub/lobe-chat/issues/9940) ([6ec01a3](https://github.com/lobehub/lobe-chat/commit/6ec01a3))
|
|
25
|
+
|
|
26
|
+
#### Styles
|
|
27
|
+
|
|
28
|
+
- **misc**: Add new bedrock model support, closes [#9826](https://github.com/lobehub/lobe-chat/issues/9826) ([1b8a981](https://github.com/lobehub/lobe-chat/commit/1b8a981))
|
|
29
|
+
- **misc**: Add pricing info for Azure GPT-5 series models, closes [#9833](https://github.com/lobehub/lobe-chat/issues/9833) ([39a80c5](https://github.com/lobehub/lobe-chat/commit/39a80c5))
|
|
30
|
+
|
|
31
|
+
</details>
|
|
32
|
+
|
|
33
|
+
<div align="right">
|
|
34
|
+
|
|
35
|
+
[](#readme-top)
|
|
36
|
+
|
|
37
|
+
</div>
|
|
38
|
+
|
|
39
|
+
## [Version 2.0.0-next.2](https://github.com/lobehub/lobe-chat/compare/v2.0.0-next.1...v2.0.0-next.2)
|
|
40
|
+
|
|
41
|
+
<sup>Released on **2025-10-30**</sup>
|
|
42
|
+
|
|
43
|
+
#### 🐛 Bug Fixes
|
|
44
|
+
|
|
45
|
+
- **misc**: Hide marketplace link from Plugin List when market disabled, OIDC error when connecting to self-host instance, only include input_fidelity parameter for gpt-image-1..
|
|
46
|
+
|
|
47
|
+
<br/>
|
|
48
|
+
|
|
49
|
+
<details>
|
|
50
|
+
<summary><kbd>Improvements and Fixes</kbd></summary>
|
|
51
|
+
|
|
52
|
+
#### What's fixed
|
|
53
|
+
|
|
54
|
+
- **misc**: Hide marketplace link from Plugin List when market disabled, closes [#9929](https://github.com/lobehub/lobe-chat/issues/9929) ([e303979](https://github.com/lobehub/lobe-chat/commit/e303979))
|
|
55
|
+
- **misc**: OIDC error when connecting to self-host instance, closes [#9916](https://github.com/lobehub/lobe-chat/issues/9916) ([7a2ca19](https://github.com/lobehub/lobe-chat/commit/7a2ca19))
|
|
56
|
+
- **misc**: Only include input_fidelity parameter for gpt-image-1., closes [#9920](https://github.com/lobehub/lobe-chat/issues/9920) ([65dbc63](https://github.com/lobehub/lobe-chat/commit/65dbc63))
|
|
57
|
+
|
|
58
|
+
</details>
|
|
59
|
+
|
|
60
|
+
<div align="right">
|
|
61
|
+
|
|
62
|
+
[](#readme-top)
|
|
63
|
+
|
|
64
|
+
</div>
|
|
65
|
+
|
|
5
66
|
## [Version 2.0.0-next.1](https://github.com/lobehub/lobe-chat/compare/v1.143.0-next.2...v2.0.0-next.1)
|
|
6
67
|
|
|
7
68
|
<sup>Released on **2025-10-30**</sup>
|
package/changelog/v1.json
CHANGED
|
@@ -1,4 +1,22 @@
|
|
|
1
1
|
[
|
|
2
|
+
{
|
|
3
|
+
"children": {
|
|
4
|
+
"improvements": [
|
|
5
|
+
"Add new bedrock model support, add pricing info for Azure GPT-5 series models."
|
|
6
|
+
]
|
|
7
|
+
},
|
|
8
|
+
"date": "2025-10-30",
|
|
9
|
+
"version": "2.0.0-next.3"
|
|
10
|
+
},
|
|
11
|
+
{
|
|
12
|
+
"children": {
|
|
13
|
+
"fixes": [
|
|
14
|
+
"Hide marketplace link from Plugin List when market disabled, OIDC error when connecting to self-host instance, only include input_fidelity parameter for gpt-image-1.."
|
|
15
|
+
]
|
|
16
|
+
},
|
|
17
|
+
"date": "2025-10-30",
|
|
18
|
+
"version": "2.0.0-next.2"
|
|
19
|
+
},
|
|
2
20
|
{
|
|
3
21
|
"children": {
|
|
4
22
|
"features": [
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@lobehub/lobehub",
|
|
3
|
-
"version": "2.0.0-next.
|
|
3
|
+
"version": "2.0.0-next.3",
|
|
4
4
|
"description": "LobeHub - an open-source,comprehensive AI Agent framework that supports speech synthesis, multimodal, and extensible Function Call plugin system. Supports one-click free deployment of your private ChatGPT/LLM web application.",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"framework",
|
|
@@ -35,6 +35,9 @@ export const responsesAPIModels = new Set([
|
|
|
35
35
|
'codex-mini-latest',
|
|
36
36
|
'computer-use-preview',
|
|
37
37
|
'computer-use-preview-2025-03-11',
|
|
38
|
+
'gpt-5-codex',
|
|
39
|
+
'gpt-5-pro',
|
|
40
|
+
'gpt-5-pro-2025-10-06',
|
|
38
41
|
]);
|
|
39
42
|
|
|
40
43
|
/**
|
|
@@ -56,6 +59,11 @@ export const contextCachingModels = new Set([
|
|
|
56
59
|
'claude-3-5-sonnet-20240620',
|
|
57
60
|
'claude-3-5-haiku-latest',
|
|
58
61
|
'claude-3-5-haiku-20241022',
|
|
62
|
+
// Bedrock model IDs
|
|
63
|
+
'us.anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
64
|
+
'anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
65
|
+
'us.anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
66
|
+
'anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
59
67
|
]);
|
|
60
68
|
|
|
61
69
|
export const thinkingWithToolClaudeModels = new Set([
|
|
@@ -69,4 +77,9 @@ export const thinkingWithToolClaudeModels = new Set([
|
|
|
69
77
|
'anthropic/claude-sonnet-4.5',
|
|
70
78
|
'claude-3-7-sonnet-latest',
|
|
71
79
|
'claude-3-7-sonnet-20250219',
|
|
80
|
+
// Bedrock model IDs
|
|
81
|
+
'us.anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
82
|
+
'anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
83
|
+
'us.anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
84
|
+
'anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
72
85
|
]);
|
|
@@ -1,6 +1,161 @@
|
|
|
1
1
|
import { AIChatModelCard, AIImageModelCard } from '../types/aiModel';
|
|
2
2
|
|
|
3
3
|
const azureChatModels: AIChatModelCard[] = [
|
|
4
|
+
{
|
|
5
|
+
abilities: {
|
|
6
|
+
functionCall: true,
|
|
7
|
+
reasoning: true,
|
|
8
|
+
structuredOutput: true,
|
|
9
|
+
vision: true,
|
|
10
|
+
},
|
|
11
|
+
config: {
|
|
12
|
+
deploymentName: 'gpt-5-pro',
|
|
13
|
+
},
|
|
14
|
+
contextWindowTokens: 400_000,
|
|
15
|
+
description:
|
|
16
|
+
'GPT-5 Pro 是 GPT-5 系列的高级版本,具备增强的推理能力。支持结构化输出、函数调用和文本/图像处理,适用于复杂的专业任务。',
|
|
17
|
+
displayName: 'GPT-5 Pro',
|
|
18
|
+
enabled: true,
|
|
19
|
+
id: 'gpt-5-pro',
|
|
20
|
+
maxOutput: 128_000,
|
|
21
|
+
pricing: {
|
|
22
|
+
units: [
|
|
23
|
+
{ name: 'textInput', rate: 15, strategy: 'fixed', unit: 'millionTokens' },
|
|
24
|
+
{ name: 'textOutput', rate: 120, strategy: 'fixed', unit: 'millionTokens' },
|
|
25
|
+
],
|
|
26
|
+
},
|
|
27
|
+
releasedAt: '2025-10-06',
|
|
28
|
+
type: 'chat',
|
|
29
|
+
},
|
|
30
|
+
{
|
|
31
|
+
abilities: {
|
|
32
|
+
functionCall: true,
|
|
33
|
+
structuredOutput: true,
|
|
34
|
+
},
|
|
35
|
+
config: {
|
|
36
|
+
deploymentName: 'gpt-5-codex',
|
|
37
|
+
},
|
|
38
|
+
contextWindowTokens: 400_000,
|
|
39
|
+
description:
|
|
40
|
+
'GPT-5 Codex 专为编程任务优化,针对 Codex CLI 和 VS Code 扩展进行了优化。支持结构化输出和函数调用,适用于代码生成和分析。',
|
|
41
|
+
displayName: 'GPT-5 Codex',
|
|
42
|
+
enabled: true,
|
|
43
|
+
id: 'gpt-5-codex',
|
|
44
|
+
maxOutput: 128_000,
|
|
45
|
+
pricing: {
|
|
46
|
+
units: [
|
|
47
|
+
{ name: 'textInput', rate: 1.25, strategy: 'fixed', unit: 'millionTokens' },
|
|
48
|
+
{ name: 'textOutput', rate: 10, strategy: 'fixed', unit: 'millionTokens' },
|
|
49
|
+
{ name: 'textInput_cacheRead', rate: 0.125, strategy: 'fixed', unit: 'millionTokens' },
|
|
50
|
+
],
|
|
51
|
+
},
|
|
52
|
+
releasedAt: '2025-09-11',
|
|
53
|
+
type: 'chat',
|
|
54
|
+
},
|
|
55
|
+
{
|
|
56
|
+
abilities: {
|
|
57
|
+
functionCall: true,
|
|
58
|
+
reasoning: true,
|
|
59
|
+
structuredOutput: true,
|
|
60
|
+
vision: true,
|
|
61
|
+
},
|
|
62
|
+
config: {
|
|
63
|
+
deploymentName: 'gpt-5',
|
|
64
|
+
},
|
|
65
|
+
contextWindowTokens: 400_000,
|
|
66
|
+
description:
|
|
67
|
+
'GPT-5 是 OpenAI 最新的旗舰模型,具备卓越的推理能力。支持文本和图像输入,结构化输出和并行工具调用,适用于需要深度理解和分析的复杂任务。',
|
|
68
|
+
displayName: 'GPT-5',
|
|
69
|
+
enabled: true,
|
|
70
|
+
id: 'gpt-5',
|
|
71
|
+
maxOutput: 128_000,
|
|
72
|
+
pricing: {
|
|
73
|
+
units: [
|
|
74
|
+
{ name: 'textInput', rate: 1.25, strategy: 'fixed', unit: 'millionTokens' },
|
|
75
|
+
{ name: 'textOutput', rate: 10, strategy: 'fixed', unit: 'millionTokens' },
|
|
76
|
+
{ name: 'textInput_cacheRead', rate: 0.125, strategy: 'fixed', unit: 'millionTokens' },
|
|
77
|
+
],
|
|
78
|
+
},
|
|
79
|
+
releasedAt: '2025-08-07',
|
|
80
|
+
type: 'chat',
|
|
81
|
+
},
|
|
82
|
+
{
|
|
83
|
+
abilities: {
|
|
84
|
+
functionCall: true,
|
|
85
|
+
reasoning: true,
|
|
86
|
+
structuredOutput: true,
|
|
87
|
+
vision: true,
|
|
88
|
+
},
|
|
89
|
+
config: {
|
|
90
|
+
deploymentName: 'gpt-5-mini',
|
|
91
|
+
},
|
|
92
|
+
contextWindowTokens: 400_000,
|
|
93
|
+
description:
|
|
94
|
+
'GPT-5 Mini 提供与 GPT-5 相似的能力,但更加高效和经济。支持推理、函数调用和视觉功能,适合大规模部署和对成本敏感的应用场景。',
|
|
95
|
+
displayName: 'GPT-5 Mini',
|
|
96
|
+
enabled: true,
|
|
97
|
+
id: 'gpt-5-mini',
|
|
98
|
+
maxOutput: 128_000,
|
|
99
|
+
pricing: {
|
|
100
|
+
units: [
|
|
101
|
+
{ name: 'textInput', rate: 0.25, strategy: 'fixed', unit: 'millionTokens' },
|
|
102
|
+
{ name: 'textOutput', rate: 2, strategy: 'fixed', unit: 'millionTokens' },
|
|
103
|
+
{ name: 'textInput_cacheRead', rate: 0.025, strategy: 'fixed', unit: 'millionTokens' },
|
|
104
|
+
],
|
|
105
|
+
},
|
|
106
|
+
releasedAt: '2025-08-07',
|
|
107
|
+
type: 'chat',
|
|
108
|
+
},
|
|
109
|
+
{
|
|
110
|
+
abilities: {
|
|
111
|
+
functionCall: true,
|
|
112
|
+
reasoning: true,
|
|
113
|
+
structuredOutput: true,
|
|
114
|
+
vision: true,
|
|
115
|
+
},
|
|
116
|
+
config: {
|
|
117
|
+
deploymentName: 'gpt-5-nano',
|
|
118
|
+
},
|
|
119
|
+
contextWindowTokens: 400_000,
|
|
120
|
+
description:
|
|
121
|
+
'GPT-5 Nano 是 GPT-5 系列中最小、最快的版本。在保持核心能力的同时,提供超低延迟和成本效益,适合边缘计算和实时应用。',
|
|
122
|
+
displayName: 'GPT-5 Nano',
|
|
123
|
+
enabled: true,
|
|
124
|
+
id: 'gpt-5-nano',
|
|
125
|
+
maxOutput: 128_000,
|
|
126
|
+
pricing: {
|
|
127
|
+
units: [
|
|
128
|
+
{ name: 'textInput', rate: 0.05, strategy: 'fixed', unit: 'millionTokens' },
|
|
129
|
+
{ name: 'textOutput', rate: 0.4, strategy: 'fixed', unit: 'millionTokens' },
|
|
130
|
+
{ name: 'textInput_cacheRead', rate: 0.005, strategy: 'fixed', unit: 'millionTokens' },
|
|
131
|
+
],
|
|
132
|
+
},
|
|
133
|
+
releasedAt: '2025-08-07',
|
|
134
|
+
type: 'chat',
|
|
135
|
+
},
|
|
136
|
+
{
|
|
137
|
+
abilities: {
|
|
138
|
+
vision: true,
|
|
139
|
+
},
|
|
140
|
+
config: {
|
|
141
|
+
deploymentName: 'gpt-5-chat',
|
|
142
|
+
},
|
|
143
|
+
contextWindowTokens: 128_000,
|
|
144
|
+
description:
|
|
145
|
+
'GPT-5 Chat 专为对话场景优化的预览版本。支持文本和图像输入,仅输出文本,适用于聊天机器人和对话式AI应用。',
|
|
146
|
+
displayName: 'GPT-5 Chat',
|
|
147
|
+
id: 'gpt-5-chat',
|
|
148
|
+
maxOutput: 16_384,
|
|
149
|
+
pricing: {
|
|
150
|
+
units: [
|
|
151
|
+
{ name: 'textInput', rate: 1.25, strategy: 'fixed', unit: 'millionTokens' },
|
|
152
|
+
{ name: 'textOutput', rate: 10, strategy: 'fixed', unit: 'millionTokens' },
|
|
153
|
+
{ name: 'textInput_cacheRead', rate: 0.125, strategy: 'fixed', unit: 'millionTokens' },
|
|
154
|
+
],
|
|
155
|
+
},
|
|
156
|
+
releasedAt: '2025-08-07',
|
|
157
|
+
type: 'chat',
|
|
158
|
+
},
|
|
4
159
|
{
|
|
5
160
|
abilities: {
|
|
6
161
|
functionCall: true,
|
|
@@ -1,6 +1,50 @@
|
|
|
1
1
|
import { AIChatModelCard } from '../types/aiModel';
|
|
2
2
|
|
|
3
3
|
const bedrockChatModels: AIChatModelCard[] = [
|
|
4
|
+
{
|
|
5
|
+
abilities: {
|
|
6
|
+
functionCall: true,
|
|
7
|
+
reasoning: true,
|
|
8
|
+
structuredOutput: true,
|
|
9
|
+
vision: true,
|
|
10
|
+
},
|
|
11
|
+
contextWindowTokens: 200_000,
|
|
12
|
+
description: 'Claude Sonnet 4.5 是 Anthropic 迄今为止最智能的模型。',
|
|
13
|
+
displayName: 'Claude Sonnet 4.5',
|
|
14
|
+
enabled: true,
|
|
15
|
+
id: 'us.anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
16
|
+
maxOutput: 64_000,
|
|
17
|
+
pricing: {
|
|
18
|
+
units: [
|
|
19
|
+
{ name: 'textInput', rate: 3, strategy: 'fixed', unit: 'millionTokens' },
|
|
20
|
+
{ name: 'textOutput', rate: 15, strategy: 'fixed', unit: 'millionTokens' },
|
|
21
|
+
],
|
|
22
|
+
},
|
|
23
|
+
releasedAt: '2025-09-29',
|
|
24
|
+
type: 'chat',
|
|
25
|
+
},
|
|
26
|
+
{
|
|
27
|
+
abilities: {
|
|
28
|
+
functionCall: true,
|
|
29
|
+
reasoning: true,
|
|
30
|
+
structuredOutput: true,
|
|
31
|
+
vision: true,
|
|
32
|
+
},
|
|
33
|
+
contextWindowTokens: 200_000,
|
|
34
|
+
description: 'Claude Haiku 4.5 是 Anthropic 最快且最智能的 Haiku 模型,具有闪电般的速度和扩展思考能力。',
|
|
35
|
+
displayName: 'Claude Haiku 4.5',
|
|
36
|
+
enabled: true,
|
|
37
|
+
id: 'us.anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
38
|
+
maxOutput: 64_000,
|
|
39
|
+
pricing: {
|
|
40
|
+
units: [
|
|
41
|
+
{ name: 'textInput', rate: 1, strategy: 'fixed', unit: 'millionTokens' },
|
|
42
|
+
{ name: 'textOutput', rate: 5, strategy: 'fixed', unit: 'millionTokens' },
|
|
43
|
+
],
|
|
44
|
+
},
|
|
45
|
+
releasedAt: '2025-10-15',
|
|
46
|
+
type: 'chat',
|
|
47
|
+
},
|
|
4
48
|
/*
|
|
5
49
|
// TODO: Not support for now
|
|
6
50
|
{
|
|
@@ -67,7 +67,7 @@ async function generateByImageMode(
|
|
|
67
67
|
const defaultInput = {
|
|
68
68
|
n: 1,
|
|
69
69
|
...(model.includes('dall-e') ? { response_format: 'b64_json' } : {}),
|
|
70
|
-
...(isImageEdit ? { input_fidelity: 'high' } : {}),
|
|
70
|
+
...(isImageEdit && model === 'gpt-image-1' ? { input_fidelity: 'high' } : {}),
|
|
71
71
|
};
|
|
72
72
|
|
|
73
73
|
const options = cleanObject({
|
|
@@ -1254,7 +1254,6 @@ describe('LobeOpenAICompatibleFactory', () => {
|
|
|
1254
1254
|
);
|
|
1255
1255
|
expect(instance['client'].images.edit).toHaveBeenCalledWith({
|
|
1256
1256
|
image: expect.any(File),
|
|
1257
|
-
input_fidelity: 'high',
|
|
1258
1257
|
mask: 'https://example.com/mask.jpg',
|
|
1259
1258
|
model: 'dall-e-2',
|
|
1260
1259
|
n: 1,
|
|
@@ -1301,7 +1300,6 @@ describe('LobeOpenAICompatibleFactory', () => {
|
|
|
1301
1300
|
|
|
1302
1301
|
expect(instance['client'].images.edit).toHaveBeenCalledWith({
|
|
1303
1302
|
image: [mockFile1, mockFile2],
|
|
1304
|
-
input_fidelity: 'high',
|
|
1305
1303
|
model: 'dall-e-2',
|
|
1306
1304
|
n: 1,
|
|
1307
1305
|
prompt: 'Merge these images',
|
|
@@ -1330,6 +1328,39 @@ describe('LobeOpenAICompatibleFactory', () => {
|
|
|
1330
1328
|
'Failed to convert image URLs to File objects: Error: Failed to download image',
|
|
1331
1329
|
);
|
|
1332
1330
|
});
|
|
1331
|
+
|
|
1332
|
+
it('should include input_fidelity parameter for gpt-image-1 model', async () => {
|
|
1333
|
+
const mockResponse = {
|
|
1334
|
+
data: [{ b64_json: 'gpt-image-edited-base64' }],
|
|
1335
|
+
};
|
|
1336
|
+
|
|
1337
|
+
const mockFile = new File(['content'], 'test-image.jpg', { type: 'image/jpeg' });
|
|
1338
|
+
|
|
1339
|
+
vi.mocked(openaiHelpers.convertImageUrlToFile).mockResolvedValue(mockFile);
|
|
1340
|
+
vi.spyOn(instance['client'].images, 'edit').mockResolvedValue(mockResponse as any);
|
|
1341
|
+
|
|
1342
|
+
const payload = {
|
|
1343
|
+
model: 'gpt-image-1',
|
|
1344
|
+
params: {
|
|
1345
|
+
imageUrl: 'https://example.com/image.jpg',
|
|
1346
|
+
prompt: 'Edit this image with gpt-image-1',
|
|
1347
|
+
},
|
|
1348
|
+
};
|
|
1349
|
+
|
|
1350
|
+
const result = await (instance as any).createImage(payload);
|
|
1351
|
+
|
|
1352
|
+
expect(instance['client'].images.edit).toHaveBeenCalledWith({
|
|
1353
|
+
image: expect.any(File),
|
|
1354
|
+
input_fidelity: 'high',
|
|
1355
|
+
model: 'gpt-image-1',
|
|
1356
|
+
n: 1,
|
|
1357
|
+
prompt: 'Edit this image with gpt-image-1',
|
|
1358
|
+
});
|
|
1359
|
+
|
|
1360
|
+
expect(result).toEqual({
|
|
1361
|
+
imageUrl: '-image-edited-base64',
|
|
1362
|
+
});
|
|
1363
|
+
});
|
|
1333
1364
|
});
|
|
1334
1365
|
|
|
1335
1366
|
describe('error handling', () => {
|
|
@@ -1431,7 +1462,6 @@ describe('LobeOpenAICompatibleFactory', () => {
|
|
|
1431
1462
|
expect(instance['client'].images.edit).toHaveBeenCalledWith({
|
|
1432
1463
|
customParam: 'should remain unchanged',
|
|
1433
1464
|
image: expect.any(File),
|
|
1434
|
-
input_fidelity: 'high',
|
|
1435
1465
|
model: 'dall-e-2',
|
|
1436
1466
|
n: 1,
|
|
1437
1467
|
prompt: 'Test prompt',
|
|
@@ -263,6 +263,7 @@ export const MODEL_PARAMETER_CONFLICTS = {
|
|
|
263
263
|
'claude-opus-4-20250514',
|
|
264
264
|
'claude-sonnet-4-20250514',
|
|
265
265
|
'claude-sonnet-4-5-20250929',
|
|
266
|
+
'claude-haiku-4-5-20251001',
|
|
266
267
|
// Bedrock model IDs
|
|
267
268
|
'anthropic.claude-opus-4-1-20250805-v1:0',
|
|
268
269
|
'us.anthropic.claude-opus-4-1-20250805-v1:0',
|
|
@@ -272,5 +273,7 @@ export const MODEL_PARAMETER_CONFLICTS = {
|
|
|
272
273
|
'us.anthropic.claude-sonnet-4-20250514-v1:0',
|
|
273
274
|
'anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
274
275
|
'us.anthropic.claude-sonnet-4-5-20250929-v1:0',
|
|
276
|
+
'anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
277
|
+
'us.anthropic.claude-haiku-4-5-20251001-v1:0',
|
|
275
278
|
]),
|
|
276
279
|
};
|
|
@@ -51,7 +51,8 @@ export class LobeAzureOpenAI implements LobeRuntimeAI {
|
|
|
51
51
|
...message,
|
|
52
52
|
role:
|
|
53
53
|
// Convert 'system' role to 'user' or 'developer' based on the model
|
|
54
|
-
(model.includes('o1') || model.includes('o3')
|
|
54
|
+
(model.includes('o1') || model.includes('o3') || model.includes('gpt-5')) &&
|
|
55
|
+
message.role === 'system'
|
|
55
56
|
? [...systemToUserModels].some((sub) => model.includes(sub))
|
|
56
57
|
? 'user'
|
|
57
58
|
: 'developer'
|
|
@@ -15,9 +15,6 @@ const componentMap = {
|
|
|
15
15
|
[SettingsTabs.Agent]: dynamic(() => import('../agent'), {
|
|
16
16
|
loading: () => <Loading />,
|
|
17
17
|
}),
|
|
18
|
-
[SettingsTabs.LLM]: dynamic(() => import('../llm'), {
|
|
19
|
-
loading: () => <Loading />,
|
|
20
|
-
}),
|
|
21
18
|
[SettingsTabs.Provider]: dynamic(() => import('../provider'), {
|
|
22
19
|
loading: () => <Loading />,
|
|
23
20
|
}),
|
|
@@ -34,7 +34,7 @@ const AgentPlugin = memo(() => {
|
|
|
34
34
|
s.toggleAgentPlugin,
|
|
35
35
|
]);
|
|
36
36
|
|
|
37
|
-
const { showDalle } = useServerConfigStore(featureFlagsSelectors);
|
|
37
|
+
const { showDalle, showMarket } = useServerConfigStore(featureFlagsSelectors);
|
|
38
38
|
const installedPlugins = useToolStore(toolSelectors.metaList(showDalle), isEqual);
|
|
39
39
|
|
|
40
40
|
const { isLoading } = useFetchInstalledPlugins();
|
|
@@ -112,16 +112,18 @@ const AgentPlugin = memo(() => {
|
|
|
112
112
|
/>
|
|
113
113
|
</Tooltip>
|
|
114
114
|
) : null}
|
|
115
|
-
|
|
116
|
-
<
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
e
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
115
|
+
{showMarket ? (
|
|
116
|
+
<Tooltip title={t('plugin.store')}>
|
|
117
|
+
<Button
|
|
118
|
+
icon={Store}
|
|
119
|
+
onClick={(e) => {
|
|
120
|
+
e.stopPropagation();
|
|
121
|
+
setShowStore(true);
|
|
122
|
+
}}
|
|
123
|
+
size={'small'}
|
|
124
|
+
/>
|
|
125
|
+
</Tooltip>
|
|
126
|
+
) : null}
|
|
125
127
|
</Space.Compact>
|
|
126
128
|
);
|
|
127
129
|
|
|
@@ -149,7 +151,13 @@ const AgentPlugin = memo(() => {
|
|
|
149
151
|
);
|
|
150
152
|
|
|
151
153
|
const plugin: FormGroupItemType = {
|
|
152
|
-
children: isLoading
|
|
154
|
+
children: isLoading
|
|
155
|
+
? loadingSkeleton
|
|
156
|
+
: isEmpty
|
|
157
|
+
? showMarket
|
|
158
|
+
? empty
|
|
159
|
+
: []
|
|
160
|
+
: [...deprecatedList, ...list],
|
|
153
161
|
extra,
|
|
154
162
|
title: t('settingPlugin.title'),
|
|
155
163
|
};
|
|
@@ -1,93 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { AutoComplete, Input, InputPassword, Markdown } from '@lobehub/ui';
|
|
4
|
-
import { createStyles } from 'antd-style';
|
|
5
|
-
import { ModelProvider } from 'model-bank';
|
|
6
|
-
import { useTranslation } from 'react-i18next';
|
|
7
|
-
|
|
8
|
-
import { AzureProviderCard } from '@/config/modelProviders';
|
|
9
|
-
import { useUserStore } from '@/store/user';
|
|
10
|
-
import { modelProviderSelectors } from '@/store/user/selectors';
|
|
11
|
-
|
|
12
|
-
import { KeyVaultsConfigKey, LLMProviderApiTokenKey } from '../../const';
|
|
13
|
-
import { ProviderItem } from '../../type';
|
|
14
|
-
|
|
15
|
-
const useStyles = createStyles(({ css, token }) => ({
|
|
16
|
-
markdown: css`
|
|
17
|
-
p {
|
|
18
|
-
color: ${token.colorTextDescription} !important;
|
|
19
|
-
}
|
|
20
|
-
`,
|
|
21
|
-
tip: css`
|
|
22
|
-
font-size: 12px;
|
|
23
|
-
color: ${token.colorTextDescription};
|
|
24
|
-
`,
|
|
25
|
-
}));
|
|
26
|
-
|
|
27
|
-
const providerKey = ModelProvider.Azure;
|
|
28
|
-
|
|
29
|
-
export const useAzureProvider = (): ProviderItem => {
|
|
30
|
-
const { t } = useTranslation('modelProvider');
|
|
31
|
-
const { styles } = useStyles();
|
|
32
|
-
|
|
33
|
-
// Get the first model card's deployment name as the check model
|
|
34
|
-
const checkModel = useUserStore((s) => {
|
|
35
|
-
const chatModelCards = modelProviderSelectors.getModelCardsById(providerKey)(s);
|
|
36
|
-
|
|
37
|
-
if (chatModelCards.length > 0) {
|
|
38
|
-
return chatModelCards[0].deploymentName;
|
|
39
|
-
}
|
|
40
|
-
|
|
41
|
-
return 'gpt-35-turbo';
|
|
42
|
-
});
|
|
43
|
-
return {
|
|
44
|
-
...AzureProviderCard,
|
|
45
|
-
apiKeyItems: [
|
|
46
|
-
{
|
|
47
|
-
children: (
|
|
48
|
-
<InputPassword autoComplete={'new-password'} placeholder={t('azure.token.placeholder')} />
|
|
49
|
-
),
|
|
50
|
-
desc: t('azure.token.desc'),
|
|
51
|
-
label: t('azure.token.title'),
|
|
52
|
-
name: [KeyVaultsConfigKey, providerKey, LLMProviderApiTokenKey],
|
|
53
|
-
},
|
|
54
|
-
{
|
|
55
|
-
children: <Input allowClear placeholder={t('azure.endpoint.placeholder')} />,
|
|
56
|
-
desc: t('azure.endpoint.desc'),
|
|
57
|
-
label: t('azure.endpoint.title'),
|
|
58
|
-
name: [KeyVaultsConfigKey, providerKey, 'endpoint'],
|
|
59
|
-
},
|
|
60
|
-
{
|
|
61
|
-
children: (
|
|
62
|
-
<AutoComplete
|
|
63
|
-
options={[
|
|
64
|
-
'2024-06-01',
|
|
65
|
-
'2024-02-01',
|
|
66
|
-
'2024-05-01-preview',
|
|
67
|
-
'2024-04-01-preview',
|
|
68
|
-
'2024-03-01-preview',
|
|
69
|
-
'2024-02-15-preview',
|
|
70
|
-
'2023-10-01-preview',
|
|
71
|
-
'2023-06-01-preview',
|
|
72
|
-
'2023-05-15',
|
|
73
|
-
].map((i) => ({ label: i, value: i }))}
|
|
74
|
-
placeholder={'20XX-XX-XX'}
|
|
75
|
-
/>
|
|
76
|
-
),
|
|
77
|
-
desc: (
|
|
78
|
-
<Markdown className={styles.markdown} fontSize={12} variant={'chat'}>
|
|
79
|
-
{t('azure.azureApiVersion.desc')}
|
|
80
|
-
</Markdown>
|
|
81
|
-
),
|
|
82
|
-
label: t('azure.azureApiVersion.title'),
|
|
83
|
-
name: [KeyVaultsConfigKey, providerKey, 'apiVersion'],
|
|
84
|
-
},
|
|
85
|
-
],
|
|
86
|
-
checkModel,
|
|
87
|
-
modelList: {
|
|
88
|
-
azureDeployName: true,
|
|
89
|
-
notFoundContent: t('azure.empty'),
|
|
90
|
-
placeholder: t('azure.modelListPlaceholder'),
|
|
91
|
-
},
|
|
92
|
-
};
|
|
93
|
-
};
|
|
@@ -1,70 +0,0 @@
|
|
|
1
|
-
'use client';
|
|
2
|
-
|
|
3
|
-
import { InputPassword, Select } from '@lobehub/ui';
|
|
4
|
-
import { useTranslation } from 'react-i18next';
|
|
5
|
-
|
|
6
|
-
import { BedrockProviderCard } from '@/config/modelProviders';
|
|
7
|
-
import { GlobalLLMProviderKey } from '@/types/user/settings';
|
|
8
|
-
|
|
9
|
-
import { KeyVaultsConfigKey } from '../../const';
|
|
10
|
-
import { ProviderItem } from '../../type';
|
|
11
|
-
|
|
12
|
-
const providerKey: GlobalLLMProviderKey = 'bedrock';
|
|
13
|
-
|
|
14
|
-
export const useBedrockProvider = (): ProviderItem => {
|
|
15
|
-
const { t } = useTranslation('modelProvider');
|
|
16
|
-
|
|
17
|
-
return {
|
|
18
|
-
...BedrockProviderCard,
|
|
19
|
-
apiKeyItems: [
|
|
20
|
-
{
|
|
21
|
-
children: (
|
|
22
|
-
<InputPassword
|
|
23
|
-
autoComplete={'new-password'}
|
|
24
|
-
placeholder={t(`${providerKey}.accessKeyId.placeholder`)}
|
|
25
|
-
/>
|
|
26
|
-
),
|
|
27
|
-
desc: t(`${providerKey}.accessKeyId.desc`),
|
|
28
|
-
label: t(`${providerKey}.accessKeyId.title`),
|
|
29
|
-
name: [KeyVaultsConfigKey, providerKey, 'accessKeyId'],
|
|
30
|
-
},
|
|
31
|
-
{
|
|
32
|
-
children: (
|
|
33
|
-
<InputPassword
|
|
34
|
-
autoComplete={'new-password'}
|
|
35
|
-
placeholder={t(`${providerKey}.secretAccessKey.placeholder`)}
|
|
36
|
-
/>
|
|
37
|
-
),
|
|
38
|
-
desc: t(`${providerKey}.secretAccessKey.desc`),
|
|
39
|
-
label: t(`${providerKey}.secretAccessKey.title`),
|
|
40
|
-
name: [KeyVaultsConfigKey, providerKey, 'secretAccessKey'],
|
|
41
|
-
},
|
|
42
|
-
{
|
|
43
|
-
children: (
|
|
44
|
-
<InputPassword
|
|
45
|
-
autoComplete={'new-password'}
|
|
46
|
-
placeholder={t(`${providerKey}.sessionToken.placeholder`)}
|
|
47
|
-
/>
|
|
48
|
-
),
|
|
49
|
-
desc: t(`${providerKey}.sessionToken.desc`),
|
|
50
|
-
label: t(`${providerKey}.sessionToken.title`),
|
|
51
|
-
name: [KeyVaultsConfigKey, providerKey, 'sessionToken'],
|
|
52
|
-
},
|
|
53
|
-
{
|
|
54
|
-
children: (
|
|
55
|
-
<Select
|
|
56
|
-
allowClear
|
|
57
|
-
options={['us-east-1', 'us-west-2', 'ap-southeast-1', 'eu-central-1'].map((i) => ({
|
|
58
|
-
label: i,
|
|
59
|
-
value: i,
|
|
60
|
-
}))}
|
|
61
|
-
placeholder={'us-east-1'}
|
|
62
|
-
/>
|
|
63
|
-
),
|
|
64
|
-
desc: t(`${providerKey}.region.desc`),
|
|
65
|
-
label: t(`${providerKey}.region.title`),
|
|
66
|
-
name: [KeyVaultsConfigKey, providerKey, 'region'],
|
|
67
|
-
},
|
|
68
|
-
],
|
|
69
|
-
};
|
|
70
|
-
};
|