clash-verge-rev/scripts/updater.mjs

208 lines
7.1 KiB
JavaScript
Raw Normal View History

2022-02-22 01:56:06 +08:00
import fetch from "node-fetch";
2022-01-19 00:37:59 +08:00
import { getOctokit, context } from "@actions/github";
2022-03-19 14:04:58 +08:00
import { resolveUpdateLog } from "./updatelog.mjs";
2022-01-19 00:37:59 +08:00
2022-02-22 01:56:06 +08:00
const UPDATE_TAG_NAME = "updater";
const UPDATE_JSON_FILE = "update.json";
2022-03-19 11:14:12 +08:00
const UPDATE_JSON_PROXY = "update-proxy.json";
2022-01-19 00:37:59 +08:00
/// generate update.json
/// upload to update tag's release asset
async function resolveUpdater() {
2022-01-19 00:37:59 +08:00
if (process.env.GITHUB_TOKEN === undefined) {
throw new Error("GITHUB_TOKEN is required");
}
2022-02-22 01:56:06 +08:00
const options = { owner: context.repo.owner, repo: context.repo.repo };
const github = getOctokit(process.env.GITHUB_TOKEN);
const { data: tags } = await github.rest.repos.listTags({
...options,
per_page: 10,
page: 1,
});
// get the latest publish tag
const tag = tags.find((t) => t.name.startsWith("v"));
console.log(tag);
console.log();
const { data: latestRelease } = await github.rest.repos.getReleaseByTag({
...options,
tag: tag.name,
});
2022-01-19 00:37:59 +08:00
const updateData = {
2022-02-22 01:56:06 +08:00
name: tag.name,
2022-03-19 14:04:58 +08:00
notes: await resolveUpdateLog(tag.name), // use updatelog.md
2022-01-19 00:37:59 +08:00
pub_date: new Date().toISOString(),
platforms: {
win64: { signature: "", url: "" }, // compatible with older formats
linux: { signature: "", url: "" }, // compatible with older formats
darwin: { signature: "", url: "" }, // compatible with older formats
"darwin-aarch64": { signature: "", url: "" },
"darwin-intel": { signature: "", url: "" },
2023-09-11 10:16:54 +08:00
"darwin-x86_64": { signature: "", url: "" },
"linux-x86_64": { signature: "", url: "" },
2024-05-06 13:03:52 +08:00
"linux-x86": { signature: "", url: "" },
2024-06-08 19:36:58 +08:00
"linux-i686": { signature: "", url: "" },
"linux-aarch64": { signature: "", url: "" },
2023-12-10 17:14:48 +08:00
"linux-armv7": { signature: "", url: "" },
"windows-x86_64": { signature: "", url: "" },
2023-12-10 17:14:48 +08:00
"windows-aarch64": { signature: "", url: "" },
2024-05-06 13:03:52 +08:00
"windows-x86": { signature: "", url: "" },
2024-06-08 19:36:58 +08:00
"windows-i686": { signature: "", url: "" },
2022-01-19 00:37:59 +08:00
},
};
2022-02-22 01:56:06 +08:00
const promises = latestRelease.assets.map(async (asset) => {
const { name, browser_download_url } = asset;
2022-01-19 00:37:59 +08:00
2022-02-22 01:56:06 +08:00
// win64 url
2023-12-04 13:45:28 +08:00
if (name.endsWith("x64-setup.nsis.zip")) {
2022-02-22 01:56:06 +08:00
updateData.platforms.win64.url = browser_download_url;
updateData.platforms["windows-x86_64"].url = browser_download_url;
2022-02-22 01:56:06 +08:00
}
// win64 signature
2023-12-04 13:45:28 +08:00
if (name.endsWith("x64-setup.nsis.zip.sig")) {
const sig = await getSignature(browser_download_url);
updateData.platforms.win64.signature = sig;
updateData.platforms["windows-x86_64"].signature = sig;
2022-02-22 01:56:06 +08:00
}
2022-03-19 10:50:44 +08:00
2024-05-06 13:03:52 +08:00
// win32 url
if (name.endsWith("x64-setup.nsis.zip")) {
updateData.platforms["windows-x86"].url = browser_download_url;
2024-06-08 19:36:58 +08:00
updateData.platforms["windows-i686"].url = browser_download_url;
2024-05-06 13:03:52 +08:00
}
// win32 signature
if (name.endsWith("x64-setup.nsis.zip.sig")) {
const sig = await getSignature(browser_download_url);
updateData.platforms["windows-x86"].signature = sig;
2024-06-08 19:36:58 +08:00
updateData.platforms["windows-i686"].signature = sig;
2024-05-06 13:03:52 +08:00
}
2023-12-10 17:14:48 +08:00
// win arm url
if (name.endsWith("arm64-setup.nsis.zip")) {
updateData.platforms["windows-aarch64"].url = browser_download_url;
}
// win arm signature
if (name.endsWith("arm64-setup.nsis.zip.sig")) {
const sig = await getSignature(browser_download_url);
updateData.platforms["windows-aarch64"].signature = sig;
}
// darwin url (intel)
if (name.endsWith(".app.tar.gz") && !name.includes("aarch")) {
2022-03-19 10:50:44 +08:00
updateData.platforms.darwin.url = browser_download_url;
updateData.platforms["darwin-intel"].url = browser_download_url;
2023-09-11 10:12:40 +08:00
updateData.platforms["darwin-x86_64"].url = browser_download_url;
2022-03-19 10:50:44 +08:00
}
// darwin signature (intel)
if (name.endsWith(".app.tar.gz.sig") && !name.includes("aarch")) {
const sig = await getSignature(browser_download_url);
updateData.platforms.darwin.signature = sig;
updateData.platforms["darwin-intel"].signature = sig;
2023-09-11 10:12:40 +08:00
updateData.platforms["darwin-x86_64"].signature = sig;
}
// darwin url (aarch)
if (name.endsWith("aarch64.app.tar.gz")) {
updateData.platforms["darwin-aarch64"].url = browser_download_url;
2024-06-08 19:36:58 +08:00
// 使linux可以检查更新
2022-03-19 10:50:44 +08:00
updateData.platforms.linux.url = browser_download_url;
updateData.platforms["linux-x86_64"].url = browser_download_url;
2024-05-06 13:03:52 +08:00
updateData.platforms["linux-x86"].url = browser_download_url;
2024-06-08 19:36:58 +08:00
updateData.platforms["linux-i686"].url = browser_download_url;
updateData.platforms["linux-aarch64"].url = browser_download_url;
2023-12-10 17:14:48 +08:00
updateData.platforms["linux-armv7"].url = browser_download_url;
2022-03-19 10:50:44 +08:00
}
2024-06-08 19:36:58 +08:00
// darwin signature (aarch)
if (name.endsWith("aarch64.app.tar.gz.sig")) {
const sig = await getSignature(browser_download_url);
2024-06-08 19:36:58 +08:00
updateData.platforms["darwin-aarch64"].signature = sig;
updateData.platforms.linux.signature = sig;
updateData.platforms["linux-x86_64"].signature = sig;
2024-05-06 13:03:52 +08:00
updateData.platforms["linux-x86"].url = browser_download_url;
2024-06-08 19:36:58 +08:00
updateData.platforms["linux-i686"].url = browser_download_url;
updateData.platforms["linux-aarch64"].signature = sig;
2023-12-10 17:14:48 +08:00
updateData.platforms["linux-armv7"].signature = sig;
2022-03-19 10:50:44 +08:00
}
2022-01-19 00:42:37 +08:00
});
2022-02-22 01:56:06 +08:00
await Promise.allSettled(promises);
console.log(updateData);
// maybe should test the signature as well
// delete the null field
Object.entries(updateData.platforms).forEach(([key, value]) => {
if (!value.url) {
console.log(`[Error]: failed to parse release for "${key}"`);
delete updateData.platforms[key];
}
});
2022-03-19 11:14:12 +08:00
// 生成一个代理github的更新文件
// 使用 https://hub.fastgit.xyz/ 做github资源的加速
const updateDataNew = JSON.parse(JSON.stringify(updateData));
Object.entries(updateDataNew.platforms).forEach(([key, value]) => {
if (value.url) {
updateDataNew.platforms[key].url =
"https://mirror.ghproxy.com/" + value.url;
2022-03-19 11:14:12 +08:00
} else {
console.log(`[Error]: updateDataNew.platforms.${key} is null`);
}
});
2022-02-22 01:56:06 +08:00
// update the update.json
const { data: updateRelease } = await github.rest.repos.getReleaseByTag({
...options,
tag: UPDATE_TAG_NAME,
2022-01-19 00:37:59 +08:00
});
2022-03-19 11:14:12 +08:00
// delete the old assets
2022-02-22 01:56:06 +08:00
for (let asset of updateRelease.assets) {
if (asset.name === UPDATE_JSON_FILE) {
2022-01-19 00:37:59 +08:00
await github.rest.repos.deleteReleaseAsset({
2022-02-22 01:56:06 +08:00
...options,
2022-01-19 00:37:59 +08:00
asset_id: asset.id,
});
2022-03-19 11:14:12 +08:00
}
if (asset.name === UPDATE_JSON_PROXY) {
await github.rest.repos
.deleteReleaseAsset({ ...options, asset_id: asset.id })
.catch(console.error); // do not break the pipeline
2022-01-19 00:37:59 +08:00
}
}
// upload new assets
2022-01-19 00:37:59 +08:00
await github.rest.repos.uploadReleaseAsset({
2022-02-22 01:56:06 +08:00
...options,
release_id: updateRelease.id,
name: UPDATE_JSON_FILE,
2022-01-19 00:37:59 +08:00
data: JSON.stringify(updateData, null, 2),
});
2022-03-19 11:14:12 +08:00
await github.rest.repos.uploadReleaseAsset({
...options,
release_id: updateRelease.id,
name: UPDATE_JSON_PROXY,
data: JSON.stringify(updateDataNew, null, 2),
});
2022-01-19 00:37:59 +08:00
}
2022-02-22 01:56:06 +08:00
// get the signature file content
async function getSignature(url) {
const response = await fetch(url, {
method: "GET",
headers: { "Content-Type": "application/octet-stream" },
});
return response.text();
}
resolveUpdater().catch(console.error);