Merge branch 'develop' of https://github.com/HBAI-Ltd/Toonflow-app into develop
This commit is contained in:
commit
11e07a3272
@ -47,4 +47,12 @@ export default async (knex: Knex): Promise<void> => {
|
|||||||
state: "生成失败",
|
state: "生成失败",
|
||||||
errorReason: "软件退出导致失败",
|
errorReason: "软件退出导致失败",
|
||||||
});
|
});
|
||||||
|
await addColumn("o_prompt", "useData", "text");
|
||||||
|
|
||||||
|
await db("o_prompt").where("type", "scriptAssetExtraction").update({
|
||||||
|
data: `---\nname: universal_agent\ndescription: 专注于从剧本内容中提取所使用的资产(角色、场景、道具)并生成结构化资产列表的助手。\n---\n\n# Script Assets Extract\n\n你是一个专业的剧本内容分析助手,专注于从剧本文本中识别和提取所有涉及的资产(角色、场景、道具),并为每项资产生成可供下游制作流程使用的结构化描述和提示词。\n\n## 何时使用\n\n用户提供剧本内容,你需要逐段阅读并提取其中涉及的所有资产(人物角色、场景地点、道具物件),输出为结构化的资产列表。产出的资产描述将用于后续 AI 图片生成和制作流程。\n\n## 与系统的对应关系\n\n- 资产类型:\n - \`role\` — 角色(对应 \`o_assets.type = "role"\`)\n - \`scene\` — 场景(对应 \`o_assets.type = "scene"\`)\n - \`tool\` — 道具(对应 \`o_assets.type = "tool"\`)\n- 下游用途:资产提示词生成 → AI 资产图生成 → 分镜制作\n\n## 输出要求\n\n**必须通过调用 \`resultTool\` 工具返回结果**,禁止以纯文本、Markdown 表格或 JSON 代码块等形式直接输出资产列表。\n\`resultTool\` 的 schema 会对字段类型和枚举值做强校验,调用时请严格按照下方字段定义填写,确保数据结构正确、字段完整、类型匹配。\n\n每个资产对象包含以下字段:\n\n| 字段 | 类型 | 必填 | 说明 |\n| ---- | ---- | ---- | ---- |\n| \`name\` | string | 是 | 资产名称,使用剧本中的原始称呼,不做其他多余描述 |\n| \`desc\` | string | 是 | 资产描述,30-80 字的视觉化描述 |\n| \`prompt\` | string | 是 | 生成提示词,英文,用于 AI 图片生成 |\n| \`type\` | enum | 是 | 资产类型:\`role\` / \`scene\` / \`tool\` |\n\n## 提取规则\n\n### 角色(role)\n\n- 提取剧本中出现的所有有名字的角色\n- \`desc\`:包含性别、外貌特征、服饰风格、体态气质等视觉要素,需在描述开头明确标注角色性别(如"男性,……"或"女性,……")\n- \`prompt\`:英文提示词,描述角色的外观特征,需以性别词开头(如 \`a young man, ...\` 或 \`a young woman, ...\`),适用于 AI 角色图生成\n- 同一角色有多个称呼时,取最常用的作为 \`name\`\n- 无名龙套(如"路人甲"、"士兵")可跳过,除非其造型对剧情有重要视觉意义\n\n### 场景(scene)\n\n- 提取剧本中出现的所有场景/地点\n- \`desc\`:包含空间结构、光照氛围、关键陈设、色调基调等视觉要素\n- \`prompt\`:英文提示词,描述场景的整体视觉风格,适用于 AI 场景图生成\n- 同一场景的不同状态(如白天/夜晚)不重复提取,在 \`desc\` 中注明即可\n\n### 道具(tool)\n\n- 提取剧本中出现的重要道具/物品\n- \`desc\`:包含外观形状、颜色材质、尺寸参考、特殊效果等视觉要素\n- \`prompt\`:英文提示词,描述道具的外观细节,适用于 AI 道具图生成\n- 仅提取有独立视觉意义或剧情功能的道具,通用物品可跳过\n\n\n## 提示词(prompt)生成规范\n\n- 采用逗号分隔的关键词/短语格式\n- 优先描述**视觉特征**,避免抽象概念\n- 包含风格关键词(如 anime style, manga style 等,根据项目风格决定)\n- 角色 prompt 示例:\`a young man, sharp eyebrows, black hair, pale skin, wearing a gray Taoist robe, slender build, cold expression\`\n- 场景 prompt 示例:\`dark cave interior, glowing crystals on walls, misty atmosphere, dim blue lighting, stone altar in center\`\n- 道具 prompt 示例:\`ancient jade pendant, oval shape, translucent green, carved dragon pattern, glowing faintly\`\n\n## 提取流程\n\n1. 通读剧本全文,识别所有出现的角色、场景、道具\n2. 对每个资产生成结构化的 \`name\`、\`desc\`、\`prompt\`、\`type\`\n3. 去重:同一资产不重复提取\n4. **必须通过调用 \`resultTool\` 工具输出完整资产列表**,不要分多次调用,一次性将所有资产放入 \`assetsList\` 数组中提交\n\n## 提取原则\n\n1. **忠于剧本**:所有提取基于剧本中的实际内容,不臆造未出现的资产\n2. **视觉优先**:描述和提示词聚焦视觉特征,便于 AI 图片生成\n3. **精简实用**:只提取对制作有实际意义的资产,避免过度提取\n4. **分类准确**:严格按照 role/scene/tool 分类,不混淆\n5. **提示词质量**:英文提示词应具体、可执行,能直接用于 AI 图片生成\n\n## 注意事项\n\n- 资产列表中**不要包含剧本内容本身**,仅提取所使用到的资产\n- 角色的随身物品如果有独立剧情功能,应单独作为道具提取\n- 场景中的固定陈设不需要单独提取为道具,除非该物件有独立剧情作用`,
|
||||||
|
});
|
||||||
|
await db("o_prompt").where("type", "videoPromptGeneration").update({
|
||||||
|
data: `---\nname: universal_agent\ndescription: 专注于从剧本内容中提取所使用的资产(角色、场景、道具)并生成结构化资产列表的助手。\n---\n\n# Script Assets Extract\n\n你是一个专业的剧本内容分析助手,专注于从剧本文本中识别和提取所有涉及的资产(角色、场景、道具),并为每项资产生成可供下游制作流程使用的结构化描述和提示词。\n\n## 何时使用\n\n用户提供剧本内容,你需要逐段阅读并提取其中涉及的所有资产(人物角色、场景地点、道具物件),输出为结构化的资产列表。产出的资产描述将用于后续 AI 图片生成和制作流程。\n\n## 与系统的对应关系\n\n- 资产类型:\n - \`role\` — 角色(对应 \`o_assets.type = "role"\`)\n - \`scene\` — 场景(对应 \`o_assets.type = "scene"\`)\n - \`tool\` — 道具(对应 \`o_assets.type = "tool"\`)\n- 下游用途:资产提示词生成 → AI 资产图生成 → 分镜制作\n\n## 输出要求\n\n**必须通过调用 \`resultTool\` 工具返回结果**,禁止以纯文本、Markdown 表格或 JSON 代码块等形式直接输出资产列表。\n\`resultTool\` 的 schema 会对字段类型和枚举值做强校验,调用时请严格按照下方字段定义填写,确保数据结构正确、字段完整、类型匹配。\n\n每个资产对象包含以下字段:\n\n| 字段 | 类型 | 必填 | 说明 |\n| ---- | ---- | ---- | ---- |\n| \`name\` | string | 是 | 资产名称,使用剧本中的原始称呼,不做其他多余描述 |\n| \`desc\` | string | 是 | 资产描述,30-80 字的视觉化描述 |\n| \`prompt\` | string | 是 | 生成提示词,英文,用于 AI 图片生成 |\n| \`type\` | enum | 是 | 资产类型:\`role\` / \`scene\` / \`tool\` |\n\n## 提取规则\n\n### 角色(role)\n\n- 提取剧本中出现的所有有名字的角色\n- \`desc\`:包含性别、外貌特征、服饰风格、体态气质等视觉要素,需在描述开头明确标注角色性别(如"男性,……"或"女性,……")\n- \`prompt\`:英文提示词,描述角色的外观特征,需以性别词开头(如 \`a young man, ...\` 或 \`a young woman, ...\`),适用于 AI 角色图生成\n- 同一角色有多个称呼时,取最常用的作为 \`name\`\n- 无名龙套(如"路人甲"、"士兵")可跳过,除非其造型对剧情有重要视觉意义\n\n### 场景(scene)\n\n- 提取剧本中出现的所有场景/地点\n- \`desc\`:包含空间结构、光照氛围、关键陈设、色调基调等视觉要素\n- \`prompt\`:英文提示词,描述场景的整体视觉风格,适用于 AI 场景图生成\n- 同一场景的不同状态(如白天/夜晚)不重复提取,在 \`desc\` 中注明即可\n\n### 道具(tool)\n\n- 提取剧本中出现的重要道具/物品\n- \`desc\`:包含外观形状、颜色材质、尺寸参考、特殊效果等视觉要素\n- \`prompt\`:英文提示词,描述道具的外观细节,适用于 AI 道具图生成\n- 仅提取有独立视觉意义或剧情功能的道具,通用物品可跳过\n\n\n## 提示词(prompt)生成规范\n\n- 采用逗号分隔的关键词/短语格式\n- 优先描述**视觉特征**,避免抽象概念\n- 包含风格关键词(如 anime style, manga style 等,根据项目风格决定)\n- 角色 prompt 示例:\`a young man, sharp eyebrows, black hair, pale skin, wearing a gray Taoist robe, slender build, cold expression\`\n- 场景 prompt 示例:\`dark cave interior, glowing crystals on walls, misty atmosphere, dim blue lighting, stone altar in center\`\n- 道具 prompt 示例:\`ancient jade pendant, oval shape, translucent green, carved dragon pattern, glowing faintly\`\n\n## 提取流程\n\n1. 通读剧本全文,识别所有出现的角色、场景、道具\n2. 对每个资产生成结构化的 \`name\`、\`desc\`、\`prompt\`、\`type\`\n3. 去重:同一资产不重复提取\n4. **必须通过调用 \`resultTool\` 工具输出完整资产列表**,不要分多次调用,一次性将所有资产放入 \`assetsList\` 数组中提交\n\n## 提取原则\n\n1. **忠于剧本**:所有提取基于剧本中的实际内容,不臆造未出现的资产\n2. **视觉优先**:描述和提示词聚焦视觉特征,便于 AI 图片生成\n3. **精简实用**:只提取对制作有实际意义的资产,避免过度提取\n4. **分类准确**:严格按照 role/scene/tool 分类,不混淆\n5. **提示词质量**:英文提示词应具体、可执行,能直接用于 AI 图片生成\n\n## 注意事项\n\n- 资产列表中**不要包含剧本内容本身**,仅提取所使用到的资产\n- 角色的随身物品如果有独立剧情功能,应单独作为道具提取\n- 场景中的固定陈设不需要单独提取为道具,除非该物件有独立剧情作用`,
|
||||||
|
});
|
||||||
};
|
};
|
||||||
|
|||||||
@ -196,6 +196,7 @@ export default async (knex: Knex, forceInit: boolean = false): Promise<void> =>
|
|||||||
table.string("name");
|
table.string("name");
|
||||||
table.string("type");
|
table.string("type");
|
||||||
table.text("data");
|
table.text("data");
|
||||||
|
table.text("useData");
|
||||||
table.primary(["id"]);
|
table.primary(["id"]);
|
||||||
table.unique(["id"]);
|
table.unique(["id"]);
|
||||||
},
|
},
|
||||||
|
|||||||
464
src/router.ts
464
src/router.ts
@ -1,4 +1,4 @@
|
|||||||
// @routes-hash 3fe6b0875d18070c4a2ef9d9f8e97e91
|
// @routes-hash 533b8bb2b9e91ff514cd1560e6d1cca8
|
||||||
import { Express } from "express";
|
import { Express } from "express";
|
||||||
|
|
||||||
import route1 from "./routes/agents/clearMemory";
|
import route1 from "./routes/agents/clearMemory";
|
||||||
@ -22,121 +22,122 @@ import route18 from "./routes/assets/updateAssets";
|
|||||||
import route19 from "./routes/assets/uploadClip";
|
import route19 from "./routes/assets/uploadClip";
|
||||||
import route20 from "./routes/assetsGenerate/batchGenerateImageAssets";
|
import route20 from "./routes/assetsGenerate/batchGenerateImageAssets";
|
||||||
import route21 from "./routes/assetsGenerate/batchPolishAssetsPrompt";
|
import route21 from "./routes/assetsGenerate/batchPolishAssetsPrompt";
|
||||||
import route22 from "./routes/assetsGenerate/generateAssets";
|
import route22 from "./routes/assetsGenerate/cancelGenerate";
|
||||||
import route23 from "./routes/assetsGenerate/polishAssetsPrompt";
|
import route23 from "./routes/assetsGenerate/generateAssets";
|
||||||
import route24 from "./routes/cornerScape/getAllAssets";
|
import route24 from "./routes/assetsGenerate/polishAssetsPrompt";
|
||||||
import route25 from "./routes/general/generalStatistics";
|
import route25 from "./routes/cornerScape/getAllAssets";
|
||||||
import route26 from "./routes/general/getSingleProject";
|
import route26 from "./routes/general/generalStatistics";
|
||||||
import route27 from "./routes/general/updateProject";
|
import route27 from "./routes/general/getSingleProject";
|
||||||
import route28 from "./routes/login/login";
|
import route28 from "./routes/general/updateProject";
|
||||||
import route29 from "./routes/migrate/migrateData";
|
import route29 from "./routes/login/login";
|
||||||
import route30 from "./routes/modelSelect/getModelDetail";
|
import route30 from "./routes/migrate/migrateData";
|
||||||
import route31 from "./routes/modelSelect/getModelList";
|
import route31 from "./routes/modelSelect/getModelDetail";
|
||||||
import route32 from "./routes/novel/addNovel";
|
import route32 from "./routes/modelSelect/getModelList";
|
||||||
import route33 from "./routes/novel/batchDeleteNovel";
|
import route33 from "./routes/novel/addNovel";
|
||||||
import route34 from "./routes/novel/delNovel";
|
import route34 from "./routes/novel/batchDeleteNovel";
|
||||||
import route35 from "./routes/novel/event/batchDeleteEvent";
|
import route35 from "./routes/novel/delNovel";
|
||||||
import route36 from "./routes/novel/event/deletEvent";
|
import route36 from "./routes/novel/event/batchDeleteEvent";
|
||||||
import route37 from "./routes/novel/event/generateEvents";
|
import route37 from "./routes/novel/event/deletEvent";
|
||||||
import route38 from "./routes/novel/event/getEvent";
|
import route38 from "./routes/novel/event/generateEvents";
|
||||||
import route39 from "./routes/novel/getNovel";
|
import route39 from "./routes/novel/event/getEvent";
|
||||||
import route40 from "./routes/novel/getNovelData";
|
import route40 from "./routes/novel/getNovel";
|
||||||
import route41 from "./routes/novel/getNovelEventState";
|
import route41 from "./routes/novel/getNovelData";
|
||||||
import route42 from "./routes/novel/getNovelIndex";
|
import route42 from "./routes/novel/getNovelEventState";
|
||||||
import route43 from "./routes/novel/updateNovel";
|
import route43 from "./routes/novel/getNovelIndex";
|
||||||
import route44 from "./routes/other/deleteAllData";
|
import route44 from "./routes/novel/updateNovel";
|
||||||
import route45 from "./routes/other/getVersion";
|
import route45 from "./routes/other/deleteAllData";
|
||||||
import route46 from "./routes/production/assets/batchGenerateAssetsImage";
|
import route46 from "./routes/other/getVersion";
|
||||||
import route47 from "./routes/production/assets/deleteAssetsDireve";
|
import route47 from "./routes/production/assets/batchGenerateAssetsImage";
|
||||||
import route48 from "./routes/production/assets/getAssetsData";
|
import route48 from "./routes/production/assets/deleteAssetsDireve";
|
||||||
import route49 from "./routes/production/assets/pollingImage";
|
import route49 from "./routes/production/assets/getAssetsData";
|
||||||
import route50 from "./routes/production/assets/updateAssetsUrl";
|
import route50 from "./routes/production/assets/pollingImage";
|
||||||
import route51 from "./routes/production/editImage/generateFlowImage";
|
import route51 from "./routes/production/assets/updateAssetsUrl";
|
||||||
import route52 from "./routes/production/editImage/getImageDefaultModle";
|
import route52 from "./routes/production/editImage/generateFlowImage";
|
||||||
import route53 from "./routes/production/editImage/getImageFlow";
|
import route53 from "./routes/production/editImage/getImageDefaultModle";
|
||||||
import route54 from "./routes/production/editImage/saveImageFlow";
|
import route54 from "./routes/production/editImage/getImageFlow";
|
||||||
import route55 from "./routes/production/editImage/updateImageFlow";
|
import route55 from "./routes/production/editImage/saveImageFlow";
|
||||||
import route56 from "./routes/production/editImage/uploadImage";
|
import route56 from "./routes/production/editImage/updateImageFlow";
|
||||||
import route57 from "./routes/production/exportImage";
|
import route57 from "./routes/production/editImage/uploadImage";
|
||||||
import route58 from "./routes/production/getFlowData";
|
import route58 from "./routes/production/exportImage";
|
||||||
import route59 from "./routes/production/getProductionData";
|
import route59 from "./routes/production/getFlowData";
|
||||||
import route60 from "./routes/production/getStoryboardData";
|
import route60 from "./routes/production/getProductionData";
|
||||||
import route61 from "./routes/production/saveFlowData";
|
import route61 from "./routes/production/getStoryboardData";
|
||||||
import route62 from "./routes/production/storyboard/addStoryboard";
|
import route62 from "./routes/production/saveFlowData";
|
||||||
import route63 from "./routes/production/storyboard/batchAddStoryboardInfo";
|
import route63 from "./routes/production/storyboard/addStoryboard";
|
||||||
import route64 from "./routes/production/storyboard/batchGenerateImage";
|
import route64 from "./routes/production/storyboard/batchAddStoryboardInfo";
|
||||||
import route65 from "./routes/production/storyboard/downPreviewImage";
|
import route65 from "./routes/production/storyboard/batchGenerateImage";
|
||||||
import route66 from "./routes/production/storyboard/editStoryboardInfo";
|
import route66 from "./routes/production/storyboard/downPreviewImage";
|
||||||
import route67 from "./routes/production/storyboard/getStoryboardData";
|
import route67 from "./routes/production/storyboard/editStoryboardInfo";
|
||||||
import route68 from "./routes/production/storyboard/pollingImage";
|
import route68 from "./routes/production/storyboard/getStoryboardData";
|
||||||
import route69 from "./routes/production/storyboard/previewImage";
|
import route69 from "./routes/production/storyboard/pollingImage";
|
||||||
import route70 from "./routes/production/storyboard/removeFrame";
|
import route70 from "./routes/production/storyboard/previewImage";
|
||||||
import route71 from "./routes/production/storyboard/updateStoryboardUrl";
|
import route71 from "./routes/production/storyboard/removeFrame";
|
||||||
import route72 from "./routes/production/workbench/addTrack";
|
import route72 from "./routes/production/storyboard/updateStoryboardUrl";
|
||||||
import route73 from "./routes/production/workbench/deleteTrack";
|
import route73 from "./routes/production/workbench/addTrack";
|
||||||
import route74 from "./routes/production/workbench/delVideo";
|
import route74 from "./routes/production/workbench/deleteTrack";
|
||||||
import route75 from "./routes/production/workbench/generateVideo";
|
import route75 from "./routes/production/workbench/delVideo";
|
||||||
import route76 from "./routes/production/workbench/generateVideoPrompt";
|
import route76 from "./routes/production/workbench/generateVideo";
|
||||||
import route77 from "./routes/production/workbench/getGenerateData";
|
import route77 from "./routes/production/workbench/generateVideoPrompt";
|
||||||
import route78 from "./routes/production/workbench/getVideoList";
|
import route78 from "./routes/production/workbench/getGenerateData";
|
||||||
import route79 from "./routes/production/workbench/getVideoModelDetail";
|
import route79 from "./routes/production/workbench/getVideoList";
|
||||||
import route80 from "./routes/production/workbench/selectVideo";
|
import route80 from "./routes/production/workbench/getVideoModelDetail";
|
||||||
import route81 from "./routes/project/addDirectorManual";
|
import route81 from "./routes/production/workbench/selectVideo";
|
||||||
import route82 from "./routes/project/addProject";
|
import route82 from "./routes/project/addDirectorManual";
|
||||||
import route83 from "./routes/project/addVisualManual";
|
import route83 from "./routes/project/addProject";
|
||||||
import route84 from "./routes/project/deleteDirectorManual";
|
import route84 from "./routes/project/addVisualManual";
|
||||||
import route85 from "./routes/project/deleteVisualManual";
|
import route85 from "./routes/project/deleteDirectorManual";
|
||||||
import route86 from "./routes/project/delProject";
|
import route86 from "./routes/project/deleteVisualManual";
|
||||||
import route87 from "./routes/project/editDirectorlManual";
|
import route87 from "./routes/project/delProject";
|
||||||
import route88 from "./routes/project/editProject";
|
import route88 from "./routes/project/editDirectorlManual";
|
||||||
import route89 from "./routes/project/editVisualManual";
|
import route89 from "./routes/project/editProject";
|
||||||
import route90 from "./routes/project/getProject";
|
import route90 from "./routes/project/editVisualManual";
|
||||||
import route91 from "./routes/project/getVisualManual";
|
import route91 from "./routes/project/getProject";
|
||||||
import route92 from "./routes/project/queryDirectorManual";
|
import route92 from "./routes/project/getVisualManual";
|
||||||
import route93 from "./routes/project/visualManual";
|
import route93 from "./routes/project/queryDirectorManual";
|
||||||
import route94 from "./routes/script/addScript";
|
import route94 from "./routes/project/visualManual";
|
||||||
import route95 from "./routes/script/delScript";
|
import route95 from "./routes/script/addScript";
|
||||||
import route96 from "./routes/script/exportScript";
|
import route96 from "./routes/script/delScript";
|
||||||
import route97 from "./routes/script/extractAssets";
|
import route97 from "./routes/script/exportScript";
|
||||||
import route98 from "./routes/script/getScrptApi";
|
import route98 from "./routes/script/extractAssets";
|
||||||
import route99 from "./routes/script/pollScriptAssets";
|
import route99 from "./routes/script/getScrptApi";
|
||||||
import route100 from "./routes/script/updateScript";
|
import route100 from "./routes/script/pollScriptAssets";
|
||||||
import route101 from "./routes/scriptAgent/getPlanData";
|
import route101 from "./routes/script/updateScript";
|
||||||
import route102 from "./routes/scriptAgent/setPlanData";
|
import route102 from "./routes/scriptAgent/getPlanData";
|
||||||
import route103 from "./routes/scriptAgent/updateData";
|
import route103 from "./routes/scriptAgent/setPlanData";
|
||||||
import route104 from "./routes/setting/about/checkUpdate";
|
import route104 from "./routes/scriptAgent/updateData";
|
||||||
import route105 from "./routes/setting/about/downloadApp";
|
import route105 from "./routes/setting/about/checkUpdate";
|
||||||
import route106 from "./routes/setting/agentDeploy/agentSetKey";
|
import route106 from "./routes/setting/about/downloadApp";
|
||||||
import route107 from "./routes/setting/agentDeploy/deployAgentModel";
|
import route107 from "./routes/setting/agentDeploy/agentSetKey";
|
||||||
import route108 from "./routes/setting/agentDeploy/getAgentDeploy";
|
import route108 from "./routes/setting/agentDeploy/deployAgentModel";
|
||||||
import route109 from "./routes/setting/dbConfig/clearData";
|
import route109 from "./routes/setting/agentDeploy/getAgentDeploy";
|
||||||
import route110 from "./routes/setting/dev/getSwitchAiDevTool";
|
import route110 from "./routes/setting/dbConfig/clearData";
|
||||||
import route111 from "./routes/setting/dev/updateSwitchAiDevTool";
|
import route111 from "./routes/setting/dev/getSwitchAiDevTool";
|
||||||
import route112 from "./routes/setting/fileManagement/openFolder";
|
import route112 from "./routes/setting/dev/updateSwitchAiDevTool";
|
||||||
import route113 from "./routes/setting/getTextModel";
|
import route113 from "./routes/setting/fileManagement/openFolder";
|
||||||
import route114 from "./routes/setting/loginConfig/getUser";
|
import route114 from "./routes/setting/getTextModel";
|
||||||
import route115 from "./routes/setting/loginConfig/updateUserPwd";
|
import route115 from "./routes/setting/loginConfig/getUser";
|
||||||
import route116 from "./routes/setting/memoryConfig/delAllMemory";
|
import route116 from "./routes/setting/loginConfig/updateUserPwd";
|
||||||
import route117 from "./routes/setting/memoryConfig/getMemory";
|
import route117 from "./routes/setting/memoryConfig/delAllMemory";
|
||||||
import route118 from "./routes/setting/memoryConfig/sureMemory";
|
import route118 from "./routes/setting/memoryConfig/getMemory";
|
||||||
import route119 from "./routes/setting/promptManage/getPrompt";
|
import route119 from "./routes/setting/memoryConfig/sureMemory";
|
||||||
import route120 from "./routes/setting/promptManage/updatePrompt";
|
import route120 from "./routes/setting/promptManage/getPrompt";
|
||||||
import route121 from "./routes/setting/skillManagement/getSkillContent";
|
import route121 from "./routes/setting/promptManage/updatePrompt";
|
||||||
import route122 from "./routes/setting/skillManagement/getSkillList";
|
import route122 from "./routes/setting/skillManagement/getSkillContent";
|
||||||
import route123 from "./routes/setting/skillManagement/saveSkillContent";
|
import route123 from "./routes/setting/skillManagement/getSkillList";
|
||||||
import route124 from "./routes/setting/vendorConfig/addVendor";
|
import route124 from "./routes/setting/skillManagement/saveSkillContent";
|
||||||
import route125 from "./routes/setting/vendorConfig/deleteVendor";
|
import route125 from "./routes/setting/vendorConfig/addVendor";
|
||||||
import route126 from "./routes/setting/vendorConfig/enableVendor";
|
import route126 from "./routes/setting/vendorConfig/deleteVendor";
|
||||||
import route127 from "./routes/setting/vendorConfig/getCodeByLink";
|
import route127 from "./routes/setting/vendorConfig/enableVendor";
|
||||||
import route128 from "./routes/setting/vendorConfig/getVendorList";
|
import route128 from "./routes/setting/vendorConfig/getCodeByLink";
|
||||||
import route129 from "./routes/setting/vendorConfig/modelTest";
|
import route129 from "./routes/setting/vendorConfig/getVendorList";
|
||||||
import route130 from "./routes/setting/vendorConfig/updateCode";
|
import route130 from "./routes/setting/vendorConfig/modelTest";
|
||||||
import route131 from "./routes/setting/vendorConfig/updateVendor";
|
import route131 from "./routes/setting/vendorConfig/updateCode";
|
||||||
import route132 from "./routes/task/getProject";
|
import route132 from "./routes/setting/vendorConfig/updateVendor";
|
||||||
import route133 from "./routes/task/getTaskApi";
|
import route133 from "./routes/task/getProject";
|
||||||
import route134 from "./routes/task/getTaskCategories";
|
import route134 from "./routes/task/getTaskApi";
|
||||||
import route135 from "./routes/task/taskDetails";
|
import route135 from "./routes/task/getTaskCategories";
|
||||||
import route136 from "./routes/test/test";
|
import route136 from "./routes/task/taskDetails";
|
||||||
|
import route137 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);
|
||||||
@ -160,119 +161,120 @@ export default async (app: Express) => {
|
|||||||
app.use("/api/assets/uploadClip", route19);
|
app.use("/api/assets/uploadClip", route19);
|
||||||
app.use("/api/assetsGenerate/batchGenerateImageAssets", route20);
|
app.use("/api/assetsGenerate/batchGenerateImageAssets", route20);
|
||||||
app.use("/api/assetsGenerate/batchPolishAssetsPrompt", route21);
|
app.use("/api/assetsGenerate/batchPolishAssetsPrompt", route21);
|
||||||
app.use("/api/assetsGenerate/generateAssets", route22);
|
app.use("/api/assetsGenerate/cancelGenerate", route22);
|
||||||
app.use("/api/assetsGenerate/polishAssetsPrompt", route23);
|
app.use("/api/assetsGenerate/generateAssets", route23);
|
||||||
app.use("/api/cornerScape/getAllAssets", route24);
|
app.use("/api/assetsGenerate/polishAssetsPrompt", route24);
|
||||||
app.use("/api/general/generalStatistics", route25);
|
app.use("/api/cornerScape/getAllAssets", route25);
|
||||||
app.use("/api/general/getSingleProject", route26);
|
app.use("/api/general/generalStatistics", route26);
|
||||||
app.use("/api/general/updateProject", route27);
|
app.use("/api/general/getSingleProject", route27);
|
||||||
app.use("/api/login/login", route28);
|
app.use("/api/general/updateProject", route28);
|
||||||
app.use("/api/migrate/migrateData", route29);
|
app.use("/api/login/login", route29);
|
||||||
app.use("/api/modelSelect/getModelDetail", route30);
|
app.use("/api/migrate/migrateData", route30);
|
||||||
app.use("/api/modelSelect/getModelList", route31);
|
app.use("/api/modelSelect/getModelDetail", route31);
|
||||||
app.use("/api/novel/addNovel", route32);
|
app.use("/api/modelSelect/getModelList", route32);
|
||||||
app.use("/api/novel/batchDeleteNovel", route33);
|
app.use("/api/novel/addNovel", route33);
|
||||||
app.use("/api/novel/delNovel", route34);
|
app.use("/api/novel/batchDeleteNovel", route34);
|
||||||
app.use("/api/novel/event/batchDeleteEvent", route35);
|
app.use("/api/novel/delNovel", route35);
|
||||||
app.use("/api/novel/event/deletEvent", route36);
|
app.use("/api/novel/event/batchDeleteEvent", route36);
|
||||||
app.use("/api/novel/event/generateEvents", route37);
|
app.use("/api/novel/event/deletEvent", route37);
|
||||||
app.use("/api/novel/event/getEvent", route38);
|
app.use("/api/novel/event/generateEvents", route38);
|
||||||
app.use("/api/novel/getNovel", route39);
|
app.use("/api/novel/event/getEvent", route39);
|
||||||
app.use("/api/novel/getNovelData", route40);
|
app.use("/api/novel/getNovel", route40);
|
||||||
app.use("/api/novel/getNovelEventState", route41);
|
app.use("/api/novel/getNovelData", route41);
|
||||||
app.use("/api/novel/getNovelIndex", route42);
|
app.use("/api/novel/getNovelEventState", route42);
|
||||||
app.use("/api/novel/updateNovel", route43);
|
app.use("/api/novel/getNovelIndex", route43);
|
||||||
app.use("/api/other/deleteAllData", route44);
|
app.use("/api/novel/updateNovel", route44);
|
||||||
app.use("/api/other/getVersion", route45);
|
app.use("/api/other/deleteAllData", route45);
|
||||||
app.use("/api/production/assets/batchGenerateAssetsImage", route46);
|
app.use("/api/other/getVersion", route46);
|
||||||
app.use("/api/production/assets/deleteAssetsDireve", route47);
|
app.use("/api/production/assets/batchGenerateAssetsImage", route47);
|
||||||
app.use("/api/production/assets/getAssetsData", route48);
|
app.use("/api/production/assets/deleteAssetsDireve", route48);
|
||||||
app.use("/api/production/assets/pollingImage", route49);
|
app.use("/api/production/assets/getAssetsData", route49);
|
||||||
app.use("/api/production/assets/updateAssetsUrl", route50);
|
app.use("/api/production/assets/pollingImage", route50);
|
||||||
app.use("/api/production/editImage/generateFlowImage", route51);
|
app.use("/api/production/assets/updateAssetsUrl", route51);
|
||||||
app.use("/api/production/editImage/getImageDefaultModle", route52);
|
app.use("/api/production/editImage/generateFlowImage", route52);
|
||||||
app.use("/api/production/editImage/getImageFlow", route53);
|
app.use("/api/production/editImage/getImageDefaultModle", route53);
|
||||||
app.use("/api/production/editImage/saveImageFlow", route54);
|
app.use("/api/production/editImage/getImageFlow", route54);
|
||||||
app.use("/api/production/editImage/updateImageFlow", route55);
|
app.use("/api/production/editImage/saveImageFlow", route55);
|
||||||
app.use("/api/production/editImage/uploadImage", route56);
|
app.use("/api/production/editImage/updateImageFlow", route56);
|
||||||
app.use("/api/production/exportImage", route57);
|
app.use("/api/production/editImage/uploadImage", route57);
|
||||||
app.use("/api/production/getFlowData", route58);
|
app.use("/api/production/exportImage", route58);
|
||||||
app.use("/api/production/getProductionData", route59);
|
app.use("/api/production/getFlowData", route59);
|
||||||
app.use("/api/production/getStoryboardData", route60);
|
app.use("/api/production/getProductionData", route60);
|
||||||
app.use("/api/production/saveFlowData", route61);
|
app.use("/api/production/getStoryboardData", route61);
|
||||||
app.use("/api/production/storyboard/addStoryboard", route62);
|
app.use("/api/production/saveFlowData", route62);
|
||||||
app.use("/api/production/storyboard/batchAddStoryboardInfo", route63);
|
app.use("/api/production/storyboard/addStoryboard", route63);
|
||||||
app.use("/api/production/storyboard/batchGenerateImage", route64);
|
app.use("/api/production/storyboard/batchAddStoryboardInfo", route64);
|
||||||
app.use("/api/production/storyboard/downPreviewImage", route65);
|
app.use("/api/production/storyboard/batchGenerateImage", route65);
|
||||||
app.use("/api/production/storyboard/editStoryboardInfo", route66);
|
app.use("/api/production/storyboard/downPreviewImage", route66);
|
||||||
app.use("/api/production/storyboard/getStoryboardData", route67);
|
app.use("/api/production/storyboard/editStoryboardInfo", route67);
|
||||||
app.use("/api/production/storyboard/pollingImage", route68);
|
app.use("/api/production/storyboard/getStoryboardData", route68);
|
||||||
app.use("/api/production/storyboard/previewImage", route69);
|
app.use("/api/production/storyboard/pollingImage", route69);
|
||||||
app.use("/api/production/storyboard/removeFrame", route70);
|
app.use("/api/production/storyboard/previewImage", route70);
|
||||||
app.use("/api/production/storyboard/updateStoryboardUrl", route71);
|
app.use("/api/production/storyboard/removeFrame", route71);
|
||||||
app.use("/api/production/workbench/addTrack", route72);
|
app.use("/api/production/storyboard/updateStoryboardUrl", route72);
|
||||||
app.use("/api/production/workbench/deleteTrack", route73);
|
app.use("/api/production/workbench/addTrack", route73);
|
||||||
app.use("/api/production/workbench/delVideo", route74);
|
app.use("/api/production/workbench/deleteTrack", route74);
|
||||||
app.use("/api/production/workbench/generateVideo", route75);
|
app.use("/api/production/workbench/delVideo", route75);
|
||||||
app.use("/api/production/workbench/generateVideoPrompt", route76);
|
app.use("/api/production/workbench/generateVideo", route76);
|
||||||
app.use("/api/production/workbench/getGenerateData", route77);
|
app.use("/api/production/workbench/generateVideoPrompt", route77);
|
||||||
app.use("/api/production/workbench/getVideoList", route78);
|
app.use("/api/production/workbench/getGenerateData", route78);
|
||||||
app.use("/api/production/workbench/getVideoModelDetail", route79);
|
app.use("/api/production/workbench/getVideoList", route79);
|
||||||
app.use("/api/production/workbench/selectVideo", route80);
|
app.use("/api/production/workbench/getVideoModelDetail", route80);
|
||||||
app.use("/api/project/addDirectorManual", route81);
|
app.use("/api/production/workbench/selectVideo", route81);
|
||||||
app.use("/api/project/addProject", route82);
|
app.use("/api/project/addDirectorManual", route82);
|
||||||
app.use("/api/project/addVisualManual", route83);
|
app.use("/api/project/addProject", route83);
|
||||||
app.use("/api/project/deleteDirectorManual", route84);
|
app.use("/api/project/addVisualManual", route84);
|
||||||
app.use("/api/project/deleteVisualManual", route85);
|
app.use("/api/project/deleteDirectorManual", route85);
|
||||||
app.use("/api/project/delProject", route86);
|
app.use("/api/project/deleteVisualManual", route86);
|
||||||
app.use("/api/project/editDirectorlManual", route87);
|
app.use("/api/project/delProject", route87);
|
||||||
app.use("/api/project/editProject", route88);
|
app.use("/api/project/editDirectorlManual", route88);
|
||||||
app.use("/api/project/editVisualManual", route89);
|
app.use("/api/project/editProject", route89);
|
||||||
app.use("/api/project/getProject", route90);
|
app.use("/api/project/editVisualManual", route90);
|
||||||
app.use("/api/project/getVisualManual", route91);
|
app.use("/api/project/getProject", route91);
|
||||||
app.use("/api/project/queryDirectorManual", route92);
|
app.use("/api/project/getVisualManual", route92);
|
||||||
app.use("/api/project/visualManual", route93);
|
app.use("/api/project/queryDirectorManual", route93);
|
||||||
app.use("/api/script/addScript", route94);
|
app.use("/api/project/visualManual", route94);
|
||||||
app.use("/api/script/delScript", route95);
|
app.use("/api/script/addScript", route95);
|
||||||
app.use("/api/script/exportScript", route96);
|
app.use("/api/script/delScript", route96);
|
||||||
app.use("/api/script/extractAssets", route97);
|
app.use("/api/script/exportScript", route97);
|
||||||
app.use("/api/script/getScrptApi", route98);
|
app.use("/api/script/extractAssets", route98);
|
||||||
app.use("/api/script/pollScriptAssets", route99);
|
app.use("/api/script/getScrptApi", route99);
|
||||||
app.use("/api/script/updateScript", route100);
|
app.use("/api/script/pollScriptAssets", route100);
|
||||||
app.use("/api/scriptAgent/getPlanData", route101);
|
app.use("/api/script/updateScript", route101);
|
||||||
app.use("/api/scriptAgent/setPlanData", route102);
|
app.use("/api/scriptAgent/getPlanData", route102);
|
||||||
app.use("/api/scriptAgent/updateData", route103);
|
app.use("/api/scriptAgent/setPlanData", route103);
|
||||||
app.use("/api/setting/about/checkUpdate", route104);
|
app.use("/api/scriptAgent/updateData", route104);
|
||||||
app.use("/api/setting/about/downloadApp", route105);
|
app.use("/api/setting/about/checkUpdate", route105);
|
||||||
app.use("/api/setting/agentDeploy/agentSetKey", route106);
|
app.use("/api/setting/about/downloadApp", route106);
|
||||||
app.use("/api/setting/agentDeploy/deployAgentModel", route107);
|
app.use("/api/setting/agentDeploy/agentSetKey", route107);
|
||||||
app.use("/api/setting/agentDeploy/getAgentDeploy", route108);
|
app.use("/api/setting/agentDeploy/deployAgentModel", route108);
|
||||||
app.use("/api/setting/dbConfig/clearData", route109);
|
app.use("/api/setting/agentDeploy/getAgentDeploy", route109);
|
||||||
app.use("/api/setting/dev/getSwitchAiDevTool", route110);
|
app.use("/api/setting/dbConfig/clearData", route110);
|
||||||
app.use("/api/setting/dev/updateSwitchAiDevTool", route111);
|
app.use("/api/setting/dev/getSwitchAiDevTool", route111);
|
||||||
app.use("/api/setting/fileManagement/openFolder", route112);
|
app.use("/api/setting/dev/updateSwitchAiDevTool", route112);
|
||||||
app.use("/api/setting/getTextModel", route113);
|
app.use("/api/setting/fileManagement/openFolder", route113);
|
||||||
app.use("/api/setting/loginConfig/getUser", route114);
|
app.use("/api/setting/getTextModel", route114);
|
||||||
app.use("/api/setting/loginConfig/updateUserPwd", route115);
|
app.use("/api/setting/loginConfig/getUser", route115);
|
||||||
app.use("/api/setting/memoryConfig/delAllMemory", route116);
|
app.use("/api/setting/loginConfig/updateUserPwd", route116);
|
||||||
app.use("/api/setting/memoryConfig/getMemory", route117);
|
app.use("/api/setting/memoryConfig/delAllMemory", route117);
|
||||||
app.use("/api/setting/memoryConfig/sureMemory", route118);
|
app.use("/api/setting/memoryConfig/getMemory", route118);
|
||||||
app.use("/api/setting/promptManage/getPrompt", route119);
|
app.use("/api/setting/memoryConfig/sureMemory", route119);
|
||||||
app.use("/api/setting/promptManage/updatePrompt", route120);
|
app.use("/api/setting/promptManage/getPrompt", route120);
|
||||||
app.use("/api/setting/skillManagement/getSkillContent", route121);
|
app.use("/api/setting/promptManage/updatePrompt", route121);
|
||||||
app.use("/api/setting/skillManagement/getSkillList", route122);
|
app.use("/api/setting/skillManagement/getSkillContent", route122);
|
||||||
app.use("/api/setting/skillManagement/saveSkillContent", route123);
|
app.use("/api/setting/skillManagement/getSkillList", route123);
|
||||||
app.use("/api/setting/vendorConfig/addVendor", route124);
|
app.use("/api/setting/skillManagement/saveSkillContent", route124);
|
||||||
app.use("/api/setting/vendorConfig/deleteVendor", route125);
|
app.use("/api/setting/vendorConfig/addVendor", route125);
|
||||||
app.use("/api/setting/vendorConfig/enableVendor", route126);
|
app.use("/api/setting/vendorConfig/deleteVendor", route126);
|
||||||
app.use("/api/setting/vendorConfig/getCodeByLink", route127);
|
app.use("/api/setting/vendorConfig/enableVendor", route127);
|
||||||
app.use("/api/setting/vendorConfig/getVendorList", route128);
|
app.use("/api/setting/vendorConfig/getCodeByLink", route128);
|
||||||
app.use("/api/setting/vendorConfig/modelTest", route129);
|
app.use("/api/setting/vendorConfig/getVendorList", route129);
|
||||||
app.use("/api/setting/vendorConfig/updateCode", route130);
|
app.use("/api/setting/vendorConfig/modelTest", route130);
|
||||||
app.use("/api/setting/vendorConfig/updateVendor", route131);
|
app.use("/api/setting/vendorConfig/updateCode", route131);
|
||||||
app.use("/api/task/getProject", route132);
|
app.use("/api/setting/vendorConfig/updateVendor", route132);
|
||||||
app.use("/api/task/getTaskApi", route133);
|
app.use("/api/task/getProject", route133);
|
||||||
app.use("/api/task/getTaskCategories", route134);
|
app.use("/api/task/getTaskApi", route134);
|
||||||
app.use("/api/task/taskDetails", route135);
|
app.use("/api/task/getTaskCategories", route135);
|
||||||
app.use("/api/test/test", route136);
|
app.use("/api/task/taskDetails", route136);
|
||||||
|
app.use("/api/test/test", route137);
|
||||||
}
|
}
|
||||||
|
|||||||
@ -98,6 +98,10 @@ export default router.post("/", validateFields(requestSchema), async (req, res)
|
|||||||
const tasks = items.map((item: { id: number; type: string; name: string; prompt: string; base64: string | null | undefined }, index: number) =>
|
const tasks = items.map((item: { id: number; type: string; name: string; prompt: string; base64: string | null | undefined }, index: number) =>
|
||||||
limit(async () => {
|
limit(async () => {
|
||||||
const imageId = totalNovelId[index];
|
const imageId = totalNovelId[index];
|
||||||
|
const data = await u.db("o_image").where("id", imageId).select("state").first();
|
||||||
|
if (data?.state === "生成失败") {
|
||||||
|
return;
|
||||||
|
}
|
||||||
const cfg = assetTypeConfig[item.type as AssetType];
|
const cfg = assetTypeConfig[item.type as AssetType];
|
||||||
if (!cfg) return;
|
if (!cfg) return;
|
||||||
|
|
||||||
@ -126,8 +130,10 @@ export default router.post("/", validateFields(requestSchema), async (req, res)
|
|||||||
aiImage.save(imagePath);
|
aiImage.save(imagePath);
|
||||||
|
|
||||||
const imageData = await u.db("o_image").where("id", imageId).select("*").first();
|
const imageData = await u.db("o_image").where("id", imageId).select("*").first();
|
||||||
|
console.log("%c Line:133 🥒 imageData", "background:#465975", imageData);
|
||||||
|
if (!imageData) return res.status(500).send("资产已被删除");
|
||||||
if (!imageData) return;
|
if (!imageData) return;
|
||||||
|
if (imageData.state === "生成失败") return;
|
||||||
await u
|
await u
|
||||||
.db("o_image")
|
.db("o_image")
|
||||||
.where("id", imageId)
|
.where("id", imageId)
|
||||||
|
|||||||
22
src/routes/assetsGenerate/cancelGenerate.ts
Normal file
22
src/routes/assetsGenerate/cancelGenerate.ts
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
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(),
|
||||||
|
}),
|
||||||
|
async (req, res) => {
|
||||||
|
const { id } = req.body;
|
||||||
|
console.log("%c Line:16 🌭 id", "background:#2eafb0", id);
|
||||||
|
await u.db("o_image").where("id", id).update({
|
||||||
|
state: "生成失败",
|
||||||
|
});
|
||||||
|
res.status(200).send(success({ message: "取消成功" }));
|
||||||
|
},
|
||||||
|
);
|
||||||
@ -96,7 +96,6 @@ export default router.post("/", validateFields(requestSchema), async (req, res)
|
|||||||
const relatedObjects = { id, projectId, type: cfg.label };
|
const relatedObjects = { id, projectId, type: cfg.label };
|
||||||
|
|
||||||
try {
|
try {
|
||||||
// 4. 调用 AI 生成图片
|
|
||||||
const aiImage = u.Ai.Image(model);
|
const aiImage = u.Ai.Image(model);
|
||||||
await aiImage.run(
|
await aiImage.run(
|
||||||
{
|
{
|
||||||
@ -113,11 +112,10 @@ export default router.post("/", validateFields(requestSchema), async (req, res)
|
|||||||
},
|
},
|
||||||
);
|
);
|
||||||
aiImage.save(imagePath);
|
aiImage.save(imagePath);
|
||||||
|
|
||||||
// 5. 更新记录 & 返回结果
|
// 5. 更新记录 & 返回结果
|
||||||
const imageData = await u.db("o_image").where("id", imageId).select("*").first();
|
const imageData = await u.db("o_image").where("id", imageId).select("*").first();
|
||||||
if (!imageData) return res.status(500).send("资产已被删除");
|
if (!imageData) return res.status(500).send("资产已被删除");
|
||||||
|
if (imageData.state === "生成失败") return;
|
||||||
await u
|
await u
|
||||||
.db("o_image")
|
.db("o_image")
|
||||||
.where("id", imageId)
|
.where("id", imageId)
|
||||||
|
|||||||
@ -16,7 +16,15 @@ export default router.post(
|
|||||||
const data = await u
|
const data = await u
|
||||||
.db("o_assets")
|
.db("o_assets")
|
||||||
.leftJoin("o_image", "o_assets.imageId", "o_image.id")
|
.leftJoin("o_image", "o_assets.imageId", "o_image.id")
|
||||||
.select("o_assets.*", "o_image.filePath", "o_image.state", "o_image.model", "o_image.resolution", "o_image.errorReason")
|
.select(
|
||||||
|
"o_assets.*",
|
||||||
|
"o_image.filePath",
|
||||||
|
"o_image.state",
|
||||||
|
"o_image.model",
|
||||||
|
"o_image.resolution",
|
||||||
|
"o_image.errorReason",
|
||||||
|
"o_image.id as imageId",
|
||||||
|
)
|
||||||
.where("o_assets.projectId", projectId)
|
.where("o_assets.projectId", projectId)
|
||||||
.andWhere("o_assets.type", "<>", "clip")
|
.andWhere("o_assets.type", "<>", "clip")
|
||||||
.andWhere("o_assets.assetsId", null)
|
.andWhere("o_assets.assetsId", null)
|
||||||
|
|||||||
@ -113,6 +113,12 @@ export default router.post(
|
|||||||
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 videoPrompt = await u.db("o_prompt").where("type", "videoPromptGeneration").first();
|
const videoPrompt = await u.db("o_prompt").where("type", "videoPromptGeneration").first();
|
||||||
|
let videoPromptGeneration = "" as string | undefined;
|
||||||
|
if (videoPrompt && videoPrompt.useData) {
|
||||||
|
videoPromptGeneration = videoPrompt.useData;
|
||||||
|
} else {
|
||||||
|
videoPromptGeneration = videoPrompt?.data ?? undefined;
|
||||||
|
}
|
||||||
const artStyle = projectData?.artStyle || "无";
|
const artStyle = projectData?.artStyle || "无";
|
||||||
const visualManual = u.getArtPrompt(artStyle, "art_skills", "art_storyboard_video");
|
const visualManual = u.getArtPrompt(artStyle, "art_skills", "art_storyboard_video");
|
||||||
const content = `
|
const content = `
|
||||||
@ -132,7 +138,7 @@ export default router.post(
|
|||||||
|
|
||||||
try {
|
try {
|
||||||
const { text } = await u.Ai.Text("universalAi").invoke({
|
const { text } = await u.Ai.Text("universalAi").invoke({
|
||||||
system: videoPrompt?.data!,
|
system: videoPromptGeneration,
|
||||||
messages: [
|
messages: [
|
||||||
{
|
{
|
||||||
role: "assistant",
|
role: "assistant",
|
||||||
|
|||||||
@ -65,7 +65,6 @@ export default router.post(
|
|||||||
|
|
||||||
if (!scriptIds.length) return res.status(400).send(error("请先选择剧本"));
|
if (!scriptIds.length) return res.status(400).send(error("请先选择剧本"));
|
||||||
const scripts = await u.db("o_script").whereIn("id", scriptIds);
|
const scripts = await u.db("o_script").whereIn("id", scriptIds);
|
||||||
|
|
||||||
|
|
||||||
// 构建 scriptId -> script 内容的映射
|
// 构建 scriptId -> script 内容的映射
|
||||||
const scriptMap = new Map(scripts.map((s: o_script) => [s.id, s]));
|
const scriptMap = new Map(scripts.map((s: o_script) => [s.id, s]));
|
||||||
@ -198,7 +197,13 @@ export default router.post(
|
|||||||
return "无需回复用户任何内容";
|
return "无需回复用户任何内容";
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
const data = await u.db("o_prompt").where("type", "scriptAssetExtraction").first("data");
|
const promptData = await u.db("o_prompt").where("type", "scriptAssetExtraction").first();
|
||||||
|
let scriptAssetExtraction = "" as string | undefined;
|
||||||
|
if (promptData && promptData.useData) {
|
||||||
|
scriptAssetExtraction = promptData.useData;
|
||||||
|
} else {
|
||||||
|
scriptAssetExtraction = promptData?.data ?? undefined;
|
||||||
|
}
|
||||||
const existingHint = existingAssetsList
|
const existingHint = existingAssetsList
|
||||||
? `\n\n【已有资产列表】:${existingAssetsList}\n对于已有资产,如果在剧本中出现,只需在 existingAssetRefs 中给出资产名称和对应的 scriptIds 数组即可,无需重复生成 desc/type。对于新发现的资产(不在已有列表中),请在 newAssets 中给出完整信息。`
|
? `\n\n【已有资产列表】:${existingAssetsList}\n对于已有资产,如果在剧本中出现,只需在 existingAssetRefs 中给出资产名称和对应的 scriptIds 数组即可,无需重复生成 desc/type。对于新发现的资产(不在已有列表中),请在 newAssets 中给出完整信息。`
|
||||||
: "";
|
: "";
|
||||||
@ -207,7 +212,7 @@ export default router.post(
|
|||||||
{
|
{
|
||||||
role: "system",
|
role: "system",
|
||||||
content:
|
content:
|
||||||
data?.data +
|
scriptAssetExtraction +
|
||||||
"\n\n提取剧本中涉及的资产(角色、场景、道具),参考技能 script_assets_extract 规范,结果必须通过 resultTool 工具返回。" +
|
"\n\n提取剧本中涉及的资产(角色、场景、道具),参考技能 script_assets_extract 规范,结果必须通过 resultTool 工具返回。" +
|
||||||
"\n\n注意:本次会同时提供多集剧本,每集剧本以 ===== 【剧本ID: xxx】 ===== 分隔。你需要分析每集剧本使用了哪些资产,并在输出中用 scriptIds 数组标明每个资产在哪些剧本中出现。",
|
"\n\n注意:本次会同时提供多集剧本,每集剧本以 ===== 【剧本ID: xxx】 ===== 分隔。你需要分析每集剧本使用了哪些资产,并在输出中用 scriptIds 数组标明每个资产在哪些剧本中出现。",
|
||||||
},
|
},
|
||||||
|
|||||||
@ -5,6 +5,14 @@ import { success, error } from "@/lib/responseFormat";
|
|||||||
const router = express.Router();
|
const router = express.Router();
|
||||||
|
|
||||||
export default router.post("/", async (req, res) => {
|
export default router.post("/", async (req, res) => {
|
||||||
const data = await u.db("o_prompt").select("*");
|
const list = await u.db("o_prompt").select("*");
|
||||||
|
const data = await Promise.all(
|
||||||
|
list.map(async (item) => {
|
||||||
|
return {
|
||||||
|
...item,
|
||||||
|
data: item.useData ? item.useData : item.data,
|
||||||
|
};
|
||||||
|
}),
|
||||||
|
);
|
||||||
res.status(200).send(success(data));
|
res.status(200).send(success(data));
|
||||||
});
|
});
|
||||||
|
|||||||
@ -13,7 +13,7 @@ export default router.post(
|
|||||||
async (req, res) => {
|
async (req, res) => {
|
||||||
const { id, data } = req.body;
|
const { id, data } = req.body;
|
||||||
await u.db("o_prompt").where("id", id).update({
|
await u.db("o_prompt").where("id", id).update({
|
||||||
data,
|
useData: data,
|
||||||
});
|
});
|
||||||
res.status(200).send(success(123));
|
res.status(200).send(success(123));
|
||||||
},
|
},
|
||||||
|
|||||||
@ -35,7 +35,6 @@ const vendorConfigSchema = z.object({
|
|||||||
modelName: z.string(),
|
modelName: z.string(),
|
||||||
type: z.literal("image"),
|
type: z.literal("image"),
|
||||||
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
||||||
associationSkills: z.string().optional(),
|
|
||||||
}),
|
}),
|
||||||
z.object({
|
z.object({
|
||||||
name: z.string(),
|
name: z.string(),
|
||||||
|
|||||||
@ -36,7 +36,6 @@ const vendorConfigSchema = z.object({
|
|||||||
modelName: z.string(),
|
modelName: z.string(),
|
||||||
type: z.literal("image"),
|
type: z.literal("image"),
|
||||||
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
||||||
associationSkills: z.string().optional(),
|
|
||||||
}),
|
}),
|
||||||
z.object({
|
z.object({
|
||||||
name: z.string(),
|
name: z.string(),
|
||||||
@ -48,7 +47,6 @@ const vendorConfigSchema = z.object({
|
|||||||
z.array(z.enum(["audioReference", "videoReference", "textReference", "imageReference"])),
|
z.array(z.enum(["audioReference", "videoReference", "textReference", "imageReference"])),
|
||||||
]),
|
]),
|
||||||
),
|
),
|
||||||
associationSkills: z.string().optional(),
|
|
||||||
audio: z.union([z.literal("optional"), z.boolean()]),
|
audio: z.union([z.literal("optional"), z.boolean()]),
|
||||||
durationResolutionMap: z.array(
|
durationResolutionMap: z.array(
|
||||||
z.object({
|
z.object({
|
||||||
|
|||||||
@ -33,7 +33,6 @@ export default router.post(
|
|||||||
modelName: z.string(),
|
modelName: z.string(),
|
||||||
type: z.literal("image"),
|
type: z.literal("image"),
|
||||||
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
mode: z.array(z.enum(["text", "singleImage", "multiReference"])),
|
||||||
associationSkills: z.string().optional(),
|
|
||||||
}),
|
}),
|
||||||
z.object({
|
z.object({
|
||||||
name: z.string(),
|
name: z.string(),
|
||||||
@ -45,7 +44,6 @@ export default router.post(
|
|||||||
z.array(z.enum(["audioReference", "videoReference", "textReference", "imageReference"])),
|
z.array(z.enum(["audioReference", "videoReference", "textReference", "imageReference"])),
|
||||||
]),
|
]),
|
||||||
),
|
),
|
||||||
associationSkills: z.string().optional(),
|
|
||||||
audio: z.union([z.literal("optional"), z.boolean()]),
|
audio: z.union([z.literal("optional"), z.boolean()]),
|
||||||
durationResolutionMap: z.array(
|
durationResolutionMap: z.array(
|
||||||
z.object({
|
z.object({
|
||||||
|
|||||||
37
src/types/database.d.ts
vendored
37
src/types/database.d.ts
vendored
@ -1,6 +1,37 @@
|
|||||||
// @db-hash 6fa5017e455bc367c9c902ba574d11b4
|
// @db-hash 6cd709d9bdfe00c4dc87961a8ebba149
|
||||||
//该文件由脚本自动生成,请勿手动修改
|
//该文件由脚本自动生成,请勿手动修改
|
||||||
|
|
||||||
|
export interface _o_project_old_20260404 {
|
||||||
|
'artStyle'?: string | null;
|
||||||
|
'createTime'?: number | null;
|
||||||
|
'directorManual'?: string | null;
|
||||||
|
'id'?: number | null;
|
||||||
|
'imageModel'?: string | null;
|
||||||
|
'imageQuality'?: string | null;
|
||||||
|
'intro'?: string | null;
|
||||||
|
'mode'?: string | null;
|
||||||
|
'name'?: string | null;
|
||||||
|
'projectType'?: string | null;
|
||||||
|
'type'?: string | null;
|
||||||
|
'userId'?: number | null;
|
||||||
|
'videoModel'?: string | null;
|
||||||
|
'videoRatio'?: string | null;
|
||||||
|
}
|
||||||
|
export interface _o_prompt_old_20260406 {
|
||||||
|
'data'?: string | null;
|
||||||
|
'id'?: number;
|
||||||
|
'name'?: string | null;
|
||||||
|
'type'?: string | null;
|
||||||
|
'useData'?: string | null;
|
||||||
|
}
|
||||||
|
export interface _o_prompt_old_20260406_1 {
|
||||||
|
'data'?: string | null;
|
||||||
|
'id'?: number;
|
||||||
|
'name'?: string | null;
|
||||||
|
'TEXT'?: any | null;
|
||||||
|
'type'?: string | null;
|
||||||
|
'useData'?: string | null;
|
||||||
|
}
|
||||||
export interface memories {
|
export interface memories {
|
||||||
'content': string;
|
'content': string;
|
||||||
'createTime': number;
|
'createTime': number;
|
||||||
@ -128,6 +159,7 @@ export interface o_prompt {
|
|||||||
'id'?: number;
|
'id'?: number;
|
||||||
'name'?: string | null;
|
'name'?: string | null;
|
||||||
'type'?: string | null;
|
'type'?: string | null;
|
||||||
|
'useData'?: string | null;
|
||||||
}
|
}
|
||||||
export interface o_script {
|
export interface o_script {
|
||||||
'content'?: string | null;
|
'content'?: string | null;
|
||||||
@ -231,6 +263,9 @@ export interface o_videoTrack {
|
|||||||
}
|
}
|
||||||
|
|
||||||
export interface DB {
|
export interface DB {
|
||||||
|
"_o_project_old_20260404": _o_project_old_20260404;
|
||||||
|
"_o_prompt_old_20260406": _o_prompt_old_20260406;
|
||||||
|
"_o_prompt_old_20260406_1": _o_prompt_old_20260406_1;
|
||||||
"memories": memories;
|
"memories": memories;
|
||||||
"o_agentDeploy": o_agentDeploy;
|
"o_agentDeploy": o_agentDeploy;
|
||||||
"o_agentWorkData": o_agentWorkData;
|
"o_agentWorkData": o_agentWorkData;
|
||||||
|
|||||||
@ -27,9 +27,15 @@ class CleanNovel {
|
|||||||
private async processChapter(novel: o_novel): Promise<EventType | null> {
|
private async processChapter(novel: o_novel): Promise<EventType | null> {
|
||||||
try {
|
try {
|
||||||
const prompt = await u.getPrompts("event");
|
const prompt = await u.getPrompts("event");
|
||||||
const data = await u.db("o_prompt").where("type", "eventExtraction").first("data");
|
const promptData = await u.db("o_prompt").where("type", "eventExtraction").first();
|
||||||
|
let eventExtraction = "" as string | undefined;
|
||||||
|
if (promptData && promptData.useData) {
|
||||||
|
eventExtraction = promptData.useData;
|
||||||
|
} else {
|
||||||
|
eventExtraction = promptData?.data ?? undefined;
|
||||||
|
}
|
||||||
const resData = await u.Ai.Text("universalAi").invoke({
|
const resData = await u.Ai.Text("universalAi").invoke({
|
||||||
system: data ? JSON.stringify(data.data) : (prompt as string),
|
system: eventExtraction ? JSON.stringify(eventExtraction) : (prompt as string),
|
||||||
messages: [
|
messages: [
|
||||||
{
|
{
|
||||||
role: "user",
|
role: "user",
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user