portable-fixed-webview2.mjs 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  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(
  38. path.join(
  39. releaseDir,
  40. `Microsoft.WebView2.FixedVersionRuntime.109.0.1518.78.${arch}`
  41. ),
  42. `Microsoft.WebView2.FixedVersionRuntime.109.0.1518.78.${arch}`
  43. );
  44. zip.addLocalFolder(configDir, ".config");
  45. const require = createRequire(import.meta.url);
  46. const packageJson = require("../package.json");
  47. const { version } = packageJson;
  48. const zipFile = `Clash.Verge_${version}_${arch}_fixed_webview2_portable.zip`;
  49. zip.writeZip(zipFile);
  50. console.log("[INFO]: create portable zip successfully");
  51. // push release assets
  52. if (process.env.GITHUB_TOKEN === undefined) {
  53. throw new Error("GITHUB_TOKEN is required");
  54. }
  55. const options = { owner: context.repo.owner, repo: context.repo.repo };
  56. const github = getOctokit(process.env.GITHUB_TOKEN);
  57. const tag = alpha ? "alpha" : process.env.TAG_NAME || `v${version}`;
  58. console.log("[INFO]: upload to ", tag);
  59. const { data: release } = await github.rest.repos.getReleaseByTag({
  60. ...options,
  61. tag,
  62. });
  63. let assets = release.assets.filter((x) => {
  64. return x.name === zipFile;
  65. });
  66. if (assets.length > 0) {
  67. let id = assets[0].id;
  68. await github.rest.repos.deleteReleaseAsset({
  69. ...options,
  70. asset_id: id,
  71. });
  72. }
  73. console.log(release.name);
  74. await github.rest.repos.uploadReleaseAsset({
  75. ...options,
  76. release_id: release.id,
  77. name: zipFile,
  78. data: zip.toBuffer(),
  79. });
  80. }
  81. resolvePortable().catch(console.error);