ai-world-sdk 1.0.17 → 1.0.18
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 +9 -23
- package/dist/auth.d.ts +48 -0
- package/dist/auth.js +87 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +4 -1
- package/package.json +1 -1
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);
|
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,87 @@
|
|
|
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
|
+
const url = `${this.baseUrl}/api/auth/me`;
|
|
47
|
+
(0, log_1.debugLog)("Get current user info request:", { url });
|
|
48
|
+
(0, log_1.logRequest)("GET", url, this.headers);
|
|
49
|
+
try {
|
|
50
|
+
const response = await fetch(url, {
|
|
51
|
+
method: "GET",
|
|
52
|
+
headers: this.headers,
|
|
53
|
+
});
|
|
54
|
+
if (!response.ok) {
|
|
55
|
+
const errorText = await response.text();
|
|
56
|
+
let errorMessage = `Get user info failed: ${response.status} ${response.statusText}`;
|
|
57
|
+
try {
|
|
58
|
+
const errorJson = JSON.parse(errorText);
|
|
59
|
+
errorMessage = errorJson.detail || errorMessage;
|
|
60
|
+
}
|
|
61
|
+
catch {
|
|
62
|
+
errorMessage = errorText || errorMessage;
|
|
63
|
+
}
|
|
64
|
+
throw new Error(errorMessage);
|
|
65
|
+
}
|
|
66
|
+
const data = (await response.json());
|
|
67
|
+
(0, log_1.logResponse)(response.status, response.statusText, response.headers, data);
|
|
68
|
+
return data;
|
|
69
|
+
}
|
|
70
|
+
catch (error) {
|
|
71
|
+
(0, log_1.debugLog)("Get current user info error:", error);
|
|
72
|
+
throw error;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
exports.AuthClient = AuthClient;
|
|
77
|
+
/**
|
|
78
|
+
* Get current user information (convenience function)
|
|
79
|
+
* 获取当前用户信息(便捷函数)
|
|
80
|
+
*
|
|
81
|
+
* @param config - Optional auth configuration
|
|
82
|
+
* @returns Promise that resolves to UserInfo
|
|
83
|
+
*/
|
|
84
|
+
async function getCurrentUserInfo(config) {
|
|
85
|
+
const client = new AuthClient(config);
|
|
86
|
+
return client.getCurrentUserInfo();
|
|
87
|
+
}
|
package/dist/index.d.ts
CHANGED
|
@@ -9,6 +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 { AuthClient, getCurrentUserInfo, type AuthConfig, type UserInfo } from "./auth";
|
|
12
13
|
import { sdkConfig } from "./config";
|
|
13
14
|
export { BaseMessage, HumanMessage, AIMessage, SystemMessage, AIMessageChunk, type MessageContent, type AIMessageChunkData, } from "./messages";
|
|
14
15
|
export { BaseChatModel, type BaseChatModelParams, type AIModelProvider, type ToolDefinition, type BindOptions, } from "./base";
|
|
@@ -24,6 +25,7 @@ export { DoubaoImageGenerationClient, type DoubaoImageGenerationConfig, type Dou
|
|
|
24
25
|
export { GeminiImageGenerationClient, type GeminiImageGenerationConfig, type GeminiImageGenerationRequest, type GeminiImageGenerationResponse, };
|
|
25
26
|
export { VideoGenerationClient, type VideoGenerationConfig, type VideoGenerationRequest, type ContentGenerationTaskID, type ContentGenerationTask, };
|
|
26
27
|
export { DownloadClient, type DownloadConfig, type DownloadOptions, type StreamDownloadOptions, };
|
|
28
|
+
export { AuthClient, getCurrentUserInfo, type AuthConfig, type UserInfo, };
|
|
27
29
|
export { sdkConfig };
|
|
28
30
|
/**
|
|
29
31
|
* Create a chat model instance based on model name
|
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.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,6 +18,9 @@ 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
25
|
Object.defineProperty(exports, "sdkConfig", { enumerable: true, get: function () { return config_1.sdkConfig; } });
|
|
23
26
|
// Re-export types and classes
|
package/package.json
CHANGED