portable.mjs 1.7 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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. /// Script for ci
  7. /// 打包绿色版/便携版 (only Windows)
  8. async function resolvePortable() {
  9. if (process.platform !== "win32") return;
  10. const releaseDir = "./src-tauri/target/release";
  11. if (!(await fs.pathExists(releaseDir))) {
  12. throw new Error("could not found the release dir");
  13. }
  14. const zip = new AdmZip();
  15. zip.addLocalFile(path.join(releaseDir, "Clash Verge.exe"));
  16. zip.addLocalFile(path.join(releaseDir, "clash.exe"));
  17. zip.addLocalFile(path.join(releaseDir, "clash-meta.exe"));
  18. zip.addLocalFolder(path.join(releaseDir, "resources"), "resources");
  19. const require = createRequire(import.meta.url);
  20. const packageJson = require("../package.json");
  21. const { version } = packageJson;
  22. const zipFile = `Clash.Verge_${version}_x64_portable.zip`;
  23. zip.writeZip(zipFile);
  24. console.log("[INFO]: create portable zip successfully");
  25. // push release assets
  26. if (process.env.GITHUB_TOKEN === undefined) {
  27. throw new Error("GITHUB_TOKEN is required");
  28. }
  29. const options = { owner: context.repo.owner, repo: context.repo.repo };
  30. const github = getOctokit(process.env.GITHUB_TOKEN);
  31. console.log("[INFO]: upload to ", process.env.TAG_NAME || `v${version}`);
  32. const { data: release } = await github.rest.repos.getReleaseByTag({
  33. ...options,
  34. tag: process.env.TAG_NAME || `v${version}`,
  35. });
  36. console.log(release.name);
  37. await github.rest.repos.uploadReleaseAsset({
  38. ...options,
  39. release_id: release.id,
  40. name: zipFile,
  41. data: zip.toBuffer(),
  42. });
  43. }
  44. resolvePortable().catch(console.error);