完善生成视频
This commit is contained in:
parent
5f117f1c75
commit
1833919e7d
148
src/router.ts
148
src/router.ts
@ -1,4 +1,4 @@
|
|||||||
// @routes-hash 6d230b9f278cc0ba49f62f5e48365dea
|
// @routes-hash 0a85dfe35e0882ce29f9d4fc68c3fd73
|
||||||
import { Express } from "express";
|
import { Express } from "express";
|
||||||
|
|
||||||
import route1 from "./routes/agents/clearMemory";
|
import route1 from "./routes/agents/clearMemory";
|
||||||
@ -38,42 +38,43 @@ import route34 from "./routes/production/editStoryboard/generateStoryboardImage"
|
|||||||
import route35 from "./routes/production/editStoryboard/getStoryboardFlow";
|
import route35 from "./routes/production/editStoryboard/getStoryboardFlow";
|
||||||
import route36 from "./routes/production/editStoryboard/saveStoryboardFlow";
|
import route36 from "./routes/production/editStoryboard/saveStoryboardFlow";
|
||||||
import route37 from "./routes/production/editStoryboard/updateStoryboardFlow";
|
import route37 from "./routes/production/editStoryboard/updateStoryboardFlow";
|
||||||
import route38 from "./routes/production/getFlowData";
|
import route38 from "./routes/production/exportImage";
|
||||||
import route39 from "./routes/production/getProductionData";
|
import route39 from "./routes/production/getFlowData";
|
||||||
import route40 from "./routes/production/getStoryboardData";
|
import route40 from "./routes/production/getProductionData";
|
||||||
import route41 from "./routes/production/saveFlowData";
|
import route41 from "./routes/production/getStoryboardData";
|
||||||
import route42 from "./routes/production/workbench/confirmSelection";
|
import route42 from "./routes/production/saveFlowData";
|
||||||
import route43 from "./routes/production/workbench/delVideo";
|
import route43 from "./routes/production/workbench/confirmSelection";
|
||||||
import route44 from "./routes/production/workbench/generateVideo";
|
import route44 from "./routes/production/workbench/delVideo";
|
||||||
import route45 from "./routes/production/workbench/getVideoModelDetail";
|
import route45 from "./routes/production/workbench/generateVideo";
|
||||||
import route46 from "./routes/production/workbench/videoPolling";
|
import route46 from "./routes/production/workbench/getVideoModelDetail";
|
||||||
import route47 from "./routes/project/addProject";
|
import route47 from "./routes/production/workbench/videoPolling";
|
||||||
import route48 from "./routes/project/delProject";
|
import route48 from "./routes/project/addProject";
|
||||||
import route49 from "./routes/project/editProject";
|
import route49 from "./routes/project/delProject";
|
||||||
import route50 from "./routes/project/getProject";
|
import route50 from "./routes/project/editProject";
|
||||||
import route51 from "./routes/script/addScript";
|
import route51 from "./routes/project/getProject";
|
||||||
import route52 from "./routes/script/delScript";
|
import route52 from "./routes/script/addScript";
|
||||||
import route53 from "./routes/script/exportScript";
|
import route53 from "./routes/script/delScript";
|
||||||
import route54 from "./routes/script/getScrptApi";
|
import route54 from "./routes/script/exportScript";
|
||||||
import route55 from "./routes/script/updateScript";
|
import route55 from "./routes/script/getScrptApi";
|
||||||
import route56 from "./routes/setting/agentDeploy/deployAgentModel";
|
import route56 from "./routes/script/updateScript";
|
||||||
import route57 from "./routes/setting/agentDeploy/getAgentDeploy";
|
import route57 from "./routes/setting/agentDeploy/deployAgentModel";
|
||||||
import route58 from "./routes/setting/agentDeploy/updateKey";
|
import route58 from "./routes/setting/agentDeploy/getAgentDeploy";
|
||||||
import route59 from "./routes/setting/dbConfig/clearData";
|
import route59 from "./routes/setting/agentDeploy/updateKey";
|
||||||
import route60 from "./routes/setting/getTextModel";
|
import route60 from "./routes/setting/dbConfig/clearData";
|
||||||
import route61 from "./routes/setting/loginConfig/getUser";
|
import route61 from "./routes/setting/getTextModel";
|
||||||
import route62 from "./routes/setting/loginConfig/updateUserPwd";
|
import route62 from "./routes/setting/loginConfig/getUser";
|
||||||
import route63 from "./routes/setting/memoryConfig/getMemory";
|
import route63 from "./routes/setting/loginConfig/updateUserPwd";
|
||||||
import route64 from "./routes/setting/memoryConfig/sureMemory";
|
import route64 from "./routes/setting/memoryConfig/getMemory";
|
||||||
import route65 from "./routes/setting/vendorConfig/addVendor";
|
import route65 from "./routes/setting/memoryConfig/sureMemory";
|
||||||
import route66 from "./routes/setting/vendorConfig/deleteVendor";
|
import route66 from "./routes/setting/vendorConfig/addVendor";
|
||||||
import route67 from "./routes/setting/vendorConfig/getVendorList";
|
import route67 from "./routes/setting/vendorConfig/deleteVendor";
|
||||||
import route68 from "./routes/setting/vendorConfig/modelTest";
|
import route68 from "./routes/setting/vendorConfig/getVendorList";
|
||||||
import route69 from "./routes/setting/vendorConfig/updateVendor";
|
import route69 from "./routes/setting/vendorConfig/modelTest";
|
||||||
import route70 from "./routes/task/getTaskApi";
|
import route70 from "./routes/setting/vendorConfig/updateVendor";
|
||||||
import route71 from "./routes/task/getTaskCategories";
|
import route71 from "./routes/task/getTaskApi";
|
||||||
import route72 from "./routes/task/taskDetails";
|
import route72 from "./routes/task/getTaskCategories";
|
||||||
import route73 from "./routes/test/test";
|
import route73 from "./routes/task/taskDetails";
|
||||||
|
import route74 from "./routes/test/test";
|
||||||
|
|
||||||
export default async (app: Express) => {
|
export default async (app: Express) => {
|
||||||
app.use("/api/agents/clearMemory", route1);
|
app.use("/api/agents/clearMemory", route1);
|
||||||
@ -113,40 +114,41 @@ export default async (app: Express) => {
|
|||||||
app.use("/api/production/editStoryboard/getStoryboardFlow", route35);
|
app.use("/api/production/editStoryboard/getStoryboardFlow", route35);
|
||||||
app.use("/api/production/editStoryboard/saveStoryboardFlow", route36);
|
app.use("/api/production/editStoryboard/saveStoryboardFlow", route36);
|
||||||
app.use("/api/production/editStoryboard/updateStoryboardFlow", route37);
|
app.use("/api/production/editStoryboard/updateStoryboardFlow", route37);
|
||||||
app.use("/api/production/getFlowData", route38);
|
app.use("/api/production/exportImage", route38);
|
||||||
app.use("/api/production/getProductionData", route39);
|
app.use("/api/production/getFlowData", route39);
|
||||||
app.use("/api/production/getStoryboardData", route40);
|
app.use("/api/production/getProductionData", route40);
|
||||||
app.use("/api/production/saveFlowData", route41);
|
app.use("/api/production/getStoryboardData", route41);
|
||||||
app.use("/api/production/workbench/confirmSelection", route42);
|
app.use("/api/production/saveFlowData", route42);
|
||||||
app.use("/api/production/workbench/delVideo", route43);
|
app.use("/api/production/workbench/confirmSelection", route43);
|
||||||
app.use("/api/production/workbench/generateVideo", route44);
|
app.use("/api/production/workbench/delVideo", route44);
|
||||||
app.use("/api/production/workbench/getVideoModelDetail", route45);
|
app.use("/api/production/workbench/generateVideo", route45);
|
||||||
app.use("/api/production/workbench/videoPolling", route46);
|
app.use("/api/production/workbench/getVideoModelDetail", route46);
|
||||||
app.use("/api/project/addProject", route47);
|
app.use("/api/production/workbench/videoPolling", route47);
|
||||||
app.use("/api/project/delProject", route48);
|
app.use("/api/project/addProject", route48);
|
||||||
app.use("/api/project/editProject", route49);
|
app.use("/api/project/delProject", route49);
|
||||||
app.use("/api/project/getProject", route50);
|
app.use("/api/project/editProject", route50);
|
||||||
app.use("/api/script/addScript", route51);
|
app.use("/api/project/getProject", route51);
|
||||||
app.use("/api/script/delScript", route52);
|
app.use("/api/script/addScript", route52);
|
||||||
app.use("/api/script/exportScript", route53);
|
app.use("/api/script/delScript", route53);
|
||||||
app.use("/api/script/getScrptApi", route54);
|
app.use("/api/script/exportScript", route54);
|
||||||
app.use("/api/script/updateScript", route55);
|
app.use("/api/script/getScrptApi", route55);
|
||||||
app.use("/api/setting/agentDeploy/deployAgentModel", route56);
|
app.use("/api/script/updateScript", route56);
|
||||||
app.use("/api/setting/agentDeploy/getAgentDeploy", route57);
|
app.use("/api/setting/agentDeploy/deployAgentModel", route57);
|
||||||
app.use("/api/setting/agentDeploy/updateKey", route58);
|
app.use("/api/setting/agentDeploy/getAgentDeploy", route58);
|
||||||
app.use("/api/setting/dbConfig/clearData", route59);
|
app.use("/api/setting/agentDeploy/updateKey", route59);
|
||||||
app.use("/api/setting/getTextModel", route60);
|
app.use("/api/setting/dbConfig/clearData", route60);
|
||||||
app.use("/api/setting/loginConfig/getUser", route61);
|
app.use("/api/setting/getTextModel", route61);
|
||||||
app.use("/api/setting/loginConfig/updateUserPwd", route62);
|
app.use("/api/setting/loginConfig/getUser", route62);
|
||||||
app.use("/api/setting/memoryConfig/getMemory", route63);
|
app.use("/api/setting/loginConfig/updateUserPwd", route63);
|
||||||
app.use("/api/setting/memoryConfig/sureMemory", route64);
|
app.use("/api/setting/memoryConfig/getMemory", route64);
|
||||||
app.use("/api/setting/vendorConfig/addVendor", route65);
|
app.use("/api/setting/memoryConfig/sureMemory", route65);
|
||||||
app.use("/api/setting/vendorConfig/deleteVendor", route66);
|
app.use("/api/setting/vendorConfig/addVendor", route66);
|
||||||
app.use("/api/setting/vendorConfig/getVendorList", route67);
|
app.use("/api/setting/vendorConfig/deleteVendor", route67);
|
||||||
app.use("/api/setting/vendorConfig/modelTest", route68);
|
app.use("/api/setting/vendorConfig/getVendorList", route68);
|
||||||
app.use("/api/setting/vendorConfig/updateVendor", route69);
|
app.use("/api/setting/vendorConfig/modelTest", route69);
|
||||||
app.use("/api/task/getTaskApi", route70);
|
app.use("/api/setting/vendorConfig/updateVendor", route70);
|
||||||
app.use("/api/task/getTaskCategories", route71);
|
app.use("/api/task/getTaskApi", route71);
|
||||||
app.use("/api/task/taskDetails", route72);
|
app.use("/api/task/getTaskCategories", route72);
|
||||||
app.use("/api/test/test", route73);
|
app.use("/api/task/taskDetails", route73);
|
||||||
|
app.use("/api/test/test", route74);
|
||||||
}
|
}
|
||||||
|
|||||||
20
src/routes/production/exportImage.ts
Normal file
20
src/routes/production/exportImage.ts
Normal file
@ -0,0 +1,20 @@
|
|||||||
|
import express from "express";
|
||||||
|
import u from "@/utils";
|
||||||
|
import { z } from "zod";
|
||||||
|
import { success } from "@/lib/responseFormat";
|
||||||
|
import { validateFields } from "@/middleware/middleware";
|
||||||
|
const router = express.Router();
|
||||||
|
import { flowDataSchema } from "@/agents/productionAgent/tools";
|
||||||
|
|
||||||
|
export default router.post(
|
||||||
|
"/",
|
||||||
|
validateFields({
|
||||||
|
projectId: z.number(),
|
||||||
|
episodesId: z.number(),
|
||||||
|
data: flowDataSchema,
|
||||||
|
}),
|
||||||
|
async (req, res) => {
|
||||||
|
const { projectId, episodesId } = req.body;
|
||||||
|
return res.status(200).send(success());
|
||||||
|
},
|
||||||
|
);
|
||||||
@ -22,6 +22,68 @@ export default router.post(
|
|||||||
};
|
};
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
res.status(200).send(success(data));
|
|
||||||
|
//获取相关资产
|
||||||
|
const storyboardIds = storyboardData.map((s) => s.id as number);
|
||||||
|
|
||||||
|
// 修复:o_assets.id 关联 o_assets2Storyboard.assetId,按 storyboardId 过滤
|
||||||
|
const storyboardConfigs = await u
|
||||||
|
.db("o_assets2Storyboard")
|
||||||
|
.leftJoin("o_assets", "o_assets2Storyboard.assetId", "o_assets.id")
|
||||||
|
.leftJoin("o_image", "o_assets.imageId", "o_image.id")
|
||||||
|
.whereIn("o_assets2Storyboard.storyboardId", storyboardIds)
|
||||||
|
.select("o_assets2Storyboard.storyboardId", "o_assets.id as assetId", "o_assets.name", "o_assets.type", "o_image.filePath as avatar");
|
||||||
|
|
||||||
|
// 按 storyboardId 分组,生成 characters 列表
|
||||||
|
const storyboardCharactersMap = storyboardConfigs.reduce<Record<number, { name: string; type: string; avatar?: string }[]>>((acc, cur) => {
|
||||||
|
const storyboardId = cur.storyboardId as number;
|
||||||
|
if (!acc[storyboardId]) {
|
||||||
|
acc[storyboardId] = [];
|
||||||
|
}
|
||||||
|
const character: { name: string; type: string; avatar?: string } = {
|
||||||
|
name: cur.name ?? "",
|
||||||
|
type: cur.type ?? "",
|
||||||
|
};
|
||||||
|
if (cur.avatar) {
|
||||||
|
character.avatar = cur.avatar;
|
||||||
|
}
|
||||||
|
acc[storyboardId].push(character);
|
||||||
|
return acc;
|
||||||
|
}, {});
|
||||||
|
|
||||||
|
// 组装最终数据,符合 Shot 接口格式
|
||||||
|
const result = await Promise.all(
|
||||||
|
data.map(async (item) => {
|
||||||
|
const characters = storyboardCharactersMap[item.id as number] ?? [];
|
||||||
|
// 处理 characters 中的 avatar OSS 路径
|
||||||
|
const charactersWithUrl = await Promise.all(
|
||||||
|
characters.map(async (c) => {
|
||||||
|
if (c.avatar) {
|
||||||
|
return { ...c, avatar: await u.oss.getFileUrl(c.avatar) };
|
||||||
|
}
|
||||||
|
return c;
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
return {
|
||||||
|
id: String(item.id),
|
||||||
|
camera: item.camera ? Number(item.camera) : undefined,
|
||||||
|
createTime: item.createTime ?? undefined,
|
||||||
|
description: item.description ?? undefined,
|
||||||
|
duration: item.duration ? Number(item.duration) : undefined,
|
||||||
|
filePath: item.filePath || undefined,
|
||||||
|
frameMode: item.frameMode ? Number(item.frameMode) : undefined,
|
||||||
|
mode: item.mode ?? "",
|
||||||
|
model: item.model ?? "",
|
||||||
|
prompt: item.prompt ?? undefined,
|
||||||
|
resolution: item.resolution ?? undefined,
|
||||||
|
scriptId: item.scriptId ?? undefined,
|
||||||
|
sound: item.sound ? Number(item.sound) : undefined,
|
||||||
|
title: item.title ?? undefined,
|
||||||
|
characters: charactersWithUrl,
|
||||||
|
};
|
||||||
|
}),
|
||||||
|
);
|
||||||
|
|
||||||
|
res.status(200).send(success(result));
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
|
|||||||
@ -118,7 +118,7 @@ export default router.post(
|
|||||||
});
|
});
|
||||||
await aiVideo.save(videoPath);
|
await aiVideo.save(videoPath);
|
||||||
await u.db("o_video").where("id", videoId).update({ state: "生成成功" });
|
await u.db("o_video").where("id", videoId).update({ state: "生成成功" });
|
||||||
await u.db("o_videoConfig").where("storyboardId", storyboardId).update({ videoId, updateTime: Date.now() });
|
// await u.db("o_videoConfig").where("storyboardId", storyboardId).update({ videoId, updateTime: Date.now() });
|
||||||
} catch (error: any) {
|
} catch (error: any) {
|
||||||
await u
|
await u
|
||||||
.db("o_video")
|
.db("o_video")
|
||||||
|
|||||||
12
src/types/database.d.ts
vendored
12
src/types/database.d.ts
vendored
@ -1,4 +1,4 @@
|
|||||||
// @db-hash d0e44c9c923897d847cded0a28012baf
|
// @db-hash 56071dcf512e84c37ffd555806af7162
|
||||||
//该文件由脚本自动生成,请勿手动修改
|
//该文件由脚本自动生成,请勿手动修改
|
||||||
|
|
||||||
export interface memories {
|
export interface memories {
|
||||||
@ -59,7 +59,7 @@ export interface o_eventChapter {
|
|||||||
export interface o_flowData {
|
export interface o_flowData {
|
||||||
'createTime'?: number | null;
|
'createTime'?: number | null;
|
||||||
'data'?: string | null;
|
'data'?: string | null;
|
||||||
'episodesId'?: number | null;
|
'espisodeId'?: number | null;
|
||||||
'id'?: number;
|
'id'?: number;
|
||||||
'key'?: string | null;
|
'key'?: string | null;
|
||||||
'projectId'?: number | null;
|
'projectId'?: number | null;
|
||||||
@ -117,25 +117,25 @@ export interface o_setting {
|
|||||||
'value'?: string | null;
|
'value'?: string | null;
|
||||||
}
|
}
|
||||||
export interface o_storyboard {
|
export interface o_storyboard {
|
||||||
'associateAssetsIds'?: string | null;
|
|
||||||
'camera'?: string | null;
|
'camera'?: string | null;
|
||||||
'createTime'?: number | null;
|
'createTime'?: number | null;
|
||||||
|
'description'?: string | null;
|
||||||
'duration'?: string | null;
|
'duration'?: string | null;
|
||||||
'filePath'?: string | null;
|
'filePath'?: string | null;
|
||||||
'frameType'?: string | null;
|
'frameMode'?: string | null;
|
||||||
'id'?: number;
|
'id'?: number;
|
||||||
'mode'?: string | null;
|
'mode'?: string | null;
|
||||||
'model'?: string | null;
|
'model'?: string | null;
|
||||||
'name'?: string | null;
|
|
||||||
'prompt'?: string | null;
|
'prompt'?: string | null;
|
||||||
'resolution'?: string | null;
|
'resolution'?: string | null;
|
||||||
'scriptId'?: number | null;
|
'scriptId'?: number | null;
|
||||||
'sound'?: string | null;
|
'sound'?: string | null;
|
||||||
|
'title'?: string | null;
|
||||||
}
|
}
|
||||||
export interface o_storyboardFlow {
|
export interface o_storyboardFlow {
|
||||||
'flowData': string;
|
'flowData': string;
|
||||||
'id'?: number;
|
'id'?: number;
|
||||||
'stroryboardId': number;
|
'storyboardId': number;
|
||||||
}
|
}
|
||||||
export interface o_tasks {
|
export interface o_tasks {
|
||||||
'describe'?: string | null;
|
'describe'?: string | null;
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user