koishi-plugin-aka-ai-generator 0.7.8 → 0.7.11
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/lib/index.js +104 -0
- package/package.json +5 -2
package/lib/index.js
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
1
2
|
var __defProp = Object.defineProperty;
|
|
2
3
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
3
4
|
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
4
6
|
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
5
7
|
var __name = (target, value) => __defProp(target, "name", { value, configurable: true });
|
|
6
8
|
var __export = (target, all) => {
|
|
@@ -15,6 +17,14 @@ var __copyProps = (to, from, except, desc) => {
|
|
|
15
17
|
}
|
|
16
18
|
return to;
|
|
17
19
|
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
+
mod
|
|
27
|
+
));
|
|
18
28
|
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
19
29
|
|
|
20
30
|
// src/index.ts
|
|
@@ -28,6 +38,7 @@ module.exports = __toCommonJS(src_exports);
|
|
|
28
38
|
var import_koishi2 = require("koishi");
|
|
29
39
|
|
|
30
40
|
// src/providers/utils.ts
|
|
41
|
+
var import_jimp = __toESM(require("jimp"));
|
|
31
42
|
function sanitizeError(error) {
|
|
32
43
|
if (!error) return error;
|
|
33
44
|
if (typeof error === "string") {
|
|
@@ -92,6 +103,21 @@ async function downloadImageAsBase64(ctx, url, timeout, logger, maxSize = 10 * 1
|
|
|
92
103
|
mimeType = "image/gif";
|
|
93
104
|
}
|
|
94
105
|
}
|
|
106
|
+
if (mimeType === "image/gif") {
|
|
107
|
+
try {
|
|
108
|
+
logger.debug("检测到 GIF 图片,正在转换为 JPEG", { url });
|
|
109
|
+
const image = await import_jimp.default.read(buffer);
|
|
110
|
+
const jpegBuffer = await image.getBufferAsync(import_jimp.default.MIME_JPEG);
|
|
111
|
+
const jpegBase64 = jpegBuffer.toString("base64");
|
|
112
|
+
logger.info("GIF 已转换为 JPEG", {
|
|
113
|
+
originalSize: buffer.length,
|
|
114
|
+
newSize: jpegBuffer.length
|
|
115
|
+
});
|
|
116
|
+
return { data: jpegBase64, mimeType: "image/jpeg" };
|
|
117
|
+
} catch (conversionError) {
|
|
118
|
+
logger.warn("GIF 转换失败,尝试原样发送", { error: conversionError?.message });
|
|
119
|
+
}
|
|
120
|
+
}
|
|
95
121
|
logger.debug("图片下载并转换为Base64", { url, mimeType, size: base64.length });
|
|
96
122
|
return { data: base64, mimeType };
|
|
97
123
|
} catch (error) {
|
|
@@ -2459,6 +2485,45 @@ ${infoParts.join("\n")}`;
|
|
|
2459
2485
|
return addResult.message || "队列已满,请先查询已有任务";
|
|
2460
2486
|
}
|
|
2461
2487
|
await session.send("开始生成视频...");
|
|
2488
|
+
await new Promise((resolve) => setTimeout(resolve, 1e4));
|
|
2489
|
+
try {
|
|
2490
|
+
const firstStatus = await videoProvider.queryTaskStatus(taskId);
|
|
2491
|
+
if (firstStatus.status === "failed") {
|
|
2492
|
+
const errorMsg = firstStatus.error || "视频生成失败";
|
|
2493
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2494
|
+
return `视频生成失败:${sanitizeString(errorMsg)}`;
|
|
2495
|
+
}
|
|
2496
|
+
if (firstStatus.status === "completed" && firstStatus.videoUrl) {
|
|
2497
|
+
await session.send(import_koishi2.h.video(firstStatus.videoUrl));
|
|
2498
|
+
await recordUserUsage(session, "图生视频", videoCredits, false);
|
|
2499
|
+
await userManager.markPendingVideoTaskCharged(taskId);
|
|
2500
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2501
|
+
return "视频生成完成!";
|
|
2502
|
+
}
|
|
2503
|
+
await session.send("视频正在生成中,请稍候...");
|
|
2504
|
+
} catch (error) {
|
|
2505
|
+
logger.error("第一次查询视频状态失败", { taskId, error: sanitizeError(error) });
|
|
2506
|
+
}
|
|
2507
|
+
await new Promise((resolve) => setTimeout(resolve, config.videoMaxWaitTime * 1e3));
|
|
2508
|
+
try {
|
|
2509
|
+
const secondStatus = await videoProvider.queryTaskStatus(taskId);
|
|
2510
|
+
if (secondStatus.status === "completed" && secondStatus.videoUrl) {
|
|
2511
|
+
await session.send(import_koishi2.h.video(secondStatus.videoUrl));
|
|
2512
|
+
await recordUserUsage(session, "图生视频", videoCredits, false);
|
|
2513
|
+
await userManager.markPendingVideoTaskCharged(taskId);
|
|
2514
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2515
|
+
return "视频生成完成!";
|
|
2516
|
+
} else if (secondStatus.status === "failed") {
|
|
2517
|
+
const errorMsg = secondStatus.error || "视频生成失败";
|
|
2518
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2519
|
+
return `视频生成失败:${sanitizeString(errorMsg)}`;
|
|
2520
|
+
} else {
|
|
2521
|
+
return '视频仍在生成中,请稍后使用"查询视频"指令获取结果';
|
|
2522
|
+
}
|
|
2523
|
+
} catch (error) {
|
|
2524
|
+
logger.error("第二次查询视频状态失败", { taskId, error: sanitizeError(error) });
|
|
2525
|
+
return '视频生成中,请稍后使用"查询视频"指令获取结果';
|
|
2526
|
+
}
|
|
2462
2527
|
} catch (error) {
|
|
2463
2528
|
logger.error("视频生成任务提交失败", { userId, error: sanitizeError(error) });
|
|
2464
2529
|
if (createdTaskId) {
|
|
@@ -2627,6 +2692,45 @@ ${messages.join("\n")}`;
|
|
|
2627
2692
|
return addResult.message || "队列已满,请先查询已有任务";
|
|
2628
2693
|
}
|
|
2629
2694
|
await session.send(`开始生成视频(${style.commandName})...`);
|
|
2695
|
+
await new Promise((resolve) => setTimeout(resolve, 1e4));
|
|
2696
|
+
try {
|
|
2697
|
+
const firstStatus = await videoProvider.queryTaskStatus(taskId);
|
|
2698
|
+
if (firstStatus.status === "failed") {
|
|
2699
|
+
const errorMsg = firstStatus.error || "视频生成失败";
|
|
2700
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2701
|
+
return `视频生成失败:${sanitizeString(errorMsg)}`;
|
|
2702
|
+
}
|
|
2703
|
+
if (firstStatus.status === "completed" && firstStatus.videoUrl) {
|
|
2704
|
+
await session.send(import_koishi2.h.video(firstStatus.videoUrl));
|
|
2705
|
+
await recordUserUsage(session, style.commandName, videoCredits, false);
|
|
2706
|
+
await userManager.markPendingVideoTaskCharged(taskId);
|
|
2707
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2708
|
+
return "视频生成完成!";
|
|
2709
|
+
}
|
|
2710
|
+
await session.send("视频正在生成中,请稍候...");
|
|
2711
|
+
} catch (error) {
|
|
2712
|
+
logger.error("第一次查询视频状态失败", { taskId, error: sanitizeError(error) });
|
|
2713
|
+
}
|
|
2714
|
+
await new Promise((resolve) => setTimeout(resolve, config.videoMaxWaitTime * 1e3));
|
|
2715
|
+
try {
|
|
2716
|
+
const secondStatus = await videoProvider.queryTaskStatus(taskId);
|
|
2717
|
+
if (secondStatus.status === "completed" && secondStatus.videoUrl) {
|
|
2718
|
+
await session.send(import_koishi2.h.video(secondStatus.videoUrl));
|
|
2719
|
+
await recordUserUsage(session, style.commandName, videoCredits, false);
|
|
2720
|
+
await userManager.markPendingVideoTaskCharged(taskId);
|
|
2721
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2722
|
+
return "视频生成完成!";
|
|
2723
|
+
} else if (secondStatus.status === "failed") {
|
|
2724
|
+
const errorMsg = secondStatus.error || "视频生成失败";
|
|
2725
|
+
await userManager.deletePendingVideoTask(taskId);
|
|
2726
|
+
return `视频生成失败:${sanitizeString(errorMsg)}`;
|
|
2727
|
+
} else {
|
|
2728
|
+
return '视频仍在生成中,请稍后使用"查询视频"指令获取结果';
|
|
2729
|
+
}
|
|
2730
|
+
} catch (error) {
|
|
2731
|
+
logger.error("第二次查询视频状态失败", { taskId, error: sanitizeError(error) });
|
|
2732
|
+
return '视频生成中,请稍后使用"查询视频"指令获取结果';
|
|
2733
|
+
}
|
|
2630
2734
|
} catch (error) {
|
|
2631
2735
|
logger.error("视频风格转换任务提交失败", { userId, style: style.commandName, error: sanitizeError(error) });
|
|
2632
2736
|
if (createdTaskId) {
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "koishi-plugin-aka-ai-generator",
|
|
3
3
|
"description": "自用AI生成插件(GPTGod & Yunwu)",
|
|
4
|
-
"version": "0.7.
|
|
4
|
+
"version": "0.7.11",
|
|
5
5
|
"main": "lib/index.js",
|
|
6
6
|
"typings": "lib/index.d.ts",
|
|
7
7
|
"files": [
|
|
@@ -24,5 +24,8 @@
|
|
|
24
24
|
},
|
|
25
25
|
"peerDependencies": {
|
|
26
26
|
"koishi": "^4.18.9"
|
|
27
|
+
},
|
|
28
|
+
"dependencies": {
|
|
29
|
+
"jimp": "^0.22.10"
|
|
27
30
|
}
|
|
28
|
-
}
|
|
31
|
+
}
|