# Conflicts:
#	src/router.ts
#	src/types/database.d.ts
This commit is contained in:
zhishi 2026-04-01 15:11:50 +08:00
commit 0de504a138
9 changed files with 236 additions and 185 deletions

View File

@ -167,7 +167,6 @@ export default (toolCpnfig: ToolConfig) => {
ids: z.array(z.number()).describe("必须获取真实的分镜ID支持批量生成"), ids: z.array(z.number()).describe("必须获取真实的分镜ID支持批量生成"),
}), }),
execute: async ({ ids }) => { execute: async ({ ids }) => {
console.log("%c Line:176 🍒 ids", "background:#ea7e5c", ids);
const thinking = msg.thinking("正在生成分镜..."); const thinking = msg.thinking("正在生成分镜...");
new Promise((resolve) => socket.emit("generateStoryboard", { ids }, (res: any) => resolve(res))) new Promise((resolve) => socket.emit("generateStoryboard", { ids }, (res: any) => resolve(res)))
.then((res) => { .then((res) => {

View File

@ -1,4 +1,4 @@
// @routes-hash 3e7dcd2b8abd8bd40ca932a2c27249da // @routes-hash 74dea22f03cd475b3b00fd48e38fd9df
import { Express } from "express"; import { Express } from "express";
import route1 from "./routes/agents/clearMemory"; import route1 from "./routes/agents/clearMemory";
@ -70,65 +70,64 @@ import route66 from "./routes/production/storyboard/previewImage";
import route67 from "./routes/production/storyboard/removeFrame"; import route67 from "./routes/production/storyboard/removeFrame";
import route68 from "./routes/production/storyboard/updateStoryboardUrl"; import route68 from "./routes/production/storyboard/updateStoryboardUrl";
import route69 from "./routes/production/workbench/addTrack"; import route69 from "./routes/production/workbench/addTrack";
import route70 from "./routes/production/workbench/confirmSelection"; import route70 from "./routes/production/workbench/delVideo";
import route71 from "./routes/production/workbench/delVideo"; import route71 from "./routes/production/workbench/generateVideo";
import route72 from "./routes/production/workbench/generateVideo"; import route72 from "./routes/production/workbench/generateVideoPrompt";
import route73 from "./routes/production/workbench/generateVideoPrompt"; import route73 from "./routes/production/workbench/getGenerateData";
import route74 from "./routes/production/workbench/getGenerateData"; import route74 from "./routes/production/workbench/getVideoList";
import route75 from "./routes/production/workbench/getVideoModelDetail"; import route75 from "./routes/production/workbench/getVideoModelDetail";
import route76 from "./routes/production/workbench/videoPolling"; import route76 from "./routes/project/addProject";
import route77 from "./routes/project/addProject"; import route77 from "./routes/project/addVisual";
import route78 from "./routes/project/addVisual"; import route78 from "./routes/project/addVisualManual";
import route79 from "./routes/project/addVisualManual"; import route79 from "./routes/project/deleteVisualManual";
import route80 from "./routes/project/deleteVisualManual"; import route80 from "./routes/project/delProject";
import route81 from "./routes/project/delProject"; import route81 from "./routes/project/editProject";
import route82 from "./routes/project/editProject"; import route82 from "./routes/project/editVisualManual";
import route83 from "./routes/project/editVisualManual"; import route83 from "./routes/project/getProject";
import route84 from "./routes/project/getProject"; import route84 from "./routes/project/getVisualManual";
import route85 from "./routes/project/getVisualManual"; import route85 from "./routes/project/visualManual";
import route86 from "./routes/project/visualManual"; import route86 from "./routes/script/addScript";
import route87 from "./routes/script/addScript"; import route87 from "./routes/script/delScript";
import route88 from "./routes/script/delScript"; import route88 from "./routes/script/exportScript";
import route89 from "./routes/script/exportScript"; import route89 from "./routes/script/extractAssets";
import route90 from "./routes/script/extractAssets"; import route90 from "./routes/script/getScrptApi";
import route91 from "./routes/script/getScrptApi"; import route91 from "./routes/script/pollScriptAssets";
import route92 from "./routes/script/pollScriptAssets"; import route92 from "./routes/script/updateScript";
import route93 from "./routes/script/updateScript"; import route93 from "./routes/scriptAgent/getPlanData";
import route94 from "./routes/scriptAgent/getPlanData"; import route94 from "./routes/scriptAgent/setPlanData";
import route95 from "./routes/scriptAgent/setPlanData"; import route95 from "./routes/scriptAgent/updateData";
import route96 from "./routes/scriptAgent/updateData"; import route96 from "./routes/setting/about/checkUpdate";
import route97 from "./routes/setting/about/checkUpdate"; import route97 from "./routes/setting/about/downloadApp";
import route98 from "./routes/setting/about/downloadApp"; import route98 from "./routes/setting/agentDeploy/agentSetKey";
import route99 from "./routes/setting/agentDeploy/agentSetKey"; import route99 from "./routes/setting/agentDeploy/deployAgentModel";
import route100 from "./routes/setting/agentDeploy/deployAgentModel"; import route100 from "./routes/setting/agentDeploy/getAgentDeploy";
import route101 from "./routes/setting/agentDeploy/getAgentDeploy"; import route101 from "./routes/setting/dbConfig/clearData";
import route102 from "./routes/setting/dbConfig/clearData"; import route102 from "./routes/setting/dev/getSwitchAiDevTool";
import route103 from "./routes/setting/dev/getSwitchAiDevTool"; import route103 from "./routes/setting/dev/updateSwitchAiDevTool";
import route104 from "./routes/setting/dev/updateSwitchAiDevTool"; import route104 from "./routes/setting/fileManagement/openFolder";
import route105 from "./routes/setting/fileManagement/openFolder"; import route105 from "./routes/setting/getTextModel";
import route106 from "./routes/setting/getTextModel"; import route106 from "./routes/setting/loginConfig/getUser";
import route107 from "./routes/setting/loginConfig/getUser"; import route107 from "./routes/setting/loginConfig/updateUserPwd";
import route108 from "./routes/setting/loginConfig/updateUserPwd"; import route108 from "./routes/setting/memoryConfig/delAllMemory";
import route109 from "./routes/setting/memoryConfig/delAllMemory"; import route109 from "./routes/setting/memoryConfig/getMemory";
import route110 from "./routes/setting/memoryConfig/getMemory"; import route110 from "./routes/setting/memoryConfig/sureMemory";
import route111 from "./routes/setting/memoryConfig/sureMemory"; import route111 from "./routes/setting/promptManage/getPrompt";
import route112 from "./routes/setting/promptManage/getPrompt"; import route112 from "./routes/setting/promptManage/updatePrompt";
import route113 from "./routes/setting/promptManage/updatePrompt"; import route113 from "./routes/setting/skillManagement/getSkillContent";
import route114 from "./routes/setting/skillManagement/getSkillContent"; import route114 from "./routes/setting/skillManagement/getSkillList";
import route115 from "./routes/setting/skillManagement/getSkillList"; import route115 from "./routes/setting/skillManagement/saveSkillContent";
import route116 from "./routes/setting/skillManagement/saveSkillContent"; import route116 from "./routes/setting/vendorConfig/addVendor";
import route117 from "./routes/setting/vendorConfig/addVendor"; import route117 from "./routes/setting/vendorConfig/deleteVendor";
import route118 from "./routes/setting/vendorConfig/deleteVendor"; import route118 from "./routes/setting/vendorConfig/enableEnglishVendor";
import route119 from "./routes/setting/vendorConfig/enableEnglishVendor"; import route119 from "./routes/setting/vendorConfig/getVendorList";
import route120 from "./routes/setting/vendorConfig/getVendorList"; import route120 from "./routes/setting/vendorConfig/modelTest";
import route121 from "./routes/setting/vendorConfig/modelTest"; import route121 from "./routes/setting/vendorConfig/updateCode";
import route122 from "./routes/setting/vendorConfig/updateCode"; import route122 from "./routes/setting/vendorConfig/updateVendor";
import route123 from "./routes/setting/vendorConfig/updateVendor"; import route123 from "./routes/task/getProject";
import route124 from "./routes/task/getProject"; import route124 from "./routes/task/getTaskApi";
import route125 from "./routes/task/getTaskApi"; import route125 from "./routes/task/getTaskCategories";
import route126 from "./routes/task/getTaskCategories"; import route126 from "./routes/task/taskDetails";
import route127 from "./routes/task/taskDetails"; import route127 from "./routes/test/test";
import route128 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);
@ -200,63 +199,62 @@ export default async (app: Express) => {
app.use("/api/production/storyboard/removeFrame", route67); app.use("/api/production/storyboard/removeFrame", route67);
app.use("/api/production/storyboard/updateStoryboardUrl", route68); app.use("/api/production/storyboard/updateStoryboardUrl", route68);
app.use("/api/production/workbench/addTrack", route69); app.use("/api/production/workbench/addTrack", route69);
app.use("/api/production/workbench/confirmSelection", route70); app.use("/api/production/workbench/delVideo", route70);
app.use("/api/production/workbench/delVideo", route71); app.use("/api/production/workbench/generateVideo", route71);
app.use("/api/production/workbench/generateVideo", route72); app.use("/api/production/workbench/generateVideoPrompt", route72);
app.use("/api/production/workbench/generateVideoPrompt", route73); app.use("/api/production/workbench/getGenerateData", route73);
app.use("/api/production/workbench/getGenerateData", route74); app.use("/api/production/workbench/getVideoList", route74);
app.use("/api/production/workbench/getVideoModelDetail", route75); app.use("/api/production/workbench/getVideoModelDetail", route75);
app.use("/api/production/workbench/videoPolling", route76); app.use("/api/project/addProject", route76);
app.use("/api/project/addProject", route77); app.use("/api/project/addVisual", route77);
app.use("/api/project/addVisual", route78); app.use("/api/project/addVisualManual", route78);
app.use("/api/project/addVisualManual", route79); app.use("/api/project/deleteVisualManual", route79);
app.use("/api/project/deleteVisualManual", route80); app.use("/api/project/delProject", route80);
app.use("/api/project/delProject", route81); app.use("/api/project/editProject", route81);
app.use("/api/project/editProject", route82); app.use("/api/project/editVisualManual", route82);
app.use("/api/project/editVisualManual", route83); app.use("/api/project/getProject", route83);
app.use("/api/project/getProject", route84); app.use("/api/project/getVisualManual", route84);
app.use("/api/project/getVisualManual", route85); app.use("/api/project/visualManual", route85);
app.use("/api/project/visualManual", route86); app.use("/api/script/addScript", route86);
app.use("/api/script/addScript", route87); app.use("/api/script/delScript", route87);
app.use("/api/script/delScript", route88); app.use("/api/script/exportScript", route88);
app.use("/api/script/exportScript", route89); app.use("/api/script/extractAssets", route89);
app.use("/api/script/extractAssets", route90); app.use("/api/script/getScrptApi", route90);
app.use("/api/script/getScrptApi", route91); app.use("/api/script/pollScriptAssets", route91);
app.use("/api/script/pollScriptAssets", route92); app.use("/api/script/updateScript", route92);
app.use("/api/script/updateScript", route93); app.use("/api/scriptAgent/getPlanData", route93);
app.use("/api/scriptAgent/getPlanData", route94); app.use("/api/scriptAgent/setPlanData", route94);
app.use("/api/scriptAgent/setPlanData", route95); app.use("/api/scriptAgent/updateData", route95);
app.use("/api/scriptAgent/updateData", route96); app.use("/api/setting/about/checkUpdate", route96);
app.use("/api/setting/about/checkUpdate", route97); app.use("/api/setting/about/downloadApp", route97);
app.use("/api/setting/about/downloadApp", route98); app.use("/api/setting/agentDeploy/agentSetKey", route98);
app.use("/api/setting/agentDeploy/agentSetKey", route99); app.use("/api/setting/agentDeploy/deployAgentModel", route99);
app.use("/api/setting/agentDeploy/deployAgentModel", route100); app.use("/api/setting/agentDeploy/getAgentDeploy", route100);
app.use("/api/setting/agentDeploy/getAgentDeploy", route101); app.use("/api/setting/dbConfig/clearData", route101);
app.use("/api/setting/dbConfig/clearData", route102); app.use("/api/setting/dev/getSwitchAiDevTool", route102);
app.use("/api/setting/dev/getSwitchAiDevTool", route103); app.use("/api/setting/dev/updateSwitchAiDevTool", route103);
app.use("/api/setting/dev/updateSwitchAiDevTool", route104); app.use("/api/setting/fileManagement/openFolder", route104);
app.use("/api/setting/fileManagement/openFolder", route105); app.use("/api/setting/getTextModel", route105);
app.use("/api/setting/getTextModel", route106); app.use("/api/setting/loginConfig/getUser", route106);
app.use("/api/setting/loginConfig/getUser", route107); app.use("/api/setting/loginConfig/updateUserPwd", route107);
app.use("/api/setting/loginConfig/updateUserPwd", route108); app.use("/api/setting/memoryConfig/delAllMemory", route108);
app.use("/api/setting/memoryConfig/delAllMemory", route109); app.use("/api/setting/memoryConfig/getMemory", route109);
app.use("/api/setting/memoryConfig/getMemory", route110); app.use("/api/setting/memoryConfig/sureMemory", route110);
app.use("/api/setting/memoryConfig/sureMemory", route111); app.use("/api/setting/promptManage/getPrompt", route111);
app.use("/api/setting/promptManage/getPrompt", route112); app.use("/api/setting/promptManage/updatePrompt", route112);
app.use("/api/setting/promptManage/updatePrompt", route113); app.use("/api/setting/skillManagement/getSkillContent", route113);
app.use("/api/setting/skillManagement/getSkillContent", route114); app.use("/api/setting/skillManagement/getSkillList", route114);
app.use("/api/setting/skillManagement/getSkillList", route115); app.use("/api/setting/skillManagement/saveSkillContent", route115);
app.use("/api/setting/skillManagement/saveSkillContent", route116); app.use("/api/setting/vendorConfig/addVendor", route116);
app.use("/api/setting/vendorConfig/addVendor", route117); app.use("/api/setting/vendorConfig/deleteVendor", route117);
app.use("/api/setting/vendorConfig/deleteVendor", route118); app.use("/api/setting/vendorConfig/enableEnglishVendor", route118);
app.use("/api/setting/vendorConfig/enableEnglishVendor", route119); app.use("/api/setting/vendorConfig/getVendorList", route119);
app.use("/api/setting/vendorConfig/getVendorList", route120); app.use("/api/setting/vendorConfig/modelTest", route120);
app.use("/api/setting/vendorConfig/modelTest", route121); app.use("/api/setting/vendorConfig/updateCode", route121);
app.use("/api/setting/vendorConfig/updateCode", route122); app.use("/api/setting/vendorConfig/updateVendor", route122);
app.use("/api/setting/vendorConfig/updateVendor", route123); app.use("/api/task/getProject", route123);
app.use("/api/task/getProject", route124); app.use("/api/task/getTaskApi", route124);
app.use("/api/task/getTaskApi", route125); app.use("/api/task/getTaskCategories", route125);
app.use("/api/task/getTaskCategories", route126); app.use("/api/task/taskDetails", route126);
app.use("/api/task/taskDetails", route127); app.use("/api/test/test", route127);
app.use("/api/test/test", route128);
} }

View File

@ -1,19 +0,0 @@
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();
export default router.post(
"/",
validateFields({
storyboardId: z.number(),
videoId: z.number(),
}),
async (req, res) => {
const { storyboardId, videoId } = req.body;
await u.db("o_videoConfig").where("storyboardId", storyboardId).update({ videoId, updateTime: Date.now() });
res.status(200).send(success({ message: "选择确认成功" }));
},
);

View File

@ -22,21 +22,22 @@ export default router.post(
resolution: z.string(), resolution: z.string(),
duration: z.number(), duration: z.number(),
audio: z.boolean().optional(), audio: z.boolean().optional(),
trackId: z.number(),
}), }),
async (req, res) => { async (req, res) => {
const { scriptId, projectId, prompt, uploadData, model, duration, resolution, audio, mode } = req.body; const { scriptId, projectId, prompt, uploadData, model, duration, resolution, audio, mode, trackId } = req.body;
//获取生成视频比例 //获取生成视频比例
const ratio = await u.db("o_project").select("videoRatio").where("id", projectId).first(); const ratio = await u.db("o_project").select("videoRatio").where("id", projectId).first();
const videoPath = `/${projectId}/video/${uuidv4()}.mp4`; //视频保存路径 const videoPath = `/${projectId}/video/${uuidv4()}.mp4`; //视频保存路径
//新增 //新增
const videoData = { const [videoId] = await u.db("o_video").insert({
filePath: videoPath, filePath: videoPath,
time: Date.now(), time: Date.now(),
state: "生成中", state: "生成中",
scriptId, scriptId,
projectId, projectId,
}; videoTrackId: trackId,
const [videoId] = await u.db("o_video").insert(videoData); });
//查询出图片数据 //查询出图片数据
const images = await Promise.all( const images = await Promise.all(
uploadData.map(async (item: { id: number; type: string }) => { uploadData.map(async (item: { id: number; type: string }) => {

View File

@ -8,25 +8,31 @@ const router = express.Router();
export default router.post( export default router.post(
"/", "/",
validateFields({ validateFields({
trackId: z.number(),
projectId: z.number(), projectId: z.number(),
prompt: z.array(z.string()), prompt: z.array(z.string()),
model: z.string(), model: z.string(),
}), }),
async (req, res) => { async (req, res) => {
const { projectId, prompt, model } = req.body; const { trackId, projectId, prompt, model } = req.body;
const [id, modelData] = model.split(":"); const [id, modelData] = model.split(":");
const projectData = await u.db("o_project").select("*").where({ id: projectId }).first(); const projectData = await u.db("o_project").select("*").where({ id: projectId }).first();
const artStyle = projectData?.artStyle || "无"; const artStyle = projectData?.artStyle || "无";
const visualManual = await u.getArtPrompt(artStyle, "art_storyboard_video"); const visualManual = u.getArtPrompt(artStyle, "art_storyboard_video");
const { text } = await u.Ai.Text("universalAi").invoke({ const { text } = await u.Ai.Text("universalAi").invoke({
system: visualManual, system: visualManual,
messages: [ messages: [
{ {
role: "user", role: "user",
content: `你是一个专业的${modelData}视频生成助手。请根据以下提示词,生成一段完整的、可直接用于视频生成模型的中文提示词。${prompt.join(",")}`, content: `你是一个专业的${modelData}视频生成助手。请根据以下提示词,生成一段完整的、可直接用于视频生成模型的中文提示词。${prompt.join(
",",
)}`,
}, },
], ],
}); });
await u.db("o_videoTrack").where({ id: trackId }).update({
prompt: text,
});
res.status(200).send(success(text)); res.status(200).send(success(text));
}, },
); );

View File

@ -15,10 +15,14 @@ interface TrackMedia {
src: string; src: string;
id?: number; id?: number;
fileType: "image" | "video" | "audio"; fileType: "image" | "video" | "audio";
prompt?: string;
} }
interface TrackItem { interface TrackItem {
id?: number; id?: number;
prompt: string;
state: "未生成" | "生成中" | "已完成" | "生成失败";
reason?: string;
medias: TrackMedia[]; medias: TrackMedia[];
videoList: VideoItem[]; videoList: VideoItem[];
} }
@ -31,21 +35,59 @@ export default router.post(
}), }),
async (req, res) => { async (req, res) => {
const { projectId, scriptId } = req.body; const { projectId, scriptId } = req.body;
// const data = await u.db("o_videoTrack").where({ projectId, scriptId }); const storyboardList = await u.db("o_storyboard").where({ scriptId, projectId }).orderBy("index", "asc");
const storyboardList = await u.db("o_storyboard").where({ scriptId }).orderBy("index", "asc"); const videoList = await u.db("o_video").whereIn(
console.log("%c Line:17 🥝 storyboardList", "background:#ea7e5c", storyboardList); "videoTrackId",
// const data = await u.db("o_video").where({ projectId, scriptId }); storyboardList.map((s) => s.trackId),
const trackList: TrackItem[] = [ );
{ console.log("%c Line:40 🌽 videoList", "background:#ffdd4d", videoList);
id: 1, const trackData = await u.db("o_videoTrack").whereIn(
medias: [{ src: "https://example.com/image1.jpg", fileType: "image", id: 1 }], //@ts-ignore
videoList: [ "id",
{ id: 1, src: "https://example.com/video1.mp4", state: "已完成" }, storyboardList.map((s) => s.trackId),
{ id: 2, src: "https://example.com/video2.mp4", state: "生成中" }, );
],
},
];
res.status(200).send(success(trackList)); const trackList: TrackItem[] = [];
const trackIdMap = [...new Set<number>(storyboardList.map((s) => s.trackId!))];
for (const trackId of trackIdMap) {
const item = trackData.find((t) => t.id === trackId);
trackList.push({
id: trackId,
prompt: item?.prompt || "",
state: (item?.state as "未生成" | "生成中" | "已完成" | "生成失败") ?? "未生成",
reason: item?.reason ?? "",
medias: await Promise.all(
storyboardList
.filter((s) => s.trackId === trackId)
.map(async (s): Promise<TrackMedia> => ({
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
fileType: "image",
...(s.prompt != null ? { prompt: s.prompt } : {}),
...(s.id != null ? { id: s.id } : {}),
})),
),
videoList: await Promise.all(
videoList
.filter((v) => v.videoTrackId === trackId)
.map(async (v) => ({
id: v.id!,
src: v.filePath ? await u.oss.getFileUrl(v.filePath) : "",
state: v.state === "done" ? "已完成" : v.state === "generating" ? "生成中" : v.state === "error" ? "生成失败" : "未生成",
})),
),
});
}
res.status(200).send(
success({
storyboardList: await Promise.all(
storyboardList.map(async (s) => ({
...s,
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
})),
),
trackList,
}),
);
}, },
); );

View File

@ -0,0 +1,32 @@
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();
export default router.post(
"/",
validateFields({
projectId: z.number(),
scriptId: z.number(),
}),
async (req, res) => {
const { projectId, scriptId } = req.body;
const storyboardList = await u.db("o_storyboard").where({ scriptId, projectId }).orderBy("index", "asc");
const videoList = await u.db("o_video").whereIn(
"videoTrackId",
storyboardList.map((s) => s.trackId),
);
res.status(200).send(
success(
await Promise.all(
videoList.map(async (s) => ({
...s,
src: s.filePath ? await u.oss.getFileUrl(s.filePath) : "",
})),
),
),
);
},
);

View File

@ -1,19 +0,0 @@
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();
export default router.post(
"/",
validateFields({
id: z.number(),
specifyIds: z.array(z.number()),
}),
async (req, res) => {
const { id, specifyIds } = req.body;
const data = await u.db("o_video").where("id", id).whereIn("id", specifyIds).andWhere("state", "生成中").select("*");
res.status(200).send(success(data));
},
);

View File

@ -1,11 +1,21 @@
// @db-hash f82eb99171699f051830710c1f816b59 <<<<<<< HEAD
// @db-hash 2c7f828da2621d74d1b0d147d4ba4342
=======
// @db-hash a27fff5b05e1c9ef490898f17703079a
>>>>>>> bf124d07e35f3d45958f5c2e64a650df7249f737
//该文件由脚本自动生成,请勿手动修改 //该文件由脚本自动生成,请勿手动修改
export interface _o_videoTrack_old_20260401 { export interface _o_vendorConfig_old_20260401 {
'id'?: number; 'author'?: string | null;
'projectId'?: number | null; 'code'?: string | null;
'scriptId'?: number | null; 'createTime'?: number | null;
'videoId'?: number | null; 'description'?: string | null;
'icon'?: string | null;
'id'?: string;
'inputs'?: string | null;
'inputValues'?: string | null;
'models'?: string | null;
'name'?: string | null;
} }
export interface memories { export interface memories {
'content': string; 'content': string;
@ -203,6 +213,7 @@ export interface o_vendorConfig {
'code'?: string | null; 'code'?: string | null;
'createTime'?: number | null; 'createTime'?: number | null;
'description'?: string | null; 'description'?: string | null;
'enableEnglish'?: number | null;
'icon'?: string | null; 'icon'?: string | null;
'id'?: string; 'id'?: string;
'inputs'?: string | null; 'inputs'?: string | null;
@ -231,7 +242,7 @@ export interface o_videoTrack {
} }
export interface DB { export interface DB {
"_o_videoTrack_old_20260401": _o_videoTrack_old_20260401; "_o_vendorConfig_old_20260401": _o_vendorConfig_old_20260401;
"memories": memories; "memories": memories;
"o_agentDeploy": o_agentDeploy; "o_agentDeploy": o_agentDeploy;
"o_agentWorkData": o_agentWorkData; "o_agentWorkData": o_agentWorkData;