portable.mjs 2.4 KB

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