@unitsvc/cc-helper 1.2.2 → 1.2.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cli.js +1 -1
- package/dist/index.js +1 -1
- package/package.json +1 -1
package/dist/cli.js
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
#!/usr/bin/env node
|
|
2
|
-
"use strict";var
|
|
2
|
+
"use strict";var cr=Object.create;var S=Object.defineProperty;var lr=Object.getOwnPropertyDescriptor;var pr=Object.getOwnPropertyNames;var fr=Object.getPrototypeOf,mr=Object.prototype.hasOwnProperty;var dr=(r,n)=>{for(var e in n)S(r,e,{get:n[e],enumerable:!0})},Z=(r,n,e,o)=>{if(n&&typeof n=="object"||typeof n=="function")for(let t of pr(n))!mr.call(r,t)&&t!==e&&S(r,t,{get:()=>n[t],enumerable:!(o=lr(n,t))||o.enumerable});return r};var m=(r,n,e)=>(e=r!=null?cr(fr(r)):{},Z(n||!r||!r.__esModule?S(e,"default",{value:r,enumerable:!0}):e,r)),ur=r=>Z(S({},"__esModule",{value:!0}),r);var vr={};dr(vr,{ensureBinary:()=>F,getBinaryPath:()=>w,main:()=>nr,uninstall:()=>C});module.exports=ur(vr);var tr=require("child_process");var l=m(require("fs")),W=m(require("os")),v=m(require("path")),Q=require("child_process");var k=m(require("os")),M=m(require("path")),gr={darwin:"darwin",linux:"linux",win32:"windows"},hr={x64:"amd64",arm64:"arm64"};function $(){let r=k.default.platform(),n=k.default.arch(),e=gr[r],o=hr[n];if(!e)throw new Error(`Unsupported platform: ${r}`);if(!o)throw new Error(`Unsupported arch: ${n}`);return{platform:e,arch:o}}var R=r=>r==="windows"?"cc-helper.exe":"cc-helper";function P(r,n,e){let o=r.replace(/^v/,"");return n==="windows"?`cc-helper_${o}_${n}_${e}.zip`:`cc-helper_${o}_${n}_${e}.tar.gz`}var w=()=>{let{platform:r}=$();return M.default.join(__dirname,"bin",R(r))};var y=m(require("fs")),H=m(require("path")),q=m(require("http")),G=m(require("https"));function I(r){try{y.default.existsSync(r)&&y.default.unlinkSync(r)}catch{}}async function A(r,n,e=3){for(let o=0;o<e;o++)try{await new Promise((t,i)=>{let p=(r.startsWith("https")?G.default:q.default).get(r,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"}},c=>{if(c.statusCode===301||c.statusCode===302){let d=c.headers.location;if(d){A(d,n,e).then(t).catch(i);return}}if(c.statusCode!==200){i(new Error(`HTTP ${c.statusCode}`));return}let s=H.default.dirname(n);y.default.existsSync(s)||y.default.mkdirSync(s,{recursive:!0});let g=y.default.createWriteStream(n);c.pipe(g),g.on("finish",()=>{g.close(d=>{d?i(d):t()})}),g.on("error",d=>{I(n),i(d)}),c.on("error",d=>{I(n),i(d)})});p.setTimeout(3e4,()=>{p.destroy(),i(new Error("Timeout"))}),p.on("error",c=>{I(n),i(c)})});return}catch(t){if(I(n),o===e-1)throw t;console.log(`warn cc-helper retry ${o+1}/${e}`),await new Promise(i=>setTimeout(i,1e3*(o+1)))}}var f=m(require("fs")),u=m(require("path")),_=m(require("zlib"));async function wr(r,n){let e=0;for(;e+512<=r.length;){let o=r.subarray(e,e+512);if(o.every(c=>c===0))break;let t=o.subarray(0,100).toString().replace(/\0.*$/,""),i=o.subarray(345,500).toString().replace(/\0.*$/,"");i&&(t=`${i}/${t}`),t.startsWith("package/")&&(t=t.slice(8)),t=t.replace(/\//g,u.default.sep);let a=parseInt(o.subarray(124,136).toString().trim(),8)||0,p=o[156];if(e+=512,a>0&&t&&(p===0||p===48)){let c=u.default.join(n,t);await f.default.promises.mkdir(u.default.dirname(c),{recursive:!0}),await f.default.promises.writeFile(c,r.subarray(e,e+a)),e+=Math.ceil(a/512)*512}}}async function yr(r,n){await f.default.promises.mkdir(n,{recursive:!0});let e=await f.default.promises.readFile(r),o;try{o=_.default.unzipSync(e)}catch(t){throw new Error(`Failed to decompress tar.gz: ${t.message}`)}await wr(o,n)}async function xr(r,n){await f.default.promises.mkdir(n,{recursive:!0});let e=await f.default.promises.readFile(r);if(e.length<22)throw new Error(`Invalid ZIP: file too small (${e.length} bytes)`);let o=Buffer.from([80,75,5,6]),t=e.length-22;for(;t>=0&&!e.subarray(t,t+4).equals(o);)t--;if(t<0)throw new Error(`Invalid ZIP: missing end of central directory (file may be corrupted or incomplete, size: ${e.length} bytes)`);if(t+22>e.length)throw new Error("Invalid ZIP: truncated EOCD record");let i=e.readUInt32LE(t+16),a=e.readUInt32LE(t+12),p=i+a;if(i>=e.length||p>e.length)throw new Error(`Invalid ZIP: central directory out of bounds (cdOffset: ${i}, cdEnd: ${p}, fileSize: ${e.length})`);let c=Buffer.from([80,75,1,2]),s=i;for(;s<p;){if(s+46>e.length)throw new Error(`Invalid ZIP: truncated central directory at position ${s}`);if(!e.subarray(s,s+4).equals(c))throw new Error(`Invalid ZIP: invalid central directory signature at position ${s}`);let g=e.readUInt16LE(s+28),d=e.readUInt16LE(s+30),N=e.readUInt16LE(s+32),x=e.readUInt32LE(s+42),or=e.readUInt32LE(s+20),Er=e.readUInt32LE(s+24),Sr=e.readUInt16LE(s+10);if(s+46+g+d+N>e.length)throw new Error(`Invalid ZIP: truncated central directory entry at position ${s}`);let h=e.subarray(s+46,s+46+g).toString();if(s+=46+g+d+N,h.endsWith("/")){await f.default.promises.mkdir(u.default.join(n,h.replace(/\//g,u.default.sep)),{recursive:!0});continue}if(h=h.replace(/\//g,u.default.sep),x+30>e.length)throw new Error(`Invalid ZIP: local header out of bounds for ${h}`);let b=e.readUInt16LE(x+8),ir=e.readUInt16LE(x+26),sr=e.readUInt16LE(x+28),U=x+30+ir+sr,D=or;if(U+D>e.length)throw new Error(`Invalid ZIP: truncated file data for ${h}`);let O=e.subarray(U,U+D),L=u.default.join(n,h);await f.default.promises.mkdir(u.default.dirname(L),{recursive:!0});try{if(b===8)await f.default.promises.writeFile(L,_.default.inflateRawSync(O));else if(b===0)await f.default.promises.writeFile(L,O);else throw new Error(`Unsupported compression method ${b} for ${h}`)}catch(ar){throw new Error(`Failed to decompress ${h}: ${ar.message}`)}}}async function K(r,n,e){e==="windows"?await xr(r,n):await yr(r,n)}function V(r,n){let e=u.default.join(r,n);if(f.default.existsSync(e))return e;for(let o of f.default.readdirSync(r)){let t=u.default.join(r,o,n);if(f.default.statSync(u.default.join(r,o)).isDirectory()&&f.default.existsSync(t))return t}throw new Error(`Binary ${n} not found`)}var j=m(require("https"));var z="next-bin",B="cc-helper";function J(r){return new Promise((n,e)=>{let o=`https://api.github.com${r}`,t=j.default.get(o,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"}},i=>{let a="";i.on("data",p=>a+=p),i.on("end",()=>{i.statusCode!==200?e(new Error(`GitHub API error: ${i.statusCode}`)):n(JSON.parse(a))})});t.setTimeout(15e3,()=>{t.destroy(),e(new Error("GitHub API timeout"))}),t.on("error",e)})}async function T(){return(await J(`/repos/${z}/${B}/releases/latest`)).tag_name.replace(/^v/,"")}async function X(r,n){var t;let e=await J(`/repos/${z}/${B}/releases?per_page=10`),o=r==="windows"?`_${r}_${n}.zip`:`_${r}_${n}.tar.gz`;for(let i of e)if((t=i.assets)!=null&&t.some(a=>a.name.includes(o)))return i.tag_name.replace(/^v/,"");throw new Error(`No binary found for ${r}-${n}`)}function Y(r,n,e,o){let t=r.startsWith("v")?r:`v${r}`,i=`https://github.com/${z}/${B}/releases/download/${t}/${P(r,n,e)}`;return o?`${o}/${i}`:i}async function E(r,n,e,o,t){let i=P(r,n,e),a=v.default.join(W.default.tmpdir(),i),p=Y(r,n,e,t);console.log(`info cc-helper@${r} Installing for ${n}-${e}`),t&&console.log("info cc-helper Using proxy:",t);try{await A(p,a)}catch(s){throw t||console.log("warn cc-helper Download failed, try: npx @unitsvc/cc-helper --proxy enable"),s}let c=v.default.join(W.default.tmpdir(),`cc-helper_${Date.now()}`);l.default.mkdirSync(c,{recursive:!0});try{await K(a,c,n);let s=V(c,R(n)),g=v.default.dirname(o);l.default.existsSync(g)||l.default.mkdirSync(g,{recursive:!0}),l.default.existsSync(o)&&l.default.unlinkSync(o),l.default.copyFileSync(s,o),process.platform!=="win32"&&l.default.chmodSync(o,493),console.log("info cc-helper Installed to",o)}finally{let s=l.default.rmSync||l.default.rmdirSync;try{s(c,{recursive:!0,force:!0})}catch{}l.default.existsSync(a)&&l.default.unlinkSync(a)}}async function F(r=null,n){let{platform:e,arch:o}=$(),t=w();if(l.default.existsSync(t))return t;if(r)try{return await E(r,e,o,t,n),t}catch(a){if(!a.message.includes("404"))throw a;console.log(`warn cc-helper@${r} not available, using latest`)}let i=await T();try{await E(i,e,o,t,n)}catch(a){if(!a.message.includes("404"))throw a;i=await X(e,o),await E(i,e,o,t,n)}return t}function C(){let r=w(),n=v.default.dirname(r);l.default.existsSync(r)?(l.default.unlinkSync(r),console.log("info cc-helper Removed binary:",r)):console.log("info cc-helper No binary found"),l.default.existsSync(n)&&l.default.readdirSync(n).length===0&&l.default.rmdirSync(n),console.log("info cc-helper To complete uninstallation, run:"),console.log(" npm uninstall -g @unitsvc/cc-helper")}async function $r(r){if(!l.default.existsSync(r))return null;try{return(0,Q.execSync)(`"${r}" --version`,{timeout:5e3}).toString().trim().replace(/^v/i,"")}catch{return null}}async function rr(r){let n=w(),e=await T(),o=await $r(n);return{current:o,latest:e,needsUpdate:!o||o!==e}}function er(r){let n=[],e,o="https://edgeone.gh-proxy.org";for(let t=0;t<r.length;t++)r[t]==="--proxy"?t+1<r.length&&(r[t+1].startsWith("http://")||r[t+1].startsWith("https://"))?(e=r[t+1],t++):e=o:r[t].startsWith("--proxy=")?e=r[t].slice(8)||o:n.push(r[t]);return{proxy:e,remainingArgs:n}}async function nr(){let r=process.argv.slice(2);if(r[0]==="uninstall"){C();return}if(r[0]==="update"){let{proxy:o}=er(r.slice(1)),{current:t,latest:i,needsUpdate:a}=await rr();if(!a){console.log(`info cc-helper Already at latest version: ${t}`);return}console.log(`info cc-helper Updating from ${t||"unknown"} to ${i}`);let{platform:p,arch:c}=$(),s=w();await E(i,p,c,s,o);return}let{proxy:n,remainingArgs:e}=er(r);try{let o=await F(null,n),t=(0,tr.spawn)(o,e,{stdio:"inherit"});t.on("close",i=>process.exit(i??1)),t.on("error",i=>{console.error("ERR! cc-helper",i.message),process.exit(1)})}catch(o){console.error("ERR! cc-helper",o.message),process.exit(1)}}require.main===module&&nr();0&&(module.exports={ensureBinary,getBinaryPath,main,uninstall});
|
package/dist/index.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
"use strict";var ar=Object.create;var P=Object.defineProperty;var cr=Object.getOwnPropertyDescriptor;var lr=Object.getOwnPropertyNames;var fr=Object.getPrototypeOf,mr=Object.prototype.hasOwnProperty;var dr=(e,t)=>{for(var r in t)P(e,r,{get:t[r],enumerable:!0})},H=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of lr(t))!mr.call(e,n)&&n!==r&&P(e,n,{get:()=>t[n],enumerable:!(o=cr(t,n))||o.enumerable});return e};var d=(e,t,r)=>(r=e!=null?ar(fr(e)):{},H(t||!e||!e.__esModule?P(r,"default",{value:e,enumerable:!0}):r,e)),
|
|
1
|
+
"use strict";var ar=Object.create;var P=Object.defineProperty;var cr=Object.getOwnPropertyDescriptor;var lr=Object.getOwnPropertyNames;var fr=Object.getPrototypeOf,mr=Object.prototype.hasOwnProperty;var dr=(e,t)=>{for(var r in t)P(e,r,{get:t[r],enumerable:!0})},H=(e,t,r,o)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of lr(t))!mr.call(e,n)&&n!==r&&P(e,n,{get:()=>t[n],enumerable:!(o=cr(t,n))||o.enumerable});return e};var d=(e,t,r)=>(r=e!=null?ar(fr(e)):{},H(t||!e||!e.__esModule?P(r,"default",{value:e,enumerable:!0}):r,e)),pr=e=>H(P({},"__esModule",{value:!0}),e);var xr={};dr(xr,{checkForUpdate:()=>tr,ensureBinary:()=>F,findReleaseWithBinary:()=>U,getArchiveName:()=>w,getBinaryName:()=>v,getBinaryPath:()=>y,getCurrentVersion:()=>D,getDownloadUrl:()=>L,getLatestVersion:()=>E,getPlatform:()=>S,install:()=>rr,uninstall:()=>er});module.exports=pr(xr);var l=d(require("fs")),C=d(require("os")),I=d(require("path")),Y=require("child_process");var z=d(require("os")),G=d(require("path")),ur={darwin:"darwin",linux:"linux",win32:"windows"},gr={x64:"amd64",arm64:"arm64"};function S(){let e=z.default.platform(),t=z.default.arch(),r=ur[e],o=gr[t];if(!r)throw new Error(`Unsupported platform: ${e}`);if(!o)throw new Error(`Unsupported arch: ${t}`);return{platform:r,arch:o}}var v=e=>e==="windows"?"cc-helper.exe":"cc-helper";function w(e,t,r){let o=e.replace(/^v/,"");return t==="windows"?`cc-helper_${o}_${t}_${r}.zip`:`cc-helper_${o}_${t}_${r}.tar.gz`}var y=()=>{let{platform:e}=S();return G.default.join(__dirname,"bin",v(e))};var x=d(require("fs")),q=d(require("path")),K=d(require("http")),V=d(require("https"));function b(e){try{x.default.existsSync(e)&&x.default.unlinkSync(e)}catch{}}async function R(e,t,r=3){for(let o=0;o<r;o++)try{await new Promise((n,i)=>{let m=(e.startsWith("https")?V.default:K.default).get(e,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"}},c=>{if(c.statusCode===301||c.statusCode===302){let p=c.headers.location;if(p){R(p,t,r).then(n).catch(i);return}}if(c.statusCode!==200){i(new Error(`HTTP ${c.statusCode}`));return}let s=q.default.dirname(t);x.default.existsSync(s)||x.default.mkdirSync(s,{recursive:!0});let g=x.default.createWriteStream(t);c.pipe(g),g.on("finish",()=>{g.close(p=>{p?i(p):n()})}),g.on("error",p=>{b(t),i(p)}),c.on("error",p=>{b(t),i(p)})});m.setTimeout(3e4,()=>{m.destroy(),i(new Error("Timeout"))}),m.on("error",c=>{b(t),i(c)})});return}catch(n){if(b(t),o===r-1)throw n;console.log(`warn cc-helper retry ${o+1}/${r}`),await new Promise(i=>setTimeout(i,1e3*(o+1)))}}var f=d(require("fs")),u=d(require("path")),T=d(require("zlib"));async function hr(e,t){let r=0;for(;r+512<=e.length;){let o=e.subarray(r,r+512);if(o.every(c=>c===0))break;let n=o.subarray(0,100).toString().replace(/\0.*$/,""),i=o.subarray(345,500).toString().replace(/\0.*$/,"");i&&(n=`${i}/${n}`),n.startsWith("package/")&&(n=n.slice(8)),n=n.replace(/\//g,u.default.sep);let a=parseInt(o.subarray(124,136).toString().trim(),8)||0,m=o[156];if(r+=512,a>0&&n&&(m===0||m===48)){let c=u.default.join(t,n);await f.default.promises.mkdir(u.default.dirname(c),{recursive:!0}),await f.default.promises.writeFile(c,e.subarray(r,r+a)),r+=Math.ceil(a/512)*512}}}async function wr(e,t){await f.default.promises.mkdir(t,{recursive:!0});let r=await f.default.promises.readFile(e),o;try{o=T.default.unzipSync(r)}catch(n){throw new Error(`Failed to decompress tar.gz: ${n.message}`)}await hr(o,t)}async function yr(e,t){await f.default.promises.mkdir(t,{recursive:!0});let r=await f.default.promises.readFile(e);if(r.length<22)throw new Error(`Invalid ZIP: file too small (${r.length} bytes)`);let o=Buffer.from([80,75,5,6]),n=r.length-22;for(;n>=0&&!r.subarray(n,n+4).equals(o);)n--;if(n<0)throw new Error(`Invalid ZIP: missing end of central directory (file may be corrupted or incomplete, size: ${r.length} bytes)`);if(n+22>r.length)throw new Error("Invalid ZIP: truncated EOCD record");let i=r.readUInt32LE(n+16),a=r.readUInt32LE(n+12),m=i+a;if(i>=r.length||m>r.length)throw new Error(`Invalid ZIP: central directory out of bounds (cdOffset: ${i}, cdEnd: ${m}, fileSize: ${r.length})`);let c=Buffer.from([80,75,1,2]),s=i;for(;s<m;){if(s+46>r.length)throw new Error(`Invalid ZIP: truncated central directory at position ${s}`);if(!r.subarray(s,s+4).equals(c))throw new Error(`Invalid ZIP: invalid central directory signature at position ${s}`);let g=r.readUInt16LE(s+28),p=r.readUInt16LE(s+30),Z=r.readUInt16LE(s+32),$=r.readUInt32LE(s+42),nr=r.readUInt32LE(s+20),$r=r.readUInt32LE(s+24),Sr=r.readUInt16LE(s+10);if(s+46+g+p+Z>r.length)throw new Error(`Invalid ZIP: truncated central directory entry at position ${s}`);let h=r.subarray(s+46,s+46+g).toString();if(s+=46+g+p+Z,h.endsWith("/")){await f.default.promises.mkdir(u.default.join(t,h.replace(/\//g,u.default.sep)),{recursive:!0});continue}if(h=h.replace(/\//g,u.default.sep),$+30>r.length)throw new Error(`Invalid ZIP: local header out of bounds for ${h}`);let k=r.readUInt16LE($+8),or=r.readUInt16LE($+26),ir=r.readUInt16LE($+28),B=$+30+or+ir,M=nr;if(B+M>r.length)throw new Error(`Invalid ZIP: truncated file data for ${h}`);let O=r.subarray(B,B+M),_=u.default.join(t,h);await f.default.promises.mkdir(u.default.dirname(_),{recursive:!0});try{if(k===8)await f.default.promises.writeFile(_,T.default.inflateRawSync(O));else if(k===0)await f.default.promises.writeFile(_,O);else throw new Error(`Unsupported compression method ${k} for ${h}`)}catch(sr){throw new Error(`Failed to decompress ${h}: ${sr.message}`)}}}async function j(e,t,r){r==="windows"?await yr(e,t):await wr(e,t)}function J(e,t){let r=u.default.join(e,t);if(f.default.existsSync(r))return r;for(let o of f.default.readdirSync(e)){let n=u.default.join(e,o,t);if(f.default.statSync(u.default.join(e,o)).isDirectory()&&f.default.existsSync(n))return n}throw new Error(`Binary ${t} not found`)}var Q=d(require("https"));var W="next-bin",A="cc-helper";function X(e){return new Promise((t,r)=>{let o=`https://api.github.com${e}`,n=Q.default.get(o,{headers:{"User-Agent":"Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/120.0.0.0 Safari/537.36"}},i=>{let a="";i.on("data",m=>a+=m),i.on("end",()=>{i.statusCode!==200?r(new Error(`GitHub API error: ${i.statusCode}`)):t(JSON.parse(a))})});n.setTimeout(15e3,()=>{n.destroy(),r(new Error("GitHub API timeout"))}),n.on("error",r)})}async function E(){return(await X(`/repos/${W}/${A}/releases/latest`)).tag_name.replace(/^v/,"")}async function U(e,t){var n;let r=await X(`/repos/${W}/${A}/releases?per_page=10`),o=e==="windows"?`_${e}_${t}.zip`:`_${e}_${t}.tar.gz`;for(let i of r)if((n=i.assets)!=null&&n.some(a=>a.name.includes(o)))return i.tag_name.replace(/^v/,"");throw new Error(`No binary found for ${e}-${t}`)}function L(e,t,r,o){let n=e.startsWith("v")?e:`v${e}`,i=`https://github.com/${W}/${A}/releases/download/${n}/${w(e,t,r)}`;return o?`${o}/${i}`:i}async function N(e,t,r,o,n){let i=w(e,t,r),a=I.default.join(C.default.tmpdir(),i),m=L(e,t,r,n);console.log(`info cc-helper@${e} Installing for ${t}-${r}`),n&&console.log("info cc-helper Using proxy:",n);try{await R(m,a)}catch(s){throw n||console.log("warn cc-helper Download failed, try: npx @unitsvc/cc-helper --proxy enable"),s}let c=I.default.join(C.default.tmpdir(),`cc-helper_${Date.now()}`);l.default.mkdirSync(c,{recursive:!0});try{await j(a,c,t);let s=J(c,v(t)),g=I.default.dirname(o);l.default.existsSync(g)||l.default.mkdirSync(g,{recursive:!0}),l.default.existsSync(o)&&l.default.unlinkSync(o),l.default.copyFileSync(s,o),process.platform!=="win32"&&l.default.chmodSync(o,493),console.log("info cc-helper Installed to",o)}finally{let s=l.default.rmSync||l.default.rmdirSync;try{s(c,{recursive:!0,force:!0})}catch{}l.default.existsSync(a)&&l.default.unlinkSync(a)}}async function F(e=null,t){let{platform:r,arch:o}=S(),n=y();if(l.default.existsSync(n))return n;if(e)try{return await N(e,r,o,n,t),n}catch(a){if(!a.message.includes("404"))throw a;console.log(`warn cc-helper@${e} not available, using latest`)}let i=await E();try{await N(i,r,o,n,t)}catch(a){if(!a.message.includes("404"))throw a;i=await U(r,o),await N(i,r,o,n,t)}return n}async function rr(e=null,t){try{await F(e,t)}catch(r){console.error("ERR! cc-helper",r.message)}}function er(){let e=y(),t=I.default.dirname(e);l.default.existsSync(e)?(l.default.unlinkSync(e),console.log("info cc-helper Removed binary:",e)):console.log("info cc-helper No binary found"),l.default.existsSync(t)&&l.default.readdirSync(t).length===0&&l.default.rmdirSync(t),console.log("info cc-helper To complete uninstallation, run:"),console.log(" npm uninstall -g @unitsvc/cc-helper")}async function D(e){if(!l.default.existsSync(e))return null;try{return(0,Y.execSync)(`"${e}" --version`,{timeout:5e3}).toString().trim().replace(/^v/i,"")}catch{return null}}async function tr(e){let t=y(),r=await E(),o=await D(t);return{current:o,latest:r,needsUpdate:!o||o!==r}}0&&(module.exports={checkForUpdate,ensureBinary,findReleaseWithBinary,getArchiveName,getBinaryName,getBinaryPath,getCurrentVersion,getDownloadUrl,getLatestVersion,getPlatform,install,uninstall});
|