portable.mjs 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. import fs from "fs-extra";
  2. import path from "path";
  3. import AdmZip from "adm-zip";
  4. import { createRequire } from "module";
  5. import { getOctokit, context } from "@actions/github";
  6. const target = process.argv.slice(2)[0];
  7. const alpha = process.argv.slice(2)[1];
  8. const ARCH_MAP = {
  9. "x86_64-pc-windows-msvc": "x64",
  10. "i686-pc-windows-msvc": "x86",
  11. "aarch64-pc-windows-msvc": "arm64",
  12. };
  13. const PROCESS_MAP = {
  14. x64: "x64",
  15. ia32: "x86",
  16. arm64: "arm64",
  17. };
  18. const arch = target ? ARCH_MAP[target] : PROCESS_MAP[process.arch];
  19. /// Script for ci
  20. /// 打包绿色版/便携版 (only Windows)
  21. async function resolvePortable() {
  22. if (process.platform !== "win32") return;
  23. const releaseDir = target
  24. ? `./src-tauri/target/${target}/release`
  25. : `./src-tauri/target/release`;
  26. const configDir = path.join(releaseDir, ".config");
  27. if (!(await fs.pathExists(releaseDir))) {
  28. throw new Error("could not found the release dir");
  29. }
  30. await fs.mkdir(configDir);
  31. await fs.createFile(path.join(configDir, "PORTABLE"));
  32. const zip = new AdmZip();
  33. zip.addLocalFile(path.join(releaseDir, "Clash Verge.exe"));
  34. zip.addLocalFile(path.join(releaseDir, "verge-mihomo.exe"));
  35. zip.addLocalFile(path.join(releaseDir, "verge-mihomo-alpha.exe"));
  36. zip.addLocalFolder(path.join(releaseDir, "resources"), "resources");
  37. zip.addLocalFolder(configDir, ".config");
  38. const require = createRequire(import.meta.url);
  39. const packageJson = require("../package.json");
  40. const { version } = packageJson;
  41. const zipFile = `Clash.Verge_${version}_${arch}_portable.zip`;
  42. zip.writeZip(zipFile);
  43. console.log("[INFO]: create portable zip successfully");
  44. // push release assets
  45. if (process.env.GITHUB_TOKEN === undefined) {
  46. throw new Error("GITHUB_TOKEN is required");
  47. }
  48. const options = { owner: context.repo.owner, repo: context.repo.repo };
  49. const github = getOctokit(process.env.GITHUB_TOKEN);
  50. const tag = alpha ? "alpha" : process.env.TAG_NAME || `v${version}`;
  51. console.log("[INFO]: upload to ", tag);
  52. const { data: release } = await github.rest.repos.getReleaseByTag({
  53. ...options,
  54. tag,
  55. });
  56. let assets = release.assets.filter((x) => {
  57. return x.name === zipFile;
  58. });
  59. if (assets.length > 0) {
  60. let id = assets[0].id;
  61. await github.rest.repos.deleteReleaseAsset({
  62. ...options,
  63. asset_id: id,
  64. });
  65. }
  66. console.log(release.name);
  67. await github.rest.repos.uploadReleaseAsset({
  68. ...options,
  69. release_id: release.id,
  70. name: zipFile,
  71. data: zip.toBuffer(),
  72. });
  73. }
  74. resolvePortable().catch(console.error);