ai-world-sdk 1.0.17 → 1.1.0
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 +106 -1
- package/dist/__tests__/example.test.js +10 -29
- package/dist/auth.d.ts +48 -0
- package/dist/auth.js +89 -0
- package/dist/base.js +6 -0
- package/dist/config.d.ts +36 -3
- package/dist/config.js +115 -8
- package/dist/doubao-image-generation.js +2 -0
- package/dist/download.js +4 -0
- package/dist/gemini-image-generation.js +2 -0
- package/dist/index.d.ts +3 -2
- package/dist/index.js +8 -2
- package/dist/video_generation.js +6 -0
- package/package.json +4 -2
package/README.md
CHANGED
|
@@ -11,6 +11,7 @@ TypeScript SDK for AI World Platform - 一个功能完整的 AI 应用开发 SDK
|
|
|
11
11
|
- 🎨 **图像生成**: 支持豆包 Seedream 和 Google Gemini
|
|
12
12
|
- 🎬 **视频生成**: 支持豆包 Seedance
|
|
13
13
|
- 📥 **下载代理**: 支持流式下载和普通下载任意 URL 的二进制文件
|
|
14
|
+
- 🔐 **用户认证**: 支持获取当前登录用户信息
|
|
14
15
|
- ⚙️ **全局配置**: 自动从浏览器环境获取配置,简化初始化
|
|
15
16
|
- 🐛 **调试模式**: 支持详细的请求/响应日志
|
|
16
17
|
|
|
@@ -135,7 +136,29 @@ if (result.status === 'succeeded') {
|
|
|
135
136
|
}
|
|
136
137
|
```
|
|
137
138
|
|
|
138
|
-
### 5.
|
|
139
|
+
### 5. 用户认证
|
|
140
|
+
|
|
141
|
+
```typescript
|
|
142
|
+
import { getCurrentUserInfo, AuthClient } from 'ai-world-sdk';
|
|
143
|
+
|
|
144
|
+
// 方式1: 使用便捷函数(推荐)
|
|
145
|
+
const userInfo = await getCurrentUserInfo();
|
|
146
|
+
console.log('用户信息:', userInfo);
|
|
147
|
+
console.log('用户ID:', userInfo.id);
|
|
148
|
+
console.log('用户名:', userInfo.full_name);
|
|
149
|
+
console.log('邮箱:', userInfo.email);
|
|
150
|
+
|
|
151
|
+
// 方式2: 使用 AuthClient 类
|
|
152
|
+
const authClient = new AuthClient({
|
|
153
|
+
baseUrl: 'http://localhost:8000', // 可选,默认使用全局配置
|
|
154
|
+
token: 'your-token', // 可选,默认使用全局配置
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
const userInfo2 = await authClient.getCurrentUserInfo();
|
|
158
|
+
console.log('用户信息:', userInfo2);
|
|
159
|
+
```
|
|
160
|
+
|
|
161
|
+
### 6. 下载代理
|
|
139
162
|
|
|
140
163
|
```typescript
|
|
141
164
|
import { DownloadClient } from 'ai-world-sdk';
|
|
@@ -998,6 +1021,47 @@ const result4 = await client.generate({
|
|
|
998
1021
|
console.log('4K 图像:', result4.data[0]?.b64_json ? 'Base64 编码' : result4.data[0]?.url);
|
|
999
1022
|
```
|
|
1000
1023
|
|
|
1024
|
+
### 用户认证工作流
|
|
1025
|
+
|
|
1026
|
+
```typescript
|
|
1027
|
+
import { getCurrentUserInfo, AuthClient } from 'ai-world-sdk';
|
|
1028
|
+
|
|
1029
|
+
// 1. 获取当前用户信息(使用便捷函数)
|
|
1030
|
+
try {
|
|
1031
|
+
const userInfo = await getCurrentUserInfo();
|
|
1032
|
+
console.log('用户ID:', userInfo.id);
|
|
1033
|
+
console.log('用户名:', userInfo.full_name);
|
|
1034
|
+
console.log('邮箱:', userInfo.email);
|
|
1035
|
+
console.log('是否超级用户:', userInfo.is_superuser);
|
|
1036
|
+
} catch (error) {
|
|
1037
|
+
console.error('获取用户信息失败:', error);
|
|
1038
|
+
// 可能需要重新登录
|
|
1039
|
+
}
|
|
1040
|
+
|
|
1041
|
+
// 2. 使用 AuthClient 类(需要自定义配置时)
|
|
1042
|
+
const authClient = new AuthClient({
|
|
1043
|
+
baseUrl: 'http://localhost:8000',
|
|
1044
|
+
token: 'your-jwt-token',
|
|
1045
|
+
});
|
|
1046
|
+
|
|
1047
|
+
const userInfo = await authClient.getCurrentUserInfo();
|
|
1048
|
+
|
|
1049
|
+
// 3. 检查用户权限
|
|
1050
|
+
if (userInfo.is_superuser) {
|
|
1051
|
+
console.log('用户是超级管理员');
|
|
1052
|
+
}
|
|
1053
|
+
|
|
1054
|
+
if (userInfo.is_active) {
|
|
1055
|
+
console.log('用户账户已激活');
|
|
1056
|
+
}
|
|
1057
|
+
|
|
1058
|
+
// 4. 显示用户信息
|
|
1059
|
+
console.log(`欢迎, ${userInfo.full_name || userInfo.email || '用户'}`);
|
|
1060
|
+
if (userInfo.avatar_url) {
|
|
1061
|
+
console.log('头像:', userInfo.avatar_url);
|
|
1062
|
+
}
|
|
1063
|
+
```
|
|
1064
|
+
|
|
1001
1065
|
### 视频生成工作流
|
|
1002
1066
|
|
|
1003
1067
|
```typescript
|
|
@@ -1029,6 +1093,47 @@ if (result.status === 'succeeded') {
|
|
|
1029
1093
|
}
|
|
1030
1094
|
```
|
|
1031
1095
|
|
|
1096
|
+
### 用户认证工作流
|
|
1097
|
+
|
|
1098
|
+
```typescript
|
|
1099
|
+
import { getCurrentUserInfo, AuthClient } from 'ai-world-sdk';
|
|
1100
|
+
|
|
1101
|
+
// 1. 获取当前用户信息(使用便捷函数)
|
|
1102
|
+
try {
|
|
1103
|
+
const userInfo = await getCurrentUserInfo();
|
|
1104
|
+
console.log('用户ID:', userInfo.id);
|
|
1105
|
+
console.log('用户名:', userInfo.full_name);
|
|
1106
|
+
console.log('邮箱:', userInfo.email);
|
|
1107
|
+
console.log('是否超级用户:', userInfo.is_superuser);
|
|
1108
|
+
} catch (error) {
|
|
1109
|
+
console.error('获取用户信息失败:', error);
|
|
1110
|
+
// 可能需要重新登录
|
|
1111
|
+
}
|
|
1112
|
+
|
|
1113
|
+
// 2. 使用 AuthClient 类(需要自定义配置时)
|
|
1114
|
+
const authClient = new AuthClient({
|
|
1115
|
+
baseUrl: 'http://localhost:8000',
|
|
1116
|
+
token: 'your-jwt-token',
|
|
1117
|
+
});
|
|
1118
|
+
|
|
1119
|
+
const userInfo = await authClient.getCurrentUserInfo();
|
|
1120
|
+
|
|
1121
|
+
// 3. 检查用户权限
|
|
1122
|
+
if (userInfo.is_superuser) {
|
|
1123
|
+
console.log('用户是超级管理员');
|
|
1124
|
+
}
|
|
1125
|
+
|
|
1126
|
+
if (userInfo.is_active) {
|
|
1127
|
+
console.log('用户账户已激活');
|
|
1128
|
+
}
|
|
1129
|
+
|
|
1130
|
+
// 4. 显示用户信息
|
|
1131
|
+
console.log(`欢迎, ${userInfo.full_name || userInfo.email || '用户'}`);
|
|
1132
|
+
if (userInfo.avatar_url) {
|
|
1133
|
+
console.log('头像:', userInfo.avatar_url);
|
|
1134
|
+
}
|
|
1135
|
+
```
|
|
1136
|
+
|
|
1032
1137
|
### 下载代理工作流
|
|
1033
1138
|
|
|
1034
1139
|
```typescript
|
|
@@ -39,6 +39,7 @@ var __importStar = (this && this.__importStar) || (function () {
|
|
|
39
39
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
40
40
|
const dotenv = __importStar(require("dotenv"));
|
|
41
41
|
const index_1 = require("../index");
|
|
42
|
+
const fs_1 = require("fs");
|
|
42
43
|
// Load environment variables from .env file
|
|
43
44
|
dotenv.config();
|
|
44
45
|
index_1.sdkConfig.setBaseUrl("http://localhost:8000");
|
|
@@ -611,33 +612,18 @@ describe("Langchain SDK Tests", () => {
|
|
|
611
612
|
}, 120000);
|
|
612
613
|
test("GeminiImageGenerationClient - 多图输入图像生成", async () => {
|
|
613
614
|
const imageClient = new index_1.GeminiImageGenerationClient({});
|
|
614
|
-
// 先生成两张基础图片
|
|
615
|
-
const
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
aspect_ratio: '1:1',
|
|
619
|
-
response_modalities: ['IMAGE'],
|
|
620
|
-
});
|
|
621
|
-
const baseResult2 = await imageClient.generate({
|
|
622
|
-
prompt: 'A simple, modern logo with the letters G and A in a white circle',
|
|
623
|
-
model: 'gemini-2.5-flash-image',
|
|
624
|
-
aspect_ratio: '1:1',
|
|
625
|
-
response_modalities: ['IMAGE'],
|
|
626
|
-
});
|
|
627
|
-
expect(baseResult1.data.length).toBeGreaterThan(0);
|
|
628
|
-
expect(baseResult2.data.length).toBeGreaterThan(0);
|
|
629
|
-
const image1 = baseResult1.data[0]?.b64_json || baseResult1.data[0]?.url;
|
|
630
|
-
const image2 = baseResult2.data[0]?.b64_json || baseResult2.data[0]?.url;
|
|
631
|
-
expect(image1).toBeDefined();
|
|
632
|
-
expect(image2).toBeDefined();
|
|
633
|
-
// 使用多张图片作为输入(gemini-2.5-flash-image 最多支持 3 张)
|
|
615
|
+
const image1 = "";
|
|
616
|
+
const image2 = "";
|
|
617
|
+
const image3 = "";
|
|
618
|
+
// 使用多张图片作为输入
|
|
634
619
|
const result = await imageClient.generate({
|
|
635
|
-
prompt: '
|
|
636
|
-
image: [image1, image2],
|
|
637
|
-
model: 'gemini-
|
|
620
|
+
prompt: '将图1上半部分换成图3颜色,下半部分换成图2颜色',
|
|
621
|
+
image: [image1, image2, image3],
|
|
622
|
+
model: 'gemini-3-pro-image-preview',
|
|
638
623
|
aspect_ratio: '1:1',
|
|
639
624
|
response_modalities: ['IMAGE'],
|
|
640
625
|
});
|
|
626
|
+
(0, fs_1.writeFileSync)(__dirname + "/test_1.json", JSON.stringify(result.data));
|
|
641
627
|
expect(result).toBeDefined();
|
|
642
628
|
expect(result.data).toBeDefined();
|
|
643
629
|
expect(result.data.length).toBeGreaterThan(0);
|
|
@@ -864,12 +850,7 @@ describe("Langchain SDK Tests", () => {
|
|
|
864
850
|
expect(index_1.sdkConfig.getDebug()).toBe(true);
|
|
865
851
|
index_1.sdkConfig.setDebug(false);
|
|
866
852
|
expect(index_1.sdkConfig.getDebug()).toBe(false);
|
|
867
|
-
//
|
|
868
|
-
index_1.sdkConfig.reset();
|
|
869
|
-
expect(index_1.sdkConfig.getServerUrl()).toBeNull();
|
|
870
|
-
expect(index_1.sdkConfig.getToken()).toBeNull();
|
|
871
|
-
expect(Object.keys(index_1.sdkConfig.getHeaders()).length).toBe(0);
|
|
872
|
-
expect(index_1.sdkConfig.getDebug()).toBe(false);
|
|
853
|
+
// 注意: reset 方法已被移除,不再测试
|
|
873
854
|
// 恢复原始配置
|
|
874
855
|
if (originalBaseUrl)
|
|
875
856
|
index_1.sdkConfig.setBaseUrl(originalBaseUrl);
|
package/dist/auth.d.ts
ADDED
|
@@ -0,0 +1,48 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Auth Client
|
|
3
|
+
* 认证客户端
|
|
4
|
+
* 提供用户认证相关的 API
|
|
5
|
+
*/
|
|
6
|
+
export interface AuthConfig {
|
|
7
|
+
baseUrl?: string;
|
|
8
|
+
token?: string;
|
|
9
|
+
headers?: Record<string, string>;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* User information interface
|
|
13
|
+
* 用户信息接口
|
|
14
|
+
*/
|
|
15
|
+
export interface UserInfo {
|
|
16
|
+
id: number;
|
|
17
|
+
email?: string;
|
|
18
|
+
full_name?: string;
|
|
19
|
+
avatar_url?: string;
|
|
20
|
+
feishu_user_id: string;
|
|
21
|
+
is_active: boolean;
|
|
22
|
+
is_superuser: boolean;
|
|
23
|
+
created_at: string;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Auth Client
|
|
27
|
+
* 认证客户端类
|
|
28
|
+
*/
|
|
29
|
+
export declare class AuthClient {
|
|
30
|
+
private baseUrl;
|
|
31
|
+
private headers;
|
|
32
|
+
constructor(config?: AuthConfig);
|
|
33
|
+
/**
|
|
34
|
+
* Get current user information
|
|
35
|
+
* 获取当前用户信息
|
|
36
|
+
*
|
|
37
|
+
* @returns Promise that resolves to UserInfo
|
|
38
|
+
*/
|
|
39
|
+
getCurrentUserInfo(): Promise<UserInfo>;
|
|
40
|
+
}
|
|
41
|
+
/**
|
|
42
|
+
* Get current user information (convenience function)
|
|
43
|
+
* 获取当前用户信息(便捷函数)
|
|
44
|
+
*
|
|
45
|
+
* @param config - Optional auth configuration
|
|
46
|
+
* @returns Promise that resolves to UserInfo
|
|
47
|
+
*/
|
|
48
|
+
export declare function getCurrentUserInfo(config?: AuthConfig): Promise<UserInfo>;
|
package/dist/auth.js
ADDED
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Auth Client
|
|
4
|
+
* 认证客户端
|
|
5
|
+
* 提供用户认证相关的 API
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.AuthClient = void 0;
|
|
9
|
+
exports.getCurrentUserInfo = getCurrentUserInfo;
|
|
10
|
+
const config_1 = require("./config");
|
|
11
|
+
const log_1 = require("./log");
|
|
12
|
+
/**
|
|
13
|
+
* Auth Client
|
|
14
|
+
* 认证客户端类
|
|
15
|
+
*/
|
|
16
|
+
class AuthClient {
|
|
17
|
+
constructor(config = {}) {
|
|
18
|
+
// 使用配置的 baseUrl 或全局配置
|
|
19
|
+
this.baseUrl =
|
|
20
|
+
config.baseUrl ||
|
|
21
|
+
config_1.sdkConfig.getServerUrl() ||
|
|
22
|
+
(typeof window !== "undefined" ? window.location.origin : "");
|
|
23
|
+
// 合并 headers
|
|
24
|
+
const globalHeaders = config_1.sdkConfig.getHeaders();
|
|
25
|
+
const globalToken = config_1.sdkConfig.getToken() || config.token;
|
|
26
|
+
this.headers = {
|
|
27
|
+
"Content-Type": "application/json",
|
|
28
|
+
...globalHeaders,
|
|
29
|
+
...config.headers,
|
|
30
|
+
};
|
|
31
|
+
// 如果有 token,添加到 Authorization header
|
|
32
|
+
if (globalToken) {
|
|
33
|
+
this.headers["Authorization"] = `Bearer ${globalToken}`;
|
|
34
|
+
}
|
|
35
|
+
else if (config.token) {
|
|
36
|
+
this.headers["Authorization"] = `Bearer ${config.token}`;
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Get current user information
|
|
41
|
+
* 获取当前用户信息
|
|
42
|
+
*
|
|
43
|
+
* @returns Promise that resolves to UserInfo
|
|
44
|
+
*/
|
|
45
|
+
async getCurrentUserInfo() {
|
|
46
|
+
// 检查版本兼容性
|
|
47
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
48
|
+
const url = `${this.baseUrl}/api/auth/me`;
|
|
49
|
+
(0, log_1.debugLog)("Get current user info request:", { url });
|
|
50
|
+
(0, log_1.logRequest)("GET", url, this.headers);
|
|
51
|
+
try {
|
|
52
|
+
const response = await fetch(url, {
|
|
53
|
+
method: "GET",
|
|
54
|
+
headers: this.headers,
|
|
55
|
+
});
|
|
56
|
+
if (!response.ok) {
|
|
57
|
+
const errorText = await response.text();
|
|
58
|
+
let errorMessage = `Get user info failed: ${response.status} ${response.statusText}`;
|
|
59
|
+
try {
|
|
60
|
+
const errorJson = JSON.parse(errorText);
|
|
61
|
+
errorMessage = errorJson.detail || errorMessage;
|
|
62
|
+
}
|
|
63
|
+
catch {
|
|
64
|
+
errorMessage = errorText || errorMessage;
|
|
65
|
+
}
|
|
66
|
+
throw new Error(errorMessage);
|
|
67
|
+
}
|
|
68
|
+
const data = (await response.json());
|
|
69
|
+
(0, log_1.logResponse)(response.status, response.statusText, response.headers, data);
|
|
70
|
+
return data;
|
|
71
|
+
}
|
|
72
|
+
catch (error) {
|
|
73
|
+
(0, log_1.debugLog)("Get current user info error:", error);
|
|
74
|
+
throw error;
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
exports.AuthClient = AuthClient;
|
|
79
|
+
/**
|
|
80
|
+
* Get current user information (convenience function)
|
|
81
|
+
* 获取当前用户信息(便捷函数)
|
|
82
|
+
*
|
|
83
|
+
* @param config - Optional auth configuration
|
|
84
|
+
* @returns Promise that resolves to UserInfo
|
|
85
|
+
*/
|
|
86
|
+
async function getCurrentUserInfo(config) {
|
|
87
|
+
const client = new AuthClient(config);
|
|
88
|
+
return client.getCurrentUserInfo();
|
|
89
|
+
}
|
package/dist/base.js
CHANGED
|
@@ -33,6 +33,8 @@ class BaseChatModel {
|
|
|
33
33
|
* 遵循标准 LangChain API
|
|
34
34
|
*/
|
|
35
35
|
async invoke(messages) {
|
|
36
|
+
// 检查版本兼容性
|
|
37
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
36
38
|
const options = this._mergeOptions({});
|
|
37
39
|
const requestBody = {
|
|
38
40
|
messages,
|
|
@@ -82,6 +84,8 @@ class BaseChatModel {
|
|
|
82
84
|
* 遵循标准 LangChain API,返回 AIMessageChunk
|
|
83
85
|
*/
|
|
84
86
|
async *stream(messages) {
|
|
87
|
+
// 检查版本兼容性
|
|
88
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
85
89
|
const options = this._mergeOptions({});
|
|
86
90
|
const requestBody = {
|
|
87
91
|
messages,
|
|
@@ -153,6 +157,8 @@ class BaseChatModel {
|
|
|
153
157
|
* 遵循标准 LangChain API
|
|
154
158
|
*/
|
|
155
159
|
async batch(messagesList) {
|
|
160
|
+
// 检查版本兼容性
|
|
161
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
156
162
|
const requestBody = {
|
|
157
163
|
messages_list: messagesList,
|
|
158
164
|
config: {
|
package/dist/config.d.ts
CHANGED
|
@@ -2,11 +2,20 @@
|
|
|
2
2
|
* Global SDK Configuration
|
|
3
3
|
* 全局 SDK 配置
|
|
4
4
|
*/
|
|
5
|
+
/**
|
|
6
|
+
* 版本兼容性错误
|
|
7
|
+
*/
|
|
8
|
+
export declare class VersionCompatibilityError extends Error {
|
|
9
|
+
constructor(message: string);
|
|
10
|
+
}
|
|
5
11
|
declare class SDKConfig {
|
|
6
12
|
private _baseUrl;
|
|
7
13
|
private _token;
|
|
8
14
|
private _headers;
|
|
9
15
|
private _debug;
|
|
16
|
+
private _pluginId;
|
|
17
|
+
private _versionCompatible;
|
|
18
|
+
private _versionCheckPromise;
|
|
10
19
|
constructor();
|
|
11
20
|
/**
|
|
12
21
|
* Set global base URL
|
|
@@ -49,10 +58,34 @@ declare class SDKConfig {
|
|
|
49
58
|
*/
|
|
50
59
|
getDebug(): boolean;
|
|
51
60
|
/**
|
|
52
|
-
*
|
|
53
|
-
*
|
|
61
|
+
* Set plugin ID
|
|
62
|
+
* 设置插件 ID
|
|
63
|
+
*/
|
|
64
|
+
setPluginId(pluginId: string): void;
|
|
65
|
+
/**
|
|
66
|
+
* Get plugin ID
|
|
67
|
+
* 获取插件 ID(从 window.__INITIAL_DATA__ 自动获取或手动设置)
|
|
68
|
+
*/
|
|
69
|
+
getPluginId(): string | null;
|
|
70
|
+
/**
|
|
71
|
+
* Check version compatibility with backend
|
|
72
|
+
* 检查与后端的版本兼容性
|
|
73
|
+
*/
|
|
74
|
+
checkVersionCompatibility(): Promise<boolean>;
|
|
75
|
+
/**
|
|
76
|
+
* 执行版本兼容性检查
|
|
77
|
+
*/
|
|
78
|
+
private _performVersionCheck;
|
|
79
|
+
/**
|
|
80
|
+
* Get version compatibility status
|
|
81
|
+
* 获取版本兼容性状态
|
|
82
|
+
*/
|
|
83
|
+
isVersionCompatible(): boolean | null;
|
|
84
|
+
/**
|
|
85
|
+
* Ensure version is compatible, throw error if not
|
|
86
|
+
* 确保版本兼容,如果不兼容则抛出错误
|
|
54
87
|
*/
|
|
55
|
-
|
|
88
|
+
ensureVersionCompatible(): void;
|
|
56
89
|
}
|
|
57
90
|
export declare const sdkConfig: SDKConfig;
|
|
58
91
|
export {};
|
package/dist/config.js
CHANGED
|
@@ -4,13 +4,29 @@
|
|
|
4
4
|
* 全局 SDK 配置
|
|
5
5
|
*/
|
|
6
6
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
7
|
-
exports.sdkConfig = void 0;
|
|
7
|
+
exports.sdkConfig = exports.VersionCompatibilityError = void 0;
|
|
8
|
+
// SDK 版本号(构建时自动从 package.json 更新)
|
|
9
|
+
// 此版本号会在运行 npm run build 时自动从 package.json 读取并更新
|
|
10
|
+
const SDK_VERSION = "1.1.0";
|
|
11
|
+
/**
|
|
12
|
+
* 版本兼容性错误
|
|
13
|
+
*/
|
|
14
|
+
class VersionCompatibilityError extends Error {
|
|
15
|
+
constructor(message) {
|
|
16
|
+
super(message);
|
|
17
|
+
this.name = "VersionCompatibilityError";
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
exports.VersionCompatibilityError = VersionCompatibilityError;
|
|
8
21
|
class SDKConfig {
|
|
9
22
|
constructor() {
|
|
10
23
|
this._baseUrl = null;
|
|
11
24
|
this._token = null;
|
|
12
25
|
this._headers = {};
|
|
13
26
|
this._debug = false;
|
|
27
|
+
this._pluginId = null;
|
|
28
|
+
this._versionCompatible = null; // null 表示未检查,true/false 表示检查结果
|
|
29
|
+
this._versionCheckPromise = null; // 版本检查的 Promise,避免重复请求
|
|
14
30
|
// 通过cookie获取token
|
|
15
31
|
try {
|
|
16
32
|
const cookieString = typeof document !== 'undefined' ? document.cookie : '';
|
|
@@ -27,6 +43,23 @@ class SDKConfig {
|
|
|
27
43
|
// 通过cookie获取baseUrl
|
|
28
44
|
const baseUrl = typeof window !== 'undefined' ? window.location.origin : '';
|
|
29
45
|
this._baseUrl = baseUrl;
|
|
46
|
+
// 从 window.__INITIAL_DATA__ 获取 plugin_id(SSR 插件环境)
|
|
47
|
+
try {
|
|
48
|
+
if (typeof window !== 'undefined' && window.__INITIAL_DATA__) {
|
|
49
|
+
const initialData = window.__INITIAL_DATA__;
|
|
50
|
+
if (initialData.plugin_id) {
|
|
51
|
+
this._headers['X-Plugin-Id'] = this._pluginId = initialData.plugin_id;
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
catch (error) {
|
|
56
|
+
console.warn('Failed to read plugin_id from __INITIAL_DATA__:', error);
|
|
57
|
+
}
|
|
58
|
+
this._headers['X-SDK-Version'] = SDK_VERSION;
|
|
59
|
+
// 自动检查版本兼容性(异步,不阻塞初始化)
|
|
60
|
+
this.checkVersionCompatibility().catch((error) => {
|
|
61
|
+
console.warn('版本兼容性检查失败:', error);
|
|
62
|
+
});
|
|
30
63
|
}
|
|
31
64
|
/**
|
|
32
65
|
* Set global base URL
|
|
@@ -85,14 +118,88 @@ class SDKConfig {
|
|
|
85
118
|
return this._debug;
|
|
86
119
|
}
|
|
87
120
|
/**
|
|
88
|
-
*
|
|
89
|
-
*
|
|
121
|
+
* Set plugin ID
|
|
122
|
+
* 设置插件 ID
|
|
90
123
|
*/
|
|
91
|
-
|
|
92
|
-
this.
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
124
|
+
setPluginId(pluginId) {
|
|
125
|
+
this._pluginId = pluginId;
|
|
126
|
+
}
|
|
127
|
+
/**
|
|
128
|
+
* Get plugin ID
|
|
129
|
+
* 获取插件 ID(从 window.__INITIAL_DATA__ 自动获取或手动设置)
|
|
130
|
+
*/
|
|
131
|
+
getPluginId() {
|
|
132
|
+
return this._pluginId;
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Check version compatibility with backend
|
|
136
|
+
* 检查与后端的版本兼容性
|
|
137
|
+
*/
|
|
138
|
+
async checkVersionCompatibility() {
|
|
139
|
+
// 如果已经有检查结果,直接返回
|
|
140
|
+
if (this._versionCompatible !== null) {
|
|
141
|
+
return this._versionCompatible;
|
|
142
|
+
}
|
|
143
|
+
// 如果正在检查中,返回现有的 Promise
|
|
144
|
+
if (this._versionCheckPromise) {
|
|
145
|
+
return this._versionCheckPromise;
|
|
146
|
+
}
|
|
147
|
+
// 开始新的检查
|
|
148
|
+
this._versionCheckPromise = this._performVersionCheck();
|
|
149
|
+
const result = await this._versionCheckPromise;
|
|
150
|
+
this._versionCheckPromise = null;
|
|
151
|
+
return result;
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* 执行版本兼容性检查
|
|
155
|
+
*/
|
|
156
|
+
async _performVersionCheck() {
|
|
157
|
+
const baseUrl = this._baseUrl || (typeof window !== 'undefined' ? window.location.origin : '');
|
|
158
|
+
if (!baseUrl) {
|
|
159
|
+
this._versionCompatible = true;
|
|
160
|
+
return true;
|
|
161
|
+
}
|
|
162
|
+
try {
|
|
163
|
+
const response = await fetch(`${baseUrl}/api/sdk/version-check`, {
|
|
164
|
+
method: 'POST',
|
|
165
|
+
headers: {
|
|
166
|
+
'Content-Type': 'application/json',
|
|
167
|
+
'X-SDK-Version': SDK_VERSION,
|
|
168
|
+
},
|
|
169
|
+
body: JSON.stringify({ sdk_version: SDK_VERSION }),
|
|
170
|
+
});
|
|
171
|
+
if (!response.ok) {
|
|
172
|
+
this._versionCompatible = true;
|
|
173
|
+
return true;
|
|
174
|
+
}
|
|
175
|
+
const data = await response.json();
|
|
176
|
+
this._versionCompatible = data.compatible;
|
|
177
|
+
if (!data.compatible) {
|
|
178
|
+
console.error(`SDK 版本不兼容: ${data.message}`);
|
|
179
|
+
}
|
|
180
|
+
return data.compatible;
|
|
181
|
+
}
|
|
182
|
+
catch (error) {
|
|
183
|
+
console.warn('版本兼容性检查失败:', error);
|
|
184
|
+
this._versionCompatible = false;
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
/**
|
|
189
|
+
* Get version compatibility status
|
|
190
|
+
* 获取版本兼容性状态
|
|
191
|
+
*/
|
|
192
|
+
isVersionCompatible() {
|
|
193
|
+
return this._versionCompatible;
|
|
194
|
+
}
|
|
195
|
+
/**
|
|
196
|
+
* Ensure version is compatible, throw error if not
|
|
197
|
+
* 确保版本兼容,如果不兼容则抛出错误
|
|
198
|
+
*/
|
|
199
|
+
ensureVersionCompatible() {
|
|
200
|
+
if (this._versionCompatible === false) {
|
|
201
|
+
throw new VersionCompatibilityError('请更新 ai-world-sdk 到最新版本, 当前版本: ' + SDK_VERSION);
|
|
202
|
+
}
|
|
96
203
|
}
|
|
97
204
|
}
|
|
98
205
|
// 导出单例实例
|
package/dist/download.js
CHANGED
|
@@ -43,6 +43,8 @@ class DownloadClient {
|
|
|
43
43
|
* @returns Promise that resolves to a Blob
|
|
44
44
|
*/
|
|
45
45
|
async download(options) {
|
|
46
|
+
// 检查版本兼容性
|
|
47
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
46
48
|
const { url, filename } = options;
|
|
47
49
|
if (!url) {
|
|
48
50
|
throw new Error("URL is required");
|
|
@@ -104,6 +106,8 @@ class DownloadClient {
|
|
|
104
106
|
* ```
|
|
105
107
|
*/
|
|
106
108
|
async *streamDownload(options) {
|
|
109
|
+
// 检查版本兼容性
|
|
110
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
107
111
|
const { url, filename } = options;
|
|
108
112
|
if (!url) {
|
|
109
113
|
throw new Error("URL is required");
|
|
@@ -36,6 +36,8 @@ class GeminiImageGenerationClient {
|
|
|
36
36
|
* - response_modalities: 响应模态,["TEXT", "IMAGE"] 或 ["IMAGE"]
|
|
37
37
|
*/
|
|
38
38
|
async generate(request) {
|
|
39
|
+
// 检查版本兼容性
|
|
40
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
39
41
|
const requestBody = {
|
|
40
42
|
prompt: request.prompt,
|
|
41
43
|
model: request.model || "gemini-2.0-flash-exp-image-generation",
|
package/dist/index.d.ts
CHANGED
|
@@ -9,7 +9,7 @@ import { DoubaoImageGenerationClient, DoubaoImageSize, type DoubaoImageGeneratio
|
|
|
9
9
|
import { GeminiImageGenerationClient, type GeminiImageGenerationConfig, type GeminiImageGenerationRequest, type GeminiImageGenerationResponse } from "./gemini-image-generation";
|
|
10
10
|
import { VideoGenerationClient, type VideoGenerationConfig, type VideoGenerationRequest, type ContentGenerationTaskID, type ContentGenerationTask } from "./video_generation";
|
|
11
11
|
import { DownloadClient, type DownloadConfig, type DownloadOptions, type StreamDownloadOptions } from "./download";
|
|
12
|
-
import {
|
|
12
|
+
import { AuthClient, getCurrentUserInfo, type AuthConfig, type UserInfo } from "./auth";
|
|
13
13
|
export { BaseMessage, HumanMessage, AIMessage, SystemMessage, AIMessageChunk, type MessageContent, type AIMessageChunkData, } from "./messages";
|
|
14
14
|
export { BaseChatModel, type BaseChatModelParams, type AIModelProvider, type ToolDefinition, type BindOptions, } from "./base";
|
|
15
15
|
export { ChatOpenAI } from "./chat_models/openai";
|
|
@@ -24,7 +24,8 @@ export { DoubaoImageGenerationClient, type DoubaoImageGenerationConfig, type Dou
|
|
|
24
24
|
export { GeminiImageGenerationClient, type GeminiImageGenerationConfig, type GeminiImageGenerationRequest, type GeminiImageGenerationResponse, };
|
|
25
25
|
export { VideoGenerationClient, type VideoGenerationConfig, type VideoGenerationRequest, type ContentGenerationTaskID, type ContentGenerationTask, };
|
|
26
26
|
export { DownloadClient, type DownloadConfig, type DownloadOptions, type StreamDownloadOptions, };
|
|
27
|
-
export {
|
|
27
|
+
export { AuthClient, getCurrentUserInfo, type AuthConfig, type UserInfo, };
|
|
28
|
+
export { sdkConfig, VersionCompatibilityError } from "./config";
|
|
28
29
|
/**
|
|
29
30
|
* Create a chat model instance based on model name
|
|
30
31
|
*/
|
package/dist/index.js
CHANGED
|
@@ -6,7 +6,7 @@
|
|
|
6
6
|
* @see https://github.com/langchain-ai/langchainjs
|
|
7
7
|
*/
|
|
8
8
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
9
|
-
exports.sdkConfig = exports.DownloadClient = exports.VideoGenerationClient = exports.GeminiImageGenerationClient = exports.DoubaoImageGenerationClient = exports.ChatAnthropic = exports.ChatGoogleGenerativeAI = exports.ChatOpenAI = exports.BaseChatModel = exports.AIMessageChunk = exports.SystemMessage = exports.AIMessage = exports.HumanMessage = void 0;
|
|
9
|
+
exports.VersionCompatibilityError = exports.sdkConfig = exports.getCurrentUserInfo = exports.AuthClient = exports.DownloadClient = exports.VideoGenerationClient = exports.GeminiImageGenerationClient = exports.DoubaoImageGenerationClient = exports.ChatAnthropic = exports.ChatGoogleGenerativeAI = exports.ChatOpenAI = exports.BaseChatModel = exports.AIMessageChunk = exports.SystemMessage = exports.AIMessage = exports.HumanMessage = void 0;
|
|
10
10
|
exports.createChatModel = createChatModel;
|
|
11
11
|
const openai_1 = require("./chat_models/openai");
|
|
12
12
|
const google_1 = require("./chat_models/google");
|
|
@@ -18,8 +18,10 @@ const video_generation_1 = require("./video_generation");
|
|
|
18
18
|
Object.defineProperty(exports, "VideoGenerationClient", { enumerable: true, get: function () { return video_generation_1.VideoGenerationClient; } });
|
|
19
19
|
const download_1 = require("./download");
|
|
20
20
|
Object.defineProperty(exports, "DownloadClient", { enumerable: true, get: function () { return download_1.DownloadClient; } });
|
|
21
|
+
const auth_1 = require("./auth");
|
|
22
|
+
Object.defineProperty(exports, "AuthClient", { enumerable: true, get: function () { return auth_1.AuthClient; } });
|
|
23
|
+
Object.defineProperty(exports, "getCurrentUserInfo", { enumerable: true, get: function () { return auth_1.getCurrentUserInfo; } });
|
|
21
24
|
const config_1 = require("./config");
|
|
22
|
-
Object.defineProperty(exports, "sdkConfig", { enumerable: true, get: function () { return config_1.sdkConfig; } });
|
|
23
25
|
// Re-export types and classes
|
|
24
26
|
var messages_1 = require("./messages");
|
|
25
27
|
Object.defineProperty(exports, "HumanMessage", { enumerable: true, get: function () { return messages_1.HumanMessage; } });
|
|
@@ -34,6 +36,10 @@ var google_2 = require("./chat_models/google");
|
|
|
34
36
|
Object.defineProperty(exports, "ChatGoogleGenerativeAI", { enumerable: true, get: function () { return google_2.ChatGoogleGenerativeAI; } });
|
|
35
37
|
var anthropic_1 = require("./chat_models/anthropic");
|
|
36
38
|
Object.defineProperty(exports, "ChatAnthropic", { enumerable: true, get: function () { return anthropic_1.ChatAnthropic; } });
|
|
39
|
+
// Export global configuration
|
|
40
|
+
var config_2 = require("./config");
|
|
41
|
+
Object.defineProperty(exports, "sdkConfig", { enumerable: true, get: function () { return config_2.sdkConfig; } });
|
|
42
|
+
Object.defineProperty(exports, "VersionCompatibilityError", { enumerable: true, get: function () { return config_2.VersionCompatibilityError; } });
|
|
37
43
|
/**
|
|
38
44
|
* Create a chat model instance based on model name
|
|
39
45
|
*/
|
package/dist/video_generation.js
CHANGED
|
@@ -24,6 +24,8 @@ class VideoGenerationClient {
|
|
|
24
24
|
* 创建视频生成任务
|
|
25
25
|
*/
|
|
26
26
|
async create(request) {
|
|
27
|
+
// 检查版本兼容性
|
|
28
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
27
29
|
const url = `${config_1.sdkConfig.getServerUrl()}/api/video-proxy/generate`;
|
|
28
30
|
(0, log_1.logRequest)("POST", url, this.headers, request);
|
|
29
31
|
const response = await fetch(url, {
|
|
@@ -45,6 +47,8 @@ class VideoGenerationClient {
|
|
|
45
47
|
* 查询视频生成任务状态
|
|
46
48
|
*/
|
|
47
49
|
async get(taskId) {
|
|
50
|
+
// 检查版本兼容性
|
|
51
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
48
52
|
const url = `${config_1.sdkConfig.getServerUrl()}/api/video-proxy/${taskId}`;
|
|
49
53
|
(0, log_1.logRequest)("GET", url, this.headers);
|
|
50
54
|
const response = await fetch(url, {
|
|
@@ -65,6 +69,8 @@ class VideoGenerationClient {
|
|
|
65
69
|
* 轮询视频生成任务直到完成
|
|
66
70
|
*/
|
|
67
71
|
async poll(taskId, options) {
|
|
72
|
+
// 检查版本兼容性
|
|
73
|
+
config_1.sdkConfig.ensureVersionCompatible();
|
|
68
74
|
const interval = options?.interval || 5000;
|
|
69
75
|
const timeout = options?.timeout || 300000;
|
|
70
76
|
const startTime = Date.now();
|
package/package.json
CHANGED
|
@@ -1,12 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "ai-world-sdk",
|
|
3
|
-
"version": "1.0
|
|
3
|
+
"version": "1.1.0",
|
|
4
4
|
"description": "TypeScript SDK for AI World Platform - Chat Models, Image Generation, and Video Generation",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"types": "dist/index.d.ts",
|
|
7
7
|
"scripts": {
|
|
8
|
-
"
|
|
8
|
+
"update-version": "node scripts/update-version.js",
|
|
9
|
+
"build": "npm run update-version && rm -rf dist && tsc",
|
|
9
10
|
"prepublishOnly": "npm run build",
|
|
11
|
+
"publish": "npm run build && npm publish --access public",
|
|
10
12
|
"test": "jest",
|
|
11
13
|
"test:watch": "jest --watch",
|
|
12
14
|
"test:genimi-non-stream": "jest -t 'ChatGoogleGenerativeAI - 非流式调用'",
|