ai-world-sdk 1.0.3 → 1.0.6

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/README.md CHANGED
@@ -5,174 +5,72 @@ TypeScript SDK for AI World Platform - 一个功能完整的 AI 应用开发 SDK
5
5
  [![npm version](https://img.shields.io/npm/v/ai-world-sdk)](https://www.npmjs.com/package/ai-world-sdk)
6
6
  [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT)
7
7
 
8
- ## 简介
8
+ ## 特性
9
9
 
10
- `ai-world-sdk` 是一个功能完整的 TypeScript SDK,用于与 AI World 平台交互。它提供了:
11
-
12
- - **聊天模型**: 兼容 LangChain.js 接口的聊天模型(OpenAI、Google Gemini、Anthropic Claude、Doubao)
13
- - **图像生成**: 支持豆包 Seedream 模型的图像生成 API
14
- - **视频生成**: 支持豆包 Seedance 模型的视频生成 API
15
- - **全局配置**: 支持全局 baseUrl 和 token 配置,简化客户端初始化
16
-
17
- 设计灵感来自 [LangChain.js](https://github.com/langchain-ai/langchainjs) 的接口风格。
10
+ - 🤖 **聊天模型**: 兼容 LangChain.js 接口(OpenAI、Gemini、Claude、Doubao)
11
+ - 🎨 **图像生成**: 支持豆包 Seedream 和 Google Gemini
12
+ - 🎬 **视频生成**: 支持豆包 Seedance
13
+ - ⚙️ **全局配置**: 自动从浏览器环境获取配置,简化初始化
14
+ - 🐛 **调试模式**: 支持详细的请求/响应日志
18
15
 
19
16
  ## 安装
20
17
 
21
18
  ```bash
22
19
  npm install ai-world-sdk
23
- # 或
24
- yarn add ai-world-sdk
25
- # 或
26
- pnpm add ai-world-sdk
20
+ # 或 yarn add ai-world-sdk
21
+ # 或 pnpm add ai-world-sdk
27
22
  ```
28
23
 
29
24
  ## 快速开始
30
25
 
31
- ### 1. 全局配置(推荐)
26
+ ### 1. 配置(推荐)
32
27
 
33
28
  ```typescript
34
- import { sdkConfig, ChatGoogleGenerativeAI, ImageGenerationClient, VideoGenerationClient } from 'ai-world-sdk';
29
+ import { sdkConfig } from 'ai-world-sdk';
35
30
 
36
- // 设置全局配置(只需设置一次)
31
+ // 设置全局配置(只需一次)
37
32
  sdkConfig.setBaseUrl('http://localhost:8000');
38
33
  sdkConfig.setToken('your-jwt-token');
34
+ sdkConfig.setDebug(true); // 可选:启用调试模式
39
35
 
40
- // 现在可以创建客户端而不需要提供 baseUrltoken
41
- const chatModel = new ChatGoogleGenerativeAI({
42
- modelName: 'gemini-2.0-flash-exp-image-generation',
43
- temperature: 0.7,
44
- });
45
-
46
- const imageClient = new ImageGenerationClient({});
47
- const videoClient = new VideoGenerationClient({});
36
+ // 浏览器环境会自动从 window.location.origincookie 获取配置
48
37
  ```
49
38
 
50
- ### 2. 基础聊天模型使用
39
+ ### 2. 聊天模型
51
40
 
52
41
  ```typescript
53
- import {
54
- ChatGoogleGenerativeAI,
55
- HumanMessage,
56
- SystemMessage,
57
- AIMessageChunk,
58
- } from 'ai-world-sdk';
59
-
60
- // 初始化聊天模型
61
- const model = new ChatGoogleGenerativeAI({
62
- baseUrl: 'http://localhost:8000',
63
- token: 'your-jwt-token',
64
- modelName: 'gemini-2.0-flash-exp-image-generation',
42
+ import { ChatGoogleGenerativeAI, ChatOpenAI, ChatAnthropic, HumanMessage, SystemMessage } from 'ai-world-sdk';
43
+
44
+ // Gemini 模型(使用 gemini provider)
45
+ const geminiModel = new ChatGoogleGenerativeAI({
46
+ modelName: 'gemini-2.5-flash-image',
47
+ temperature: 0.7,
48
+ provider: 'gemini', // 或 'aihubmix'
49
+ });
50
+
51
+ // GPT 模型(使用 aihubmix provider)
52
+ const gptModel = new ChatOpenAI({
53
+ modelName: 'gpt-4o-mini',
65
54
  temperature: 0.7,
55
+ provider: 'aihubmix',
56
+ });
57
+
58
+ // Claude 模型(使用 aihubmix provider)
59
+ const claudeModel = new ChatAnthropic({
60
+ modelName: 'claude-3-sonnet-20240229',
61
+ temperature: 0.7,
62
+ provider: 'aihubmix',
66
63
  });
67
64
 
68
65
  // 非流式调用
69
- const response = await model.invoke([
66
+ const response = await geminiModel.invoke([
70
67
  new SystemMessage('You are a helpful assistant.'),
71
68
  new HumanMessage('Hello! What is AI?'),
72
69
  ]);
73
-
74
- console.log(response.content); // 输出: AI 是...
70
+ console.log(response.content);
75
71
 
76
72
  // 流式调用
77
- for await (const chunk of model.stream([
78
- new HumanMessage('Tell me a story about AI'),
79
- ])) {
80
- // chunk 是 AIMessageChunk 对象
81
- if (typeof chunk.content === 'string') {
82
- process.stdout.write(chunk.content);
83
- }
84
- }
85
- ```
86
-
87
- ## 完整 API 文档
88
-
89
- ### 全局配置 API
90
-
91
- #### `sdkConfig.setBaseUrl(baseUrl: string): void`
92
-
93
- 设置全局 baseUrl。所有客户端实例如果没有提供 baseUrl,将使用此全局值。
94
-
95
- ```typescript
96
- import { sdkConfig } from 'ai-world-sdk';
97
-
98
- sdkConfig.setBaseUrl('http://localhost:8000');
99
- ```
100
-
101
- #### `sdkConfig.setToken(token: string): void`
102
-
103
- 设置全局 token。所有客户端实例如果没有提供 token,将使用此全局值。
104
-
105
- ```typescript
106
- sdkConfig.setToken('your-jwt-token');
107
- ```
108
-
109
- #### `sdkConfig.setHeaders(headers: Record<string, string>): void`
110
-
111
- 设置全局 headers。这些 headers 会与每个客户端实例的 headers 合并。
112
-
113
- ```typescript
114
- sdkConfig.setHeaders({
115
- 'X-Custom-Header': 'value',
116
- });
117
- ```
118
-
119
- #### `sdkConfig.getBaseUrl(): string | null`
120
-
121
- 获取全局 baseUrl。
122
-
123
- #### `sdkConfig.getToken(): string | null`
124
-
125
- 获取全局 token。
126
-
127
- #### `sdkConfig.getHeaders(): Record<string, string>`
128
-
129
- 获取全局 headers。
130
-
131
- #### `sdkConfig.reset(): void`
132
-
133
- 重置所有全局配置。
134
-
135
- ### 聊天模型 API
136
-
137
- #### 支持的模型类
138
-
139
- - `ChatOpenAI` - OpenAI 兼容模型(GPT、O1、Doubao)
140
- - `ChatGoogleGenerativeAI` - Google Gemini 模型
141
- - `ChatAnthropic` - Anthropic Claude 模型
142
-
143
- #### `BaseChatModel` 接口
144
-
145
- 所有聊天模型都继承自 `BaseChatModel`,提供以下方法:
146
-
147
- ##### `invoke(messages: BaseMessage[]): Promise<AIMessage>`
148
-
149
- 发送非流式请求。
150
-
151
- **参数:**
152
- - `messages`: 消息数组,可以是 `HumanMessage`、`SystemMessage`、`AIMessage`
153
-
154
- **返回:** `AIMessage` 对象,包含 `content` 字段
155
-
156
- **示例:**
157
- ```typescript
158
- const response = await model.invoke([
159
- new HumanMessage('What is the capital of France?'),
160
- ]);
161
- console.log(response.content); // "The capital of France is Paris."
162
- ```
163
-
164
- ##### `stream(messages: BaseMessage[]): AsyncGenerator<AIMessageChunk, void, unknown>`
165
-
166
- 发送流式请求。
167
-
168
- **参数:**
169
- - `messages`: 消息数组
170
-
171
- **返回:** 异步生成器,每次 yield 一个 `AIMessageChunk` 对象
172
-
173
- **示例:**
174
- ```typescript
175
- for await (const chunk of model.stream([
73
+ for await (const chunk of geminiModel.stream([
176
74
  new HumanMessage('Tell me a story'),
177
75
  ])) {
178
76
  if (typeof chunk.content === 'string') {
@@ -181,513 +79,387 @@ for await (const chunk of model.stream([
181
79
  }
182
80
  ```
183
81
 
184
- ##### `batch(messagesList: BaseMessage[][]): Promise<AIMessage[]>`
185
-
186
- 批量处理多个消息集。
82
+ ### 3. 图像生成
187
83
 
188
- **参数:**
189
- - `messagesList`: 消息数组的数组
190
-
191
- **返回:** `AIMessage` 数组
192
-
193
- **示例:**
194
84
  ```typescript
195
- const responses = await model.batch([
196
- [new HumanMessage('What is AI?')],
197
- [new HumanMessage('What is ML?')],
198
- [new HumanMessage('What is DL?')],
199
- ]);
85
+ import { DoubaoImageGenerationClient, GeminiImageGenerationClient } from 'ai-world-sdk';
200
86
 
201
- responses.forEach((response, index) => {
202
- console.log(`Response ${index + 1}:`, response.content);
87
+ // 豆包图像生成
88
+ const doubaoClient = new DoubaoImageGenerationClient({});
89
+ const result = await doubaoClient.generate({
90
+ prompt: 'A beautiful sunset over the ocean',
91
+ size: '2K',
92
+ quality: 'hd',
93
+ n: 1,
203
94
  });
204
- ```
205
-
206
- ##### `bind(options: BindOptions): BaseChatModel`
207
-
208
- 绑定参数到模型实例,返回新的模型实例。
209
-
210
- **参数:**
211
- - `options.temperature`: 温度参数
212
- - `options.maxTokens`: 最大 token 数
213
- - `options.topP`: Top-p 采样参数
214
- - `options.tools`: 工具定义数组
215
- - `options.toolChoice`: 工具选择策略
95
+ console.log('图像 URL:', result.data[0]?.url);
216
96
 
217
- **示例:**
218
- ```typescript
219
- const boundModel = model.bind({
220
- temperature: 0.9,
221
- maxTokens: 1000,
97
+ // Gemini 图像生成
98
+ const geminiClient = new GeminiImageGenerationClient({});
99
+ const geminiResult = await geminiClient.generate({
100
+ prompt: 'A futuristic city',
101
+ aspect_ratio: '16:9',
222
102
  });
223
-
224
- const response = await boundModel.invoke([
225
- new HumanMessage('Hello!'),
226
- ]);
103
+ console.log('图像 URL:', geminiResult.data[0]?.url);
227
104
  ```
228
105
 
229
- ##### `bindTools(tools: ToolDefinition[]): BaseChatModel`
106
+ ### 4. 视频生成
230
107
 
231
- 绑定工具到模型实例。
232
-
233
- **参数:**
234
- - `tools`: 工具定义数组
235
-
236
- **示例:**
237
108
  ```typescript
238
- import { ToolDefinition } from 'ai-world-sdk';
239
-
240
- const tools: ToolDefinition[] = [
241
- {
242
- type: 'function',
243
- function: {
244
- name: 'get_weather',
245
- description: 'Get the current weather in a location',
246
- parameters: {
247
- type: 'object',
248
- properties: {
249
- location: { type: 'string' },
250
- },
251
- required: ['location'],
252
- },
253
- },
254
- },
255
- ];
256
-
257
- const modelWithTools = model.bindTools(tools);
258
- const response = await modelWithTools.invoke([
259
- new HumanMessage('What is the weather in Paris?'),
260
- ]);
261
- ```
262
-
263
- ##### `getModelName(): string`
264
-
265
- 获取当前模型名称。
266
-
267
- #### 消息类型
268
-
269
- ##### `HumanMessage`
270
-
271
- 用户消息。
272
-
273
- ```typescript
274
- import { HumanMessage } from 'ai-world-sdk';
275
-
276
- const message = new HumanMessage('Hello!');
277
- ```
109
+ import { VideoGenerationClient } from 'ai-world-sdk';
278
110
 
279
- ##### `SystemMessage`
111
+ const videoClient = new VideoGenerationClient({});
280
112
 
281
- 系统消息,用于设置助手的行为。
113
+ // 创建任务
114
+ const task = await videoClient.create({
115
+ prompt: 'A beautiful sunset over the ocean',
116
+ duration: 5,
117
+ aspect_ratio: '16:9',
118
+ });
282
119
 
283
- ```typescript
284
- import { SystemMessage } from 'ai-world-sdk';
120
+ // 轮询直到完成
121
+ const result = await videoClient.poll(task.id, {
122
+ interval: 3000,
123
+ timeout: 300000,
124
+ });
285
125
 
286
- const message = new SystemMessage('You are a helpful assistant.');
126
+ if (result.status === 'succeeded') {
127
+ console.log('视频 URL:', result.content?.video_url);
128
+ }
287
129
  ```
288
130
 
289
- ##### `AIMessage`
290
-
291
- 助手消息。
131
+ ## API 参考
292
132
 
293
- ```typescript
294
- import { AIMessage } from 'ai-world-sdk';
133
+ ### 聊天模型
295
134
 
296
- const message = new AIMessage('Hello! How can I help you?');
297
- ```
135
+ #### 支持的模型类
298
136
 
299
- ##### `AIMessageChunk`
137
+ | 模型类 | 说明 | 示例模型 |
138
+ |--------|------|----------|
139
+ | `ChatOpenAI` | OpenAI 兼容(GPT、O1、Doubao) | `gpt-4o-mini`, `doubao-pro-4k` |
140
+ | `ChatGoogleGenerativeAI` | Google Gemini | `gemini-2.5-flash-image` |
141
+ | `ChatAnthropic` | Anthropic Claude | `claude-3-sonnet-20240229` |
300
142
 
301
- 流式响应中的消息块。
143
+ #### 核心方法
302
144
 
303
145
  ```typescript
304
- import { AIMessageChunk } from 'ai-world-sdk';
146
+ // 非流式调用
147
+ const response = await model.invoke([new HumanMessage('Hello')]);
305
148
 
306
- // 在流式调用中使用
307
- for await (const chunk of model.stream([...])) {
308
- // chunk 是 AIMessageChunk 实例
149
+ // 流式调用
150
+ for await (const chunk of model.stream([new HumanMessage('Hello')])) {
309
151
  console.log(chunk.content);
310
- console.log(chunk.id);
311
- console.log(chunk.response_metadata);
312
152
  }
313
- ```
314
153
 
315
- #### 多模态输入
154
+ // 批量处理
155
+ const responses = await model.batch([
156
+ [new HumanMessage('Question 1')],
157
+ [new HumanMessage('Question 2')],
158
+ ]);
316
159
 
317
- 支持文本和图像混合输入:
160
+ // 绑定参数
161
+ const boundModel = model.bind({ temperature: 0.9, maxTokens: 1000 });
318
162
 
319
- ```typescript
320
- const response = await model.invoke([
321
- {
322
- role: 'user',
323
- content: [
324
- { type: 'text', text: 'Describe this image' },
325
- {
326
- type: 'image_url',
327
- image_url: '...',
328
- },
329
- ],
330
- },
331
- ]);
163
+ // 绑定工具
164
+ const modelWithTools = model.bindTools([...tools]);
332
165
  ```
333
166
 
334
167
  #### 工厂函数
335
168
 
336
- 使用 `createChatModel` 根据模型名称自动选择正确的模型类:
337
-
338
169
  ```typescript
339
170
  import { createChatModel } from 'ai-world-sdk';
340
171
 
341
- // 自动选择 ChatGoogleGenerativeAI
342
- const gemini = createChatModel('gemini-1.5-pro', {
343
- baseUrl: 'http://localhost:8000',
344
- token: 'your-token',
172
+ // 根据模型名称自动选择正确的类
173
+ const model = createChatModel('gemini-2.5-flash-image', {
345
174
  temperature: 0.7,
346
- });
347
-
348
- // 自动选择 ChatOpenAI
349
- const gpt = createChatModel('gpt-4', {
350
- baseUrl: 'http://localhost:8000',
351
- token: 'your-token',
352
- });
353
-
354
- // 自动选择 ChatAnthropic
355
- const claude = createChatModel('claude-3-sonnet-20240229', {
356
- baseUrl: 'http://localhost:8000',
357
- token: 'your-token',
175
+ provider: 'gemini', // 或 'aihubmix', 'doubao'
358
176
  });
359
177
  ```
360
178
 
361
179
  **支持的模型前缀:**
362
180
  - `gpt-*`, `o1-*` → `ChatOpenAI`
363
- - `doubao-*` → `ChatOpenAI` (Doubao 与 OpenAI 兼容)
181
+ - `doubao-*` → `ChatOpenAI`
364
182
  - `gemini-*` → `ChatGoogleGenerativeAI`
365
183
  - `claude-*` → `ChatAnthropic`
366
184
 
367
- ### 图像生成 API
368
-
369
- #### `ImageGenerationClient`
185
+ **Provider 参数说明:**
186
+ - `provider: 'aihubmix'` - 使用 aihubmix 聚合服务(推荐,支持所有模型)
187
+ - `provider: 'gemini'` - 直接使用 Google Gemini API
188
+ - `provider: 'doubao'` - 使用豆包服务
370
189
 
371
- 图像生成客户端,支持 OpenAI 标准格式的图像生成。
190
+ ### 图像生成
372
191
 
373
- ##### 初始化
192
+ #### DoubaoImageGenerationClient
374
193
 
375
194
  ```typescript
376
- import { ImageGenerationClient } from 'ai-world-sdk';
195
+ const client = new DoubaoImageGenerationClient({});
377
196
 
378
- const imageClient = new ImageGenerationClient({
379
- baseUrl: 'http://localhost:8000', // 可选,如果设置了全局配置
380
- token: 'your-jwt-token', // 可选,如果设置了全局配置
381
- headers: { // 可选
382
- 'X-Custom-Header': 'value',
383
- },
197
+ const result = await client.generate({
198
+ prompt: 'A beautiful landscape', // 必需
199
+ model: 'doubao-seedream-4-5-251128', // 可选,默认值
200
+ size: '2K', // 可选: 1K, 2K, 4K, 1024x1024 等
201
+ quality: 'hd', // 可选: standard, hd
202
+ n: 1, // 可选: 1-10
203
+ response_format: 'url', // 可选: url, b64_json
204
+ style: 'vivid', // 可选: vivid, natural
205
+ watermark: false, // 可选
384
206
  });
385
207
  ```
386
208
 
387
- ##### `generate(request: ImageGenerationRequest): Promise<ImageGenerationResponse>`
388
-
389
- 生成图像(同步)。
390
-
391
- **请求参数 (`ImageGenerationRequest`):**
392
- - `prompt` (必需): 图像生成提示词
393
- - `model` (可选): 模型名称,默认: `doubao-seedream-4-5-251128`
394
- - `n` (可选): 生成图像数量,1-10,默认: 1
395
- - `size` (可选): 图像尺寸,支持: `256x256`, `512x512`, `1024x1024`, `1792x1024`, `1024x1792`, `1K`, `2K`, `4K`,默认: `1024x1024`
396
- - `quality` (可选): 图像质量,`standard` 或 `hd`,默认: `standard`
397
- - `response_format` (可选): 响应格式,`url` 或 `b64_json`,默认: `url`
398
- - `style` (可选): 图像风格,`vivid` 或 `natural`(仅部分模型支持)
399
- - `user` (可选): 用户标识(用于追踪和审计)
209
+ #### GeminiImageGenerationClient
400
210
 
401
- **返回 (`ImageGenerationResponse`):**
402
- - `created`: 创建时间戳(Unix 时间戳)
403
- - `data`: 图像数据数组,每个元素包含:
404
- - `url`: 图像 URL(如果 `response_format` 为 `url`)
405
- - `b64_json`: Base64 编码的图像数据(如果 `response_format` 为 `b64_json`)
406
-
407
- **示例:**
408
211
  ```typescript
409
- const result = await imageClient.generate({
410
- prompt: '充满活力的特写编辑肖像,模特眼神犀利,头戴雕塑感帽子',
411
- model: 'doubao-seedream-4-5-251128',
412
- size: '2K',
413
- n: 1,
414
- quality: 'hd',
415
- response_format: 'url',
416
- });
212
+ const client = new GeminiImageGenerationClient({});
417
213
 
418
- console.log('生成的图像:', result.data);
419
- console.log('第一张图像 URL:', result.data[0]?.url);
214
+ const result = await client.generate({
215
+ prompt: 'A beautiful landscape', // 必需
216
+ model: 'gemini-2.0-flash-exp-image-generation', // 可选,默认值
217
+ number_of_images: 1, // 可选
218
+ aspect_ratio: '16:9', // 可选: 1:1, 9:16, 16:9, 4:3, 3:4
219
+ temperature: 0.7, // 可选
220
+ });
420
221
  ```
421
222
 
422
- ### 视频生成 API
223
+ ### 视频生成
423
224
 
424
- #### `VideoGenerationClient`
225
+ #### VideoGenerationClient
425
226
 
426
- 视频生成客户端,支持豆包 Seedance 模型的视频生成。
227
+ ```typescript
228
+ const client = new VideoGenerationClient({});
427
229
 
428
- ##### 初始化
230
+ // 创建任务
231
+ const task = await client.create({
232
+ prompt: 'A beautiful sunset', // 或 image_url
233
+ model: 'doubao-seedance-1-0-pro-fast-251015', // 可选
234
+ duration: 5, // 可选: 1-10 秒
235
+ aspect_ratio: '16:9', // 可选: 16:9, 9:16, 1:1
236
+ resolution: '720p', // 可选
237
+ return_last_frame: true, // 可选
238
+ });
429
239
 
430
- ```typescript
431
- import { VideoGenerationClient } from 'ai-world-sdk';
240
+ // 查询状态
241
+ const status = await client.get(task.id);
432
242
 
433
- const videoClient = new VideoGenerationClient({
434
- baseUrl: 'http://localhost:8000', // 可选,如果设置了全局配置
435
- token: 'your-jwt-token', // 可选,如果设置了全局配置
436
- headers: { // 可选
437
- 'X-Custom-Header': 'value',
438
- },
243
+ // 轮询直到完成
244
+ const result = await client.poll(task.id, {
245
+ interval: 3000, // 轮询间隔(毫秒)
246
+ timeout: 300000, // 超时时间(毫秒)
439
247
  });
440
248
  ```
441
249
 
442
- ##### `create(request: VideoGenerationRequest): Promise<ContentGenerationTaskID>`
250
+ ### 全局配置
443
251
 
444
- 创建视频生成任务。
252
+ ```typescript
253
+ import { sdkConfig } from 'ai-world-sdk';
445
254
 
446
- **请求参数 (`VideoGenerationRequest`):**
447
- - `prompt` (可选): 文本提示词(文本生成视频)
448
- - `image_url` (可选): 图像 URL(图像生成视频)
449
- - `model` (可选): 模型名称,默认: `doubao-seedance-1-0-pro-fast-251015`
450
- - `content` (可选): 内容列表(如果提供,将直接使用,忽略 prompt 和 image_url)
451
- - `callback_url` (可选): 回调 URL(任务完成时通知)
452
- - `return_last_frame` (可选): 是否返回最后一帧图像
453
- - `service_tier` (可选): 服务层级
454
- - `execution_expires_after` (可选): 执行过期时间(秒)
455
- - `duration` (可选): 视频时长(秒),1-10,默认: 5(将添加到 prompt)
456
- - `aspect_ratio` (可选): 视频宽高比,`16:9`, `9:16`, `1:1`,默认: `16:9`(将添加到 prompt)
457
- - `resolution` (可选): 视频分辨率,例如: `720p`, `1080p`(将添加到 prompt)
458
- - `user` (可选): 用户标识(用于追踪和审计)
255
+ // 设置配置
256
+ sdkConfig.setBaseUrl('http://localhost:8000');
257
+ sdkConfig.setToken('your-jwt-token');
258
+ sdkConfig.setHeaders({ 'X-Custom-Header': 'value' });
259
+ sdkConfig.setDebug(true);
459
260
 
460
- **注意:** `prompt` 和 `image_url` 必须提供其中之一,或者直接提供 `content`。
261
+ // 获取配置
262
+ const baseUrl = sdkConfig.getServerUrl();
263
+ const token = sdkConfig.getToken();
264
+ const headers = sdkConfig.getHeaders();
265
+ const debug = sdkConfig.getDebug();
461
266
 
462
- **返回 (`ContentGenerationTaskID`):**
463
- - `id`: 任务 ID
267
+ // 重置配置
268
+ sdkConfig.reset();
269
+ ```
464
270
 
465
- **示例(文本生成视频):**
466
- ```typescript
467
- const task = await videoClient.create({
468
- prompt: 'A beautiful sunset over the ocean with waves crashing on the shore',
469
- model: 'doubao-seedance-1-0-pro-fast-251015',
470
- duration: 5,
471
- aspect_ratio: '16:9',
472
- resolution: '720p',
473
- });
271
+ **浏览器环境自动配置:**
272
+ - `baseUrl`: 从 `window.location.origin` 自动获取
273
+ - `token`: `document.cookie` 中的 `auth_token` 自动获取
474
274
 
475
- console.log('任务 ID:', task.id);
476
- ```
275
+ ### 消息类型
477
276
 
478
- **示例(图像生成视频):**
479
277
  ```typescript
480
- const task = await videoClient.create({
481
- image_url: 'https://example.com/image.jpg',
482
- model: 'doubao-seedance-1-0-pro-fast-251015',
483
- duration: 5,
484
- });
278
+ import { HumanMessage, SystemMessage, AIMessage } from 'ai-world-sdk';
485
279
 
486
- console.log('任务 ID:', task.id);
487
- ```
280
+ // 文本消息
281
+ const userMsg = new HumanMessage('Hello');
282
+ const systemMsg = new SystemMessage('You are a helpful assistant.');
488
283
 
489
- **示例(直接提供 content):**
490
- ```typescript
491
- const task = await videoClient.create({
492
- model: 'doubao-seedance-1-0-pro-fast-251015',
493
- content: [
494
- {
495
- type: 'text',
496
- text: 'A beautiful sunset --ratio 16:9 --duration 5',
497
- },
498
- ],
499
- return_last_frame: true,
500
- callback_url: 'https://example.com/callback',
501
- });
284
+ // 多模态消息(文本 + 图像)
285
+ const multimodalMsg = new HumanMessage([
286
+ { type: 'text', text: 'Describe this image' },
287
+ { type: 'image_url', image_url: 'data:image/jpeg;base64,...' },
288
+ ]);
502
289
  ```
503
290
 
504
- ##### `get(taskId: string): Promise<ContentGenerationTask>`
291
+ ## Provider 调用示例
505
292
 
506
- 查询视频生成任务状态。
293
+ SDK 支持多个 provider,每个 provider 对应不同的服务提供商。以下是各 provider 的使用示例:
507
294
 
508
- **参数:**
509
- - `taskId`: 任务 ID
295
+ ### aihubmix Provider
510
296
 
511
- **返回 (`ContentGenerationTask`):**
512
- - `id`: 任务 ID
513
- - `model`: 使用的模型
514
- - `status`: 任务状态,`queued` | `running` | `succeeded` | `failed` | `cancelled`
515
- - `error`: 错误信息(如果失败),包含 `message` 和 `code`
516
- - `content`: 生成的内容,包含:
517
- - `video_url`: 视频 URL(任务完成时)
518
- - `last_frame_url`: 最后一帧图像 URL(如果 `return_last_frame` 为 true)
519
- - `file_url`: 文件 URL
520
- - `usage`: 使用情况,包含 `completion_tokens`
521
- - `created_at`: 创建时间戳(Unix 时间戳)
522
- - `updated_at`: 更新时间戳
523
- - 其他字段: `subdivisionlevel`, `fileformat`, `frames`, `framespersecond`, `seed`, `revised_prompt`, `service_tier`, `execution_expires_after`
297
+ `aihubmix` 是一个多模型聚合服务,支持多种模型(OpenAI、Gemini、Claude 等)。
524
298
 
525
- **示例:**
526
299
  ```typescript
527
- const task = await videoClient.get(taskId);
300
+ import { ChatOpenAI, ChatGoogleGenerativeAI, ChatAnthropic, HumanMessage } from 'ai-world-sdk';
528
301
 
529
- console.log('任务状态:', task.status);
530
- console.log('使用的模型:', task.model);
302
+ // OpenAI 模型(通过 aihubmix)
303
+ const gptModel = new ChatOpenAI({
304
+ modelName: 'gpt-4o-mini',
305
+ temperature: 0.7,
306
+ provider: 'aihubmix',
307
+ });
531
308
 
532
- if (task.status === 'succeeded' && task.content?.video_url) {
533
- console.log('视频 URL:', task.content.video_url);
534
- } else if (task.error) {
535
- console.error('错误:', task.error.message);
536
- }
537
- ```
309
+ // Gemini 模型(通过 aihubmix)
310
+ const geminiModel = new ChatGoogleGenerativeAI({
311
+ modelName: 'gemini-2.5-flash-image',
312
+ temperature: 0.7,
313
+ provider: 'aihubmix',
314
+ });
538
315
 
539
- ##### `poll(taskId: string, options?: PollOptions): Promise<ContentGenerationTask>`
316
+ // Claude 模型(通过 aihubmix)
317
+ const claudeModel = new ChatAnthropic({
318
+ modelName: 'claude-3-sonnet-20240229',
319
+ temperature: 0.7,
320
+ provider: 'aihubmix',
321
+ });
540
322
 
541
- 轮询视频生成任务直到完成。
323
+ // 使用示例
324
+ const response = await gptModel.invoke([
325
+ new HumanMessage('Hello!'),
326
+ ]);
327
+ ```
542
328
 
543
- **参数:**
544
- - `taskId`: 任务 ID
545
- - `options.interval` (可选): 轮询间隔(毫秒),默认: 5000
546
- - `options.timeout` (可选): 超时时间(毫秒),默认: 300000 (5分钟)
329
+ ### gemini Provider
547
330
 
548
- **返回:** 完成后的 `ContentGenerationTask`
331
+ 直接使用 Google Gemini 官方 API。
549
332
 
550
- **示例:**
551
333
  ```typescript
552
- // 创建任务
553
- const createTask = await videoClient.create({
554
- prompt: 'A short video of a cat playing',
555
- model: 'doubao-seedance-1-0-pro-fast-251015',
556
- duration: 3,
557
- });
334
+ import { ChatGoogleGenerativeAI, HumanMessage } from 'ai-world-sdk';
558
335
 
559
- // 轮询直到完成
560
- const result = await videoClient.poll(createTask.id, {
561
- interval: 2000, // 每 2 秒轮询一次
562
- timeout: 60000, // 60 秒超时
336
+ const model = new ChatGoogleGenerativeAI({
337
+ modelName: 'gemini-2.5-flash-image',
338
+ temperature: 0.7,
339
+ provider: 'gemini',
563
340
  });
564
341
 
565
- if (result.status === 'succeeded' && result.content?.video_url) {
566
- console.log('视频生成成功:', result.content.video_url);
567
- } else if (result.error) {
568
- console.error('生成失败:', result.error.message);
569
- }
342
+ const response = await model.invoke([
343
+ new HumanMessage('What is AI?'),
344
+ ]);
570
345
  ```
571
346
 
572
- ## 支持的模型
347
+ ### doubao Provider
573
348
 
574
- ### 聊天模型
349
+ 使用豆包(字节跳动)的模型服务。
575
350
 
576
- #### OpenAI 兼容模型
577
- - `gpt-3.5-turbo`
578
- - `gpt-4`
579
- - `gpt-4-turbo`
580
- - `o1-preview`
581
- - `o1-mini`
582
- - `doubao-*` (豆包模型,与 OpenAI 兼容)
583
-
584
- #### Google Gemini
585
- - `gemini-pro`
586
- - `gemini-1.5-pro`
587
- - `gemini-1.5-flash`
588
- - `gemini-2.0-flash-exp-image-generation`
589
-
590
- #### Anthropic Claude
591
- - `claude-3-opus-20240229`
592
- - `claude-3-sonnet-20240229`
593
- - `claude-3-haiku-20240307`
351
+ ```typescript
352
+ import { ChatOpenAI, HumanMessage } from 'ai-world-sdk';
594
353
 
595
- ### 图像生成模型
354
+ // Doubao 模型使用 ChatOpenAI(因为与 OpenAI 兼容)
355
+ const doubaoModel = new ChatOpenAI({
356
+ modelName: 'doubao-pro-4k',
357
+ temperature: 0.7,
358
+ provider: 'doubao',
359
+ });
596
360
 
597
- - `doubao-seedream-4-5-251128` (默认)
598
- - 其他 Seedream 模型版本
361
+ const response = await doubaoModel.invoke([
362
+ new HumanMessage('你好!'),
363
+ ]);
364
+ ```
599
365
 
600
- ### 视频生成模型
366
+ ### Provider 选择指南
367
+
368
+ | Provider | 适用场景 | 支持的模型 |
369
+ |----------|----------|------------|
370
+ | `aihubmix` | 多模型聚合,统一接口 | GPT、Gemini、Claude、Doubao 等 |
371
+ | `gemini` | 直接使用 Google Gemini API | 所有 Gemini 模型 |
372
+ | `doubao` | 使用豆包服务 | Doubao 系列模型 |
601
373
 
602
- - `doubao-seedance-1-0-pro-fast-251015` (默认,推荐)
603
- - `doubao-seedance-1-0-pro-250528`
604
- - `doubao-seedance-1-0-lite-t2v-250428` (文本生成视频)
605
- - `doubao-seedance-1-0-lite-i2v-250428` (图像生成视频)
374
+ **推荐使用 `aihubmix` provider**,因为它提供了统一的接口和更好的模型选择灵活性。
606
375
 
607
376
  ## 完整示例
608
377
 
609
- ### 示例 1: 使用全局配置
378
+ ### 聊天对话
610
379
 
611
380
  ```typescript
612
- import {
613
- sdkConfig,
614
- ChatGoogleGenerativeAI,
615
- ImageGenerationClient,
616
- VideoGenerationClient,
617
- HumanMessage,
618
- } from 'ai-world-sdk';
619
-
620
- // 设置全局配置
621
- sdkConfig.setBaseUrl('http://localhost:8000');
622
- sdkConfig.setToken('your-jwt-token');
381
+ import { ChatGoogleGenerativeAI, HumanMessage, SystemMessage } from 'ai-world-sdk';
623
382
 
624
- // 创建客户端(不需要提供 baseUrl token)
625
- const chatModel = new ChatGoogleGenerativeAI({
626
- modelName: 'gemini-2.0-flash-exp-image-generation',
383
+ const model = new ChatGoogleGenerativeAI({
384
+ modelName: 'gemini-2.5-flash-image',
627
385
  temperature: 0.7,
386
+ provider: 'gemini',
628
387
  });
629
388
 
630
- const imageClient = new ImageGenerationClient({});
631
- const videoClient = new VideoGenerationClient({});
632
-
633
- // 使用
634
- const response = await chatModel.invoke([
635
- new HumanMessage('Hello!'),
389
+ // 简单对话
390
+ const response = await model.invoke([
391
+ new HumanMessage('What is AI?'),
636
392
  ]);
393
+ console.log(response.content);
637
394
 
638
- const imageResult = await imageClient.generate({
639
- prompt: 'A beautiful sunset',
640
- });
395
+ // 带系统提示的对话
396
+ const response2 = await model.invoke([
397
+ new SystemMessage('You are a helpful assistant.'),
398
+ new HumanMessage('Explain machine learning.'),
399
+ ]);
641
400
  ```
642
401
 
643
- ### 示例 2: 流式聊天
402
+ ### 流式响应
644
403
 
645
404
  ```typescript
646
- import { ChatGoogleGenerativeAI, HumanMessage, AIMessageChunk } from 'ai-world-sdk';
647
-
648
- const model = new ChatGoogleGenerativeAI({
649
- baseUrl: 'http://localhost:8000',
650
- token: 'your-token',
651
- modelName: 'gemini-2.0-flash-exp-image-generation',
652
- });
653
-
654
405
  let fullText = '';
655
406
  for await (const chunk of model.stream([
656
407
  new HumanMessage('Tell me a story about AI'),
657
408
  ])) {
658
- // chunk 是 AIMessageChunk 对象
659
409
  if (typeof chunk.content === 'string') {
660
410
  fullText += chunk.content;
661
411
  process.stdout.write(chunk.content);
662
412
  }
663
413
  }
664
-
665
414
  console.log('\n完整回复:', fullText);
666
415
  ```
667
416
 
668
- ### 示例 3: 图像生成工作流
417
+ ### 工具调用
669
418
 
670
419
  ```typescript
671
- import { ImageGenerationClient } from 'ai-world-sdk';
420
+ import { ToolDefinition } from 'ai-world-sdk';
672
421
 
673
- const imageClient = new ImageGenerationClient({
674
- baseUrl: 'http://localhost:8000',
675
- token: 'your-token',
676
- });
422
+ const tools: ToolDefinition[] = [
423
+ {
424
+ type: 'function',
425
+ function: {
426
+ name: 'get_weather',
427
+ description: 'Get the current weather',
428
+ parameters: {
429
+ type: 'object',
430
+ properties: {
431
+ location: { type: 'string' },
432
+ },
433
+ required: ['location'],
434
+ },
435
+ },
436
+ },
437
+ ];
438
+
439
+ const modelWithTools = model.bindTools(tools);
440
+ const response = await modelWithTools.invoke([
441
+ new HumanMessage('What is the weather in Paris?'),
442
+ ]);
443
+ ```
444
+
445
+ ### 图像生成工作流
446
+
447
+ ```typescript
448
+ import { DoubaoImageGenerationClient } from 'ai-world-sdk';
449
+
450
+ const client = new DoubaoImageGenerationClient({});
677
451
 
678
452
  // 生成单张图像
679
- const result = await imageClient.generate({
453
+ const result = await client.generate({
680
454
  prompt: 'A futuristic city skyline at sunset',
681
- model: 'doubao-seedream-4-5-251128',
682
455
  size: '2K',
683
456
  quality: 'hd',
684
- n: 1,
685
457
  });
686
458
 
687
459
  console.log('图像 URL:', result.data[0]?.url);
688
460
 
689
461
  // 生成多张图像
690
- const multiResult = await imageClient.generate({
462
+ const multiResult = await client.generate({
691
463
  prompt: 'A beautiful landscape',
692
464
  n: 3,
693
465
  size: '2K',
@@ -698,39 +470,28 @@ multiResult.data.forEach((image, index) => {
698
470
  });
699
471
  ```
700
472
 
701
- ### 示例 4: 视频生成工作流
473
+ ### 视频生成工作流
702
474
 
703
475
  ```typescript
704
476
  import { VideoGenerationClient } from 'ai-world-sdk';
705
477
 
706
- const videoClient = new VideoGenerationClient({
707
- baseUrl: 'http://localhost:8000',
708
- token: 'your-token',
709
- });
478
+ const client = new VideoGenerationClient({});
710
479
 
711
- // 1. 创建视频生成任务
712
- const createTask = await videoClient.create({
713
- prompt: 'A beautiful sunset over the ocean with waves',
714
- model: 'doubao-seedance-1-0-pro-fast-251015',
480
+ // 1. 创建任务
481
+ const task = await client.create({
482
+ prompt: 'A beautiful sunset over the ocean',
715
483
  duration: 5,
716
484
  aspect_ratio: '16:9',
717
485
  resolution: '720p',
718
486
  });
719
487
 
720
- console.log('任务已创建,ID:', createTask.id);
721
-
722
- // 2. 查询任务状态
723
- const task = await videoClient.get(createTask.id);
724
- console.log('当前状态:', task.status);
725
-
726
- // 3. 轮询直到完成
727
- const result = await videoClient.poll(createTask.id, {
728
- interval: 3000, // 每 3 秒查询一次
729
- timeout: 300000, // 5 分钟超时
488
+ // 2. 轮询直到完成
489
+ const result = await client.poll(task.id, {
490
+ interval: 3000,
491
+ timeout: 300000,
730
492
  });
731
493
 
732
494
  if (result.status === 'succeeded') {
733
- console.log('视频生成成功!');
734
495
  console.log('视频 URL:', result.content?.video_url);
735
496
  if (result.content?.last_frame_url) {
736
497
  console.log('最后一帧:', result.content.last_frame_url);
@@ -740,147 +501,33 @@ if (result.status === 'succeeded') {
740
501
  }
741
502
  ```
742
503
 
743
- ### 示例 5: 批量处理
744
-
745
- ```typescript
746
- import { ChatGoogleGenerativeAI, HumanMessage } from 'ai-world-sdk';
747
-
748
- const model = new ChatGoogleGenerativeAI({
749
- baseUrl: 'http://localhost:8000',
750
- token: 'your-token',
751
- modelName: 'gemini-2.0-flash-exp-image-generation',
752
- });
753
-
754
- // 批量处理多个问题
755
- const questions = [
756
- 'What is artificial intelligence?',
757
- 'What is machine learning?',
758
- 'What is deep learning?',
759
- ];
760
-
761
- const responses = await model.batch(
762
- questions.map(q => [new HumanMessage(q)])
763
- );
764
-
765
- responses.forEach((response, index) => {
766
- console.log(`问题 ${index + 1}:`, questions[index]);
767
- console.log(`回答:`, response.content);
768
- console.log('---');
769
- });
770
- ```
771
-
772
- ### 示例 6: 工具调用
773
-
774
- ```typescript
775
- import {
776
- ChatGoogleGenerativeAI,
777
- HumanMessage,
778
- ToolDefinition,
779
- } from 'ai-world-sdk';
780
-
781
- const model = new ChatGoogleGenerativeAI({
782
- baseUrl: 'http://localhost:8000',
783
- token: 'your-token',
784
- modelName: 'gemini-2.0-flash-exp-image-generation',
785
- });
786
-
787
- const tools: ToolDefinition[] = [
788
- {
789
- type: 'function',
790
- function: {
791
- name: 'get_weather',
792
- description: 'Get the current weather in a location',
793
- parameters: {
794
- type: 'object',
795
- properties: {
796
- location: {
797
- type: 'string',
798
- description: 'The city and state, e.g. San Francisco, CA',
799
- },
800
- unit: {
801
- type: 'string',
802
- enum: ['celsius', 'fahrenheit'],
803
- description: 'The unit of temperature',
804
- },
805
- },
806
- required: ['location'],
807
- },
808
- },
809
- },
810
- ];
811
-
812
- const modelWithTools = model.bindTools(tools);
813
-
814
- const response = await modelWithTools.invoke([
815
- new HumanMessage('What is the weather in Paris?'),
816
- ]);
504
+ ## 支持的模型
817
505
 
818
- console.log('响应:', response.content);
819
- // 检查是否有工具调用
820
- if (response.tool_calls && response.tool_calls.length > 0) {
821
- console.log('工具调用:', response.tool_calls);
822
- }
823
- ```
506
+ ### 聊天模型
824
507
 
825
- ## 类型定义
508
+ | 提供商 | Provider | 模型示例 | 模型类 |
509
+ |--------|----------|----------|--------|
510
+ | OpenAI | `aihubmix` | `gpt-4o-mini`, `gpt-4`, `o1-preview` | `ChatOpenAI` |
511
+ | Google Gemini | `gemini` 或 `aihubmix` | `gemini-2.5-flash-image`, `gemini-1.5-pro` | `ChatGoogleGenerativeAI` |
512
+ | Anthropic Claude | `aihubmix` | `claude-3-sonnet-20240229`, `claude-3-opus-20240229` | `ChatAnthropic` |
513
+ | Doubao | `doubao` 或 `aihubmix` | `doubao-pro-4k`, `doubao-seedream-4-5-251128` | `ChatOpenAI` |
826
514
 
827
- ### 核心类型
515
+ **注意:**
516
+ - 使用 `aihubmix` provider 可以访问所有模型,推荐用于多模型场景
517
+ - 使用特定 provider(如 `gemini`、`doubao`)会直接调用对应的官方 API
828
518
 
829
- ```typescript
830
- // 消息类型
831
- export class HumanMessage extends BaseMessage { ... }
832
- export class SystemMessage extends BaseMessage { ... }
833
- export class AIMessage extends BaseMessage { ... }
834
- export class AIMessageChunk extends BaseMessage { ... }
835
-
836
- // 配置类型
837
- export interface BaseChatModelParams {
838
- temperature?: number;
839
- maxTokens?: number;
840
- topP?: number;
841
- modelName?: string;
842
- provider?: string;
843
- apiKey?: string;
844
- }
519
+ ### 图像生成模型
845
520
 
846
- export interface LangchainClientConfig {
847
- baseUrl?: string;
848
- token?: string;
849
- headers?: Record<string, string>;
850
- }
521
+ - **豆包 Seedream**: `doubao-seedream-4-5-251128` (默认)
522
+ - **Google Gemini**: `gemini-2.0-flash-exp-image-generation` (默认)
851
523
 
852
- // 工具类型
853
- export interface ToolDefinition {
854
- type: 'function';
855
- function: {
856
- name: string;
857
- description: string;
858
- parameters?: Record<string, any>;
859
- };
860
- }
524
+ ### 视频生成模型
861
525
 
862
- export interface BindOptions {
863
- temperature?: number;
864
- maxTokens?: number;
865
- topP?: number;
866
- tools?: ToolDefinition[];
867
- toolChoice?: 'auto' | 'none' | 'required' | { type: 'function'; function: { name: string } };
868
- }
869
- ```
526
+ - **豆包 Seedance**: `doubao-seedance-1-0-pro-fast-251015` (默认,推荐)
870
527
 
871
528
  ## 错误处理
872
529
 
873
- 所有 API 调用都可能抛出错误。建议使用 try-catch 进行错误处理:
874
-
875
530
  ```typescript
876
- import { ChatGoogleGenerativeAI, HumanMessage } from 'ai-world-sdk';
877
-
878
- const model = new ChatGoogleGenerativeAI({
879
- baseUrl: 'http://localhost:8000',
880
- token: 'your-token',
881
- modelName: 'gemini-2.0-flash-exp-image-generation',
882
- });
883
-
884
531
  try {
885
532
  const response = await model.invoke([
886
533
  new HumanMessage('Hello!'),
@@ -894,25 +541,6 @@ try {
894
541
  }
895
542
  ```
896
543
 
897
- ## 参考地址
898
-
899
- ### 官方文档
900
-
901
- - **AI World 平台**: [项目仓库](https://github.com/your-org/ai-world)
902
- - **LangChain.js**: [https://github.com/langchain-ai/langchainjs](https://github.com/langchain-ai/langchainjs)
903
- - **火山引擎方舟平台**: [https://www.volcengine.com/docs/82379](https://www.volcengine.com/docs/82379)
904
-
905
- ### API 文档
906
-
907
- - **图像生成 API**: [https://www.volcengine.com/docs/82379/1824121](https://www.volcengine.com/docs/82379/1824121)
908
- - **视频生成 API**: [https://www.volcengine.com/docs/82379/1366799](https://www.volcengine.com/docs/82379/1366799)
909
- - **对话 API**: [https://www.volcengine.com/docs/82379/1541595](https://www.volcengine.com/docs/82379/1541595)
910
-
911
- ### 模型文档
912
-
913
- - **Seedream 4.0-4.5 教程**: [https://www.volcengine.com/docs/82379/1824121?lang=zh](https://www.volcengine.com/docs/82379/1824121?lang=zh)
914
- - **Seedance 提示词指南**: [https://www.volcengine.com/docs/82379/1901652](https://www.volcengine.com/docs/82379/1901652)
915
-
916
544
  ## 开发
917
545
 
918
546
  ### 构建
@@ -921,121 +549,34 @@ try {
921
549
  npm run build
922
550
  ```
923
551
 
924
- 这会执行以下操作:
925
- - 清理 `dist/` 目录
926
- - 编译 TypeScript 源代码到 `dist/` 目录
927
- - **自动生成 `.d.ts` 类型声明文件**
928
-
929
- #### 生成 TypeScript 声明文件 (.d.ts)
930
-
931
- 项目已配置为自动生成类型声明文件。配置说明:
932
-
933
- 1. **tsconfig.json 配置**:
934
- ```json
935
- {
936
- "compilerOptions": {
937
- "declaration": true, // 启用声明文件生成
938
- "outDir": "./dist", // 输出目录
939
- "rootDir": "./src" // 源代码目录
940
- }
941
- }
942
- ```
943
-
944
- 2. **构建命令**:
945
- ```bash
946
- npm run build
947
- # 等同于: rm -rf dist && tsc
948
- ```
949
-
950
- 3. **生成的文件**:
951
- 运行构建后,`dist/` 目录会包含:
952
- - `.js` 文件(编译后的 JavaScript)
953
- - `.d.ts` 文件(TypeScript 类型声明)
954
-
955
- 例如:
956
- ```
957
- dist/
958
- ├── index.js # 编译后的代码
959
- ├── index.d.ts # 类型声明文件
960
- ├── base.js
961
- ├── base.d.ts
962
- └── ...
963
- ```
964
-
965
- 4. **package.json 配置**:
966
- ```json
967
- {
968
- "main": "dist/index.js",
969
- "types": "dist/index.d.ts" // 指定类型声明文件入口
970
- }
971
- ```
972
-
973
- 5. **验证声明文件**:
974
- ```bash
975
- # 检查 dist 目录中的 .d.ts 文件
976
- ls -la dist/*.d.ts
977
-
978
- # 或者查看特定文件的声明
979
- cat dist/index.d.ts
980
- ```
981
-
982
552
  ### 测试
983
553
 
984
554
  ```bash
985
- # 运行所有测试
986
555
  npm test
987
-
988
- # 运行特定测试
556
+ # 或运行特定测试
989
557
  npm run test:stream
990
558
  npm run test:image-generation
991
559
  npm run test:video-generation
992
560
  ```
993
561
 
994
- ### 项目结构
995
-
996
- ```
997
- ai-world-sdk/
998
- ├── src/
999
- │ ├── base.ts # 基础聊天模型类
1000
- │ ├── config.ts # 全局配置管理
1001
- │ ├── messages.ts # 消息类型定义
1002
- │ ├── image_generation.ts # 图像生成客户端
1003
- │ ├── video_generation.ts # 视频生成客户端
1004
- │ ├── chat_models/ # 具体模型实现
1005
- │ │ ├── openai.ts
1006
- │ │ ├── google.ts
1007
- │ │ └── anthropic.ts
1008
- │ └── index.ts # 主入口文件
1009
- ├── __tests__/ # 测试文件
1010
- ├── package.json
1011
- ├── tsconfig.json
1012
- └── README.md
1013
- ```
1014
-
1015
- ## 发布
562
+ ## 参考链接
1016
563
 
1017
- ### 安装
1018
-
1019
- ```bash
1020
- npm install ai-world-sdk
1021
- ```
564
+ - [LangChain.js](https://github.com/langchain-ai/langchainjs) - 设计灵感来源
565
+ - [火山引擎方舟平台](https://www.volcengine.com/docs/82379) - 图像/视频生成 API 文档
1022
566
 
1023
567
  ## 许可证
1024
568
 
1025
569
  MIT
1026
570
 
1027
- ## 贡献
1028
-
1029
- 欢迎提交 Issue 和 Pull Request!
1030
-
1031
571
  ## 更新日志
1032
572
 
1033
- ### 1.0.0
573
+ ### 1.0.3
574
+ - ✨ 新增 Google Gemini 图像生成客户端
575
+ - ✨ 全局配置支持自动从浏览器环境获取
576
+ - ✨ 新增调试模式
577
+ - 🔧 改进日志输出
1034
578
 
579
+ ### 1.0.0
1035
580
  - ✨ 初始版本发布
1036
- - ✨ 支持聊天模型(OpenAI、Gemini、Claude、Doubao)
1037
- - ✨ 支持图像生成(Seedream)
1038
- - ✨ 支持视频生成(Seedance)
1039
- - ✨ 支持全局配置(baseUrl、token)
581
+ - ✨ 支持聊天模型、图像生成、视频生成
1040
582
  - ✨ 兼容 LangChain.js 接口风格
1041
- - ✨ 完整的 TypeScript 类型定义