重写版本更新

This commit is contained in:
ACT丶流星雨 2026-04-06 03:19:55 +08:00
parent d3a99c1558
commit 1ac9639f59
10 changed files with 62 additions and 65 deletions

View File

@ -1,27 +0,0 @@
{
"version": "1.0.8",
"time": 1775118545494,
"data": {
"toonflow": [
{
"type": "zip",
"url": "https://toonflow.oss-cn-beijing.aliyuncs.com/latest/latest.zip"
},
{
"type": "windows",
"url": "https://toonflow.oss-cn-beijing.aliyuncs.com/latest/latest.exe"
},
{
"type": "linux",
"url": "https://toonflow.oss-cn-beijing.aliyuncs.com/latest/latest.AppImage"
},
{
"type": "macos",
"url": "https://toonflow.oss-cn-beijing.aliyuncs.com/latest/latest.dmg"
}
],
"github": [],
"atomgit": [],
"gitee": []
}
}

1
data/version.txt Normal file
View File

@ -0,0 +1 @@
1.0.11

File diff suppressed because one or more lines are too long

View File

@ -9,17 +9,6 @@ app.commandLine.appendSwitch("disable-features", "CalculateNativeWinOcclusion");
declare const __APP_VERSION__: string | undefined;
/**
* extraResources data
*/
function getVersionFromUpdateJson(filePath: string): string | null {
try {
return JSON.parse(fs.readFileSync(filePath, "utf8")).version ?? null;
} catch {}
return null;
}
const SKIP_ENTRIES = new Set(["logs", "oss", "db2.sqlite"]);
function copyDir(src: string, dest: string, overwrite = false): void {
@ -40,9 +29,9 @@ function copyDir(src: string, dest: string, overwrite = false): void {
function initializeData(): void {
const srcDir = path.join(process.resourcesPath, "data");
const destDir = path.join(app.getPath("userData"), "data");
const updateJsonFile = path.join(destDir, "update.json");
const updateJsonFile = path.join(destDir, "version.txt");
const currentVersion = typeof __APP_VERSION__ !== "undefined" ? __APP_VERSION__ : "0.0.0";
const userVersion = getVersionFromUpdateJson(updateJsonFile);
const userVersion = fs.existsSync(updateJsonFile) ? fs.readFileSync(updateJsonFile, "utf8") : null;
if (!userVersion) {
copyDir(srcDir, destDir);

View File

@ -17,6 +17,9 @@ const app = express();
const server = http.createServer(app);
export default async function startServe(randomPort: Boolean = false) {
await u.writeVersion()
const io = new Server(server, { cors: { origin: "*" } });
socketInit(io);

View File

@ -1,22 +1,10 @@
import express from "express";
import { success } from "@/lib/responseFormat";
import {getVersion} from "@/utils/writeVersion";
const router = express.Router();
import fs from "fs";
import path from "path";
declare const __APP_VERSION__: string | undefined;
const APP_VERSION: string = (() => {
if (typeof __APP_VERSION__ !== "undefined") {
return __APP_VERSION__;
}
// 开发环境回退:从 package.json 读取
const pkgPath = path.resolve(process.cwd(), "package.json");
const pkg = JSON.parse(fs.readFileSync(pkgPath, "utf8"));
return pkg.version;
})();
export default router.get("/", async (req, res) => {
res.status(200).send(success(APP_VERSION));
const version = await getVersion();
res.status(200).send(success(version));
});

View File

@ -50,18 +50,22 @@ export default router.post(
//对比Major
if (taggerList[0] > currentVersionList[0]) {
if (!installerItem) return res.status(400).send(error("该源暂无适用于当前系统的安装包"));
return res.status(200).send(success({ needUpdate: true, latestVersion: tagger, reinstall: true, time, url: installerItem.url }));
return res
.status(200)
.send(success({ needUpdate: true, latestVersion: tagger, reinstall: true, time, url: installerItem.url, version: tagger }));
}
//对比Minor
if (taggerList[1] > currentVersionList[1]) {
if (!installerItem) return res.status(400).send(error("该源暂无适用于当前系统的安装包"));
return res.status(200).send(success({ needUpdate: true, latestVersion: tagger, reinstall: true, time, url: installerItem.url }));
return res
.status(200)
.send(success({ needUpdate: true, latestVersion: tagger, reinstall: true, time, url: installerItem.url, version: tagger }));
}
//Patch
if (taggerList[2] > currentVersionList[2]) {
if (!zipItem) return res.status(400).send(error("该源暂无增量更新包"));
return res.status(200).send(success({ needUpdate: true, latestVersion: tagger, reinstall: false, time, url: zipItem.url }));
return res.status(200).send(success({ needUpdate: true, latestVersion: tagger, reinstall: false, time, url: zipItem.url, version: tagger }));
}
return res.status(200).send(success({ needUpdate: false, latestVersion: tagger, reinstall: false, time }));
return res.status(200).send(success({ needUpdate: false, latestVersion: tagger, reinstall: false, time ,version: tagger}));
},
);

View File

@ -24,9 +24,10 @@ export default router.post(
validateFields({
url: z.url(),
reinstall: z.boolean(),
version: z.string(),
}),
async (req, res) => {
const { reinstall, url } = req.body;
const { reinstall, url, version } = req.body;
const rootDir = u.getPath(["temp"]);
fs.mkdirSync(rootDir, { recursive: true });
if (reinstall) {
@ -58,6 +59,7 @@ export default router.post(
fs.cpSync(tempModelsPath, u.getPath(["models"]), { recursive: true, force: true });
}
fs.rmSync(rootDir, { recursive: true, force: true });
await u.writeVersion(version);
res.status(200).send(success("更新成功5秒后重启"));
}
},

View File

@ -11,6 +11,7 @@ import Ai from "@/utils/ai";
import { getPrompts } from "@/utils/getPrompts";
import { getArtPrompt } from "@/utils/getArtPrompt";
import replaceUrl from "@/utils/replaceUrl";
import writeVersion from "@/utils/writeVersion";
export default {
db,
@ -25,5 +26,6 @@ export default {
task,
getPrompts,
getArtPrompt,
replaceUrl
replaceUrl,
writeVersion,
};

35
src/utils/writeVersion.ts Normal file
View File

@ -0,0 +1,35 @@
import path from "path";
import fs from "fs";
import getPath from "@/utils/getPath";
declare const __APP_VERSION__: string | undefined;
const APP_VERSION: string = (() => {
if (typeof __APP_VERSION__ !== "undefined") {
return __APP_VERSION__;
}
// 开发环境回退:从 package.json 读取
const pkgPath = path.resolve(process.cwd(), "package.json");
const pkg = JSON.parse(fs.readFileSync(pkgPath, "utf8"));
return pkg.version;
})();
export default async (version?: string) => {
const versionFile = path.join(getPath(), "version.txt");
if (!fs.existsSync(versionFile)) {
fs.mkdirSync(path.dirname(versionFile), { recursive: true });
}
await fs.promises.writeFile(versionFile, version ?? APP_VERSION, "utf8");
};
export const getVersion = async () => {
const versionFile = path.join(getPath(), "version.txt");
if (fs.existsSync(versionFile)) {
return fs.readFileSync(versionFile, "utf8");
}
if (!fs.existsSync(versionFile)) {
fs.mkdirSync(path.dirname(versionFile), { recursive: true });
}
await fs.promises.writeFile(versionFile, APP_VERSION, "utf8");
return APP_VERSION;
};