coze-bridge 0.1.92 → 0.1.93-beta.0

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.
Files changed (2) hide show
  1. package/dist/index.js +45 -45
  2. package/package.json +1 -1
package/dist/index.js CHANGED
@@ -5,33 +5,33 @@ import { dirname as __coze_dirname } from 'node:path';
5
5
  const require = __coze_createRequire(import.meta.url);
6
6
  const __filename = __coze_fileURLToPath(import.meta.url);
7
7
  const __dirname = __coze_dirname(__filename);
8
- var Fg=Object.create;var $o=Object.defineProperty;var Mg=Object.getOwnPropertyDescriptor;var Bg=Object.getOwnPropertyNames;var Ug=Object.getPrototypeOf,zg=Object.prototype.hasOwnProperty;var j=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,n)=>(typeof require<"u"?require:e)[n]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var ve=(t,e)=>()=>(t&&(e=t(t=0)),e);var H=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Ni=(t,e)=>{for(var n in e)$o(t,n,{get:e[n],enumerable:!0})},$g=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Bg(e))!zg.call(t,i)&&i!==n&&$o(t,i,{get:()=>e[i],enumerable:!(r=Mg(e,i))||r.enumerable});return t};var ht=(t,e,n)=>(n=t!=null?Fg(Ug(t)):{},$g(e||!t||!t.__esModule?$o(n,"default",{value:t,enumerable:!0}):n,t));function pt(t,e){let n=process.env[t];if(!n)return e;let r=Number(n);return Number.isFinite(r)&&r>0?r:e}var Li=ve(()=>{"use strict"});import{createWriteStream as Gg,mkdirSync as Hg,readdirSync as jg,unlinkSync as Wg}from"node:fs";import{join as Dl}from"node:path";function xn(t){let e=n=>String(n).padStart(2,"0");return`${t.getFullYear()}-${e(t.getMonth()+1)}-${e(t.getDate())}`}function Fi(t,e){return`${t}-${e}.log`}function Go(t,e){let n=t.match(/^(.+)-(\d{4}-\d{2}-\d{2})\.log$/);return!n||n[1]!==e?null:n[2]??null}function qg(t,e,n){let r=s=>{let[o,a,c]=s.split("-").map(Number);return Date.UTC(o??0,(a??1)-1,c??1)};return Math.floor((r(e)-r(t))/864e5)>n}function Mi(t,e,n,r){let i;try{i=jg(t)}catch{return}for(let s of i){let o=Go(s,e);if(o&&qg(o,n,r))try{Wg(Dl(t,s))}catch{}}}var Rr,Ho=ve(()=>{"use strict";Rr=class{constructor(e,n,r){this.dir=e;this.prefix=n;this.opts=r;this.clock=r.clock??(()=>xn(new Date))}dir;prefix;opts;currentDate;stream;clock;write(e){let n=this.clock();n!==this.currentDate&&this.rotate(n),this.stream?.write(e)}rotate(e){this.stream?.end();try{Hg(this.dir,{recursive:!0});let n=Gg(Dl(this.dir,Fi(this.prefix,e)),{flags:"a"});n.on("error",r=>process.stderr.write(`[log-sink] stream error: ${String(r)}
8
+ var Fg=Object.create;var Ho=Object.defineProperty;var Mg=Object.getOwnPropertyDescriptor;var Bg=Object.getOwnPropertyNames;var Ug=Object.getPrototypeOf,zg=Object.prototype.hasOwnProperty;var j=(t=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(t,{get:(e,n)=>(typeof require<"u"?require:e)[n]}):t)(function(t){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+t+'" is not supported')});var ve=(t,e)=>()=>(t&&(e=t(t=0)),e);var H=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports),Li=(t,e)=>{for(var n in e)Ho(t,n,{get:e[n],enumerable:!0})},$g=(t,e,n,r)=>{if(e&&typeof e=="object"||typeof e=="function")for(let i of Bg(e))!zg.call(t,i)&&i!==n&&Ho(t,i,{get:()=>e[i],enumerable:!(r=Mg(e,i))||r.enumerable});return t};var ht=(t,e,n)=>(n=t!=null?Fg(Ug(t)):{},$g(e||!t||!t.__esModule?Ho(n,"default",{value:t,enumerable:!0}):n,t));function pt(t,e){let n=process.env[t];if(!n)return e;let r=Number(n);return Number.isFinite(r)&&r>0?r:e}var Fi=ve(()=>{"use strict"});import{createWriteStream as Gg,mkdirSync as Hg,readdirSync as jg,unlinkSync as Wg}from"node:fs";import{join as Dl}from"node:path";function xn(t){let e=n=>String(n).padStart(2,"0");return`${t.getFullYear()}-${e(t.getMonth()+1)}-${e(t.getDate())}`}function Mi(t,e){return`${t}-${e}.log`}function jo(t,e){let n=t.match(/^(.+)-(\d{4}-\d{2}-\d{2})\.log$/);return!n||n[1]!==e?null:n[2]??null}function qg(t,e,n){let r=s=>{let[o,a,c]=s.split("-").map(Number);return Date.UTC(o??0,(a??1)-1,c??1)};return Math.floor((r(e)-r(t))/864e5)>n}function Bi(t,e,n,r){let i;try{i=jg(t)}catch{return}for(let s of i){let o=jo(s,e);if(o&&qg(o,n,r))try{Wg(Dl(t,s))}catch{}}}var kr,Wo=ve(()=>{"use strict";kr=class{constructor(e,n,r){this.dir=e;this.prefix=n;this.opts=r;this.clock=r.clock??(()=>xn(new Date))}dir;prefix;opts;currentDate;stream;clock;write(e){let n=this.clock();n!==this.currentDate&&this.rotate(n),this.stream?.write(e)}rotate(e){this.stream?.end();try{Hg(this.dir,{recursive:!0});let n=Gg(Dl(this.dir,Mi(this.prefix,e)),{flags:"a"});n.on("error",r=>process.stderr.write(`[log-sink] stream error: ${String(r)}
9
9
  `)),this.stream=n}catch(n){process.stderr.write(`[log-sink] rotate failed: ${String(n)}
10
- `),this.stream=void 0;return}this.currentDate!==void 0&&Mi(this.dir,this.prefix,e,this.opts.retentionDays),this.currentDate=e}close(){this.stream?.end(),this.stream=void 0,this.currentDate=void 0}}});function Ll(t){let e=t.retentionDays??Zg,n=t.clock??(()=>xn(new Date));Ui={bridgeSink:new Rr(t.bridgeLogsDir,"bridge",{retentionDays:e,clock:n}),agentSinks:new Map,makeAgentSink:i=>new Rr(t.agentLogsDir(i),"agent",{retentionDays:e,clock:n})};let r=n();Mi(t.bridgeLogsDir,"bridge",r,e);for(let i of t.listAgentIds?.()??[])Mi(t.agentLogsDir(i),"agent",r,e)}function Kg(t,e){let n=t.agentSinks.get(e);return n||(n=t.makeAgentSink(e),t.agentSinks.set(e,n)),n}function Fl(t){jo=t}function Ml(t){return On[jo]<=On[t]}function Bl(t,e){let n=On[t];return n===void 0?!0:n>=On[e]}function zi(t){Nl={...t}}function Xg(t){let e=(a,c=2)=>String(a).padStart(c,"0"),n=-t.getTimezoneOffset(),r=n>=0?"+":"-",i=Math.abs(n),s=e(Math.floor(i/60)),o=e(i%60);return`${xn(t)}T${e(t.getHours())}:${e(t.getMinutes())}:${e(t.getSeconds())}.${e(t.getMilliseconds(),3)}${r}${s}:${o}`}function Yg(t,e){if(t)return t;let n=e?.agentId;return typeof n=="string"&&n.length>0?n:void 0}function Bi(t,e,n,r,i){if(On[t]<On[jo])return;let s=`${JSON.stringify({ts:Xg(new Date),level:t,module:e,msg:n,...Nl,...r})}
11
- `;if(Ui){let o=Yg(i,r),a=o?Kg(Ui,o):Ui.bridgeSink;try{a.write(s)}catch{process.stderr.write(s)}return}t==="error"||t==="warn"?Jg.write(s):Vg.write(s)}function b(t,e){return{debug:(n,r)=>Bi("debug",t,n,r,e),info:(n,r)=>Bi("info",t,n,r,e),warn:(n,r)=>Bi("warn",t,n,r,e),error:(n,r)=>Bi("error",t,n,r,e),child:n=>b(`${t}.${n}`,e),forAgent:n=>b(t,n)}}var On,jo,Vg,Jg,Nl,Zg,Ui,L=ve(()=>{"use strict";Li();Ho();On={debug:10,info:20,warn:30,error:40},jo=(()=>{let t=process.env.COZE_BRIDGE_LOG_LEVEL;return t==="debug"||t==="info"||t==="warn"||t==="error"?t:"info"})(),Vg=process.stdout,Jg=process.stderr,Nl={},Zg=pt("COZE_BRIDGE_LOG_RETENTION_DAYS",30),Ui=null});import{execFile as Qg,spawn as em,spawnSync as QT}from"node:child_process";import{promisify as tm}from"node:util";function rm(t){if(process.platform!=="win32")return!1;if(Ul.test(t))return!0;let n=(t.split(/[/\\]/).pop()??t).replace(Ul,"").toLowerCase();return nm.has(n)}function zl(t,e){if(process.platform!=="win32")return e??{};let n={...e??{}};return rm(t)&&n.shell===void 0&&(n.shell=!0),n.windowsHide===void 0&&(n.windowsHide=!0),n}function Fe(t,e=[],n={}){return em(t,e,zl(t,n))}function Pn(t,e=[],n={}){return im(t,e,zl(t,n))}var nm,Ul,im,gt=ve(()=>{"use strict";nm=new Set(["npm","npx","yarn","pnpm","coze","tsx","claude-agent-acp","codex-acp","openclaw"]),Ul=/\.(cmd|bat|ps1)$/i;im=tm(Qg)});var _,Te=ve(()=>{"use strict";_=class extends Error{code;retriable;cause;constructor(e,n,r){super(n),this.name="BridgeError",this.code=e,this.retriable=r?.retriable??!1,r?.cause!==void 0&&(this.cause=r.cause)}}});var Zl={};Ni(Zl,{_resetAcpInstallerForTests:()=>hm,_resetInstallTimeoutsForTests:()=>fm,_setBinaryPathCacheForTests:()=>gm,_setInFlightForTests:()=>pm,_setInstallTimeoutsForTests:()=>um,buildInstallFailureMessage:()=>Jl,ensureAcpInstalled:()=>en,formatExecError:()=>Hl,getAcpBinaryPath:()=>kr,getAcpPackageSpec:()=>lm,getInFlightInstall:()=>Vo,npmInstallGlobal:()=>Vl,parseVersionTriple:()=>Wl,pickWhichLine:()=>Hi,probeAcpVersion:()=>jl,resolveAcpCommand:()=>br,versionSatisfiesSpec:()=>ql});import{readFile as sm,realpath as om,stat as am}from"node:fs/promises";import{dirname as Wo,join as cm}from"node:path";function lm(t){let e=qo[t];if(e)return`${e.npmPackage}@${e.versionSpec}`}function um(t,e){$i=t,Gi=e}function fm(){$i=5e4,Gi=5e3}function Hl(t){if(t==null||typeof t!="object")return String(t);let e=t,n=[];e.message&&n.push(e.message),e.code!==void 0&&e.code!==null&&n.push(`code=${e.code}`),e.signal&&n.push(`signal=${e.signal}`);let r=e.stderr?.toString().trim();r&&n.push(`stderr=${r.slice(0,2e3)}`);let i=e.stdout?.toString().trim();return i&&n.push(`stdout=${i.slice(0,2e3)}`),n.length>0?n.join(" | "):String(t)}async function $l(t){let e=process.platform==="win32"?"where":"which";try{let{stdout:n}=await Pn(e,[t],{timeout:dm});return Hi(n)}catch{return}}function Hi(t){let e=t.split(/\r?\n/).map(r=>r.trim()).filter(Boolean);if(e.length===0)return;if(process.platform!=="win32")return e[0];let n=r=>e.find(i=>i.toLowerCase().endsWith(r));return n(".cmd")??n(".exe")??n(".bat")??n(".ps1")??e[0]}async function jl(t,e){let n=qo[t];if(!n)return;let r=e??kr(t);if(!r){ce.warn("acp wrapper probe: binary path cache empty",{framework:t,binary:n.binary,hint:"ensureAcpInstalled \u6CA1\u8DD1\u8FC7 / \u88C5\u5931\u8D25 / \u4E4B\u524D negative cache 5min \u5185"});return}let i;try{i=await om(r)}catch(o){ce.warn("acp wrapper probe: realpath failed (symlink target \u4E0D\u5B58\u5728?)",{framework:t,binaryPath:r,err:String(o)});return}let s=Wo(i);for(let o=0;o<Gl;o++){let a=cm(s,"package.json");try{if(!(await am(a)).isFile()){s=Wo(s);continue}let d=await sm(a,"utf8"),p=JSON.parse(d);if(p.name===n.npmPackage){if(typeof p.version=="string"&&p.version.length>0)return p.version;ce.warn("acp wrapper probe: package.json \u627E\u5230\u4F46 version \u5B57\u6BB5\u7F3A",{framework:t,packageJsonPath:a});return}}catch(l){let d=l;d.code!=="ENOENT"&&ce.warn("acp wrapper probe: package.json \u8BFB\u53D6\u5F02\u5E38",{framework:t,candidate:a,errCode:d?.code,err:String(l)})}let c=Wo(s);if(c===s)break;s=c}ce.warn("acp wrapper probe: \u627E\u4E0D\u5230\u5339\u914D name \u7684 package.json (\u4E0A\u6EAF\u5230 max depth)",{framework:t,binaryPath:r,realBinary:i,expectedName:n.npmPackage,maxDepth:Gl})}function Wl(t){let e=/^\s*(\d+)\.(\d+)\.(\d+)/.exec(t);return e?[Number(e[1]),Number(e[2]),Number(e[3])]:null}function ql(t,e){let n=Wl(t);if(!n)return!0;let r=/^\^(\d+)\.(\d+)(?:\.(\d+))?$/.exec(e.trim());if(!r)return!0;let[i,s,o]=n,a=Number(r[1]),c=Number(r[2]),l=r[3]!==void 0?Number(r[3]):0;return i>a||i===a&&(s>c||s===c&&o>=l)?a>=1?i===a:c>=1?i===0&&s===c:i===0&&s===0&&o===l:!1}async function Vl(t,e,n){let r=`${t}@${e}`;ce.info("npm install -g start",{npmPackage:t,versionSpec:e});let i=Date.now(),s=process.platform==="win32";return new Promise((o,a)=>{let c=Fe("npm",["install","-g",r],{stdio:["ignore","pipe","pipe"],...s?{}:{detached:!0}});if(!c.pid){c.once("error",y=>{ce.warn("npm spawn failed (no pid, error swallowed)",{npmPackage:t,err:String(y)})}),a(new Error(`failed to spawn npm: no pid (npmPackage=${t})`));return}let l=c.pid,d=10*1024*1024,p=[],m=[],u=0,h=0;c.stdout?.on("data",y=>{u+=y.length,u<d&&p.push(y)}),c.stderr?.on("data",y=>{h+=y.length,h<d&&m.push(y)});let g="running",w,S=y=>{try{return s?c.kill(y):process.kill(-l,y),!0}catch(E){return ce.warn("npm install: kill failed (process already dead?)",{npmPackage:t,pid:l,sig:y,err:String(E)}),!1}},v=setTimeout(()=>{g="terminating",ce.warn("npm install timeout, sending SIGTERM to process group",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i,timeoutMs:$i,graceMs:Gi,stdoutBytes:u,stderrBytes:h}),S("SIGTERM"),w=setTimeout(()=>{g="killing",ce.warn("npm install SIGTERM grace expired, escalating to SIGKILL",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i,stdoutBytes:u,stderrBytes:h}),S("SIGKILL")},Gi)},$i),f=()=>{g="aborted",ce.warn("npm install externally aborted, sending SIGKILL to process group",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i}),S("SIGKILL")};n&&(n.aborted?f():n.addEventListener("abort",f,{once:!0})),c.on("error",y=>{clearTimeout(v),w&&clearTimeout(w),n?.removeEventListener("abort",f),ce.warn("npm install spawn error",{npmPackage:t,versionSpec:e,pid:l,err:String(y)}),a(new Error(`spawn npm failed: ${String(y)}`))}),c.on("close",(y,E)=>{clearTimeout(v),w&&clearTimeout(w),n?.removeEventListener("abort",f);let T=Buffer.concat(p).toString("utf8"),R=Buffer.concat(m).toString("utf8"),D=Date.now()-i;if(y===0&&g==="running"){ce.info("npm install -g done",{npmPackage:t,versionSpec:e,elapsedMs:D}),o();return}ce.warn("npm install -g exited non-success",{npmPackage:t,versionSpec:e,pid:l,phase:g,exitCode:y,signal:E,elapsedMs:D,stdoutBytes:u,stderrBytes:h});let C=Object.assign(new Error(`Command failed: npm install -g ${r}${E?` (killed by ${E})`:""}${y!==null?` (exit ${y})`:""}${g!=="running"?` (phase=${g})`:""}`),{code:y,signal:E,stderr:R,stdout:T});a(C)})})}function Jl(t){let{framework:e,npmPackage:n,versionSpec:r,command:i,reason:s,elapsedMs:o}=t;return["ACP wrapper \u5B89\u88C5\u5931\u8D25",`Framework: ${e}`,`Package: ${n}@${r}`,`\u6267\u884C\u547D\u4EE4: ${i}`,`\u5931\u8D25\u539F\u56E0: ${s}`,`\u8017\u65F6: ${o}ms`,"","\u6392\u67E5\u5EFA\u8BAE:"," 1. \u68C0\u67E5\u7F51\u7EDC: curl -v https://registry.npmjs.org"," 2. \u67E5\u770B\u5F53\u524D npm \u6E90: npm config get registry"," 3. \u56FD\u5185\u7F51\u7EDC\u5EFA\u8BAE\u5207\u955C\u50CF\u6E90:"," npm config set registry https://registry.npmmirror.com/"].join(`
12
- `)}async function en(t,e){let n=qo[t];if(!n)throw new _("BRIDGE_INTERNAL",`ensureAcpInstalled called for non-npm framework: ${t}`);let r=Cn.get(t);if(r)return r;let i=Dn.get(t);if(i)return i;let s=`npm install -g ${n.npmPackage}@${n.versionSpec}`,o=(c,l,d)=>new _("AGENT_DEPENDENCY_INSTALL_FAILED",Jl({framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,command:s,reason:c,elapsedMs:l}),d!==void 0?{cause:d}:{}),a=(async()=>{let c=await $l(n.binary);if(c){let p=process.env.COZE_BRIDGE_ACP_NO_AUTO_UPGRADE==="1",m=p?void 0:await jl(t,c);if(p||ql(m??"",n.versionSpec))return Cn.set(t,c),ce.info("acp wrapper found on PATH",{binary:n.binary,path:c,version:m??(p?"unchecked (auto-upgrade off)":"unknown"),spec:n.versionSpec}),c;ce.info("acp wrapper on PATH but version out of spec \u2014 reinstalling to locked range",{binary:n.binary,path:c,installed:m,spec:n.versionSpec})}let l=Date.now();try{await Vl(n.npmPackage,n.versionSpec,e)}catch(p){let m=Hl(p);throw ce.warn("acp wrapper install failed",{framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,binary:n.binary,err:m}),o(m,Date.now()-l,p)}let d=await $l(n.binary);if(!d)throw ce.warn("acp wrapper installed but binary not found on PATH",{framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,binary:n.binary}),o(`npm install \u6210\u529F\u4F46 \`${process.platform==="win32"?"where":"which"} ${n.binary}\` \u627E\u4E0D\u5230 binary (npm prefix \u53EF\u80FD\u672A\u52A0\u5165 PATH, \u6216\u88AB\u88C5\u5230\u4E86 nvm/asdf \u522B\u7684\u7248\u672C\u4E0B)`,Date.now()-l);return Cn.set(t,d),d})().finally(()=>{Dn.delete(t)});return Dn.set(t,a),a}function kr(t){return Cn.get(t)}function br(t,e){if(e)return e;let n=kr(t);if(!n)throw new _("BRIDGE_INTERNAL",`${t} ACP wrapper binary path cache miss (ensureAcpInstalled \u672A\u5728\u6784\u9020\u524D\u8DD1\u901A)`);return n}function Vo(t){return Dn.get(t)}function hm(){Cn.clear(),Dn.clear()}function pm(t,e){Dn.set(t,e)}function gm(t,e){Cn.set(t,e)}var ce,qo,$i,Gi,dm,Cn,Dn,Gl,tn=ve(()=>{"use strict";gt();Te();L();ce=b("agents.acp-installer"),qo={"claude-code":{npmPackage:"@agentclientprotocol/claude-agent-acp",binary:"claude-agent-acp",versionSpec:"^0.39"},codex:{npmPackage:"@zed-industries/codex-acp",binary:"codex-acp",versionSpec:"^0.15"}};$i=5e4,Gi=5e3,dm=5e3;Cn=new Map,Dn=new Map;Gl=6});import{chmod as wm,mkdir as ym,readFile as _m,rename as Yl,writeFile as Ql}from"node:fs/promises";import{dirname as Em}from"node:path";async function Nn(t){try{let e=await _m(t,"utf8");return JSON.parse(e)}catch(e){if(e.code==="ENOENT")return null;throw e}}async function ji(t,e,n){await ym(Em(t),{recursive:!0});let r=`${JSON.stringify(e,null,2)}
13
- `,i=`${t}.tmp-${process.pid}-${Math.random().toString(36).slice(2,10)}`;try{n?.mode!==void 0?await Ql(i,r,{encoding:"utf8",mode:n.mode}):await Ql(i,r,"utf8"),await Yl(i,t),n?.mode!==void 0&&await wm(t,n.mode)}catch(s){await Yl(i,i).catch(()=>{});let{rm:o}=await import("node:fs/promises");throw await o(i,{force:!0}).catch(()=>{}),s}}var Wi=ve(()=>{"use strict"});import{promises as ed,readdirSync as Sm}from"node:fs";import{homedir as vm}from"node:os";import{sep as Im,join as ne,resolve as td}from"node:path";function F(t){let e=t??vm(),n=ne(e,".coze"),r=ne(n,"bridge"),i=ne(r,"lib"),s=ne(r,"logs");return{cozeRoot:n,bridgeRoot:r,libDir:i,libEntry:ne(i,"index.js"),binDir:ne(r,"bin"),pidFile:ne(r,"bridge.pid"),portFile:ne(r,"bridge.port"),tokenFile:ne(r,"bridge.token"),patTokenFile:ne(r,"pat-token"),logFile:ne(r,"bridge.log"),bridgeLogsDir:s,daemonStdioLog:ne(s,"daemon-stdio.log"),installLock:ne(r,"install.lock"),configFile:ne(r,"config.json"),agentsRoot:ne(n,"agents")}}function be(t,e=F()){let n=ne(e.agentsRoot,t);return{root:n,config:ne(n,"config.json"),workspace:ne(n,"workspace"),logs:ne(n,"logs")}}function qi(t=F()){try{return Sm(t.agentsRoot,{withFileTypes:!0}).filter(e=>e.isDirectory()).map(e=>e.name)}catch{return[]}}async function Ar(t,e){let n=await ed.realpath(td(t)).catch(()=>null);if(!n)return!1;let r=await ed.realpath(td(e)).catch(()=>null);if(!r)return!1;let i=process.platform==="win32"?n.toLowerCase():n,s=process.platform==="win32"?r.toLowerCase():r;return i===s||i.startsWith(s+Im)}var le=ve(()=>{"use strict"});var Zi={};Ni(Zi,{AGENT_CONFIG_FILE_MODE:()=>Vi,enforceAgentConfigMode:()=>km,loadAgentConfig:()=>me,persistAgentSessions:()=>xr,persistAgentSkills:()=>Ji,saveAgentConfig:()=>Ae});import{chmod as Tm,stat as Rm}from"node:fs/promises";function me(t,e){return Nn(be(t,e).config)}function Ae(t,e){return ji(be(t.agentId,e).config,t,{mode:Vi})}async function km(t,e){if(process.platform==="win32")return;let n=be(t,e).config;try{let r=await Rm(n);if(!r.isFile())return;let i=r.mode&511;i!==Vi&&(await Tm(n,Vi),nd.warn("agent config mode auto-corrected to 0600",{path:n,from:i.toString(8)}))}catch(r){if(r.code==="ENOENT")return;nd.warn("enforceAgentConfigMode: chmod failed (ignored)",{path:n,err:String(r)})}}async function xr(t,e,n){let r=await me(t,n);r&&(r.sessions=Object.fromEntries(e),await Ae(r,n))}async function Ji(t,e,n){let r=await me(t,n);r&&(r.skills=e,await Ae(r,n))}var nd,Vi,At=ve(()=>{"use strict";Wi();L();le();nd=b("agent-config"),Vi=384});var Zo=H((OR,od)=>{od.exports={LOCHDR:30,LOCSIG:67324752,LOCVER:4,LOCFLG:6,LOCHOW:8,LOCTIM:10,LOCCRC:14,LOCSIZ:18,LOCLEN:22,LOCNAM:26,LOCEXT:28,EXTSIG:134695760,EXTHDR:16,EXTCRC:4,EXTSIZ:8,EXTLEN:12,CENHDR:46,CENSIG:33639248,CENVEM:4,CENVER:6,CENFLG:8,CENHOW:10,CENTIM:12,CENCRC:16,CENSIZ:20,CENLEN:24,CENNAM:28,CENEXT:30,CENCOM:32,CENDSK:34,CENATT:36,CENATX:38,CENOFF:42,ENDHDR:22,ENDSIG:101010256,ENDSUB:8,ENDTOT:10,ENDSIZ:12,ENDOFF:16,ENDCOM:20,END64HDR:20,END64SIG:117853008,END64START:4,END64OFF:8,END64NUMDISKS:16,ZIP64SIG:101075792,ZIP64HDR:56,ZIP64LEAD:12,ZIP64SIZE:4,ZIP64VEM:12,ZIP64VER:14,ZIP64DSK:16,ZIP64DSKDIR:20,ZIP64SUB:24,ZIP64TOT:32,ZIP64SIZB:40,ZIP64OFF:48,ZIP64EXTRA:56,STORED:0,SHRUNK:1,REDUCED1:2,REDUCED2:3,REDUCED3:4,REDUCED4:5,IMPLODED:6,DEFLATED:8,ENHANCED_DEFLATED:9,PKWARE:10,BZIP2:12,LZMA:14,IBM_TERSE:18,IBM_LZ77:19,AES_ENCRYPT:99,FLG_ENC:1,FLG_COMP1:2,FLG_COMP2:4,FLG_DESC:8,FLG_ENH:16,FLG_PATCH:32,FLG_STR:64,FLG_EFS:2048,FLG_MSK:4096,FILE:2,BUFFER:1,NONE:0,EF_ID:0,EF_SIZE:2,ID_ZIP64:1,ID_AVINFO:7,ID_PFS:8,ID_OS2:9,ID_NTFS:10,ID_OPENVMS:12,ID_UNIX:13,ID_FORK:14,ID_PATCH:15,ID_X509_PKCS7:20,ID_X509_CERTID_F:21,ID_X509_CERTID_C:22,ID_STRONGENC:23,ID_RECORD_MGT:24,ID_X509_PKCS7_RL:25,ID_IBM1:101,ID_IBM2:102,ID_POSZIP:18064,EF_ZIP64_OR_32:4294967295,EF_ZIP64_OR_16:65535,EF_ZIP64_SUNCOMP:0,EF_ZIP64_SCOMP:8,EF_ZIP64_RHO:16,EF_ZIP64_DSN:24}});var Xi=H(cd=>{var ad={INVALID_LOC:"Invalid LOC header (bad signature)",INVALID_CEN:"Invalid CEN header (bad signature)",INVALID_END:"Invalid END header (bad signature)",DESCRIPTOR_NOT_EXIST:"No descriptor present",DESCRIPTOR_UNKNOWN:"Unknown descriptor format",DESCRIPTOR_FAULTY:"Descriptor data is malformed",NO_DATA:"Nothing to decompress",BAD_CRC:"CRC32 checksum failed {0}",FILE_IN_THE_WAY:"There is a file in the way: {0}",UNKNOWN_METHOD:"Invalid/unsupported compression method",AVAIL_DATA:"inflate::Available inflate data did not terminate",INVALID_DISTANCE:"inflate::Invalid literal/length or distance code in fixed or dynamic block",TO_MANY_CODES:"inflate::Dynamic block code description: too many length or distance codes",INVALID_REPEAT_LEN:"inflate::Dynamic block code description: repeat more than specified lengths",INVALID_REPEAT_FIRST:"inflate::Dynamic block code description: repeat lengths with no first length",INCOMPLETE_CODES:"inflate::Dynamic block code description: code lengths codes incomplete",INVALID_DYN_DISTANCE:"inflate::Dynamic block code description: invalid distance code lengths",INVALID_CODES_LEN:"inflate::Dynamic block code description: invalid literal/length code lengths",INVALID_STORE_BLOCK:"inflate::Stored block length did not match one's complement",INVALID_BLOCK_TYPE:"inflate::Invalid block type (type == 3)",CANT_EXTRACT_FILE:"Could not extract the file",CANT_OVERRIDE:"Target file already exists",DISK_ENTRY_TOO_LARGE:"Number of disk entries is too large",NO_ZIP:"No zip file was loaded",NO_ENTRY:"Entry doesn't exist",DIRECTORY_CONTENT_ERROR:"A directory cannot have content",FILE_NOT_FOUND:'File not found: "{0}"',NOT_IMPLEMENTED:"Not implemented",INVALID_FILENAME:"Invalid filename",INVALID_FORMAT:"Invalid or unsupported zip format. No END header found",INVALID_PASS_PARAM:"Incompatible password parameter",WRONG_PASSWORD:"Wrong Password",COMMENT_TOO_LONG:"Comment is too long",EXTRA_FIELD_PARSE_ERROR:"Extra field parsing error"};function Pm(t){return function(...e){return e.length&&(t=t.replace(/\{(\d)\}/g,(n,r)=>e[r]||"")),new Error("ADM-ZIP: "+t)}}for(let t of Object.keys(ad))cd[t]=Pm(ad[t])});var hd=H((CR,fd)=>{var Cm=j("fs"),re=j("path"),ld=Zo(),Dm=Xi(),Nm=typeof process=="object"&&process.platform==="win32",dd=t=>typeof t=="object"&&t!==null,ud=new Uint32Array(256).map((t,e)=>{for(let n=0;n<8;n++)(e&1)!==0?e=3988292384^e>>>1:e>>>=1;return e>>>0});function X(t){this.sep=re.sep,this.fs=Cm,dd(t)&&dd(t.fs)&&typeof t.fs.statSync=="function"&&(this.fs=t.fs)}fd.exports=X;X.prototype.makeDir=function(t){let e=this;function n(r){let i=r.split(e.sep)[0];r.split(e.sep).forEach(function(s){if(!(!s||s.substr(-1,1)===":")){i+=e.sep+s;var o;try{o=e.fs.statSync(i)}catch(a){if(a.message&&a.message.startsWith("ENOENT"))e.fs.mkdirSync(i);else throw a}if(o&&o.isFile())throw Dm.FILE_IN_THE_WAY(`"${i}"`)}})}n(t)};X.prototype.writeFileTo=function(t,e,n,r){let i=this;if(i.fs.existsSync(t)){if(!n)return!1;var s=i.fs.statSync(t);if(s.isDirectory())return!1}var o=re.dirname(t);i.fs.existsSync(o)||i.makeDir(o);var a;try{a=i.fs.openSync(t,"w",438)}catch{i.fs.chmodSync(t,438),a=i.fs.openSync(t,"w",438)}if(a)try{i.fs.writeSync(a,e,0,e.length,0)}finally{i.fs.closeSync(a)}return i.fs.chmodSync(t,r||438),!0};X.prototype.writeFileToAsync=function(t,e,n,r,i){typeof r=="function"&&(i=r,r=void 0);let s=this;s.fs.exists(t,function(o){if(o&&!n)return i(!1);s.fs.stat(t,function(a,c){if(o&&c.isDirectory())return i(!1);var l=re.dirname(t);s.fs.exists(l,function(d){d||s.makeDir(l),s.fs.open(t,"w",438,function(p,m){p?s.fs.chmod(t,438,function(){s.fs.open(t,"w",438,function(u,h){s.fs.write(h,e,0,e.length,0,function(){s.fs.close(h,function(){s.fs.chmod(t,r||438,function(){i(!0)})})})})}):m?s.fs.write(m,e,0,e.length,0,function(){s.fs.close(m,function(){s.fs.chmod(t,r||438,function(){i(!0)})})}):s.fs.chmod(t,r||438,function(){i(!0)})})})})})};X.prototype.findFiles=function(t){let e=this;function n(r,i,s){typeof i=="boolean"&&(s=i,i=void 0);let o=[];return e.fs.readdirSync(r).forEach(function(a){let c=re.join(r,a),l=e.fs.statSync(c);(!i||i.test(c))&&o.push(re.normalize(c)+(l.isDirectory()?e.sep:"")),l.isDirectory()&&s&&(o=o.concat(n(c,i,s)))}),o}return n(t,void 0,!0)};X.prototype.findFilesAsync=function(t,e){let n=this,r=[];n.fs.readdir(t,function(i,s){if(i)return e(i);let o=s.length;if(!o)return e(null,r);s.forEach(function(a){a=re.join(t,a),n.fs.stat(a,function(c,l){if(c)return e(c);l&&(r.push(re.normalize(a)+(l.isDirectory()?n.sep:"")),l.isDirectory()?n.findFilesAsync(a,function(d,p){if(d)return e(d);r=r.concat(p),--o||e(null,r)}):--o||e(null,r))})})})};X.prototype.getAttributes=function(){};X.prototype.setAttributes=function(){};X.crc32update=function(t,e){return ud[(t^e)&255]^t>>>8};X.crc32=function(t){typeof t=="string"&&(t=Buffer.from(t,"utf8"));let e=t.length,n=-1;for(let r=0;r<e;)n=X.crc32update(n,t[r++]);return~n>>>0};X.methodToString=function(t){switch(t){case ld.STORED:return"STORED ("+t+")";case ld.DEFLATED:return"DEFLATED ("+t+")";default:return"UNSUPPORTED ("+t+")"}};X.canonical=function(t){if(!t)return"";let e=re.posix.normalize("/"+t.split("\\").join("/"));return re.join(".",e)};X.zipnamefix=function(t){if(!t)return"";let e=re.posix.normalize("/"+t.split("\\").join("/"));return re.posix.join(".",e)};X.findLast=function(t,e){if(!Array.isArray(t))throw new TypeError("arr is not array");let n=t.length>>>0;for(let r=n-1;r>=0;r--)if(e(t[r],r,t))return t[r]};X.sanitize=function(t,e){t=re.resolve(re.normalize(t));for(var n=e.split("/"),r=0,i=n.length;r<i;r++){var s=re.normalize(re.join(t,n.slice(r,i).join(re.sep)));if(s.indexOf(t)===0)return s}return re.normalize(re.join(t,re.basename(e)))};X.toBuffer=function(e,n){return Buffer.isBuffer(e)?e:e instanceof Uint8Array?Buffer.from(e):typeof e=="string"?n(e):Buffer.alloc(0)};X.readBigUInt64LE=function(t,e){let n=t.readUInt32LE(e);return t.readUInt32LE(e+4)*4294967296+n};X.fromDOS2Date=function(t){return new Date((t>>25&127)+1980,Math.max((t>>21&15)-1,0),Math.max(t>>16&31,1),t>>11&31,t>>5&63,(t&31)<<1)};X.fromDate2DOS=function(t){let e=0,n=0;return t.getFullYear()>1979&&(e=(t.getFullYear()-1980&127)<<9|t.getMonth()+1<<5|t.getDate(),n=t.getHours()<<11|t.getMinutes()<<5|t.getSeconds()>>1),e<<16|n};X.isWin=Nm;X.crcTable=ud});var gd=H((DR,pd)=>{var Lm=j("path");pd.exports=function(t,{fs:e}){var n=t||"",r=s(),i=null;function s(){return{directory:!1,readonly:!1,hidden:!1,executable:!1,mtime:0,atime:0}}return n&&e.existsSync(n)?(i=e.statSync(n),r.directory=i.isDirectory(),r.mtime=i.mtime,r.atime=i.atime,r.executable=(73&i.mode)!==0,r.readonly=(128&i.mode)===0,r.hidden=Lm.basename(n)[0]==="."):console.warn("Invalid path: "+n),{get directory(){return r.directory},get readOnly(){return r.readonly},get hidden(){return r.hidden},get mtime(){return r.mtime},get atime(){return r.atime},get executable(){return r.executable},decodeAttributes:function(){},encodeAttributes:function(){},toJSON:function(){return{path:n,isDirectory:r.directory,isReadOnly:r.readonly,isHidden:r.hidden,isExecutable:r.executable,mTime:r.mtime,aTime:r.atime}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var wd=H((NR,md)=>{md.exports={efs:!0,encode:t=>Buffer.from(t,"utf8"),decode:t=>t.toString("utf8")}});var Mn=H((LR,Fn)=>{Fn.exports=hd();Fn.exports.Constants=Zo();Fn.exports.Errors=Xi();Fn.exports.FileAttr=gd();Fn.exports.decoder=wd()});var _d=H((FR,yd)=>{var xt=Mn(),k=xt.Constants;yd.exports=function(){var t=20,e=10,n=0,r=0,i=0,s=0,o=0,a=0,c=0,l=0,d=0,p=0,m=0,u=0,h=0;t|=xt.isWin?2560:768,n|=k.FLG_EFS;let g={extraLen:0},w=f=>Math.max(0,f)>>>0,S=f=>Math.max(0,f)&65535,v=f=>Math.max(0,f)&255;return i=xt.fromDate2DOS(new Date),{get made(){return t},set made(f){t=f},get version(){return e},set version(f){e=f},get flags(){return n},set flags(f){n=f},get flags_efs(){return(n&k.FLG_EFS)>0},set flags_efs(f){f?n|=k.FLG_EFS:n&=~k.FLG_EFS},get flags_desc(){return(n&k.FLG_DESC)>0},set flags_desc(f){f?n|=k.FLG_DESC:n&=~k.FLG_DESC},get method(){return r},set method(f){switch(f){case k.STORED:this.version=10;case k.DEFLATED:default:this.version=20}r=f},get time(){return xt.fromDOS2Date(this.timeval)},set time(f){f=new Date(f),this.timeval=xt.fromDate2DOS(f)},get timeval(){return i},set timeval(f){i=w(f)},get timeHighByte(){return v(i>>>8)},get crc(){return s},set crc(f){s=w(f)},get compressedSize(){return o},set compressedSize(f){o=w(f)},get size(){return a},set size(f){a=w(f)},get fileNameLength(){return c},set fileNameLength(f){c=f},get extraLength(){return l},set extraLength(f){l=f},get extraLocalLength(){return g.extraLen},set extraLocalLength(f){g.extraLen=f},get commentLength(){return d},set commentLength(f){d=f},get diskNumStart(){return p},set diskNumStart(f){p=w(f)},get inAttr(){return m},set inAttr(f){m=w(f)},get attr(){return u},set attr(f){u=w(f)},get fileAttr(){return(u||0)>>16&4095},get offset(){return h},set offset(f){h=w(f)},get encrypted(){return(n&k.FLG_ENC)===k.FLG_ENC},get centralHeaderSize(){return k.CENHDR+c+l+d},get realDataOffset(){return h+k.LOCHDR+g.fnameLen+g.extraLen},get localHeader(){return g},loadLocalHeaderFromBinary:function(f){var y=f.slice(h,h+k.LOCHDR);if(y.readUInt32LE(0)!==k.LOCSIG)throw xt.Errors.INVALID_LOC();g.version=y.readUInt16LE(k.LOCVER),g.flags=y.readUInt16LE(k.LOCFLG),g.flags_desc=(g.flags&k.FLG_DESC)>0,g.method=y.readUInt16LE(k.LOCHOW),g.time=y.readUInt32LE(k.LOCTIM),g.crc=y.readUInt32LE(k.LOCCRC),g.compressedSize=y.readUInt32LE(k.LOCSIZ),g.size=y.readUInt32LE(k.LOCLEN),g.fnameLen=y.readUInt16LE(k.LOCNAM),g.extraLen=y.readUInt16LE(k.LOCEXT);let E=h+k.LOCHDR+g.fnameLen,T=E+g.extraLen;return f.slice(E,T)},loadFromBinary:function(f){if(f.length!==k.CENHDR||f.readUInt32LE(0)!==k.CENSIG)throw xt.Errors.INVALID_CEN();t=f.readUInt16LE(k.CENVEM),e=f.readUInt16LE(k.CENVER),n=f.readUInt16LE(k.CENFLG),r=f.readUInt16LE(k.CENHOW),i=f.readUInt32LE(k.CENTIM),s=f.readUInt32LE(k.CENCRC),o=f.readUInt32LE(k.CENSIZ),a=f.readUInt32LE(k.CENLEN),c=f.readUInt16LE(k.CENNAM),l=f.readUInt16LE(k.CENEXT),d=f.readUInt16LE(k.CENCOM),p=f.readUInt16LE(k.CENDSK),m=f.readUInt16LE(k.CENATT),u=f.readUInt32LE(k.CENATX),h=f.readUInt32LE(k.CENOFF)},localHeaderToBinary:function(){var f=Buffer.alloc(k.LOCHDR);return f.writeUInt32LE(k.LOCSIG,0),f.writeUInt16LE(e,k.LOCVER),f.writeUInt16LE(n,k.LOCFLG),f.writeUInt16LE(r,k.LOCHOW),f.writeUInt32LE(i,k.LOCTIM),f.writeUInt32LE(s,k.LOCCRC),f.writeUInt32LE(o,k.LOCSIZ),f.writeUInt32LE(a,k.LOCLEN),f.writeUInt16LE(c,k.LOCNAM),f.writeUInt16LE(g.extraLen,k.LOCEXT),f},centralHeaderToBinary:function(){var f=Buffer.alloc(k.CENHDR+c+l+d);return f.writeUInt32LE(k.CENSIG,0),f.writeUInt16LE(t,k.CENVEM),f.writeUInt16LE(e,k.CENVER),f.writeUInt16LE(n,k.CENFLG),f.writeUInt16LE(r,k.CENHOW),f.writeUInt32LE(i,k.CENTIM),f.writeUInt32LE(s,k.CENCRC),f.writeUInt32LE(o,k.CENSIZ),f.writeUInt32LE(a,k.CENLEN),f.writeUInt16LE(c,k.CENNAM),f.writeUInt16LE(l,k.CENEXT),f.writeUInt16LE(d,k.CENCOM),f.writeUInt16LE(p,k.CENDSK),f.writeUInt16LE(m,k.CENATT),f.writeUInt32LE(u,k.CENATX),f.writeUInt32LE(h,k.CENOFF),f},toJSON:function(){let f=function(y){return y+" bytes"};return{made:t,version:e,flags:n,method:xt.methodToString(r),time:this.time,crc:"0x"+s.toString(16).toUpperCase(),compressedSize:f(o),size:f(a),fileNameLength:f(c),extraLength:f(l),commentLength:f(d),diskNumStart:p,inAttr:m,attr:u,offset:h,centralHeaderSize:f(k.CENHDR+c+l+d)}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Sd=H((MR,Ed)=>{var Bn=Mn(),V=Bn.Constants;Ed.exports=function(){var t=0,e=0,n=0,r=0,i=0;return{get diskEntries(){return t},set diskEntries(s){t=e=s},get totalEntries(){return e},set totalEntries(s){e=t=s},get size(){return n},set size(s){n=s},get offset(){return r},set offset(s){r=s},get commentLength(){return i},set commentLength(s){i=s},get mainHeaderSize(){return V.ENDHDR+i},loadFromBinary:function(s){if((s.length!==V.ENDHDR||s.readUInt32LE(0)!==V.ENDSIG)&&(s.length<V.ZIP64HDR||s.readUInt32LE(0)!==V.ZIP64SIG))throw Bn.Errors.INVALID_END();s.readUInt32LE(0)===V.ENDSIG?(t=s.readUInt16LE(V.ENDSUB),e=s.readUInt16LE(V.ENDTOT),n=s.readUInt32LE(V.ENDSIZ),r=s.readUInt32LE(V.ENDOFF),i=s.readUInt16LE(V.ENDCOM)):(t=Bn.readBigUInt64LE(s,V.ZIP64SUB),e=Bn.readBigUInt64LE(s,V.ZIP64TOT),n=Bn.readBigUInt64LE(s,V.ZIP64SIZE),r=Bn.readBigUInt64LE(s,V.ZIP64OFF),i=0)},toBinary:function(){var s=Buffer.alloc(V.ENDHDR+i);return s.writeUInt32LE(V.ENDSIG,0),s.writeUInt32LE(0,4),s.writeUInt16LE(t,V.ENDSUB),s.writeUInt16LE(e,V.ENDTOT),s.writeUInt32LE(n,V.ENDSIZ),s.writeUInt32LE(r,V.ENDOFF),s.writeUInt16LE(i,V.ENDCOM),s.fill(" ",V.ENDHDR),s},toJSON:function(){let s=function(o,a){let c=o.toString(16).toUpperCase();for(;c.length<a;)c="0"+c;return"0x"+c};return{diskEntries:t,totalEntries:e,size:n+" bytes",offset:s(r,4),commentLength:i}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Xo=H(Ko=>{Ko.EntryHeader=_d();Ko.MainHeader=Sd()});var Id=H((UR,vd)=>{vd.exports=function(t){var e=j("zlib"),n={chunkSize:(parseInt(t.length/1024)+1)*1024};return{deflate:function(){return e.deflateRawSync(t,n)},deflateAsync:function(r){var i=e.createDeflateRaw(n),s=[],o=0;i.on("data",function(a){s.push(a),o+=a.length}),i.on("end",function(){var a=Buffer.alloc(o),c=0;a.fill(0);for(var l=0;l<s.length;l++){var d=s[l];d.copy(a,c),c+=d.length}r&&r(a)}),i.end(t)}}}});var Rd=H((zR,Td)=>{var Fm=+(process.versions?process.versions.node:"").split(".")[0]||0;Td.exports=function(t,e){var n=j("zlib");let r=Fm>=15&&e>0?{maxOutputLength:e}:{};return{inflate:function(){return n.inflateRawSync(t,r)},inflateAsync:function(i){var s=n.createInflateRaw(r),o=[],a=0;s.on("data",function(c){o.push(c),a+=c.length}),s.on("end",function(){var c=Buffer.alloc(a),l=0;c.fill(0);for(var d=0;d<o.length;d++){var p=o[d];p.copy(c,l),l+=p.length}i&&i(c)}),s.end(t)}}}});var Od=H(($R,xd)=>{"use strict";var{randomFillSync:kd}=j("crypto"),Mm=Xi(),Bm=new Uint32Array(256).map((t,e)=>{for(let n=0;n<8;n++)(e&1)!==0?e=e>>>1^3988292384:e>>>=1;return e>>>0}),Ad=(t,e)=>Math.imul(t,e)>>>0,bd=(t,e)=>Bm[(t^e)&255]^t>>>8,Or=()=>typeof kd=="function"?kd(Buffer.alloc(12)):Or.node();Or.node=()=>{let t=Buffer.alloc(12),e=t.length;for(let n=0;n<e;n++)t[n]=Math.random()*256&255;return t};var Yi={genSalt:Or};function Qi(t){let e=Buffer.isBuffer(t)?t:Buffer.from(t);this.keys=new Uint32Array([305419896,591751049,878082192]);for(let n=0;n<e.length;n++)this.updateKeys(e[n])}Qi.prototype.updateKeys=function(t){let e=this.keys;return e[0]=bd(e[0],t),e[1]+=e[0]&255,e[1]=Ad(e[1],134775813)+1,e[2]=bd(e[2],e[1]>>>24),t};Qi.prototype.next=function(){let t=(this.keys[2]|2)>>>0;return Ad(t,t^1)>>8&255};function Um(t){let e=new Qi(t);return function(n){let r=Buffer.alloc(n.length),i=0;for(let s of n)r[i++]=e.updateKeys(s^e.next());return r}}function zm(t){let e=new Qi(t);return function(n,r,i=0){r||(r=Buffer.alloc(n.length));for(let s of n){let o=e.next();r[i++]=s^o,e.updateKeys(s)}return r}}function $m(t,e,n){if(!t||!Buffer.isBuffer(t)||t.length<12)return Buffer.alloc(0);let r=Um(n),i=r(t.slice(0,12)),s=(e.flags&8)===8?e.timeHighByte:e.crc>>>24;if(i[11]!==s)throw Mm.WRONG_PASSWORD();return r(t.slice(12))}function Gm(t){Buffer.isBuffer(t)&&t.length>=12?Yi.genSalt=function(){return t.slice(0,12)}:t==="node"?Yi.genSalt=Or.node:Yi.genSalt=Or}function Hm(t,e,n,r=!1){t==null&&(t=Buffer.alloc(0)),Buffer.isBuffer(t)||(t=Buffer.from(t.toString()));let i=zm(n),s=Yi.genSalt();s[11]=e.crc>>>24&255,r&&(s[10]=e.crc>>>16&255);let o=Buffer.alloc(t.length+12);return i(s,o),i(t,o,12)}xd.exports={decrypt:$m,encrypt:Hm,_salter:Gm}});var Pd=H(es=>{es.Deflater=Id();es.Inflater=Rd();es.ZipCrypto=Od()});var Qo=H((HR,Cd)=>{var z=Mn(),jm=Xo(),Y=z.Constants,Yo=Pd();Cd.exports=function(t,e){var n=new jm.EntryHeader,r=Buffer.alloc(0),i=Buffer.alloc(0),s=!1,o=null,a=Buffer.alloc(0),c=Buffer.alloc(0),l=!0;let d=t,p=typeof d.decoder=="object"?d.decoder:z.decoder;l=p.hasOwnProperty("efs")?p.efs:!1;function m(){return!e||!(e instanceof Uint8Array)?Buffer.alloc(0):(c=n.loadLocalHeaderFromBinary(e),e.slice(n.realDataOffset,n.realDataOffset+n.compressedSize))}function u(f){if(!n.flags_desc&&!n.localHeader.flags_desc){if(z.crc32(f)!==n.localHeader.crc)return!1}else{let y={},E=n.realDataOffset+n.compressedSize;if(e.readUInt32LE(E)==Y.LOCSIG||e.readUInt32LE(E)==Y.CENSIG)throw z.Errors.DESCRIPTOR_NOT_EXIST();if(e.readUInt32LE(E)==Y.EXTSIG)y.crc=e.readUInt32LE(E+Y.EXTCRC),y.compressedSize=e.readUInt32LE(E+Y.EXTSIZ),y.size=e.readUInt32LE(E+Y.EXTLEN);else if(e.readUInt16LE(E+12)===19280)y.crc=e.readUInt32LE(E+Y.EXTCRC-4),y.compressedSize=e.readUInt32LE(E+Y.EXTSIZ-4),y.size=e.readUInt32LE(E+Y.EXTLEN-4);else throw z.Errors.DESCRIPTOR_UNKNOWN();if(y.compressedSize!==n.compressedSize||y.size!==n.size||y.crc!==n.crc)throw z.Errors.DESCRIPTOR_FAULTY();if(z.crc32(f)!==y.crc)return!1}return!0}function h(f,y,E){if(typeof y>"u"&&typeof f=="string"&&(E=f,f=void 0),s)return f&&y&&y(Buffer.alloc(0),z.Errors.DIRECTORY_CONTENT_ERROR()),Buffer.alloc(0);var T=m();if(T.length===0)return f&&y&&y(T),T;if(n.encrypted){if(typeof E!="string"&&!Buffer.isBuffer(E))throw z.Errors.INVALID_PASS_PARAM();T=Yo.ZipCrypto.decrypt(T,n,E)}var R=Buffer.alloc(n.size);switch(n.method){case z.Constants.STORED:if(T.copy(R),u(R))return f&&y&&y(R),R;throw f&&y&&y(R,z.Errors.BAD_CRC()),z.Errors.BAD_CRC();case z.Constants.DEFLATED:var D=new Yo.Inflater(T,n.size);if(f)D.inflateAsync(function(C){C.copy(C,0),y&&(u(C)?y(C):y(C,z.Errors.BAD_CRC()))});else{if(D.inflate(R).copy(R,0),!u(R))throw z.Errors.BAD_CRC(`"${p.decode(r)}"`);return R}break;default:throw f&&y&&y(Buffer.alloc(0),z.Errors.UNKNOWN_METHOD()),z.Errors.UNKNOWN_METHOD()}}function g(f,y){if((!o||!o.length)&&Buffer.isBuffer(e))return f&&y&&y(m()),m();if(o.length&&!s){var E;switch(n.method){case z.Constants.STORED:return n.compressedSize=n.size,E=Buffer.alloc(o.length),o.copy(E),f&&y&&y(E),E;default:case z.Constants.DEFLATED:var T=new Yo.Deflater(o);if(f)T.deflateAsync(function(D){E=Buffer.alloc(D.length),n.compressedSize=D.length,D.copy(E),y&&y(E)});else{var R=T.deflate();return n.compressedSize=R.length,R}T=null;break}}else if(f&&y)y(Buffer.alloc(0));else return Buffer.alloc(0)}function w(f,y){return z.readBigUInt64LE(f,y)}function S(f){try{for(var y=0,E,T,R;y+4<f.length;)E=f.readUInt16LE(y),y+=2,T=f.readUInt16LE(y),y+=2,R=f.slice(y,y+T),y+=T,Y.ID_ZIP64===E&&v(R)}catch{throw z.Errors.EXTRA_FIELD_PARSE_ERROR()}}function v(f){var y,E,T,R;f.length>=Y.EF_ZIP64_SCOMP&&(y=w(f,Y.EF_ZIP64_SUNCOMP),n.size===Y.EF_ZIP64_OR_32&&(n.size=y)),f.length>=Y.EF_ZIP64_RHO&&(E=w(f,Y.EF_ZIP64_SCOMP),n.compressedSize===Y.EF_ZIP64_OR_32&&(n.compressedSize=E)),f.length>=Y.EF_ZIP64_DSN&&(T=w(f,Y.EF_ZIP64_RHO),n.offset===Y.EF_ZIP64_OR_32&&(n.offset=T)),f.length>=Y.EF_ZIP64_DSN+4&&(R=f.readUInt32LE(Y.EF_ZIP64_DSN),n.diskNumStart===Y.EF_ZIP64_OR_16&&(n.diskNumStart=R))}return{get entryName(){return p.decode(r)},get rawEntryName(){return r},set entryName(f){r=z.toBuffer(f,p.encode);var y=r[r.length-1];s=y===47||y===92,n.fileNameLength=r.length},get efs(){return typeof l=="function"?l(this.entryName):l},get extra(){return a},set extra(f){a=f,n.extraLength=f.length,S(f)},get comment(){return p.decode(i)},set comment(f){if(i=z.toBuffer(f,p.encode),n.commentLength=i.length,i.length>65535)throw z.Errors.COMMENT_TOO_LONG()},get name(){var f=p.decode(r);return s?f.substr(f.length-1).split("/").pop():f.split("/").pop()},get isDirectory(){return s},getCompressedData:function(){return g(!1,null)},getCompressedDataAsync:function(f){g(!0,f)},setData:function(f){o=z.toBuffer(f,z.decoder.encode),!s&&o.length?(n.size=o.length,n.method=z.Constants.DEFLATED,n.crc=z.crc32(f),n.changed=!0):n.method=z.Constants.STORED},getData:function(f){return n.changed?o:h(!1,null,f)},getDataAsync:function(f,y){n.changed?f(o):h(!0,f,y)},set attr(f){n.attr=f},get attr(){return n.attr},set header(f){n.loadFromBinary(f)},get header(){return n},packCentralHeader:function(){n.flags_efs=this.efs,n.extraLength=a.length;var f=n.centralHeaderToBinary(),y=z.Constants.CENHDR;return r.copy(f,y),y+=r.length,a.copy(f,y),y+=n.extraLength,i.copy(f,y),f},packLocalHeader:function(){let f=0;n.flags_efs=this.efs,n.extraLocalLength=c.length;let y=n.localHeaderToBinary(),E=Buffer.alloc(y.length+r.length+n.extraLocalLength);return y.copy(E,f),f+=y.length,r.copy(E,f),f+=r.length,c.copy(E,f),f+=c.length,E},toJSON:function(){let f=function(y){return"<"+(y&&y.length+" bytes buffer"||"null")+">"};return{entryName:this.entryName,name:this.name,comment:this.comment,isDirectory:this.isDirectory,header:n.toJSON(),compressedData:f(e),data:f(o)}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Ld=H((jR,Nd)=>{var Dd=Qo(),Wm=Xo(),we=Mn();Nd.exports=function(t,e){var n=[],r={},i=Buffer.alloc(0),s=new Wm.MainHeader,o=!1,a=null;let c=new Set,l=e,{noSort:d,decoder:p}=l;t?h(l.readEntries):o=!0;function m(){let w=new Set;for(let S of Object.keys(r)){let v=S.split("/");if(v.pop(),!!v.length)for(let f=0;f<v.length;f++){let y=v.slice(0,f+1).join("/")+"/";w.add(y)}}for(let S of w)if(!(S in r)){let v=new Dd(l);v.entryName=S,v.attr=16,v.temporary=!0,n.push(v),r[v.entryName]=v,c.add(v)}}function u(){if(o=!0,r={},s.diskEntries>(t.length-s.offset)/we.Constants.CENHDR)throw we.Errors.DISK_ENTRY_TOO_LARGE();n=new Array(s.diskEntries);for(var w=s.offset,S=0;S<n.length;S++){var v=w,f=new Dd(l,t);f.header=t.slice(v,v+=we.Constants.CENHDR),f.entryName=t.slice(v,v+=f.header.fileNameLength),f.header.extraLength&&(f.extra=t.slice(v,v+=f.header.extraLength)),f.header.commentLength&&(f.comment=t.slice(v,v+f.header.commentLength)),w+=f.header.centralHeaderSize,n[S]=f,r[f.entryName]=f}c.clear(),m()}function h(w){var S=t.length-we.Constants.ENDHDR,v=Math.max(0,S-65535),f=v,y=t.length,E=-1,T=0;for(typeof l.trailingSpace=="boolean"&&l.trailingSpace&&(v=0),S;S>=f;S--)if(t[S]===80){if(t.readUInt32LE(S)===we.Constants.ENDSIG){E=S,T=S,y=S+we.Constants.ENDHDR,f=S-we.Constants.END64HDR;continue}if(t.readUInt32LE(S)===we.Constants.END64SIG){f=v;continue}if(t.readUInt32LE(S)===we.Constants.ZIP64SIG){E=S,y=S+we.readBigUInt64LE(t,S+we.Constants.ZIP64SIZE)+we.Constants.ZIP64LEAD;break}}if(E==-1)throw we.Errors.INVALID_FORMAT();s.loadFromBinary(t.slice(E,y)),s.commentLength&&(i=t.slice(T+we.Constants.ENDHDR)),w&&u()}function g(){n.length>1&&!d&&n.sort((w,S)=>w.entryName.toLowerCase().localeCompare(S.entryName.toLowerCase()))}return{get entries(){return o||u(),n.filter(w=>!c.has(w))},get comment(){return p.decode(i)},set comment(w){i=we.toBuffer(w,p.encode),s.commentLength=i.length},getEntryCount:function(){return o?n.length:s.diskEntries},forEach:function(w){this.entries.forEach(w)},getEntry:function(w){return o||u(),r[w]||null},setEntry:function(w){o||u(),n.push(w),r[w.entryName]=w,s.totalEntries=n.length},deleteFile:function(w,S=!0){o||u();let v=r[w];this.getEntryChildren(v,S).map(y=>y.entryName).forEach(this.deleteEntry)},deleteEntry:function(w){o||u();let S=r[w],v=n.indexOf(S);v>=0&&(n.splice(v,1),delete r[w],s.totalEntries=n.length)},getEntryChildren:function(w,S=!0){if(o||u(),typeof w=="object")if(w.isDirectory&&S){let v=[],f=w.entryName;for(let y of n)y.entryName.startsWith(f)&&v.push(y);return v}else return[w];return[]},getChildCount:function(w){if(w&&w.isDirectory){let S=this.getEntryChildren(w);return S.includes(w)?S.length-1:S.length}return 0},compressToBuffer:function(){o||u(),g();let w=[],S=[],v=0,f=0;s.size=0,s.offset=0;let y=0;for(let R of this.entries){let D=R.getCompressedData();R.header.offset=f;let C=R.packLocalHeader(),G=C.length+D.length;f+=G,w.push(C),w.push(D);let M=R.packCentralHeader();S.push(M),s.size+=M.length,v+=G+M.length,y++}v+=s.mainHeaderSize,s.offset=f,s.totalEntries=y,f=0;let E=Buffer.alloc(v);for(let R of w)R.copy(E,f),f+=R.length;for(let R of S)R.copy(E,f),f+=R.length;let T=s.toBinary();return i&&i.copy(T,we.Constants.ENDHDR),T.copy(E,f),t=E,o=!1,E},toAsyncBuffer:function(w,S,v,f){try{o||u(),g();let y=[],E=[],T=0,R=0,D=0;s.size=0,s.offset=0;let C=function(G){if(G.length>0){let M=G.shift(),oe=M.entryName+M.extra.toString();v&&v(oe),M.getCompressedDataAsync(function(Ee){f&&f(oe),M.header.offset=R;let I=M.packLocalHeader(),x=I.length+Ee.length;R+=x,y.push(I),y.push(Ee);let O=M.packCentralHeader();E.push(O),s.size+=O.length,T+=x+O.length,D++,C(G)})}else{T+=s.mainHeaderSize,s.offset=R,s.totalEntries=D,R=0;let M=Buffer.alloc(T);y.forEach(function(Ee){Ee.copy(M,R),R+=Ee.length}),E.forEach(function(Ee){Ee.copy(M,R),R+=Ee.length});let oe=s.toBinary();i&&i.copy(oe,we.Constants.ENDHDR),oe.copy(M,R),t=M,o=!1,w(M)}};C(Array.from(this.entries))}catch(y){S(y)}}}}});var Bd=H((WR,Md)=>{var Z=Mn(),J=j("path"),qm=Qo(),Vm=Ld(),nn=(...t)=>Z.findLast(t,e=>typeof e=="boolean"),Fd=(...t)=>Z.findLast(t,e=>typeof e=="string"),Jm=(...t)=>Z.findLast(t,e=>typeof e=="function"),Zm={noSort:!1,readEntries:!1,method:Z.Constants.NONE,fs:null};Md.exports=function(t,e){let n=null,r=Object.assign(Object.create(null),Zm);t&&typeof t=="object"&&(t instanceof Uint8Array||(Object.assign(r,t),t=r.input?r.input:void 0,r.input&&delete r.input),Buffer.isBuffer(t)&&(n=t,r.method=Z.Constants.BUFFER,t=void 0)),Object.assign(r,e);let i=new Z(r);if((typeof r.decoder!="object"||typeof r.decoder.encode!="function"||typeof r.decoder.decode!="function")&&(r.decoder=Z.decoder),t&&typeof t=="string")if(i.fs.existsSync(t))r.method=Z.Constants.FILE,r.filename=t,n=i.fs.readFileSync(t);else throw Z.Errors.INVALID_FILENAME();let s=new Vm(n,r),{canonical:o,sanitize:a,zipnamefix:c}=Z;function l(u){if(u&&s){var h;if(typeof u=="string"&&(h=s.getEntry(J.posix.normalize(u))),typeof u=="object"&&typeof u.entryName<"u"&&typeof u.header<"u"&&(h=s.getEntry(u.entryName)),h)return h}return null}function d(u){let{join:h,normalize:g,sep:w}=J.posix;return h(J.isAbsolute(u)?"/":".",g(w+u.split("\\").join(w)+w))}function p(u){return u instanceof RegExp?(function(h){return function(g){return h.test(g)}})(u):typeof u!="function"?()=>!0:u}let m=(u,h)=>{let g=h.slice(-1);return g=g===i.sep?i.sep:"",J.relative(u,h)+g};return{readFile:function(u,h){var g=l(u);return g&&g.getData(h)||null},childCount:function(u){let h=l(u);if(h)return s.getChildCount(h)},readFileAsync:function(u,h){var g=l(u);g?g.getDataAsync(h):h(null,"getEntry failed for:"+u)},readAsText:function(u,h){var g=l(u);if(g){var w=g.getData();if(w&&w.length)return w.toString(h||"utf8")}return""},readAsTextAsync:function(u,h,g){var w=l(u);w?w.getDataAsync(function(S,v){if(v){h(S,v);return}S&&S.length?h(S.toString(g||"utf8")):h("")}):h("")},deleteFile:function(u,h=!0){var g=l(u);g&&s.deleteFile(g.entryName,h)},deleteEntry:function(u){var h=l(u);h&&s.deleteEntry(h.entryName)},addZipComment:function(u){s.comment=u},getZipComment:function(){return s.comment||""},addZipEntryComment:function(u,h){var g=l(u);g&&(g.comment=h)},getZipEntryComment:function(u){var h=l(u);return h&&h.comment||""},updateFile:function(u,h){var g=l(u);g&&g.setData(h)},addLocalFile:function(u,h,g,w){if(i.fs.existsSync(u)){h=h?d(h):"";let S=J.win32.basename(J.win32.normalize(u));h+=g||S;let v=i.fs.statSync(u),f=v.isFile()?i.fs.readFileSync(u):Buffer.alloc(0);v.isDirectory()&&(h+=i.sep),this.addFile(h,f,w,v)}else throw Z.Errors.FILE_NOT_FOUND(u)},addLocalFileAsync:function(u,h){u=typeof u=="object"?u:{localPath:u};let g=J.resolve(u.localPath),{comment:w}=u,{zipPath:S,zipName:v}=u,f=this;i.fs.stat(g,function(y,E){if(y)return h(y,!1);S=S?d(S):"";let T=J.win32.basename(J.win32.normalize(g));if(S+=v||T,E.isFile())i.fs.readFile(g,function(R,D){return R?h(R,!1):(f.addFile(S,D,w,E),setImmediate(h,void 0,!0))});else if(E.isDirectory())return S+=i.sep,f.addFile(S,Buffer.alloc(0),w,E),setImmediate(h,void 0,!0)})},addLocalFolder:function(u,h,g){if(g=p(g),h=h?d(h):"",u=J.normalize(u),i.fs.existsSync(u)){let w=i.findFiles(u),S=this;if(w.length)for(let v of w){let f=J.join(h,m(u,v));g(f)&&S.addLocalFile(v,J.dirname(f))}}else throw Z.Errors.FILE_NOT_FOUND(u)},addLocalFolderAsync:function(u,h,g,w){w=p(w),g=g?d(g):"",u=J.normalize(u);var S=this;i.fs.open(u,"r",function(v){if(v&&v.code==="ENOENT")h(void 0,Z.Errors.FILE_NOT_FOUND(u));else if(v)h(void 0,v);else{var f=i.findFiles(u),y=-1,E=function(){if(y+=1,y<f.length){var T=f[y],R=m(u,T).split("\\").join("/");R=R.normalize("NFD").replace(/[\u0300-\u036f]/g,"").replace(/[^\x20-\x7E]/g,""),w(R)?i.fs.stat(T,function(D,C){D&&h(void 0,D),C.isFile()?i.fs.readFile(T,function(G,M){G?h(void 0,G):(S.addFile(g+R,M,"",C),E())}):(S.addFile(g+R+"/",Buffer.alloc(0),"",C),E())}):process.nextTick(()=>{E()})}else h(!0,void 0)};E()}})},addLocalFolderAsync2:function(u,h){let g=this;u=typeof u=="object"?u:{localPath:u},localPath=J.resolve(d(u.localPath));let{zipPath:w,filter:S,namefix:v}=u;S instanceof RegExp?S=(function(E){return function(T){return E.test(T)}})(S):typeof S!="function"&&(S=function(){return!0}),w=w?d(w):"",v=="latin1"&&(v=E=>E.normalize("NFD").replace(/[\u0300-\u036f]/g,"").replace(/[^\x20-\x7E]/g,"")),typeof v!="function"&&(v=E=>E);let f=E=>J.join(w,v(m(localPath,E))),y=E=>J.win32.basename(J.win32.normalize(v(E)));i.fs.open(localPath,"r",function(E){E&&E.code==="ENOENT"?h(void 0,Z.Errors.FILE_NOT_FOUND(localPath)):E?h(void 0,E):i.findFilesAsync(localPath,function(T,R){if(T)return h(T);R=R.filter(D=>S(f(D))),R.length||h(void 0,!1),setImmediate(R.reverse().reduce(function(D,C){return function(G,M){if(G||M===!1)return setImmediate(D,G,!1);g.addLocalFileAsync({localPath:C,zipPath:J.dirname(f(C)),zipName:y(C)},D)}},h))})})},addLocalFolderPromise:function(u,h){return new Promise((g,w)=>{this.addLocalFolderAsync2(Object.assign({localPath:u},h),(S,v)=>{S&&w(S),v&&g(this)})})},addFile:function(u,h,g,w){u=c(u);let S=l(u),v=S!=null;v||(S=new qm(r),S.entryName=u),S.comment=g||"";let f=typeof w=="object"&&w instanceof i.fs.Stats;f&&(S.header.time=w.mtime);var y=S.isDirectory?16:0;let E=S.isDirectory?16384:32768;return f?E|=4095&w.mode:typeof w=="number"?E|=4095&w:E|=S.isDirectory?493:420,y=(y|E<<16)>>>0,S.attr=y,S.setData(h),v||s.setEntry(S),S},getEntries:function(u){return s.password=u,s?s.entries:[]},getEntry:function(u){return l(u)},getEntryCount:function(){return s.getEntryCount()},forEach:function(u){return s.forEach(u)},extractEntryTo:function(u,h,g,w,S,v){w=nn(!1,w),S=nn(!1,S),g=nn(!0,g),v=Fd(S,v);var f=l(u);if(!f)throw Z.Errors.NO_ENTRY();var y=o(f.entryName),E=a(h,v&&!f.isDirectory?v:g?y:J.basename(y));if(f.isDirectory){var T=s.getEntryChildren(f);return T.forEach(function(C){if(C.isDirectory)return;var G=C.getData();if(!G)throw Z.Errors.CANT_EXTRACT_FILE();var M=o(C.entryName),oe=a(h,g?M:J.basename(M));let Ee=S?C.header.fileAttr:void 0;i.writeFileTo(oe,G,w,Ee)}),!0}var R=f.getData(s.password);if(!R)throw Z.Errors.CANT_EXTRACT_FILE();if(i.fs.existsSync(E)&&!w)throw Z.Errors.CANT_OVERRIDE();let D=S?u.header.fileAttr:void 0;return i.writeFileTo(E,R,w,D),!0},test:function(u){if(!s)return!1;for(var h in s.entries)try{if(h.isDirectory)continue;var g=s.entries[h].getData(u);if(!g)return!1}catch{return!1}return!0},extractAllTo:function(u,h,g,w){if(g=nn(!1,g),w=Fd(g,w),h=nn(!1,h),!s)throw Z.Errors.NO_ZIP();s.entries.forEach(function(S){var v=a(u,o(S.entryName));if(S.isDirectory){i.makeDir(v);return}var f=S.getData(w);if(!f)throw Z.Errors.CANT_EXTRACT_FILE();let y=g?S.header.fileAttr:void 0;i.writeFileTo(v,f,h,y);try{i.fs.utimesSync(v,S.header.time,S.header.time)}catch{throw Z.Errors.CANT_EXTRACT_FILE()}})},extractAllToAsync:function(u,h,g,w){if(w=Jm(h,g,w),g=nn(!1,g),h=nn(!1,h),!w)return new Promise((E,T)=>{this.extractAllToAsync(u,h,g,function(R){R?T(R):E(this)})});if(!s){w(Z.Errors.NO_ZIP());return}u=J.resolve(u);let S=E=>a(u,J.normalize(o(E.entryName))),v=(E,T)=>new Error(E+': "'+T+'"'),f=[],y=[];s.entries.forEach(E=>{E.isDirectory?f.push(E):y.push(E)});for(let E of f){let T=S(E),R=g?E.header.fileAttr:void 0;try{i.makeDir(T),R&&i.fs.chmodSync(T,R),i.fs.utimesSync(T,E.header.time,E.header.time)}catch{w(v("Unable to create folder",T))}}y.reverse().reduce(function(E,T){return function(R){if(R)E(R);else{let D=J.normalize(o(T.entryName)),C=a(u,D);T.getDataAsync(function(G,M){if(M)E(M);else if(!G)E(Z.Errors.CANT_EXTRACT_FILE());else{let oe=g?T.header.fileAttr:void 0;i.writeFileToAsync(C,G,h,oe,function(Ee){Ee||E(v("Unable to write file",C)),i.fs.utimes(C,T.header.time,T.header.time,function(I){I?E(v("Unable to set times",C)):E()})})}})}}},w)()},writeZip:function(u,h){if(arguments.length===1&&typeof u=="function"&&(h=u,u=""),!u&&r.filename&&(u=r.filename),!!u){var g=s.compressToBuffer();if(g){var w=i.writeFileTo(u,g,!0);typeof h=="function"&&h(w?null:new Error("failed"),"")}}},writeZipPromise:function(u,h){let{overwrite:g,perm:w}=Object.assign({overwrite:!0},h);return new Promise((S,v)=>{!u&&r.filename&&(u=r.filename),u||v("ADM-ZIP: ZIP File Name Missing"),this.toBufferPromise().then(f=>{let y=E=>E?S(E):v("ADM-ZIP: Wasn't able to write zip file");i.writeFileToAsync(u,f,g,w,y)},v)})},toBufferPromise:function(){return new Promise((u,h)=>{s.toAsyncBuffer(u,h)})},toBuffer:function(u,h,g,w){return typeof u=="function"?(s.toAsyncBuffer(u,h,g,w),null):s.compressToBuffer()}}}});function wS(){return wh||(wh=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction])}function yS(){return yh||(yh=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])}function _S(t){let e=new Promise((n,r)=>{let i=()=>{t.removeEventListener("success",s),t.removeEventListener("error",o)},s=()=>{n(Ue(t.result)),i()},o=()=>{r(t.error),i()};t.addEventListener("success",s),t.addEventListener("error",o)});return e.then(n=>{n instanceof IDBCursor&&_h.set(n,t)}).catch(()=>{}),bc.set(e,t),e}function ES(t){if(Rc.has(t))return;let e=new Promise((n,r)=>{let i=()=>{t.removeEventListener("complete",s),t.removeEventListener("error",o),t.removeEventListener("abort",o)},s=()=>{n(),i()},o=()=>{r(t.error||new DOMException("AbortError","AbortError")),i()};t.addEventListener("complete",s),t.addEventListener("error",o),t.addEventListener("abort",o)});Rc.set(t,e)}function Sh(t){kc=t(kc)}function SS(t){return t===IDBDatabase.prototype.transaction&&!("objectStoreNames"in IDBTransaction.prototype)?function(e,...n){let r=t.call(gi(this),e,...n);return Eh.set(r,e.sort?e.sort():[e]),Ue(r)}:yS().includes(t)?function(...e){return t.apply(gi(this),e),Ue(_h.get(this))}:function(...e){return Ue(t.apply(gi(this),e))}}function vS(t){return typeof t=="function"?SS(t):(t instanceof IDBTransaction&&ES(t),mS(t,wS())?new Proxy(t,kc):t)}function Ue(t){if(t instanceof IDBRequest)return _S(t);if(Tc.has(t))return Tc.get(t);let e=vS(t);return e!==t&&(Tc.set(t,e),bc.set(e,t)),e}var mS,wh,yh,_h,Rc,Eh,Tc,bc,kc,gi,Ac=ve(()=>{mS=(t,e)=>e.some(n=>t instanceof n);_h=new WeakMap,Rc=new WeakMap,Eh=new WeakMap,Tc=new WeakMap,bc=new WeakMap;kc={get(t,e,n){if(t instanceof IDBTransaction){if(e==="done")return Rc.get(t);if(e==="objectStoreNames")return t.objectStoreNames||Eh.get(t);if(e==="store")return n.objectStoreNames[1]?void 0:n.objectStore(n.objectStoreNames[0])}return Ue(t[e])},set(t,e,n){return t[e]=n,!0},has(t,e){return t instanceof IDBTransaction&&(e==="done"||e==="store")?!0:e in t}};gi=t=>bc.get(t)});var Ih={};Ni(Ih,{deleteDB:()=>TS,openDB:()=>IS,unwrap:()=>gi,wrap:()=>Ue});function IS(t,e,{blocked:n,upgrade:r,blocking:i,terminated:s}={}){let o=indexedDB.open(t,e),a=Ue(o);return r&&o.addEventListener("upgradeneeded",c=>{r(Ue(o.result),c.oldVersion,c.newVersion,Ue(o.transaction))}),n&&o.addEventListener("blocked",()=>n()),a.then(c=>{s&&c.addEventListener("close",()=>s()),i&&c.addEventListener("versionchange",()=>i())}).catch(()=>{}),a}function TS(t,{blocked:e}={}){let n=indexedDB.deleteDatabase(t);return e&&n.addEventListener("blocked",()=>e()),Ue(n).then(()=>{})}function vh(t,e){if(!(t instanceof IDBDatabase&&!(e in t)&&typeof e=="string"))return;if(xc.get(e))return xc.get(e);let n=e.replace(/FromIndex$/,""),r=e!==n,i=kS.includes(n);if(!(n in(r?IDBIndex:IDBObjectStore).prototype)||!(i||RS.includes(n)))return;let s=async function(o,...a){let c=this.transaction(o,i?"readwrite":"readonly"),l=c.store;return r&&(l=l.index(a.shift())),(await Promise.all([l[n](...a),i&&c.done]))[0]};return xc.set(e,s),s}var RS,kS,xc,Th=ve(()=>{Ac();Ac();RS=["get","getKey","getAll","getAllKeys","count"],kS=["put","add","delete","clear"],xc=new Map;Sh(t=>({...t,get:(e,n,r)=>vh(e,n)||t.get(e,n,r),has:(e,n)=>!!vh(e,n)||t.has(e,n)}))});var It=H((TO,Kh)=>{"use strict";var Jh=["nodebuffer","arraybuffer","fragments"],Zh=typeof Blob<"u";Zh&&Jh.push("blob");Kh.exports={BINARY_TYPES:Jh,CLOSE_TIMEOUT:3e4,EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",hasBlob:Zh,kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP:()=>{}}});var Si=H((RO,ao)=>{"use strict";var{EMPTY_BUFFER:x0}=It(),Yc=Buffer[Symbol.species];function O0(t,e){if(t.length===0)return x0;if(t.length===1)return t[0];let n=Buffer.allocUnsafe(e),r=0;for(let i=0;i<t.length;i++){let s=t[i];n.set(s,r),r+=s.length}return r<e?new Yc(n.buffer,n.byteOffset,r):n}function Xh(t,e,n,r,i){for(let s=0;s<i;s++)n[r+s]=t[s]^e[s&3]}function Yh(t,e){for(let n=0;n<t.length;n++)t[n]^=e[n&3]}function P0(t){return t.length===t.buffer.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.length)}function Qc(t){if(Qc.readOnly=!0,Buffer.isBuffer(t))return t;let e;return t instanceof ArrayBuffer?e=new Yc(t):ArrayBuffer.isView(t)?e=new Yc(t.buffer,t.byteOffset,t.byteLength):(e=Buffer.from(t),Qc.readOnly=!1),e}ao.exports={concat:O0,mask:Xh,toArrayBuffer:P0,toBuffer:Qc,unmask:Yh};if(!process.env.WS_NO_BUFFER_UTIL)try{let t=j("bufferutil");ao.exports.mask=function(e,n,r,i,s){s<48?Xh(e,n,r,i,s):t.mask(e,n,r,i,s)},ao.exports.unmask=function(e,n){e.length<32?Yh(e,n):t.unmask(e,n)}}catch{}});var tp=H((kO,ep)=>{"use strict";var Qh=Symbol("kDone"),el=Symbol("kRun"),tl=class{constructor(e){this[Qh]=()=>{this.pending--,this[el]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[el]()}[el](){if(this.pending!==this.concurrency&&this.jobs.length){let e=this.jobs.shift();this.pending++,e(this[Qh])}}};ep.exports=tl});var fr=H((bO,sp)=>{"use strict";var vi=j("zlib"),np=Si(),C0=tp(),{kStatusCode:rp}=It(),D0=Buffer[Symbol.species],N0=Buffer.from([0,0,255,255]),lo=Symbol("permessage-deflate"),Tt=Symbol("total-length"),dr=Symbol("callback"),Zt=Symbol("buffers"),ur=Symbol("error"),co,nl=class{constructor(e){if(this._options=e||{},this._threshold=this._options.threshold!==void 0?this._options.threshold:1024,this._maxPayload=this._options.maxPayload|0,this._isServer=!!this._options.isServer,this._deflate=null,this._inflate=null,this.params=null,!co){let n=this._options.concurrencyLimit!==void 0?this._options.concurrencyLimit:10;co=new C0(n)}}static get extensionName(){return"permessage-deflate"}offer(){let e={};return this._options.serverNoContextTakeover&&(e.server_no_context_takeover=!0),this._options.clientNoContextTakeover&&(e.client_no_context_takeover=!0),this._options.serverMaxWindowBits&&(e.server_max_window_bits=this._options.serverMaxWindowBits),this._options.clientMaxWindowBits?e.client_max_window_bits=this._options.clientMaxWindowBits:this._options.clientMaxWindowBits==null&&(e.client_max_window_bits=!0),e}accept(e){return e=this.normalizeParams(e),this.params=this._isServer?this.acceptAsServer(e):this.acceptAsClient(e),this.params}cleanup(){if(this._inflate&&(this._inflate.close(),this._inflate=null),this._deflate){let e=this._deflate[dr];this._deflate.close(),this._deflate=null,e&&e(new Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){let n=this._options,r=e.find(i=>!(n.serverNoContextTakeover===!1&&i.server_no_context_takeover||i.server_max_window_bits&&(n.serverMaxWindowBits===!1||typeof n.serverMaxWindowBits=="number"&&n.serverMaxWindowBits>i.server_max_window_bits)||typeof n.clientMaxWindowBits=="number"&&!i.client_max_window_bits));if(!r)throw new Error("None of the extension offers can be accepted");return n.serverNoContextTakeover&&(r.server_no_context_takeover=!0),n.clientNoContextTakeover&&(r.client_no_context_takeover=!0),typeof n.serverMaxWindowBits=="number"&&(r.server_max_window_bits=n.serverMaxWindowBits),typeof n.clientMaxWindowBits=="number"?r.client_max_window_bits=n.clientMaxWindowBits:(r.client_max_window_bits===!0||n.clientMaxWindowBits===!1)&&delete r.client_max_window_bits,r}acceptAsClient(e){let n=e[0];if(this._options.clientNoContextTakeover===!1&&n.client_no_context_takeover)throw new Error('Unexpected parameter "client_no_context_takeover"');if(!n.client_max_window_bits)typeof this._options.clientMaxWindowBits=="number"&&(n.client_max_window_bits=this._options.clientMaxWindowBits);else if(this._options.clientMaxWindowBits===!1||typeof this._options.clientMaxWindowBits=="number"&&n.client_max_window_bits>this._options.clientMaxWindowBits)throw new Error('Unexpected or invalid parameter "client_max_window_bits"');return n}normalizeParams(e){return e.forEach(n=>{Object.keys(n).forEach(r=>{let i=n[r];if(i.length>1)throw new Error(`Parameter "${r}" must have only a single value`);if(i=i[0],r==="client_max_window_bits"){if(i!==!0){let s=+i;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${r}": ${i}`);i=s}else if(!this._isServer)throw new TypeError(`Invalid value for parameter "${r}": ${i}`)}else if(r==="server_max_window_bits"){let s=+i;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${r}": ${i}`);i=s}else if(r==="client_no_context_takeover"||r==="server_no_context_takeover"){if(i!==!0)throw new TypeError(`Invalid value for parameter "${r}": ${i}`)}else throw new Error(`Unknown parameter "${r}"`);n[r]=i})}),e}decompress(e,n,r){co.add(i=>{this._decompress(e,n,(s,o)=>{i(),r(s,o)})})}compress(e,n,r){co.add(i=>{this._compress(e,n,(s,o)=>{i(),r(s,o)})})}_decompress(e,n,r){let i=this._isServer?"client":"server";if(!this._inflate){let s=`${i}_max_window_bits`,o=typeof this.params[s]!="number"?vi.Z_DEFAULT_WINDOWBITS:this.params[s];this._inflate=vi.createInflateRaw({...this._options.zlibInflateOptions,windowBits:o}),this._inflate[lo]=this,this._inflate[Tt]=0,this._inflate[Zt]=[],this._inflate.on("error",F0),this._inflate.on("data",ip)}this._inflate[dr]=r,this._inflate.write(e),n&&this._inflate.write(N0),this._inflate.flush(()=>{let s=this._inflate[ur];if(s){this._inflate.close(),this._inflate=null,r(s);return}let o=np.concat(this._inflate[Zt],this._inflate[Tt]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[Tt]=0,this._inflate[Zt]=[],n&&this.params[`${i}_no_context_takeover`]&&this._inflate.reset()),r(null,o)})}_compress(e,n,r){let i=this._isServer?"server":"client";if(!this._deflate){let s=`${i}_max_window_bits`,o=typeof this.params[s]!="number"?vi.Z_DEFAULT_WINDOWBITS:this.params[s];this._deflate=vi.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:o}),this._deflate[Tt]=0,this._deflate[Zt]=[],this._deflate.on("data",L0)}this._deflate[dr]=r,this._deflate.write(e),this._deflate.flush(vi.Z_SYNC_FLUSH,()=>{if(!this._deflate)return;let s=np.concat(this._deflate[Zt],this._deflate[Tt]);n&&(s=new D0(s.buffer,s.byteOffset,s.length-4)),this._deflate[dr]=null,this._deflate[Tt]=0,this._deflate[Zt]=[],n&&this.params[`${i}_no_context_takeover`]&&this._deflate.reset(),r(null,s)})}};sp.exports=nl;function L0(t){this[Zt].push(t),this[Tt]+=t.length}function ip(t){if(this[Tt]+=t.length,this[lo]._maxPayload<1||this[Tt]<=this[lo]._maxPayload){this[Zt].push(t);return}this[ur]=new RangeError("Max payload size exceeded"),this[ur].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[ur][rp]=1009,this.removeListener("data",ip),this.reset()}function F0(t){if(this[lo]._inflate=null,this[ur]){this[dr](this[ur]);return}t[rp]=1007,this[dr](t)}});var hr=H((AO,uo)=>{"use strict";var{isUtf8:op}=j("buffer"),{hasBlob:M0}=It(),B0=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,0,0,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,0];function U0(t){return t>=1e3&&t<=1014&&t!==1004&&t!==1005&&t!==1006||t>=3e3&&t<=4999}function rl(t){let e=t.length,n=0;for(;n<e;)if((t[n]&128)===0)n++;else if((t[n]&224)===192){if(n+1===e||(t[n+1]&192)!==128||(t[n]&254)===192)return!1;n+=2}else if((t[n]&240)===224){if(n+2>=e||(t[n+1]&192)!==128||(t[n+2]&192)!==128||t[n]===224&&(t[n+1]&224)===128||t[n]===237&&(t[n+1]&224)===160)return!1;n+=3}else if((t[n]&248)===240){if(n+3>=e||(t[n+1]&192)!==128||(t[n+2]&192)!==128||(t[n+3]&192)!==128||t[n]===240&&(t[n+1]&240)===128||t[n]===244&&t[n+1]>143||t[n]>244)return!1;n+=4}else return!1;return!0}function z0(t){return M0&&typeof t=="object"&&typeof t.arrayBuffer=="function"&&typeof t.type=="string"&&typeof t.stream=="function"&&(t[Symbol.toStringTag]==="Blob"||t[Symbol.toStringTag]==="File")}uo.exports={isBlob:z0,isValidStatusCode:U0,isValidUTF8:rl,tokenChars:B0};if(op)uo.exports.isValidUTF8=function(t){return t.length<24?rl(t):op(t)};else if(!process.env.WS_NO_UTF_8_VALIDATE)try{let t=j("utf-8-validate");uo.exports.isValidUTF8=function(e){return e.length<32?rl(e):t(e)}}catch{}});var cl=H((xO,hp)=>{"use strict";var{Writable:$0}=j("stream"),ap=fr(),{BINARY_TYPES:G0,EMPTY_BUFFER:cp,kStatusCode:H0,kWebSocket:j0}=It(),{concat:il,toArrayBuffer:W0,unmask:q0}=Si(),{isValidStatusCode:V0,isValidUTF8:lp}=hr(),fo=Buffer[Symbol.species],$e=0,dp=1,up=2,fp=3,sl=4,ol=5,ho=6,al=class extends $0{constructor(e={}){super(),this._allowSynchronousEvents=e.allowSynchronousEvents!==void 0?e.allowSynchronousEvents:!0,this._binaryType=e.binaryType||G0[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=e.maxPayload|0,this._skipUTF8Validation=!!e.skipUTF8Validation,this[j0]=void 0,this._bufferedBytes=0,this._buffers=[],this._compressed=!1,this._payloadLength=0,this._mask=void 0,this._fragmented=0,this._masked=!1,this._fin=!1,this._opcode=0,this._totalPayloadLength=0,this._messageLength=0,this._fragments=[],this._errored=!1,this._loop=!1,this._state=$e}_write(e,n,r){if(this._opcode===8&&this._state==$e)return r();this._bufferedBytes+=e.length,this._buffers.push(e),this.startLoop(r)}consume(e){if(this._bufferedBytes-=e,e===this._buffers[0].length)return this._buffers.shift();if(e<this._buffers[0].length){let r=this._buffers[0];return this._buffers[0]=new fo(r.buffer,r.byteOffset+e,r.length-e),new fo(r.buffer,r.byteOffset,e)}let n=Buffer.allocUnsafe(e);do{let r=this._buffers[0],i=n.length-e;e>=r.length?n.set(this._buffers.shift(),i):(n.set(new Uint8Array(r.buffer,r.byteOffset,e),i),this._buffers[0]=new fo(r.buffer,r.byteOffset+e,r.length-e)),e-=r.length}while(e>0);return n}startLoop(e){this._loop=!0;do switch(this._state){case $e:this.getInfo(e);break;case dp:this.getPayloadLength16(e);break;case up:this.getPayloadLength64(e);break;case fp:this.getMask();break;case sl:this.getData(e);break;case ol:case ho:this._loop=!1;return}while(this._loop);this._errored||e()}getInfo(e){if(this._bufferedBytes<2){this._loop=!1;return}let n=this.consume(2);if((n[0]&48)!==0){let i=this.createError(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");e(i);return}let r=(n[0]&64)===64;if(r&&!this._extensions[ap.extensionName]){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(this._fin=(n[0]&128)===128,this._opcode=n[0]&15,this._payloadLength=n[1]&127,this._opcode===0){if(r){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(!this._fragmented){let i=this.createError(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}this._opcode=this._fragmented}else if(this._opcode===1||this._opcode===2){if(this._fragmented){let i=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}this._compressed=r}else if(this._opcode>7&&this._opcode<11){if(!this._fin){let i=this.createError(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");e(i);return}if(r){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(this._payloadLength>125||this._opcode===8&&this._payloadLength===1){let i=this.createError(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");e(i);return}}else{let i=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}if(!this._fin&&!this._fragmented&&(this._fragmented=this._opcode),this._masked=(n[1]&128)===128,this._isServer){if(!this._masked){let i=this.createError(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK");e(i);return}}else if(this._masked){let i=this.createError(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");e(i);return}this._payloadLength===126?this._state=dp:this._payloadLength===127?this._state=up:this.haveLength(e)}getPayloadLength16(e){if(this._bufferedBytes<2){this._loop=!1;return}this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength(e)}getPayloadLength64(e){if(this._bufferedBytes<8){this._loop=!1;return}let n=this.consume(8),r=n.readUInt32BE(0);if(r>Math.pow(2,21)-1){let i=this.createError(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH");e(i);return}this._payloadLength=r*Math.pow(2,32)+n.readUInt32BE(4),this.haveLength(e)}haveLength(e){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0)){let n=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");e(n);return}this._masked?this._state=fp:this._state=sl}getMask(){if(this._bufferedBytes<4){this._loop=!1;return}this._mask=this.consume(4),this._state=sl}getData(e){let n=cp;if(this._payloadLength){if(this._bufferedBytes<this._payloadLength){this._loop=!1;return}n=this.consume(this._payloadLength),this._masked&&(this._mask[0]|this._mask[1]|this._mask[2]|this._mask[3])!==0&&q0(n,this._mask)}if(this._opcode>7){this.controlMessage(n,e);return}if(this._compressed){this._state=ol,this.decompress(n,e);return}n.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(n)),this.dataMessage(e)}decompress(e,n){this._extensions[ap.extensionName].decompress(e,this._fin,(i,s)=>{if(i)return n(i);if(s.length){if(this._messageLength+=s.length,this._messageLength>this._maxPayload&&this._maxPayload>0){let o=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");n(o);return}this._fragments.push(s)}this.dataMessage(n),this._state===$e&&this.startLoop(n)})}dataMessage(e){if(!this._fin){this._state=$e;return}let n=this._messageLength,r=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],this._opcode===2){let i;this._binaryType==="nodebuffer"?i=il(r,n):this._binaryType==="arraybuffer"?i=W0(il(r,n)):this._binaryType==="blob"?i=new Blob(r):i=r,this._allowSynchronousEvents?(this.emit("message",i,!0),this._state=$e):(this._state=ho,setImmediate(()=>{this.emit("message",i,!0),this._state=$e,this.startLoop(e)}))}else{let i=il(r,n);if(!this._skipUTF8Validation&&!lp(i)){let s=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");e(s);return}this._state===ol||this._allowSynchronousEvents?(this.emit("message",i,!1),this._state=$e):(this._state=ho,setImmediate(()=>{this.emit("message",i,!1),this._state=$e,this.startLoop(e)}))}}controlMessage(e,n){if(this._opcode===8){if(e.length===0)this._loop=!1,this.emit("conclude",1005,cp),this.end();else{let r=e.readUInt16BE(0);if(!V0(r)){let s=this.createError(RangeError,`invalid status code ${r}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");n(s);return}let i=new fo(e.buffer,e.byteOffset+2,e.length-2);if(!this._skipUTF8Validation&&!lp(i)){let s=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");n(s);return}this._loop=!1,this.emit("conclude",r,i),this.end()}this._state=$e;return}this._allowSynchronousEvents?(this.emit(this._opcode===9?"ping":"pong",e),this._state=$e):(this._state=ho,setImmediate(()=>{this.emit(this._opcode===9?"ping":"pong",e),this._state=$e,this.startLoop(n)}))}createError(e,n,r,i,s){this._loop=!1,this._errored=!0;let o=new e(r?`Invalid WebSocket frame: ${n}`:n);return Error.captureStackTrace(o,this.createError),o.code=s,o[H0]=i,o}};hp.exports=al});var ul=H((PO,mp)=>{"use strict";var{Duplex:OO}=j("stream"),{randomFillSync:J0}=j("crypto"),pp=fr(),{EMPTY_BUFFER:Z0,kWebSocket:K0,NOOP:X0}=It(),{isBlob:pr,isValidStatusCode:Y0}=hr(),{mask:gp,toBuffer:In}=Si(),Ge=Symbol("kByteLength"),Q0=Buffer.alloc(4),po=8*1024,Tn,gr=po,Ye=0,ev=1,tv=2,ll=class t{constructor(e,n,r){this._extensions=n||{},r&&(this._generateMask=r,this._maskBuffer=Buffer.alloc(4)),this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._queue=[],this._state=Ye,this.onerror=X0,this[K0]=void 0}static frame(e,n){let r,i=!1,s=2,o=!1;n.mask&&(r=n.maskBuffer||Q0,n.generateMask?n.generateMask(r):(gr===po&&(Tn===void 0&&(Tn=Buffer.alloc(po)),J0(Tn,0,po),gr=0),r[0]=Tn[gr++],r[1]=Tn[gr++],r[2]=Tn[gr++],r[3]=Tn[gr++]),o=(r[0]|r[1]|r[2]|r[3])===0,s=6);let a;typeof e=="string"?(!n.mask||o)&&n[Ge]!==void 0?a=n[Ge]:(e=Buffer.from(e),a=e.length):(a=e.length,i=n.mask&&n.readOnly&&!o);let c=a;a>=65536?(s+=8,c=127):a>125&&(s+=2,c=126);let l=Buffer.allocUnsafe(i?a+s:s);return l[0]=n.fin?n.opcode|128:n.opcode,n.rsv1&&(l[0]|=64),l[1]=c,c===126?l.writeUInt16BE(a,2):c===127&&(l[2]=l[3]=0,l.writeUIntBE(a,4,6)),n.mask?(l[1]|=128,l[s-4]=r[0],l[s-3]=r[1],l[s-2]=r[2],l[s-1]=r[3],o?[l,e]:i?(gp(e,r,l,s,a),[l]):(gp(e,r,e,0,a),[l,e])):[l,e]}close(e,n,r,i){let s;if(e===void 0)s=Z0;else{if(typeof e!="number"||!Y0(e))throw new TypeError("First argument must be a valid error code number");if(n===void 0||!n.length)s=Buffer.allocUnsafe(2),s.writeUInt16BE(e,0);else{let a=Buffer.byteLength(n);if(a>123)throw new RangeError("The message must not be greater than 123 bytes");s=Buffer.allocUnsafe(2+a),s.writeUInt16BE(e,0),typeof n=="string"?s.write(n,2):s.set(n,2)}}let o={[Ge]:s.length,fin:!0,generateMask:this._generateMask,mask:r,maskBuffer:this._maskBuffer,opcode:8,readOnly:!1,rsv1:!1};this._state!==Ye?this.enqueue([this.dispatch,s,!1,o,i]):this.sendFrame(t.frame(s,o),i)}ping(e,n,r){let i,s;if(typeof e=="string"?(i=Buffer.byteLength(e),s=!1):pr(e)?(i=e.size,s=!1):(e=In(e),i=e.length,s=In.readOnly),i>125)throw new RangeError("The data size must not be greater than 125 bytes");let o={[Ge]:i,fin:!0,generateMask:this._generateMask,mask:n,maskBuffer:this._maskBuffer,opcode:9,readOnly:s,rsv1:!1};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,!1,o,r]):this.getBlobData(e,!1,o,r):this._state!==Ye?this.enqueue([this.dispatch,e,!1,o,r]):this.sendFrame(t.frame(e,o),r)}pong(e,n,r){let i,s;if(typeof e=="string"?(i=Buffer.byteLength(e),s=!1):pr(e)?(i=e.size,s=!1):(e=In(e),i=e.length,s=In.readOnly),i>125)throw new RangeError("The data size must not be greater than 125 bytes");let o={[Ge]:i,fin:!0,generateMask:this._generateMask,mask:n,maskBuffer:this._maskBuffer,opcode:10,readOnly:s,rsv1:!1};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,!1,o,r]):this.getBlobData(e,!1,o,r):this._state!==Ye?this.enqueue([this.dispatch,e,!1,o,r]):this.sendFrame(t.frame(e,o),r)}send(e,n,r){let i=this._extensions[pp.extensionName],s=n.binary?2:1,o=n.compress,a,c;typeof e=="string"?(a=Buffer.byteLength(e),c=!1):pr(e)?(a=e.size,c=!1):(e=In(e),a=e.length,c=In.readOnly),this._firstFragment?(this._firstFragment=!1,o&&i&&i.params[i._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(o=a>=i._threshold),this._compress=o):(o=!1,s=0),n.fin&&(this._firstFragment=!0);let l={[Ge]:a,fin:n.fin,generateMask:this._generateMask,mask:n.mask,maskBuffer:this._maskBuffer,opcode:s,readOnly:c,rsv1:o};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,this._compress,l,r]):this.getBlobData(e,this._compress,l,r):this._state!==Ye?this.enqueue([this.dispatch,e,this._compress,l,r]):this.dispatch(e,this._compress,l,r)}getBlobData(e,n,r,i){this._bufferedBytes+=r[Ge],this._state=tv,e.arrayBuffer().then(s=>{if(this._socket.destroyed){let a=new Error("The socket was closed while the blob was being read");process.nextTick(dl,this,a,i);return}this._bufferedBytes-=r[Ge];let o=In(s);n?this.dispatch(o,n,r,i):(this._state=Ye,this.sendFrame(t.frame(o,r),i),this.dequeue())}).catch(s=>{process.nextTick(nv,this,s,i)})}dispatch(e,n,r,i){if(!n){this.sendFrame(t.frame(e,r),i);return}let s=this._extensions[pp.extensionName];this._bufferedBytes+=r[Ge],this._state=ev,s.compress(e,r.fin,(o,a)=>{if(this._socket.destroyed){let c=new Error("The socket was closed while data was being compressed");dl(this,c,i);return}this._bufferedBytes-=r[Ge],this._state=Ye,r.readOnly=!1,this.sendFrame(t.frame(a,r),i),this.dequeue()})}dequeue(){for(;this._state===Ye&&this._queue.length;){let e=this._queue.shift();this._bufferedBytes-=e[3][Ge],Reflect.apply(e[0],this,e.slice(1))}}enqueue(e){this._bufferedBytes+=e[3][Ge],this._queue.push(e)}sendFrame(e,n){e.length===2?(this._socket.cork(),this._socket.write(e[0]),this._socket.write(e[1],n),this._socket.uncork()):this._socket.write(e[0],n)}};mp.exports=ll;function dl(t,e,n){typeof n=="function"&&n(e);for(let r=0;r<t._queue.length;r++){let i=t._queue[r],s=i[i.length-1];typeof s=="function"&&s(e)}}function nv(t,e,n){dl(t,e,n),t.onerror(e)}});var Rp=H((CO,Tp)=>{"use strict";var{kForOnEventAttribute:Ii,kListener:fl}=It(),wp=Symbol("kCode"),yp=Symbol("kData"),_p=Symbol("kError"),Ep=Symbol("kMessage"),Sp=Symbol("kReason"),mr=Symbol("kTarget"),vp=Symbol("kType"),Ip=Symbol("kWasClean"),Rt=class{constructor(e){this[mr]=null,this[vp]=e}get target(){return this[mr]}get type(){return this[vp]}};Object.defineProperty(Rt.prototype,"target",{enumerable:!0});Object.defineProperty(Rt.prototype,"type",{enumerable:!0});var Rn=class extends Rt{constructor(e,n={}){super(e),this[wp]=n.code===void 0?0:n.code,this[Sp]=n.reason===void 0?"":n.reason,this[Ip]=n.wasClean===void 0?!1:n.wasClean}get code(){return this[wp]}get reason(){return this[Sp]}get wasClean(){return this[Ip]}};Object.defineProperty(Rn.prototype,"code",{enumerable:!0});Object.defineProperty(Rn.prototype,"reason",{enumerable:!0});Object.defineProperty(Rn.prototype,"wasClean",{enumerable:!0});var wr=class extends Rt{constructor(e,n={}){super(e),this[_p]=n.error===void 0?null:n.error,this[Ep]=n.message===void 0?"":n.message}get error(){return this[_p]}get message(){return this[Ep]}};Object.defineProperty(wr.prototype,"error",{enumerable:!0});Object.defineProperty(wr.prototype,"message",{enumerable:!0});var Ti=class extends Rt{constructor(e,n={}){super(e),this[yp]=n.data===void 0?null:n.data}get data(){return this[yp]}};Object.defineProperty(Ti.prototype,"data",{enumerable:!0});var rv={addEventListener(t,e,n={}){for(let i of this.listeners(t))if(!n[Ii]&&i[fl]===e&&!i[Ii])return;let r;if(t==="message")r=function(s,o){let a=new Ti("message",{data:o?s:s.toString()});a[mr]=this,go(e,this,a)};else if(t==="close")r=function(s,o){let a=new Rn("close",{code:s,reason:o.toString(),wasClean:this._closeFrameReceived&&this._closeFrameSent});a[mr]=this,go(e,this,a)};else if(t==="error")r=function(s){let o=new wr("error",{error:s,message:s.message});o[mr]=this,go(e,this,o)};else if(t==="open")r=function(){let s=new Rt("open");s[mr]=this,go(e,this,s)};else return;r[Ii]=!!n[Ii],r[fl]=e,n.once?this.once(t,r):this.on(t,r)},removeEventListener(t,e){for(let n of this.listeners(t))if(n[fl]===e&&!n[Ii]){this.removeListener(t,n);break}}};Tp.exports={CloseEvent:Rn,ErrorEvent:wr,Event:Rt,EventTarget:rv,MessageEvent:Ti};function go(t,e,n){typeof t=="object"&&t.handleEvent?t.handleEvent.call(t,n):t.call(e,n)}});var mo=H((DO,kp)=>{"use strict";var{tokenChars:Ri}=hr();function ut(t,e,n){t[e]===void 0?t[e]=[n]:t[e].push(n)}function iv(t){let e=Object.create(null),n=Object.create(null),r=!1,i=!1,s=!1,o,a,c=-1,l=-1,d=-1,p=0;for(;p<t.length;p++)if(l=t.charCodeAt(p),o===void 0)if(d===-1&&Ri[l]===1)c===-1&&(c=p);else if(p!==0&&(l===32||l===9))d===-1&&c!==-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p);let u=t.slice(c,d);l===44?(ut(e,u,n),n=Object.create(null)):o=u,c=d=-1}else throw new SyntaxError(`Unexpected character at index ${p}`);else if(a===void 0)if(d===-1&&Ri[l]===1)c===-1&&(c=p);else if(l===32||l===9)d===-1&&c!==-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p),ut(n,t.slice(c,d),!0),l===44&&(ut(e,o,n),n=Object.create(null),o=void 0),c=d=-1}else if(l===61&&c!==-1&&d===-1)a=t.slice(c,p),c=d=-1;else throw new SyntaxError(`Unexpected character at index ${p}`);else if(i){if(Ri[l]!==1)throw new SyntaxError(`Unexpected character at index ${p}`);c===-1?c=p:r||(r=!0),i=!1}else if(s)if(Ri[l]===1)c===-1&&(c=p);else if(l===34&&c!==-1)s=!1,d=p;else if(l===92)i=!0;else throw new SyntaxError(`Unexpected character at index ${p}`);else if(l===34&&t.charCodeAt(p-1)===61)s=!0;else if(d===-1&&Ri[l]===1)c===-1&&(c=p);else if(c!==-1&&(l===32||l===9))d===-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p);let u=t.slice(c,d);r&&(u=u.replace(/\\/g,""),r=!1),ut(n,a,u),l===44&&(ut(e,o,n),n=Object.create(null),o=void 0),a=void 0,c=d=-1}else throw new SyntaxError(`Unexpected character at index ${p}`);if(c===-1||s||l===32||l===9)throw new SyntaxError("Unexpected end of input");d===-1&&(d=p);let m=t.slice(c,d);return o===void 0?ut(e,m,n):(a===void 0?ut(n,m,!0):r?ut(n,a,m.replace(/\\/g,"")):ut(n,a,m),ut(e,o,n)),e}function sv(t){return Object.keys(t).map(e=>{let n=t[e];return Array.isArray(n)||(n=[n]),n.map(r=>[e].concat(Object.keys(r).map(i=>{let s=r[i];return Array.isArray(s)||(s=[s]),s.map(o=>o===!0?i:`${i}=${o}`).join("; ")})).join("; ")).join(", ")}).join(", ")}kp.exports={format:sv,parse:iv}});var Eo=H((FO,Bp)=>{"use strict";var ov=j("events"),av=j("https"),cv=j("http"),xp=j("net"),lv=j("tls"),{randomBytes:dv,createHash:uv}=j("crypto"),{Duplex:NO,Readable:LO}=j("stream"),{URL:hl}=j("url"),Kt=fr(),fv=cl(),hv=ul(),{isBlob:pv}=hr(),{BINARY_TYPES:bp,CLOSE_TIMEOUT:gv,EMPTY_BUFFER:wo,GUID:mv,kForOnEventAttribute:pl,kListener:wv,kStatusCode:yv,kWebSocket:pe,NOOP:Op}=It(),{EventTarget:{addEventListener:_v,removeEventListener:Ev}}=Rp(),{format:Sv,parse:vv}=mo(),{toBuffer:Iv}=Si(),Pp=Symbol("kAborted"),gl=[8,13],kt=["CONNECTING","OPEN","CLOSING","CLOSED"],Tv=/^[!#$%&'*+\-.0-9A-Z^_`|a-z~]+$/,q=class t extends ov{constructor(e,n,r){super(),this._binaryType=bp[0],this._closeCode=1006,this._closeFrameReceived=!1,this._closeFrameSent=!1,this._closeMessage=wo,this._closeTimer=null,this._errorEmitted=!1,this._extensions={},this._paused=!1,this._protocol="",this._readyState=t.CONNECTING,this._receiver=null,this._sender=null,this._socket=null,e!==null?(this._bufferedAmount=0,this._isServer=!1,this._redirects=0,n===void 0?n=[]:Array.isArray(n)||(typeof n=="object"&&n!==null?(r=n,n=[]):n=[n]),Cp(this,e,n,r)):(this._autoPong=r.autoPong,this._closeTimeout=r.closeTimeout,this._isServer=!0)}get binaryType(){return this._binaryType}set binaryType(e){bp.includes(e)&&(this._binaryType=e,this._receiver&&(this._receiver._binaryType=e))}get bufferedAmount(){return this._socket?this._socket._writableState.length+this._sender._bufferedBytes:this._bufferedAmount}get extensions(){return Object.keys(this._extensions).join()}get isPaused(){return this._paused}get onclose(){return null}get onerror(){return null}get onopen(){return null}get onmessage(){return null}get protocol(){return this._protocol}get readyState(){return this._readyState}get url(){return this._url}setSocket(e,n,r){let i=new fv({allowSynchronousEvents:r.allowSynchronousEvents,binaryType:this.binaryType,extensions:this._extensions,isServer:this._isServer,maxPayload:r.maxPayload,skipUTF8Validation:r.skipUTF8Validation}),s=new hv(e,this._extensions,r.generateMask);this._receiver=i,this._sender=s,this._socket=e,i[pe]=this,s[pe]=this,e[pe]=this,i.on("conclude",bv),i.on("drain",Av),i.on("error",xv),i.on("message",Ov),i.on("ping",Pv),i.on("pong",Cv),s.onerror=Dv,e.setTimeout&&e.setTimeout(0),e.setNoDelay&&e.setNoDelay(),n.length>0&&e.unshift(n),e.on("close",Lp),e.on("data",_o),e.on("end",Fp),e.on("error",Mp),this._readyState=t.OPEN,this.emit("open")}emitClose(){if(!this._socket){this._readyState=t.CLOSED,this.emit("close",this._closeCode,this._closeMessage);return}this._extensions[Kt.extensionName]&&this._extensions[Kt.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=t.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,n){if(this.readyState!==t.CLOSED){if(this.readyState===t.CONNECTING){Le(this,this._req,"WebSocket was closed before the connection was established");return}if(this.readyState===t.CLOSING){this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end();return}this._readyState=t.CLOSING,this._sender.close(e,n,!this._isServer,r=>{r||(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())}),Np(this)}}pause(){this.readyState===t.CONNECTING||this.readyState===t.CLOSED||(this._paused=!0,this._socket.pause())}ping(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(r=e,e=n=void 0):typeof n=="function"&&(r=n,n=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){ml(this,e,r);return}n===void 0&&(n=!this._isServer),this._sender.ping(e||wo,n,r)}pong(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(r=e,e=n=void 0):typeof n=="function"&&(r=n,n=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){ml(this,e,r);return}n===void 0&&(n=!this._isServer),this._sender.pong(e||wo,n,r)}resume(){this.readyState===t.CONNECTING||this.readyState===t.CLOSED||(this._paused=!1,this._receiver._writableState.needDrain||this._socket.resume())}send(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof n=="function"&&(r=n,n={}),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){ml(this,e,r);return}let i={binary:typeof e!="string",mask:!this._isServer,compress:!0,fin:!0,...n};this._extensions[Kt.extensionName]||(i.compress=!1),this._sender.send(e||wo,i,r)}terminate(){if(this.readyState!==t.CLOSED){if(this.readyState===t.CONNECTING){Le(this,this._req,"WebSocket was closed before the connection was established");return}this._socket&&(this._readyState=t.CLOSING,this._socket.destroy())}}};Object.defineProperty(q,"CONNECTING",{enumerable:!0,value:kt.indexOf("CONNECTING")});Object.defineProperty(q.prototype,"CONNECTING",{enumerable:!0,value:kt.indexOf("CONNECTING")});Object.defineProperty(q,"OPEN",{enumerable:!0,value:kt.indexOf("OPEN")});Object.defineProperty(q.prototype,"OPEN",{enumerable:!0,value:kt.indexOf("OPEN")});Object.defineProperty(q,"CLOSING",{enumerable:!0,value:kt.indexOf("CLOSING")});Object.defineProperty(q.prototype,"CLOSING",{enumerable:!0,value:kt.indexOf("CLOSING")});Object.defineProperty(q,"CLOSED",{enumerable:!0,value:kt.indexOf("CLOSED")});Object.defineProperty(q.prototype,"CLOSED",{enumerable:!0,value:kt.indexOf("CLOSED")});["binaryType","bufferedAmount","extensions","isPaused","protocol","readyState","url"].forEach(t=>{Object.defineProperty(q.prototype,t,{enumerable:!0})});["open","error","close","message"].forEach(t=>{Object.defineProperty(q.prototype,`on${t}`,{enumerable:!0,get(){for(let e of this.listeners(t))if(e[pl])return e[wv];return null},set(e){for(let n of this.listeners(t))if(n[pl]){this.removeListener(t,n);break}typeof e=="function"&&this.addEventListener(t,e,{[pl]:!0})}})});q.prototype.addEventListener=_v;q.prototype.removeEventListener=Ev;Bp.exports=q;function Cp(t,e,n,r){let i={allowSynchronousEvents:!0,autoPong:!0,closeTimeout:gv,protocolVersion:gl[1],maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...r,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:"GET",host:void 0,path:void 0,port:void 0};if(t._autoPong=i.autoPong,t._closeTimeout=i.closeTimeout,!gl.includes(i.protocolVersion))throw new RangeError(`Unsupported protocol version: ${i.protocolVersion} (supported versions: ${gl.join(", ")})`);let s;if(e instanceof hl)s=e;else try{s=new hl(e)}catch{throw new SyntaxError(`Invalid URL: ${e}`)}s.protocol==="http:"?s.protocol="ws:":s.protocol==="https:"&&(s.protocol="wss:"),t._url=s.href;let o=s.protocol==="wss:",a=s.protocol==="ws+unix:",c;if(s.protocol!=="ws:"&&!o&&!a?c=`The URL's protocol must be one of "ws:", "wss:", "http:", "https:", or "ws+unix:"`:a&&!s.pathname?c="The URL's pathname is empty":s.hash&&(c="The URL contains a fragment identifier"),c){let g=new SyntaxError(c);if(t._redirects===0)throw g;yo(t,g);return}let l=o?443:80,d=dv(16).toString("base64"),p=o?av.request:cv.request,m=new Set,u;if(i.createConnection=i.createConnection||(o?kv:Rv),i.defaultPort=i.defaultPort||l,i.port=s.port||l,i.host=s.hostname.startsWith("[")?s.hostname.slice(1,-1):s.hostname,i.headers={...i.headers,"Sec-WebSocket-Version":i.protocolVersion,"Sec-WebSocket-Key":d,Connection:"Upgrade",Upgrade:"websocket"},i.path=s.pathname+s.search,i.timeout=i.handshakeTimeout,i.perMessageDeflate&&(u=new Kt({...i.perMessageDeflate,isServer:!1,maxPayload:i.maxPayload}),i.headers["Sec-WebSocket-Extensions"]=Sv({[Kt.extensionName]:u.offer()})),n.length){for(let g of n){if(typeof g!="string"||!Tv.test(g)||m.has(g))throw new SyntaxError("An invalid or duplicated subprotocol was specified");m.add(g)}i.headers["Sec-WebSocket-Protocol"]=n.join(",")}if(i.origin&&(i.protocolVersion<13?i.headers["Sec-WebSocket-Origin"]=i.origin:i.headers.Origin=i.origin),(s.username||s.password)&&(i.auth=`${s.username}:${s.password}`),a){let g=i.path.split(":");i.socketPath=g[0],i.path=g[1]}let h;if(i.followRedirects){if(t._redirects===0){t._originalIpc=a,t._originalSecure=o,t._originalHostOrSocketPath=a?i.socketPath:s.host;let g=r&&r.headers;if(r={...r,headers:{}},g)for(let[w,S]of Object.entries(g))r.headers[w.toLowerCase()]=S}else if(t.listenerCount("redirect")===0){let g=a?t._originalIpc?i.socketPath===t._originalHostOrSocketPath:!1:t._originalIpc?!1:s.host===t._originalHostOrSocketPath;(!g||t._originalSecure&&!o)&&(delete i.headers.authorization,delete i.headers.cookie,g||delete i.headers.host,i.auth=void 0)}i.auth&&!r.headers.authorization&&(r.headers.authorization="Basic "+Buffer.from(i.auth).toString("base64")),h=t._req=p(i),t._redirects&&t.emit("redirect",t.url,h)}else h=t._req=p(i);i.timeout&&h.on("timeout",()=>{Le(t,h,"Opening handshake has timed out")}),h.on("error",g=>{h===null||h[Pp]||(h=t._req=null,yo(t,g))}),h.on("response",g=>{let w=g.headers.location,S=g.statusCode;if(w&&i.followRedirects&&S>=300&&S<400){if(++t._redirects>i.maxRedirects){Le(t,h,"Maximum redirects exceeded");return}h.abort();let v;try{v=new hl(w,e)}catch{let y=new SyntaxError(`Invalid URL: ${w}`);yo(t,y);return}Cp(t,v,n,r)}else t.emit("unexpected-response",h,g)||Le(t,h,`Unexpected server response: ${g.statusCode}`)}),h.on("upgrade",(g,w,S)=>{if(t.emit("upgrade",g),t.readyState!==q.CONNECTING)return;h=t._req=null;let v=g.headers.upgrade;if(v===void 0||v.toLowerCase()!=="websocket"){Le(t,w,"Invalid Upgrade header");return}let f=uv("sha1").update(d+mv).digest("base64");if(g.headers["sec-websocket-accept"]!==f){Le(t,w,"Invalid Sec-WebSocket-Accept header");return}let y=g.headers["sec-websocket-protocol"],E;if(y!==void 0?m.size?m.has(y)||(E="Server sent an invalid subprotocol"):E="Server sent a subprotocol but none was requested":m.size&&(E="Server sent no subprotocol"),E){Le(t,w,E);return}y&&(t._protocol=y);let T=g.headers["sec-websocket-extensions"];if(T!==void 0){if(!u){Le(t,w,"Server sent a Sec-WebSocket-Extensions header but no extension was requested");return}let R;try{R=vv(T)}catch{Le(t,w,"Invalid Sec-WebSocket-Extensions header");return}let D=Object.keys(R);if(D.length!==1||D[0]!==Kt.extensionName){Le(t,w,"Server indicated an extension that was not requested");return}try{u.accept(R[Kt.extensionName])}catch{Le(t,w,"Invalid Sec-WebSocket-Extensions header");return}t._extensions[Kt.extensionName]=u}t.setSocket(w,S,{allowSynchronousEvents:i.allowSynchronousEvents,generateMask:i.generateMask,maxPayload:i.maxPayload,skipUTF8Validation:i.skipUTF8Validation})}),i.finishRequest?i.finishRequest(h,t):h.end()}function yo(t,e){t._readyState=q.CLOSING,t._errorEmitted=!0,t.emit("error",e),t.emitClose()}function Rv(t){return t.path=t.socketPath,xp.connect(t)}function kv(t){return t.path=void 0,!t.servername&&t.servername!==""&&(t.servername=xp.isIP(t.host)?"":t.host),lv.connect(t)}function Le(t,e,n){t._readyState=q.CLOSING;let r=new Error(n);Error.captureStackTrace(r,Le),e.setHeader?(e[Pp]=!0,e.abort(),e.socket&&!e.socket.destroyed&&e.socket.destroy(),process.nextTick(yo,t,r)):(e.destroy(r),e.once("error",t.emit.bind(t,"error")),e.once("close",t.emitClose.bind(t)))}function ml(t,e,n){if(e){let r=pv(e)?e.size:Iv(e).length;t._socket?t._sender._bufferedBytes+=r:t._bufferedAmount+=r}if(n){let r=new Error(`WebSocket is not open: readyState ${t.readyState} (${kt[t.readyState]})`);process.nextTick(n,r)}}function bv(t,e){let n=this[pe];n._closeFrameReceived=!0,n._closeMessage=e,n._closeCode=t,n._socket[pe]!==void 0&&(n._socket.removeListener("data",_o),process.nextTick(Dp,n._socket),t===1005?n.close():n.close(t,e))}function Av(){let t=this[pe];t.isPaused||t._socket.resume()}function xv(t){let e=this[pe];e._socket[pe]!==void 0&&(e._socket.removeListener("data",_o),process.nextTick(Dp,e._socket),e.close(t[yv])),e._errorEmitted||(e._errorEmitted=!0,e.emit("error",t))}function Ap(){this[pe].emitClose()}function Ov(t,e){this[pe].emit("message",t,e)}function Pv(t){let e=this[pe];e._autoPong&&e.pong(t,!this._isServer,Op),e.emit("ping",t)}function Cv(t){this[pe].emit("pong",t)}function Dp(t){t.resume()}function Dv(t){let e=this[pe];e.readyState!==q.CLOSED&&(e.readyState===q.OPEN&&(e._readyState=q.CLOSING,Np(e)),this._socket.end(),e._errorEmitted||(e._errorEmitted=!0,e.emit("error",t)))}function Np(t){t._closeTimer=setTimeout(t._socket.destroy.bind(t._socket),t._closeTimeout)}function Lp(){let t=this[pe];if(this.removeListener("close",Lp),this.removeListener("data",_o),this.removeListener("end",Fp),t._readyState=q.CLOSING,!this._readableState.endEmitted&&!t._closeFrameReceived&&!t._receiver._writableState.errorEmitted&&this._readableState.length!==0){let e=this.read(this._readableState.length);t._receiver.write(e)}t._receiver.end(),this[pe]=void 0,clearTimeout(t._closeTimer),t._receiver._writableState.finished||t._receiver._writableState.errorEmitted?t.emitClose():(t._receiver.on("error",Ap),t._receiver.on("finish",Ap))}function _o(t){this[pe]._receiver.write(t)||this.pause()}function Fp(){let t=this[pe];t._readyState=q.CLOSING,t._receiver.end(),this.end()}function Mp(){let t=this[pe];this.removeListener("error",Mp),this.on("error",Op),t&&(t._readyState=q.CLOSING,this.destroy())}});var Gp=H((BO,$p)=>{"use strict";var MO=Eo(),{Duplex:Nv}=j("stream");function Up(t){t.emit("close")}function Lv(){!this.destroyed&&this._writableState.finished&&this.destroy()}function zp(t){this.removeListener("error",zp),this.destroy(),this.listenerCount("error")===0&&this.emit("error",t)}function Fv(t,e){let n=!0,r=new Nv({...e,autoDestroy:!1,emitClose:!1,objectMode:!1,writableObjectMode:!1});return t.on("message",function(s,o){let a=!o&&r._readableState.objectMode?s.toString():s;r.push(a)||t.pause()}),t.once("error",function(s){r.destroyed||(n=!1,r.destroy(s))}),t.once("close",function(){r.destroyed||r.push(null)}),r._destroy=function(i,s){if(t.readyState===t.CLOSED){s(i),process.nextTick(Up,r);return}let o=!1;t.once("error",function(c){o=!0,s(c)}),t.once("close",function(){o||s(i),process.nextTick(Up,r)}),n&&t.terminate()},r._final=function(i){if(t.readyState===t.CONNECTING){t.once("open",function(){r._final(i)});return}t._socket!==null&&(t._socket._writableState.finished?(i(),r._readableState.endEmitted&&r.destroy()):(t._socket.once("finish",function(){i()}),t.close()))},r._read=function(){t.isPaused&&t.resume()},r._write=function(i,s,o){if(t.readyState===t.CONNECTING){t.once("open",function(){r._write(i,s,o)});return}t.send(i,o)},r.on("end",Lv),r.on("error",zp),r}$p.exports=Fv});var wl=H((UO,Hp)=>{"use strict";var{tokenChars:Mv}=hr();function Bv(t){let e=new Set,n=-1,r=-1,i=0;for(i;i<t.length;i++){let o=t.charCodeAt(i);if(r===-1&&Mv[o]===1)n===-1&&(n=i);else if(i!==0&&(o===32||o===9))r===-1&&n!==-1&&(r=i);else if(o===44){if(n===-1)throw new SyntaxError(`Unexpected character at index ${i}`);r===-1&&(r=i);let a=t.slice(n,r);if(e.has(a))throw new SyntaxError(`The "${a}" subprotocol is duplicated`);e.add(a),n=r=-1}else throw new SyntaxError(`Unexpected character at index ${i}`)}if(n===-1||r!==-1)throw new SyntaxError("Unexpected end of input");let s=t.slice(n,i);if(e.has(s))throw new SyntaxError(`The "${s}" subprotocol is duplicated`);return e.add(s),e}Hp.exports={parse:Bv}});var Kp=H(($O,Zp)=>{"use strict";var Uv=j("events"),So=j("http"),{Duplex:zO}=j("stream"),{createHash:zv}=j("crypto"),jp=mo(),kn=fr(),$v=wl(),Gv=Eo(),{CLOSE_TIMEOUT:Hv,GUID:jv,kWebSocket:Wv}=It(),qv=/^[+/0-9A-Za-z]{22}==$/,Wp=0,qp=1,Jp=2,yl=class extends Uv{constructor(e,n){if(super(),e={allowSynchronousEvents:!0,autoPong:!0,maxPayload:100*1024*1024,skipUTF8Validation:!1,perMessageDeflate:!1,handleProtocols:null,clientTracking:!0,closeTimeout:Hv,verifyClient:null,noServer:!1,backlog:null,server:null,host:null,path:null,port:null,WebSocket:Gv,...e},e.port==null&&!e.server&&!e.noServer||e.port!=null&&(e.server||e.noServer)||e.server&&e.noServer)throw new TypeError('One and only one of the "port", "server", or "noServer" options must be specified');if(e.port!=null?(this._server=So.createServer((r,i)=>{let s=So.STATUS_CODES[426];i.writeHead(426,{"Content-Length":s.length,"Content-Type":"text/plain"}),i.end(s)}),this._server.listen(e.port,e.host,e.backlog,n)):e.server&&(this._server=e.server),this._server){let r=this.emit.bind(this,"connection");this._removeListeners=Vv(this._server,{listening:this.emit.bind(this,"listening"),error:this.emit.bind(this,"error"),upgrade:(i,s,o)=>{this.handleUpgrade(i,s,o,r)}})}e.perMessageDeflate===!0&&(e.perMessageDeflate={}),e.clientTracking&&(this.clients=new Set,this._shouldEmitClose=!1),this.options=e,this._state=Wp}address(){if(this.options.noServer)throw new Error('The server is operating in "noServer" mode');return this._server?this._server.address():null}close(e){if(this._state===Jp){e&&this.once("close",()=>{e(new Error("The server is not running"))}),process.nextTick(ki,this);return}if(e&&this.once("close",e),this._state!==qp)if(this._state=qp,this.options.noServer||this.options.server)this._server&&(this._removeListeners(),this._removeListeners=this._server=null),this.clients?this.clients.size?this._shouldEmitClose=!0:process.nextTick(ki,this):process.nextTick(ki,this);else{let n=this._server;this._removeListeners(),this._removeListeners=this._server=null,n.close(()=>{ki(this)})}}shouldHandle(e){if(this.options.path){let n=e.url.indexOf("?");if((n!==-1?e.url.slice(0,n):e.url)!==this.options.path)return!1}return!0}handleUpgrade(e,n,r,i){n.on("error",Vp);let s=e.headers["sec-websocket-key"],o=e.headers.upgrade,a=+e.headers["sec-websocket-version"];if(e.method!=="GET"){bn(this,e,n,405,"Invalid HTTP method");return}if(o===void 0||o.toLowerCase()!=="websocket"){bn(this,e,n,400,"Invalid Upgrade header");return}if(s===void 0||!qv.test(s)){bn(this,e,n,400,"Missing or invalid Sec-WebSocket-Key header");return}if(a!==13&&a!==8){bn(this,e,n,400,"Missing or invalid Sec-WebSocket-Version header",{"Sec-WebSocket-Version":"13, 8"});return}if(!this.shouldHandle(e)){bi(n,400);return}let c=e.headers["sec-websocket-protocol"],l=new Set;if(c!==void 0)try{l=$v.parse(c)}catch{bn(this,e,n,400,"Invalid Sec-WebSocket-Protocol header");return}let d=e.headers["sec-websocket-extensions"],p={};if(this.options.perMessageDeflate&&d!==void 0){let m=new kn({...this.options.perMessageDeflate,isServer:!0,maxPayload:this.options.maxPayload});try{let u=jp.parse(d);u[kn.extensionName]&&(m.accept(u[kn.extensionName]),p[kn.extensionName]=m)}catch{bn(this,e,n,400,"Invalid or unacceptable Sec-WebSocket-Extensions header");return}}if(this.options.verifyClient){let m={origin:e.headers[`${a===8?"sec-websocket-origin":"origin"}`],secure:!!(e.socket.authorized||e.socket.encrypted),req:e};if(this.options.verifyClient.length===2){this.options.verifyClient(m,(u,h,g,w)=>{if(!u)return bi(n,h||401,g,w);this.completeUpgrade(p,s,l,e,n,r,i)});return}if(!this.options.verifyClient(m))return bi(n,401)}this.completeUpgrade(p,s,l,e,n,r,i)}completeUpgrade(e,n,r,i,s,o,a){if(!s.readable||!s.writable)return s.destroy();if(s[Wv])throw new Error("server.handleUpgrade() was called more than once with the same socket, possibly due to a misconfiguration");if(this._state>Wp)return bi(s,503);let l=["HTTP/1.1 101 Switching Protocols","Upgrade: websocket","Connection: Upgrade",`Sec-WebSocket-Accept: ${zv("sha1").update(n+jv).digest("base64")}`],d=new this.options.WebSocket(null,void 0,this.options);if(r.size){let p=this.options.handleProtocols?this.options.handleProtocols(r,i):r.values().next().value;p&&(l.push(`Sec-WebSocket-Protocol: ${p}`),d._protocol=p)}if(e[kn.extensionName]){let p=e[kn.extensionName].params,m=jp.format({[kn.extensionName]:[p]});l.push(`Sec-WebSocket-Extensions: ${m}`),d._extensions=e}this.emit("headers",l,i),s.write(l.concat(`\r
10
+ `),this.stream=void 0;return}this.currentDate!==void 0&&Bi(this.dir,this.prefix,e,this.opts.retentionDays),this.currentDate=e}close(){this.stream?.end(),this.stream=void 0,this.currentDate=void 0}}});function Ll(t){let e=t.retentionDays??Zg,n=t.clock??(()=>xn(new Date));zi={bridgeSink:new kr(t.bridgeLogsDir,"bridge",{retentionDays:e,clock:n}),agentSinks:new Map,makeAgentSink:i=>new kr(t.agentLogsDir(i),"agent",{retentionDays:e,clock:n})};let r=n();Bi(t.bridgeLogsDir,"bridge",r,e);for(let i of t.listAgentIds?.()??[])Bi(t.agentLogsDir(i),"agent",r,e)}function Kg(t,e){let n=t.agentSinks.get(e);return n||(n=t.makeAgentSink(e),t.agentSinks.set(e,n)),n}function Fl(t){qo=t}function Ml(t){return On[qo]<=On[t]}function Bl(t,e){let n=On[t];return n===void 0?!0:n>=On[e]}function $i(t){Nl={...t}}function Xg(t){let e=(a,c=2)=>String(a).padStart(c,"0"),n=-t.getTimezoneOffset(),r=n>=0?"+":"-",i=Math.abs(n),s=e(Math.floor(i/60)),o=e(i%60);return`${xn(t)}T${e(t.getHours())}:${e(t.getMinutes())}:${e(t.getSeconds())}.${e(t.getMilliseconds(),3)}${r}${s}:${o}`}function Yg(t,e){if(t)return t;let n=e?.agentId;return typeof n=="string"&&n.length>0?n:void 0}function Ui(t,e,n,r,i){if(On[t]<On[qo])return;let s=`${JSON.stringify({ts:Xg(new Date),level:t,module:e,msg:n,...Nl,...r})}
11
+ `;if(zi){let o=Yg(i,r),a=o?Kg(zi,o):zi.bridgeSink;try{a.write(s)}catch{process.stderr.write(s)}return}t==="error"||t==="warn"?Jg.write(s):Vg.write(s)}function b(t,e){return{debug:(n,r)=>Ui("debug",t,n,r,e),info:(n,r)=>Ui("info",t,n,r,e),warn:(n,r)=>Ui("warn",t,n,r,e),error:(n,r)=>Ui("error",t,n,r,e),child:n=>b(`${t}.${n}`,e),forAgent:n=>b(t,n)}}var On,qo,Vg,Jg,Nl,Zg,zi,L=ve(()=>{"use strict";Fi();Wo();On={debug:10,info:20,warn:30,error:40},qo=(()=>{let t=process.env.COZE_BRIDGE_LOG_LEVEL;return t==="debug"||t==="info"||t==="warn"||t==="error"?t:"info"})(),Vg=process.stdout,Jg=process.stderr,Nl={},Zg=pt("COZE_BRIDGE_LOG_RETENTION_DAYS",30),zi=null});import{execFile as Qg,spawn as em,spawnSync as eR}from"node:child_process";import{promisify as tm}from"node:util";function rm(t){if(process.platform!=="win32")return!1;if(Ul.test(t))return!0;let n=(t.split(/[/\\]/).pop()??t).replace(Ul,"").toLowerCase();return nm.has(n)}function zl(t,e){if(process.platform!=="win32")return e??{};let n={...e??{}};return rm(t)&&n.shell===void 0&&(n.shell=!0),n.windowsHide===void 0&&(n.windowsHide=!0),n}function Fe(t,e=[],n={}){return em(t,e,zl(t,n))}function Pn(t,e=[],n={}){return im(t,e,zl(t,n))}var nm,Ul,im,gt=ve(()=>{"use strict";nm=new Set(["npm","npx","yarn","pnpm","coze","tsx","claude-agent-acp","codex-acp","openclaw"]),Ul=/\.(cmd|bat|ps1)$/i;im=tm(Qg)});var _,Te=ve(()=>{"use strict";_=class extends Error{code;retriable;cause;constructor(e,n,r){super(n),this.name="BridgeError",this.code=e,this.retriable=r?.retriable??!1,r?.cause!==void 0&&(this.cause=r.cause)}}});var Zl={};Li(Zl,{_resetAcpInstallerForTests:()=>hm,_resetInstallTimeoutsForTests:()=>fm,_setBinaryPathCacheForTests:()=>gm,_setInFlightForTests:()=>pm,_setInstallTimeoutsForTests:()=>um,buildInstallFailureMessage:()=>Jl,ensureAcpInstalled:()=>en,formatExecError:()=>Hl,getAcpBinaryPath:()=>br,getAcpPackageSpec:()=>lm,getInFlightInstall:()=>Zo,npmInstallGlobal:()=>Vl,parseVersionTriple:()=>Wl,pickWhichLine:()=>ji,probeAcpVersion:()=>jl,resolveAcpCommand:()=>Ar,versionSatisfiesSpec:()=>ql});import{readFile as sm,realpath as om,stat as am}from"node:fs/promises";import{dirname as Vo,join as cm}from"node:path";function lm(t){let e=Jo[t];if(e)return`${e.npmPackage}@${e.versionSpec}`}function um(t,e){Gi=t,Hi=e}function fm(){Gi=5e4,Hi=5e3}function Hl(t){if(t==null||typeof t!="object")return String(t);let e=t,n=[];e.message&&n.push(e.message),e.code!==void 0&&e.code!==null&&n.push(`code=${e.code}`),e.signal&&n.push(`signal=${e.signal}`);let r=e.stderr?.toString().trim();r&&n.push(`stderr=${r.slice(0,2e3)}`);let i=e.stdout?.toString().trim();return i&&n.push(`stdout=${i.slice(0,2e3)}`),n.length>0?n.join(" | "):String(t)}async function $l(t){let e=process.platform==="win32"?"where":"which";try{let{stdout:n}=await Pn(e,[t],{timeout:dm});return ji(n)}catch{return}}function ji(t){let e=t.split(/\r?\n/).map(r=>r.trim()).filter(Boolean);if(e.length===0)return;if(process.platform!=="win32")return e[0];let n=r=>e.find(i=>i.toLowerCase().endsWith(r));return n(".cmd")??n(".exe")??n(".bat")??n(".ps1")??e[0]}async function jl(t,e){let n=Jo[t];if(!n)return;let r=e??br(t);if(!r){ce.warn("acp wrapper probe: binary path cache empty",{framework:t,binary:n.binary,hint:"ensureAcpInstalled \u6CA1\u8DD1\u8FC7 / \u88C5\u5931\u8D25 / \u4E4B\u524D negative cache 5min \u5185"});return}let i;try{i=await om(r)}catch(o){ce.warn("acp wrapper probe: realpath failed (symlink target \u4E0D\u5B58\u5728?)",{framework:t,binaryPath:r,err:String(o)});return}let s=Vo(i);for(let o=0;o<Gl;o++){let a=cm(s,"package.json");try{if(!(await am(a)).isFile()){s=Vo(s);continue}let d=await sm(a,"utf8"),p=JSON.parse(d);if(p.name===n.npmPackage){if(typeof p.version=="string"&&p.version.length>0)return p.version;ce.warn("acp wrapper probe: package.json \u627E\u5230\u4F46 version \u5B57\u6BB5\u7F3A",{framework:t,packageJsonPath:a});return}}catch(l){let d=l;d.code!=="ENOENT"&&ce.warn("acp wrapper probe: package.json \u8BFB\u53D6\u5F02\u5E38",{framework:t,candidate:a,errCode:d?.code,err:String(l)})}let c=Vo(s);if(c===s)break;s=c}ce.warn("acp wrapper probe: \u627E\u4E0D\u5230\u5339\u914D name \u7684 package.json (\u4E0A\u6EAF\u5230 max depth)",{framework:t,binaryPath:r,realBinary:i,expectedName:n.npmPackage,maxDepth:Gl})}function Wl(t){let e=/^\s*(\d+)\.(\d+)\.(\d+)/.exec(t);return e?[Number(e[1]),Number(e[2]),Number(e[3])]:null}function ql(t,e){let n=Wl(t);if(!n)return!0;let r=/^\^(\d+)\.(\d+)(?:\.(\d+))?$/.exec(e.trim());if(!r)return!0;let[i,s,o]=n,a=Number(r[1]),c=Number(r[2]),l=r[3]!==void 0?Number(r[3]):0;return i>a||i===a&&(s>c||s===c&&o>=l)?a>=1?i===a:c>=1?i===0&&s===c:i===0&&s===0&&o===l:!1}async function Vl(t,e,n){let r=`${t}@${e}`;ce.info("npm install -g start",{npmPackage:t,versionSpec:e});let i=Date.now(),s=process.platform==="win32";return new Promise((o,a)=>{let c=Fe("npm",["install","-g",r],{stdio:["ignore","pipe","pipe"],...s?{}:{detached:!0}});if(!c.pid){c.once("error",y=>{ce.warn("npm spawn failed (no pid, error swallowed)",{npmPackage:t,err:String(y)})}),a(new Error(`failed to spawn npm: no pid (npmPackage=${t})`));return}let l=c.pid,d=10*1024*1024,p=[],m=[],u=0,h=0;c.stdout?.on("data",y=>{u+=y.length,u<d&&p.push(y)}),c.stderr?.on("data",y=>{h+=y.length,h<d&&m.push(y)});let g="running",w,S=y=>{try{return s?c.kill(y):process.kill(-l,y),!0}catch(E){return ce.warn("npm install: kill failed (process already dead?)",{npmPackage:t,pid:l,sig:y,err:String(E)}),!1}},v=setTimeout(()=>{g="terminating",ce.warn("npm install timeout, sending SIGTERM to process group",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i,timeoutMs:Gi,graceMs:Hi,stdoutBytes:u,stderrBytes:h}),S("SIGTERM"),w=setTimeout(()=>{g="killing",ce.warn("npm install SIGTERM grace expired, escalating to SIGKILL",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i,stdoutBytes:u,stderrBytes:h}),S("SIGKILL")},Hi)},Gi),f=()=>{g="aborted",ce.warn("npm install externally aborted, sending SIGKILL to process group",{npmPackage:t,versionSpec:e,pid:l,elapsedMs:Date.now()-i}),S("SIGKILL")};n&&(n.aborted?f():n.addEventListener("abort",f,{once:!0})),c.on("error",y=>{clearTimeout(v),w&&clearTimeout(w),n?.removeEventListener("abort",f),ce.warn("npm install spawn error",{npmPackage:t,versionSpec:e,pid:l,err:String(y)}),a(new Error(`spawn npm failed: ${String(y)}`))}),c.on("close",(y,E)=>{clearTimeout(v),w&&clearTimeout(w),n?.removeEventListener("abort",f);let T=Buffer.concat(p).toString("utf8"),R=Buffer.concat(m).toString("utf8"),D=Date.now()-i;if(y===0&&g==="running"){ce.info("npm install -g done",{npmPackage:t,versionSpec:e,elapsedMs:D}),o();return}ce.warn("npm install -g exited non-success",{npmPackage:t,versionSpec:e,pid:l,phase:g,exitCode:y,signal:E,elapsedMs:D,stdoutBytes:u,stderrBytes:h});let C=Object.assign(new Error(`Command failed: npm install -g ${r}${E?` (killed by ${E})`:""}${y!==null?` (exit ${y})`:""}${g!=="running"?` (phase=${g})`:""}`),{code:y,signal:E,stderr:R,stdout:T});a(C)})})}function Jl(t){let{framework:e,npmPackage:n,versionSpec:r,command:i,reason:s,elapsedMs:o}=t;return["ACP wrapper \u5B89\u88C5\u5931\u8D25",`Framework: ${e}`,`Package: ${n}@${r}`,`\u6267\u884C\u547D\u4EE4: ${i}`,`\u5931\u8D25\u539F\u56E0: ${s}`,`\u8017\u65F6: ${o}ms`,"","\u6392\u67E5\u5EFA\u8BAE:"," 1. \u68C0\u67E5\u7F51\u7EDC: curl -v https://registry.npmjs.org"," 2. \u67E5\u770B\u5F53\u524D npm \u6E90: npm config get registry"," 3. \u56FD\u5185\u7F51\u7EDC\u5EFA\u8BAE\u5207\u955C\u50CF\u6E90:"," npm config set registry https://registry.npmmirror.com/"].join(`
12
+ `)}async function en(t,e){let n=Jo[t];if(!n)throw new _("BRIDGE_INTERNAL",`ensureAcpInstalled called for non-npm framework: ${t}`);let r=Cn.get(t);if(r)return r;let i=Dn.get(t);if(i)return i;let s=`npm install -g ${n.npmPackage}@${n.versionSpec}`,o=(c,l,d)=>new _("AGENT_DEPENDENCY_INSTALL_FAILED",Jl({framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,command:s,reason:c,elapsedMs:l}),d!==void 0?{cause:d}:{}),a=(async()=>{let c=await $l(n.binary);if(c){let p=process.env.COZE_BRIDGE_ACP_NO_AUTO_UPGRADE==="1",m=p?void 0:await jl(t,c);if(p||ql(m??"",n.versionSpec))return Cn.set(t,c),ce.info("acp wrapper found on PATH",{binary:n.binary,path:c,version:m??(p?"unchecked (auto-upgrade off)":"unknown"),spec:n.versionSpec}),c;ce.info("acp wrapper on PATH but version out of spec \u2014 reinstalling to locked range",{binary:n.binary,path:c,installed:m,spec:n.versionSpec})}let l=Date.now();try{await Vl(n.npmPackage,n.versionSpec,e)}catch(p){let m=Hl(p);throw ce.warn("acp wrapper install failed",{framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,binary:n.binary,err:m}),o(m,Date.now()-l,p)}let d=await $l(n.binary);if(!d)throw ce.warn("acp wrapper installed but binary not found on PATH",{framework:t,npmPackage:n.npmPackage,versionSpec:n.versionSpec,binary:n.binary}),o(`npm install \u6210\u529F\u4F46 \`${process.platform==="win32"?"where":"which"} ${n.binary}\` \u627E\u4E0D\u5230 binary (npm prefix \u53EF\u80FD\u672A\u52A0\u5165 PATH, \u6216\u88AB\u88C5\u5230\u4E86 nvm/asdf \u522B\u7684\u7248\u672C\u4E0B)`,Date.now()-l);return Cn.set(t,d),d})().finally(()=>{Dn.delete(t)});return Dn.set(t,a),a}function br(t){return Cn.get(t)}function Ar(t,e){if(e)return e;let n=br(t);if(!n)throw new _("BRIDGE_INTERNAL",`${t} ACP wrapper binary path cache miss (ensureAcpInstalled \u672A\u5728\u6784\u9020\u524D\u8DD1\u901A)`);return n}function Zo(t){return Dn.get(t)}function hm(){Cn.clear(),Dn.clear()}function pm(t,e){Dn.set(t,e)}function gm(t,e){Cn.set(t,e)}var ce,Jo,Gi,Hi,dm,Cn,Dn,Gl,tn=ve(()=>{"use strict";gt();Te();L();ce=b("agents.acp-installer"),Jo={"claude-code":{npmPackage:"@agentclientprotocol/claude-agent-acp",binary:"claude-agent-acp",versionSpec:"^0.39"},codex:{npmPackage:"@zed-industries/codex-acp",binary:"codex-acp",versionSpec:"^0.15"}};Gi=5e4,Hi=5e3,dm=5e3;Cn=new Map,Dn=new Map;Gl=6});import{chmod as wm,mkdir as ym,readFile as _m,rename as Yl,writeFile as Ql}from"node:fs/promises";import{dirname as Em}from"node:path";async function Nn(t){try{let e=await _m(t,"utf8");return JSON.parse(e)}catch(e){if(e.code==="ENOENT")return null;throw e}}async function Wi(t,e,n){await ym(Em(t),{recursive:!0});let r=`${JSON.stringify(e,null,2)}
13
+ `,i=`${t}.tmp-${process.pid}-${Math.random().toString(36).slice(2,10)}`;try{n?.mode!==void 0?await Ql(i,r,{encoding:"utf8",mode:n.mode}):await Ql(i,r,"utf8"),await Yl(i,t),n?.mode!==void 0&&await wm(t,n.mode)}catch(s){await Yl(i,i).catch(()=>{});let{rm:o}=await import("node:fs/promises");throw await o(i,{force:!0}).catch(()=>{}),s}}var qi=ve(()=>{"use strict"});import{promises as ed,readdirSync as Sm}from"node:fs";import{homedir as vm}from"node:os";import{sep as Im,join as ne,resolve as td}from"node:path";function F(t){let e=t??vm(),n=ne(e,".coze"),r=ne(n,"bridge"),i=ne(r,"lib"),s=ne(r,"logs");return{cozeRoot:n,bridgeRoot:r,libDir:i,libEntry:ne(i,"index.js"),binDir:ne(r,"bin"),pidFile:ne(r,"bridge.pid"),portFile:ne(r,"bridge.port"),tokenFile:ne(r,"bridge.token"),patTokenFile:ne(r,"pat-token"),logFile:ne(r,"bridge.log"),bridgeLogsDir:s,daemonStdioLog:ne(s,"daemon-stdio.log"),installLock:ne(r,"install.lock"),configFile:ne(r,"config.json"),agentsRoot:ne(n,"agents")}}function be(t,e=F()){let n=ne(e.agentsRoot,t);return{root:n,config:ne(n,"config.json"),workspace:ne(n,"workspace"),logs:ne(n,"logs")}}function Vi(t=F()){try{return Sm(t.agentsRoot,{withFileTypes:!0}).filter(e=>e.isDirectory()).map(e=>e.name)}catch{return[]}}async function xr(t,e){let n=await ed.realpath(td(t)).catch(()=>null);if(!n)return!1;let r=await ed.realpath(td(e)).catch(()=>null);if(!r)return!1;let i=process.platform==="win32"?n.toLowerCase():n,s=process.platform==="win32"?r.toLowerCase():r;return i===s||i.startsWith(s+Im)}var le=ve(()=>{"use strict"});var Ki={};Li(Ki,{AGENT_CONFIG_FILE_MODE:()=>Ji,enforceAgentConfigMode:()=>km,loadAgentConfig:()=>me,persistAgentSessions:()=>Or,persistAgentSkills:()=>Zi,saveAgentConfig:()=>Ae});import{chmod as Tm,stat as Rm}from"node:fs/promises";function me(t,e){return Nn(be(t,e).config)}function Ae(t,e){return Wi(be(t.agentId,e).config,t,{mode:Ji})}async function km(t,e){if(process.platform==="win32")return;let n=be(t,e).config;try{let r=await Rm(n);if(!r.isFile())return;let i=r.mode&511;i!==Ji&&(await Tm(n,Ji),nd.warn("agent config mode auto-corrected to 0600",{path:n,from:i.toString(8)}))}catch(r){if(r.code==="ENOENT")return;nd.warn("enforceAgentConfigMode: chmod failed (ignored)",{path:n,err:String(r)})}}async function Or(t,e,n){let r=await me(t,n);r&&(r.sessions=Object.fromEntries(e),await Ae(r,n))}async function Zi(t,e,n){let r=await me(t,n);r&&(r.skills=e,await Ae(r,n))}var nd,Ji,At=ve(()=>{"use strict";qi();L();le();nd=b("agent-config"),Ji=384});var Xo=H((PR,od)=>{od.exports={LOCHDR:30,LOCSIG:67324752,LOCVER:4,LOCFLG:6,LOCHOW:8,LOCTIM:10,LOCCRC:14,LOCSIZ:18,LOCLEN:22,LOCNAM:26,LOCEXT:28,EXTSIG:134695760,EXTHDR:16,EXTCRC:4,EXTSIZ:8,EXTLEN:12,CENHDR:46,CENSIG:33639248,CENVEM:4,CENVER:6,CENFLG:8,CENHOW:10,CENTIM:12,CENCRC:16,CENSIZ:20,CENLEN:24,CENNAM:28,CENEXT:30,CENCOM:32,CENDSK:34,CENATT:36,CENATX:38,CENOFF:42,ENDHDR:22,ENDSIG:101010256,ENDSUB:8,ENDTOT:10,ENDSIZ:12,ENDOFF:16,ENDCOM:20,END64HDR:20,END64SIG:117853008,END64START:4,END64OFF:8,END64NUMDISKS:16,ZIP64SIG:101075792,ZIP64HDR:56,ZIP64LEAD:12,ZIP64SIZE:4,ZIP64VEM:12,ZIP64VER:14,ZIP64DSK:16,ZIP64DSKDIR:20,ZIP64SUB:24,ZIP64TOT:32,ZIP64SIZB:40,ZIP64OFF:48,ZIP64EXTRA:56,STORED:0,SHRUNK:1,REDUCED1:2,REDUCED2:3,REDUCED3:4,REDUCED4:5,IMPLODED:6,DEFLATED:8,ENHANCED_DEFLATED:9,PKWARE:10,BZIP2:12,LZMA:14,IBM_TERSE:18,IBM_LZ77:19,AES_ENCRYPT:99,FLG_ENC:1,FLG_COMP1:2,FLG_COMP2:4,FLG_DESC:8,FLG_ENH:16,FLG_PATCH:32,FLG_STR:64,FLG_EFS:2048,FLG_MSK:4096,FILE:2,BUFFER:1,NONE:0,EF_ID:0,EF_SIZE:2,ID_ZIP64:1,ID_AVINFO:7,ID_PFS:8,ID_OS2:9,ID_NTFS:10,ID_OPENVMS:12,ID_UNIX:13,ID_FORK:14,ID_PATCH:15,ID_X509_PKCS7:20,ID_X509_CERTID_F:21,ID_X509_CERTID_C:22,ID_STRONGENC:23,ID_RECORD_MGT:24,ID_X509_PKCS7_RL:25,ID_IBM1:101,ID_IBM2:102,ID_POSZIP:18064,EF_ZIP64_OR_32:4294967295,EF_ZIP64_OR_16:65535,EF_ZIP64_SUNCOMP:0,EF_ZIP64_SCOMP:8,EF_ZIP64_RHO:16,EF_ZIP64_DSN:24}});var Yi=H(cd=>{var ad={INVALID_LOC:"Invalid LOC header (bad signature)",INVALID_CEN:"Invalid CEN header (bad signature)",INVALID_END:"Invalid END header (bad signature)",DESCRIPTOR_NOT_EXIST:"No descriptor present",DESCRIPTOR_UNKNOWN:"Unknown descriptor format",DESCRIPTOR_FAULTY:"Descriptor data is malformed",NO_DATA:"Nothing to decompress",BAD_CRC:"CRC32 checksum failed {0}",FILE_IN_THE_WAY:"There is a file in the way: {0}",UNKNOWN_METHOD:"Invalid/unsupported compression method",AVAIL_DATA:"inflate::Available inflate data did not terminate",INVALID_DISTANCE:"inflate::Invalid literal/length or distance code in fixed or dynamic block",TO_MANY_CODES:"inflate::Dynamic block code description: too many length or distance codes",INVALID_REPEAT_LEN:"inflate::Dynamic block code description: repeat more than specified lengths",INVALID_REPEAT_FIRST:"inflate::Dynamic block code description: repeat lengths with no first length",INCOMPLETE_CODES:"inflate::Dynamic block code description: code lengths codes incomplete",INVALID_DYN_DISTANCE:"inflate::Dynamic block code description: invalid distance code lengths",INVALID_CODES_LEN:"inflate::Dynamic block code description: invalid literal/length code lengths",INVALID_STORE_BLOCK:"inflate::Stored block length did not match one's complement",INVALID_BLOCK_TYPE:"inflate::Invalid block type (type == 3)",CANT_EXTRACT_FILE:"Could not extract the file",CANT_OVERRIDE:"Target file already exists",DISK_ENTRY_TOO_LARGE:"Number of disk entries is too large",NO_ZIP:"No zip file was loaded",NO_ENTRY:"Entry doesn't exist",DIRECTORY_CONTENT_ERROR:"A directory cannot have content",FILE_NOT_FOUND:'File not found: "{0}"',NOT_IMPLEMENTED:"Not implemented",INVALID_FILENAME:"Invalid filename",INVALID_FORMAT:"Invalid or unsupported zip format. No END header found",INVALID_PASS_PARAM:"Incompatible password parameter",WRONG_PASSWORD:"Wrong Password",COMMENT_TOO_LONG:"Comment is too long",EXTRA_FIELD_PARSE_ERROR:"Extra field parsing error"};function Pm(t){return function(...e){return e.length&&(t=t.replace(/\{(\d)\}/g,(n,r)=>e[r]||"")),new Error("ADM-ZIP: "+t)}}for(let t of Object.keys(ad))cd[t]=Pm(ad[t])});var hd=H((DR,fd)=>{var Cm=j("fs"),re=j("path"),ld=Xo(),Dm=Yi(),Nm=typeof process=="object"&&process.platform==="win32",dd=t=>typeof t=="object"&&t!==null,ud=new Uint32Array(256).map((t,e)=>{for(let n=0;n<8;n++)(e&1)!==0?e=3988292384^e>>>1:e>>>=1;return e>>>0});function X(t){this.sep=re.sep,this.fs=Cm,dd(t)&&dd(t.fs)&&typeof t.fs.statSync=="function"&&(this.fs=t.fs)}fd.exports=X;X.prototype.makeDir=function(t){let e=this;function n(r){let i=r.split(e.sep)[0];r.split(e.sep).forEach(function(s){if(!(!s||s.substr(-1,1)===":")){i+=e.sep+s;var o;try{o=e.fs.statSync(i)}catch(a){if(a.message&&a.message.startsWith("ENOENT"))e.fs.mkdirSync(i);else throw a}if(o&&o.isFile())throw Dm.FILE_IN_THE_WAY(`"${i}"`)}})}n(t)};X.prototype.writeFileTo=function(t,e,n,r){let i=this;if(i.fs.existsSync(t)){if(!n)return!1;var s=i.fs.statSync(t);if(s.isDirectory())return!1}var o=re.dirname(t);i.fs.existsSync(o)||i.makeDir(o);var a;try{a=i.fs.openSync(t,"w",438)}catch{i.fs.chmodSync(t,438),a=i.fs.openSync(t,"w",438)}if(a)try{i.fs.writeSync(a,e,0,e.length,0)}finally{i.fs.closeSync(a)}return i.fs.chmodSync(t,r||438),!0};X.prototype.writeFileToAsync=function(t,e,n,r,i){typeof r=="function"&&(i=r,r=void 0);let s=this;s.fs.exists(t,function(o){if(o&&!n)return i(!1);s.fs.stat(t,function(a,c){if(o&&c.isDirectory())return i(!1);var l=re.dirname(t);s.fs.exists(l,function(d){d||s.makeDir(l),s.fs.open(t,"w",438,function(p,m){p?s.fs.chmod(t,438,function(){s.fs.open(t,"w",438,function(u,h){s.fs.write(h,e,0,e.length,0,function(){s.fs.close(h,function(){s.fs.chmod(t,r||438,function(){i(!0)})})})})}):m?s.fs.write(m,e,0,e.length,0,function(){s.fs.close(m,function(){s.fs.chmod(t,r||438,function(){i(!0)})})}):s.fs.chmod(t,r||438,function(){i(!0)})})})})})};X.prototype.findFiles=function(t){let e=this;function n(r,i,s){typeof i=="boolean"&&(s=i,i=void 0);let o=[];return e.fs.readdirSync(r).forEach(function(a){let c=re.join(r,a),l=e.fs.statSync(c);(!i||i.test(c))&&o.push(re.normalize(c)+(l.isDirectory()?e.sep:"")),l.isDirectory()&&s&&(o=o.concat(n(c,i,s)))}),o}return n(t,void 0,!0)};X.prototype.findFilesAsync=function(t,e){let n=this,r=[];n.fs.readdir(t,function(i,s){if(i)return e(i);let o=s.length;if(!o)return e(null,r);s.forEach(function(a){a=re.join(t,a),n.fs.stat(a,function(c,l){if(c)return e(c);l&&(r.push(re.normalize(a)+(l.isDirectory()?n.sep:"")),l.isDirectory()?n.findFilesAsync(a,function(d,p){if(d)return e(d);r=r.concat(p),--o||e(null,r)}):--o||e(null,r))})})})};X.prototype.getAttributes=function(){};X.prototype.setAttributes=function(){};X.crc32update=function(t,e){return ud[(t^e)&255]^t>>>8};X.crc32=function(t){typeof t=="string"&&(t=Buffer.from(t,"utf8"));let e=t.length,n=-1;for(let r=0;r<e;)n=X.crc32update(n,t[r++]);return~n>>>0};X.methodToString=function(t){switch(t){case ld.STORED:return"STORED ("+t+")";case ld.DEFLATED:return"DEFLATED ("+t+")";default:return"UNSUPPORTED ("+t+")"}};X.canonical=function(t){if(!t)return"";let e=re.posix.normalize("/"+t.split("\\").join("/"));return re.join(".",e)};X.zipnamefix=function(t){if(!t)return"";let e=re.posix.normalize("/"+t.split("\\").join("/"));return re.posix.join(".",e)};X.findLast=function(t,e){if(!Array.isArray(t))throw new TypeError("arr is not array");let n=t.length>>>0;for(let r=n-1;r>=0;r--)if(e(t[r],r,t))return t[r]};X.sanitize=function(t,e){t=re.resolve(re.normalize(t));for(var n=e.split("/"),r=0,i=n.length;r<i;r++){var s=re.normalize(re.join(t,n.slice(r,i).join(re.sep)));if(s.indexOf(t)===0)return s}return re.normalize(re.join(t,re.basename(e)))};X.toBuffer=function(e,n){return Buffer.isBuffer(e)?e:e instanceof Uint8Array?Buffer.from(e):typeof e=="string"?n(e):Buffer.alloc(0)};X.readBigUInt64LE=function(t,e){let n=t.readUInt32LE(e);return t.readUInt32LE(e+4)*4294967296+n};X.fromDOS2Date=function(t){return new Date((t>>25&127)+1980,Math.max((t>>21&15)-1,0),Math.max(t>>16&31,1),t>>11&31,t>>5&63,(t&31)<<1)};X.fromDate2DOS=function(t){let e=0,n=0;return t.getFullYear()>1979&&(e=(t.getFullYear()-1980&127)<<9|t.getMonth()+1<<5|t.getDate(),n=t.getHours()<<11|t.getMinutes()<<5|t.getSeconds()>>1),e<<16|n};X.isWin=Nm;X.crcTable=ud});var gd=H((NR,pd)=>{var Lm=j("path");pd.exports=function(t,{fs:e}){var n=t||"",r=s(),i=null;function s(){return{directory:!1,readonly:!1,hidden:!1,executable:!1,mtime:0,atime:0}}return n&&e.existsSync(n)?(i=e.statSync(n),r.directory=i.isDirectory(),r.mtime=i.mtime,r.atime=i.atime,r.executable=(73&i.mode)!==0,r.readonly=(128&i.mode)===0,r.hidden=Lm.basename(n)[0]==="."):console.warn("Invalid path: "+n),{get directory(){return r.directory},get readOnly(){return r.readonly},get hidden(){return r.hidden},get mtime(){return r.mtime},get atime(){return r.atime},get executable(){return r.executable},decodeAttributes:function(){},encodeAttributes:function(){},toJSON:function(){return{path:n,isDirectory:r.directory,isReadOnly:r.readonly,isHidden:r.hidden,isExecutable:r.executable,mTime:r.mtime,aTime:r.atime}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var wd=H((LR,md)=>{md.exports={efs:!0,encode:t=>Buffer.from(t,"utf8"),decode:t=>t.toString("utf8")}});var Mn=H((FR,Fn)=>{Fn.exports=hd();Fn.exports.Constants=Xo();Fn.exports.Errors=Yi();Fn.exports.FileAttr=gd();Fn.exports.decoder=wd()});var _d=H((MR,yd)=>{var xt=Mn(),k=xt.Constants;yd.exports=function(){var t=20,e=10,n=0,r=0,i=0,s=0,o=0,a=0,c=0,l=0,d=0,p=0,m=0,u=0,h=0;t|=xt.isWin?2560:768,n|=k.FLG_EFS;let g={extraLen:0},w=f=>Math.max(0,f)>>>0,S=f=>Math.max(0,f)&65535,v=f=>Math.max(0,f)&255;return i=xt.fromDate2DOS(new Date),{get made(){return t},set made(f){t=f},get version(){return e},set version(f){e=f},get flags(){return n},set flags(f){n=f},get flags_efs(){return(n&k.FLG_EFS)>0},set flags_efs(f){f?n|=k.FLG_EFS:n&=~k.FLG_EFS},get flags_desc(){return(n&k.FLG_DESC)>0},set flags_desc(f){f?n|=k.FLG_DESC:n&=~k.FLG_DESC},get method(){return r},set method(f){switch(f){case k.STORED:this.version=10;case k.DEFLATED:default:this.version=20}r=f},get time(){return xt.fromDOS2Date(this.timeval)},set time(f){f=new Date(f),this.timeval=xt.fromDate2DOS(f)},get timeval(){return i},set timeval(f){i=w(f)},get timeHighByte(){return v(i>>>8)},get crc(){return s},set crc(f){s=w(f)},get compressedSize(){return o},set compressedSize(f){o=w(f)},get size(){return a},set size(f){a=w(f)},get fileNameLength(){return c},set fileNameLength(f){c=f},get extraLength(){return l},set extraLength(f){l=f},get extraLocalLength(){return g.extraLen},set extraLocalLength(f){g.extraLen=f},get commentLength(){return d},set commentLength(f){d=f},get diskNumStart(){return p},set diskNumStart(f){p=w(f)},get inAttr(){return m},set inAttr(f){m=w(f)},get attr(){return u},set attr(f){u=w(f)},get fileAttr(){return(u||0)>>16&4095},get offset(){return h},set offset(f){h=w(f)},get encrypted(){return(n&k.FLG_ENC)===k.FLG_ENC},get centralHeaderSize(){return k.CENHDR+c+l+d},get realDataOffset(){return h+k.LOCHDR+g.fnameLen+g.extraLen},get localHeader(){return g},loadLocalHeaderFromBinary:function(f){var y=f.slice(h,h+k.LOCHDR);if(y.readUInt32LE(0)!==k.LOCSIG)throw xt.Errors.INVALID_LOC();g.version=y.readUInt16LE(k.LOCVER),g.flags=y.readUInt16LE(k.LOCFLG),g.flags_desc=(g.flags&k.FLG_DESC)>0,g.method=y.readUInt16LE(k.LOCHOW),g.time=y.readUInt32LE(k.LOCTIM),g.crc=y.readUInt32LE(k.LOCCRC),g.compressedSize=y.readUInt32LE(k.LOCSIZ),g.size=y.readUInt32LE(k.LOCLEN),g.fnameLen=y.readUInt16LE(k.LOCNAM),g.extraLen=y.readUInt16LE(k.LOCEXT);let E=h+k.LOCHDR+g.fnameLen,T=E+g.extraLen;return f.slice(E,T)},loadFromBinary:function(f){if(f.length!==k.CENHDR||f.readUInt32LE(0)!==k.CENSIG)throw xt.Errors.INVALID_CEN();t=f.readUInt16LE(k.CENVEM),e=f.readUInt16LE(k.CENVER),n=f.readUInt16LE(k.CENFLG),r=f.readUInt16LE(k.CENHOW),i=f.readUInt32LE(k.CENTIM),s=f.readUInt32LE(k.CENCRC),o=f.readUInt32LE(k.CENSIZ),a=f.readUInt32LE(k.CENLEN),c=f.readUInt16LE(k.CENNAM),l=f.readUInt16LE(k.CENEXT),d=f.readUInt16LE(k.CENCOM),p=f.readUInt16LE(k.CENDSK),m=f.readUInt16LE(k.CENATT),u=f.readUInt32LE(k.CENATX),h=f.readUInt32LE(k.CENOFF)},localHeaderToBinary:function(){var f=Buffer.alloc(k.LOCHDR);return f.writeUInt32LE(k.LOCSIG,0),f.writeUInt16LE(e,k.LOCVER),f.writeUInt16LE(n,k.LOCFLG),f.writeUInt16LE(r,k.LOCHOW),f.writeUInt32LE(i,k.LOCTIM),f.writeUInt32LE(s,k.LOCCRC),f.writeUInt32LE(o,k.LOCSIZ),f.writeUInt32LE(a,k.LOCLEN),f.writeUInt16LE(c,k.LOCNAM),f.writeUInt16LE(g.extraLen,k.LOCEXT),f},centralHeaderToBinary:function(){var f=Buffer.alloc(k.CENHDR+c+l+d);return f.writeUInt32LE(k.CENSIG,0),f.writeUInt16LE(t,k.CENVEM),f.writeUInt16LE(e,k.CENVER),f.writeUInt16LE(n,k.CENFLG),f.writeUInt16LE(r,k.CENHOW),f.writeUInt32LE(i,k.CENTIM),f.writeUInt32LE(s,k.CENCRC),f.writeUInt32LE(o,k.CENSIZ),f.writeUInt32LE(a,k.CENLEN),f.writeUInt16LE(c,k.CENNAM),f.writeUInt16LE(l,k.CENEXT),f.writeUInt16LE(d,k.CENCOM),f.writeUInt16LE(p,k.CENDSK),f.writeUInt16LE(m,k.CENATT),f.writeUInt32LE(u,k.CENATX),f.writeUInt32LE(h,k.CENOFF),f},toJSON:function(){let f=function(y){return y+" bytes"};return{made:t,version:e,flags:n,method:xt.methodToString(r),time:this.time,crc:"0x"+s.toString(16).toUpperCase(),compressedSize:f(o),size:f(a),fileNameLength:f(c),extraLength:f(l),commentLength:f(d),diskNumStart:p,inAttr:m,attr:u,offset:h,centralHeaderSize:f(k.CENHDR+c+l+d)}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Sd=H((BR,Ed)=>{var Bn=Mn(),V=Bn.Constants;Ed.exports=function(){var t=0,e=0,n=0,r=0,i=0;return{get diskEntries(){return t},set diskEntries(s){t=e=s},get totalEntries(){return e},set totalEntries(s){e=t=s},get size(){return n},set size(s){n=s},get offset(){return r},set offset(s){r=s},get commentLength(){return i},set commentLength(s){i=s},get mainHeaderSize(){return V.ENDHDR+i},loadFromBinary:function(s){if((s.length!==V.ENDHDR||s.readUInt32LE(0)!==V.ENDSIG)&&(s.length<V.ZIP64HDR||s.readUInt32LE(0)!==V.ZIP64SIG))throw Bn.Errors.INVALID_END();s.readUInt32LE(0)===V.ENDSIG?(t=s.readUInt16LE(V.ENDSUB),e=s.readUInt16LE(V.ENDTOT),n=s.readUInt32LE(V.ENDSIZ),r=s.readUInt32LE(V.ENDOFF),i=s.readUInt16LE(V.ENDCOM)):(t=Bn.readBigUInt64LE(s,V.ZIP64SUB),e=Bn.readBigUInt64LE(s,V.ZIP64TOT),n=Bn.readBigUInt64LE(s,V.ZIP64SIZE),r=Bn.readBigUInt64LE(s,V.ZIP64OFF),i=0)},toBinary:function(){var s=Buffer.alloc(V.ENDHDR+i);return s.writeUInt32LE(V.ENDSIG,0),s.writeUInt32LE(0,4),s.writeUInt16LE(t,V.ENDSUB),s.writeUInt16LE(e,V.ENDTOT),s.writeUInt32LE(n,V.ENDSIZ),s.writeUInt32LE(r,V.ENDOFF),s.writeUInt16LE(i,V.ENDCOM),s.fill(" ",V.ENDHDR),s},toJSON:function(){let s=function(o,a){let c=o.toString(16).toUpperCase();for(;c.length<a;)c="0"+c;return"0x"+c};return{diskEntries:t,totalEntries:e,size:n+" bytes",offset:s(r,4),commentLength:i}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Qo=H(Yo=>{Yo.EntryHeader=_d();Yo.MainHeader=Sd()});var Id=H((zR,vd)=>{vd.exports=function(t){var e=j("zlib"),n={chunkSize:(parseInt(t.length/1024)+1)*1024};return{deflate:function(){return e.deflateRawSync(t,n)},deflateAsync:function(r){var i=e.createDeflateRaw(n),s=[],o=0;i.on("data",function(a){s.push(a),o+=a.length}),i.on("end",function(){var a=Buffer.alloc(o),c=0;a.fill(0);for(var l=0;l<s.length;l++){var d=s[l];d.copy(a,c),c+=d.length}r&&r(a)}),i.end(t)}}}});var Rd=H(($R,Td)=>{var Fm=+(process.versions?process.versions.node:"").split(".")[0]||0;Td.exports=function(t,e){var n=j("zlib");let r=Fm>=15&&e>0?{maxOutputLength:e}:{};return{inflate:function(){return n.inflateRawSync(t,r)},inflateAsync:function(i){var s=n.createInflateRaw(r),o=[],a=0;s.on("data",function(c){o.push(c),a+=c.length}),s.on("end",function(){var c=Buffer.alloc(a),l=0;c.fill(0);for(var d=0;d<o.length;d++){var p=o[d];p.copy(c,l),l+=p.length}i&&i(c)}),s.end(t)}}}});var Od=H((GR,xd)=>{"use strict";var{randomFillSync:kd}=j("crypto"),Mm=Yi(),Bm=new Uint32Array(256).map((t,e)=>{for(let n=0;n<8;n++)(e&1)!==0?e=e>>>1^3988292384:e>>>=1;return e>>>0}),Ad=(t,e)=>Math.imul(t,e)>>>0,bd=(t,e)=>Bm[(t^e)&255]^t>>>8,Pr=()=>typeof kd=="function"?kd(Buffer.alloc(12)):Pr.node();Pr.node=()=>{let t=Buffer.alloc(12),e=t.length;for(let n=0;n<e;n++)t[n]=Math.random()*256&255;return t};var Qi={genSalt:Pr};function es(t){let e=Buffer.isBuffer(t)?t:Buffer.from(t);this.keys=new Uint32Array([305419896,591751049,878082192]);for(let n=0;n<e.length;n++)this.updateKeys(e[n])}es.prototype.updateKeys=function(t){let e=this.keys;return e[0]=bd(e[0],t),e[1]+=e[0]&255,e[1]=Ad(e[1],134775813)+1,e[2]=bd(e[2],e[1]>>>24),t};es.prototype.next=function(){let t=(this.keys[2]|2)>>>0;return Ad(t,t^1)>>8&255};function Um(t){let e=new es(t);return function(n){let r=Buffer.alloc(n.length),i=0;for(let s of n)r[i++]=e.updateKeys(s^e.next());return r}}function zm(t){let e=new es(t);return function(n,r,i=0){r||(r=Buffer.alloc(n.length));for(let s of n){let o=e.next();r[i++]=s^o,e.updateKeys(s)}return r}}function $m(t,e,n){if(!t||!Buffer.isBuffer(t)||t.length<12)return Buffer.alloc(0);let r=Um(n),i=r(t.slice(0,12)),s=(e.flags&8)===8?e.timeHighByte:e.crc>>>24;if(i[11]!==s)throw Mm.WRONG_PASSWORD();return r(t.slice(12))}function Gm(t){Buffer.isBuffer(t)&&t.length>=12?Qi.genSalt=function(){return t.slice(0,12)}:t==="node"?Qi.genSalt=Pr.node:Qi.genSalt=Pr}function Hm(t,e,n,r=!1){t==null&&(t=Buffer.alloc(0)),Buffer.isBuffer(t)||(t=Buffer.from(t.toString()));let i=zm(n),s=Qi.genSalt();s[11]=e.crc>>>24&255,r&&(s[10]=e.crc>>>16&255);let o=Buffer.alloc(t.length+12);return i(s,o),i(t,o,12)}xd.exports={decrypt:$m,encrypt:Hm,_salter:Gm}});var Pd=H(ts=>{ts.Deflater=Id();ts.Inflater=Rd();ts.ZipCrypto=Od()});var ta=H((jR,Cd)=>{var z=Mn(),jm=Qo(),Y=z.Constants,ea=Pd();Cd.exports=function(t,e){var n=new jm.EntryHeader,r=Buffer.alloc(0),i=Buffer.alloc(0),s=!1,o=null,a=Buffer.alloc(0),c=Buffer.alloc(0),l=!0;let d=t,p=typeof d.decoder=="object"?d.decoder:z.decoder;l=p.hasOwnProperty("efs")?p.efs:!1;function m(){return!e||!(e instanceof Uint8Array)?Buffer.alloc(0):(c=n.loadLocalHeaderFromBinary(e),e.slice(n.realDataOffset,n.realDataOffset+n.compressedSize))}function u(f){if(!n.flags_desc&&!n.localHeader.flags_desc){if(z.crc32(f)!==n.localHeader.crc)return!1}else{let y={},E=n.realDataOffset+n.compressedSize;if(e.readUInt32LE(E)==Y.LOCSIG||e.readUInt32LE(E)==Y.CENSIG)throw z.Errors.DESCRIPTOR_NOT_EXIST();if(e.readUInt32LE(E)==Y.EXTSIG)y.crc=e.readUInt32LE(E+Y.EXTCRC),y.compressedSize=e.readUInt32LE(E+Y.EXTSIZ),y.size=e.readUInt32LE(E+Y.EXTLEN);else if(e.readUInt16LE(E+12)===19280)y.crc=e.readUInt32LE(E+Y.EXTCRC-4),y.compressedSize=e.readUInt32LE(E+Y.EXTSIZ-4),y.size=e.readUInt32LE(E+Y.EXTLEN-4);else throw z.Errors.DESCRIPTOR_UNKNOWN();if(y.compressedSize!==n.compressedSize||y.size!==n.size||y.crc!==n.crc)throw z.Errors.DESCRIPTOR_FAULTY();if(z.crc32(f)!==y.crc)return!1}return!0}function h(f,y,E){if(typeof y>"u"&&typeof f=="string"&&(E=f,f=void 0),s)return f&&y&&y(Buffer.alloc(0),z.Errors.DIRECTORY_CONTENT_ERROR()),Buffer.alloc(0);var T=m();if(T.length===0)return f&&y&&y(T),T;if(n.encrypted){if(typeof E!="string"&&!Buffer.isBuffer(E))throw z.Errors.INVALID_PASS_PARAM();T=ea.ZipCrypto.decrypt(T,n,E)}var R=Buffer.alloc(n.size);switch(n.method){case z.Constants.STORED:if(T.copy(R),u(R))return f&&y&&y(R),R;throw f&&y&&y(R,z.Errors.BAD_CRC()),z.Errors.BAD_CRC();case z.Constants.DEFLATED:var D=new ea.Inflater(T,n.size);if(f)D.inflateAsync(function(C){C.copy(C,0),y&&(u(C)?y(C):y(C,z.Errors.BAD_CRC()))});else{if(D.inflate(R).copy(R,0),!u(R))throw z.Errors.BAD_CRC(`"${p.decode(r)}"`);return R}break;default:throw f&&y&&y(Buffer.alloc(0),z.Errors.UNKNOWN_METHOD()),z.Errors.UNKNOWN_METHOD()}}function g(f,y){if((!o||!o.length)&&Buffer.isBuffer(e))return f&&y&&y(m()),m();if(o.length&&!s){var E;switch(n.method){case z.Constants.STORED:return n.compressedSize=n.size,E=Buffer.alloc(o.length),o.copy(E),f&&y&&y(E),E;default:case z.Constants.DEFLATED:var T=new ea.Deflater(o);if(f)T.deflateAsync(function(D){E=Buffer.alloc(D.length),n.compressedSize=D.length,D.copy(E),y&&y(E)});else{var R=T.deflate();return n.compressedSize=R.length,R}T=null;break}}else if(f&&y)y(Buffer.alloc(0));else return Buffer.alloc(0)}function w(f,y){return z.readBigUInt64LE(f,y)}function S(f){try{for(var y=0,E,T,R;y+4<f.length;)E=f.readUInt16LE(y),y+=2,T=f.readUInt16LE(y),y+=2,R=f.slice(y,y+T),y+=T,Y.ID_ZIP64===E&&v(R)}catch{throw z.Errors.EXTRA_FIELD_PARSE_ERROR()}}function v(f){var y,E,T,R;f.length>=Y.EF_ZIP64_SCOMP&&(y=w(f,Y.EF_ZIP64_SUNCOMP),n.size===Y.EF_ZIP64_OR_32&&(n.size=y)),f.length>=Y.EF_ZIP64_RHO&&(E=w(f,Y.EF_ZIP64_SCOMP),n.compressedSize===Y.EF_ZIP64_OR_32&&(n.compressedSize=E)),f.length>=Y.EF_ZIP64_DSN&&(T=w(f,Y.EF_ZIP64_RHO),n.offset===Y.EF_ZIP64_OR_32&&(n.offset=T)),f.length>=Y.EF_ZIP64_DSN+4&&(R=f.readUInt32LE(Y.EF_ZIP64_DSN),n.diskNumStart===Y.EF_ZIP64_OR_16&&(n.diskNumStart=R))}return{get entryName(){return p.decode(r)},get rawEntryName(){return r},set entryName(f){r=z.toBuffer(f,p.encode);var y=r[r.length-1];s=y===47||y===92,n.fileNameLength=r.length},get efs(){return typeof l=="function"?l(this.entryName):l},get extra(){return a},set extra(f){a=f,n.extraLength=f.length,S(f)},get comment(){return p.decode(i)},set comment(f){if(i=z.toBuffer(f,p.encode),n.commentLength=i.length,i.length>65535)throw z.Errors.COMMENT_TOO_LONG()},get name(){var f=p.decode(r);return s?f.substr(f.length-1).split("/").pop():f.split("/").pop()},get isDirectory(){return s},getCompressedData:function(){return g(!1,null)},getCompressedDataAsync:function(f){g(!0,f)},setData:function(f){o=z.toBuffer(f,z.decoder.encode),!s&&o.length?(n.size=o.length,n.method=z.Constants.DEFLATED,n.crc=z.crc32(f),n.changed=!0):n.method=z.Constants.STORED},getData:function(f){return n.changed?o:h(!1,null,f)},getDataAsync:function(f,y){n.changed?f(o):h(!0,f,y)},set attr(f){n.attr=f},get attr(){return n.attr},set header(f){n.loadFromBinary(f)},get header(){return n},packCentralHeader:function(){n.flags_efs=this.efs,n.extraLength=a.length;var f=n.centralHeaderToBinary(),y=z.Constants.CENHDR;return r.copy(f,y),y+=r.length,a.copy(f,y),y+=n.extraLength,i.copy(f,y),f},packLocalHeader:function(){let f=0;n.flags_efs=this.efs,n.extraLocalLength=c.length;let y=n.localHeaderToBinary(),E=Buffer.alloc(y.length+r.length+n.extraLocalLength);return y.copy(E,f),f+=y.length,r.copy(E,f),f+=r.length,c.copy(E,f),f+=c.length,E},toJSON:function(){let f=function(y){return"<"+(y&&y.length+" bytes buffer"||"null")+">"};return{entryName:this.entryName,name:this.name,comment:this.comment,isDirectory:this.isDirectory,header:n.toJSON(),compressedData:f(e),data:f(o)}},toString:function(){return JSON.stringify(this.toJSON(),null," ")}}}});var Ld=H((WR,Nd)=>{var Dd=ta(),Wm=Qo(),we=Mn();Nd.exports=function(t,e){var n=[],r={},i=Buffer.alloc(0),s=new Wm.MainHeader,o=!1,a=null;let c=new Set,l=e,{noSort:d,decoder:p}=l;t?h(l.readEntries):o=!0;function m(){let w=new Set;for(let S of Object.keys(r)){let v=S.split("/");if(v.pop(),!!v.length)for(let f=0;f<v.length;f++){let y=v.slice(0,f+1).join("/")+"/";w.add(y)}}for(let S of w)if(!(S in r)){let v=new Dd(l);v.entryName=S,v.attr=16,v.temporary=!0,n.push(v),r[v.entryName]=v,c.add(v)}}function u(){if(o=!0,r={},s.diskEntries>(t.length-s.offset)/we.Constants.CENHDR)throw we.Errors.DISK_ENTRY_TOO_LARGE();n=new Array(s.diskEntries);for(var w=s.offset,S=0;S<n.length;S++){var v=w,f=new Dd(l,t);f.header=t.slice(v,v+=we.Constants.CENHDR),f.entryName=t.slice(v,v+=f.header.fileNameLength),f.header.extraLength&&(f.extra=t.slice(v,v+=f.header.extraLength)),f.header.commentLength&&(f.comment=t.slice(v,v+f.header.commentLength)),w+=f.header.centralHeaderSize,n[S]=f,r[f.entryName]=f}c.clear(),m()}function h(w){var S=t.length-we.Constants.ENDHDR,v=Math.max(0,S-65535),f=v,y=t.length,E=-1,T=0;for(typeof l.trailingSpace=="boolean"&&l.trailingSpace&&(v=0),S;S>=f;S--)if(t[S]===80){if(t.readUInt32LE(S)===we.Constants.ENDSIG){E=S,T=S,y=S+we.Constants.ENDHDR,f=S-we.Constants.END64HDR;continue}if(t.readUInt32LE(S)===we.Constants.END64SIG){f=v;continue}if(t.readUInt32LE(S)===we.Constants.ZIP64SIG){E=S,y=S+we.readBigUInt64LE(t,S+we.Constants.ZIP64SIZE)+we.Constants.ZIP64LEAD;break}}if(E==-1)throw we.Errors.INVALID_FORMAT();s.loadFromBinary(t.slice(E,y)),s.commentLength&&(i=t.slice(T+we.Constants.ENDHDR)),w&&u()}function g(){n.length>1&&!d&&n.sort((w,S)=>w.entryName.toLowerCase().localeCompare(S.entryName.toLowerCase()))}return{get entries(){return o||u(),n.filter(w=>!c.has(w))},get comment(){return p.decode(i)},set comment(w){i=we.toBuffer(w,p.encode),s.commentLength=i.length},getEntryCount:function(){return o?n.length:s.diskEntries},forEach:function(w){this.entries.forEach(w)},getEntry:function(w){return o||u(),r[w]||null},setEntry:function(w){o||u(),n.push(w),r[w.entryName]=w,s.totalEntries=n.length},deleteFile:function(w,S=!0){o||u();let v=r[w];this.getEntryChildren(v,S).map(y=>y.entryName).forEach(this.deleteEntry)},deleteEntry:function(w){o||u();let S=r[w],v=n.indexOf(S);v>=0&&(n.splice(v,1),delete r[w],s.totalEntries=n.length)},getEntryChildren:function(w,S=!0){if(o||u(),typeof w=="object")if(w.isDirectory&&S){let v=[],f=w.entryName;for(let y of n)y.entryName.startsWith(f)&&v.push(y);return v}else return[w];return[]},getChildCount:function(w){if(w&&w.isDirectory){let S=this.getEntryChildren(w);return S.includes(w)?S.length-1:S.length}return 0},compressToBuffer:function(){o||u(),g();let w=[],S=[],v=0,f=0;s.size=0,s.offset=0;let y=0;for(let R of this.entries){let D=R.getCompressedData();R.header.offset=f;let C=R.packLocalHeader(),G=C.length+D.length;f+=G,w.push(C),w.push(D);let M=R.packCentralHeader();S.push(M),s.size+=M.length,v+=G+M.length,y++}v+=s.mainHeaderSize,s.offset=f,s.totalEntries=y,f=0;let E=Buffer.alloc(v);for(let R of w)R.copy(E,f),f+=R.length;for(let R of S)R.copy(E,f),f+=R.length;let T=s.toBinary();return i&&i.copy(T,we.Constants.ENDHDR),T.copy(E,f),t=E,o=!1,E},toAsyncBuffer:function(w,S,v,f){try{o||u(),g();let y=[],E=[],T=0,R=0,D=0;s.size=0,s.offset=0;let C=function(G){if(G.length>0){let M=G.shift(),oe=M.entryName+M.extra.toString();v&&v(oe),M.getCompressedDataAsync(function(Ee){f&&f(oe),M.header.offset=R;let I=M.packLocalHeader(),x=I.length+Ee.length;R+=x,y.push(I),y.push(Ee);let O=M.packCentralHeader();E.push(O),s.size+=O.length,T+=x+O.length,D++,C(G)})}else{T+=s.mainHeaderSize,s.offset=R,s.totalEntries=D,R=0;let M=Buffer.alloc(T);y.forEach(function(Ee){Ee.copy(M,R),R+=Ee.length}),E.forEach(function(Ee){Ee.copy(M,R),R+=Ee.length});let oe=s.toBinary();i&&i.copy(oe,we.Constants.ENDHDR),oe.copy(M,R),t=M,o=!1,w(M)}};C(Array.from(this.entries))}catch(y){S(y)}}}}});var Bd=H((qR,Md)=>{var Z=Mn(),J=j("path"),qm=ta(),Vm=Ld(),nn=(...t)=>Z.findLast(t,e=>typeof e=="boolean"),Fd=(...t)=>Z.findLast(t,e=>typeof e=="string"),Jm=(...t)=>Z.findLast(t,e=>typeof e=="function"),Zm={noSort:!1,readEntries:!1,method:Z.Constants.NONE,fs:null};Md.exports=function(t,e){let n=null,r=Object.assign(Object.create(null),Zm);t&&typeof t=="object"&&(t instanceof Uint8Array||(Object.assign(r,t),t=r.input?r.input:void 0,r.input&&delete r.input),Buffer.isBuffer(t)&&(n=t,r.method=Z.Constants.BUFFER,t=void 0)),Object.assign(r,e);let i=new Z(r);if((typeof r.decoder!="object"||typeof r.decoder.encode!="function"||typeof r.decoder.decode!="function")&&(r.decoder=Z.decoder),t&&typeof t=="string")if(i.fs.existsSync(t))r.method=Z.Constants.FILE,r.filename=t,n=i.fs.readFileSync(t);else throw Z.Errors.INVALID_FILENAME();let s=new Vm(n,r),{canonical:o,sanitize:a,zipnamefix:c}=Z;function l(u){if(u&&s){var h;if(typeof u=="string"&&(h=s.getEntry(J.posix.normalize(u))),typeof u=="object"&&typeof u.entryName<"u"&&typeof u.header<"u"&&(h=s.getEntry(u.entryName)),h)return h}return null}function d(u){let{join:h,normalize:g,sep:w}=J.posix;return h(J.isAbsolute(u)?"/":".",g(w+u.split("\\").join(w)+w))}function p(u){return u instanceof RegExp?(function(h){return function(g){return h.test(g)}})(u):typeof u!="function"?()=>!0:u}let m=(u,h)=>{let g=h.slice(-1);return g=g===i.sep?i.sep:"",J.relative(u,h)+g};return{readFile:function(u,h){var g=l(u);return g&&g.getData(h)||null},childCount:function(u){let h=l(u);if(h)return s.getChildCount(h)},readFileAsync:function(u,h){var g=l(u);g?g.getDataAsync(h):h(null,"getEntry failed for:"+u)},readAsText:function(u,h){var g=l(u);if(g){var w=g.getData();if(w&&w.length)return w.toString(h||"utf8")}return""},readAsTextAsync:function(u,h,g){var w=l(u);w?w.getDataAsync(function(S,v){if(v){h(S,v);return}S&&S.length?h(S.toString(g||"utf8")):h("")}):h("")},deleteFile:function(u,h=!0){var g=l(u);g&&s.deleteFile(g.entryName,h)},deleteEntry:function(u){var h=l(u);h&&s.deleteEntry(h.entryName)},addZipComment:function(u){s.comment=u},getZipComment:function(){return s.comment||""},addZipEntryComment:function(u,h){var g=l(u);g&&(g.comment=h)},getZipEntryComment:function(u){var h=l(u);return h&&h.comment||""},updateFile:function(u,h){var g=l(u);g&&g.setData(h)},addLocalFile:function(u,h,g,w){if(i.fs.existsSync(u)){h=h?d(h):"";let S=J.win32.basename(J.win32.normalize(u));h+=g||S;let v=i.fs.statSync(u),f=v.isFile()?i.fs.readFileSync(u):Buffer.alloc(0);v.isDirectory()&&(h+=i.sep),this.addFile(h,f,w,v)}else throw Z.Errors.FILE_NOT_FOUND(u)},addLocalFileAsync:function(u,h){u=typeof u=="object"?u:{localPath:u};let g=J.resolve(u.localPath),{comment:w}=u,{zipPath:S,zipName:v}=u,f=this;i.fs.stat(g,function(y,E){if(y)return h(y,!1);S=S?d(S):"";let T=J.win32.basename(J.win32.normalize(g));if(S+=v||T,E.isFile())i.fs.readFile(g,function(R,D){return R?h(R,!1):(f.addFile(S,D,w,E),setImmediate(h,void 0,!0))});else if(E.isDirectory())return S+=i.sep,f.addFile(S,Buffer.alloc(0),w,E),setImmediate(h,void 0,!0)})},addLocalFolder:function(u,h,g){if(g=p(g),h=h?d(h):"",u=J.normalize(u),i.fs.existsSync(u)){let w=i.findFiles(u),S=this;if(w.length)for(let v of w){let f=J.join(h,m(u,v));g(f)&&S.addLocalFile(v,J.dirname(f))}}else throw Z.Errors.FILE_NOT_FOUND(u)},addLocalFolderAsync:function(u,h,g,w){w=p(w),g=g?d(g):"",u=J.normalize(u);var S=this;i.fs.open(u,"r",function(v){if(v&&v.code==="ENOENT")h(void 0,Z.Errors.FILE_NOT_FOUND(u));else if(v)h(void 0,v);else{var f=i.findFiles(u),y=-1,E=function(){if(y+=1,y<f.length){var T=f[y],R=m(u,T).split("\\").join("/");R=R.normalize("NFD").replace(/[\u0300-\u036f]/g,"").replace(/[^\x20-\x7E]/g,""),w(R)?i.fs.stat(T,function(D,C){D&&h(void 0,D),C.isFile()?i.fs.readFile(T,function(G,M){G?h(void 0,G):(S.addFile(g+R,M,"",C),E())}):(S.addFile(g+R+"/",Buffer.alloc(0),"",C),E())}):process.nextTick(()=>{E()})}else h(!0,void 0)};E()}})},addLocalFolderAsync2:function(u,h){let g=this;u=typeof u=="object"?u:{localPath:u},localPath=J.resolve(d(u.localPath));let{zipPath:w,filter:S,namefix:v}=u;S instanceof RegExp?S=(function(E){return function(T){return E.test(T)}})(S):typeof S!="function"&&(S=function(){return!0}),w=w?d(w):"",v=="latin1"&&(v=E=>E.normalize("NFD").replace(/[\u0300-\u036f]/g,"").replace(/[^\x20-\x7E]/g,"")),typeof v!="function"&&(v=E=>E);let f=E=>J.join(w,v(m(localPath,E))),y=E=>J.win32.basename(J.win32.normalize(v(E)));i.fs.open(localPath,"r",function(E){E&&E.code==="ENOENT"?h(void 0,Z.Errors.FILE_NOT_FOUND(localPath)):E?h(void 0,E):i.findFilesAsync(localPath,function(T,R){if(T)return h(T);R=R.filter(D=>S(f(D))),R.length||h(void 0,!1),setImmediate(R.reverse().reduce(function(D,C){return function(G,M){if(G||M===!1)return setImmediate(D,G,!1);g.addLocalFileAsync({localPath:C,zipPath:J.dirname(f(C)),zipName:y(C)},D)}},h))})})},addLocalFolderPromise:function(u,h){return new Promise((g,w)=>{this.addLocalFolderAsync2(Object.assign({localPath:u},h),(S,v)=>{S&&w(S),v&&g(this)})})},addFile:function(u,h,g,w){u=c(u);let S=l(u),v=S!=null;v||(S=new qm(r),S.entryName=u),S.comment=g||"";let f=typeof w=="object"&&w instanceof i.fs.Stats;f&&(S.header.time=w.mtime);var y=S.isDirectory?16:0;let E=S.isDirectory?16384:32768;return f?E|=4095&w.mode:typeof w=="number"?E|=4095&w:E|=S.isDirectory?493:420,y=(y|E<<16)>>>0,S.attr=y,S.setData(h),v||s.setEntry(S),S},getEntries:function(u){return s.password=u,s?s.entries:[]},getEntry:function(u){return l(u)},getEntryCount:function(){return s.getEntryCount()},forEach:function(u){return s.forEach(u)},extractEntryTo:function(u,h,g,w,S,v){w=nn(!1,w),S=nn(!1,S),g=nn(!0,g),v=Fd(S,v);var f=l(u);if(!f)throw Z.Errors.NO_ENTRY();var y=o(f.entryName),E=a(h,v&&!f.isDirectory?v:g?y:J.basename(y));if(f.isDirectory){var T=s.getEntryChildren(f);return T.forEach(function(C){if(C.isDirectory)return;var G=C.getData();if(!G)throw Z.Errors.CANT_EXTRACT_FILE();var M=o(C.entryName),oe=a(h,g?M:J.basename(M));let Ee=S?C.header.fileAttr:void 0;i.writeFileTo(oe,G,w,Ee)}),!0}var R=f.getData(s.password);if(!R)throw Z.Errors.CANT_EXTRACT_FILE();if(i.fs.existsSync(E)&&!w)throw Z.Errors.CANT_OVERRIDE();let D=S?u.header.fileAttr:void 0;return i.writeFileTo(E,R,w,D),!0},test:function(u){if(!s)return!1;for(var h in s.entries)try{if(h.isDirectory)continue;var g=s.entries[h].getData(u);if(!g)return!1}catch{return!1}return!0},extractAllTo:function(u,h,g,w){if(g=nn(!1,g),w=Fd(g,w),h=nn(!1,h),!s)throw Z.Errors.NO_ZIP();s.entries.forEach(function(S){var v=a(u,o(S.entryName));if(S.isDirectory){i.makeDir(v);return}var f=S.getData(w);if(!f)throw Z.Errors.CANT_EXTRACT_FILE();let y=g?S.header.fileAttr:void 0;i.writeFileTo(v,f,h,y);try{i.fs.utimesSync(v,S.header.time,S.header.time)}catch{throw Z.Errors.CANT_EXTRACT_FILE()}})},extractAllToAsync:function(u,h,g,w){if(w=Jm(h,g,w),g=nn(!1,g),h=nn(!1,h),!w)return new Promise((E,T)=>{this.extractAllToAsync(u,h,g,function(R){R?T(R):E(this)})});if(!s){w(Z.Errors.NO_ZIP());return}u=J.resolve(u);let S=E=>a(u,J.normalize(o(E.entryName))),v=(E,T)=>new Error(E+': "'+T+'"'),f=[],y=[];s.entries.forEach(E=>{E.isDirectory?f.push(E):y.push(E)});for(let E of f){let T=S(E),R=g?E.header.fileAttr:void 0;try{i.makeDir(T),R&&i.fs.chmodSync(T,R),i.fs.utimesSync(T,E.header.time,E.header.time)}catch{w(v("Unable to create folder",T))}}y.reverse().reduce(function(E,T){return function(R){if(R)E(R);else{let D=J.normalize(o(T.entryName)),C=a(u,D);T.getDataAsync(function(G,M){if(M)E(M);else if(!G)E(Z.Errors.CANT_EXTRACT_FILE());else{let oe=g?T.header.fileAttr:void 0;i.writeFileToAsync(C,G,h,oe,function(Ee){Ee||E(v("Unable to write file",C)),i.fs.utimes(C,T.header.time,T.header.time,function(I){I?E(v("Unable to set times",C)):E()})})}})}}},w)()},writeZip:function(u,h){if(arguments.length===1&&typeof u=="function"&&(h=u,u=""),!u&&r.filename&&(u=r.filename),!!u){var g=s.compressToBuffer();if(g){var w=i.writeFileTo(u,g,!0);typeof h=="function"&&h(w?null:new Error("failed"),"")}}},writeZipPromise:function(u,h){let{overwrite:g,perm:w}=Object.assign({overwrite:!0},h);return new Promise((S,v)=>{!u&&r.filename&&(u=r.filename),u||v("ADM-ZIP: ZIP File Name Missing"),this.toBufferPromise().then(f=>{let y=E=>E?S(E):v("ADM-ZIP: Wasn't able to write zip file");i.writeFileToAsync(u,f,g,w,y)},v)})},toBufferPromise:function(){return new Promise((u,h)=>{s.toAsyncBuffer(u,h)})},toBuffer:function(u,h,g,w){return typeof u=="function"?(s.toAsyncBuffer(u,h,g,w),null):s.compressToBuffer()}}}});function wS(){return wh||(wh=[IDBDatabase,IDBObjectStore,IDBIndex,IDBCursor,IDBTransaction])}function yS(){return yh||(yh=[IDBCursor.prototype.advance,IDBCursor.prototype.continue,IDBCursor.prototype.continuePrimaryKey])}function _S(t){let e=new Promise((n,r)=>{let i=()=>{t.removeEventListener("success",s),t.removeEventListener("error",o)},s=()=>{n(Ue(t.result)),i()},o=()=>{r(t.error),i()};t.addEventListener("success",s),t.addEventListener("error",o)});return e.then(n=>{n instanceof IDBCursor&&_h.set(n,t)}).catch(()=>{}),xc.set(e,t),e}function ES(t){if(bc.has(t))return;let e=new Promise((n,r)=>{let i=()=>{t.removeEventListener("complete",s),t.removeEventListener("error",o),t.removeEventListener("abort",o)},s=()=>{n(),i()},o=()=>{r(t.error||new DOMException("AbortError","AbortError")),i()};t.addEventListener("complete",s),t.addEventListener("error",o),t.addEventListener("abort",o)});bc.set(t,e)}function Sh(t){Ac=t(Ac)}function SS(t){return t===IDBDatabase.prototype.transaction&&!("objectStoreNames"in IDBTransaction.prototype)?function(e,...n){let r=t.call(mi(this),e,...n);return Eh.set(r,e.sort?e.sort():[e]),Ue(r)}:yS().includes(t)?function(...e){return t.apply(mi(this),e),Ue(_h.get(this))}:function(...e){return Ue(t.apply(mi(this),e))}}function vS(t){return typeof t=="function"?SS(t):(t instanceof IDBTransaction&&ES(t),mS(t,wS())?new Proxy(t,Ac):t)}function Ue(t){if(t instanceof IDBRequest)return _S(t);if(kc.has(t))return kc.get(t);let e=vS(t);return e!==t&&(kc.set(t,e),xc.set(e,t)),e}var mS,wh,yh,_h,bc,Eh,kc,xc,Ac,mi,Oc=ve(()=>{mS=(t,e)=>e.some(n=>t instanceof n);_h=new WeakMap,bc=new WeakMap,Eh=new WeakMap,kc=new WeakMap,xc=new WeakMap;Ac={get(t,e,n){if(t instanceof IDBTransaction){if(e==="done")return bc.get(t);if(e==="objectStoreNames")return t.objectStoreNames||Eh.get(t);if(e==="store")return n.objectStoreNames[1]?void 0:n.objectStore(n.objectStoreNames[0])}return Ue(t[e])},set(t,e,n){return t[e]=n,!0},has(t,e){return t instanceof IDBTransaction&&(e==="done"||e==="store")?!0:e in t}};mi=t=>xc.get(t)});var Ih={};Li(Ih,{deleteDB:()=>TS,openDB:()=>IS,unwrap:()=>mi,wrap:()=>Ue});function IS(t,e,{blocked:n,upgrade:r,blocking:i,terminated:s}={}){let o=indexedDB.open(t,e),a=Ue(o);return r&&o.addEventListener("upgradeneeded",c=>{r(Ue(o.result),c.oldVersion,c.newVersion,Ue(o.transaction))}),n&&o.addEventListener("blocked",()=>n()),a.then(c=>{s&&c.addEventListener("close",()=>s()),i&&c.addEventListener("versionchange",()=>i())}).catch(()=>{}),a}function TS(t,{blocked:e}={}){let n=indexedDB.deleteDatabase(t);return e&&n.addEventListener("blocked",()=>e()),Ue(n).then(()=>{})}function vh(t,e){if(!(t instanceof IDBDatabase&&!(e in t)&&typeof e=="string"))return;if(Pc.get(e))return Pc.get(e);let n=e.replace(/FromIndex$/,""),r=e!==n,i=kS.includes(n);if(!(n in(r?IDBIndex:IDBObjectStore).prototype)||!(i||RS.includes(n)))return;let s=async function(o,...a){let c=this.transaction(o,i?"readwrite":"readonly"),l=c.store;return r&&(l=l.index(a.shift())),(await Promise.all([l[n](...a),i&&c.done]))[0]};return Pc.set(e,s),s}var RS,kS,Pc,Th=ve(()=>{Oc();Oc();RS=["get","getKey","getAll","getAllKeys","count"],kS=["put","add","delete","clear"],Pc=new Map;Sh(t=>({...t,get:(e,n,r)=>vh(e,n)||t.get(e,n,r),has:(e,n)=>!!vh(e,n)||t.has(e,n)}))});var It=H((RO,Kh)=>{"use strict";var Jh=["nodebuffer","arraybuffer","fragments"],Zh=typeof Blob<"u";Zh&&Jh.push("blob");Kh.exports={BINARY_TYPES:Jh,CLOSE_TIMEOUT:3e4,EMPTY_BUFFER:Buffer.alloc(0),GUID:"258EAFA5-E914-47DA-95CA-C5AB0DC85B11",hasBlob:Zh,kForOnEventAttribute:Symbol("kIsForOnEventAttribute"),kListener:Symbol("kListener"),kStatusCode:Symbol("status-code"),kWebSocket:Symbol("websocket"),NOOP:()=>{}}});var vi=H((kO,co)=>{"use strict";var{EMPTY_BUFFER:x0}=It(),el=Buffer[Symbol.species];function O0(t,e){if(t.length===0)return x0;if(t.length===1)return t[0];let n=Buffer.allocUnsafe(e),r=0;for(let i=0;i<t.length;i++){let s=t[i];n.set(s,r),r+=s.length}return r<e?new el(n.buffer,n.byteOffset,r):n}function Xh(t,e,n,r,i){for(let s=0;s<i;s++)n[r+s]=t[s]^e[s&3]}function Yh(t,e){for(let n=0;n<t.length;n++)t[n]^=e[n&3]}function P0(t){return t.length===t.buffer.byteLength?t.buffer:t.buffer.slice(t.byteOffset,t.byteOffset+t.length)}function tl(t){if(tl.readOnly=!0,Buffer.isBuffer(t))return t;let e;return t instanceof ArrayBuffer?e=new el(t):ArrayBuffer.isView(t)?e=new el(t.buffer,t.byteOffset,t.byteLength):(e=Buffer.from(t),tl.readOnly=!1),e}co.exports={concat:O0,mask:Xh,toArrayBuffer:P0,toBuffer:tl,unmask:Yh};if(!process.env.WS_NO_BUFFER_UTIL)try{let t=j("bufferutil");co.exports.mask=function(e,n,r,i,s){s<48?Xh(e,n,r,i,s):t.mask(e,n,r,i,s)},co.exports.unmask=function(e,n){e.length<32?Yh(e,n):t.unmask(e,n)}}catch{}});var tp=H((bO,ep)=>{"use strict";var Qh=Symbol("kDone"),nl=Symbol("kRun"),rl=class{constructor(e){this[Qh]=()=>{this.pending--,this[nl]()},this.concurrency=e||1/0,this.jobs=[],this.pending=0}add(e){this.jobs.push(e),this[nl]()}[nl](){if(this.pending!==this.concurrency&&this.jobs.length){let e=this.jobs.shift();this.pending++,e(this[Qh])}}};ep.exports=rl});var fr=H((AO,sp)=>{"use strict";var Ii=j("zlib"),np=vi(),C0=tp(),{kStatusCode:rp}=It(),D0=Buffer[Symbol.species],N0=Buffer.from([0,0,255,255]),uo=Symbol("permessage-deflate"),Tt=Symbol("total-length"),dr=Symbol("callback"),Zt=Symbol("buffers"),ur=Symbol("error"),lo,il=class{constructor(e){if(this._options=e||{},this._threshold=this._options.threshold!==void 0?this._options.threshold:1024,this._maxPayload=this._options.maxPayload|0,this._isServer=!!this._options.isServer,this._deflate=null,this._inflate=null,this.params=null,!lo){let n=this._options.concurrencyLimit!==void 0?this._options.concurrencyLimit:10;lo=new C0(n)}}static get extensionName(){return"permessage-deflate"}offer(){let e={};return this._options.serverNoContextTakeover&&(e.server_no_context_takeover=!0),this._options.clientNoContextTakeover&&(e.client_no_context_takeover=!0),this._options.serverMaxWindowBits&&(e.server_max_window_bits=this._options.serverMaxWindowBits),this._options.clientMaxWindowBits?e.client_max_window_bits=this._options.clientMaxWindowBits:this._options.clientMaxWindowBits==null&&(e.client_max_window_bits=!0),e}accept(e){return e=this.normalizeParams(e),this.params=this._isServer?this.acceptAsServer(e):this.acceptAsClient(e),this.params}cleanup(){if(this._inflate&&(this._inflate.close(),this._inflate=null),this._deflate){let e=this._deflate[dr];this._deflate.close(),this._deflate=null,e&&e(new Error("The deflate stream was closed while data was being processed"))}}acceptAsServer(e){let n=this._options,r=e.find(i=>!(n.serverNoContextTakeover===!1&&i.server_no_context_takeover||i.server_max_window_bits&&(n.serverMaxWindowBits===!1||typeof n.serverMaxWindowBits=="number"&&n.serverMaxWindowBits>i.server_max_window_bits)||typeof n.clientMaxWindowBits=="number"&&!i.client_max_window_bits));if(!r)throw new Error("None of the extension offers can be accepted");return n.serverNoContextTakeover&&(r.server_no_context_takeover=!0),n.clientNoContextTakeover&&(r.client_no_context_takeover=!0),typeof n.serverMaxWindowBits=="number"&&(r.server_max_window_bits=n.serverMaxWindowBits),typeof n.clientMaxWindowBits=="number"?r.client_max_window_bits=n.clientMaxWindowBits:(r.client_max_window_bits===!0||n.clientMaxWindowBits===!1)&&delete r.client_max_window_bits,r}acceptAsClient(e){let n=e[0];if(this._options.clientNoContextTakeover===!1&&n.client_no_context_takeover)throw new Error('Unexpected parameter "client_no_context_takeover"');if(!n.client_max_window_bits)typeof this._options.clientMaxWindowBits=="number"&&(n.client_max_window_bits=this._options.clientMaxWindowBits);else if(this._options.clientMaxWindowBits===!1||typeof this._options.clientMaxWindowBits=="number"&&n.client_max_window_bits>this._options.clientMaxWindowBits)throw new Error('Unexpected or invalid parameter "client_max_window_bits"');return n}normalizeParams(e){return e.forEach(n=>{Object.keys(n).forEach(r=>{let i=n[r];if(i.length>1)throw new Error(`Parameter "${r}" must have only a single value`);if(i=i[0],r==="client_max_window_bits"){if(i!==!0){let s=+i;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${r}": ${i}`);i=s}else if(!this._isServer)throw new TypeError(`Invalid value for parameter "${r}": ${i}`)}else if(r==="server_max_window_bits"){let s=+i;if(!Number.isInteger(s)||s<8||s>15)throw new TypeError(`Invalid value for parameter "${r}": ${i}`);i=s}else if(r==="client_no_context_takeover"||r==="server_no_context_takeover"){if(i!==!0)throw new TypeError(`Invalid value for parameter "${r}": ${i}`)}else throw new Error(`Unknown parameter "${r}"`);n[r]=i})}),e}decompress(e,n,r){lo.add(i=>{this._decompress(e,n,(s,o)=>{i(),r(s,o)})})}compress(e,n,r){lo.add(i=>{this._compress(e,n,(s,o)=>{i(),r(s,o)})})}_decompress(e,n,r){let i=this._isServer?"client":"server";if(!this._inflate){let s=`${i}_max_window_bits`,o=typeof this.params[s]!="number"?Ii.Z_DEFAULT_WINDOWBITS:this.params[s];this._inflate=Ii.createInflateRaw({...this._options.zlibInflateOptions,windowBits:o}),this._inflate[uo]=this,this._inflate[Tt]=0,this._inflate[Zt]=[],this._inflate.on("error",F0),this._inflate.on("data",ip)}this._inflate[dr]=r,this._inflate.write(e),n&&this._inflate.write(N0),this._inflate.flush(()=>{let s=this._inflate[ur];if(s){this._inflate.close(),this._inflate=null,r(s);return}let o=np.concat(this._inflate[Zt],this._inflate[Tt]);this._inflate._readableState.endEmitted?(this._inflate.close(),this._inflate=null):(this._inflate[Tt]=0,this._inflate[Zt]=[],n&&this.params[`${i}_no_context_takeover`]&&this._inflate.reset()),r(null,o)})}_compress(e,n,r){let i=this._isServer?"server":"client";if(!this._deflate){let s=`${i}_max_window_bits`,o=typeof this.params[s]!="number"?Ii.Z_DEFAULT_WINDOWBITS:this.params[s];this._deflate=Ii.createDeflateRaw({...this._options.zlibDeflateOptions,windowBits:o}),this._deflate[Tt]=0,this._deflate[Zt]=[],this._deflate.on("data",L0)}this._deflate[dr]=r,this._deflate.write(e),this._deflate.flush(Ii.Z_SYNC_FLUSH,()=>{if(!this._deflate)return;let s=np.concat(this._deflate[Zt],this._deflate[Tt]);n&&(s=new D0(s.buffer,s.byteOffset,s.length-4)),this._deflate[dr]=null,this._deflate[Tt]=0,this._deflate[Zt]=[],n&&this.params[`${i}_no_context_takeover`]&&this._deflate.reset(),r(null,s)})}};sp.exports=il;function L0(t){this[Zt].push(t),this[Tt]+=t.length}function ip(t){if(this[Tt]+=t.length,this[uo]._maxPayload<1||this[Tt]<=this[uo]._maxPayload){this[Zt].push(t);return}this[ur]=new RangeError("Max payload size exceeded"),this[ur].code="WS_ERR_UNSUPPORTED_MESSAGE_LENGTH",this[ur][rp]=1009,this.removeListener("data",ip),this.reset()}function F0(t){if(this[uo]._inflate=null,this[ur]){this[dr](this[ur]);return}t[rp]=1007,this[dr](t)}});var hr=H((xO,fo)=>{"use strict";var{isUtf8:op}=j("buffer"),{hasBlob:M0}=It(),B0=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,1,1,1,1,0,0,1,1,0,1,1,0,1,1,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,0,0,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,0,1,0,1,0];function U0(t){return t>=1e3&&t<=1014&&t!==1004&&t!==1005&&t!==1006||t>=3e3&&t<=4999}function sl(t){let e=t.length,n=0;for(;n<e;)if((t[n]&128)===0)n++;else if((t[n]&224)===192){if(n+1===e||(t[n+1]&192)!==128||(t[n]&254)===192)return!1;n+=2}else if((t[n]&240)===224){if(n+2>=e||(t[n+1]&192)!==128||(t[n+2]&192)!==128||t[n]===224&&(t[n+1]&224)===128||t[n]===237&&(t[n+1]&224)===160)return!1;n+=3}else if((t[n]&248)===240){if(n+3>=e||(t[n+1]&192)!==128||(t[n+2]&192)!==128||(t[n+3]&192)!==128||t[n]===240&&(t[n+1]&240)===128||t[n]===244&&t[n+1]>143||t[n]>244)return!1;n+=4}else return!1;return!0}function z0(t){return M0&&typeof t=="object"&&typeof t.arrayBuffer=="function"&&typeof t.type=="string"&&typeof t.stream=="function"&&(t[Symbol.toStringTag]==="Blob"||t[Symbol.toStringTag]==="File")}fo.exports={isBlob:z0,isValidStatusCode:U0,isValidUTF8:sl,tokenChars:B0};if(op)fo.exports.isValidUTF8=function(t){return t.length<24?sl(t):op(t)};else if(!process.env.WS_NO_UTF_8_VALIDATE)try{let t=j("utf-8-validate");fo.exports.isValidUTF8=function(e){return e.length<32?sl(e):t(e)}}catch{}});var dl=H((OO,hp)=>{"use strict";var{Writable:$0}=j("stream"),ap=fr(),{BINARY_TYPES:G0,EMPTY_BUFFER:cp,kStatusCode:H0,kWebSocket:j0}=It(),{concat:ol,toArrayBuffer:W0,unmask:q0}=vi(),{isValidStatusCode:V0,isValidUTF8:lp}=hr(),ho=Buffer[Symbol.species],$e=0,dp=1,up=2,fp=3,al=4,cl=5,po=6,ll=class extends $0{constructor(e={}){super(),this._allowSynchronousEvents=e.allowSynchronousEvents!==void 0?e.allowSynchronousEvents:!0,this._binaryType=e.binaryType||G0[0],this._extensions=e.extensions||{},this._isServer=!!e.isServer,this._maxPayload=e.maxPayload|0,this._skipUTF8Validation=!!e.skipUTF8Validation,this[j0]=void 0,this._bufferedBytes=0,this._buffers=[],this._compressed=!1,this._payloadLength=0,this._mask=void 0,this._fragmented=0,this._masked=!1,this._fin=!1,this._opcode=0,this._totalPayloadLength=0,this._messageLength=0,this._fragments=[],this._errored=!1,this._loop=!1,this._state=$e}_write(e,n,r){if(this._opcode===8&&this._state==$e)return r();this._bufferedBytes+=e.length,this._buffers.push(e),this.startLoop(r)}consume(e){if(this._bufferedBytes-=e,e===this._buffers[0].length)return this._buffers.shift();if(e<this._buffers[0].length){let r=this._buffers[0];return this._buffers[0]=new ho(r.buffer,r.byteOffset+e,r.length-e),new ho(r.buffer,r.byteOffset,e)}let n=Buffer.allocUnsafe(e);do{let r=this._buffers[0],i=n.length-e;e>=r.length?n.set(this._buffers.shift(),i):(n.set(new Uint8Array(r.buffer,r.byteOffset,e),i),this._buffers[0]=new ho(r.buffer,r.byteOffset+e,r.length-e)),e-=r.length}while(e>0);return n}startLoop(e){this._loop=!0;do switch(this._state){case $e:this.getInfo(e);break;case dp:this.getPayloadLength16(e);break;case up:this.getPayloadLength64(e);break;case fp:this.getMask();break;case al:this.getData(e);break;case cl:case po:this._loop=!1;return}while(this._loop);this._errored||e()}getInfo(e){if(this._bufferedBytes<2){this._loop=!1;return}let n=this.consume(2);if((n[0]&48)!==0){let i=this.createError(RangeError,"RSV2 and RSV3 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_2_3");e(i);return}let r=(n[0]&64)===64;if(r&&!this._extensions[ap.extensionName]){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(this._fin=(n[0]&128)===128,this._opcode=n[0]&15,this._payloadLength=n[1]&127,this._opcode===0){if(r){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(!this._fragmented){let i=this.createError(RangeError,"invalid opcode 0",!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}this._opcode=this._fragmented}else if(this._opcode===1||this._opcode===2){if(this._fragmented){let i=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}this._compressed=r}else if(this._opcode>7&&this._opcode<11){if(!this._fin){let i=this.createError(RangeError,"FIN must be set",!0,1002,"WS_ERR_EXPECTED_FIN");e(i);return}if(r){let i=this.createError(RangeError,"RSV1 must be clear",!0,1002,"WS_ERR_UNEXPECTED_RSV_1");e(i);return}if(this._payloadLength>125||this._opcode===8&&this._payloadLength===1){let i=this.createError(RangeError,`invalid payload length ${this._payloadLength}`,!0,1002,"WS_ERR_INVALID_CONTROL_PAYLOAD_LENGTH");e(i);return}}else{let i=this.createError(RangeError,`invalid opcode ${this._opcode}`,!0,1002,"WS_ERR_INVALID_OPCODE");e(i);return}if(!this._fin&&!this._fragmented&&(this._fragmented=this._opcode),this._masked=(n[1]&128)===128,this._isServer){if(!this._masked){let i=this.createError(RangeError,"MASK must be set",!0,1002,"WS_ERR_EXPECTED_MASK");e(i);return}}else if(this._masked){let i=this.createError(RangeError,"MASK must be clear",!0,1002,"WS_ERR_UNEXPECTED_MASK");e(i);return}this._payloadLength===126?this._state=dp:this._payloadLength===127?this._state=up:this.haveLength(e)}getPayloadLength16(e){if(this._bufferedBytes<2){this._loop=!1;return}this._payloadLength=this.consume(2).readUInt16BE(0),this.haveLength(e)}getPayloadLength64(e){if(this._bufferedBytes<8){this._loop=!1;return}let n=this.consume(8),r=n.readUInt32BE(0);if(r>Math.pow(2,21)-1){let i=this.createError(RangeError,"Unsupported WebSocket frame: payload length > 2^53 - 1",!1,1009,"WS_ERR_UNSUPPORTED_DATA_PAYLOAD_LENGTH");e(i);return}this._payloadLength=r*Math.pow(2,32)+n.readUInt32BE(4),this.haveLength(e)}haveLength(e){if(this._payloadLength&&this._opcode<8&&(this._totalPayloadLength+=this._payloadLength,this._totalPayloadLength>this._maxPayload&&this._maxPayload>0)){let n=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");e(n);return}this._masked?this._state=fp:this._state=al}getMask(){if(this._bufferedBytes<4){this._loop=!1;return}this._mask=this.consume(4),this._state=al}getData(e){let n=cp;if(this._payloadLength){if(this._bufferedBytes<this._payloadLength){this._loop=!1;return}n=this.consume(this._payloadLength),this._masked&&(this._mask[0]|this._mask[1]|this._mask[2]|this._mask[3])!==0&&q0(n,this._mask)}if(this._opcode>7){this.controlMessage(n,e);return}if(this._compressed){this._state=cl,this.decompress(n,e);return}n.length&&(this._messageLength=this._totalPayloadLength,this._fragments.push(n)),this.dataMessage(e)}decompress(e,n){this._extensions[ap.extensionName].decompress(e,this._fin,(i,s)=>{if(i)return n(i);if(s.length){if(this._messageLength+=s.length,this._messageLength>this._maxPayload&&this._maxPayload>0){let o=this.createError(RangeError,"Max payload size exceeded",!1,1009,"WS_ERR_UNSUPPORTED_MESSAGE_LENGTH");n(o);return}this._fragments.push(s)}this.dataMessage(n),this._state===$e&&this.startLoop(n)})}dataMessage(e){if(!this._fin){this._state=$e;return}let n=this._messageLength,r=this._fragments;if(this._totalPayloadLength=0,this._messageLength=0,this._fragmented=0,this._fragments=[],this._opcode===2){let i;this._binaryType==="nodebuffer"?i=ol(r,n):this._binaryType==="arraybuffer"?i=W0(ol(r,n)):this._binaryType==="blob"?i=new Blob(r):i=r,this._allowSynchronousEvents?(this.emit("message",i,!0),this._state=$e):(this._state=po,setImmediate(()=>{this.emit("message",i,!0),this._state=$e,this.startLoop(e)}))}else{let i=ol(r,n);if(!this._skipUTF8Validation&&!lp(i)){let s=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");e(s);return}this._state===cl||this._allowSynchronousEvents?(this.emit("message",i,!1),this._state=$e):(this._state=po,setImmediate(()=>{this.emit("message",i,!1),this._state=$e,this.startLoop(e)}))}}controlMessage(e,n){if(this._opcode===8){if(e.length===0)this._loop=!1,this.emit("conclude",1005,cp),this.end();else{let r=e.readUInt16BE(0);if(!V0(r)){let s=this.createError(RangeError,`invalid status code ${r}`,!0,1002,"WS_ERR_INVALID_CLOSE_CODE");n(s);return}let i=new ho(e.buffer,e.byteOffset+2,e.length-2);if(!this._skipUTF8Validation&&!lp(i)){let s=this.createError(Error,"invalid UTF-8 sequence",!0,1007,"WS_ERR_INVALID_UTF8");n(s);return}this._loop=!1,this.emit("conclude",r,i),this.end()}this._state=$e;return}this._allowSynchronousEvents?(this.emit(this._opcode===9?"ping":"pong",e),this._state=$e):(this._state=po,setImmediate(()=>{this.emit(this._opcode===9?"ping":"pong",e),this._state=$e,this.startLoop(n)}))}createError(e,n,r,i,s){this._loop=!1,this._errored=!0;let o=new e(r?`Invalid WebSocket frame: ${n}`:n);return Error.captureStackTrace(o,this.createError),o.code=s,o[H0]=i,o}};hp.exports=ll});var hl=H((CO,mp)=>{"use strict";var{Duplex:PO}=j("stream"),{randomFillSync:J0}=j("crypto"),pp=fr(),{EMPTY_BUFFER:Z0,kWebSocket:K0,NOOP:X0}=It(),{isBlob:pr,isValidStatusCode:Y0}=hr(),{mask:gp,toBuffer:In}=vi(),Ge=Symbol("kByteLength"),Q0=Buffer.alloc(4),go=8*1024,Tn,gr=go,Ye=0,ev=1,tv=2,ul=class t{constructor(e,n,r){this._extensions=n||{},r&&(this._generateMask=r,this._maskBuffer=Buffer.alloc(4)),this._socket=e,this._firstFragment=!0,this._compress=!1,this._bufferedBytes=0,this._queue=[],this._state=Ye,this.onerror=X0,this[K0]=void 0}static frame(e,n){let r,i=!1,s=2,o=!1;n.mask&&(r=n.maskBuffer||Q0,n.generateMask?n.generateMask(r):(gr===go&&(Tn===void 0&&(Tn=Buffer.alloc(go)),J0(Tn,0,go),gr=0),r[0]=Tn[gr++],r[1]=Tn[gr++],r[2]=Tn[gr++],r[3]=Tn[gr++]),o=(r[0]|r[1]|r[2]|r[3])===0,s=6);let a;typeof e=="string"?(!n.mask||o)&&n[Ge]!==void 0?a=n[Ge]:(e=Buffer.from(e),a=e.length):(a=e.length,i=n.mask&&n.readOnly&&!o);let c=a;a>=65536?(s+=8,c=127):a>125&&(s+=2,c=126);let l=Buffer.allocUnsafe(i?a+s:s);return l[0]=n.fin?n.opcode|128:n.opcode,n.rsv1&&(l[0]|=64),l[1]=c,c===126?l.writeUInt16BE(a,2):c===127&&(l[2]=l[3]=0,l.writeUIntBE(a,4,6)),n.mask?(l[1]|=128,l[s-4]=r[0],l[s-3]=r[1],l[s-2]=r[2],l[s-1]=r[3],o?[l,e]:i?(gp(e,r,l,s,a),[l]):(gp(e,r,e,0,a),[l,e])):[l,e]}close(e,n,r,i){let s;if(e===void 0)s=Z0;else{if(typeof e!="number"||!Y0(e))throw new TypeError("First argument must be a valid error code number");if(n===void 0||!n.length)s=Buffer.allocUnsafe(2),s.writeUInt16BE(e,0);else{let a=Buffer.byteLength(n);if(a>123)throw new RangeError("The message must not be greater than 123 bytes");s=Buffer.allocUnsafe(2+a),s.writeUInt16BE(e,0),typeof n=="string"?s.write(n,2):s.set(n,2)}}let o={[Ge]:s.length,fin:!0,generateMask:this._generateMask,mask:r,maskBuffer:this._maskBuffer,opcode:8,readOnly:!1,rsv1:!1};this._state!==Ye?this.enqueue([this.dispatch,s,!1,o,i]):this.sendFrame(t.frame(s,o),i)}ping(e,n,r){let i,s;if(typeof e=="string"?(i=Buffer.byteLength(e),s=!1):pr(e)?(i=e.size,s=!1):(e=In(e),i=e.length,s=In.readOnly),i>125)throw new RangeError("The data size must not be greater than 125 bytes");let o={[Ge]:i,fin:!0,generateMask:this._generateMask,mask:n,maskBuffer:this._maskBuffer,opcode:9,readOnly:s,rsv1:!1};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,!1,o,r]):this.getBlobData(e,!1,o,r):this._state!==Ye?this.enqueue([this.dispatch,e,!1,o,r]):this.sendFrame(t.frame(e,o),r)}pong(e,n,r){let i,s;if(typeof e=="string"?(i=Buffer.byteLength(e),s=!1):pr(e)?(i=e.size,s=!1):(e=In(e),i=e.length,s=In.readOnly),i>125)throw new RangeError("The data size must not be greater than 125 bytes");let o={[Ge]:i,fin:!0,generateMask:this._generateMask,mask:n,maskBuffer:this._maskBuffer,opcode:10,readOnly:s,rsv1:!1};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,!1,o,r]):this.getBlobData(e,!1,o,r):this._state!==Ye?this.enqueue([this.dispatch,e,!1,o,r]):this.sendFrame(t.frame(e,o),r)}send(e,n,r){let i=this._extensions[pp.extensionName],s=n.binary?2:1,o=n.compress,a,c;typeof e=="string"?(a=Buffer.byteLength(e),c=!1):pr(e)?(a=e.size,c=!1):(e=In(e),a=e.length,c=In.readOnly),this._firstFragment?(this._firstFragment=!1,o&&i&&i.params[i._isServer?"server_no_context_takeover":"client_no_context_takeover"]&&(o=a>=i._threshold),this._compress=o):(o=!1,s=0),n.fin&&(this._firstFragment=!0);let l={[Ge]:a,fin:n.fin,generateMask:this._generateMask,mask:n.mask,maskBuffer:this._maskBuffer,opcode:s,readOnly:c,rsv1:o};pr(e)?this._state!==Ye?this.enqueue([this.getBlobData,e,this._compress,l,r]):this.getBlobData(e,this._compress,l,r):this._state!==Ye?this.enqueue([this.dispatch,e,this._compress,l,r]):this.dispatch(e,this._compress,l,r)}getBlobData(e,n,r,i){this._bufferedBytes+=r[Ge],this._state=tv,e.arrayBuffer().then(s=>{if(this._socket.destroyed){let a=new Error("The socket was closed while the blob was being read");process.nextTick(fl,this,a,i);return}this._bufferedBytes-=r[Ge];let o=In(s);n?this.dispatch(o,n,r,i):(this._state=Ye,this.sendFrame(t.frame(o,r),i),this.dequeue())}).catch(s=>{process.nextTick(nv,this,s,i)})}dispatch(e,n,r,i){if(!n){this.sendFrame(t.frame(e,r),i);return}let s=this._extensions[pp.extensionName];this._bufferedBytes+=r[Ge],this._state=ev,s.compress(e,r.fin,(o,a)=>{if(this._socket.destroyed){let c=new Error("The socket was closed while data was being compressed");fl(this,c,i);return}this._bufferedBytes-=r[Ge],this._state=Ye,r.readOnly=!1,this.sendFrame(t.frame(a,r),i),this.dequeue()})}dequeue(){for(;this._state===Ye&&this._queue.length;){let e=this._queue.shift();this._bufferedBytes-=e[3][Ge],Reflect.apply(e[0],this,e.slice(1))}}enqueue(e){this._bufferedBytes+=e[3][Ge],this._queue.push(e)}sendFrame(e,n){e.length===2?(this._socket.cork(),this._socket.write(e[0]),this._socket.write(e[1],n),this._socket.uncork()):this._socket.write(e[0],n)}};mp.exports=ul;function fl(t,e,n){typeof n=="function"&&n(e);for(let r=0;r<t._queue.length;r++){let i=t._queue[r],s=i[i.length-1];typeof s=="function"&&s(e)}}function nv(t,e,n){fl(t,e,n),t.onerror(e)}});var Rp=H((DO,Tp)=>{"use strict";var{kForOnEventAttribute:Ti,kListener:pl}=It(),wp=Symbol("kCode"),yp=Symbol("kData"),_p=Symbol("kError"),Ep=Symbol("kMessage"),Sp=Symbol("kReason"),mr=Symbol("kTarget"),vp=Symbol("kType"),Ip=Symbol("kWasClean"),Rt=class{constructor(e){this[mr]=null,this[vp]=e}get target(){return this[mr]}get type(){return this[vp]}};Object.defineProperty(Rt.prototype,"target",{enumerable:!0});Object.defineProperty(Rt.prototype,"type",{enumerable:!0});var Rn=class extends Rt{constructor(e,n={}){super(e),this[wp]=n.code===void 0?0:n.code,this[Sp]=n.reason===void 0?"":n.reason,this[Ip]=n.wasClean===void 0?!1:n.wasClean}get code(){return this[wp]}get reason(){return this[Sp]}get wasClean(){return this[Ip]}};Object.defineProperty(Rn.prototype,"code",{enumerable:!0});Object.defineProperty(Rn.prototype,"reason",{enumerable:!0});Object.defineProperty(Rn.prototype,"wasClean",{enumerable:!0});var wr=class extends Rt{constructor(e,n={}){super(e),this[_p]=n.error===void 0?null:n.error,this[Ep]=n.message===void 0?"":n.message}get error(){return this[_p]}get message(){return this[Ep]}};Object.defineProperty(wr.prototype,"error",{enumerable:!0});Object.defineProperty(wr.prototype,"message",{enumerable:!0});var Ri=class extends Rt{constructor(e,n={}){super(e),this[yp]=n.data===void 0?null:n.data}get data(){return this[yp]}};Object.defineProperty(Ri.prototype,"data",{enumerable:!0});var rv={addEventListener(t,e,n={}){for(let i of this.listeners(t))if(!n[Ti]&&i[pl]===e&&!i[Ti])return;let r;if(t==="message")r=function(s,o){let a=new Ri("message",{data:o?s:s.toString()});a[mr]=this,mo(e,this,a)};else if(t==="close")r=function(s,o){let a=new Rn("close",{code:s,reason:o.toString(),wasClean:this._closeFrameReceived&&this._closeFrameSent});a[mr]=this,mo(e,this,a)};else if(t==="error")r=function(s){let o=new wr("error",{error:s,message:s.message});o[mr]=this,mo(e,this,o)};else if(t==="open")r=function(){let s=new Rt("open");s[mr]=this,mo(e,this,s)};else return;r[Ti]=!!n[Ti],r[pl]=e,n.once?this.once(t,r):this.on(t,r)},removeEventListener(t,e){for(let n of this.listeners(t))if(n[pl]===e&&!n[Ti]){this.removeListener(t,n);break}}};Tp.exports={CloseEvent:Rn,ErrorEvent:wr,Event:Rt,EventTarget:rv,MessageEvent:Ri};function mo(t,e,n){typeof t=="object"&&t.handleEvent?t.handleEvent.call(t,n):t.call(e,n)}});var wo=H((NO,kp)=>{"use strict";var{tokenChars:ki}=hr();function ut(t,e,n){t[e]===void 0?t[e]=[n]:t[e].push(n)}function iv(t){let e=Object.create(null),n=Object.create(null),r=!1,i=!1,s=!1,o,a,c=-1,l=-1,d=-1,p=0;for(;p<t.length;p++)if(l=t.charCodeAt(p),o===void 0)if(d===-1&&ki[l]===1)c===-1&&(c=p);else if(p!==0&&(l===32||l===9))d===-1&&c!==-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p);let u=t.slice(c,d);l===44?(ut(e,u,n),n=Object.create(null)):o=u,c=d=-1}else throw new SyntaxError(`Unexpected character at index ${p}`);else if(a===void 0)if(d===-1&&ki[l]===1)c===-1&&(c=p);else if(l===32||l===9)d===-1&&c!==-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p),ut(n,t.slice(c,d),!0),l===44&&(ut(e,o,n),n=Object.create(null),o=void 0),c=d=-1}else if(l===61&&c!==-1&&d===-1)a=t.slice(c,p),c=d=-1;else throw new SyntaxError(`Unexpected character at index ${p}`);else if(i){if(ki[l]!==1)throw new SyntaxError(`Unexpected character at index ${p}`);c===-1?c=p:r||(r=!0),i=!1}else if(s)if(ki[l]===1)c===-1&&(c=p);else if(l===34&&c!==-1)s=!1,d=p;else if(l===92)i=!0;else throw new SyntaxError(`Unexpected character at index ${p}`);else if(l===34&&t.charCodeAt(p-1)===61)s=!0;else if(d===-1&&ki[l]===1)c===-1&&(c=p);else if(c!==-1&&(l===32||l===9))d===-1&&(d=p);else if(l===59||l===44){if(c===-1)throw new SyntaxError(`Unexpected character at index ${p}`);d===-1&&(d=p);let u=t.slice(c,d);r&&(u=u.replace(/\\/g,""),r=!1),ut(n,a,u),l===44&&(ut(e,o,n),n=Object.create(null),o=void 0),a=void 0,c=d=-1}else throw new SyntaxError(`Unexpected character at index ${p}`);if(c===-1||s||l===32||l===9)throw new SyntaxError("Unexpected end of input");d===-1&&(d=p);let m=t.slice(c,d);return o===void 0?ut(e,m,n):(a===void 0?ut(n,m,!0):r?ut(n,a,m.replace(/\\/g,"")):ut(n,a,m),ut(e,o,n)),e}function sv(t){return Object.keys(t).map(e=>{let n=t[e];return Array.isArray(n)||(n=[n]),n.map(r=>[e].concat(Object.keys(r).map(i=>{let s=r[i];return Array.isArray(s)||(s=[s]),s.map(o=>o===!0?i:`${i}=${o}`).join("; ")})).join("; ")).join(", ")}).join(", ")}kp.exports={format:sv,parse:iv}});var So=H((MO,Bp)=>{"use strict";var ov=j("events"),av=j("https"),cv=j("http"),xp=j("net"),lv=j("tls"),{randomBytes:dv,createHash:uv}=j("crypto"),{Duplex:LO,Readable:FO}=j("stream"),{URL:gl}=j("url"),Kt=fr(),fv=dl(),hv=hl(),{isBlob:pv}=hr(),{BINARY_TYPES:bp,CLOSE_TIMEOUT:gv,EMPTY_BUFFER:yo,GUID:mv,kForOnEventAttribute:ml,kListener:wv,kStatusCode:yv,kWebSocket:pe,NOOP:Op}=It(),{EventTarget:{addEventListener:_v,removeEventListener:Ev}}=Rp(),{format:Sv,parse:vv}=wo(),{toBuffer:Iv}=vi(),Pp=Symbol("kAborted"),wl=[8,13],kt=["CONNECTING","OPEN","CLOSING","CLOSED"],Tv=/^[!#$%&'*+\-.0-9A-Z^_`|a-z~]+$/,q=class t extends ov{constructor(e,n,r){super(),this._binaryType=bp[0],this._closeCode=1006,this._closeFrameReceived=!1,this._closeFrameSent=!1,this._closeMessage=yo,this._closeTimer=null,this._errorEmitted=!1,this._extensions={},this._paused=!1,this._protocol="",this._readyState=t.CONNECTING,this._receiver=null,this._sender=null,this._socket=null,e!==null?(this._bufferedAmount=0,this._isServer=!1,this._redirects=0,n===void 0?n=[]:Array.isArray(n)||(typeof n=="object"&&n!==null?(r=n,n=[]):n=[n]),Cp(this,e,n,r)):(this._autoPong=r.autoPong,this._closeTimeout=r.closeTimeout,this._isServer=!0)}get binaryType(){return this._binaryType}set binaryType(e){bp.includes(e)&&(this._binaryType=e,this._receiver&&(this._receiver._binaryType=e))}get bufferedAmount(){return this._socket?this._socket._writableState.length+this._sender._bufferedBytes:this._bufferedAmount}get extensions(){return Object.keys(this._extensions).join()}get isPaused(){return this._paused}get onclose(){return null}get onerror(){return null}get onopen(){return null}get onmessage(){return null}get protocol(){return this._protocol}get readyState(){return this._readyState}get url(){return this._url}setSocket(e,n,r){let i=new fv({allowSynchronousEvents:r.allowSynchronousEvents,binaryType:this.binaryType,extensions:this._extensions,isServer:this._isServer,maxPayload:r.maxPayload,skipUTF8Validation:r.skipUTF8Validation}),s=new hv(e,this._extensions,r.generateMask);this._receiver=i,this._sender=s,this._socket=e,i[pe]=this,s[pe]=this,e[pe]=this,i.on("conclude",bv),i.on("drain",Av),i.on("error",xv),i.on("message",Ov),i.on("ping",Pv),i.on("pong",Cv),s.onerror=Dv,e.setTimeout&&e.setTimeout(0),e.setNoDelay&&e.setNoDelay(),n.length>0&&e.unshift(n),e.on("close",Lp),e.on("data",Eo),e.on("end",Fp),e.on("error",Mp),this._readyState=t.OPEN,this.emit("open")}emitClose(){if(!this._socket){this._readyState=t.CLOSED,this.emit("close",this._closeCode,this._closeMessage);return}this._extensions[Kt.extensionName]&&this._extensions[Kt.extensionName].cleanup(),this._receiver.removeAllListeners(),this._readyState=t.CLOSED,this.emit("close",this._closeCode,this._closeMessage)}close(e,n){if(this.readyState!==t.CLOSED){if(this.readyState===t.CONNECTING){Le(this,this._req,"WebSocket was closed before the connection was established");return}if(this.readyState===t.CLOSING){this._closeFrameSent&&(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end();return}this._readyState=t.CLOSING,this._sender.close(e,n,!this._isServer,r=>{r||(this._closeFrameSent=!0,(this._closeFrameReceived||this._receiver._writableState.errorEmitted)&&this._socket.end())}),Np(this)}}pause(){this.readyState===t.CONNECTING||this.readyState===t.CLOSED||(this._paused=!0,this._socket.pause())}ping(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(r=e,e=n=void 0):typeof n=="function"&&(r=n,n=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){yl(this,e,r);return}n===void 0&&(n=!this._isServer),this._sender.ping(e||yo,n,r)}pong(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof e=="function"?(r=e,e=n=void 0):typeof n=="function"&&(r=n,n=void 0),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){yl(this,e,r);return}n===void 0&&(n=!this._isServer),this._sender.pong(e||yo,n,r)}resume(){this.readyState===t.CONNECTING||this.readyState===t.CLOSED||(this._paused=!1,this._receiver._writableState.needDrain||this._socket.resume())}send(e,n,r){if(this.readyState===t.CONNECTING)throw new Error("WebSocket is not open: readyState 0 (CONNECTING)");if(typeof n=="function"&&(r=n,n={}),typeof e=="number"&&(e=e.toString()),this.readyState!==t.OPEN){yl(this,e,r);return}let i={binary:typeof e!="string",mask:!this._isServer,compress:!0,fin:!0,...n};this._extensions[Kt.extensionName]||(i.compress=!1),this._sender.send(e||yo,i,r)}terminate(){if(this.readyState!==t.CLOSED){if(this.readyState===t.CONNECTING){Le(this,this._req,"WebSocket was closed before the connection was established");return}this._socket&&(this._readyState=t.CLOSING,this._socket.destroy())}}};Object.defineProperty(q,"CONNECTING",{enumerable:!0,value:kt.indexOf("CONNECTING")});Object.defineProperty(q.prototype,"CONNECTING",{enumerable:!0,value:kt.indexOf("CONNECTING")});Object.defineProperty(q,"OPEN",{enumerable:!0,value:kt.indexOf("OPEN")});Object.defineProperty(q.prototype,"OPEN",{enumerable:!0,value:kt.indexOf("OPEN")});Object.defineProperty(q,"CLOSING",{enumerable:!0,value:kt.indexOf("CLOSING")});Object.defineProperty(q.prototype,"CLOSING",{enumerable:!0,value:kt.indexOf("CLOSING")});Object.defineProperty(q,"CLOSED",{enumerable:!0,value:kt.indexOf("CLOSED")});Object.defineProperty(q.prototype,"CLOSED",{enumerable:!0,value:kt.indexOf("CLOSED")});["binaryType","bufferedAmount","extensions","isPaused","protocol","readyState","url"].forEach(t=>{Object.defineProperty(q.prototype,t,{enumerable:!0})});["open","error","close","message"].forEach(t=>{Object.defineProperty(q.prototype,`on${t}`,{enumerable:!0,get(){for(let e of this.listeners(t))if(e[ml])return e[wv];return null},set(e){for(let n of this.listeners(t))if(n[ml]){this.removeListener(t,n);break}typeof e=="function"&&this.addEventListener(t,e,{[ml]:!0})}})});q.prototype.addEventListener=_v;q.prototype.removeEventListener=Ev;Bp.exports=q;function Cp(t,e,n,r){let i={allowSynchronousEvents:!0,autoPong:!0,closeTimeout:gv,protocolVersion:wl[1],maxPayload:104857600,skipUTF8Validation:!1,perMessageDeflate:!0,followRedirects:!1,maxRedirects:10,...r,socketPath:void 0,hostname:void 0,protocol:void 0,timeout:void 0,method:"GET",host:void 0,path:void 0,port:void 0};if(t._autoPong=i.autoPong,t._closeTimeout=i.closeTimeout,!wl.includes(i.protocolVersion))throw new RangeError(`Unsupported protocol version: ${i.protocolVersion} (supported versions: ${wl.join(", ")})`);let s;if(e instanceof gl)s=e;else try{s=new gl(e)}catch{throw new SyntaxError(`Invalid URL: ${e}`)}s.protocol==="http:"?s.protocol="ws:":s.protocol==="https:"&&(s.protocol="wss:"),t._url=s.href;let o=s.protocol==="wss:",a=s.protocol==="ws+unix:",c;if(s.protocol!=="ws:"&&!o&&!a?c=`The URL's protocol must be one of "ws:", "wss:", "http:", "https:", or "ws+unix:"`:a&&!s.pathname?c="The URL's pathname is empty":s.hash&&(c="The URL contains a fragment identifier"),c){let g=new SyntaxError(c);if(t._redirects===0)throw g;_o(t,g);return}let l=o?443:80,d=dv(16).toString("base64"),p=o?av.request:cv.request,m=new Set,u;if(i.createConnection=i.createConnection||(o?kv:Rv),i.defaultPort=i.defaultPort||l,i.port=s.port||l,i.host=s.hostname.startsWith("[")?s.hostname.slice(1,-1):s.hostname,i.headers={...i.headers,"Sec-WebSocket-Version":i.protocolVersion,"Sec-WebSocket-Key":d,Connection:"Upgrade",Upgrade:"websocket"},i.path=s.pathname+s.search,i.timeout=i.handshakeTimeout,i.perMessageDeflate&&(u=new Kt({...i.perMessageDeflate,isServer:!1,maxPayload:i.maxPayload}),i.headers["Sec-WebSocket-Extensions"]=Sv({[Kt.extensionName]:u.offer()})),n.length){for(let g of n){if(typeof g!="string"||!Tv.test(g)||m.has(g))throw new SyntaxError("An invalid or duplicated subprotocol was specified");m.add(g)}i.headers["Sec-WebSocket-Protocol"]=n.join(",")}if(i.origin&&(i.protocolVersion<13?i.headers["Sec-WebSocket-Origin"]=i.origin:i.headers.Origin=i.origin),(s.username||s.password)&&(i.auth=`${s.username}:${s.password}`),a){let g=i.path.split(":");i.socketPath=g[0],i.path=g[1]}let h;if(i.followRedirects){if(t._redirects===0){t._originalIpc=a,t._originalSecure=o,t._originalHostOrSocketPath=a?i.socketPath:s.host;let g=r&&r.headers;if(r={...r,headers:{}},g)for(let[w,S]of Object.entries(g))r.headers[w.toLowerCase()]=S}else if(t.listenerCount("redirect")===0){let g=a?t._originalIpc?i.socketPath===t._originalHostOrSocketPath:!1:t._originalIpc?!1:s.host===t._originalHostOrSocketPath;(!g||t._originalSecure&&!o)&&(delete i.headers.authorization,delete i.headers.cookie,g||delete i.headers.host,i.auth=void 0)}i.auth&&!r.headers.authorization&&(r.headers.authorization="Basic "+Buffer.from(i.auth).toString("base64")),h=t._req=p(i),t._redirects&&t.emit("redirect",t.url,h)}else h=t._req=p(i);i.timeout&&h.on("timeout",()=>{Le(t,h,"Opening handshake has timed out")}),h.on("error",g=>{h===null||h[Pp]||(h=t._req=null,_o(t,g))}),h.on("response",g=>{let w=g.headers.location,S=g.statusCode;if(w&&i.followRedirects&&S>=300&&S<400){if(++t._redirects>i.maxRedirects){Le(t,h,"Maximum redirects exceeded");return}h.abort();let v;try{v=new gl(w,e)}catch{let y=new SyntaxError(`Invalid URL: ${w}`);_o(t,y);return}Cp(t,v,n,r)}else t.emit("unexpected-response",h,g)||Le(t,h,`Unexpected server response: ${g.statusCode}`)}),h.on("upgrade",(g,w,S)=>{if(t.emit("upgrade",g),t.readyState!==q.CONNECTING)return;h=t._req=null;let v=g.headers.upgrade;if(v===void 0||v.toLowerCase()!=="websocket"){Le(t,w,"Invalid Upgrade header");return}let f=uv("sha1").update(d+mv).digest("base64");if(g.headers["sec-websocket-accept"]!==f){Le(t,w,"Invalid Sec-WebSocket-Accept header");return}let y=g.headers["sec-websocket-protocol"],E;if(y!==void 0?m.size?m.has(y)||(E="Server sent an invalid subprotocol"):E="Server sent a subprotocol but none was requested":m.size&&(E="Server sent no subprotocol"),E){Le(t,w,E);return}y&&(t._protocol=y);let T=g.headers["sec-websocket-extensions"];if(T!==void 0){if(!u){Le(t,w,"Server sent a Sec-WebSocket-Extensions header but no extension was requested");return}let R;try{R=vv(T)}catch{Le(t,w,"Invalid Sec-WebSocket-Extensions header");return}let D=Object.keys(R);if(D.length!==1||D[0]!==Kt.extensionName){Le(t,w,"Server indicated an extension that was not requested");return}try{u.accept(R[Kt.extensionName])}catch{Le(t,w,"Invalid Sec-WebSocket-Extensions header");return}t._extensions[Kt.extensionName]=u}t.setSocket(w,S,{allowSynchronousEvents:i.allowSynchronousEvents,generateMask:i.generateMask,maxPayload:i.maxPayload,skipUTF8Validation:i.skipUTF8Validation})}),i.finishRequest?i.finishRequest(h,t):h.end()}function _o(t,e){t._readyState=q.CLOSING,t._errorEmitted=!0,t.emit("error",e),t.emitClose()}function Rv(t){return t.path=t.socketPath,xp.connect(t)}function kv(t){return t.path=void 0,!t.servername&&t.servername!==""&&(t.servername=xp.isIP(t.host)?"":t.host),lv.connect(t)}function Le(t,e,n){t._readyState=q.CLOSING;let r=new Error(n);Error.captureStackTrace(r,Le),e.setHeader?(e[Pp]=!0,e.abort(),e.socket&&!e.socket.destroyed&&e.socket.destroy(),process.nextTick(_o,t,r)):(e.destroy(r),e.once("error",t.emit.bind(t,"error")),e.once("close",t.emitClose.bind(t)))}function yl(t,e,n){if(e){let r=pv(e)?e.size:Iv(e).length;t._socket?t._sender._bufferedBytes+=r:t._bufferedAmount+=r}if(n){let r=new Error(`WebSocket is not open: readyState ${t.readyState} (${kt[t.readyState]})`);process.nextTick(n,r)}}function bv(t,e){let n=this[pe];n._closeFrameReceived=!0,n._closeMessage=e,n._closeCode=t,n._socket[pe]!==void 0&&(n._socket.removeListener("data",Eo),process.nextTick(Dp,n._socket),t===1005?n.close():n.close(t,e))}function Av(){let t=this[pe];t.isPaused||t._socket.resume()}function xv(t){let e=this[pe];e._socket[pe]!==void 0&&(e._socket.removeListener("data",Eo),process.nextTick(Dp,e._socket),e.close(t[yv])),e._errorEmitted||(e._errorEmitted=!0,e.emit("error",t))}function Ap(){this[pe].emitClose()}function Ov(t,e){this[pe].emit("message",t,e)}function Pv(t){let e=this[pe];e._autoPong&&e.pong(t,!this._isServer,Op),e.emit("ping",t)}function Cv(t){this[pe].emit("pong",t)}function Dp(t){t.resume()}function Dv(t){let e=this[pe];e.readyState!==q.CLOSED&&(e.readyState===q.OPEN&&(e._readyState=q.CLOSING,Np(e)),this._socket.end(),e._errorEmitted||(e._errorEmitted=!0,e.emit("error",t)))}function Np(t){t._closeTimer=setTimeout(t._socket.destroy.bind(t._socket),t._closeTimeout)}function Lp(){let t=this[pe];if(this.removeListener("close",Lp),this.removeListener("data",Eo),this.removeListener("end",Fp),t._readyState=q.CLOSING,!this._readableState.endEmitted&&!t._closeFrameReceived&&!t._receiver._writableState.errorEmitted&&this._readableState.length!==0){let e=this.read(this._readableState.length);t._receiver.write(e)}t._receiver.end(),this[pe]=void 0,clearTimeout(t._closeTimer),t._receiver._writableState.finished||t._receiver._writableState.errorEmitted?t.emitClose():(t._receiver.on("error",Ap),t._receiver.on("finish",Ap))}function Eo(t){this[pe]._receiver.write(t)||this.pause()}function Fp(){let t=this[pe];t._readyState=q.CLOSING,t._receiver.end(),this.end()}function Mp(){let t=this[pe];this.removeListener("error",Mp),this.on("error",Op),t&&(t._readyState=q.CLOSING,this.destroy())}});var Gp=H((UO,$p)=>{"use strict";var BO=So(),{Duplex:Nv}=j("stream");function Up(t){t.emit("close")}function Lv(){!this.destroyed&&this._writableState.finished&&this.destroy()}function zp(t){this.removeListener("error",zp),this.destroy(),this.listenerCount("error")===0&&this.emit("error",t)}function Fv(t,e){let n=!0,r=new Nv({...e,autoDestroy:!1,emitClose:!1,objectMode:!1,writableObjectMode:!1});return t.on("message",function(s,o){let a=!o&&r._readableState.objectMode?s.toString():s;r.push(a)||t.pause()}),t.once("error",function(s){r.destroyed||(n=!1,r.destroy(s))}),t.once("close",function(){r.destroyed||r.push(null)}),r._destroy=function(i,s){if(t.readyState===t.CLOSED){s(i),process.nextTick(Up,r);return}let o=!1;t.once("error",function(c){o=!0,s(c)}),t.once("close",function(){o||s(i),process.nextTick(Up,r)}),n&&t.terminate()},r._final=function(i){if(t.readyState===t.CONNECTING){t.once("open",function(){r._final(i)});return}t._socket!==null&&(t._socket._writableState.finished?(i(),r._readableState.endEmitted&&r.destroy()):(t._socket.once("finish",function(){i()}),t.close()))},r._read=function(){t.isPaused&&t.resume()},r._write=function(i,s,o){if(t.readyState===t.CONNECTING){t.once("open",function(){r._write(i,s,o)});return}t.send(i,o)},r.on("end",Lv),r.on("error",zp),r}$p.exports=Fv});var _l=H((zO,Hp)=>{"use strict";var{tokenChars:Mv}=hr();function Bv(t){let e=new Set,n=-1,r=-1,i=0;for(i;i<t.length;i++){let o=t.charCodeAt(i);if(r===-1&&Mv[o]===1)n===-1&&(n=i);else if(i!==0&&(o===32||o===9))r===-1&&n!==-1&&(r=i);else if(o===44){if(n===-1)throw new SyntaxError(`Unexpected character at index ${i}`);r===-1&&(r=i);let a=t.slice(n,r);if(e.has(a))throw new SyntaxError(`The "${a}" subprotocol is duplicated`);e.add(a),n=r=-1}else throw new SyntaxError(`Unexpected character at index ${i}`)}if(n===-1||r!==-1)throw new SyntaxError("Unexpected end of input");let s=t.slice(n,i);if(e.has(s))throw new SyntaxError(`The "${s}" subprotocol is duplicated`);return e.add(s),e}Hp.exports={parse:Bv}});var Kp=H((GO,Zp)=>{"use strict";var Uv=j("events"),vo=j("http"),{Duplex:$O}=j("stream"),{createHash:zv}=j("crypto"),jp=wo(),kn=fr(),$v=_l(),Gv=So(),{CLOSE_TIMEOUT:Hv,GUID:jv,kWebSocket:Wv}=It(),qv=/^[+/0-9A-Za-z]{22}==$/,Wp=0,qp=1,Jp=2,El=class extends Uv{constructor(e,n){if(super(),e={allowSynchronousEvents:!0,autoPong:!0,maxPayload:100*1024*1024,skipUTF8Validation:!1,perMessageDeflate:!1,handleProtocols:null,clientTracking:!0,closeTimeout:Hv,verifyClient:null,noServer:!1,backlog:null,server:null,host:null,path:null,port:null,WebSocket:Gv,...e},e.port==null&&!e.server&&!e.noServer||e.port!=null&&(e.server||e.noServer)||e.server&&e.noServer)throw new TypeError('One and only one of the "port", "server", or "noServer" options must be specified');if(e.port!=null?(this._server=vo.createServer((r,i)=>{let s=vo.STATUS_CODES[426];i.writeHead(426,{"Content-Length":s.length,"Content-Type":"text/plain"}),i.end(s)}),this._server.listen(e.port,e.host,e.backlog,n)):e.server&&(this._server=e.server),this._server){let r=this.emit.bind(this,"connection");this._removeListeners=Vv(this._server,{listening:this.emit.bind(this,"listening"),error:this.emit.bind(this,"error"),upgrade:(i,s,o)=>{this.handleUpgrade(i,s,o,r)}})}e.perMessageDeflate===!0&&(e.perMessageDeflate={}),e.clientTracking&&(this.clients=new Set,this._shouldEmitClose=!1),this.options=e,this._state=Wp}address(){if(this.options.noServer)throw new Error('The server is operating in "noServer" mode');return this._server?this._server.address():null}close(e){if(this._state===Jp){e&&this.once("close",()=>{e(new Error("The server is not running"))}),process.nextTick(bi,this);return}if(e&&this.once("close",e),this._state!==qp)if(this._state=qp,this.options.noServer||this.options.server)this._server&&(this._removeListeners(),this._removeListeners=this._server=null),this.clients?this.clients.size?this._shouldEmitClose=!0:process.nextTick(bi,this):process.nextTick(bi,this);else{let n=this._server;this._removeListeners(),this._removeListeners=this._server=null,n.close(()=>{bi(this)})}}shouldHandle(e){if(this.options.path){let n=e.url.indexOf("?");if((n!==-1?e.url.slice(0,n):e.url)!==this.options.path)return!1}return!0}handleUpgrade(e,n,r,i){n.on("error",Vp);let s=e.headers["sec-websocket-key"],o=e.headers.upgrade,a=+e.headers["sec-websocket-version"];if(e.method!=="GET"){bn(this,e,n,405,"Invalid HTTP method");return}if(o===void 0||o.toLowerCase()!=="websocket"){bn(this,e,n,400,"Invalid Upgrade header");return}if(s===void 0||!qv.test(s)){bn(this,e,n,400,"Missing or invalid Sec-WebSocket-Key header");return}if(a!==13&&a!==8){bn(this,e,n,400,"Missing or invalid Sec-WebSocket-Version header",{"Sec-WebSocket-Version":"13, 8"});return}if(!this.shouldHandle(e)){Ai(n,400);return}let c=e.headers["sec-websocket-protocol"],l=new Set;if(c!==void 0)try{l=$v.parse(c)}catch{bn(this,e,n,400,"Invalid Sec-WebSocket-Protocol header");return}let d=e.headers["sec-websocket-extensions"],p={};if(this.options.perMessageDeflate&&d!==void 0){let m=new kn({...this.options.perMessageDeflate,isServer:!0,maxPayload:this.options.maxPayload});try{let u=jp.parse(d);u[kn.extensionName]&&(m.accept(u[kn.extensionName]),p[kn.extensionName]=m)}catch{bn(this,e,n,400,"Invalid or unacceptable Sec-WebSocket-Extensions header");return}}if(this.options.verifyClient){let m={origin:e.headers[`${a===8?"sec-websocket-origin":"origin"}`],secure:!!(e.socket.authorized||e.socket.encrypted),req:e};if(this.options.verifyClient.length===2){this.options.verifyClient(m,(u,h,g,w)=>{if(!u)return Ai(n,h||401,g,w);this.completeUpgrade(p,s,l,e,n,r,i)});return}if(!this.options.verifyClient(m))return Ai(n,401)}this.completeUpgrade(p,s,l,e,n,r,i)}completeUpgrade(e,n,r,i,s,o,a){if(!s.readable||!s.writable)return s.destroy();if(s[Wv])throw new Error("server.handleUpgrade() was called more than once with the same socket, possibly due to a misconfiguration");if(this._state>Wp)return Ai(s,503);let l=["HTTP/1.1 101 Switching Protocols","Upgrade: websocket","Connection: Upgrade",`Sec-WebSocket-Accept: ${zv("sha1").update(n+jv).digest("base64")}`],d=new this.options.WebSocket(null,void 0,this.options);if(r.size){let p=this.options.handleProtocols?this.options.handleProtocols(r,i):r.values().next().value;p&&(l.push(`Sec-WebSocket-Protocol: ${p}`),d._protocol=p)}if(e[kn.extensionName]){let p=e[kn.extensionName].params,m=jp.format({[kn.extensionName]:[p]});l.push(`Sec-WebSocket-Extensions: ${m}`),d._extensions=e}this.emit("headers",l,i),s.write(l.concat(`\r
14
14
  `).join(`\r
15
- `)),s.removeListener("error",Vp),d.setSocket(s,o,{allowSynchronousEvents:this.options.allowSynchronousEvents,maxPayload:this.options.maxPayload,skipUTF8Validation:this.options.skipUTF8Validation}),this.clients&&(this.clients.add(d),d.on("close",()=>{this.clients.delete(d),this._shouldEmitClose&&!this.clients.size&&process.nextTick(ki,this)})),a(d,i)}};Zp.exports=yl;function Vv(t,e){for(let n of Object.keys(e))t.on(n,e[n]);return function(){for(let r of Object.keys(e))t.removeListener(r,e[r])}}function ki(t){t._state=Jp,t.emit("close")}function Vp(){this.destroy()}function bi(t,e,n,r){n=n||So.STATUS_CODES[e],r={Connection:"close","Content-Type":"text/html","Content-Length":Buffer.byteLength(n),...r},t.once("finish",t.destroy),t.end(`HTTP/1.1 ${e} ${So.STATUS_CODES[e]}\r
15
+ `)),s.removeListener("error",Vp),d.setSocket(s,o,{allowSynchronousEvents:this.options.allowSynchronousEvents,maxPayload:this.options.maxPayload,skipUTF8Validation:this.options.skipUTF8Validation}),this.clients&&(this.clients.add(d),d.on("close",()=>{this.clients.delete(d),this._shouldEmitClose&&!this.clients.size&&process.nextTick(bi,this)})),a(d,i)}};Zp.exports=El;function Vv(t,e){for(let n of Object.keys(e))t.on(n,e[n]);return function(){for(let r of Object.keys(e))t.removeListener(r,e[r])}}function bi(t){t._state=Jp,t.emit("close")}function Vp(){this.destroy()}function Ai(t,e,n,r){n=n||vo.STATUS_CODES[e],r={Connection:"close","Content-Type":"text/html","Content-Length":Buffer.byteLength(n),...r},t.once("finish",t.destroy),t.end(`HTTP/1.1 ${e} ${vo.STATUS_CODES[e]}\r
16
16
  `+Object.keys(r).map(i=>`${i}: ${r[i]}`).join(`\r
17
17
  `)+`\r
18
18
  \r
19
- `+n)}function bn(t,e,n,r,i,s){if(t.listenerCount("wsClientError")){let o=new Error(i);Error.captureStackTrace(o,bn),t.emit("wsClientError",o,n,e)}else bi(n,r,i,s)}});import{existsSync as wI,openSync as yI}from"node:fs";import{mkdir as _I}from"node:fs/promises";import{dirname as EI}from"node:path";import{fileURLToPath as SI}from"node:url";function II(t,e){return e==="legacy"?t.logFile:t.daemonStdioLog}function vl(t=F()){return wI(t.libEntry)?t.libEntry:SI(new URL("../index.ts",import.meta.url))}async function lg(t={}){let e=t.paths??F(),n=t.entryOverride??vl(e),r=II(e,process.env.COZE_BRIDGE_LOG_MODE);await _I(EI(r),{recursive:!0});let i=yI(r,"a"),o=n.endsWith(".ts")?["--import","tsx/esm",n,"--daemon"]:[n,"--daemon"],a=Fe(process.execPath,o,{detached:!0,stdio:["ignore",i,i],env:{...process.env,[Oi]:"1"}});if(a.unref(),typeof a.pid!="number")throw new Error("failed to spawn daemon (no pid)");return vI.info("daemon spawned",{pid:a.pid,entry:n}),{pid:a.pid,entry:n}}var vI,Oi,bo=ve(()=>{"use strict";gt();L();le();vI=b("spawn-daemon"),Oi="COZE_BRIDGE_DAEMON"});import{spawn as aT}from"node:child_process";import{mkdir as cT,unlink as lT,writeFile as dT}from"node:fs/promises";import{dirname as uT,join as fT}from"node:path";function _r(t){return t.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function hT(t){if(!t)return"";let e=Object.entries(t).map(([n,r])=>` <key>${_r(n)}</key>
20
- <string>${_r(r)}</string>`).join(`
19
+ `+n)}function bn(t,e,n,r,i,s){if(t.listenerCount("wsClientError")){let o=new Error(i);Error.captureStackTrace(o,bn),t.emit("wsClientError",o,n,e)}else Ai(n,r,i,s)}});import{existsSync as wI,openSync as yI}from"node:fs";import{mkdir as _I}from"node:fs/promises";import{dirname as EI}from"node:path";import{fileURLToPath as SI}from"node:url";function II(t,e){return e==="legacy"?t.logFile:t.daemonStdioLog}function Tl(t=F()){return wI(t.libEntry)?t.libEntry:SI(new URL("../index.ts",import.meta.url))}async function lg(t={}){let e=t.paths??F(),n=t.entryOverride??Tl(e),r=II(e,process.env.COZE_BRIDGE_LOG_MODE);await _I(EI(r),{recursive:!0});let i=yI(r,"a"),o=n.endsWith(".ts")?["--import","tsx/esm",n,"--daemon"]:[n,"--daemon"],a=Fe(process.execPath,o,{detached:!0,stdio:["ignore",i,i],env:{...process.env,[Pi]:"1"}});if(a.unref(),typeof a.pid!="number")throw new Error("failed to spawn daemon (no pid)");return vI.info("daemon spawned",{pid:a.pid,entry:n}),{pid:a.pid,entry:n}}var vI,Pi,Ao=ve(()=>{"use strict";gt();L();le();vI=b("spawn-daemon"),Pi="COZE_BRIDGE_DAEMON"});import{spawn as aT}from"node:child_process";import{mkdir as cT,unlink as lT,writeFile as dT}from"node:fs/promises";import{dirname as uT,join as fT}from"node:path";function Er(t){return t.replace(/&/g,"&amp;").replace(/</g,"&lt;").replace(/>/g,"&gt;").replace(/"/g,"&quot;")}function hT(t){if(!t)return"";let e=Object.entries(t).map(([n,r])=>` <key>${Er(n)}</key>
20
+ <string>${Er(r)}</string>`).join(`
21
21
  `);return e?`
22
22
  <key>EnvironmentVariables</key>
23
23
  <dict>
24
24
  ${e}
25
- </dict>`:""}function Al(t,e){return new Promise((n,r)=>{let i=aT(t,e,{stdio:["ignore","pipe","pipe"]}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var Pi,bl,xl,Tg=ve(()=>{"use strict";L();Pi=b("supervisor.launchd"),bl="ai.coze.bridge",xl={platform:"darwin",renderConfig(t){return`<?xml version="1.0" encoding="UTF-8"?>
25
+ </dict>`:""}function pT(t,e){return new Promise((n,r)=>{let i=aT(t,e,{stdio:["ignore","pipe","pipe"]}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var _r,Ci,Lo,xl,Tg=ve(()=>{"use strict";L();_r=b("supervisor.launchd"),Ci="ai.coze.bridge",Lo=pT,xl={platform:"darwin",renderConfig(t){return`<?xml version="1.0" encoding="UTF-8"?>
26
26
  <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
27
27
  <plist version="1.0">
28
28
  <dict>
29
29
  <key>Label</key>
30
- <string>${bl}</string>
30
+ <string>${Ci}</string>
31
31
  <key>ProgramArguments</key>
32
32
  <array>
33
- <string>${_r(t.nodeBin)}</string>
34
- <string>${_r(t.entry)}</string>
33
+ <string>${Er(t.nodeBin)}</string>
34
+ <string>${Er(t.entry)}</string>
35
35
  <string>--daemon</string>
36
36
  </array>
37
37
  <key>RunAtLoad</key>
@@ -41,13 +41,13 @@ ${e}
41
41
  <key>ThrottleInterval</key>
42
42
  <integer>10</integer>
43
43
  <key>StandardOutPath</key>
44
- <string>${_r(t.logFile)}</string>
44
+ <string>${Er(t.logFile)}</string>
45
45
  <key>StandardErrorPath</key>
46
- <string>${_r(t.logFile)}</string>${hT(t.env)}
46
+ <string>${Er(t.logFile)}</string>${hT(t.env)}
47
47
  </dict>
48
48
  </plist>
49
- `},configPath(t){return fT(t.homeDir,"Library","LaunchAgents",`${bl}.plist`)},async install(t,e){let n=e?.activate!==!1,r=this.configPath(t);await cT(uT(r),{recursive:!0}),await dT(r,this.renderConfig(t),"utf8"),Pi.info("plist written",{plistPath:r,activate:n}),n&&(await Al("launchctl",["unload","-w",r]).catch(i=>Pi.info("launchctl unload before load (ignored, likely not loaded yet)",{err:String(i)})),await Al("launchctl",["load","-w",r]),Pi.info("launchd job loaded",{label:bl}))},async uninstall(t){let e=this.configPath(t);await Al("launchctl",["unload","-w",e]).catch(n=>Pi.warn("launchctl unload failed (ignored)",{err:String(n)})),await lT(e).catch(n=>{if(n.code!=="ENOENT")throw n}),Pi.info("launchd job removed",{plistPath:e})}}});import{spawn as pT}from"node:child_process";import{mkdir as gT,unlink as mT,writeFile as wT}from"node:fs/promises";import{dirname as yT,join as Rg}from"node:path";function Lo(t,e){return t.isRoot?e:["--user",...e]}function ET(t){return t?Object.entries(t).map(([e,n])=>{let r=n.replace(/\\/g,"\\\\").replace(/"/g,'\\"');return`Environment="${e}=${r}"`}).join(`
50
- `):""}function Fo(t,e){return new Promise((n,r)=>{let i=pT(t,e,{stdio:["ignore","pipe","pipe"]}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var No,Er,_T,Ol,kg=ve(()=>{"use strict";L();No=b("supervisor.systemd"),Er="coze-bridge.service",_T="/etc/systemd/system";Ol={platform:"linux",renderConfig(t){let e=t.isRoot?"multi-user.target":"default.target";return`[Unit]
49
+ `},configPath(t){return fT(t.homeDir,"Library","LaunchAgents",`${Ci}.plist`)},async install(t,e){let n=e?.activate!==!1,r=this.configPath(t);if(await cT(uT(r),{recursive:!0}),await dT(r,this.renderConfig(t),"utf8"),_r.info("plist written",{plistPath:r,activate:n}),!n)return;await Lo("launchctl",["unload","-w",r]).catch(s=>_r.info("launchctl unload before load (ignored, likely not loaded yet)",{err:String(s)})),await Lo("launchctl",["load","-w",r]),_r.info("launchd job loaded",{label:Ci});let i=process.getuid?.()??0;await Lo("launchctl",["kickstart","-k",`gui/${i}/${Ci}`]),_r.info("launchd job kickstarted",{label:Ci,uid:i})},async uninstall(t){let e=this.configPath(t);await Lo("launchctl",["unload","-w",e]).catch(n=>_r.warn("launchctl unload failed (ignored)",{err:String(n)})),await lT(e).catch(n=>{if(n.code!=="ENOENT")throw n}),_r.info("launchd job removed",{plistPath:e})}}});import{spawn as gT}from"node:child_process";import{mkdir as mT,unlink as wT,writeFile as yT}from"node:fs/promises";import{dirname as _T,join as Rg}from"node:path";function Mo(t,e){return t.isRoot?e:["--user",...e]}function ST(t){return t?Object.entries(t).map(([e,n])=>{let r=n.replace(/\\/g,"\\\\").replace(/"/g,'\\"');return`Environment="${e}=${r}"`}).join(`
50
+ `):""}function Bo(t,e){return new Promise((n,r)=>{let i=gT(t,e,{stdio:["ignore","pipe","pipe"]}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var Fo,Sr,ET,Ol,kg=ve(()=>{"use strict";L();Fo=b("supervisor.systemd"),Sr="coze-bridge.service",ET="/etc/systemd/system";Ol={platform:"linux",renderConfig(t){let e=t.isRoot?"multi-user.target":"default.target";return`[Unit]
51
51
  Description=Coze Bridge daemon
52
52
  After=network.target
53
53
 
@@ -58,10 +58,10 @@ Restart=always
58
58
  RestartSec=3
59
59
  StandardOutput=append:${t.logFile}
60
60
  StandardError=append:${t.logFile}
61
- ${ET(t.env)}
61
+ ${ST(t.env)}
62
62
  [Install]
63
63
  WantedBy=${e}
64
- `},configPath(t){return t.isRoot?Rg(_T,Er):Rg(t.homeDir,".config","systemd","user",Er)},async install(t,e){let n=e?.activate!==!1,r=this.configPath(t),i=t.isRoot?"system":"user";await gT(yT(r),{recursive:!0}),await wT(r,this.renderConfig(t),"utf8"),No.info("systemd unit written",{unitPath:r,mode:i,activate:n}),await Fo("systemctl",Lo(t,["daemon-reload"])),await Fo("systemctl",Lo(t,n?["enable","--now",Er]:["enable",Er])),No.info("systemd unit enabled",{unitName:Er,mode:i,activate:n})},async uninstall(t){let e=this.configPath(t);await Fo("systemctl",Lo(t,["disable","--now",Er])).catch(n=>No.warn("systemctl disable failed (ignored)",{err:String(n)})),await mT(e).catch(n=>{if(n.code!=="ENOENT")throw n}),await Fo("systemctl",Lo(t,["daemon-reload"])).catch(()=>{}),No.info("systemd unit removed",{unitPath:e})}}});import{spawn as ST}from"node:child_process";import{join as vT}from"node:path";function bg(t,e){return new Promise((n,r)=>{let i=ST(t,e,{stdio:["ignore","pipe","pipe"],shell:!1}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var Pl,Mo,Cl,Ag=ve(()=>{"use strict";L();Pl=b("supervisor.taskscheduler"),Mo="CozeBridge",Cl={platform:"win32",renderConfig(t){return`<?xml version="1.0" encoding="UTF-16"?>
64
+ `},configPath(t){return t.isRoot?Rg(ET,Sr):Rg(t.homeDir,".config","systemd","user",Sr)},async install(t,e){let n=e?.activate!==!1,r=this.configPath(t),i=t.isRoot?"system":"user";await mT(_T(r),{recursive:!0}),await yT(r,this.renderConfig(t),"utf8"),Fo.info("systemd unit written",{unitPath:r,mode:i,activate:n}),await Bo("systemctl",Mo(t,["daemon-reload"])),await Bo("systemctl",Mo(t,n?["enable","--now",Sr]:["enable",Sr])),Fo.info("systemd unit enabled",{unitName:Sr,mode:i,activate:n})},async uninstall(t){let e=this.configPath(t);await Bo("systemctl",Mo(t,["disable","--now",Sr])).catch(n=>Fo.warn("systemctl disable failed (ignored)",{err:String(n)})),await wT(e).catch(n=>{if(n.code!=="ENOENT")throw n}),await Bo("systemctl",Mo(t,["daemon-reload"])).catch(()=>{}),Fo.info("systemd unit removed",{unitPath:e})}}});import{spawn as vT}from"node:child_process";import{join as IT}from"node:path";function bg(t,e){return new Promise((n,r)=>{let i=vT(t,e,{stdio:["ignore","pipe","pipe"],shell:!1}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`${t} ${e.join(" ")} exited ${o}: ${s.trim()}`))})})}var Pl,Uo,Cl,Ag=ve(()=>{"use strict";L();Pl=b("supervisor.taskscheduler"),Uo="CozeBridge",Cl={platform:"win32",renderConfig(t){return`<?xml version="1.0" encoding="UTF-16"?>
65
65
  <Task version="1.2" xmlns="http://schemas.microsoft.com/windows/2004/02/mit/task">
66
66
  <RegistrationInfo>
67
67
  <Description>Coze Bridge daemon</Description>
@@ -85,24 +85,24 @@ WantedBy=${e}
85
85
  </Exec>
86
86
  </Actions>
87
87
  </Task>
88
- `},configPath(t){return vT(t.homeDir,".coze","bridge","task.xml")},async install(t){let n=`cmd.exe /c ${[`^"${t.nodeBin}^"`,`^"${t.entry}^"`,"--daemon",`>> ^"${t.logFile}^" 2>&1`].join(" ")}`;await bg("schtasks",["/Create","/SC","ONLOGON","/TN",Mo,"/TR",n,"/RU",t.userName,"/F"]),Pl.info("task scheduler entry created",{task:Mo,logFile:t.logFile})},async uninstall(t){await bg("schtasks",["/Delete","/TN",Mo,"/F"]).catch(e=>Pl.warn("schtasks /Delete failed (ignored)",{err:String(e)})),Pl.info("task scheduler entry removed",{task:Mo})}}});var xg={};Ni(xg,{buildContext:()=>AT,getSupervisor:()=>RT,launchdSupervisor:()=>xl,systemdSupervisor:()=>Ol,taskSchedulerSupervisor:()=>Cl});import{homedir as IT,userInfo as TT}from"node:os";function RT(t=process.platform){switch(t){case"darwin":return xl;case"linux":return Ol;case"win32":return Cl;default:throw new Error(`unsupported platform for OS supervisor: ${t}`)}}function bT(){let t={};for(let e of kT){let n=process.env[e];n&&(t[e]=n)}return t}function AT(){let t=F();return{nodeBin:process.execPath,entry:vl(t),logFile:t.logFile,homeDir:IT(),userName:TT().username,isRoot:process.getuid?.()===0,env:bT()}}var kT,Og=ve(()=>{"use strict";le();bo();Tg();kg();Ag();kT=["PATH","HOME","HTTP_PROXY","HTTPS_PROXY","NO_PROXY","ALL_PROXY","http_proxy","https_proxy","no_proxy","all_proxy","NODE_EXTRA_CA_CERTS"]});L();tn();var Kl=b("acp-installer-warmup"),mm=["claude-code","codex"];async function Xl(t={}){let e=t.ensure??en,r=(await Promise.allSettled(mm.map(async i=>{let s=await e(i);Kl.info("acp wrapper warmup ok",{framework:i,path:s})}))).filter(i=>i.status==="rejected");r.length>0&&Kl.warn("acp wrapper warmup partial failure (\u5C06\u5728\u4E0B\u6B21 createAgent \u65F6\u91CD\u8BD5\u5E76\u629B\u9519\u7ED9\u7528\u6237)",{failedCount:r.length,reasons:r.map(i=>i.reason instanceof Error?i.reason.message:String(i.reason))})}At();L();import{readdir as Am}from"node:fs/promises";import{mkdir as rd,writeFile as id}from"node:fs/promises";import{join as Jo}from"node:path";var bm={"claude-code":"CLAUDE.md",codex:"AGENTS.md",openclaw:"SOUL.md"};async function Ln(t,e,n){await rd(t,{recursive:!0});let r=bm[e],i=Jo(t,r);return await id(i,n??"","utf8"),i}async function sd(t){let e=Jo(t,".claude");await rd(e,{recursive:!0});let n=Jo(e,"settings.local.json"),r=JSON.stringify({permissions:{defaultMode:"bypassPermissions"}},null,2);return await id(n,r,"utf8"),n}var Oe=b("agent-detail-sync"),xm=6e4,Om=5*6e4,Ki=class{constructor(e){this.opts=e}opts;retryQueue=new Map;async syncAll(e){let n=this.opts.paths.agentsRoot,r;try{r=await Am(n)}catch(i){Oe.info("agents dir not found, skip detail sync",{root:n,err:String(i)});return}Oe.info("starting detail sync",{reason:e,count:r.length}),await Promise.allSettled(r.map(async i=>{let s=await me(i,this.opts.paths).catch(()=>null);if(s){if(s.disconnectedAt){Oe.debug("detail sync: skip disconnected agent",{agentId:i});return}try{await this.syncOne(i,s)}catch(o){Oe.warn("detail sync failed for agent, skipping",{agentId:i,err:String(o)})}}})),Oe.info("detail sync done",{reason:e})}async retryPending(){if(this.retryQueue.size===0)return;let e=Date.now(),n=[];for(let[r,i]of this.retryQueue)e>=i.dueAt&&n.push(r);if(n.length!==0){Oe.info("retrying pending detail syncs",{count:n.length});for(let r of n)try{await this.syncOne(r)}catch(i){Oe.debug("detail sync retry still failing, will try again",{agentId:r,err:String(i)})}}}async syncOne(e,n){let r=n??await me(e,this.opts.paths);if(!r){Oe.info("detail sync: agent config missing, skip",{agentId:e});return}let i;try{i=await this.opts.sendDetail({_meta:{cozeAgentId:e}}),this.retryQueue.delete(e)}catch(a){Oe.warn("detail RPC failed, using local data",{agentId:e,err:String(a)});let c=this.retryQueue.get(e),l=c?Math.min(c.currentDelay*2,Om):xm;this.retryQueue.set(e,{dueAt:Date.now()+l,currentDelay:l});return}if(i.agentId&&i.agentId!==e){Oe.warn("detail response agentId mismatch, ignoring",{agentId:e,responseAgentId:i.agentId});return}let s=!1,o=!1;if(i.agentName&&i.agentName!==r.agentName&&(r.agentName=i.agentName,s=!0),i.description!==void 0&&i.description!==r.description&&(r.description=i.description,s=!0),i.cozeIdentity&&i.cozeIdentity!==r.cozeIdentity&&(r.cozeIdentity=i.cozeIdentity,s=!0,o=!0),i.deployType&&Oe.info("detail.deployType",{agentId:e,deployType:i.deployType}),!s){Oe.debug("detail sync: no diff",{agentId:e});return}await Ae(r,this.opts.paths),Oe.info("detail sync: config updated",{agentId:e,identityChanged:o,agentName:r.agentName}),o&&(await Ln(r.workspace,r.framework,r.cozeIdentity),this.opts.handlers.reloadAgentSessionsPublic(e,"detail-sync"))}};var vf=ht(Bd(),1);import{lstat as lc,mkdir as dc,readFile as yf,readdir as r_,rm as i_,stat as s_,writeFile as uc}from"node:fs/promises";import{dirname as o_,join as at,normalize as a_,relative as pc,resolve as fc,sep as _f}from"node:path";import{Readable as Ef}from"node:stream";import{pipeline as Sf}from"node:stream/promises";import Ym from"events";import xe from"fs";import{EventEmitter as Va}from"node:events";import _u from"node:stream";import{StringDecoder as Qm}from"node:string_decoder";import vu from"node:path";import Vn from"node:fs";import{dirname as fw,parse as hw}from"path";import{EventEmitter as Sw}from"events";import Aa from"assert";import{Buffer as hn}from"buffer";import*as Hd from"zlib";import vw from"zlib";import{posix as zn}from"node:path";import{basename as Zw}from"node:path";import As from"fs";import it from"fs";import Kd from"path";import{win32 as oy}from"node:path";import ru from"path";import Mu from"node:fs";import Iy from"node:assert";import{randomBytes as Bu}from"node:crypto";import B from"node:fs";import ie from"node:path";import Uu from"fs";import Ms from"node:fs";import Jr from"node:path";import De from"node:fs";import Oy from"node:fs/promises";import Ps from"node:path";import{join as Ku}from"node:path";import Ce from"node:fs";import Qu from"node:path";var Km=Object.defineProperty,Xm=(t,e)=>{for(var n in e)Km(t,n,{get:e[n],enumerable:!0})},Ud=typeof process=="object"&&process?process:{stdout:null,stderr:null},ew=t=>!!t&&typeof t=="object"&&(t instanceof mn||t instanceof _u||tw(t)||nw(t)),tw=t=>!!t&&typeof t=="object"&&t instanceof Va&&typeof t.pipe=="function"&&t.pipe!==_u.Writable.prototype.pipe,nw=t=>!!t&&typeof t=="object"&&t instanceof Va&&typeof t.write=="function"&&typeof t.end=="function",mt=Symbol("EOF"),wt=Symbol("maybeEmitEnd"),Ot=Symbol("emittedEnd"),ts=Symbol("emittingEnd"),Pr=Symbol("emittedError"),ns=Symbol("closed"),zd=Symbol("read"),rs=Symbol("flush"),$d=Symbol("flushChunk"),je=Symbol("encoding"),Un=Symbol("decoder"),de=Symbol("flowing"),Cr=Symbol("paused"),jn=Symbol("resume"),ue=Symbol("buffer"),Re=Symbol("pipes"),fe=Symbol("bufferLength"),ea=Symbol("bufferPush"),is=Symbol("bufferShift"),Ie=Symbol("objectMode"),Q=Symbol("destroyed"),ta=Symbol("error"),na=Symbol("emitData"),Gd=Symbol("emitEnd"),ra=Symbol("emitEnd2"),et=Symbol("async"),ia=Symbol("abort"),ss=Symbol("aborted"),Dr=Symbol("signal"),rn=Symbol("dataListeners"),Pe=Symbol("discarded"),Nr=t=>Promise.resolve().then(t),rw=t=>t(),iw=t=>t==="end"||t==="finish"||t==="prefinish",sw=t=>t instanceof ArrayBuffer||!!t&&typeof t=="object"&&t.constructor&&t.constructor.name==="ArrayBuffer"&&t.byteLength>=0,ow=t=>!Buffer.isBuffer(t)&&ArrayBuffer.isView(t),Eu=class{src;dest;opts;ondrain;constructor(t,e,n){this.src=t,this.dest=e,this.opts=n,this.ondrain=()=>t[jn](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(t){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},aw=class extends Eu{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor(t,e,n){super(t,e,n),this.proxyErrors=r=>this.dest.emit("error",r),t.on("error",this.proxyErrors)}},cw=t=>!!t.objectMode,lw=t=>!t.objectMode&&!!t.encoding&&t.encoding!=="buffer",mn=class extends Va{[de]=!1;[Cr]=!1;[Re]=[];[ue]=[];[Ie];[je];[et];[Un];[mt]=!1;[Ot]=!1;[ts]=!1;[ns]=!1;[Pr]=null;[fe]=0;[Q]=!1;[Dr];[ss]=!1;[rn]=0;[Pe]=!1;writable=!0;readable=!0;constructor(...t){let e=t[0]||{};if(super(),e.objectMode&&typeof e.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");cw(e)?(this[Ie]=!0,this[je]=null):lw(e)?(this[je]=e.encoding,this[Ie]=!1):(this[Ie]=!1,this[je]=null),this[et]=!!e.async,this[Un]=this[je]?new Qm(this[je]):null,e&&e.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[ue]}),e&&e.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[Re]});let{signal:n}=e;n&&(this[Dr]=n,n.aborted?this[ia]():n.addEventListener("abort",()=>this[ia]()))}get bufferLength(){return this[fe]}get encoding(){return this[je]}set encoding(t){throw new Error("Encoding must be set at instantiation time")}setEncoding(t){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[Ie]}set objectMode(t){throw new Error("objectMode must be set at instantiation time")}get async(){return this[et]}set async(t){this[et]=this[et]||!!t}[ia](){this[ss]=!0,this.emit("abort",this[Dr]?.reason),this.destroy(this[Dr]?.reason)}get aborted(){return this[ss]}set aborted(t){}write(t,e,n){if(this[ss])return!1;if(this[mt])throw new Error("write after end");if(this[Q])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;typeof e=="function"&&(n=e,e="utf8"),e||(e="utf8");let r=this[et]?Nr:rw;if(!this[Ie]&&!Buffer.isBuffer(t)){if(ow(t))t=Buffer.from(t.buffer,t.byteOffset,t.byteLength);else if(sw(t))t=Buffer.from(t);else if(typeof t!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[Ie]?(this[de]&&this[fe]!==0&&this[rs](!0),this[de]?this.emit("data",t):this[ea](t),this[fe]!==0&&this.emit("readable"),n&&r(n),this[de]):t.length?(typeof t=="string"&&!(e===this[je]&&!this[Un]?.lastNeed)&&(t=Buffer.from(t,e)),Buffer.isBuffer(t)&&this[je]&&(t=this[Un].write(t)),this[de]&&this[fe]!==0&&this[rs](!0),this[de]?this.emit("data",t):this[ea](t),this[fe]!==0&&this.emit("readable"),n&&r(n),this[de]):(this[fe]!==0&&this.emit("readable"),n&&r(n),this[de])}read(t){if(this[Q])return null;if(this[Pe]=!1,this[fe]===0||t===0||t&&t>this[fe])return this[wt](),null;this[Ie]&&(t=null),this[ue].length>1&&!this[Ie]&&(this[ue]=[this[je]?this[ue].join(""):Buffer.concat(this[ue],this[fe])]);let e=this[zd](t||null,this[ue][0]);return this[wt](),e}[zd](t,e){if(this[Ie])this[is]();else{let n=e;t===n.length||t===null?this[is]():typeof n=="string"?(this[ue][0]=n.slice(t),e=n.slice(0,t),this[fe]-=t):(this[ue][0]=n.subarray(t),e=n.subarray(0,t),this[fe]-=t)}return this.emit("data",e),!this[ue].length&&!this[mt]&&this.emit("drain"),e}end(t,e,n){return typeof t=="function"&&(n=t,t=void 0),typeof e=="function"&&(n=e,e="utf8"),t!==void 0&&this.write(t,e),n&&this.once("end",n),this[mt]=!0,this.writable=!1,(this[de]||!this[Cr])&&this[wt](),this}[jn](){this[Q]||(!this[rn]&&!this[Re].length&&(this[Pe]=!0),this[Cr]=!1,this[de]=!0,this.emit("resume"),this[ue].length?this[rs]():this[mt]?this[wt]():this.emit("drain"))}resume(){return this[jn]()}pause(){this[de]=!1,this[Cr]=!0,this[Pe]=!1}get destroyed(){return this[Q]}get flowing(){return this[de]}get paused(){return this[Cr]}[ea](t){this[Ie]?this[fe]+=1:this[fe]+=t.length,this[ue].push(t)}[is](){return this[Ie]?this[fe]-=1:this[fe]-=this[ue][0].length,this[ue].shift()}[rs](t=!1){do;while(this[$d](this[is]())&&this[ue].length);!t&&!this[ue].length&&!this[mt]&&this.emit("drain")}[$d](t){return this.emit("data",t),this[de]}pipe(t,e){if(this[Q])return t;this[Pe]=!1;let n=this[Ot];return e=e||{},t===Ud.stdout||t===Ud.stderr?e.end=!1:e.end=e.end!==!1,e.proxyErrors=!!e.proxyErrors,n?e.end&&t.end():(this[Re].push(e.proxyErrors?new aw(this,t,e):new Eu(this,t,e)),this[et]?Nr(()=>this[jn]()):this[jn]()),t}unpipe(t){let e=this[Re].find(n=>n.dest===t);e&&(this[Re].length===1?(this[de]&&this[rn]===0&&(this[de]=!1),this[Re]=[]):this[Re].splice(this[Re].indexOf(e),1),e.unpipe())}addListener(t,e){return this.on(t,e)}on(t,e){let n=super.on(t,e);if(t==="data")this[Pe]=!1,this[rn]++,!this[Re].length&&!this[de]&&this[jn]();else if(t==="readable"&&this[fe]!==0)super.emit("readable");else if(iw(t)&&this[Ot])super.emit(t),this.removeAllListeners(t);else if(t==="error"&&this[Pr]){let r=e;this[et]?Nr(()=>r.call(this,this[Pr])):r.call(this,this[Pr])}return n}removeListener(t,e){return this.off(t,e)}off(t,e){let n=super.off(t,e);return t==="data"&&(this[rn]=this.listeners("data").length,this[rn]===0&&!this[Pe]&&!this[Re].length&&(this[de]=!1)),n}removeAllListeners(t){let e=super.removeAllListeners(t);return(t==="data"||t===void 0)&&(this[rn]=0,!this[Pe]&&!this[Re].length&&(this[de]=!1)),e}get emittedEnd(){return this[Ot]}[wt](){!this[ts]&&!this[Ot]&&!this[Q]&&this[ue].length===0&&this[mt]&&(this[ts]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[ns]&&this.emit("close"),this[ts]=!1)}emit(t,...e){let n=e[0];if(t!=="error"&&t!=="close"&&t!==Q&&this[Q])return!1;if(t==="data")return!this[Ie]&&!n?!1:this[et]?(Nr(()=>this[na](n)),!0):this[na](n);if(t==="end")return this[Gd]();if(t==="close"){if(this[ns]=!0,!this[Ot]&&!this[Q])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(t==="error"){this[Pr]=n,super.emit(ta,n);let i=!this[Dr]||this.listeners("error").length?super.emit("error",n):!1;return this[wt](),i}else if(t==="resume"){let i=super.emit("resume");return this[wt](),i}else if(t==="finish"||t==="prefinish"){let i=super.emit(t);return this.removeAllListeners(t),i}let r=super.emit(t,...e);return this[wt](),r}[na](t){for(let n of this[Re])n.dest.write(t)===!1&&this.pause();let e=this[Pe]?!1:super.emit("data",t);return this[wt](),e}[Gd](){return this[Ot]?!1:(this[Ot]=!0,this.readable=!1,this[et]?(Nr(()=>this[ra]()),!0):this[ra]())}[ra](){if(this[Un]){let e=this[Un].end();if(e){for(let n of this[Re])n.dest.write(e);this[Pe]||super.emit("data",e)}}for(let e of this[Re])e.end();let t=super.emit("end");return this.removeAllListeners("end"),t}async collect(){let t=Object.assign([],{dataLength:0});this[Ie]||(t.dataLength=0);let e=this.promise();return this.on("data",n=>{t.push(n),this[Ie]||(t.dataLength+=n.length)}),await e,t}async concat(){if(this[Ie])throw new Error("cannot concat in objectMode");let t=await this.collect();return this[je]?t.join(""):Buffer.concat(t,t.dataLength)}async promise(){return new Promise((t,e)=>{this.on(Q,()=>e(new Error("stream destroyed"))),this.on("error",n=>e(n)),this.on("end",()=>t())})}[Symbol.asyncIterator](){this[Pe]=!1;let t=!1,e=async()=>(this.pause(),t=!0,{value:void 0,done:!0});return{next:()=>{if(t)return e();let n=this.read();if(n!==null)return Promise.resolve({done:!1,value:n});if(this[mt])return e();let r,i,s=l=>{this.off("data",o),this.off("end",a),this.off(Q,c),e(),i(l)},o=l=>{this.off("error",s),this.off("end",a),this.off(Q,c),this.pause(),r({value:l,done:!!this[mt]})},a=()=>{this.off("error",s),this.off("data",o),this.off(Q,c),e(),r({done:!0,value:void 0})},c=()=>s(new Error("stream destroyed"));return new Promise((l,d)=>{i=d,r=l,this.once(Q,c),this.once("error",s),this.once("end",a),this.once("data",o)})},throw:e,return:e,[Symbol.asyncIterator](){return this},[Symbol.asyncDispose]:async()=>{}}}[Symbol.iterator](){this[Pe]=!1;let t=!1,e=()=>(this.pause(),this.off(ta,e),this.off(Q,e),this.off("end",e),t=!0,{done:!0,value:void 0}),n=()=>{if(t)return e();let r=this.read();return r===null?e():{done:!1,value:r}};return this.once("end",e),this.once(ta,e),this.once(Q,e),{next:n,throw:e,return:e,[Symbol.iterator](){return this},[Symbol.dispose]:()=>{}}}destroy(t){if(this[Q])return t?this.emit("error",t):this.emit(Q),this;this[Q]=!0,this[Pe]=!0,this[ue].length=0,this[fe]=0;let e=this;return typeof e.close=="function"&&!this[ns]&&e.close(),t?this.emit("error",t):this.emit(Q),this}static get isStream(){return ew}},dw=xe.writev,zt=Symbol("_autoClose"),Je=Symbol("_close"),Lr=Symbol("_ended"),$=Symbol("_fd"),sa=Symbol("_finished"),St=Symbol("_flags"),oa=Symbol("_flush"),ka=Symbol("_handleChunk"),ba=Symbol("_makeBuf"),qr=Symbol("_mode"),os=Symbol("_needDrain"),Zn=Symbol("_onerror"),Kn=Symbol("_onopen"),aa=Symbol("_onread"),Wn=Symbol("_onwrite"),$t=Symbol("_open"),Ve=Symbol("_path"),Lt=Symbol("_pos"),nt=Symbol("_queue"),qn=Symbol("_read"),ca=Symbol("_readSize"),Et=Symbol("_reading"),Fr=Symbol("_remain"),la=Symbol("_size"),ms=Symbol("_write"),sn=Symbol("_writing"),ws=Symbol("_defaultFlag"),fn=Symbol("_errored"),Ja=class extends mn{[fn]=!1;[$];[Ve];[ca];[Et]=!1;[la];[Fr];[zt];constructor(t,e){if(e=e||{},super(e),this.readable=!0,this.writable=!1,typeof t!="string")throw new TypeError("path must be a string");this[fn]=!1,this[$]=typeof e.fd=="number"?e.fd:void 0,this[Ve]=t,this[ca]=e.readSize||16*1024*1024,this[Et]=!1,this[la]=typeof e.size=="number"?e.size:1/0,this[Fr]=this[la],this[zt]=typeof e.autoClose=="boolean"?e.autoClose:!0,typeof this[$]=="number"?this[qn]():this[$t]()}get fd(){return this[$]}get path(){return this[Ve]}write(){throw new TypeError("this is a readable stream")}end(){throw new TypeError("this is a readable stream")}[$t](){xe.open(this[Ve],"r",(t,e)=>this[Kn](t,e))}[Kn](t,e){t?this[Zn](t):(this[$]=e,this.emit("open",e),this[qn]())}[ba](){return Buffer.allocUnsafe(Math.min(this[ca],this[Fr]))}[qn](){if(!this[Et]){this[Et]=!0;let t=this[ba]();if(t.length===0)return process.nextTick(()=>this[aa](null,0,t));xe.read(this[$],t,0,t.length,null,(e,n,r)=>this[aa](e,n,r))}}[aa](t,e,n){this[Et]=!1,t?this[Zn](t):this[ka](e,n)&&this[qn]()}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.close(t,e=>e?this.emit("error",e):this.emit("close"))}}[Zn](t){this[Et]=!0,this[Je](),this.emit("error",t)}[ka](t,e){let n=!1;return this[Fr]-=t,t>0&&(n=super.write(t<e.length?e.subarray(0,t):e)),(t===0||this[Fr]<=0)&&(n=!1,this[Je](),super.end()),n}emit(t,...e){switch(t){case"prefinish":case"finish":return!1;case"drain":return typeof this[$]=="number"&&this[qn](),!1;case"error":return this[fn]?!1:(this[fn]=!0,super.emit(t,...e));default:return super.emit(t,...e)}}},uw=class extends Ja{[$t](){let t=!0;try{this[Kn](null,xe.openSync(this[Ve],"r")),t=!1}finally{t&&this[Je]()}}[qn](){let t=!0;try{if(!this[Et]){this[Et]=!0;do{let e=this[ba](),n=e.length===0?0:xe.readSync(this[$],e,0,e.length,null);if(!this[ka](n,e))break}while(!0);this[Et]=!1}t=!1}finally{t&&this[Je]()}}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.closeSync(t),this.emit("close")}}},Cs=class extends Ym{readable=!1;writable=!0;[fn]=!1;[sn]=!1;[Lr]=!1;[nt]=[];[os]=!1;[Ve];[qr];[zt];[$];[ws];[St];[sa]=!1;[Lt];constructor(t,e){e=e||{},super(e),this[Ve]=t,this[$]=typeof e.fd=="number"?e.fd:void 0,this[qr]=e.mode===void 0?438:e.mode,this[Lt]=typeof e.start=="number"?e.start:void 0,this[zt]=typeof e.autoClose=="boolean"?e.autoClose:!0;let n=this[Lt]!==void 0?"r+":"w";this[ws]=e.flags===void 0,this[St]=e.flags===void 0?n:e.flags,this[$]===void 0&&this[$t]()}emit(t,...e){if(t==="error"){if(this[fn])return!1;this[fn]=!0}return super.emit(t,...e)}get fd(){return this[$]}get path(){return this[Ve]}[Zn](t){this[Je](),this[sn]=!0,this.emit("error",t)}[$t](){xe.open(this[Ve],this[St],this[qr],(t,e)=>this[Kn](t,e))}[Kn](t,e){this[ws]&&this[St]==="r+"&&t&&t.code==="ENOENT"?(this[St]="w",this[$t]()):t?this[Zn](t):(this[$]=e,this.emit("open",e),this[sn]||this[oa]())}end(t,e){return t&&this.write(t,e),this[Lr]=!0,!this[sn]&&!this[nt].length&&typeof this[$]=="number"&&this[Wn](null,0),this}write(t,e){return typeof t=="string"&&(t=Buffer.from(t,e)),this[Lr]?(this.emit("error",new Error("write() after end()")),!1):this[$]===void 0||this[sn]||this[nt].length?(this[nt].push(t),this[os]=!0,!1):(this[sn]=!0,this[ms](t),!0)}[ms](t){xe.write(this[$],t,0,t.length,this[Lt],(e,n)=>this[Wn](e,n))}[Wn](t,e){t?this[Zn](t):(this[Lt]!==void 0&&typeof e=="number"&&(this[Lt]+=e),this[nt].length?this[oa]():(this[sn]=!1,this[Lr]&&!this[sa]?(this[sa]=!0,this[Je](),this.emit("finish")):this[os]&&(this[os]=!1,this.emit("drain"))))}[oa](){if(this[nt].length===0)this[Lr]&&this[Wn](null,0);else if(this[nt].length===1)this[ms](this[nt].pop());else{let t=this[nt];this[nt]=[],dw(this[$],t,this[Lt],(e,n)=>this[Wn](e,n))}}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.close(t,e=>e?this.emit("error",e):this.emit("close"))}}},Su=class extends Cs{[$t](){let t;if(this[ws]&&this[St]==="r+")try{t=xe.openSync(this[Ve],this[St],this[qr])}catch(e){if(e?.code==="ENOENT")return this[St]="w",this[$t]();throw e}else t=xe.openSync(this[Ve],this[St],this[qr]);this[Kn](null,t)}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.closeSync(t),this.emit("close")}}[ms](t){let e=!0;try{this[Wn](null,xe.writeSync(this[$],t,0,t.length,this[Lt])),e=!1}finally{if(e)try{this[Je]()}catch{}}}},pw=new Map([["C","cwd"],["f","file"],["z","gzip"],["P","preservePaths"],["U","unlink"],["strip-components","strip"],["stripComponents","strip"],["keep-newer","newer"],["keepNewer","newer"],["keep-newer-files","newer"],["keepNewerFiles","newer"],["k","keep"],["keep-existing","keep"],["keepExisting","keep"],["m","noMtime"],["no-mtime","noMtime"],["p","preserveOwner"],["L","follow"],["h","follow"],["onentry","onReadEntry"]]),gw=t=>!!t.sync&&!!t.file,mw=t=>!t.sync&&!!t.file,ww=t=>!!t.sync&&!t.file,yw=t=>!t.sync&&!t.file,_w=t=>!!t.file,Ew=t=>pw.get(t)||t,Za=(t={})=>{if(!t)return{};let e={};for(let[n,r]of Object.entries(t)){let i=Ew(n);e[i]=r}return e.chmod===void 0&&e.noChmod===!1&&(e.chmod=!0),delete e.noChmod,e},ti=(t,e,n,r,i)=>Object.assign((s=[],o,a)=>{Array.isArray(s)&&(o=s,s={}),typeof o=="function"&&(a=o,o=void 0),o=o?Array.from(o):[];let c=Za(s);if(i?.(c,o),gw(c)){if(typeof a=="function")throw new TypeError("callback not supported for sync tar functions");return t(c,o)}else if(mw(c)){let l=e(c,o);return a?l.then(()=>a(),a):l}else if(ww(c)){if(typeof a=="function")throw new TypeError("callback not supported for sync tar functions");return n(c,o)}else if(yw(c)){if(typeof a=="function")throw new TypeError("callback only supported with file option");return r(c,o)}throw new Error("impossible options??")},{syncFile:t,asyncFile:e,syncNoFile:n,asyncNoFile:r,validate:i}),Iw=vw.constants||{ZLIB_VERNUM:4736},ot=Object.freeze(Object.assign(Object.create(null),{Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_VERSION_ERROR:-6,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,DEFLATE:1,INFLATE:2,GZIP:3,GUNZIP:4,DEFLATERAW:5,INFLATERAW:6,UNZIP:7,BROTLI_DECODE:8,BROTLI_ENCODE:9,Z_MIN_WINDOWBITS:8,Z_MAX_WINDOWBITS:15,Z_DEFAULT_WINDOWBITS:15,Z_MIN_CHUNK:64,Z_MAX_CHUNK:1/0,Z_DEFAULT_CHUNK:16384,Z_MIN_MEMLEVEL:1,Z_MAX_MEMLEVEL:9,Z_DEFAULT_MEMLEVEL:8,Z_MIN_LEVEL:-1,Z_MAX_LEVEL:9,Z_DEFAULT_LEVEL:-1,BROTLI_OPERATION_PROCESS:0,BROTLI_OPERATION_FLUSH:1,BROTLI_OPERATION_FINISH:2,BROTLI_OPERATION_EMIT_METADATA:3,BROTLI_MODE_GENERIC:0,BROTLI_MODE_TEXT:1,BROTLI_MODE_FONT:2,BROTLI_DEFAULT_MODE:0,BROTLI_MIN_QUALITY:0,BROTLI_MAX_QUALITY:11,BROTLI_DEFAULT_QUALITY:11,BROTLI_MIN_WINDOW_BITS:10,BROTLI_MAX_WINDOW_BITS:24,BROTLI_LARGE_MAX_WINDOW_BITS:30,BROTLI_DEFAULT_WINDOW:22,BROTLI_MIN_INPUT_BLOCK_BITS:16,BROTLI_MAX_INPUT_BLOCK_BITS:24,BROTLI_PARAM_MODE:0,BROTLI_PARAM_QUALITY:1,BROTLI_PARAM_LGWIN:2,BROTLI_PARAM_LGBLOCK:3,BROTLI_PARAM_DISABLE_LITERAL_CONTEXT_MODELING:4,BROTLI_PARAM_SIZE_HINT:5,BROTLI_PARAM_LARGE_WINDOW:6,BROTLI_PARAM_NPOSTFIX:7,BROTLI_PARAM_NDIRECT:8,BROTLI_DECODER_RESULT_ERROR:0,BROTLI_DECODER_RESULT_SUCCESS:1,BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT:2,BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT:3,BROTLI_DECODER_PARAM_DISABLE_RING_BUFFER_REALLOCATION:0,BROTLI_DECODER_PARAM_LARGE_WINDOW:1,BROTLI_DECODER_NO_ERROR:0,BROTLI_DECODER_SUCCESS:1,BROTLI_DECODER_NEEDS_MORE_INPUT:2,BROTLI_DECODER_NEEDS_MORE_OUTPUT:3,BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_NIBBLE:-1,BROTLI_DECODER_ERROR_FORMAT_RESERVED:-2,BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_META_NIBBLE:-3,BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_ALPHABET:-4,BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_SAME:-5,BROTLI_DECODER_ERROR_FORMAT_CL_SPACE:-6,BROTLI_DECODER_ERROR_FORMAT_HUFFMAN_SPACE:-7,BROTLI_DECODER_ERROR_FORMAT_CONTEXT_MAP_REPEAT:-8,BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_1:-9,BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_2:-10,BROTLI_DECODER_ERROR_FORMAT_TRANSFORM:-11,BROTLI_DECODER_ERROR_FORMAT_DICTIONARY:-12,BROTLI_DECODER_ERROR_FORMAT_WINDOW_BITS:-13,BROTLI_DECODER_ERROR_FORMAT_PADDING_1:-14,BROTLI_DECODER_ERROR_FORMAT_PADDING_2:-15,BROTLI_DECODER_ERROR_FORMAT_DISTANCE:-16,BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET:-19,BROTLI_DECODER_ERROR_INVALID_ARGUMENTS:-20,BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MODES:-21,BROTLI_DECODER_ERROR_ALLOC_TREE_GROUPS:-22,BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MAP:-25,BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_1:-26,BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_2:-27,BROTLI_DECODER_ERROR_ALLOC_BLOCK_TYPE_TREES:-30,BROTLI_DECODER_ERROR_UNREACHABLE:-31},Iw)),Tw=hn.concat,jd=Object.getOwnPropertyDescriptor(hn,"concat"),Rw=t=>t,da=jd?.writable===!0||jd?.set!==void 0?t=>{hn.concat=t?Rw:Tw}:t=>{},pn=Symbol("_superWrite"),as=class extends Error{code;errno;constructor(t,e){super("zlib: "+t.message,{cause:t}),this.code=t.code,this.errno=t.errno,this.code||(this.code="ZLIB_ERROR"),this.message="zlib: "+t.message,Error.captureStackTrace(this,e??this.constructor)}get name(){return"ZlibError"}},ua=Symbol("flushFlag"),Ka=class extends mn{#e=!1;#n=!1;#r;#s;#i;#t;#o;get sawError(){return this.#e}get handle(){return this.#t}get flushFlag(){return this.#r}constructor(t,e){if(!t||typeof t!="object")throw new TypeError("invalid options for ZlibBase constructor");if(super(t),this.#r=t.flush??0,this.#s=t.finishFlush??0,this.#i=t.fullFlushFlag??0,typeof Hd[e]!="function")throw new TypeError("Compression method not supported: "+e);try{this.#t=new Hd[e](t)}catch(n){throw new as(n,this.constructor)}this.#o=n=>{this.#e||(this.#e=!0,this.close(),this.emit("error",n))},this.#t?.on("error",n=>this.#o(new as(n))),this.once("end",()=>this.close)}close(){this.#t&&(this.#t.close(),this.#t=void 0,this.emit("close"))}reset(){if(!this.#e)return Aa(this.#t,"zlib binding closed"),this.#t.reset?.()}flush(t){this.ended||(typeof t!="number"&&(t=this.#i),this.write(Object.assign(hn.alloc(0),{[ua]:t})))}end(t,e,n){return typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),t&&(e?this.write(t,e):this.write(t)),this.flush(this.#s),this.#n=!0,super.end(n)}get ended(){return this.#n}[pn](t){return super.write(t)}write(t,e,n){if(typeof e=="function"&&(n=e,e="utf8"),typeof t=="string"&&(t=hn.from(t,e)),this.#e)return;Aa(this.#t,"zlib binding closed");let r=this.#t._handle,i=r.close;r.close=()=>{};let s=this.#t.close;this.#t.close=()=>{},da(!0);let o;try{let c=typeof t[ua]=="number"?t[ua]:this.#r;o=this.#t._processChunk(t,c),da(!1)}catch(c){da(!1),this.#o(new as(c,this.write))}finally{this.#t&&(this.#t._handle=r,r.close=i,this.#t.close=s,this.#t.removeAllListeners("error"))}this.#t&&this.#t.on("error",c=>this.#o(new as(c,this.write)));let a;if(o)if(Array.isArray(o)&&o.length>0){let c=o[0];a=this[pn](hn.from(c));for(let l=1;l<o.length;l++)a=this[pn](o[l])}else a=this[pn](hn.from(o));return n&&n(),a}},Iu=class extends Ka{#e;#n;constructor(t,e){t=t||{},t.flush=t.flush||ot.Z_NO_FLUSH,t.finishFlush=t.finishFlush||ot.Z_FINISH,t.fullFlushFlag=ot.Z_FULL_FLUSH,super(t,e),this.#e=t.level,this.#n=t.strategy}params(t,e){if(!this.sawError){if(!this.handle)throw new Error("cannot switch params when binding is closed");if(!this.handle.params)throw new Error("not supported in this implementation");if(this.#e!==t||this.#n!==e){this.flush(ot.Z_SYNC_FLUSH),Aa(this.handle,"zlib binding closed");let n=this.handle.flush;this.handle.flush=(r,i)=>{typeof r=="function"&&(i=r,r=this.flushFlag),this.flush(r),i?.()};try{this.handle.params(t,e)}finally{this.handle.flush=n}this.handle&&(this.#e=t,this.#n=e)}}}},kw=class extends Iu{#e;constructor(t){super(t,"Gzip"),this.#e=t&&!!t.portable}[pn](t){return this.#e?(this.#e=!1,t[9]=255,super[pn](t)):super[pn](t)}},bw=class extends Iu{constructor(t){super(t,"Unzip")}},Tu=class extends Ka{constructor(t,e){t=t||{},t.flush=t.flush||ot.BROTLI_OPERATION_PROCESS,t.finishFlush=t.finishFlush||ot.BROTLI_OPERATION_FINISH,t.fullFlushFlag=ot.BROTLI_OPERATION_FLUSH,super(t,e)}},Aw=class extends Tu{constructor(t){super(t,"BrotliCompress")}},xw=class extends Tu{constructor(t){super(t,"BrotliDecompress")}},Ru=class extends Ka{constructor(t,e){t=t||{},t.flush=t.flush||ot.ZSTD_e_continue,t.finishFlush=t.finishFlush||ot.ZSTD_e_end,t.fullFlushFlag=ot.ZSTD_e_flush,super(t,e)}},Ow=class extends Ru{constructor(t){super(t,"ZstdCompress")}},Pw=class extends Ru{constructor(t){super(t,"ZstdDecompress")}},Cw=(t,e)=>{if(Number.isSafeInteger(t))t<0?Nw(t,e):Dw(t,e);else throw Error("cannot encode number outside of javascript safe integer range");return e},Dw=(t,e)=>{e[0]=128;for(var n=e.length;n>1;n--)e[n-1]=t&255,t=Math.floor(t/256)},Nw=(t,e)=>{e[0]=255;var n=!1;t=t*-1;for(var r=e.length;r>1;r--){var i=t&255;t=Math.floor(t/256),n?e[r-1]=ku(i):i===0?e[r-1]=0:(n=!0,e[r-1]=bu(i))}},Lw=t=>{let e=t[0],n=e===128?Mw(t.subarray(1,t.length)):e===255?Fw(t):null;if(n===null)throw Error("invalid base256 encoding");if(!Number.isSafeInteger(n))throw Error("parsed number outside of javascript safe integer range");return n},Fw=t=>{for(var e=t.length,n=0,r=!1,i=e-1;i>-1;i--){var s=Number(t[i]),o;r?o=ku(s):s===0?o=s:(r=!0,o=bu(s)),o!==0&&(n-=o*Math.pow(256,e-i-1))}return n},Mw=t=>{for(var e=t.length,n=0,r=e-1;r>-1;r--){var i=Number(t[r]);i!==0&&(n+=i*Math.pow(256,e-r-1))}return n},ku=t=>(255^t)&255,bu=t=>(255^t)+1&255,Bw={};Xm(Bw,{code:()=>Xa,isCode:()=>ys,isName:()=>Uw,name:()=>Ds});var ys=t=>Ds.has(t),Uw=t=>Xa.has(t),Ds=new Map([["0","File"],["","OldFile"],["1","Link"],["2","SymbolicLink"],["3","CharacterDevice"],["4","BlockDevice"],["5","Directory"],["6","FIFO"],["7","ContiguousFile"],["g","GlobalExtendedHeader"],["x","ExtendedHeader"],["A","SolarisACL"],["D","GNUDumpDir"],["I","Inode"],["K","NextFileHasLongLinkpath"],["L","NextFileHasLongPath"],["M","ContinuationFile"],["N","OldGnuLongPath"],["S","SparseFile"],["V","TapeVolumeHeader"],["X","OldExtendedHeader"]]),Xa=new Map(Array.from(Ds).map(t=>[t[1],t[0]])),gn=class{cksumValid=!1;needPax=!1;nullBlock=!1;block;path;mode;uid;gid;size;cksum;#e="Unsupported";linkpath;uname;gname;devmaj=0;devmin=0;atime;ctime;mtime;charset;comment;constructor(t,e=0,n,r){Buffer.isBuffer(t)?this.decode(t,e||0,n,r):t&&this.#n(t)}decode(t,e,n,r){if(e||(e=0),!t||!(t.length>=e+512))throw new Error("need 512 bytes for header");this.path=n?.path??on(t,e,100),this.mode=n?.mode??r?.mode??Ft(t,e+100,8),this.uid=n?.uid??r?.uid??Ft(t,e+108,8),this.gid=n?.gid??r?.gid??Ft(t,e+116,8),this.size=n?.size??r?.size??Ft(t,e+124,12),this.mtime=n?.mtime??r?.mtime??fa(t,e+136,12),this.cksum=Ft(t,e+148,12),r&&this.#n(r,!0),n&&this.#n(n);let i=on(t,e+156,1);if(ys(i)&&(this.#e=i||"0"),this.#e==="0"&&this.path.slice(-1)==="/"&&(this.#e="5"),this.#e==="5"&&(this.size=0),this.linkpath=on(t,e+157,100),t.subarray(e+257,e+265).toString()==="ustar\x0000")if(this.uname=n?.uname??r?.uname??on(t,e+265,32),this.gname=n?.gname??r?.gname??on(t,e+297,32),this.devmaj=n?.devmaj??r?.devmaj??Ft(t,e+329,8)??0,this.devmin=n?.devmin??r?.devmin??Ft(t,e+337,8)??0,t[e+475]!==0){let o=on(t,e+345,155);this.path=o+"/"+this.path}else{let o=on(t,e+345,130);o&&(this.path=o+"/"+this.path),this.atime=n?.atime??r?.atime??fa(t,e+476,12),this.ctime=n?.ctime??r?.ctime??fa(t,e+488,12)}let s=256;for(let o=e;o<e+148;o++)s+=t[o];for(let o=e+156;o<e+512;o++)s+=t[o];this.cksumValid=s===this.cksum,this.cksum===void 0&&s===256&&(this.nullBlock=!0)}#n(t,e=!1){Object.assign(this,Object.fromEntries(Object.entries(t).filter(([n,r])=>!(r==null||n==="path"&&e||n==="linkpath"&&e||n==="global"))))}encode(t,e=0){if(t||(t=this.block=Buffer.alloc(512)),this.#e==="Unsupported"&&(this.#e="0"),!(t.length>=e+512))throw new Error("need 512 bytes for header");let n=this.ctime||this.atime?130:155,r=zw(this.path||"",n),i=r[0],s=r[1];this.needPax=!!r[2],this.needPax=an(t,e,100,i)||this.needPax,this.needPax=Mt(t,e+100,8,this.mode)||this.needPax,this.needPax=Mt(t,e+108,8,this.uid)||this.needPax,this.needPax=Mt(t,e+116,8,this.gid)||this.needPax,this.needPax=Mt(t,e+124,12,this.size)||this.needPax,this.needPax=ha(t,e+136,12,this.mtime)||this.needPax,t[e+156]=Number(this.#e.codePointAt(0)),this.needPax=an(t,e+157,100,this.linkpath)||this.needPax,t.write("ustar\x0000",e+257,8),this.needPax=an(t,e+265,32,this.uname)||this.needPax,this.needPax=an(t,e+297,32,this.gname)||this.needPax,this.needPax=Mt(t,e+329,8,this.devmaj)||this.needPax,this.needPax=Mt(t,e+337,8,this.devmin)||this.needPax,this.needPax=an(t,e+345,n,s)||this.needPax,t[e+475]!==0?this.needPax=an(t,e+345,155,s)||this.needPax:(this.needPax=an(t,e+345,130,s)||this.needPax,this.needPax=ha(t,e+476,12,this.atime)||this.needPax,this.needPax=ha(t,e+488,12,this.ctime)||this.needPax);let o=256;for(let a=e;a<e+148;a++)o+=t[a];for(let a=e+156;a<e+512;a++)o+=t[a];return this.cksum=o,Mt(t,e+148,8,this.cksum),this.cksumValid=!0,this.needPax}get type(){return this.#e==="Unsupported"?this.#e:Ds.get(this.#e)}get typeKey(){return this.#e}set type(t){let e=String(Xa.get(t));if(ys(e)||e==="Unsupported")this.#e=e;else if(ys(t))this.#e=t;else throw new TypeError("invalid entry type: "+t)}},zw=(t,e)=>{let n=t,r="",i,s=zn.parse(t).root||".";if(Buffer.byteLength(n)<100)i=[n,r,!1];else{r=zn.dirname(n),n=zn.basename(n);do Buffer.byteLength(n)<=100&&Buffer.byteLength(r)<=e?i=[n,r,!1]:Buffer.byteLength(n)>100&&Buffer.byteLength(r)<=e?i=[n.slice(0,99),r,!0]:(n=zn.join(zn.basename(r),n),r=zn.dirname(r));while(r!==s&&i===void 0);i||(i=[t.slice(0,99),"",!0])}return i},on=(t,e,n)=>t.subarray(e,e+n).toString("utf8").replace(/\0.*/,""),fa=(t,e,n)=>$w(Ft(t,e,n)),$w=t=>t===void 0?void 0:new Date(t*1e3),Ft=(t,e,n)=>Number(t[e])&128?Lw(t.subarray(e,e+n)):Hw(t,e,n),Gw=t=>isNaN(t)?void 0:t,Hw=(t,e,n)=>Gw(parseInt(t.subarray(e,e+n).toString("utf8").replace(/\0.*$/,"").trim(),8)),jw={12:8589934591,8:2097151},Mt=(t,e,n,r)=>r===void 0?!1:r>jw[n]||r<0?(Cw(r,t.subarray(e,e+n)),!0):(Ww(t,e,n,r),!1),Ww=(t,e,n,r)=>t.write(qw(r,n),e,n,"ascii"),qw=(t,e)=>Vw(Math.floor(t).toString(8),e),Vw=(t,e)=>(t.length===e-1?t:new Array(e-t.length-1).join("0")+t+" ")+"\0",ha=(t,e,n,r)=>r===void 0?!1:Mt(t,e,n,r.getTime()/1e3),Jw=new Array(156).join("\0"),an=(t,e,n,r)=>r===void 0?!1:(t.write(r+Jw,e,n,"utf8"),r.length!==Buffer.byteLength(r)||r.length>n),bs=class Au{atime;mtime;ctime;charset;comment;gid;uid;gname;uname;linkpath;dev;ino;nlink;path;size;mode;global;constructor(e,n=!1){this.atime=e.atime,this.charset=e.charset,this.comment=e.comment,this.ctime=e.ctime,this.dev=e.dev,this.gid=e.gid,this.global=n,this.gname=e.gname,this.ino=e.ino,this.linkpath=e.linkpath,this.mtime=e.mtime,this.nlink=e.nlink,this.path=e.path,this.size=e.size,this.uid=e.uid,this.uname=e.uname}encode(){let e=this.encodeBody();if(e==="")return Buffer.allocUnsafe(0);let n=Buffer.byteLength(e),r=512*Math.ceil(1+n/512),i=Buffer.allocUnsafe(r);for(let s=0;s<512;s++)i[s]=0;new gn({path:("PaxHeader/"+Zw(this.path??"")).slice(0,99),mode:this.mode||420,uid:this.uid,gid:this.gid,size:n,mtime:this.mtime,type:this.global?"GlobalExtendedHeader":"ExtendedHeader",linkpath:"",uname:this.uname||"",gname:this.gname||"",devmaj:0,devmin:0,atime:this.atime,ctime:this.ctime}).encode(i),i.write(e,512,n,"utf8");for(let s=n+512;s<i.length;s++)i[s]=0;return i}encodeBody(){return this.encodeField("path")+this.encodeField("ctime")+this.encodeField("atime")+this.encodeField("dev")+this.encodeField("ino")+this.encodeField("nlink")+this.encodeField("charset")+this.encodeField("comment")+this.encodeField("gid")+this.encodeField("gname")+this.encodeField("linkpath")+this.encodeField("mtime")+this.encodeField("size")+this.encodeField("uid")+this.encodeField("uname")}encodeField(e){if(this[e]===void 0)return"";let n=this[e],r=n instanceof Date?n.getTime()/1e3:n,i=" "+(e==="dev"||e==="ino"||e==="nlink"?"SCHILY.":"")+e+"="+r+`
88
+ `},configPath(t){return IT(t.homeDir,".coze","bridge","task.xml")},async install(t){let n=`cmd.exe /c ${[`^"${t.nodeBin}^"`,`^"${t.entry}^"`,"--daemon",`>> ^"${t.logFile}^" 2>&1`].join(" ")}`;await bg("schtasks",["/Create","/SC","ONLOGON","/TN",Uo,"/TR",n,"/RU",t.userName,"/F"]),Pl.info("task scheduler entry created",{task:Uo,logFile:t.logFile})},async uninstall(t){await bg("schtasks",["/Delete","/TN",Uo,"/F"]).catch(e=>Pl.warn("schtasks /Delete failed (ignored)",{err:String(e)})),Pl.info("task scheduler entry removed",{task:Uo})}}});var xg={};Li(xg,{buildContext:()=>xT,getSupervisor:()=>kT,launchdSupervisor:()=>xl,systemdSupervisor:()=>Ol,taskSchedulerSupervisor:()=>Cl});import{homedir as TT,userInfo as RT}from"node:os";function kT(t=process.platform){switch(t){case"darwin":return xl;case"linux":return Ol;case"win32":return Cl;default:throw new Error(`unsupported platform for OS supervisor: ${t}`)}}function AT(){let t={};for(let e of bT){let n=process.env[e];n&&(t[e]=n)}return t}function xT(){let t=F();return{nodeBin:process.execPath,entry:Tl(t),logFile:t.logFile,homeDir:TT(),userName:RT().username,isRoot:process.getuid?.()===0,env:AT()}}var bT,Og=ve(()=>{"use strict";le();Ao();Tg();kg();Ag();bT=["PATH","HOME","HTTP_PROXY","HTTPS_PROXY","NO_PROXY","ALL_PROXY","http_proxy","https_proxy","no_proxy","all_proxy","NODE_EXTRA_CA_CERTS"]});L();tn();var Kl=b("acp-installer-warmup"),mm=["claude-code","codex"];async function Xl(t={}){let e=t.ensure??en,r=(await Promise.allSettled(mm.map(async i=>{let s=await e(i);Kl.info("acp wrapper warmup ok",{framework:i,path:s})}))).filter(i=>i.status==="rejected");r.length>0&&Kl.warn("acp wrapper warmup partial failure (\u5C06\u5728\u4E0B\u6B21 createAgent \u65F6\u91CD\u8BD5\u5E76\u629B\u9519\u7ED9\u7528\u6237)",{failedCount:r.length,reasons:r.map(i=>i.reason instanceof Error?i.reason.message:String(i.reason))})}At();L();import{readdir as Am}from"node:fs/promises";import{mkdir as rd,writeFile as id}from"node:fs/promises";import{join as Ko}from"node:path";var bm={"claude-code":"CLAUDE.md",codex:"AGENTS.md",openclaw:"SOUL.md"};async function Ln(t,e,n){await rd(t,{recursive:!0});let r=bm[e],i=Ko(t,r);return await id(i,n??"","utf8"),i}async function sd(t){let e=Ko(t,".claude");await rd(e,{recursive:!0});let n=Ko(e,"settings.local.json"),r=JSON.stringify({permissions:{defaultMode:"bypassPermissions"}},null,2);return await id(n,r,"utf8"),n}var Oe=b("agent-detail-sync"),xm=6e4,Om=5*6e4,Xi=class{constructor(e){this.opts=e}opts;retryQueue=new Map;async syncAll(e){let n=this.opts.paths.agentsRoot,r;try{r=await Am(n)}catch(i){Oe.info("agents dir not found, skip detail sync",{root:n,err:String(i)});return}Oe.info("starting detail sync",{reason:e,count:r.length}),await Promise.allSettled(r.map(async i=>{let s=await me(i,this.opts.paths).catch(()=>null);if(s){if(s.disconnectedAt){Oe.debug("detail sync: skip disconnected agent",{agentId:i});return}try{await this.syncOne(i,s)}catch(o){Oe.warn("detail sync failed for agent, skipping",{agentId:i,err:String(o)})}}})),Oe.info("detail sync done",{reason:e})}async retryPending(){if(this.retryQueue.size===0)return;let e=Date.now(),n=[];for(let[r,i]of this.retryQueue)e>=i.dueAt&&n.push(r);if(n.length!==0){Oe.info("retrying pending detail syncs",{count:n.length});for(let r of n)try{await this.syncOne(r)}catch(i){Oe.debug("detail sync retry still failing, will try again",{agentId:r,err:String(i)})}}}async syncOne(e,n){let r=n??await me(e,this.opts.paths);if(!r){Oe.info("detail sync: agent config missing, skip",{agentId:e});return}let i;try{i=await this.opts.sendDetail({_meta:{cozeAgentId:e}}),this.retryQueue.delete(e)}catch(a){Oe.warn("detail RPC failed, using local data",{agentId:e,err:String(a)});let c=this.retryQueue.get(e),l=c?Math.min(c.currentDelay*2,Om):xm;this.retryQueue.set(e,{dueAt:Date.now()+l,currentDelay:l});return}if(i.agentId&&i.agentId!==e){Oe.warn("detail response agentId mismatch, ignoring",{agentId:e,responseAgentId:i.agentId});return}let s=!1,o=!1;if(i.agentName&&i.agentName!==r.agentName&&(r.agentName=i.agentName,s=!0),i.description!==void 0&&i.description!==r.description&&(r.description=i.description,s=!0),i.cozeIdentity&&i.cozeIdentity!==r.cozeIdentity&&(r.cozeIdentity=i.cozeIdentity,s=!0,o=!0),i.deployType&&Oe.info("detail.deployType",{agentId:e,deployType:i.deployType}),!s){Oe.debug("detail sync: no diff",{agentId:e});return}await Ae(r,this.opts.paths),Oe.info("detail sync: config updated",{agentId:e,identityChanged:o,agentName:r.agentName}),o&&(await Ln(r.workspace,r.framework,r.cozeIdentity),this.opts.handlers.reloadAgentSessionsPublic(e,"detail-sync"))}};var vf=ht(Bd(),1);import{lstat as uc,mkdir as fc,readFile as yf,readdir as r_,rm as i_,stat as s_,writeFile as hc}from"node:fs/promises";import{dirname as o_,join as at,normalize as a_,relative as mc,resolve as pc,sep as _f}from"node:path";import{Readable as Ef}from"node:stream";import{pipeline as Sf}from"node:stream/promises";import Ym from"events";import xe from"fs";import{EventEmitter as Za}from"node:events";import _u from"node:stream";import{StringDecoder as Qm}from"node:string_decoder";import vu from"node:path";import Vn from"node:fs";import{dirname as fw,parse as hw}from"path";import{EventEmitter as Sw}from"events";import Oa from"assert";import{Buffer as hn}from"buffer";import*as Hd from"zlib";import vw from"zlib";import{posix as zn}from"node:path";import{basename as Zw}from"node:path";import xs from"fs";import it from"fs";import Kd from"path";import{win32 as oy}from"node:path";import ru from"path";import Mu from"node:fs";import Iy from"node:assert";import{randomBytes as Bu}from"node:crypto";import B from"node:fs";import ie from"node:path";import Uu from"fs";import Bs from"node:fs";import Zr from"node:path";import De from"node:fs";import Oy from"node:fs/promises";import Cs from"node:path";import{join as Ku}from"node:path";import Ce from"node:fs";import Qu from"node:path";var Km=Object.defineProperty,Xm=(t,e)=>{for(var n in e)Km(t,n,{get:e[n],enumerable:!0})},Ud=typeof process=="object"&&process?process:{stdout:null,stderr:null},ew=t=>!!t&&typeof t=="object"&&(t instanceof mn||t instanceof _u||tw(t)||nw(t)),tw=t=>!!t&&typeof t=="object"&&t instanceof Za&&typeof t.pipe=="function"&&t.pipe!==_u.Writable.prototype.pipe,nw=t=>!!t&&typeof t=="object"&&t instanceof Za&&typeof t.write=="function"&&typeof t.end=="function",mt=Symbol("EOF"),wt=Symbol("maybeEmitEnd"),Ot=Symbol("emittedEnd"),ns=Symbol("emittingEnd"),Cr=Symbol("emittedError"),rs=Symbol("closed"),zd=Symbol("read"),is=Symbol("flush"),$d=Symbol("flushChunk"),je=Symbol("encoding"),Un=Symbol("decoder"),de=Symbol("flowing"),Dr=Symbol("paused"),jn=Symbol("resume"),ue=Symbol("buffer"),Re=Symbol("pipes"),fe=Symbol("bufferLength"),na=Symbol("bufferPush"),ss=Symbol("bufferShift"),Ie=Symbol("objectMode"),Q=Symbol("destroyed"),ra=Symbol("error"),ia=Symbol("emitData"),Gd=Symbol("emitEnd"),sa=Symbol("emitEnd2"),et=Symbol("async"),oa=Symbol("abort"),os=Symbol("aborted"),Nr=Symbol("signal"),rn=Symbol("dataListeners"),Pe=Symbol("discarded"),Lr=t=>Promise.resolve().then(t),rw=t=>t(),iw=t=>t==="end"||t==="finish"||t==="prefinish",sw=t=>t instanceof ArrayBuffer||!!t&&typeof t=="object"&&t.constructor&&t.constructor.name==="ArrayBuffer"&&t.byteLength>=0,ow=t=>!Buffer.isBuffer(t)&&ArrayBuffer.isView(t),Eu=class{src;dest;opts;ondrain;constructor(t,e,n){this.src=t,this.dest=e,this.opts=n,this.ondrain=()=>t[jn](),this.dest.on("drain",this.ondrain)}unpipe(){this.dest.removeListener("drain",this.ondrain)}proxyErrors(t){}end(){this.unpipe(),this.opts.end&&this.dest.end()}},aw=class extends Eu{unpipe(){this.src.removeListener("error",this.proxyErrors),super.unpipe()}constructor(t,e,n){super(t,e,n),this.proxyErrors=r=>this.dest.emit("error",r),t.on("error",this.proxyErrors)}},cw=t=>!!t.objectMode,lw=t=>!t.objectMode&&!!t.encoding&&t.encoding!=="buffer",mn=class extends Za{[de]=!1;[Dr]=!1;[Re]=[];[ue]=[];[Ie];[je];[et];[Un];[mt]=!1;[Ot]=!1;[ns]=!1;[rs]=!1;[Cr]=null;[fe]=0;[Q]=!1;[Nr];[os]=!1;[rn]=0;[Pe]=!1;writable=!0;readable=!0;constructor(...t){let e=t[0]||{};if(super(),e.objectMode&&typeof e.encoding=="string")throw new TypeError("Encoding and objectMode may not be used together");cw(e)?(this[Ie]=!0,this[je]=null):lw(e)?(this[je]=e.encoding,this[Ie]=!1):(this[Ie]=!1,this[je]=null),this[et]=!!e.async,this[Un]=this[je]?new Qm(this[je]):null,e&&e.debugExposeBuffer===!0&&Object.defineProperty(this,"buffer",{get:()=>this[ue]}),e&&e.debugExposePipes===!0&&Object.defineProperty(this,"pipes",{get:()=>this[Re]});let{signal:n}=e;n&&(this[Nr]=n,n.aborted?this[oa]():n.addEventListener("abort",()=>this[oa]()))}get bufferLength(){return this[fe]}get encoding(){return this[je]}set encoding(t){throw new Error("Encoding must be set at instantiation time")}setEncoding(t){throw new Error("Encoding must be set at instantiation time")}get objectMode(){return this[Ie]}set objectMode(t){throw new Error("objectMode must be set at instantiation time")}get async(){return this[et]}set async(t){this[et]=this[et]||!!t}[oa](){this[os]=!0,this.emit("abort",this[Nr]?.reason),this.destroy(this[Nr]?.reason)}get aborted(){return this[os]}set aborted(t){}write(t,e,n){if(this[os])return!1;if(this[mt])throw new Error("write after end");if(this[Q])return this.emit("error",Object.assign(new Error("Cannot call write after a stream was destroyed"),{code:"ERR_STREAM_DESTROYED"})),!0;typeof e=="function"&&(n=e,e="utf8"),e||(e="utf8");let r=this[et]?Lr:rw;if(!this[Ie]&&!Buffer.isBuffer(t)){if(ow(t))t=Buffer.from(t.buffer,t.byteOffset,t.byteLength);else if(sw(t))t=Buffer.from(t);else if(typeof t!="string")throw new Error("Non-contiguous data written to non-objectMode stream")}return this[Ie]?(this[de]&&this[fe]!==0&&this[is](!0),this[de]?this.emit("data",t):this[na](t),this[fe]!==0&&this.emit("readable"),n&&r(n),this[de]):t.length?(typeof t=="string"&&!(e===this[je]&&!this[Un]?.lastNeed)&&(t=Buffer.from(t,e)),Buffer.isBuffer(t)&&this[je]&&(t=this[Un].write(t)),this[de]&&this[fe]!==0&&this[is](!0),this[de]?this.emit("data",t):this[na](t),this[fe]!==0&&this.emit("readable"),n&&r(n),this[de]):(this[fe]!==0&&this.emit("readable"),n&&r(n),this[de])}read(t){if(this[Q])return null;if(this[Pe]=!1,this[fe]===0||t===0||t&&t>this[fe])return this[wt](),null;this[Ie]&&(t=null),this[ue].length>1&&!this[Ie]&&(this[ue]=[this[je]?this[ue].join(""):Buffer.concat(this[ue],this[fe])]);let e=this[zd](t||null,this[ue][0]);return this[wt](),e}[zd](t,e){if(this[Ie])this[ss]();else{let n=e;t===n.length||t===null?this[ss]():typeof n=="string"?(this[ue][0]=n.slice(t),e=n.slice(0,t),this[fe]-=t):(this[ue][0]=n.subarray(t),e=n.subarray(0,t),this[fe]-=t)}return this.emit("data",e),!this[ue].length&&!this[mt]&&this.emit("drain"),e}end(t,e,n){return typeof t=="function"&&(n=t,t=void 0),typeof e=="function"&&(n=e,e="utf8"),t!==void 0&&this.write(t,e),n&&this.once("end",n),this[mt]=!0,this.writable=!1,(this[de]||!this[Dr])&&this[wt](),this}[jn](){this[Q]||(!this[rn]&&!this[Re].length&&(this[Pe]=!0),this[Dr]=!1,this[de]=!0,this.emit("resume"),this[ue].length?this[is]():this[mt]?this[wt]():this.emit("drain"))}resume(){return this[jn]()}pause(){this[de]=!1,this[Dr]=!0,this[Pe]=!1}get destroyed(){return this[Q]}get flowing(){return this[de]}get paused(){return this[Dr]}[na](t){this[Ie]?this[fe]+=1:this[fe]+=t.length,this[ue].push(t)}[ss](){return this[Ie]?this[fe]-=1:this[fe]-=this[ue][0].length,this[ue].shift()}[is](t=!1){do;while(this[$d](this[ss]())&&this[ue].length);!t&&!this[ue].length&&!this[mt]&&this.emit("drain")}[$d](t){return this.emit("data",t),this[de]}pipe(t,e){if(this[Q])return t;this[Pe]=!1;let n=this[Ot];return e=e||{},t===Ud.stdout||t===Ud.stderr?e.end=!1:e.end=e.end!==!1,e.proxyErrors=!!e.proxyErrors,n?e.end&&t.end():(this[Re].push(e.proxyErrors?new aw(this,t,e):new Eu(this,t,e)),this[et]?Lr(()=>this[jn]()):this[jn]()),t}unpipe(t){let e=this[Re].find(n=>n.dest===t);e&&(this[Re].length===1?(this[de]&&this[rn]===0&&(this[de]=!1),this[Re]=[]):this[Re].splice(this[Re].indexOf(e),1),e.unpipe())}addListener(t,e){return this.on(t,e)}on(t,e){let n=super.on(t,e);if(t==="data")this[Pe]=!1,this[rn]++,!this[Re].length&&!this[de]&&this[jn]();else if(t==="readable"&&this[fe]!==0)super.emit("readable");else if(iw(t)&&this[Ot])super.emit(t),this.removeAllListeners(t);else if(t==="error"&&this[Cr]){let r=e;this[et]?Lr(()=>r.call(this,this[Cr])):r.call(this,this[Cr])}return n}removeListener(t,e){return this.off(t,e)}off(t,e){let n=super.off(t,e);return t==="data"&&(this[rn]=this.listeners("data").length,this[rn]===0&&!this[Pe]&&!this[Re].length&&(this[de]=!1)),n}removeAllListeners(t){let e=super.removeAllListeners(t);return(t==="data"||t===void 0)&&(this[rn]=0,!this[Pe]&&!this[Re].length&&(this[de]=!1)),e}get emittedEnd(){return this[Ot]}[wt](){!this[ns]&&!this[Ot]&&!this[Q]&&this[ue].length===0&&this[mt]&&(this[ns]=!0,this.emit("end"),this.emit("prefinish"),this.emit("finish"),this[rs]&&this.emit("close"),this[ns]=!1)}emit(t,...e){let n=e[0];if(t!=="error"&&t!=="close"&&t!==Q&&this[Q])return!1;if(t==="data")return!this[Ie]&&!n?!1:this[et]?(Lr(()=>this[ia](n)),!0):this[ia](n);if(t==="end")return this[Gd]();if(t==="close"){if(this[rs]=!0,!this[Ot]&&!this[Q])return!1;let i=super.emit("close");return this.removeAllListeners("close"),i}else if(t==="error"){this[Cr]=n,super.emit(ra,n);let i=!this[Nr]||this.listeners("error").length?super.emit("error",n):!1;return this[wt](),i}else if(t==="resume"){let i=super.emit("resume");return this[wt](),i}else if(t==="finish"||t==="prefinish"){let i=super.emit(t);return this.removeAllListeners(t),i}let r=super.emit(t,...e);return this[wt](),r}[ia](t){for(let n of this[Re])n.dest.write(t)===!1&&this.pause();let e=this[Pe]?!1:super.emit("data",t);return this[wt](),e}[Gd](){return this[Ot]?!1:(this[Ot]=!0,this.readable=!1,this[et]?(Lr(()=>this[sa]()),!0):this[sa]())}[sa](){if(this[Un]){let e=this[Un].end();if(e){for(let n of this[Re])n.dest.write(e);this[Pe]||super.emit("data",e)}}for(let e of this[Re])e.end();let t=super.emit("end");return this.removeAllListeners("end"),t}async collect(){let t=Object.assign([],{dataLength:0});this[Ie]||(t.dataLength=0);let e=this.promise();return this.on("data",n=>{t.push(n),this[Ie]||(t.dataLength+=n.length)}),await e,t}async concat(){if(this[Ie])throw new Error("cannot concat in objectMode");let t=await this.collect();return this[je]?t.join(""):Buffer.concat(t,t.dataLength)}async promise(){return new Promise((t,e)=>{this.on(Q,()=>e(new Error("stream destroyed"))),this.on("error",n=>e(n)),this.on("end",()=>t())})}[Symbol.asyncIterator](){this[Pe]=!1;let t=!1,e=async()=>(this.pause(),t=!0,{value:void 0,done:!0});return{next:()=>{if(t)return e();let n=this.read();if(n!==null)return Promise.resolve({done:!1,value:n});if(this[mt])return e();let r,i,s=l=>{this.off("data",o),this.off("end",a),this.off(Q,c),e(),i(l)},o=l=>{this.off("error",s),this.off("end",a),this.off(Q,c),this.pause(),r({value:l,done:!!this[mt]})},a=()=>{this.off("error",s),this.off("data",o),this.off(Q,c),e(),r({done:!0,value:void 0})},c=()=>s(new Error("stream destroyed"));return new Promise((l,d)=>{i=d,r=l,this.once(Q,c),this.once("error",s),this.once("end",a),this.once("data",o)})},throw:e,return:e,[Symbol.asyncIterator](){return this},[Symbol.asyncDispose]:async()=>{}}}[Symbol.iterator](){this[Pe]=!1;let t=!1,e=()=>(this.pause(),this.off(ra,e),this.off(Q,e),this.off("end",e),t=!0,{done:!0,value:void 0}),n=()=>{if(t)return e();let r=this.read();return r===null?e():{done:!1,value:r}};return this.once("end",e),this.once(ra,e),this.once(Q,e),{next:n,throw:e,return:e,[Symbol.iterator](){return this},[Symbol.dispose]:()=>{}}}destroy(t){if(this[Q])return t?this.emit("error",t):this.emit(Q),this;this[Q]=!0,this[Pe]=!0,this[ue].length=0,this[fe]=0;let e=this;return typeof e.close=="function"&&!this[rs]&&e.close(),t?this.emit("error",t):this.emit(Q),this}static get isStream(){return ew}},dw=xe.writev,zt=Symbol("_autoClose"),Je=Symbol("_close"),Fr=Symbol("_ended"),$=Symbol("_fd"),aa=Symbol("_finished"),St=Symbol("_flags"),ca=Symbol("_flush"),Aa=Symbol("_handleChunk"),xa=Symbol("_makeBuf"),Vr=Symbol("_mode"),as=Symbol("_needDrain"),Zn=Symbol("_onerror"),Kn=Symbol("_onopen"),la=Symbol("_onread"),Wn=Symbol("_onwrite"),$t=Symbol("_open"),Ve=Symbol("_path"),Lt=Symbol("_pos"),nt=Symbol("_queue"),qn=Symbol("_read"),da=Symbol("_readSize"),Et=Symbol("_reading"),Mr=Symbol("_remain"),ua=Symbol("_size"),ws=Symbol("_write"),sn=Symbol("_writing"),ys=Symbol("_defaultFlag"),fn=Symbol("_errored"),Ka=class extends mn{[fn]=!1;[$];[Ve];[da];[Et]=!1;[ua];[Mr];[zt];constructor(t,e){if(e=e||{},super(e),this.readable=!0,this.writable=!1,typeof t!="string")throw new TypeError("path must be a string");this[fn]=!1,this[$]=typeof e.fd=="number"?e.fd:void 0,this[Ve]=t,this[da]=e.readSize||16*1024*1024,this[Et]=!1,this[ua]=typeof e.size=="number"?e.size:1/0,this[Mr]=this[ua],this[zt]=typeof e.autoClose=="boolean"?e.autoClose:!0,typeof this[$]=="number"?this[qn]():this[$t]()}get fd(){return this[$]}get path(){return this[Ve]}write(){throw new TypeError("this is a readable stream")}end(){throw new TypeError("this is a readable stream")}[$t](){xe.open(this[Ve],"r",(t,e)=>this[Kn](t,e))}[Kn](t,e){t?this[Zn](t):(this[$]=e,this.emit("open",e),this[qn]())}[xa](){return Buffer.allocUnsafe(Math.min(this[da],this[Mr]))}[qn](){if(!this[Et]){this[Et]=!0;let t=this[xa]();if(t.length===0)return process.nextTick(()=>this[la](null,0,t));xe.read(this[$],t,0,t.length,null,(e,n,r)=>this[la](e,n,r))}}[la](t,e,n){this[Et]=!1,t?this[Zn](t):this[Aa](e,n)&&this[qn]()}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.close(t,e=>e?this.emit("error",e):this.emit("close"))}}[Zn](t){this[Et]=!0,this[Je](),this.emit("error",t)}[Aa](t,e){let n=!1;return this[Mr]-=t,t>0&&(n=super.write(t<e.length?e.subarray(0,t):e)),(t===0||this[Mr]<=0)&&(n=!1,this[Je](),super.end()),n}emit(t,...e){switch(t){case"prefinish":case"finish":return!1;case"drain":return typeof this[$]=="number"&&this[qn](),!1;case"error":return this[fn]?!1:(this[fn]=!0,super.emit(t,...e));default:return super.emit(t,...e)}}},uw=class extends Ka{[$t](){let t=!0;try{this[Kn](null,xe.openSync(this[Ve],"r")),t=!1}finally{t&&this[Je]()}}[qn](){let t=!0;try{if(!this[Et]){this[Et]=!0;do{let e=this[xa](),n=e.length===0?0:xe.readSync(this[$],e,0,e.length,null);if(!this[Aa](n,e))break}while(!0);this[Et]=!1}t=!1}finally{t&&this[Je]()}}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.closeSync(t),this.emit("close")}}},Ds=class extends Ym{readable=!1;writable=!0;[fn]=!1;[sn]=!1;[Fr]=!1;[nt]=[];[as]=!1;[Ve];[Vr];[zt];[$];[ys];[St];[aa]=!1;[Lt];constructor(t,e){e=e||{},super(e),this[Ve]=t,this[$]=typeof e.fd=="number"?e.fd:void 0,this[Vr]=e.mode===void 0?438:e.mode,this[Lt]=typeof e.start=="number"?e.start:void 0,this[zt]=typeof e.autoClose=="boolean"?e.autoClose:!0;let n=this[Lt]!==void 0?"r+":"w";this[ys]=e.flags===void 0,this[St]=e.flags===void 0?n:e.flags,this[$]===void 0&&this[$t]()}emit(t,...e){if(t==="error"){if(this[fn])return!1;this[fn]=!0}return super.emit(t,...e)}get fd(){return this[$]}get path(){return this[Ve]}[Zn](t){this[Je](),this[sn]=!0,this.emit("error",t)}[$t](){xe.open(this[Ve],this[St],this[Vr],(t,e)=>this[Kn](t,e))}[Kn](t,e){this[ys]&&this[St]==="r+"&&t&&t.code==="ENOENT"?(this[St]="w",this[$t]()):t?this[Zn](t):(this[$]=e,this.emit("open",e),this[sn]||this[ca]())}end(t,e){return t&&this.write(t,e),this[Fr]=!0,!this[sn]&&!this[nt].length&&typeof this[$]=="number"&&this[Wn](null,0),this}write(t,e){return typeof t=="string"&&(t=Buffer.from(t,e)),this[Fr]?(this.emit("error",new Error("write() after end()")),!1):this[$]===void 0||this[sn]||this[nt].length?(this[nt].push(t),this[as]=!0,!1):(this[sn]=!0,this[ws](t),!0)}[ws](t){xe.write(this[$],t,0,t.length,this[Lt],(e,n)=>this[Wn](e,n))}[Wn](t,e){t?this[Zn](t):(this[Lt]!==void 0&&typeof e=="number"&&(this[Lt]+=e),this[nt].length?this[ca]():(this[sn]=!1,this[Fr]&&!this[aa]?(this[aa]=!0,this[Je](),this.emit("finish")):this[as]&&(this[as]=!1,this.emit("drain"))))}[ca](){if(this[nt].length===0)this[Fr]&&this[Wn](null,0);else if(this[nt].length===1)this[ws](this[nt].pop());else{let t=this[nt];this[nt]=[],dw(this[$],t,this[Lt],(e,n)=>this[Wn](e,n))}}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.close(t,e=>e?this.emit("error",e):this.emit("close"))}}},Su=class extends Ds{[$t](){let t;if(this[ys]&&this[St]==="r+")try{t=xe.openSync(this[Ve],this[St],this[Vr])}catch(e){if(e?.code==="ENOENT")return this[St]="w",this[$t]();throw e}else t=xe.openSync(this[Ve],this[St],this[Vr]);this[Kn](null,t)}[Je](){if(this[zt]&&typeof this[$]=="number"){let t=this[$];this[$]=void 0,xe.closeSync(t),this.emit("close")}}[ws](t){let e=!0;try{this[Wn](null,xe.writeSync(this[$],t,0,t.length,this[Lt])),e=!1}finally{if(e)try{this[Je]()}catch{}}}},pw=new Map([["C","cwd"],["f","file"],["z","gzip"],["P","preservePaths"],["U","unlink"],["strip-components","strip"],["stripComponents","strip"],["keep-newer","newer"],["keepNewer","newer"],["keep-newer-files","newer"],["keepNewerFiles","newer"],["k","keep"],["keep-existing","keep"],["keepExisting","keep"],["m","noMtime"],["no-mtime","noMtime"],["p","preserveOwner"],["L","follow"],["h","follow"],["onentry","onReadEntry"]]),gw=t=>!!t.sync&&!!t.file,mw=t=>!t.sync&&!!t.file,ww=t=>!!t.sync&&!t.file,yw=t=>!t.sync&&!t.file,_w=t=>!!t.file,Ew=t=>pw.get(t)||t,Xa=(t={})=>{if(!t)return{};let e={};for(let[n,r]of Object.entries(t)){let i=Ew(n);e[i]=r}return e.chmod===void 0&&e.noChmod===!1&&(e.chmod=!0),delete e.noChmod,e},ni=(t,e,n,r,i)=>Object.assign((s=[],o,a)=>{Array.isArray(s)&&(o=s,s={}),typeof o=="function"&&(a=o,o=void 0),o=o?Array.from(o):[];let c=Xa(s);if(i?.(c,o),gw(c)){if(typeof a=="function")throw new TypeError("callback not supported for sync tar functions");return t(c,o)}else if(mw(c)){let l=e(c,o);return a?l.then(()=>a(),a):l}else if(ww(c)){if(typeof a=="function")throw new TypeError("callback not supported for sync tar functions");return n(c,o)}else if(yw(c)){if(typeof a=="function")throw new TypeError("callback only supported with file option");return r(c,o)}throw new Error("impossible options??")},{syncFile:t,asyncFile:e,syncNoFile:n,asyncNoFile:r,validate:i}),Iw=vw.constants||{ZLIB_VERNUM:4736},ot=Object.freeze(Object.assign(Object.create(null),{Z_NO_FLUSH:0,Z_PARTIAL_FLUSH:1,Z_SYNC_FLUSH:2,Z_FULL_FLUSH:3,Z_FINISH:4,Z_BLOCK:5,Z_OK:0,Z_STREAM_END:1,Z_NEED_DICT:2,Z_ERRNO:-1,Z_STREAM_ERROR:-2,Z_DATA_ERROR:-3,Z_MEM_ERROR:-4,Z_BUF_ERROR:-5,Z_VERSION_ERROR:-6,Z_NO_COMPRESSION:0,Z_BEST_SPEED:1,Z_BEST_COMPRESSION:9,Z_DEFAULT_COMPRESSION:-1,Z_FILTERED:1,Z_HUFFMAN_ONLY:2,Z_RLE:3,Z_FIXED:4,Z_DEFAULT_STRATEGY:0,DEFLATE:1,INFLATE:2,GZIP:3,GUNZIP:4,DEFLATERAW:5,INFLATERAW:6,UNZIP:7,BROTLI_DECODE:8,BROTLI_ENCODE:9,Z_MIN_WINDOWBITS:8,Z_MAX_WINDOWBITS:15,Z_DEFAULT_WINDOWBITS:15,Z_MIN_CHUNK:64,Z_MAX_CHUNK:1/0,Z_DEFAULT_CHUNK:16384,Z_MIN_MEMLEVEL:1,Z_MAX_MEMLEVEL:9,Z_DEFAULT_MEMLEVEL:8,Z_MIN_LEVEL:-1,Z_MAX_LEVEL:9,Z_DEFAULT_LEVEL:-1,BROTLI_OPERATION_PROCESS:0,BROTLI_OPERATION_FLUSH:1,BROTLI_OPERATION_FINISH:2,BROTLI_OPERATION_EMIT_METADATA:3,BROTLI_MODE_GENERIC:0,BROTLI_MODE_TEXT:1,BROTLI_MODE_FONT:2,BROTLI_DEFAULT_MODE:0,BROTLI_MIN_QUALITY:0,BROTLI_MAX_QUALITY:11,BROTLI_DEFAULT_QUALITY:11,BROTLI_MIN_WINDOW_BITS:10,BROTLI_MAX_WINDOW_BITS:24,BROTLI_LARGE_MAX_WINDOW_BITS:30,BROTLI_DEFAULT_WINDOW:22,BROTLI_MIN_INPUT_BLOCK_BITS:16,BROTLI_MAX_INPUT_BLOCK_BITS:24,BROTLI_PARAM_MODE:0,BROTLI_PARAM_QUALITY:1,BROTLI_PARAM_LGWIN:2,BROTLI_PARAM_LGBLOCK:3,BROTLI_PARAM_DISABLE_LITERAL_CONTEXT_MODELING:4,BROTLI_PARAM_SIZE_HINT:5,BROTLI_PARAM_LARGE_WINDOW:6,BROTLI_PARAM_NPOSTFIX:7,BROTLI_PARAM_NDIRECT:8,BROTLI_DECODER_RESULT_ERROR:0,BROTLI_DECODER_RESULT_SUCCESS:1,BROTLI_DECODER_RESULT_NEEDS_MORE_INPUT:2,BROTLI_DECODER_RESULT_NEEDS_MORE_OUTPUT:3,BROTLI_DECODER_PARAM_DISABLE_RING_BUFFER_REALLOCATION:0,BROTLI_DECODER_PARAM_LARGE_WINDOW:1,BROTLI_DECODER_NO_ERROR:0,BROTLI_DECODER_SUCCESS:1,BROTLI_DECODER_NEEDS_MORE_INPUT:2,BROTLI_DECODER_NEEDS_MORE_OUTPUT:3,BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_NIBBLE:-1,BROTLI_DECODER_ERROR_FORMAT_RESERVED:-2,BROTLI_DECODER_ERROR_FORMAT_EXUBERANT_META_NIBBLE:-3,BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_ALPHABET:-4,BROTLI_DECODER_ERROR_FORMAT_SIMPLE_HUFFMAN_SAME:-5,BROTLI_DECODER_ERROR_FORMAT_CL_SPACE:-6,BROTLI_DECODER_ERROR_FORMAT_HUFFMAN_SPACE:-7,BROTLI_DECODER_ERROR_FORMAT_CONTEXT_MAP_REPEAT:-8,BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_1:-9,BROTLI_DECODER_ERROR_FORMAT_BLOCK_LENGTH_2:-10,BROTLI_DECODER_ERROR_FORMAT_TRANSFORM:-11,BROTLI_DECODER_ERROR_FORMAT_DICTIONARY:-12,BROTLI_DECODER_ERROR_FORMAT_WINDOW_BITS:-13,BROTLI_DECODER_ERROR_FORMAT_PADDING_1:-14,BROTLI_DECODER_ERROR_FORMAT_PADDING_2:-15,BROTLI_DECODER_ERROR_FORMAT_DISTANCE:-16,BROTLI_DECODER_ERROR_DICTIONARY_NOT_SET:-19,BROTLI_DECODER_ERROR_INVALID_ARGUMENTS:-20,BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MODES:-21,BROTLI_DECODER_ERROR_ALLOC_TREE_GROUPS:-22,BROTLI_DECODER_ERROR_ALLOC_CONTEXT_MAP:-25,BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_1:-26,BROTLI_DECODER_ERROR_ALLOC_RING_BUFFER_2:-27,BROTLI_DECODER_ERROR_ALLOC_BLOCK_TYPE_TREES:-30,BROTLI_DECODER_ERROR_UNREACHABLE:-31},Iw)),Tw=hn.concat,jd=Object.getOwnPropertyDescriptor(hn,"concat"),Rw=t=>t,fa=jd?.writable===!0||jd?.set!==void 0?t=>{hn.concat=t?Rw:Tw}:t=>{},pn=Symbol("_superWrite"),cs=class extends Error{code;errno;constructor(t,e){super("zlib: "+t.message,{cause:t}),this.code=t.code,this.errno=t.errno,this.code||(this.code="ZLIB_ERROR"),this.message="zlib: "+t.message,Error.captureStackTrace(this,e??this.constructor)}get name(){return"ZlibError"}},ha=Symbol("flushFlag"),Ya=class extends mn{#e=!1;#n=!1;#r;#s;#i;#t;#o;get sawError(){return this.#e}get handle(){return this.#t}get flushFlag(){return this.#r}constructor(t,e){if(!t||typeof t!="object")throw new TypeError("invalid options for ZlibBase constructor");if(super(t),this.#r=t.flush??0,this.#s=t.finishFlush??0,this.#i=t.fullFlushFlag??0,typeof Hd[e]!="function")throw new TypeError("Compression method not supported: "+e);try{this.#t=new Hd[e](t)}catch(n){throw new cs(n,this.constructor)}this.#o=n=>{this.#e||(this.#e=!0,this.close(),this.emit("error",n))},this.#t?.on("error",n=>this.#o(new cs(n))),this.once("end",()=>this.close)}close(){this.#t&&(this.#t.close(),this.#t=void 0,this.emit("close"))}reset(){if(!this.#e)return Oa(this.#t,"zlib binding closed"),this.#t.reset?.()}flush(t){this.ended||(typeof t!="number"&&(t=this.#i),this.write(Object.assign(hn.alloc(0),{[ha]:t})))}end(t,e,n){return typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),t&&(e?this.write(t,e):this.write(t)),this.flush(this.#s),this.#n=!0,super.end(n)}get ended(){return this.#n}[pn](t){return super.write(t)}write(t,e,n){if(typeof e=="function"&&(n=e,e="utf8"),typeof t=="string"&&(t=hn.from(t,e)),this.#e)return;Oa(this.#t,"zlib binding closed");let r=this.#t._handle,i=r.close;r.close=()=>{};let s=this.#t.close;this.#t.close=()=>{},fa(!0);let o;try{let c=typeof t[ha]=="number"?t[ha]:this.#r;o=this.#t._processChunk(t,c),fa(!1)}catch(c){fa(!1),this.#o(new cs(c,this.write))}finally{this.#t&&(this.#t._handle=r,r.close=i,this.#t.close=s,this.#t.removeAllListeners("error"))}this.#t&&this.#t.on("error",c=>this.#o(new cs(c,this.write)));let a;if(o)if(Array.isArray(o)&&o.length>0){let c=o[0];a=this[pn](hn.from(c));for(let l=1;l<o.length;l++)a=this[pn](o[l])}else a=this[pn](hn.from(o));return n&&n(),a}},Iu=class extends Ya{#e;#n;constructor(t,e){t=t||{},t.flush=t.flush||ot.Z_NO_FLUSH,t.finishFlush=t.finishFlush||ot.Z_FINISH,t.fullFlushFlag=ot.Z_FULL_FLUSH,super(t,e),this.#e=t.level,this.#n=t.strategy}params(t,e){if(!this.sawError){if(!this.handle)throw new Error("cannot switch params when binding is closed");if(!this.handle.params)throw new Error("not supported in this implementation");if(this.#e!==t||this.#n!==e){this.flush(ot.Z_SYNC_FLUSH),Oa(this.handle,"zlib binding closed");let n=this.handle.flush;this.handle.flush=(r,i)=>{typeof r=="function"&&(i=r,r=this.flushFlag),this.flush(r),i?.()};try{this.handle.params(t,e)}finally{this.handle.flush=n}this.handle&&(this.#e=t,this.#n=e)}}}},kw=class extends Iu{#e;constructor(t){super(t,"Gzip"),this.#e=t&&!!t.portable}[pn](t){return this.#e?(this.#e=!1,t[9]=255,super[pn](t)):super[pn](t)}},bw=class extends Iu{constructor(t){super(t,"Unzip")}},Tu=class extends Ya{constructor(t,e){t=t||{},t.flush=t.flush||ot.BROTLI_OPERATION_PROCESS,t.finishFlush=t.finishFlush||ot.BROTLI_OPERATION_FINISH,t.fullFlushFlag=ot.BROTLI_OPERATION_FLUSH,super(t,e)}},Aw=class extends Tu{constructor(t){super(t,"BrotliCompress")}},xw=class extends Tu{constructor(t){super(t,"BrotliDecompress")}},Ru=class extends Ya{constructor(t,e){t=t||{},t.flush=t.flush||ot.ZSTD_e_continue,t.finishFlush=t.finishFlush||ot.ZSTD_e_end,t.fullFlushFlag=ot.ZSTD_e_flush,super(t,e)}},Ow=class extends Ru{constructor(t){super(t,"ZstdCompress")}},Pw=class extends Ru{constructor(t){super(t,"ZstdDecompress")}},Cw=(t,e)=>{if(Number.isSafeInteger(t))t<0?Nw(t,e):Dw(t,e);else throw Error("cannot encode number outside of javascript safe integer range");return e},Dw=(t,e)=>{e[0]=128;for(var n=e.length;n>1;n--)e[n-1]=t&255,t=Math.floor(t/256)},Nw=(t,e)=>{e[0]=255;var n=!1;t=t*-1;for(var r=e.length;r>1;r--){var i=t&255;t=Math.floor(t/256),n?e[r-1]=ku(i):i===0?e[r-1]=0:(n=!0,e[r-1]=bu(i))}},Lw=t=>{let e=t[0],n=e===128?Mw(t.subarray(1,t.length)):e===255?Fw(t):null;if(n===null)throw Error("invalid base256 encoding");if(!Number.isSafeInteger(n))throw Error("parsed number outside of javascript safe integer range");return n},Fw=t=>{for(var e=t.length,n=0,r=!1,i=e-1;i>-1;i--){var s=Number(t[i]),o;r?o=ku(s):s===0?o=s:(r=!0,o=bu(s)),o!==0&&(n-=o*Math.pow(256,e-i-1))}return n},Mw=t=>{for(var e=t.length,n=0,r=e-1;r>-1;r--){var i=Number(t[r]);i!==0&&(n+=i*Math.pow(256,e-r-1))}return n},ku=t=>(255^t)&255,bu=t=>(255^t)+1&255,Bw={};Xm(Bw,{code:()=>Qa,isCode:()=>_s,isName:()=>Uw,name:()=>Ns});var _s=t=>Ns.has(t),Uw=t=>Qa.has(t),Ns=new Map([["0","File"],["","OldFile"],["1","Link"],["2","SymbolicLink"],["3","CharacterDevice"],["4","BlockDevice"],["5","Directory"],["6","FIFO"],["7","ContiguousFile"],["g","GlobalExtendedHeader"],["x","ExtendedHeader"],["A","SolarisACL"],["D","GNUDumpDir"],["I","Inode"],["K","NextFileHasLongLinkpath"],["L","NextFileHasLongPath"],["M","ContinuationFile"],["N","OldGnuLongPath"],["S","SparseFile"],["V","TapeVolumeHeader"],["X","OldExtendedHeader"]]),Qa=new Map(Array.from(Ns).map(t=>[t[1],t[0]])),gn=class{cksumValid=!1;needPax=!1;nullBlock=!1;block;path;mode;uid;gid;size;cksum;#e="Unsupported";linkpath;uname;gname;devmaj=0;devmin=0;atime;ctime;mtime;charset;comment;constructor(t,e=0,n,r){Buffer.isBuffer(t)?this.decode(t,e||0,n,r):t&&this.#n(t)}decode(t,e,n,r){if(e||(e=0),!t||!(t.length>=e+512))throw new Error("need 512 bytes for header");this.path=n?.path??on(t,e,100),this.mode=n?.mode??r?.mode??Ft(t,e+100,8),this.uid=n?.uid??r?.uid??Ft(t,e+108,8),this.gid=n?.gid??r?.gid??Ft(t,e+116,8),this.size=n?.size??r?.size??Ft(t,e+124,12),this.mtime=n?.mtime??r?.mtime??pa(t,e+136,12),this.cksum=Ft(t,e+148,12),r&&this.#n(r,!0),n&&this.#n(n);let i=on(t,e+156,1);if(_s(i)&&(this.#e=i||"0"),this.#e==="0"&&this.path.slice(-1)==="/"&&(this.#e="5"),this.#e==="5"&&(this.size=0),this.linkpath=on(t,e+157,100),t.subarray(e+257,e+265).toString()==="ustar\x0000")if(this.uname=n?.uname??r?.uname??on(t,e+265,32),this.gname=n?.gname??r?.gname??on(t,e+297,32),this.devmaj=n?.devmaj??r?.devmaj??Ft(t,e+329,8)??0,this.devmin=n?.devmin??r?.devmin??Ft(t,e+337,8)??0,t[e+475]!==0){let o=on(t,e+345,155);this.path=o+"/"+this.path}else{let o=on(t,e+345,130);o&&(this.path=o+"/"+this.path),this.atime=n?.atime??r?.atime??pa(t,e+476,12),this.ctime=n?.ctime??r?.ctime??pa(t,e+488,12)}let s=256;for(let o=e;o<e+148;o++)s+=t[o];for(let o=e+156;o<e+512;o++)s+=t[o];this.cksumValid=s===this.cksum,this.cksum===void 0&&s===256&&(this.nullBlock=!0)}#n(t,e=!1){Object.assign(this,Object.fromEntries(Object.entries(t).filter(([n,r])=>!(r==null||n==="path"&&e||n==="linkpath"&&e||n==="global"))))}encode(t,e=0){if(t||(t=this.block=Buffer.alloc(512)),this.#e==="Unsupported"&&(this.#e="0"),!(t.length>=e+512))throw new Error("need 512 bytes for header");let n=this.ctime||this.atime?130:155,r=zw(this.path||"",n),i=r[0],s=r[1];this.needPax=!!r[2],this.needPax=an(t,e,100,i)||this.needPax,this.needPax=Mt(t,e+100,8,this.mode)||this.needPax,this.needPax=Mt(t,e+108,8,this.uid)||this.needPax,this.needPax=Mt(t,e+116,8,this.gid)||this.needPax,this.needPax=Mt(t,e+124,12,this.size)||this.needPax,this.needPax=ga(t,e+136,12,this.mtime)||this.needPax,t[e+156]=Number(this.#e.codePointAt(0)),this.needPax=an(t,e+157,100,this.linkpath)||this.needPax,t.write("ustar\x0000",e+257,8),this.needPax=an(t,e+265,32,this.uname)||this.needPax,this.needPax=an(t,e+297,32,this.gname)||this.needPax,this.needPax=Mt(t,e+329,8,this.devmaj)||this.needPax,this.needPax=Mt(t,e+337,8,this.devmin)||this.needPax,this.needPax=an(t,e+345,n,s)||this.needPax,t[e+475]!==0?this.needPax=an(t,e+345,155,s)||this.needPax:(this.needPax=an(t,e+345,130,s)||this.needPax,this.needPax=ga(t,e+476,12,this.atime)||this.needPax,this.needPax=ga(t,e+488,12,this.ctime)||this.needPax);let o=256;for(let a=e;a<e+148;a++)o+=t[a];for(let a=e+156;a<e+512;a++)o+=t[a];return this.cksum=o,Mt(t,e+148,8,this.cksum),this.cksumValid=!0,this.needPax}get type(){return this.#e==="Unsupported"?this.#e:Ns.get(this.#e)}get typeKey(){return this.#e}set type(t){let e=String(Qa.get(t));if(_s(e)||e==="Unsupported")this.#e=e;else if(_s(t))this.#e=t;else throw new TypeError("invalid entry type: "+t)}},zw=(t,e)=>{let n=t,r="",i,s=zn.parse(t).root||".";if(Buffer.byteLength(n)<100)i=[n,r,!1];else{r=zn.dirname(n),n=zn.basename(n);do Buffer.byteLength(n)<=100&&Buffer.byteLength(r)<=e?i=[n,r,!1]:Buffer.byteLength(n)>100&&Buffer.byteLength(r)<=e?i=[n.slice(0,99),r,!0]:(n=zn.join(zn.basename(r),n),r=zn.dirname(r));while(r!==s&&i===void 0);i||(i=[t.slice(0,99),"",!0])}return i},on=(t,e,n)=>t.subarray(e,e+n).toString("utf8").replace(/\0.*/,""),pa=(t,e,n)=>$w(Ft(t,e,n)),$w=t=>t===void 0?void 0:new Date(t*1e3),Ft=(t,e,n)=>Number(t[e])&128?Lw(t.subarray(e,e+n)):Hw(t,e,n),Gw=t=>isNaN(t)?void 0:t,Hw=(t,e,n)=>Gw(parseInt(t.subarray(e,e+n).toString("utf8").replace(/\0.*$/,"").trim(),8)),jw={12:8589934591,8:2097151},Mt=(t,e,n,r)=>r===void 0?!1:r>jw[n]||r<0?(Cw(r,t.subarray(e,e+n)),!0):(Ww(t,e,n,r),!1),Ww=(t,e,n,r)=>t.write(qw(r,n),e,n,"ascii"),qw=(t,e)=>Vw(Math.floor(t).toString(8),e),Vw=(t,e)=>(t.length===e-1?t:new Array(e-t.length-1).join("0")+t+" ")+"\0",ga=(t,e,n,r)=>r===void 0?!1:Mt(t,e,n,r.getTime()/1e3),Jw=new Array(156).join("\0"),an=(t,e,n,r)=>r===void 0?!1:(t.write(r+Jw,e,n,"utf8"),r.length!==Buffer.byteLength(r)||r.length>n),As=class Au{atime;mtime;ctime;charset;comment;gid;uid;gname;uname;linkpath;dev;ino;nlink;path;size;mode;global;constructor(e,n=!1){this.atime=e.atime,this.charset=e.charset,this.comment=e.comment,this.ctime=e.ctime,this.dev=e.dev,this.gid=e.gid,this.global=n,this.gname=e.gname,this.ino=e.ino,this.linkpath=e.linkpath,this.mtime=e.mtime,this.nlink=e.nlink,this.path=e.path,this.size=e.size,this.uid=e.uid,this.uname=e.uname}encode(){let e=this.encodeBody();if(e==="")return Buffer.allocUnsafe(0);let n=Buffer.byteLength(e),r=512*Math.ceil(1+n/512),i=Buffer.allocUnsafe(r);for(let s=0;s<512;s++)i[s]=0;new gn({path:("PaxHeader/"+Zw(this.path??"")).slice(0,99),mode:this.mode||420,uid:this.uid,gid:this.gid,size:n,mtime:this.mtime,type:this.global?"GlobalExtendedHeader":"ExtendedHeader",linkpath:"",uname:this.uname||"",gname:this.gname||"",devmaj:0,devmin:0,atime:this.atime,ctime:this.ctime}).encode(i),i.write(e,512,n,"utf8");for(let s=n+512;s<i.length;s++)i[s]=0;return i}encodeBody(){return this.encodeField("path")+this.encodeField("ctime")+this.encodeField("atime")+this.encodeField("dev")+this.encodeField("ino")+this.encodeField("nlink")+this.encodeField("charset")+this.encodeField("comment")+this.encodeField("gid")+this.encodeField("gname")+this.encodeField("linkpath")+this.encodeField("mtime")+this.encodeField("size")+this.encodeField("uid")+this.encodeField("uname")}encodeField(e){if(this[e]===void 0)return"";let n=this[e],r=n instanceof Date?n.getTime()/1e3:n,i=" "+(e==="dev"||e==="ino"||e==="nlink"?"SCHILY.":"")+e+"="+r+`
89
89
  `,s=Buffer.byteLength(i),o=Math.floor(Math.log(s)/Math.log(10))+1;return s+o>=Math.pow(10,o)&&(o+=1),o+s+i}static parse(e,n,r=!1){return new Au(Kw(Xw(e),n),r)}},Kw=(t,e)=>e?Object.assign({},e,t):t,Xw=t=>t.replace(/\n$/,"").split(`
90
- `).reduce(Yw,Object.create(null)),Yw=(t,e)=>{let n=parseInt(e,10);if(n!==Buffer.byteLength(e)+1)return t;e=e.slice((n+" ").length);let r=e.split("="),i=r.shift();if(!i)return t;let s=i.replace(/^SCHILY\.(dev|ino|nlink)/,"$1"),o=r.join("=");return t[s]=/^([A-Z]+\.)?([mac]|birth|creation)time$/.test(s)?new Date(Number(o)*1e3):/^[0-9]+$/.test(o)?+o:o,t},Qw=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,N=Qw!=="win32"?t=>t:t=>t&&t.replaceAll(/\\/g,"/"),xu=class extends mn{extended;globalExtended;header;startBlockSize;blockRemain;remain;type;meta=!1;ignore=!1;path;mode;uid;gid;uname;gname;size=0;mtime;atime;ctime;linkpath;dev;ino;nlink;invalid=!1;absolute;unsupported=!1;constructor(t,e,n){switch(super({}),this.pause(),this.extended=e,this.globalExtended=n,this.header=t,this.remain=t.size??0,this.startBlockSize=512*Math.ceil(this.remain/512),this.blockRemain=this.startBlockSize,this.type=t.type,this.type){case"File":case"OldFile":case"Link":case"SymbolicLink":case"CharacterDevice":case"BlockDevice":case"Directory":case"FIFO":case"ContiguousFile":case"GNUDumpDir":break;case"NextFileHasLongLinkpath":case"NextFileHasLongPath":case"OldGnuLongPath":case"GlobalExtendedHeader":case"ExtendedHeader":case"OldExtendedHeader":this.meta=!0;break;default:this.ignore=!0}if(!t.path)throw new Error("no path provided for tar.ReadEntry");this.path=N(t.path),this.mode=t.mode,this.mode&&(this.mode=this.mode&4095),this.uid=t.uid,this.gid=t.gid,this.uname=t.uname,this.gname=t.gname,this.size=this.remain,this.mtime=t.mtime,this.atime=t.atime,this.ctime=t.ctime,this.linkpath=t.linkpath?N(t.linkpath):void 0,this.uname=t.uname,this.gname=t.gname,e&&this.#e(e),n&&this.#e(n,!0)}write(t){let e=t.length;if(e>this.blockRemain)throw new Error("writing more to entry than is appropriate");let n=this.remain,r=this.blockRemain;return this.remain=Math.max(0,n-e),this.blockRemain=Math.max(0,r-e),this.ignore?!0:n>=e?super.write(t):super.write(t.subarray(0,n))}#e(t,e=!1){t.path&&(t.path=N(t.path)),t.linkpath&&(t.linkpath=N(t.linkpath)),Object.assign(this,Object.fromEntries(Object.entries(t).filter(([n,r])=>!(r==null||n==="path"&&e))))}},Ns=(t,e,n,r={})=>{t.file&&(r.file=t.file),t.cwd&&(r.cwd=t.cwd),r.code=n instanceof Error&&n.code||e,r.tarCode=e,!t.strict&&r.recoverable!==!1?(n instanceof Error&&(r=Object.assign(n,r),n=n.message),t.emit("warn",e,n,r)):n instanceof Error?t.emit("error",Object.assign(n,r)):t.emit("error",Object.assign(new Error(`${e}: ${n}`),r))},ey=1024*1024,xa=Buffer.from([31,139]),Oa=Buffer.from([40,181,47,253]),ty=Math.max(xa.length,Oa.length),Me=Symbol("state"),cn=Symbol("writeEntry"),yt=Symbol("readEntry"),pa=Symbol("nextEntry"),Wd=Symbol("processEntry"),rt=Symbol("extendedHeader"),Mr=Symbol("globalExtendedHeader"),Pt=Symbol("meta"),qd=Symbol("emitMeta"),W=Symbol("buffer"),_t=Symbol("queue"),Ct=Symbol("ended"),ga=Symbol("emittedEnd"),ln=Symbol("emit"),ee=Symbol("unzip"),cs=Symbol("consumeChunk"),ls=Symbol("consumeChunkSub"),ma=Symbol("consumeBody"),Vd=Symbol("consumeMeta"),Jd=Symbol("consumeHeader"),Br=Symbol("consuming"),wa=Symbol("bufferConcat"),ds=Symbol("maybeEnd"),$n=Symbol("writing"),Dt=Symbol("aborted"),us=Symbol("onDone"),dn=Symbol("sawValidEntry"),fs=Symbol("sawNullBlock"),hs=Symbol("sawEOF"),Zd=Symbol("closeStream"),ny=()=>!0,ei=class extends Sw{file;strict;maxMetaEntrySize;filter;brotli;zstd;writable=!0;readable=!1;[_t]=[];[W];[yt];[cn];[Me]="begin";[Pt]="";[rt];[Mr];[Ct]=!1;[ee];[Dt]=!1;[dn];[fs]=!1;[hs]=!1;[$n]=!1;[Br]=!1;[ga]=!1;constructor(t={}){super(),this.file=t.file||"",this.on(us,()=>{(this[Me]==="begin"||this[dn]===!1)&&this.warn("TAR_BAD_ARCHIVE","Unrecognized archive format")}),t.ondone?this.on(us,t.ondone):this.on(us,()=>{this.emit("prefinish"),this.emit("finish"),this.emit("end")}),this.strict=!!t.strict,this.maxMetaEntrySize=t.maxMetaEntrySize||ey,this.filter=typeof t.filter=="function"?t.filter:ny;let e=t.file&&(t.file.endsWith(".tar.br")||t.file.endsWith(".tbr"));this.brotli=!(t.gzip||t.zstd)&&t.brotli!==void 0?t.brotli:e?void 0:!1;let n=t.file&&(t.file.endsWith(".tar.zst")||t.file.endsWith(".tzst"));this.zstd=!(t.gzip||t.brotli)&&t.zstd!==void 0?t.zstd:n?!0:void 0,this.on("end",()=>this[Zd]()),typeof t.onwarn=="function"&&this.on("warn",t.onwarn),typeof t.onReadEntry=="function"&&this.on("entry",t.onReadEntry)}warn(t,e,n={}){Ns(this,t,e,n)}[Jd](t,e){this[dn]===void 0&&(this[dn]=!1);let n;try{n=new gn(t,e,this[rt],this[Mr])}catch(r){return this.warn("TAR_ENTRY_INVALID",r)}if(n.nullBlock)this[fs]?(this[hs]=!0,this[Me]==="begin"&&(this[Me]="header"),this[ln]("eof")):(this[fs]=!0,this[ln]("nullBlock"));else if(this[fs]=!1,!n.cksumValid)this.warn("TAR_ENTRY_INVALID","checksum failure",{header:n});else if(!n.path)this.warn("TAR_ENTRY_INVALID","path is required",{header:n});else{let r=n.type;if(/^(Symbolic)?Link$/.test(r)&&!n.linkpath)this.warn("TAR_ENTRY_INVALID","linkpath required",{header:n});else if(!/^(Symbolic)?Link$/.test(r)&&!/^(Global)?ExtendedHeader$/.test(r)&&n.linkpath)this.warn("TAR_ENTRY_INVALID","linkpath forbidden",{header:n});else{let i=this[cn]=new xu(n,this[rt],this[Mr]);if(!this[dn])if(i.remain){let s=()=>{i.invalid||(this[dn]=!0)};i.on("end",s)}else this[dn]=!0;i.meta?i.size>this.maxMetaEntrySize?(i.ignore=!0,this[ln]("ignoredEntry",i),this[Me]="ignore",i.resume()):i.size>0&&(this[Pt]="",i.on("data",s=>this[Pt]+=s),this[Me]="meta"):(this[rt]=void 0,i.ignore=i.ignore||!this.filter(i.path,i),i.ignore?(this[ln]("ignoredEntry",i),this[Me]=i.remain?"ignore":"header",i.resume()):(i.remain?this[Me]="body":(this[Me]="header",i.end()),this[yt]?this[_t].push(i):(this[_t].push(i),this[pa]())))}}}[Zd](){queueMicrotask(()=>this.emit("close"))}[Wd](t){let e=!0;if(!t)this[yt]=void 0,e=!1;else if(Array.isArray(t)){let[n,...r]=t;this.emit(n,...r)}else this[yt]=t,this.emit("entry",t),t.emittedEnd||(t.on("end",()=>this[pa]()),e=!1);return e}[pa](){do;while(this[Wd](this[_t].shift()));if(this[_t].length===0){let t=this[yt];!t||t.flowing||t.size===t.remain?this[$n]||this.emit("drain"):t.once("drain",()=>this.emit("drain"))}}[ma](t,e){let n=this[cn];if(!n)throw new Error("attempt to consume body without entry??");let r=n.blockRemain??0,i=r>=t.length&&e===0?t:t.subarray(e,e+r);return n.write(i),n.blockRemain||(this[Me]="header",this[cn]=void 0,n.end()),i.length}[Vd](t,e){let n=this[cn],r=this[ma](t,e);return!this[cn]&&n&&this[qd](n),r}[ln](t,e,n){this[_t].length===0&&!this[yt]?this.emit(t,e,n):this[_t].push([t,e,n])}[qd](t){switch(this[ln]("meta",this[Pt]),t.type){case"ExtendedHeader":case"OldExtendedHeader":this[rt]=bs.parse(this[Pt],this[rt],!1);break;case"GlobalExtendedHeader":this[Mr]=bs.parse(this[Pt],this[Mr],!0);break;case"NextFileHasLongPath":case"OldGnuLongPath":{let e=this[rt]??Object.create(null);this[rt]=e,e.path=this[Pt].replace(/\0.*/,"");break}case"NextFileHasLongLinkpath":{let e=this[rt]||Object.create(null);this[rt]=e,e.linkpath=this[Pt].replace(/\0.*/,"");break}default:throw new Error("unknown meta: "+t.type)}}abort(t){this[Dt]=!0,this.emit("abort",t),this.warn("TAR_ABORT",t,{recoverable:!1})}write(t,e,n){if(typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8")),this[Dt])return n?.(),!1;if((this[ee]===void 0||this.brotli===void 0&&this[ee]===!1)&&t){if(this[W]&&(t=Buffer.concat([this[W],t]),this[W]=void 0),t.length<ty)return this[W]=t,n?.(),!0;for(let o=0;this[ee]===void 0&&o<xa.length;o++)t[o]!==xa[o]&&(this[ee]=!1);let i=!1;if(this[ee]===!1&&this.zstd!==!1){i=!0;for(let o=0;o<Oa.length;o++)if(t[o]!==Oa[o]){i=!1;break}}let s=this.brotli===void 0&&!i;if(this[ee]===!1&&s)if(t.length<512)if(this[Ct])this.brotli=!0;else return this[W]=t,n?.(),!0;else try{new gn(t.subarray(0,512)),this.brotli=!1}catch{this.brotli=!0}if(this[ee]===void 0||this[ee]===!1&&(this.brotli||i)){let o=this[Ct];this[Ct]=!1,this[ee]=this[ee]===void 0?new bw({}):i?new Pw({}):new xw({}),this[ee].on("data",c=>this[cs](c)),this[ee].on("error",c=>this.abort(c)),this[ee].on("end",()=>{this[Ct]=!0,this[cs]()}),this[$n]=!0;let a=!!this[ee][o?"end":"write"](t);return this[$n]=!1,n?.(),a}}this[$n]=!0,this[ee]?this[ee].write(t):this[cs](t),this[$n]=!1;let r=this[_t].length>0?!1:this[yt]?this[yt].flowing:!0;return!r&&this[_t].length===0&&this[yt]?.once("drain",()=>this.emit("drain")),n?.(),r}[wa](t){t&&!this[Dt]&&(this[W]=this[W]?Buffer.concat([this[W],t]):t)}[ds](){if(this[Ct]&&!this[ga]&&!this[Dt]&&!this[Br]){this[ga]=!0;let t=this[cn];if(t&&t.blockRemain){let e=this[W]?this[W].length:0;this.warn("TAR_BAD_ARCHIVE",`Truncated input (needed ${t.blockRemain} more bytes, only ${e} available)`,{entry:t}),this[W]&&t.write(this[W]),t.end()}this[ln](us)}}[cs](t){if(this[Br]&&t)this[wa](t);else if(!t&&!this[W])this[ds]();else if(t){if(this[Br]=!0,this[W]){this[wa](t);let e=this[W];this[W]=void 0,this[ls](e)}else this[ls](t);for(;this[W]&&this[W]?.length>=512&&!this[Dt]&&!this[hs];){let e=this[W];this[W]=void 0,this[ls](e)}this[Br]=!1}(!this[W]||this[Ct])&&this[ds]()}[ls](t){let e=0,n=t.length;for(;e+512<=n&&!this[Dt]&&!this[hs];)switch(this[Me]){case"begin":case"header":this[Jd](t,e),e+=512;break;case"ignore":case"body":e+=this[ma](t,e);break;case"meta":e+=this[Vd](t,e);break;default:throw new Error("invalid state: "+this[Me])}e<n&&(this[W]=this[W]?Buffer.concat([t.subarray(e),this[W]]):t.subarray(e))}end(t,e,n){return typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,e)),n&&this.once("finish",n),this[Dt]||(this[ee]?(t&&this[ee].write(t),this[ee].end()):(this[Ct]=!0,(this.brotli===void 0||this.zstd===void 0)&&(t=t||Buffer.alloc(0)),t&&this.write(t),this[ds]())),this}},Vr=t=>{let e=t.length-1,n=-1;for(;e>-1&&t.charAt(e)==="/";)n=e,e--;return n===-1?t:t.slice(0,n)},ry=t=>{let e=t.onReadEntry;t.onReadEntry=e?n=>{e(n),n.resume()}:n=>n.resume()},Ou=(t,e)=>{let n=new Map(e.map(s=>[Vr(s),!0])),r=t.filter,i=(s,o="")=>{let a=o||hw(s).root||".",c;if(s===a)c=!1;else{let l=n.get(s);c=l!==void 0?l:i(fw(s),a)}return n.set(s,c),c};t.filter=r?(s,o)=>r(s,o)&&i(Vr(s)):s=>i(Vr(s))},iy=t=>{let e=new ei(t),n=t.file,r;try{r=Vn.openSync(n,"r");let i=Vn.fstatSync(r),s=t.maxReadSize||16*1024*1024;if(i.size<s){let o=Buffer.allocUnsafe(i.size),a=Vn.readSync(r,o,0,i.size,0);e.end(a===o.byteLength?o:o.subarray(0,a))}else{let o=0,a=Buffer.allocUnsafe(s);for(;o<i.size;){let c=Vn.readSync(r,a,0,s,o);if(c===0)break;o+=c,e.write(a.subarray(0,c))}e.end()}}finally{if(typeof r=="number")try{Vn.closeSync(r)}catch{}}},sy=(t,e)=>{let n=new ei(t),r=t.maxReadSize||16*1024*1024,i=t.file;return new Promise((s,o)=>{n.on("error",o),n.on("end",s),Vn.stat(i,(a,c)=>{if(a)o(a);else{let l=new Ja(i,{readSize:r,size:c.size});l.on("error",o),l.pipe(n)}})})},Xn=ti(iy,sy,t=>new ei(t),t=>new ei(t),(t,e)=>{e?.length&&Ou(t,e),t.noResume||ry(t)}),Pu=(t,e,n)=>(t&=4095,n&&(t=(t|384)&-19),e&&(t&256&&(t|=64),t&32&&(t|=8),t&4&&(t|=1)),t),{isAbsolute:ay,parse:Xd}=oy,Ya=t=>{let e="",n=Xd(t);for(;ay(t)||n.root;){let r=t.charAt(0)==="/"&&t.slice(0,4)!=="//?/"?"/":n.root;t=t.slice(r.length),e+=r,n=Xd(t)}return[e,t]},Ls=["|","<",">","?",":"],Qa=Ls.map(t=>String.fromCodePoint(61440+Number(t.codePointAt(0)))),cy=new Map(Ls.map((t,e)=>[t,Qa[e]])),ly=new Map(Qa.map((t,e)=>[t,Ls[e]])),Yd=t=>Ls.reduce((e,n)=>e.split(n).join(cy.get(n)),t),dy=t=>Qa.reduce((e,n)=>e.split(n).join(ly.get(n)),t),Cu=(t,e)=>e?(t=N(t).replace(/^\.(\/|$)/,""),Vr(e)+"/"+t):N(t),uy=16*1024*1024,Qd=Symbol("process"),eu=Symbol("file"),tu=Symbol("directory"),Pa=Symbol("symlink"),nu=Symbol("hardlink"),Ur=Symbol("header"),_s=Symbol("read"),Ca=Symbol("lstat"),Es=Symbol("onlstat"),Da=Symbol("onread"),Na=Symbol("onreadlink"),La=Symbol("openfile"),Fa=Symbol("onopenfile"),Bt=Symbol("close"),xs=Symbol("mode"),Ma=Symbol("awaitDrain"),ya=Symbol("ondrain"),st=Symbol("prefix"),Du=class extends mn{path;portable;myuid=process.getuid&&process.getuid()||0;myuser=process.env.USER||"";maxReadSize;linkCache;statCache;preservePaths;cwd;strict;mtime;noPax;noMtime;prefix;fd;blockLen=0;blockRemain=0;buf;pos=0;remain=0;length=0;offset=0;win32;absolute;header;type;linkpath;stat;onWriteEntry;#e=!1;constructor(t,e={}){let n=Za(e);super(),this.path=N(t),this.portable=!!n.portable,this.maxReadSize=n.maxReadSize||uy,this.linkCache=n.linkCache||new Map,this.statCache=n.statCache||new Map,this.preservePaths=!!n.preservePaths,this.cwd=N(n.cwd||process.cwd()),this.strict=!!n.strict,this.noPax=!!n.noPax,this.noMtime=!!n.noMtime,this.mtime=n.mtime,this.prefix=n.prefix?N(n.prefix):void 0,this.onWriteEntry=n.onWriteEntry,typeof n.onwarn=="function"&&this.on("warn",n.onwarn);let r=!1;if(!this.preservePaths){let[s,o]=Ya(this.path);s&&typeof o=="string"&&(this.path=o,r=s)}this.win32=!!n.win32||process.platform==="win32",this.win32&&(this.path=dy(this.path.replaceAll(/\\/g,"/")),t=t.replaceAll(/\\/g,"/")),this.absolute=N(n.absolute||Kd.resolve(this.cwd,t)),this.path===""&&(this.path="./"),r&&this.warn("TAR_ENTRY_INFO",`stripping ${r} from absolute path`,{entry:this,path:r+this.path});let i=this.statCache.get(this.absolute);i?this[Es](i):this[Ca]()}warn(t,e,n={}){return Ns(this,t,e,n)}emit(t,...e){return t==="error"&&(this.#e=!0),super.emit(t,...e)}[Ca](){it.lstat(this.absolute,(t,e)=>{if(t)return this.emit("error",t);this[Es](e)})}[Es](t){this.statCache.set(this.absolute,t),this.stat=t,t.isFile()||(t.size=0),this.type=py(t),this.emit("stat",t),this[Qd]()}[Qd](){switch(this.type){case"File":return this[eu]();case"Directory":return this[tu]();case"SymbolicLink":return this[Pa]();default:return this.end()}}[xs](t){return Pu(t,this.type==="Directory",this.portable)}[st](t){return Cu(t,this.prefix)}[Ur](){if(!this.stat)throw new Error("cannot write header before stat");this.type==="Directory"&&this.portable&&(this.noMtime=!0),this.onWriteEntry?.(this),this.header=new gn({path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,mode:this[xs](this.stat.mode),uid:this.portable?void 0:this.stat.uid,gid:this.portable?void 0:this.stat.gid,size:this.stat.size,mtime:this.noMtime?void 0:this.mtime||this.stat.mtime,type:this.type==="Unsupported"?void 0:this.type,uname:this.portable?void 0:this.stat.uid===this.myuid?this.myuser:"",atime:this.portable?void 0:this.stat.atime,ctime:this.portable?void 0:this.stat.ctime}),this.header.encode()&&!this.noPax&&super.write(new bs({atime:this.portable?void 0:this.header.atime,ctime:this.portable?void 0:this.header.ctime,gid:this.portable?void 0:this.header.gid,mtime:this.noMtime?void 0:this.mtime||this.header.mtime,path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,size:this.header.size,uid:this.portable?void 0:this.header.uid,uname:this.portable?void 0:this.header.uname,dev:this.portable?void 0:this.stat.dev,ino:this.portable?void 0:this.stat.ino,nlink:this.portable?void 0:this.stat.nlink}).encode());let t=this.header?.block;if(!t)throw new Error("failed to encode header");super.write(t)}[tu](){if(!this.stat)throw new Error("cannot create directory entry without stat");this.path.slice(-1)!=="/"&&(this.path+="/"),this.stat.size=0,this[Ur](),this.end()}[Pa](){it.readlink(this.absolute,(t,e)=>{if(t)return this.emit("error",t);this[Na](e)})}[Na](t){this.linkpath=N(t),this[Ur](),this.end()}[nu](t){if(!this.stat)throw new Error("cannot create link entry without stat");this.type="Link",this.linkpath=N(Kd.relative(this.cwd,t)),this.stat.size=0,this[Ur](),this.end()}[eu](){if(!this.stat)throw new Error("cannot create file entry without stat");if(this.stat.nlink>1){let t=`${this.stat.dev}:${this.stat.ino}`,e=this.linkCache.get(t);if(e?.indexOf(this.cwd)===0)return this[nu](e);this.linkCache.set(t,this.absolute)}if(this[Ur](),this.stat.size===0)return this.end();this[La]()}[La](){it.open(this.absolute,"r",(t,e)=>{if(t)return this.emit("error",t);this[Fa](e)})}[Fa](t){if(this.fd=t,this.#e)return this[Bt]();if(!this.stat)throw new Error("should stat before calling onopenfile");this.blockLen=512*Math.ceil(this.stat.size/512),this.blockRemain=this.blockLen;let e=Math.min(this.blockLen,this.maxReadSize);this.buf=Buffer.allocUnsafe(e),this.offset=0,this.pos=0,this.remain=this.stat.size,this.length=this.buf.length,this[_s]()}[_s](){let{fd:t,buf:e,offset:n,length:r,pos:i}=this;if(t===void 0||e===void 0)throw new Error("cannot read file without first opening");it.read(t,e,n,r,i,(s,o)=>{if(s)return this[Bt](()=>this.emit("error",s));this[Da](o)})}[Bt](t=()=>{}){this.fd!==void 0&&it.close(this.fd,t)}[Da](t){if(t<=0&&this.remain>0){let n=Object.assign(new Error("encountered unexpected EOF"),{path:this.absolute,syscall:"read",code:"EOF"});return this[Bt](()=>this.emit("error",n))}if(t>this.remain){let n=Object.assign(new Error("did not encounter expected EOF"),{path:this.absolute,syscall:"read",code:"EOF"});return this[Bt](()=>this.emit("error",n))}if(!this.buf)throw new Error("should have created buffer prior to reading");if(t===this.remain)for(let n=t;n<this.length&&t<this.blockRemain;n++)this.buf[n+this.offset]=0,t++,this.remain++;let e=this.offset===0&&t===this.buf.length?this.buf:this.buf.subarray(this.offset,this.offset+t);this.write(e)?this[ya]():this[Ma](()=>this[ya]())}[Ma](t){this.once("drain",t)}write(t,e,n){if(typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8")),this.blockRemain<t.length){let r=Object.assign(new Error("writing more data than expected"),{path:this.absolute});return this.emit("error",r)}return this.remain-=t.length,this.blockRemain-=t.length,this.pos+=t.length,this.offset+=t.length,super.write(t,null,n)}[ya](){if(!this.remain)return this.blockRemain&&super.write(Buffer.alloc(this.blockRemain)),this[Bt](t=>t?this.emit("error",t):this.end());if(!this.buf)throw new Error("buffer lost somehow in ONDRAIN");this.offset>=this.length&&(this.buf=Buffer.allocUnsafe(Math.min(this.blockRemain,this.buf.length)),this.offset=0),this.length=this.buf.length-this.offset,this[_s]()}},fy=class extends Du{sync=!0;[Ca](){this[Es](it.lstatSync(this.absolute))}[Pa](){this[Na](it.readlinkSync(this.absolute))}[La](){this[Fa](it.openSync(this.absolute,"r"))}[_s](){let t=!0;try{let{fd:e,buf:n,offset:r,length:i,pos:s}=this;if(e===void 0||n===void 0)throw new Error("fd and buf must be set in READ method");let o=it.readSync(e,n,r,i,s);this[Da](o),t=!1}finally{if(t)try{this[Bt](()=>{})}catch{}}}[Ma](t){t()}[Bt](t=()=>{}){this.fd!==void 0&&it.closeSync(this.fd),t()}},hy=class extends mn{blockLen=0;blockRemain=0;buf=0;pos=0;remain=0;length=0;preservePaths;portable;strict;noPax;noMtime;readEntry;type;prefix;path;mode;uid;gid;uname;gname;header;mtime;atime;ctime;linkpath;size;onWriteEntry;warn(t,e,n={}){return Ns(this,t,e,n)}constructor(t,e={}){let n=Za(e);super(),this.preservePaths=!!n.preservePaths,this.portable=!!n.portable,this.strict=!!n.strict,this.noPax=!!n.noPax,this.noMtime=!!n.noMtime,this.onWriteEntry=n.onWriteEntry,this.readEntry=t;let{type:r}=t;if(r==="Unsupported")throw new Error("writing entry that should be ignored");this.type=r,this.type==="Directory"&&this.portable&&(this.noMtime=!0),this.prefix=n.prefix,this.path=N(t.path),this.mode=t.mode!==void 0?this[xs](t.mode):void 0,this.uid=this.portable?void 0:t.uid,this.gid=this.portable?void 0:t.gid,this.uname=this.portable?void 0:t.uname,this.gname=this.portable?void 0:t.gname,this.size=t.size,this.mtime=this.noMtime?void 0:n.mtime||t.mtime,this.atime=this.portable?void 0:t.atime,this.ctime=this.portable?void 0:t.ctime,this.linkpath=t.linkpath!==void 0?N(t.linkpath):void 0,typeof n.onwarn=="function"&&this.on("warn",n.onwarn);let i=!1;if(!this.preservePaths){let[o,a]=Ya(this.path);o&&typeof a=="string"&&(this.path=a,i=o)}this.remain=t.size,this.blockRemain=t.startBlockSize,this.onWriteEntry?.(this),this.header=new gn({path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,mode:this.mode,uid:this.portable?void 0:this.uid,gid:this.portable?void 0:this.gid,size:this.size,mtime:this.noMtime?void 0:this.mtime,type:this.type,uname:this.portable?void 0:this.uname,atime:this.portable?void 0:this.atime,ctime:this.portable?void 0:this.ctime}),i&&this.warn("TAR_ENTRY_INFO",`stripping ${i} from absolute path`,{entry:this,path:i+this.path}),this.header.encode()&&!this.noPax&&super.write(new bs({atime:this.portable?void 0:this.atime,ctime:this.portable?void 0:this.ctime,gid:this.portable?void 0:this.gid,mtime:this.noMtime?void 0:this.mtime,path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,size:this.size,uid:this.portable?void 0:this.uid,uname:this.portable?void 0:this.uname,dev:this.portable?void 0:this.readEntry.dev,ino:this.portable?void 0:this.readEntry.ino,nlink:this.portable?void 0:this.readEntry.nlink}).encode());let s=this.header?.block;if(!s)throw new Error("failed to encode header");super.write(s),t.pipe(this)}[st](t){return Cu(t,this.prefix)}[xs](t){return Pu(t,this.type==="Directory",this.portable)}write(t,e,n){typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8"));let r=t.length;if(r>this.blockRemain)throw new Error("writing more to entry than is appropriate");return this.blockRemain-=r,super.write(t,n)}end(t,e,n){return this.blockRemain&&super.write(Buffer.alloc(this.blockRemain)),typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,e??"utf8")),n&&this.once("finish",n),t?super.end(t,n):super.end(n),this}},py=t=>t.isFile()?"File":t.isDirectory()?"Directory":t.isSymbolicLink()?"SymbolicLink":"Unsupported",gy=class Jn{tail;head;length=0;static create(e=[]){return new Jn(e)}constructor(e=[]){for(let n of e)this.push(n)}*[Symbol.iterator](){for(let e=this.head;e;e=e.next)yield e.value}removeNode(e){if(e.list!==this)throw new Error("removing node which does not belong to this list");let n=e.next,r=e.prev;return n&&(n.prev=r),r&&(r.next=n),e===this.head&&(this.head=n),e===this.tail&&(this.tail=r),this.length--,e.next=void 0,e.prev=void 0,e.list=void 0,n}unshiftNode(e){if(e===this.head)return;e.list&&e.list.removeNode(e);let n=this.head;e.list=this,e.next=n,n&&(n.prev=e),this.head=e,this.tail||(this.tail=e),this.length++}pushNode(e){if(e===this.tail)return;e.list&&e.list.removeNode(e);let n=this.tail;e.list=this,e.prev=n,n&&(n.next=e),this.tail=e,this.head||(this.head=e),this.length++}push(...e){for(let n=0,r=e.length;n<r;n++)wy(this,e[n]);return this.length}unshift(...e){for(var n=0,r=e.length;n<r;n++)yy(this,e[n]);return this.length}pop(){if(!this.tail)return;let e=this.tail.value,n=this.tail;return this.tail=this.tail.prev,this.tail?this.tail.next=void 0:this.head=void 0,n.list=void 0,this.length--,e}shift(){if(!this.head)return;let e=this.head.value,n=this.head;return this.head=this.head.next,this.head?this.head.prev=void 0:this.tail=void 0,n.list=void 0,this.length--,e}forEach(e,n){n=n||this;for(let r=this.head,i=0;r;i++)e.call(n,r.value,i,this),r=r.next}forEachReverse(e,n){n=n||this;for(let r=this.tail,i=this.length-1;r;i--)e.call(n,r.value,i,this),r=r.prev}get(e){let n=0,r=this.head;for(;r&&n<e;n++)r=r.next;if(n===e&&r)return r.value}getReverse(e){let n=0,r=this.tail;for(;r&&n<e;n++)r=r.prev;if(n===e&&r)return r.value}map(e,n){n=n||this;let r=new Jn;for(let i=this.head;i;)r.push(e.call(n,i.value,this)),i=i.next;return r}mapReverse(e,n){n=n||this;var r=new Jn;for(let i=this.tail;i;)r.push(e.call(n,i.value,this)),i=i.prev;return r}reduce(e,n){let r,i=this.head;if(arguments.length>1)r=n;else if(this.head)i=this.head.next,r=this.head.value;else throw new TypeError("Reduce of empty list with no initial value");for(var s=0;i;s++)r=e(r,i.value,s),i=i.next;return r}reduceReverse(e,n){let r,i=this.tail;if(arguments.length>1)r=n;else if(this.tail)i=this.tail.prev,r=this.tail.value;else throw new TypeError("Reduce of empty list with no initial value");for(let s=this.length-1;i;s--)r=e(r,i.value,s),i=i.prev;return r}toArray(){let e=new Array(this.length);for(let n=0,r=this.head;r;n++)e[n]=r.value,r=r.next;return e}toArrayReverse(){let e=new Array(this.length);for(let n=0,r=this.tail;r;n++)e[n]=r.value,r=r.prev;return e}slice(e=0,n=this.length){n<0&&(n+=this.length),e<0&&(e+=this.length);let r=new Jn;if(n<e||n<0)return r;e<0&&(e=0),n>this.length&&(n=this.length);let i=this.head,s=0;for(s=0;i&&s<e;s++)i=i.next;for(;i&&s<n;s++,i=i.next)r.push(i.value);return r}sliceReverse(e=0,n=this.length){n<0&&(n+=this.length),e<0&&(e+=this.length);let r=new Jn;if(n<e||n<0)return r;e<0&&(e=0),n>this.length&&(n=this.length);let i=this.length,s=this.tail;for(;s&&i>n;i--)s=s.prev;for(;s&&i>e;i--,s=s.prev)r.push(s.value);return r}splice(e,n=0,...r){e>this.length&&(e=this.length-1),e<0&&(e=this.length+e);let i=this.head;for(let o=0;i&&o<e;o++)i=i.next;let s=[];for(let o=0;i&&o<n;o++)s.push(i.value),i=this.removeNode(i);i?i!==this.tail&&(i=i.prev):i=this.tail;for(let o of r)i=my(this,i,o);return s}reverse(){let e=this.head,n=this.tail;for(let r=e;r;r=r.prev){let i=r.prev;r.prev=r.next,r.next=i}return this.head=n,this.tail=e,this}};function my(t,e,n){let r=e,i=e?e.next:t.head,s=new ec(n,r,i,t);return s.next===void 0&&(t.tail=s),s.prev===void 0&&(t.head=s),t.length++,s}function wy(t,e){t.tail=new ec(e,t.tail,void 0,t),t.head||(t.head=t.tail),t.length++}function yy(t,e){t.head=new ec(e,void 0,t.head,t),t.tail||(t.tail=t.head),t.length++}var ec=class{list;next;prev;value;constructor(t,e,n,r){this.list=r,this.value=t,e?(e.next=this,this.prev=e):this.prev=void 0,n?(n.prev=this,this.next=n):this.next=void 0}},iu=class{path;absolute;entry;stat;readdir;pending=!1;pendingLink=!1;ignore=!1;piped=!1;constructor(t,e){this.path=t||"./",this.absolute=e}},su=Buffer.alloc(1024),Ss=Symbol("onStat"),zr=Symbol("ended"),We=Symbol("queue"),$r=Symbol("queue"),Nt=Symbol("current"),un=Symbol("process"),Gr=Symbol("processing"),ps=Symbol("processJob"),qe=Symbol("jobs"),_a=Symbol("jobDone"),vs=Symbol("addFSEntry"),ou=Symbol("addTarEntry"),Ba=Symbol("stat"),Ua=Symbol("readdir"),Is=Symbol("onreaddir"),Ts=Symbol("pipe"),au=Symbol("entry"),Ea=Symbol("entryOpt"),Rs=Symbol("writeEntryClass"),Nu=Symbol("write"),Sa=Symbol("ondrain"),Fs=class extends mn{sync=!1;opt;cwd;maxReadSize;preservePaths;strict;noPax;prefix;linkCache;statCache;file;portable;zip;readdirCache;noDirRecurse;follow;noMtime;mtime;filter;jobs;[Rs];onWriteEntry;[We];[$r]=new Map;[qe]=0;[Gr]=!1;[zr]=!1;constructor(t={}){if(super(),this.opt=t,this.file=t.file||"",this.cwd=t.cwd||process.cwd(),this.maxReadSize=t.maxReadSize,this.preservePaths=!!t.preservePaths,this.strict=!!t.strict,this.noPax=!!t.noPax,this.prefix=N(t.prefix||""),this.linkCache=t.linkCache||new Map,this.statCache=t.statCache||new Map,this.readdirCache=t.readdirCache||new Map,this.onWriteEntry=t.onWriteEntry,this[Rs]=Du,typeof t.onwarn=="function"&&this.on("warn",t.onwarn),this.portable=!!t.portable,t.gzip||t.brotli||t.zstd){if((t.gzip?1:0)+(t.brotli?1:0)+(t.zstd?1:0)>1)throw new TypeError("gzip, brotli, zstd are mutually exclusive");if(t.gzip&&(typeof t.gzip!="object"&&(t.gzip={}),this.portable&&(t.gzip.portable=!0),this.zip=new kw(t.gzip)),t.brotli&&(typeof t.brotli!="object"&&(t.brotli={}),this.zip=new Aw(t.brotli)),t.zstd&&(typeof t.zstd!="object"&&(t.zstd={}),this.zip=new Ow(t.zstd)),!this.zip)throw new Error("impossible");let e=this.zip;e.on("data",n=>super.write(n)),e.on("end",()=>super.end()),e.on("drain",()=>this[Sa]()),this.on("resume",()=>e.resume())}else this.on("drain",this[Sa]);this.noDirRecurse=!!t.noDirRecurse,this.follow=!!t.follow,this.noMtime=!!t.noMtime,t.mtime&&(this.mtime=t.mtime),this.filter=typeof t.filter=="function"?t.filter:()=>!0,this[We]=new gy,this[qe]=0,this.jobs=Number(t.jobs)||4,this[Gr]=!1,this[zr]=!1}[Nu](t){return super.write(t)}add(t){return this.write(t),this}end(t,e,n){return typeof t=="function"&&(n=t,t=void 0),typeof e=="function"&&(n=e,e=void 0),t&&this.add(t),this[zr]=!0,this[un](),n&&n(),this}write(t){if(this[zr])throw new Error("write after end");return t instanceof xu?this[ou](t):this[vs](t),this.flowing}[ou](t){let e=N(ru.resolve(this.cwd,t.path));if(!this.filter(t.path,t))t.resume();else{let n=new iu(t.path,e);n.entry=new hy(t,this[Ea](n)),n.entry.on("end",()=>this[_a](n)),this[qe]+=1,this[We].push(n)}this[un]()}[vs](t){let e=N(ru.resolve(this.cwd,t));this[We].push(new iu(t,e)),this[un]()}[Ba](t){t.pending=!0,this[qe]+=1;let e=this.follow?"stat":"lstat";As[e](t.absolute,(n,r)=>{t.pending=!1,this[qe]-=1,n?this.emit("error",n):this[Ss](t,r)})}[Ss](t,e){if(this.statCache.set(t.absolute,e),t.stat=e,!this.filter(t.path,e))t.ignore=!0;else if(e.isFile()&&e.nlink>1&&!this.linkCache.get(`${e.dev}:${e.ino}`)&&!this.sync)if(t===this[Nt])this[ps](t);else{let n=`${e.dev}:${e.ino}`,r=this[$r].get(n);r?r.push(t):this[$r].set(n,[t]),t.pendingLink=!0,t.pending=!0}this[un]()}[Ua](t){t.pending=!0,this[qe]+=1,As.readdir(t.absolute,(e,n)=>{if(t.pending=!1,this[qe]-=1,e)return this.emit("error",e);this[Is](t,n)})}[Is](t,e){this.readdirCache.set(t.absolute,e),t.readdir=e,this[un]()}[un](){if(!this[Gr]){this[Gr]=!0;for(let t=this[We].head;t&&this[qe]<this.jobs;t=t.next)if(this[ps](t.value),t.value.ignore){let e=t.next;this[We].removeNode(t),t.next=e}this[Gr]=!1,this[zr]&&this[We].length===0&&this[qe]===0&&(this.zip?this.zip.end(su):(super.write(su),super.end()))}}get[Nt](){return this[We]&&this[We].head&&this[We].head.value}[_a](t){this[We].shift(),this[qe]-=1;let{stat:e}=t;if(e&&e.isFile()&&e.nlink>1){let n=`${e.dev}:${e.ino}`,r=this[$r].get(n);if(r){this[$r].delete(n);for(let i of r)i.pending=!1,this[ps](i)}}this[un]()}[ps](t){if(t.pending&&t.pendingLink&&t===this[Nt]&&(t.pending=!1,t.pendingLink=!1),!t.pending){if(t.entry){t===this[Nt]&&!t.piped&&this[Ts](t);return}if(!t.stat){let e=this.statCache.get(t.absolute);e?this[Ss](t,e):this[Ba](t)}if(t.stat&&!t.ignore){if(!this.noDirRecurse&&t.stat.isDirectory()&&!t.readdir){let e=this.readdirCache.get(t.absolute);if(e?this[Is](t,e):this[Ua](t),!t.readdir)return}if(t.entry=this[au](t),!t.entry){t.ignore=!0;return}t===this[Nt]&&!t.piped&&this[Ts](t)}}}[Ea](t){return{onwarn:(e,n,r)=>this.warn(e,n,r),noPax:this.noPax,cwd:this.cwd,absolute:t.absolute,preservePaths:this.preservePaths,maxReadSize:this.maxReadSize,strict:this.strict,portable:this.portable,linkCache:this.linkCache,statCache:this.statCache,noMtime:this.noMtime,mtime:this.mtime,prefix:this.prefix,onWriteEntry:this.onWriteEntry}}[au](t){this[qe]+=1;try{return new this[Rs](t.path,this[Ea](t)).on("end",()=>this[_a](t)).on("error",e=>this.emit("error",e))}catch(e){this.emit("error",e)}}[Sa](){this[Nt]&&this[Nt].entry&&this[Nt].entry.resume()}[Ts](t){t.piped=!0,t.readdir&&t.readdir.forEach(r=>{let i=t.path,s=i==="./"?"":i.replace(/\/*$/,"/");this[vs](s+r)});let e=t.entry,n=this.zip;if(!e)throw new Error("cannot pipe without source");n?e.on("data",r=>{n.write(r)||e.pause()}):e.on("data",r=>{super.write(r)||e.pause()})}pause(){return this.zip&&this.zip.pause(),super.pause()}warn(t,e,n={}){Ns(this,t,e,n)}},tc=class extends Fs{sync=!0;constructor(t){super(t),this[Rs]=fy}pause(){}resume(){}[Ba](t){let e=this.follow?"statSync":"lstatSync";this[Ss](t,As[e](t.absolute))}[Ua](t){this[Is](t,As.readdirSync(t.absolute))}[Ts](t){let e=t.entry,n=this.zip;if(t.readdir&&t.readdir.forEach(r=>{let i=t.path,s=i==="./"?"":i.replace(/\/*$/,"/");this[vs](s+r)}),!e)throw new Error("Cannot pipe without source");n?e.on("data",r=>{n.write(r)}):e.on("data",r=>{super[Nu](r)})}},_y=(t,e)=>{let n=new tc(t),r=new Su(t.file,{mode:t.mode||438});n.pipe(r),Lu(n,e)},Ey=(t,e)=>{let n=new Fs(t),r=new Cs(t.file,{mode:t.mode||438});n.pipe(r);let i=new Promise((s,o)=>{r.on("error",o),r.on("close",s),n.on("error",o)});return Fu(n,e).catch(s=>n.emit("error",s)),i},Lu=(t,e)=>{e.forEach(n=>{n.charAt(0)==="@"?Xn({file:vu.resolve(t.cwd,n.slice(1)),sync:!0,noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n)}),t.end()},Fu=async(t,e)=>{for(let n of e)n.charAt(0)==="@"?await Xn({file:vu.resolve(String(t.cwd),n.slice(1)),noResume:!0,onReadEntry:r=>{t.add(r)}}):t.add(n);t.end()},Sy=(t,e)=>{let n=new tc(t);return Lu(n,e),n},vy=(t,e)=>{let n=new Fs(t);return Fu(n,e).catch(r=>n.emit("error",r)),n},uk=ti(_y,Ey,Sy,vy,(t,e)=>{if(!e?.length)throw new TypeError("no paths specified to add to archive")}),Ty=process.env.__FAKE_PLATFORM__||process.platform,zu=Ty==="win32",{O_CREAT:$u,O_NOFOLLOW:cu,O_TRUNC:Gu,O_WRONLY:Hu}=Uu.constants,ju=Number(process.env.__FAKE_FS_O_FILENAME__)||Uu.constants.UV_FS_O_FILEMAP||0,Ry=zu&&!!ju,ky=512*1024,by=ju|Gu|$u|Hu,lu=!zu&&typeof cu=="number"?cu|Gu|$u|Hu:null,Wu=lu!==null?()=>lu:Ry?t=>t<ky?by:"w":()=>"w",za=(t,e,n)=>{try{return Ms.lchownSync(t,e,n)}catch(r){if(r?.code!=="ENOENT")throw r}},Os=(t,e,n,r)=>{Ms.lchown(t,e,n,i=>{r(i&&i?.code!=="ENOENT"?i:null)})},Ay=(t,e,n,r,i)=>{if(e.isDirectory())qu(Jr.resolve(t,e.name),n,r,s=>{if(s)return i(s);let o=Jr.resolve(t,e.name);Os(o,n,r,i)});else{let s=Jr.resolve(t,e.name);Os(s,n,r,i)}},qu=(t,e,n,r)=>{Ms.readdir(t,{withFileTypes:!0},(i,s)=>{if(i){if(i.code==="ENOENT")return r();if(i.code!=="ENOTDIR"&&i.code!=="ENOTSUP")return r(i)}if(i||!s.length)return Os(t,e,n,r);let o=s.length,a=null,c=l=>{if(!a){if(l)return r(a=l);if(--o===0)return Os(t,e,n,r)}};for(let l of s)Ay(t,l,e,n,c)})},xy=(t,e,n,r)=>{e.isDirectory()&&Vu(Jr.resolve(t,e.name),n,r),za(Jr.resolve(t,e.name),n,r)},Vu=(t,e,n)=>{let r;try{r=Ms.readdirSync(t,{withFileTypes:!0})}catch(i){let s=i;if(s?.code==="ENOENT")return;if(s?.code==="ENOTDIR"||s?.code==="ENOTSUP")return za(t,e,n);throw s}for(let i of r)xy(t,i,e,n);return za(t,e,n)},Ju=class extends Error{path;code;syscall="chdir";constructor(t,e){super(`${e}: Cannot cd into '${t}'`),this.path=t,this.code=e}get name(){return"CwdError"}},Bs=class extends Error{path;symlink;syscall="symlink";code="TAR_SYMLINK_ERROR";constructor(t,e){super("TAR_SYMLINK_ERROR: Cannot extract through symbolic link"),this.symlink=t,this.path=e}get name(){return"SymlinkError"}},Py=(t,e)=>{De.stat(t,(n,r)=>{(n||!r.isDirectory())&&(n=new Ju(t,n?.code||"ENOTDIR")),e(n)})},Cy=(t,e,n)=>{t=N(t);let r=e.umask??18,i=e.mode|448,s=(i&r)!==0,o=e.uid,a=e.gid,c=typeof o=="number"&&typeof a=="number"&&(o!==e.processUid||a!==e.processGid),l=e.preserve,d=e.unlink,p=N(e.cwd),m=(h,g)=>{h?n(h):g&&c?qu(g,o,a,w=>m(w)):s?De.chmod(t,i,n):n()};if(t===p)return Py(t,m);if(l)return Oy.mkdir(t,{mode:i,recursive:!0}).then(h=>m(null,h??void 0),m);let u=N(Ps.relative(p,t)).split("/");$a(p,u,i,d,p,void 0,m)},$a=(t,e,n,r,i,s,o)=>{if(e.length===0)return o(null,s);let a=e.shift(),c=N(Ps.resolve(t+"/"+a));De.mkdir(c,n,Zu(c,e,n,r,i,s,o))},Zu=(t,e,n,r,i,s,o)=>a=>{a?De.lstat(t,(c,l)=>{if(c)c.path=c.path&&N(c.path),o(c);else if(l.isDirectory())$a(t,e,n,r,i,s,o);else if(r)De.unlink(t,d=>{if(d)return o(d);De.mkdir(t,n,Zu(t,e,n,r,i,s,o))});else{if(l.isSymbolicLink())return o(new Bs(t,t+"/"+e.join("/")));o(a)}}):(s=s||t,$a(t,e,n,r,i,s,o))},Dy=t=>{let e=!1,n;try{e=De.statSync(t).isDirectory()}catch(r){n=r?.code}finally{if(!e)throw new Ju(t,n??"ENOTDIR")}},Ny=(t,e)=>{t=N(t);let n=e.umask??18,r=e.mode|448,i=(r&n)!==0,s=e.uid,o=e.gid,a=typeof s=="number"&&typeof o=="number"&&(s!==e.processUid||o!==e.processGid),c=e.preserve,l=e.unlink,d=N(e.cwd),p=h=>{h&&a&&Vu(h,s,o),i&&De.chmodSync(t,r)};if(t===d)return Dy(d),p();if(c)return p(De.mkdirSync(t,{mode:r,recursive:!0})??void 0);let m=N(Ps.relative(d,t)).split("/"),u;for(let h=m.shift(),g=d;h&&(g+="/"+h);h=m.shift()){g=N(Ps.resolve(g));try{De.mkdirSync(g,r),u=u||g}catch{let w=De.lstatSync(g);if(w.isDirectory())continue;if(l){De.unlinkSync(g),De.mkdirSync(g,r),u=u||g;continue}else if(w.isSymbolicLink())return new Bs(g,g+"/"+m.join("/"))}}return p(u)},va=Object.create(null),du=1e4,Gn=new Set,Ly=t=>{Gn.has(t)?Gn.delete(t):va[t]=t.normalize("NFD").toLocaleLowerCase("en").toLocaleUpperCase("en"),Gn.add(t);let e=va[t],n=Gn.size-du;if(n>du/10){for(let r of Gn)if(Gn.delete(r),delete va[r],--n<=0)break}return e},Fy=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,My=Fy==="win32",By=t=>t.split("/").slice(0,-1).reduce((e,n)=>{let r=e.at(-1);return r!==void 0&&(n=Ku(r,n)),e.push(n||"/"),e},[]),Uy=class{#e=new Map;#n=new Map;#r=new Set;reserve(t,e){t=My?["win32 parallelization disabled"]:t.map(r=>Vr(Ku(Ly(r))));let n=new Set(t.map(r=>By(r)).reduce((r,i)=>r.concat(i)));this.#n.set(e,{dirs:n,paths:t});for(let r of t){let i=this.#e.get(r);i?i.push(e):this.#e.set(r,[e])}for(let r of n){let i=this.#e.get(r);if(!i)this.#e.set(r,[new Set([e])]);else{let s=i.at(-1);s instanceof Set?s.add(e):i.push(new Set([e]))}}return this.#i(e)}#s(t){let e=this.#n.get(t);if(!e)throw new Error("function does not have any path reservations");return{paths:e.paths.map(n=>this.#e.get(n)),dirs:[...e.dirs].map(n=>this.#e.get(n))}}check(t){let{paths:e,dirs:n}=this.#s(t);return e.every(r=>r&&r[0]===t)&&n.every(r=>r&&r[0]instanceof Set&&r[0].has(t))}#i(t){return this.#r.has(t)||!this.check(t)?!1:(this.#r.add(t),t(()=>this.#t(t)),!0)}#t(t){if(!this.#r.has(t))return!1;let e=this.#n.get(t);if(!e)throw new Error("invalid reservation");let{paths:n,dirs:r}=e,i=new Set;for(let s of n){let o=this.#e.get(s);if(!o||o?.[0]!==t)continue;let a=o[1];if(!a){this.#e.delete(s);continue}if(o.shift(),typeof a=="function")i.add(a);else for(let c of a)i.add(c)}for(let s of r){let o=this.#e.get(s),a=o?.[0];if(!(!o||!(a instanceof Set)))if(a.size===1&&o.length===1){this.#e.delete(s);continue}else if(a.size===1){o.shift();let c=o[0];typeof c=="function"&&i.add(c)}else a.delete(t)}return this.#r.delete(t),i.forEach(s=>this.#i(s)),!0}},zy=()=>process.umask(),uu=Symbol("onEntry"),Ga=Symbol("checkFs"),fu=Symbol("checkFs2"),Ha=Symbol("isReusable"),Be=Symbol("makeFs"),ja=Symbol("file"),Wa=Symbol("directory"),ks=Symbol("link"),hu=Symbol("symlink"),pu=Symbol("hardlink"),Wr=Symbol("ensureNoSymlink"),gu=Symbol("unsupported"),mu=Symbol("checkPath"),Ia=Symbol("stripAbsolutePath"),Ut=Symbol("mkdir"),he=Symbol("onError"),gs=Symbol("pending"),wu=Symbol("pend"),Hn=Symbol("unpend"),Ta=Symbol("ended"),Ra=Symbol("maybeClose"),qa=Symbol("skip"),Zr=Symbol("doChown"),Kr=Symbol("uid"),Xr=Symbol("gid"),Yr=Symbol("checkedCwd"),$y=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,Qr=$y==="win32",Gy=1024,Hy=(t,e)=>{if(!Qr)return B.unlink(t,e);let n=t+".DELETE."+Bu(16).toString("hex");B.rename(t,n,r=>{if(r)return e(r);B.unlink(n,e)})},jy=t=>{if(!Qr)return B.unlinkSync(t);let e=t+".DELETE."+Bu(16).toString("hex");B.renameSync(t,e),B.unlinkSync(e)},yu=(t,e,n)=>t!==void 0&&t===t>>>0?t:e!==void 0&&e===e>>>0?e:n,nc=class extends ei{[Ta]=!1;[Yr]=!1;[gs]=0;reservations=new Uy;transform;writable=!0;readable=!1;uid;gid;setOwner;preserveOwner;processGid;processUid;maxDepth;forceChown;win32;newer;keep;noMtime;preservePaths;unlink;cwd;strip;processUmask;umask;dmode;fmode;chmod;constructor(t={}){if(t.ondone=()=>{this[Ta]=!0,this[Ra]()},super(t),this.transform=t.transform,this.chmod=!!t.chmod,typeof t.uid=="number"||typeof t.gid=="number"){if(typeof t.uid!="number"||typeof t.gid!="number")throw new TypeError("cannot set owner without number uid and gid");if(t.preserveOwner)throw new TypeError("cannot preserve owner in archive and also set owner explicitly");this.uid=t.uid,this.gid=t.gid,this.setOwner=!0}else this.uid=void 0,this.gid=void 0,this.setOwner=!1;this.preserveOwner=t.preserveOwner===void 0&&typeof t.uid!="number"?!!(process.getuid&&process.getuid()===0):!!t.preserveOwner,this.processUid=(this.preserveOwner||this.setOwner)&&process.getuid?process.getuid():void 0,this.processGid=(this.preserveOwner||this.setOwner)&&process.getgid?process.getgid():void 0,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:Gy,this.forceChown=t.forceChown===!0,this.win32=!!t.win32||Qr,this.newer=!!t.newer,this.keep=!!t.keep,this.noMtime=!!t.noMtime,this.preservePaths=!!t.preservePaths,this.unlink=!!t.unlink,this.cwd=N(ie.resolve(t.cwd||process.cwd())),this.strip=Number(t.strip)||0,this.processUmask=this.chmod?typeof t.processUmask=="number"?t.processUmask:zy():0,this.umask=typeof t.umask=="number"?t.umask:this.processUmask,this.dmode=t.dmode||511&~this.umask,this.fmode=t.fmode||438&~this.umask,this.on("entry",e=>this[uu](e))}warn(t,e,n={}){return(t==="TAR_BAD_ARCHIVE"||t==="TAR_ABORT")&&(n.recoverable=!1),super.warn(t,e,n)}[Ra](){this[Ta]&&this[gs]===0&&(this.emit("prefinish"),this.emit("finish"),this.emit("end"))}[Ia](t,e){let n=t[e],{type:r}=t;if(!n||this.preservePaths)return!0;let[i,s]=Ya(n),o=s.replaceAll(/\\/g,"/").split("/");if(o.includes("..")||Qr&&/^[a-z]:\.\.$/i.test(o[0]??"")){if(e==="path"||r==="Link")return this.warn("TAR_ENTRY_ERROR",`${e} contains '..'`,{entry:t,[e]:n}),!1;let a=ie.posix.dirname(t.path),c=ie.posix.normalize(ie.posix.join(a,o.join("/")));if(c.startsWith("../")||c==="..")return this.warn("TAR_ENTRY_ERROR",`${e} escapes extraction directory`,{entry:t,[e]:n}),!1}return i&&(t[e]=String(s),this.warn("TAR_ENTRY_INFO",`stripping ${i} from absolute ${e}`,{entry:t,[e]:n})),!0}[mu](t){let e=N(t.path),n=e.split("/");if(this.strip){if(n.length<this.strip)return!1;if(t.type==="Link"){let r=N(String(t.linkpath)).split("/");if(r.length>=this.strip)t.linkpath=r.slice(this.strip).join("/");else return!1}n.splice(0,this.strip),t.path=n.join("/")}if(isFinite(this.maxDepth)&&n.length>this.maxDepth)return this.warn("TAR_ENTRY_ERROR","path excessively deep",{entry:t,path:e,depth:n.length,maxDepth:this.maxDepth}),!1;if(!this[Ia](t,"path")||!this[Ia](t,"linkpath"))return!1;if(t.absolute=ie.isAbsolute(t.path)?N(ie.resolve(t.path)):N(ie.resolve(this.cwd,t.path)),!this.preservePaths&&typeof t.absolute=="string"&&t.absolute.indexOf(this.cwd+"/")!==0&&t.absolute!==this.cwd)return this.warn("TAR_ENTRY_ERROR","path escaped extraction target",{entry:t,path:N(t.path),resolvedPath:t.absolute,cwd:this.cwd}),!1;if(t.absolute===this.cwd&&t.type!=="Directory"&&t.type!=="GNUDumpDir")return!1;if(this.win32){let{root:r}=ie.win32.parse(String(t.absolute));t.absolute=r+Yd(String(t.absolute).slice(r.length));let{root:i}=ie.win32.parse(t.path);t.path=i+Yd(t.path.slice(i.length))}return!0}[uu](t){if(!this[mu](t))return t.resume();switch(Iy.equal(typeof t.absolute,"string"),t.type){case"Directory":case"GNUDumpDir":t.mode&&(t.mode=t.mode|448);case"File":case"OldFile":case"ContiguousFile":case"Link":case"SymbolicLink":return this[Ga](t);default:return this[gu](t)}}[he](t,e){t.name==="CwdError"?this.emit("error",t):(this.warn("TAR_ENTRY_ERROR",t,{entry:e}),this[Hn](),e.resume())}[Ut](t,e,n){Cy(N(t),{uid:this.uid,gid:this.gid,processUid:this.processUid,processGid:this.processGid,umask:this.processUmask,preserve:this.preservePaths,unlink:this.unlink,cwd:this.cwd,mode:e},n)}[Zr](t){return this.forceChown||this.preserveOwner&&(typeof t.uid=="number"&&t.uid!==this.processUid||typeof t.gid=="number"&&t.gid!==this.processGid)||typeof this.uid=="number"&&this.uid!==this.processUid||typeof this.gid=="number"&&this.gid!==this.processGid}[Kr](t){return yu(this.uid,t.uid,this.processUid)}[Xr](t){return yu(this.gid,t.gid,this.processGid)}[ja](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.fmode,r=new Cs(String(t.absolute),{flags:Wu(t.size),mode:n,autoClose:!1});r.on("error",a=>{r.fd&&B.close(r.fd,()=>{}),r.write=()=>!0,this[he](a,t),e()});let i=1,s=a=>{if(a){r.fd&&B.close(r.fd,()=>{}),this[he](a,t),e();return}--i===0&&r.fd!==void 0&&B.close(r.fd,c=>{c?this[he](c,t):this[Hn](),e()})};r.on("finish",()=>{let a=String(t.absolute),c=r.fd;if(typeof c=="number"&&t.mtime&&!this.noMtime){i++;let l=t.atime||new Date,d=t.mtime;B.futimes(c,l,d,p=>p?B.utimes(a,l,d,m=>s(m&&p)):s())}if(typeof c=="number"&&this[Zr](t)){i++;let l=this[Kr](t),d=this[Xr](t);typeof l=="number"&&typeof d=="number"&&B.fchown(c,l,d,p=>p?B.chown(a,l,d,m=>s(m&&p)):s())}s()});let o=this.transform&&this.transform(t)||t;o!==t&&(o.on("error",a=>{this[he](a,t),e()}),t.pipe(o)),o.pipe(r)}[Wa](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.dmode;this[Ut](String(t.absolute),n,r=>{if(r){this[he](r,t),e();return}let i=1,s=()=>{--i===0&&(e(),this[Hn](),t.resume())};t.mtime&&!this.noMtime&&(i++,B.utimes(String(t.absolute),t.atime||new Date,t.mtime,s)),this[Zr](t)&&(i++,B.chown(String(t.absolute),Number(this[Kr](t)),Number(this[Xr](t)),s)),s()})}[gu](t){t.unsupported=!0,this.warn("TAR_ENTRY_UNSUPPORTED",`unsupported entry type: ${t.type}`,{entry:t}),t.resume()}[hu](t,e){let n=N(ie.relative(this.cwd,ie.resolve(ie.dirname(String(t.absolute)),String(t.linkpath)))).split("/");this[Wr](t,this.cwd,n,()=>this[ks](t,String(t.linkpath),"symlink",e),r=>{this[he](r,t),e()})}[pu](t,e){let n=N(ie.resolve(this.cwd,String(t.linkpath))),r=N(String(t.linkpath)).split("/");this[Wr](t,this.cwd,r,()=>this[ks](t,n,"link",e),i=>{this[he](i,t),e()})}[Wr](t,e,n,r,i){let s=n.shift();if(this.preservePaths||s===void 0)return r();let o=ie.resolve(e,s);B.lstat(o,(a,c)=>{if(a)return r();if(c?.isSymbolicLink())return i(new Bs(o,ie.resolve(o,n.join("/"))));this[Wr](t,o,n,r,i)})}[wu](){this[gs]++}[Hn](){this[gs]--,this[Ra]()}[qa](t){this[Hn](),t.resume()}[Ha](t,e){return t.type==="File"&&!this.unlink&&e.isFile()&&e.nlink<=1&&!Qr}[Ga](t){this[wu]();let e=[t.path];t.linkpath&&e.push(t.linkpath),this.reservations.reserve(e,n=>this[fu](t,n))}[fu](t,e){let n=o=>{e(o)},r=()=>{this[Ut](this.cwd,this.dmode,o=>{if(o){this[he](o,t),n();return}this[Yr]=!0,i()})},i=()=>{if(t.absolute!==this.cwd){let o=N(ie.dirname(String(t.absolute)));if(o!==this.cwd)return this[Ut](o,this.dmode,a=>{if(a){this[he](a,t),n();return}s()})}s()},s=()=>{B.lstat(String(t.absolute),(o,a)=>{if(a&&(this.keep||this.newer&&a.mtime>(t.mtime??a.mtime))){this[qa](t),n();return}if(o||this[Ha](t,a))return this[Be](null,t,n);if(a.isDirectory()){if(t.type==="Directory"){let c=this.chmod&&t.mode&&(a.mode&4095)!==t.mode,l=d=>this[Be](d??null,t,n);return c?B.chmod(String(t.absolute),Number(t.mode),l):l()}if(t.absolute!==this.cwd)return B.rmdir(String(t.absolute),c=>this[Be](c??null,t,n))}if(t.absolute===this.cwd)return this[Be](null,t,n);Hy(String(t.absolute),c=>this[Be](c??null,t,n))})};this[Yr]?i():r()}[Be](t,e,n){if(t){this[he](t,e),n();return}switch(e.type){case"File":case"OldFile":case"ContiguousFile":return this[ja](e,n);case"Link":return this[pu](e,n);case"SymbolicLink":return this[hu](e,n);case"Directory":case"GNUDumpDir":return this[Wa](e,n)}}[ks](t,e,n,r){B[n](e,String(t.absolute),i=>{i?this[he](i,t):(this[Hn](),t.resume()),r()})}},Hr=t=>{try{return[null,t()]}catch(e){return[e,null]}},Xu=class extends nc{sync=!0;[Be](t,e){return super[Be](t,e,()=>{})}[Ga](t){if(!this[Yr]){let i=this[Ut](this.cwd,this.dmode);if(i)return this[he](i,t);this[Yr]=!0}if(t.absolute!==this.cwd){let i=N(ie.dirname(String(t.absolute)));if(i!==this.cwd){let s=this[Ut](i,this.dmode);if(s)return this[he](s,t)}}let[e,n]=Hr(()=>B.lstatSync(String(t.absolute)));if(n&&(this.keep||this.newer&&n.mtime>(t.mtime??n.mtime)))return this[qa](t);if(e||this[Ha](t,n))return this[Be](null,t);if(n.isDirectory()){if(t.type==="Directory"){let s=this.chmod&&t.mode&&(n.mode&4095)!==t.mode,[o]=s?Hr(()=>{B.chmodSync(String(t.absolute),Number(t.mode))}):[];return this[Be](o,t)}let[i]=Hr(()=>B.rmdirSync(String(t.absolute)));this[Be](i,t)}let[r]=t.absolute===this.cwd?[]:Hr(()=>jy(String(t.absolute)));this[Be](r,t)}[ja](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.fmode,r=o=>{let a;try{B.closeSync(i)}catch(c){a=c}(o||a)&&this[he](o||a,t),e()},i;try{i=B.openSync(String(t.absolute),Wu(t.size),n)}catch(o){return r(o)}let s=this.transform&&this.transform(t)||t;s!==t&&(s.on("error",o=>this[he](o,t)),t.pipe(s)),s.on("data",o=>{try{B.writeSync(i,o,0,o.length)}catch(a){r(a)}}),s.on("end",()=>{let o=null;if(t.mtime&&!this.noMtime){let a=t.atime||new Date,c=t.mtime;try{B.futimesSync(i,a,c)}catch(l){try{B.utimesSync(String(t.absolute),a,c)}catch{o=l}}}if(this[Zr](t)){let a=this[Kr](t),c=this[Xr](t);try{B.fchownSync(i,Number(a),Number(c))}catch(l){try{B.chownSync(String(t.absolute),Number(a),Number(c))}catch{o=o||l}}}r(o)})}[Wa](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.dmode,r=this[Ut](String(t.absolute),n);if(r){this[he](r,t),e();return}if(t.mtime&&!this.noMtime)try{B.utimesSync(String(t.absolute),t.atime||new Date,t.mtime)}catch{}if(this[Zr](t))try{B.chownSync(String(t.absolute),Number(this[Kr](t)),Number(this[Xr](t)))}catch{}e(),t.resume()}[Ut](t,e){try{return Ny(N(t),{uid:this.uid,gid:this.gid,processUid:this.processUid,processGid:this.processGid,umask:this.processUmask,preserve:this.preservePaths,unlink:this.unlink,cwd:this.cwd,mode:e})}catch(n){return n}}[Wr](t,e,n,r,i){if(this.preservePaths||n.length===0)return r();let s=e;for(let o of n){s=ie.resolve(s,o);let[a,c]=Hr(()=>B.lstatSync(s));if(a)return r();if(c.isSymbolicLink())return i(new Bs(s,ie.resolve(e,n.join("/"))))}r()}[ks](t,e,n,r){let i=`${n}Sync`;try{B[i](e,String(t.absolute)),r(),t.resume()}catch(s){return this[he](s,t)}}},Wy=t=>{let e=new Xu(t),n=t.file,r=Mu.statSync(n),i=t.maxReadSize||16*1024*1024;new uw(n,{readSize:i,size:r.size}).pipe(e)},qy=(t,e)=>{let n=new nc(t),r=t.maxReadSize||16*1024*1024,i=t.file;return new Promise((s,o)=>{n.on("error",o),n.on("close",s),Mu.stat(i,(a,c)=>{if(a)o(a);else{let l=new Ja(i,{readSize:r,size:c.size});l.on("error",o),l.pipe(n)}})})},Yu=ti(Wy,qy,t=>new Xu(t),t=>new nc(t),(t,e)=>{e?.length&&Ou(t,e)}),Vy=(t,e)=>{let n=new tc(t),r=!0,i,s;try{try{i=Ce.openSync(t.file,"r+")}catch(c){if(c?.code==="ENOENT")i=Ce.openSync(t.file,"w+");else throw c}let o=Ce.fstatSync(i),a=Buffer.alloc(512);e:for(s=0;s<o.size;s+=512){for(let d=0,p=0;d<512;d+=p){if(p=Ce.readSync(i,a,d,a.length-d,s+d),s===0&&a[0]===31&&a[1]===139)throw new Error("cannot append to compressed archives");if(!p)break e}let c=new gn(a);if(!c.cksumValid)break;let l=512*Math.ceil((c.size||0)/512);if(s+l+512>o.size)break;s+=l,t.mtimeCache&&c.mtime&&t.mtimeCache.set(String(c.path),c.mtime)}r=!1,Jy(t,n,s,i,e)}finally{if(r)try{Ce.closeSync(i)}catch{}}},Jy=(t,e,n,r,i)=>{let s=new Su(t.file,{fd:r,start:n});e.pipe(s),Ky(e,i)},Zy=(t,e)=>{e=Array.from(e);let n=new Fs(t),r=(i,s,o)=>{let a=(m,u)=>{m?Ce.close(i,h=>o(m)):o(null,u)},c=0;if(s===0)return a(null,0);let l=0,d=Buffer.alloc(512),p=(m,u)=>{if(m||u===void 0)return a(m);if(l+=u,l<512&&u)return Ce.read(i,d,l,d.length-l,c+l,p);if(c===0&&d[0]===31&&d[1]===139)return a(new Error("cannot append to compressed archives"));if(l<512)return a(null,c);let h=new gn(d);if(!h.cksumValid)return a(null,c);let g=512*Math.ceil((h.size??0)/512);if(c+g+512>s||(c+=g+512,c>=s))return a(null,c);t.mtimeCache&&h.mtime&&t.mtimeCache.set(String(h.path),h.mtime),l=0,Ce.read(i,d,0,512,c,p)};Ce.read(i,d,0,512,c,p)};return new Promise((i,s)=>{n.on("error",s);let o="r+",a=(c,l)=>{if(c&&c.code==="ENOENT"&&o==="r+")return o="w+",Ce.open(t.file,o,a);if(c||!l)return s(c);Ce.fstat(l,(d,p)=>{if(d)return Ce.close(l,()=>s(d));r(l,p.size,(m,u)=>{if(m)return s(m);let h=new Cs(t.file,{fd:l,start:u});n.pipe(h),h.on("error",s),h.on("close",i),Xy(n,e)})})};Ce.open(t.file,o,a)})},Ky=(t,e)=>{e.forEach(n=>{n.charAt(0)==="@"?Xn({file:Qu.resolve(t.cwd,n.slice(1)),sync:!0,noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n)}),t.end()},Xy=async(t,e)=>{for(let n of e)n.charAt(0)==="@"?await Xn({file:Qu.resolve(String(t.cwd),n.slice(1)),noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n);t.end()},jr=ti(Vy,Zy,()=>{throw new TypeError("file is required")},()=>{throw new TypeError("file is required")},(t,e)=>{if(!_w(t))throw new TypeError("file is required");if(t.gzip||t.brotli||t.zstd||t.file.endsWith(".br")||t.file.endsWith(".tbr"))throw new TypeError("cannot append to compressed archives");if(!e?.length)throw new TypeError("no paths specified to add/replace")}),kk=ti(jr.syncFile,jr.asyncFile,jr.syncNoFile,jr.asyncNoFile,(t,e=[])=>{jr.validate?.(t,e),Yy(t)}),Yy=t=>{let e=t.filter;t.mtimeCache||(t.mtimeCache=new Map),t.filter=e?(n,r)=>e(n,r)&&!((t.mtimeCache?.get(n)??r.mtime??0)>(r.mtime??0)):(n,r)=>!((t.mtimeCache?.get(n)??r.mtime??0)>(r.mtime??0))};At();var Ze={PAIR:"_agent/pair",CREATE:"_agent/create",HEALTH:"_agent/health",LIST_SKILLS:"_agent/listSkills",ADD_SKILLS:"_agent/addSkills",REMOVE_SKILLS:"_agent/removeSkills",GET_FILE_TREE:"_agent/getFileTree",GET_FILE_CONTENT:"_agent/getFileContent",DETAIL:"_agent/detail",UPDATE:"_agent/update",DISCONNECT:"_agent/disconnect",SWITCH_MODEL:"_agent/switchModel",GEN_MODEL_TOKEN:"_agent/genModelToken",RESET:"_agent/reset",REPAIR:"_agent/repair",DELETE:"_agent/delete"};function ni(t){return t?.cozeDeployType==="cloud"?"cloud":"local"}function ef(t){let e=t?.cozeAccountId?.trim();if(!(!e||e==="0"))return e}function rc(t){let e=t?.cozeGroupId?.trim();if(!(!e||e==="0"))return e}function tf(t){let{_meta:e,...n}=t;return{stripped:n,meta:e}}function Yn(t){if(!t?.cozeAgentId)throw new Error("missing _meta.cozeAgentId");return t.cozeAgentId}Te();L();le();Te();function vt(t,e){if(ni(t)!=="cloud")throw new _("OPERATION_NOT_ALLOWED_FOR_LOCAL",`${e} is not allowed for local agent`)}function Us(t){return t.startsWith("http://")||t.startsWith("https://")}function zs(t){return t.endsWith("/")?t.slice(0,-1):t}Te();L();var $s="1008033",nf="1289";var rf="pbbp2",sf="https://www.coze.cn",of="/api/coze_claw/resource/get_frontier_key",e_="https://www.coze.cn",t_="wss://frontier.coze.cn";function Gs(t){return t??process.env.COZE_BRIDGE_HANDSHAKE_URL??e_}function af(t){return t??process.env.COZE_BRIDGE_FRONTIER_URL??t_}function Qn(t){let e={},n=t?.ttEnv??process.env.COZE_BRIDGE_TT_ENV,r=t?.usePpe??process.env.COZE_BRIDGE_USE_PPE;return n&&(e["x-tt-env"]=n),r&&(e["x-use-ppe"]=r),e}function ii(t){return t?t.startsWith("boe_")?{ttEnv:t}:{ttEnv:t,usePpe:"1"}:{}}var ri=b("handshake");async function ic(t){let e=Gs(t.endpoint),n=t.timeoutMs??1e4,r=`${zs(e)}${of}?aid=${encodeURIComponent($s)}`,i={Authorization:`Bearer ${t.privatecode}`,Accept:"application/json",...Qn(t.ppeOverride)},s=new AbortController,o=setTimeout(()=>s.abort(),n);ri.info("frontier key handshake",{base:e});try{let a=await fetch(r,{method:"GET",headers:i,signal:s.signal}),c=a.headers.get("x-tt-logid")??"",l=a.headers.get("x-tt-trace-id")??"";if(!a.ok){let h=await a.text().catch(()=>"");throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake HTTP ${a.status} logid=${c}: ${h.slice(0,200)}`)}let d=await a.json();if(d.code!==void 0&&d.code!==0)throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake code=${d.code} msg=${d.msg??"-"} logid=${c}`);let p=d.data??{},m=typeof p.access_key=="string"&&p.access_key||typeof p.accessKey=="string"&&p.accessKey||void 0,u=typeof p.device_id=="string"&&p.device_id||typeof p.deviceId=="string"&&p.deviceId||void 0;if(!m||!u){let h=JSON.stringify(d).slice(0,500);throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake response missing access_key/device_id (also tried camelCase) logid=${c}: ${h}`)}return ri.info("handshake ok",{remoteDeviceId:u,logid:c,traceId:l}),{accessKey:m,deviceId:u}}catch(a){if(a instanceof _)throw ri.error("handshake failed (bridge error)",{base:e,message:a.message,code:a.code}),a;if(a.name==="AbortError")throw ri.warn("handshake timeout",{base:e,timeoutMs:n}),new _("UPSTREAM_HANDSHAKE_FAILED",`handshake timeout (${n}ms)`,{cause:a});let c=a.cause;throw ri.error("handshake error",{base:e,message:a instanceof Error?a.message:String(a),errno:c?.code,syscall:c?.syscall,cause:String(a).slice(0,300)}),new _("UPSTREAM_HANDSHAKE_FAILED",String(a),{cause:a})}finally{clearTimeout(o)}}var sc=process.env.COZE_BRIDGE_LLM_GATEWAY_URL?.trim()||"https://llm-gateway.coze.cn",Ke="auto",cf=2e5;function lf(t){return{model:oc(t.model)??Ke,...t.modelToken?{modelToken:t.modelToken}:{}}}function df(t){return!t||t===Ke}var n_=new Set(["auto","\u81EA\u52A8"]);function oc(t){let e=t?.trim();if(e)return n_.has(e.toLowerCase())?Ke:e}function uf(t){let e={};if(t.modelToken){e.ANTHROPIC_BASE_URL=sc,e.ANTHROPIC_AUTH_TOKEN=t.modelToken;let n=t.model||Ke;e.ANTHROPIC_MODEL=n,e.ANTHROPIC_SMALL_FAST_MODEL=n,t.modelInfo?.contextWindow&&(e.CLAUDE_CODE_MAX_CONTEXT_TOKENS=String(t.modelInfo.contextWindow))}else df(t.model)||(e.ANTHROPIC_MODEL=t.model);return e}function ff(t){let e=[];if(t.modelToken?e.push("-c",`model="${t.model||Ke}"`):df(t.model)||e.push("-c",`model="${t.model}"`),t.modelToken){e.push("-c",'model_providers.coze.name="coze"'),e.push("-c",`model_providers.coze.base_url="${sc}/v1"`),e.push("-c",'model_providers.coze.env_key="OPENAI_API_KEY"'),e.push("-c",'model_providers.coze.wire_api="responses"'),e.push("-c","model_providers.coze.requires_openai_auth=false"),e.push("-c","model_providers.coze.supports_websockets=false"),e.push("-c",'model_provider="coze"');let n=t.modelInfo?.contextWindow??cf;e.push("-c",`model_context_window=${n}`)}return e}function hf(t){return t.modelToken?{OPENAI_API_KEY:t.modelToken}:{}}function ac(t,e){let{ttEnv:n,usePpe:r}=ii(t),i={};return n&&(i["x-tt-env"]=n),r&&(i["x-use-ppe"]=r),e&&(i["x-mock-scenario"]=e),i}function pf(t,e,n){if(!t.modelToken)return{};let r=ac(e,n);return Object.keys(r).length===0?{}:{ANTHROPIC_CUSTOM_HEADERS:Object.entries(r).map(([s,o])=>`${s}:${o}`).join(`
91
- `)}}function cc(t){return`coze-session-${t.replace(/[^A-Za-z0-9_-]+/g,"-")}`}function gf(t,e,n){if(!t.modelToken)return null;let r=t.model||Ke,i=ac(e,n),s=["text"];t.modelInfo?.capabilities?.image===!0&&s.push("image");let o={baseUrl:`${sc}/v1`,api:"openai-completions",apiKey:t.modelToken,models:[{id:r,name:r,reasoning:!1,input:s,cost:{input:0,output:0,cacheRead:0,cacheWrite:0},contextWindow:t.modelInfo?.contextWindow??cf,maxTokens:8192,api:"openai-completions"}]};return Object.keys(i).length>0&&(o.headers=i),o}function mf(t,e,n){if(!t.modelToken)return[];let r=ac(e,n),i=[];for(let[s,o]of Object.entries(r))i.push("-c",`model_providers.coze.http_headers.${s}="${o}"`);return i}var se=b("agent-handlers"),wf=5*1024*1024,c_=1,l_=6,d_=new Set(["node_modules",".git",".coze","dist","build",".next"]),Hs=class{constructor(e){this.opts=e}opts;async listSkills(e){vt(e._meta,"_agent/listSkills");let n=Yn(e._meta),r=await this.loadAgentCfg(n),i=r?.workspace??be(n).workspace,s=r?.skills??[],o=[];for(let a of s){let c=at(i,a.relPath,"SKILL.md");await s_(c).then(d=>d.isFile()).catch(()=>!1)&&o.push(g_(a))}return{skills:o}}async addSkills(e){vt(e._meta,"_agent/addSkills");let n=Yn(e._meta),r=await this.requireAgentCfg(n),i=e.skills??[],s=[...r.skills??[]],o=new Map(s.map((c,l)=>[c.skillId,l])),a=[];for(let c of i){let l=await gc({agentId:n,workspace:r.workspace,framework:r.framework,skill:c});mc(s,o,l),a.push(c)}return await Ji(n,s),this.reloadAgentSessions(n,"skills-added"),{installedSkills:a}}async removeSkills(e){vt(e._meta,"_agent/removeSkills");let n=Yn(e._meta),r=await this.requireAgentCfg(n),i=new Set(e.skillIds??[]),s=r.skills??[],o=[];for(let a of s){if(!i.has(a.skillId)){o.push(a);continue}let c=at(r.workspace,a.relPath);await i_(c,{recursive:!0,force:!0}),se.info("skill removed",{agentId:n,skillId:a.skillId,relPath:a.relPath})}return await Ji(n,o),this.reloadAgentSessions(n,"skills-removed"),{ok:!0}}reloadAgentSessionsPublic(e,n){this.reloadAgentSessions(e,n)}reloadAgentSessions(e,n){let r=this.opts.agents.get(e);if(r)for(let[i,s]of r.sessions){if(!s.downstream)continue;let o=s.acpSessionId;if(o&&r.activeTriggers.has(o)||this.isRuntimePendingPermission(s)){s.reloadAfterTurn=!0,se.info("downstream busy, scheduling reload after turn",{reason:n,agentId:e,framework:r.framework,cloudId:i,acpId:o});continue}let c=s.downstream;s.downstream=void 0,se.info("killing downstream for workspace reload (idle)",{reason:n,agentId:e,framework:r.framework,cloudId:i,acpId:o}),c.stop(n).catch(l=>se.warn("downstream stop failed during reload (ignored)",{reason:n,agentId:e,cloudId:i,err:String(l)}))}}isRuntimePendingPermission(e){let n=this.opts.isRuntimePendingPermission;return!n||!e.downstream?!1:n(e.downstream)}async updateAgent(e){if(!e.cozeIdentity?.trim())return se.info("_agent/update: empty cozeIdentity, noop",{agentId:e.agentId}),{ok:!0};let n=e.agentId,r=await me(n);if(!r)throw new _("AGENT_NOT_FOUND",`agent not found: ${n}`);if(r.cozeIdentity===e.cozeIdentity)return se.info("_agent/update: cozeIdentity unchanged, noop",{agentId:n}),{ok:!0};try{await Ln(r.workspace,r.framework,e.cozeIdentity)}catch(i){throw se.error("_agent/update: writeInstructionFile failed, aborting update",{agentId:n,framework:r.framework,workspace:r.workspace,err:String(i)}),new _("AGENT_PROTOCOL_ERROR",`failed to write instruction file for agent ${n}: ${String(i)}`,{cause:i})}return r.cozeIdentity=e.cozeIdentity,await Ae(r),se.info("_agent/update: cozeIdentity rewritten",{agentId:n,framework:r.framework}),this.reloadAgentSessions(n,"identity-changed"),{ok:!0}}async disconnectAgent(e){let n=e.agentId;if(!n)throw new _("IPC_BAD_REQUEST","_agent/disconnect: missing agentId");let r=await me(n);return r?(r.disconnectedAt=Date.now(),r.disconnectReason=e.reason??"",await Ae(r),se.info("agent disconnected",{agentId:n,reason:e.reason??"",force:e.force??!1}),this.opts.disposeAndMarkDisconnected&&await this.opts.disposeAndMarkDisconnected(n,e.reason??"disconnect"),{ok:!0}):(se.warn("_agent/disconnect: agent not found, ignoring",{agentId:n}),{ok:!0})}async switchModel(e){if(vt(e._meta,"_agent/switchModel"),!e.agentId)throw new _("IPC_BAD_REQUEST","_agent/switchModel: missing agentId");let n=oc(e.model)??Ke,r=await me(e.agentId);if(!r)throw new _("AGENT_NOT_FOUND",`agent not found: ${e.agentId}`);r.model=n,e.modelInfo&&(r.modelInfo=e.modelInfo),await Ae(r),se.info("_agent/switchModel: model persisted",{agentId:e.agentId,model:n,reason:e.reason??""});let i=this.opts.agents.get(e.agentId);if(!i)return se.info("_agent/switchModel: agent not running, config persisted only",{agentId:e.agentId}),{ok:!0};i.model=n,e.modelInfo&&i.setModelInfo(e.modelInfo),this.opts.cleanupOpenclawProviders&&await this.opts.cleanupOpenclawProviders(i).catch(o=>se.warn("cleanupOpenclawProviders before switchModel failed (ignored)",{agentId:e.agentId,err:String(o)}));let s=[];for(let[o,a]of i.allSessionQueues())s.push(a.enqueue(async()=>{let c=i.sessions.get(o);c?.downstream&&(await c.downstream.stop(`switchModel: ${n}`).catch(()=>{}),c.downstream=void 0)}));return await Promise.all(s),se.info("_agent/switchModel: all session runtimes killed, next prompt will respawn",{agentId:e.agentId,model:n,cloudSessions:s.length}),{ok:!0}}async resetAgent(e){if(vt(e._meta,Ze.RESET),!e.agentId)throw new _("IPC_BAD_REQUEST",`${Ze.RESET}: missing agentId`);return await this.clearSessionMappings(e.agentId,Ze.RESET),await this.runDetailSync(e.agentId,Ze.RESET,e.reason),{ok:!0}}async clearSessionMappings(e,n){let r=this.opts.agents.get(e);if(!r){await this.clearPersistedAcpSessionIds(e),se.info("reset: agent not in memory, cleared persisted acpSessionIds only",{agentId:e});return}await r.killAllRuntimes(n);for(let s of r.sessions.values())s.acpSessionId=void 0,s.replySeq=0,s.loadingSession=!1,s.spawnFailCount=void 0,s.spawnFailedAt=void 0;let i=new Map;for(let[s,o]of r.sessions)i.set(s,{modelToken:o.modelToken,tokenGeneratedAt:o.tokenGeneratedAt});await xr(e,i)}async clearPersistedAcpSessionIds(e){let n=await me(e).catch(()=>null);if(!n?.sessions)return;let r=!1;for(let i of Object.values(n.sessions))i.acpSessionId&&(i.acpSessionId=void 0,r=!0);r&&await Ae(n)}async repairAgent(e){if(vt(e._meta,Ze.REPAIR),!e.agentId)throw new _("IPC_BAD_REQUEST",`${Ze.REPAIR}: missing agentId`);let n=await this.loadAgentCfg(e.agentId);if(n&&n.framework!=="openclaw")throw new _("IPC_BAD_REQUEST",`${Ze.REPAIR} only allowed for openclaw, got ${n.framework}`);if(n&&this.opts.openclawRepair)try{await this.opts.openclawRepair(e.agentId,n.workspace)}catch(r){se.warn("openclaw repair (delete+add) failed (ignored)",{agentId:e.agentId,reason:e.reason,err:String(r)})}return await this.runDetailSync(e.agentId,Ze.REPAIR,e.reason),{ok:!0}}async runDetailSync(e,n,r){if(!this.opts.detailSyncer){se.warn("detailSyncer not wired, skipping sync",{method:n,agentId:e});return}try{await this.opts.detailSyncer(e)}catch(i){se.warn("detail sync failed (ignored)",{method:n,agentId:e,reason:r,err:String(i)})}}async getFileTree(e){vt(e._meta,"_agent/getFileTree");let n=e._meta,r=Yn(n),i=await this.resolveWorkspace(r),s=e.filePath??"",o=this.safeJoin(i,s),a=await lc(o).catch(()=>null);if(!a)throw new _("IPC_BAD_REQUEST",`path not found: ${s}`);if(a.isSymbolicLink())throw new _("IPC_BAD_REQUEST",`symlink not allowed: ${s}`);if(!await Ar(o,i))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${s}`);let c=k_(e.depth);return a.isDirectory()?{tree:await R_(i,o,s,c)}:{tree:[{name:b_(s),path:Tf(s||"."),isDir:!1,size:a.size,modifiedAt:Math.floor(a.mtimeMs)}]}}async getFileContent(e){vt(e._meta,"_agent/getFileContent");let n=Yn(e._meta),r=await this.resolveWorkspace(n);if(!e.filePath)throw new _("IPC_BAD_REQUEST","filePath required");let i=this.safeJoin(r,e.filePath),s=await lc(i).catch(()=>null);if(!s||!s.isFile())throw new _("IPC_BAD_REQUEST",`not a file: ${e.filePath}`);if(s.isSymbolicLink())throw new _("IPC_BAD_REQUEST",`symlink not allowed: ${e.filePath}`);if(!await Ar(i,r))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${e.filePath}`);if(s.size>wf)throw new _("IPC_BAD_REQUEST",`file too large: ${s.size} bytes (max ${wf})`);let o=await yf(i);return o.includes(0)?{content:o.toString("base64"),encoding:"base64",size:s.size}:{content:o.toString("utf8"),encoding:"utf-8",size:s.size}}async resolveWorkspace(e){let n=this.opts.agents.get(e);return n?n.workspace:(await me(e).catch(()=>null))?.workspace??be(e).workspace}safeJoin(e,n){let r=fc(e,n||"."),i=pc(e,r);if(i.startsWith("..")||i===".."||i.startsWith(`..${_f}`))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${n}`);return r}loadAgentCfg(e){return me(e)}async requireAgentCfg(e){let n=await this.loadAgentCfg(e);if(!n)throw new _("AGENT_NOT_FOUND",`no config for agent: ${e}`);return n}};function u_(t){let e=t.trim().replace(/[\x00-\x1f<>:"|?*/\\]+/g,"-").replace(/^[\s.-]+|[\s.-]+$/g,"").slice(0,64);if(!e||e==="."||e==="..")throw new _("IPC_BAD_REQUEST",`invalid skill name: ${t}`);if(/^(con|prn|aux|nul|com[1-9]|lpt[1-9])$/i.test(e))throw new _("IPC_BAD_REQUEST",`reserved windows filename: ${t}`);return e}function f_(t){return t==="claude-code"?at(".claude","skills"):at(".agents","skills")}var h_=3e4,p_=50*1024*1024,er=3e4;async function gc(t){let{agentId:e,workspace:n,framework:r,skill:i}=t;if(!i.skillName)throw new _("IPC_BAD_REQUEST","skill missing skillName");let s=typeof i.content=="string"&&i.content.length>0,o=typeof i.downloadUrl=="string"&&i.downloadUrl.length>0;if(!s&&!o)throw new _("IPC_BAD_REQUEST",`skill ${i.skillId} missing both content and downloadUrl`);let a=u_(i.skillName),c=f_(r),l=at(c,a),d=at(n,l);if(await dc(d,{recursive:!0}),s){let m=Buffer.from(i.content,"utf8");si(m.length),await uc(at(d,"SKILL.md"),m,"utf8")}else{let m=await m_(i.downloadUrl);y_(m)?await v_(m,d):__(m)?await E_(m,d):await uc(at(d,"SKILL.md"),m.toString("utf8"),"utf8")}let p={skillId:i.skillId,skillName:i.skillName,relPath:l,installedAt:Date.now(),...i.description?{description:i.description}:{},...i.icon?{icon:i.icon}:{},...i.version?{version:i.version}:{},...i.downloadUrl?{downloadUrl:i.downloadUrl}:{},...i.config?{config:i.config}:{},...i.builtin?{builtin:i.builtin}:{}};return se.info("skill installed",{agentId:e,skillId:i.skillId,skillName:i.skillName,relPath:l,source:s?"content":"downloadUrl"}),p}function mc(t,e,n){let r=e.get(n.skillId);if(r!==void 0){t[r]=n;return}e.set(n.skillId,t.length),t.push(n)}function g_(t){return{skillId:t.skillId,skillName:t.skillName,...t.description?{description:t.description}:{},...t.icon?{icon:t.icon}:{},...t.version?{version:t.version}:{},...t.config?{config:t.config}:{},...t.builtin?{builtin:t.builtin}:{}}}async function m_(t){if(!t)throw new _("IPC_BAD_REQUEST","skill missing downloadUrl");if(t.startsWith("data:")){let e=Math.floor(t.length*3/4);si(e);let n=w_(t);return si(n.length),n}if(t.startsWith("file:")){let e=new URL(t).pathname,n=await yf(e);return si(n.length),n}if(Us(t)){let e=new AbortController,n=setTimeout(()=>e.abort(),h_);try{let r=await fetch(t,{signal:e.signal});if(!r.ok)throw new _("IPC_BAD_REQUEST",`fetch skill failed HTTP ${r.status} ${t}`);let i=await r.arrayBuffer();return si(i.byteLength),Buffer.from(i)}finally{clearTimeout(n)}}throw new _("IPC_BAD_REQUEST",`unsupported downloadUrl scheme (\u8981 https/data/file): ${t.slice(0,80)}`)}function si(t){if(t>p_)throw new _("IPC_BAD_REQUEST",`skill too large: ${t} bytes`)}function w_(t){let e=/^data:([^,;]*)(;base64)?,(.*)$/s.exec(t);if(!e)throw new _("IPC_BAD_REQUEST","bad data URL");let n=!!e[2],r=e[3]??"";return n?Buffer.from(r,"base64"):Buffer.from(decodeURIComponent(r),"utf8")}function y_(t){return t.length>=2&&t[0]===31&&t[1]===139}function __(t){if(t.length<4||t[0]!==80||t[1]!==75)return!1;let e=t[2],n=t[3];return e===3&&n===4||e===5&&n===6}function hc(t){return t==="__MACOSX"||t.startsWith("__MACOSX/")}async function E_(t,e){let n,r;try{n=new vf.default(t),r=n.getEntries()}catch(o){throw new _("IPC_BAD_REQUEST",`zip parse failed: ${o.message}`,{cause:o})}for(let o of r){let a=o.entryName;if(!a||hc(a))continue;if(a.startsWith("/")||/^[A-Za-z]:[\\/]/.test(a))throw new _("IPC_BAD_REQUEST",`zip entry absolute path: ${a}`);if(a.split(/[/\\]/).some(l=>l===".."))throw new _("IPC_BAD_REQUEST",`zip entry contains '..' (traversal): ${a}`);let c=o.header.attr>>>16&61440;if(c!==0&&c!==32768&&c!==16384)throw new _("IPC_BAD_REQUEST",`zip entry kind 0x${c.toString(16)} not allowed (symlink/hardlink/special): ${a}`)}let i=S_(r),s=fc(e);for(let o of r){if(hc(o.entryName))continue;let a=o.entryName;if(i&&a.startsWith(i)&&(a=a.slice(i.length)),!a)continue;let c=fc(e,a),l=pc(s,c);if(l.startsWith("..")||l==="..")throw new _("IPC_BAD_REQUEST",`zip entry escapes destDir: ${a}`);if(o.isDirectory){await dc(c,{recursive:!0});continue}await dc(o_(c),{recursive:!0});let d;try{d=o.getData()}catch(p){throw new _("IPC_BAD_REQUEST",`zip entry getData failed (${o.entryName}): ${p.message}`,{cause:p})}await uc(c,d)}}function S_(t){let e;for(let n of t){let r=n.entryName;if(!r||hc(r))continue;let i=r.indexOf("/");if(i<=0)return;let s=r.slice(0,i+1);if(e===void 0)e=s;else if(e!==s)return}return e}async function v_(t,e){await I_(t);let n=Yu({cwd:e,strip:1}),r=!1,i=setTimeout(()=>{r=!0,n.destroy(new _("IPC_BAD_REQUEST",`tar extract timeout (${er}ms)`))},er);try{await Sf(Ef.from(t),n)}catch(s){throw s instanceof _?s:r?new _("IPC_BAD_REQUEST",`tar extract timeout (${er}ms)`):new _("IPC_BAD_REQUEST",`tar extract failed: ${s.message??String(s)}`,{cause:s})}finally{clearTimeout(i)}}async function I_(t){let e=[],n=Xn({onReadEntry:s=>{let o=s.path,a=s.type;if(a!=="File"&&a!=="Directory"){e.push(`tar entry kind '${a}' not allowed (symlink/hardlink/special): ${o.slice(0,100)}`);return}if(o.startsWith("/")||o.startsWith("\\")||/^[a-zA-Z]:[\\/]/.test(o)){e.push(`tar entry absolute path: ${o}`);return}o.split(/[/\\]/).some(l=>l==="..")&&e.push(`tar entry contains '..': ${o}`)}}),r=!1,i=setTimeout(()=>{r=!0,n.destroy(new _("IPC_BAD_REQUEST",`tar list timeout (${er}ms)`))},er);try{await Sf(Ef.from(t),n)}catch(s){throw r?new _("IPC_BAD_REQUEST",`tar list timeout (${er}ms)`):new _("IPC_BAD_REQUEST",`tar list failed: ${s.message??String(s)}`,{cause:s})}finally{clearTimeout(i)}if(e.length>0)throw new _("IPC_BAD_REQUEST",e[0]??"tar entry validation failed")}var T_=5e3;async function R_(t,e,n,r){return If(t,e,n,r,{count:0})}async function If(t,e,n,r,i){if(r<=0)return[];let s;try{s=await r_(e,{withFileTypes:!0})}catch{return[]}let o=[];for(let a of s){if(d_.has(a.name)||a.isSymbolicLink())continue;if(i.count>=T_){o.push({name:"...",path:"...",isDir:!1,size:0,modifiedAt:0,hasMore:!0});break}let c=at(e,a.name),l=a_(at(n,a.name)),d=null;try{d=await lc(c)}catch{continue}if(d.isSymbolicLink())continue;i.count++;let p={name:a.name,path:Tf(pc(t,c)),isDir:d.isDirectory(),size:d.size,modifiedAt:Math.floor(d.mtimeMs)};d.isDirectory()&&r>1&&(p.children=await If(t,c,l,r-1,i)),o.push(p)}return o.sort((a,c)=>a.isDir!==c.isDir?a.isDir?-1:1:a.name.localeCompare(c.name)),o}function k_(t){return!t||t<=0?c_:Math.min(t,l_)}function b_(t){if(!t||t==="."||t==="/")return".";let e=t.split(/[/\\]/);return e[e.length-1]||"."}function Tf(t){return t.split(_f).join("/")}L();import{readFileSync as Fb}from"node:fs";import{dirname as Bb,join as Ub}from"node:path";import{fileURLToPath as $b}from"node:url";var tr="0.1.92";var Gt=b("agent-health-reporter"),A_=1e4,oi=class{constructor(e){this.opts=e;this.intervalMs=e.intervalMs??A_}opts;timer=null;inFlight=!1;unsubscribeRegister=null;intervalMs;start(){this.timer||(this.timer=setInterval(()=>{this.tick()},this.intervalMs),this.timer.unref?.(),this.unsubscribeRegister=this.opts.core.onAgentRegister(()=>{this.tick()}),Gt.info("heartbeat started",{intervalMs:this.intervalMs}),this.tick())}stop(){this.timer&&(clearInterval(this.timer),this.timer=null,this.unsubscribeRegister&&(this.unsubscribeRegister(),this.unsubscribeRegister=null),Gt.info("heartbeat stopped"))}async tick(){if(this.inFlight){Gt.debug("previous tick still in-flight, skip");return}let e=this.opts.getDeviceId();if(!e){Gt.debug("deviceId not available, skip tick (\u5C1A\u672A pair)");return}this.inFlight=!0;try{let n=[];for(let o of this.opts.core.agents.values()){let a=x_(o);if(!a)continue;let c={agentId:o.agentId,status:a};o.patToken&&(c.patToken=o.patToken),o.accountId&&(c.accountId=o.accountId),n.push(c)}if(n.length===0)return;let r={agents:n,bridgeVersion:tr,_meta:{cozeDeviceId:e}},i;try{i=await this.opts.core.sendRequest("_agent/health",r,5e3)}catch(o){Gt.warn("heartbeat batch send failed",{count:n.length,err:String(o)})}let s=i?.authFailures;if(s&&s.length>0&&(Gt.warn("heartbeat received authFailures from cloud",{count:s.length,agentIds:s.map(o=>o.agentId)}),this.opts.onAuthFailures))try{await this.opts.onAuthFailures(s)}catch(o){Gt.warn("onAuthFailures callback failed (ignored)",{err:String(o)})}}finally{this.inFlight=!1}if(this.opts.onTickEnd)try{await this.opts.onTickEnd()}catch(n){Gt.warn("onTickEnd hook failed",{err:String(n)})}}};function x_(t){return t.status==="error"?"error":t.activeTriggers.size>0?"busy":t.status==="ok"?"online":null}At();import{chmod as lE,mkdir as Ys,rm as dE,stat as uE,writeFile as fE}from"node:fs/promises";import{homedir as hE}from"node:os";import{join as jf}from"node:path";tn();import{spawnSync as M_}from"node:child_process";function ai(t,e,n){return n===void 0?{jsonrpc:"2.0",id:t,method:e}:{jsonrpc:"2.0",id:t,method:e,params:n}}function nr(t,e){return e===void 0?{jsonrpc:"2.0",method:t}:{jsonrpc:"2.0",method:t,params:e}}function rr(t,e){return{jsonrpc:"2.0",id:t,result:e}}function Ht(t,e){return{jsonrpc:"2.0",id:t,error:e}}Te();var js=class extends Error{code;data;constructor(e){super(`JSON-RPC error code=${e.code} ${e.message}`),this.name="RemoteRpcError",this.code=e.code,e.data!==void 0&&(this.data=e.data)}},U={PARSE_ERROR:-32700,INVALID_REQUEST:-32600,METHOD_NOT_FOUND:-32601,INVALID_PARAMS:-32602,INTERNAL_ERROR:-32603,AGENT_NOT_FOUND:-32001,AGENT_BUSY:-32002,AGENT_TIMEOUT:-32003,AGENT_SPAWN_FAILED:-32004,OPERATION_NOT_ALLOWED_FOR_LOCAL:-32005,AGENT_DISCONNECTED:-32006,MODEL_TOKEN_GEN_FAILED:-32009,PATH_OUTSIDE_WORKSPACE:-32010,FILE_TOO_LARGE:-32011,UNSUPPORTED_MIME:-32012,UPLOAD_FAILED:-32013,UPSTREAM_NOT_READY:-32014,AGENT_FRAME_IDLE_TIMEOUT:-32016,MODEL_MODALITY_UNSUPPORTED:-32017,AGENT_DEPENDENCY_INSTALL_FAILED:-32018,AGENT_APPROVAL_TIMEOUT:-32019};function Rf(t){return"method"in t&&"id"in t&&t.id!==void 0}function kf(t){return"method"in t&&!("id"in t)}function Ws(t){return!("method"in t)&&"id"in t}var O_={AGENT_NOT_FOUND:U.AGENT_NOT_FOUND,AGENT_BUSY:U.AGENT_BUSY,AGENT_DISCONNECTED:U.AGENT_DISCONNECTED,AGENT_TIMEOUT:U.AGENT_TIMEOUT,AGENT_FRAME_IDLE_TIMEOUT:U.AGENT_FRAME_IDLE_TIMEOUT,AGENT_SPAWN_FAILED:U.AGENT_SPAWN_FAILED,AGENT_PROTOCOL_ERROR:U.INTERNAL_ERROR,BRIDGE_CONFIG_INVALID:U.INTERNAL_ERROR,BRIDGE_INTERNAL:U.INTERNAL_ERROR,IPC_AUTH_FAILED:U.INTERNAL_ERROR,IPC_BAD_REQUEST:U.INVALID_REQUEST,MODEL_TOKEN_GEN_FAILED:U.MODEL_TOKEN_GEN_FAILED,MODEL_MODALITY_UNSUPPORTED:U.MODEL_MODALITY_UNSUPPORTED,OPERATION_NOT_ALLOWED_FOR_LOCAL:U.OPERATION_NOT_ALLOWED_FOR_LOCAL,UPSTREAM_DISCONNECTED:U.INTERNAL_ERROR,UPSTREAM_HANDSHAKE_FAILED:U.INTERNAL_ERROR,PATH_OUTSIDE_WORKSPACE:U.PATH_OUTSIDE_WORKSPACE,FILE_TOO_LARGE:U.FILE_TOO_LARGE,UNSUPPORTED_MIME:U.UNSUPPORTED_MIME,UPLOAD_FAILED:U.UPLOAD_FAILED,UPSTREAM_NOT_READY:U.UPSTREAM_NOT_READY,AGENT_DEPENDENCY_INSTALL_FAILED:U.AGENT_DEPENDENCY_INSTALL_FAILED,AGENT_APPROVAL_TIMEOUT:U.AGENT_APPROVAL_TIMEOUT};function P_(t){if(t!=null)return t instanceof Error?{name:t.name,message:ci(t.message)}:typeof t=="string"?ci(t):typeof t=="object"?D_(t):t}var C_=[[/\/Users\/[^/\s'"`)]+/g,"/Users/<redacted>"],[/\/home\/[^/\s'"`)]+/g,"/home/<redacted>"],[/[A-Za-z]:\\Users\\[^\\\s'"`)]+/g,"C:\\Users\\<redacted>"],[/(Bearer|Token|Authorization:)\s+[\w._-]+/gi,"$1 <redacted>"],[/\b(sk|pat|ak)[-_][A-Za-z0-9_-]{20,}\b/g,"<redacted-key>"]];function ci(t){let e=t;for(let[n,r]of C_)e=e.replace(n,r);return e}function D_(t){let e={};for(let[n,r]of Object.entries(t))typeof r=="string"?e[n]=ci(r):e[n]=r;return e}function li(t){if(t instanceof _){let e=P_(t.cause),n={bridgeCode:t.code,retriable:t.retriable};return e!==void 0&&(n.cause=e),{code:O_[t.code]??U.INTERNAL_ERROR,message:ci(t.message),data:n}}return{code:U.INTERNAL_ERROR,message:ci(t instanceof Error?t.message:String(t))}}function bf(t){let e=t.data,n=e?.bridgeCode??"AGENT_PROTOCOL_ERROR",r=!!e&&typeof e.message=="string"&&!!e.message,i=r?e?.message:t.message,s=t.data;if(r&&e){let{message:o,...a}=e;s=a}return new _(n,i,{retriable:e?.retriable??!1,cause:s})}function xf(t){return`${JSON.stringify(t)}
92
- `}var Af=10*1024*1024,qs=class{buffer="";onError;constructor(e={}){this.onError=e.onError}push(e){if(this.buffer+=typeof e=="string"?e:e.toString("utf8"),this.buffer.length>Af){let i=this.buffer.length;return this.buffer="",this.onError?.({line:`<buffer overflow: ${i} bytes, dropped>`,error:new Error(`LdjsonDecoder buffer exceeded ${Af} bytes`)}),[]}let n=this.buffer.split(`
93
- `);this.buffer=n.pop()??"";let r=[];for(let i of n){let s=i.replace(/\r$/,"").trim();if(s)try{r.push(JSON.parse(s))}catch(o){this.onError?.({line:s,error:o})}}return r}flush(){if(!this.buffer)return[];let e=this.buffer.replace(/\r$/,"").trim();if(this.buffer="",!e)return[];try{return[JSON.parse(e)]}catch(n){return this.onError?.({line:e,error:n}),[]}}};var Pf={"session/prompt":"session.prompt","session/cancel":"session.cancel","session/new":"session.new","session/load":"session.load","_agent/create":"agent.create","_agent/health":"agent.health","_agent/pair":"agent.pair","_agent/listSkills":"agent.listSkills","_agent/addSkills":"agent.addSkills","_agent/removeSkills":"agent.removeSkills","_agent/getFileTree":"agent.getFileTree","_agent/getFileContent":"agent.getFileContent","_agent/detail":"agent.detail","_agent/update":"agent.update","_agent/disconnect":"agent.disconnect","_agent/switchModel":"agent.switchModel","_agent/genModelToken":"agent.genModelToken","_agent/reset":"agent.reset","_agent/repair":"agent.repair","session/request_permission":"session.requestPermission",initialize:"initialize"},Yb=Object.fromEntries(Object.entries(Pf).map(([t,e])=>[e,t])),N_={"session.prompt":["agentId","triggerMsgId","sessionId"],"session.cancel":["agentId","triggerMsgId","sessionId"],"session.new":["agentId"],"session.load":["agentId"],"agent.create":["agentId"],"agent.health":[],"agent.listSkills":["agentId"],"agent.addSkills":["agentId"],"agent.removeSkills":["agentId"],"agent.getFileTree":["agentId"],"agent.getFileContent":["agentId"],"agent.detail":["agentId"],"agent.update":["agentId"],"agent.disconnect":["agentId"],"agent.switchModel":["agentId"],"agent.genModelToken":["agentId","sessionId"],"agent.reset":["agentId"],"agent.repair":["agentId"],"session.requestPermission":["agentId","sessionId"],"agent.pair":[],initialize:[]},ir=class{seq=0;next(e,n){this.seq+=1;let r=Pf[e]??L_(e),i=N_[r]??[],s=[r,String(this.seq)];if(i.length>0){let o=i.map(c=>Of(n?.[c]??"")),a=F_(o).join(":");a&&s.push(a)}else n&&Object.values(n).some(o=>o)&&s.push(Object.values(n).filter(Boolean).map(o=>Of(String(o))).join(":"));return s.join("_")}reset(){this.seq=0}};function L_(t){return t.replace(/[\s/]+/g,".").replace(/_+/g,"-")}function Of(t){return t.replace(/[:_\s]+/g,"-")}function F_(t){let e=t.length;for(;e>0&&!t[e-1];)e-=1;return t.slice(0,e)}gt();Li();Te();L();var B_=pt("COZE_BRIDGE_INITIALIZE_TIMEOUT_MS",3e4),U_=200,z_=pt("COZE_BRIDGE_SESSION_PROMPT_MAX_MS",3600*1e3),$_=pt("COZE_BRIDGE_SESSION_PROMPT_FRAME_IDLE_MS",600*1e3),G_=pt("COZE_BRIDGE_SESSION_PROMPT_APPROVAL_MAX_MS",1440*60*1e3),Cf=500;function H_(t){try{let e=JSON.stringify(t);return e===void 0||e.length<=Cf?t:`${e.slice(0,Cf)}...<truncated, total ${e.length} chars>`}catch{return"<unserializable>"}}function Df(t,e){if(!(typeof t!="number"||t<=0))try{if(process.platform==="win32"){let n=["/PID",String(t),"/T"];e==="SIGKILL"&&n.push("/F"),M_("taskkill",n,{stdio:"ignore",windowsHide:!0})}else process.kill(-t,e)}catch{}}var ct=class{constructor(e){this.opts=e;this.log=b(`downstream.${this.constructor.name}`,this.opts.agentId),this.decoder=new qs({onError:n=>this.log.warn("decode line failed",{line:n.line})})}opts;child;decoder;pending=new Map;inflightAgentRequests=new Map;idAllocator=new ir;updateHandlers=[];agentRequestHandlers=[];exitHandlers=[];log;stopped=!1;stderrRing=[];sanitizeEnv(e){return e}async start(){if(this.child)throw new _("BRIDGE_INTERNAL","Downstream already started");let e=process.platform!=="win32",n=Fe(this.opts.command,this.opts.args,{cwd:this.opts.cwd,env:{...this.sanitizeEnv(process.env),...this.opts.env},stdio:["pipe","pipe","pipe"],detached:e});this.child=n,n.stdout?.setEncoding("utf8"),n.stdout?.on("data",r=>{try{for(let i of this.decoder.push(r))this.dispatch(i)}catch(i){this.log.warn("stdout dispatch threw, swallowed to keep daemon alive",{err:String(i)})}}),n.stderr?.setEncoding("utf8"),n.stderr?.on("data",r=>{let i=r.trimEnd();this.stderrRing.push(i),this.stderrRing.length>U_&&this.stderrRing.shift(),this.log.debug("stderr",{text:i})}),n.stdin?.on("error",r=>{this.log.warn("child stdin error",{err:String(r)})}),n.stdout?.on("error",r=>{this.log.warn("child stdout error",{err:String(r)})}),n.stderr?.on("error",r=>{this.log.warn("child stderr error",{err:String(r)})}),n.on("exit",(r,i)=>{this.stopped=!0,(r!==0||i!==null)&&this.stderrRing.length>0&&this.log.warn("downstream exited abnormally, recent stderr",{code:r,signal:i,recentStderr:[...this.stderrRing]});try{for(let o of this.decoder.flush())this.dispatch(o)}catch(o){this.log.debug("decoder.flush on exit threw (ignored)",{err:String(o)})}this.failAllPending(new _("AGENT_PROTOCOL_ERROR",`agent exited (${r}/${i})`));for(let o of this.exitHandlers)o(r,i)}),n.on("error",r=>{this.log.error("child error",{err:String(r)}),this.failAllPending(new _("AGENT_SPAWN_FAILED",String(r),{cause:r}))}),this.log.info("downstream started",{command:this.opts.command,pid:n.pid,cwd:this.opts.cwd})}async stop(e){if(!this.child||this.stopped)return;this.stopped=!0,this.log.info("downstream stopping",{reason:e});let n=this.child,r=new Promise(s=>n.once("exit",()=>s()));Df(n.pid,"SIGTERM");let i=setTimeout(()=>{n.killed||Df(n.pid,"SIGKILL")},5e3);try{await r}finally{clearTimeout(i)}}pid(){return this.child?.pid}isAlive(){return!!this.child&&!this.stopped}getStderrTail(){return[...this.stderrRing]}initialize(e){return this.call("initialize",e)}sessionNew(e){return this.call("session/new",{mcpServers:[],...e})}sessionLoad(e){return this.call("session/load",{mcpServers:[],...e})}sessionPrompt(e,n=z_,r=$_,i=G_){return this.call("session/prompt",e,n,r,i)}async sessionCancel(e){!this.child||this.stopped||this.writeFrame(nr("session/cancel",e))}onUpdate(e){this.updateHandlers.push(e)}onAgentRequest(e){this.agentRequestHandlers.push(e)}respondAgentRequest(e,n){if(this.inflightAgentRequests.delete(e),!(!this.child||this.stopped))try{this.writeFrame(rr(e,n))}catch(r){this.log.warn("respondAgentRequest write failed",{id:e,err:String(r)})}}respondAgentRequestError(e,n){if(this.inflightAgentRequests.delete(e),!(!this.child||this.stopped))try{this.writeFrame(Ht(e,n))}catch(r){this.log.warn("respondAgentRequestError write failed",{id:e,err:String(r)})}}onExit(e){this.exitHandlers.push(e)}call(e,n,r=B_,i=0,s=0){if(!this.child||this.stopped)return Promise.reject(new _("AGENT_PROTOCOL_ERROR","downstream not started"));let o=this.idAllocator.next(e),a=ai(o,e,n),c=(()=>{if(typeof n!="object"||n===null)return;let p=n.sessionId;return typeof p=="string"?p:void 0})(),l=r>0&&Number.isFinite(r),d=i>0&&Number.isFinite(i);return new Promise((p,m)=>{let u={resolve:p,reject:m,timer:null,frameIdleTimer:null,armFrameIdle:null,method:e},h=Date.now();if(l){let w=()=>{u.timer=setTimeout(()=>{let S=Date.now()-h;if(this.inflightAgentRequests.size>0&&S<s){this.log.debug("hard cap fired but agent request inflight, extending to approval cap",{id:o,method:e,elapsed:S,approvalMaxMs:s,...c?{sessionId:c}:{}}),w();return}this.pending.delete(o),u.frameIdleTimer&&clearTimeout(u.frameIdleTimer);let v=this.inflightAgentRequests.size>0;this.log.warn("downstream call timeout",{id:o,method:e,timeoutMs:r,approvalMaxMs:s,awaitingApproval:v,...c?{sessionId:c}:{}}),m(v?new _("AGENT_APPROVAL_TIMEOUT",`${e} awaiting permission timed out after ${s}ms`):new _("AGENT_TIMEOUT",`${e} timed out after ${r}ms`))},r)};w()}let g=d?()=>{u.frameIdleTimer&&clearTimeout(u.frameIdleTimer),u.frameIdleTimer=setTimeout(()=>{if(this.inflightAgentRequests.size>0){this.log.debug("frame-idle fired but agent request inflight, re-arming",{id:o,method:e,inflight:this.inflightAgentRequests.size,...c?{sessionId:c}:{}}),g?.();return}u.timer&&clearTimeout(u.timer),this.pending.delete(o),this.log.warn("frame-idle timeout, rejecting pending call",{id:o,method:e,frameIdleMs:i,...c?{sessionId:c}:{}}),m(new _("AGENT_FRAME_IDLE_TIMEOUT",`${e} no session/update for ${i}ms (no inflight agent request)`))},i)}:null;u.armFrameIdle=g,this.pending.set(o,u),g?.();try{this.writeFrame(a)}catch(w){u.timer&&clearTimeout(u.timer),u.frameIdleTimer&&clearTimeout(u.frameIdleTimer),this.pending.delete(o),m(w)}})}writeFrame(e){if(!this.child?.stdin||this.child.stdin.destroyed)throw new _("AGENT_PROTOCOL_ERROR","downstream stdin not writable");this.child.stdin.write(xf(e),n=>{n&&this.log.warn("stdin write callback err",{err:String(n)})})}dispatch(e){if(Ws(e)){let n=e.id!==null?this.pending.get(e.id):void 0;if(!n){this.log.warn("orphan response",{id:e.id});return}this.pending.delete(e.id),n.timer&&clearTimeout(n.timer),n.frameIdleTimer&&clearTimeout(n.frameIdleTimer),e.error?(this.log.warn("downstream returned error frame",{id:e.id,method:n.method,code:e.error.code,message:e.error.message,data:e.error.data}),n.reject(bf(e.error))):e.result===void 0?(this.log.warn("downstream response missing both result and error",{id:e.id,method:n.method}),n.reject(new _("AGENT_PROTOCOL_ERROR",`${n.method} response missing both result and error`))):(this.log.info("downstream returned result",{id:e.id,method:n.method,result:H_(e.result)}),n.resolve(e.result));return}if(kf(e)){if(e.method==="session/update"){for(let n of this.pending.values())n.armFrameIdle?.();for(let n of this.updateHandlers)try{Promise.resolve(n(e.params)).catch(r=>this.log.warn("update handler failed (async)",{err:String(r)}))}catch(r){this.log.warn("update handler threw sync, swallowed",{err:String(r)})}}else this.log.info("unknown notification (drop, not forwarded)",{method:e.method});return}if(Rf(e)){let n=e;try{this.handleAgentRequest(n).catch(r=>this.log.error("agent request handler failed (async)",{method:n.method,err:String(r)}))}catch(r){this.log.warn("handleAgentRequest threw sync, swallowed",{method:n.method,err:String(r)})}}}async handleAgentRequest(e){if(this.agentRequestHandlers.length===0){this.writeFrame(Ht(e.id,{code:-32601,message:`method not handled by Bridge: ${e.method}`}));return}this.inflightAgentRequests.set(e.id,e.method);for(let n of this.agentRequestHandlers)try{await n(e)}catch(r){this.log.error("agentRequestHandler threw",{method:e.method,err:String(r)});try{this.writeFrame(Ht(e.id,li(r)))}catch{}this.inflightAgentRequests.delete(e.id)}}failAllPending(e){for(let n of this.pending.values())n.timer&&clearTimeout(n.timer),n.frameIdleTimer&&clearTimeout(n.frameIdleTimer),n.reject(e);this.pending.clear(),this.inflightAgentRequests.clear()}};function j_(t){let e={};for(let[n,r]of Object.entries(t))r!==void 0&&(n.startsWith("CLAUDE")||n==="AI_AGENT"||n==="BAGGAGE"||(e[n]=r));return e}var Vs=class extends ct{framework="claude-code";constructor(e){let n=br("claude-code",e.command),r=e.args??[],i={command:n,args:r,cwd:e.cwd,agentId:e.agentId,...e.env?{env:e.env}:{}};super(i)}sanitizeEnv(e){return j_(e)}};tn();import{mkdtempSync as W_,rmSync as q_}from"node:fs";import{tmpdir as V_}from"node:os";import{join as J_}from"node:path";var Js=class extends ct{framework="codex";authMethodId;codexHomeDir;constructor(e){let n=br("codex",e.command),r=e.args??[],i=e.extraArgs?[...r,...e.extraArgs]:r,s=e.isolateCodexHome?W_(J_(V_(),"coze-bridge-codex-home-")):void 0,o=s?{...e.env??{},CODEX_HOME:s}:e.env,a={command:n,args:i,cwd:e.cwd,agentId:e.agentId,...o?{env:o}:{}};super(a),this.authMethodId=e.authMethodId,this.codexHomeDir=s}async initialize(e){let n=await super.initialize(e);return this.authMethodId&&await this.call("authenticate",{methodId:this.authMethodId}),n}async stop(e){if(await super.stop(e),this.codexHomeDir)try{q_(this.codexHomeDir,{recursive:!0,force:!0})}catch{}}};var Z_=3e4,sr=class extends ct{framework="openclaw";agentId;sessionName;slashModelOnStart;constructor(e){let n=e.sessionName??"default",r=["acp","--session",`agent:${e.agentId}:${n}`];e.gatewayToken&&r.push("--token",e.gatewayToken);let i={command:e.command,args:r,cwd:e.cwd,agentId:e.agentId,...e.env?{env:e.env}:{}};super(i),this.agentId=e.agentId,this.sessionName=n,this.slashModelOnStart=e.slashModelOnStart}async afterSessionEstablished(e){this.slashModelOnStart&&(this.log.info("switching session to per-session provider via /model",{agentId:this.agentId,sessionName:this.sessionName,slash:this.slashModelOnStart}),await this.sessionPrompt({sessionId:e,prompt:[{type:"text",text:`/model ${this.slashModelOnStart}`}]},Z_))}get acpSessionName(){return this.sessionName}};Te();L();le();function wc(t){return t.replace(/[^A-Za-z0-9._-]+/g,"-")}tn();var jt=class{slots=[];running=!1;closed=!1;disposed=!1;enqueue(e){return this.disposed?Promise.reject(new Error("AsyncQueue disposed")):this.closed?Promise.reject(new Error("AsyncQueue closed")):new Promise((n,r)=>{this.slots.push({task:e,resolve:n,reject:r}),this.drain()})}close(){this.closed=!0}dispose(e=new Error("AsyncQueue disposed")){for(this.disposed=!0,this.closed=!0;this.slots.length>0;)this.slots.shift()?.reject(e)}get size(){return this.slots.length}get isRunning(){return this.running}get isDisposed(){return this.disposed}async drain(){if(!this.running){this.running=!0;try{for(;this.slots.length>0&&!this.disposed;){let e=this.slots.shift();if(!e)break;try{let n=await e.task();e.resolve(n)}catch(n){e.reject(n)}}}finally{this.running=!1}}}};var Zs=class{agentId;framework;workspace;deployType;accountId;patToken;modelInfo;sessions=new Map;sessionQueues=new Map;activeTriggers=new Map;activeGroupIds=new Map;status="ok";model;lastActiveAt=Date.now();constructor(e){this.agentId=e.agentId,this.framework=e.framework,this.workspace=e.workspace,this.model=e.model,this.deployType=e.deployType??"local",e.accountId&&(this.accountId=e.accountId),e.patToken&&(this.patToken=e.patToken),e.modelInfo&&(this.modelInfo=e.modelInfo)}setPatToken(e){this.patToken=e}setModelInfo(e){this.modelInfo=e}getSessionQueue(e){let n=this.sessionQueues.get(e);return(!n||n.isDisposed)&&(n=new jt,this.sessionQueues.set(e,n)),n}allSessionQueues(){return this.sessionQueues.entries()}hasSessionQueue(e){let n=this.sessionQueues.get(e);return!!n&&!n.isDisposed}async dispose(e){this.status="stopped";let n=new Error(`AgentSession disposed${e?`: ${e}`:""}`);for(let r of this.sessionQueues.values())r.dispose(n);this.sessionQueues.clear(),await this.killAllRuntimes(e??"dispose")}async killAllRuntimes(e){let n=[];for(let[,r]of this.sessions)di(r),r.downstream&&(n.push(r.downstream.stop(e).catch(()=>{})),r.downstream=void 0);await Promise.all(n),this.activeTriggers.clear(),this.activeGroupIds.clear()}};function di(t){t.idleTimer&&(clearTimeout(t.idleTimer),t.idleTimer=void 0)}gt();L();import{promises as yc}from"node:fs";import{join as K_}from"node:path";var wn=b("agents.codex-sandbox-installer"),Nf="@openai/codex@0.135.0",Lf="https://registry.npmmirror.com",_c="/usr/lib/node_modules/@openai/codex/node_modules/@openai/codex-linux-x64/vendor/x86_64-unknown-linux-musl/bin/codex",X_="/usr/bin",Ff=["apply_patch","applypatch","codex-execve-wrapper","codex-linux-sandbox"],Y_=9e4,Q_=5e3,ui=null,Mf=!1;async function Bf(t,e={}){if((e.platform??process.platform)!=="linux"||Mf)return;if(ui)return ui;let r=e.exec??Pn,i=e.statFile??(async a=>{try{return await yc.stat(a),!0}catch{return!1}}),s=e.symlink??((a,c)=>yc.symlink(a,c)),o=e.unlink??(a=>yc.unlink(a));return ui=(async()=>{try{let a=!1;try{let{stdout:l}=await r("which",["codex"],{timeout:Q_});a=l.trim().length>0}catch{a=!1}if(a)wn.info("codex already present, skip install");else{wn.info("codex not found, installing",{package:Nf,registry:Lf});try{await r("npm",["i","-g",Nf,`--registry=${Lf}`],{timeout:Y_,maxBuffer:10*1024*1024,signal:t}),wn.info("codex install ok")}catch(l){wn.warn("codex install failed (skip symlinks)",{err:String(l)});return}}if(!await i(_c)){wn.warn("codex vendor bin not found, skip symlinks",{target:_c});return}let c=0;for(let l of Ff){let d=K_(X_,l);try{await o(d).catch(()=>{}),await s(_c,d),c+=1,wn.info("codex sandbox symlink created",{link:d})}catch(p){wn.warn("codex sandbox symlink failed (ignored)",{link:d,err:String(p)})}}c===Ff.length&&(Mf=!0)}finally{ui=null}})(),ui}gt();L();import{constants as Uf,access as eE}from"node:fs/promises";import{delimiter as tE,join as nE}from"node:path";var Wt=b("framework-detector"),zf={"claude-code":"claude",codex:"codex",openclaw:"openclaw"},rE=[".exe",".cmd",".bat",".ps1"],qt=class{env;constructor(e={}){this.env={pathEnv:e.pathEnv??process.env.PATH??"",platform:e.platform??process.platform,spawn:e.spawn??Fe,access:e.access??eE}}async detect(e){let n=zf[e],r=await this.which(n);if(!r)return Wt.debug("framework binary not found",{framework:e,bin:n}),null;let i=e==="openclaw"?["--log-level","silent"]:[],[s,o]=await Promise.all([this.probeVersion(r,i),e==="openclaw"?this.probeOpenclawDefaultAgent(r):Promise.resolve(null)]),a={path:r,version:s};return o&&(a.defaultAgent=o),a}async detectAll(){let e=await Promise.all(Object.keys(zf).map(async r=>[r,await this.detect(r)])),n={};for(let[r,i]of e)i&&(n[r]=i);return n}async which(e){let n=this.env.pathEnv.split(tE).filter(Boolean),r=this.env.platform==="win32"?["",...rE]:[""];for(let i of n)for(let s of r){let o=nE(i,e+s);if(await this.isExecutable(o))return o}return null}async isExecutable(e){try{let n=this.env.platform==="win32"?Uf.F_OK:Uf.X_OK;return await this.env.access(e,n),!0}catch{return!1}}async probeOpenclawDefaultAgent(e){let n=await this.runProbe(e,["--log-level","silent","agents","list","--json"]);if(!n)return Wt.warn("openclaw default agent probe: runProbe returned null (spawn err / timeout)",{path:e}),null;if(n.code!==0)return Wt.warn("openclaw default agent probe: non-zero exit",{path:e,code:n.code,stdoutHead:n.stdout.slice(0,200)}),null;let r=n.stdout.match(/\[\s*\{[\s\S]*\}\s*\]/);if(!r)return Wt.warn("openclaw default agent probe: regex no match (no JSON array in stdout)",{path:e,stdoutHead:n.stdout.slice(0,200)}),null;try{let i=JSON.parse(r[0]);if(!Array.isArray(i))return Wt.warn("openclaw default agent probe: JSON parsed but not an array",{path:e}),null;let s=i.find(o=>o?.isDefault===!0);return s?!s.id||!s.workspace?(Wt.warn("openclaw default agent probe: default agent missing id or workspace",{path:e,hasId:!!s.id,hasWorkspace:!!s.workspace}),null):{id:s.id,workspace:s.workspace}:(Wt.info("openclaw default agent probe: no agent has isDefault=true",{path:e,agentCount:i.length}),null)}catch(i){return Wt.warn("openclaw default agent probe: JSON.parse failed",{path:e,err:String(i),matchHead:r[0].slice(0,200)}),null}}async probeVersion(e,n=[]){let r=await this.runProbe(e,[...n,"--version"]);return r&&(sE(r.stdout).split(/\r?\n/)[0]??"").trim()||"unknown"}runProbe(e,n){return new Promise(r=>{let i="",s=!1,o,a=c=>{s||(s=!0,o&&clearTimeout(o),r(c))};try{let c=this.env.spawn(e,n,{stdio:["ignore","pipe","pipe"]});o=setTimeout(()=>{c.kill("SIGKILL"),a(null)},15e3),c.stdout?.on("data",l=>{i+=l.toString("utf8")}),c.on("error",()=>a(null)),c.on("close",l=>a({code:l,stdout:i}))}catch{a(null)}})}},iE=new RegExp("\x1B\\[[0-9;]*[A-Za-z]","g");function sE(t){return t.replace(iE,"")}import{homedir as oE}from"node:os";import{join as aE}from"node:path";gt();Te();Wi();L();async function Hf(){let t=aE(oE(),".openclaw/openclaw.json");return(await Nn(t))?.gateway?.auth?.token??""}var $f=b("openclaw.config"),cE=[0,5e3,5e3],Gf="models.providers.",Ks="agents.defaults.models",Xs=class{command;env;retryDelaysMs;queue=new jt;constructor(e){this.command=e.command,this.env=e.env??process.env,this.retryDelaysMs=e.retryDelaysMs??cE}async withRetry(e,n){let r;for(let i=0;i<this.retryDelaysMs.length;i++){let s=this.retryDelaysMs[i]??0;s>0&&await new Promise(o=>setTimeout(o,s));try{return await n()}catch(o){r=o,$f.warn("openclaw cli failed, will retry",{label:e,attempt:i+1,err:String(o)})}}throw new _("AGENT_SPAWN_FAILED",`openclaw cli ${e} failed after ${this.retryDelaysMs.length} attempts: ${r?.message??"unknown"}`)}runCli(e){return new Promise((n,r)=>{let i=Fe(this.command,e,{stdio:["ignore","pipe","pipe"],env:this.env}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`exit ${o}: ${s.trim().slice(0,500)}`))})})}async runCliTolerant(e,n){try{await this.runCli(e)}catch(r){let i=String(r);if(n.some(s=>i.includes(s)))return;throw r}}async bestEffortUnset(e,n){try{await this.queue.enqueue(()=>this.withRetry(e,()=>this.runCli(["config","unset",n])))}catch(r){$f.warn(`${e} failed (best-effort)`,{configPath:n,err:String(r)})}}ensureProvider(e,n){return this.queue.enqueue(()=>this.withRetry(`config set models.providers.${e}`,()=>this.runCli(["config","set",`${Gf}${e}`,JSON.stringify(n),"--strict-json","--merge"])))}removeProvider(e){return this.bestEffortUnset(`config unset models.providers.${e}`,`${Gf}${e}`)}addModelToAllowlist(e,n){let r={[e]:n?{alias:n}:{}};return this.queue.enqueue(()=>this.withRetry(`config set ${Ks}[${e}]`,()=>this.runCli(["config","set",Ks,JSON.stringify(r),"--strict-json","--merge"])))}removeModelFromAllowlist(e){return this.bestEffortUnset(`config unset ${Ks}[${e}]`,`${Ks}.${e}`)}ensureAgent(e,n,r){let i=["agents","add",e,"--workspace",n,"--non-interactive"];return r&&i.push("--model",r),this.queue.enqueue(()=>this.withRetry(`agents add ${e}`,()=>this.runCliTolerant(i,["already exists","already registered"])))}restartGateway(){return this.queue.enqueue(()=>this.withRetry("gateway restart",()=>this.runCli(["gateway","restart"])))}deleteAgent(e){return this.queue.enqueue(()=>this.withRetry(`agents delete ${e}`,()=>this.runCliTolerant(["agents","delete",e,"--force"],["not found","does not exist"])))}};var K=b("agent-manager"),pE=(t,e,n,r,i,s,o,a,c)=>{switch(t){case"claude-code":{let l={...i?{...uf(i),...pf(i,o,a)}:{},...c??{},IS_SANDBOX:"1"};return new Vs({cwd:n,env:l,agentId:r})}case"codex":{let d=[...i?[...ff(i),...mf(i,o,a)]:[],"-c",'sandbox_mode="danger-full-access"',"-c",'approval_policy="never"'],p={...i?hf(i):{},...c??{}},m=!!i;return new Js({cwd:n,agentId:r,...d.length>0?{extraArgs:d}:{},...Object.keys(p).length>0?{env:p}:{},...m?{authMethodId:"openai-api-key",isolateCodexHome:!0}:{}})}case"openclaw":return new sr({command:e,cwd:n,agentId:r,...s?{sessionName:wc(s)}:{}})}};function Ec(t){return t==="claude-code"||t==="codex"}function gE(t){let e=[],n=Object.keys(t).sort();for(let r of n){let i=t[r];i!==void 0&&(mE(i)||e.push(`${r}=${i}`))}return e.length===0?"":`${e.join(`
90
+ `).reduce(Yw,Object.create(null)),Yw=(t,e)=>{let n=parseInt(e,10);if(n!==Buffer.byteLength(e)+1)return t;e=e.slice((n+" ").length);let r=e.split("="),i=r.shift();if(!i)return t;let s=i.replace(/^SCHILY\.(dev|ino|nlink)/,"$1"),o=r.join("=");return t[s]=/^([A-Z]+\.)?([mac]|birth|creation)time$/.test(s)?new Date(Number(o)*1e3):/^[0-9]+$/.test(o)?+o:o,t},Qw=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,N=Qw!=="win32"?t=>t:t=>t&&t.replaceAll(/\\/g,"/"),xu=class extends mn{extended;globalExtended;header;startBlockSize;blockRemain;remain;type;meta=!1;ignore=!1;path;mode;uid;gid;uname;gname;size=0;mtime;atime;ctime;linkpath;dev;ino;nlink;invalid=!1;absolute;unsupported=!1;constructor(t,e,n){switch(super({}),this.pause(),this.extended=e,this.globalExtended=n,this.header=t,this.remain=t.size??0,this.startBlockSize=512*Math.ceil(this.remain/512),this.blockRemain=this.startBlockSize,this.type=t.type,this.type){case"File":case"OldFile":case"Link":case"SymbolicLink":case"CharacterDevice":case"BlockDevice":case"Directory":case"FIFO":case"ContiguousFile":case"GNUDumpDir":break;case"NextFileHasLongLinkpath":case"NextFileHasLongPath":case"OldGnuLongPath":case"GlobalExtendedHeader":case"ExtendedHeader":case"OldExtendedHeader":this.meta=!0;break;default:this.ignore=!0}if(!t.path)throw new Error("no path provided for tar.ReadEntry");this.path=N(t.path),this.mode=t.mode,this.mode&&(this.mode=this.mode&4095),this.uid=t.uid,this.gid=t.gid,this.uname=t.uname,this.gname=t.gname,this.size=this.remain,this.mtime=t.mtime,this.atime=t.atime,this.ctime=t.ctime,this.linkpath=t.linkpath?N(t.linkpath):void 0,this.uname=t.uname,this.gname=t.gname,e&&this.#e(e),n&&this.#e(n,!0)}write(t){let e=t.length;if(e>this.blockRemain)throw new Error("writing more to entry than is appropriate");let n=this.remain,r=this.blockRemain;return this.remain=Math.max(0,n-e),this.blockRemain=Math.max(0,r-e),this.ignore?!0:n>=e?super.write(t):super.write(t.subarray(0,n))}#e(t,e=!1){t.path&&(t.path=N(t.path)),t.linkpath&&(t.linkpath=N(t.linkpath)),Object.assign(this,Object.fromEntries(Object.entries(t).filter(([n,r])=>!(r==null||n==="path"&&e))))}},Ls=(t,e,n,r={})=>{t.file&&(r.file=t.file),t.cwd&&(r.cwd=t.cwd),r.code=n instanceof Error&&n.code||e,r.tarCode=e,!t.strict&&r.recoverable!==!1?(n instanceof Error&&(r=Object.assign(n,r),n=n.message),t.emit("warn",e,n,r)):n instanceof Error?t.emit("error",Object.assign(n,r)):t.emit("error",Object.assign(new Error(`${e}: ${n}`),r))},ey=1024*1024,Pa=Buffer.from([31,139]),Ca=Buffer.from([40,181,47,253]),ty=Math.max(Pa.length,Ca.length),Me=Symbol("state"),cn=Symbol("writeEntry"),yt=Symbol("readEntry"),ma=Symbol("nextEntry"),Wd=Symbol("processEntry"),rt=Symbol("extendedHeader"),Br=Symbol("globalExtendedHeader"),Pt=Symbol("meta"),qd=Symbol("emitMeta"),W=Symbol("buffer"),_t=Symbol("queue"),Ct=Symbol("ended"),wa=Symbol("emittedEnd"),ln=Symbol("emit"),ee=Symbol("unzip"),ls=Symbol("consumeChunk"),ds=Symbol("consumeChunkSub"),ya=Symbol("consumeBody"),Vd=Symbol("consumeMeta"),Jd=Symbol("consumeHeader"),Ur=Symbol("consuming"),_a=Symbol("bufferConcat"),us=Symbol("maybeEnd"),$n=Symbol("writing"),Dt=Symbol("aborted"),fs=Symbol("onDone"),dn=Symbol("sawValidEntry"),hs=Symbol("sawNullBlock"),ps=Symbol("sawEOF"),Zd=Symbol("closeStream"),ny=()=>!0,ti=class extends Sw{file;strict;maxMetaEntrySize;filter;brotli;zstd;writable=!0;readable=!1;[_t]=[];[W];[yt];[cn];[Me]="begin";[Pt]="";[rt];[Br];[Ct]=!1;[ee];[Dt]=!1;[dn];[hs]=!1;[ps]=!1;[$n]=!1;[Ur]=!1;[wa]=!1;constructor(t={}){super(),this.file=t.file||"",this.on(fs,()=>{(this[Me]==="begin"||this[dn]===!1)&&this.warn("TAR_BAD_ARCHIVE","Unrecognized archive format")}),t.ondone?this.on(fs,t.ondone):this.on(fs,()=>{this.emit("prefinish"),this.emit("finish"),this.emit("end")}),this.strict=!!t.strict,this.maxMetaEntrySize=t.maxMetaEntrySize||ey,this.filter=typeof t.filter=="function"?t.filter:ny;let e=t.file&&(t.file.endsWith(".tar.br")||t.file.endsWith(".tbr"));this.brotli=!(t.gzip||t.zstd)&&t.brotli!==void 0?t.brotli:e?void 0:!1;let n=t.file&&(t.file.endsWith(".tar.zst")||t.file.endsWith(".tzst"));this.zstd=!(t.gzip||t.brotli)&&t.zstd!==void 0?t.zstd:n?!0:void 0,this.on("end",()=>this[Zd]()),typeof t.onwarn=="function"&&this.on("warn",t.onwarn),typeof t.onReadEntry=="function"&&this.on("entry",t.onReadEntry)}warn(t,e,n={}){Ls(this,t,e,n)}[Jd](t,e){this[dn]===void 0&&(this[dn]=!1);let n;try{n=new gn(t,e,this[rt],this[Br])}catch(r){return this.warn("TAR_ENTRY_INVALID",r)}if(n.nullBlock)this[hs]?(this[ps]=!0,this[Me]==="begin"&&(this[Me]="header"),this[ln]("eof")):(this[hs]=!0,this[ln]("nullBlock"));else if(this[hs]=!1,!n.cksumValid)this.warn("TAR_ENTRY_INVALID","checksum failure",{header:n});else if(!n.path)this.warn("TAR_ENTRY_INVALID","path is required",{header:n});else{let r=n.type;if(/^(Symbolic)?Link$/.test(r)&&!n.linkpath)this.warn("TAR_ENTRY_INVALID","linkpath required",{header:n});else if(!/^(Symbolic)?Link$/.test(r)&&!/^(Global)?ExtendedHeader$/.test(r)&&n.linkpath)this.warn("TAR_ENTRY_INVALID","linkpath forbidden",{header:n});else{let i=this[cn]=new xu(n,this[rt],this[Br]);if(!this[dn])if(i.remain){let s=()=>{i.invalid||(this[dn]=!0)};i.on("end",s)}else this[dn]=!0;i.meta?i.size>this.maxMetaEntrySize?(i.ignore=!0,this[ln]("ignoredEntry",i),this[Me]="ignore",i.resume()):i.size>0&&(this[Pt]="",i.on("data",s=>this[Pt]+=s),this[Me]="meta"):(this[rt]=void 0,i.ignore=i.ignore||!this.filter(i.path,i),i.ignore?(this[ln]("ignoredEntry",i),this[Me]=i.remain?"ignore":"header",i.resume()):(i.remain?this[Me]="body":(this[Me]="header",i.end()),this[yt]?this[_t].push(i):(this[_t].push(i),this[ma]())))}}}[Zd](){queueMicrotask(()=>this.emit("close"))}[Wd](t){let e=!0;if(!t)this[yt]=void 0,e=!1;else if(Array.isArray(t)){let[n,...r]=t;this.emit(n,...r)}else this[yt]=t,this.emit("entry",t),t.emittedEnd||(t.on("end",()=>this[ma]()),e=!1);return e}[ma](){do;while(this[Wd](this[_t].shift()));if(this[_t].length===0){let t=this[yt];!t||t.flowing||t.size===t.remain?this[$n]||this.emit("drain"):t.once("drain",()=>this.emit("drain"))}}[ya](t,e){let n=this[cn];if(!n)throw new Error("attempt to consume body without entry??");let r=n.blockRemain??0,i=r>=t.length&&e===0?t:t.subarray(e,e+r);return n.write(i),n.blockRemain||(this[Me]="header",this[cn]=void 0,n.end()),i.length}[Vd](t,e){let n=this[cn],r=this[ya](t,e);return!this[cn]&&n&&this[qd](n),r}[ln](t,e,n){this[_t].length===0&&!this[yt]?this.emit(t,e,n):this[_t].push([t,e,n])}[qd](t){switch(this[ln]("meta",this[Pt]),t.type){case"ExtendedHeader":case"OldExtendedHeader":this[rt]=As.parse(this[Pt],this[rt],!1);break;case"GlobalExtendedHeader":this[Br]=As.parse(this[Pt],this[Br],!0);break;case"NextFileHasLongPath":case"OldGnuLongPath":{let e=this[rt]??Object.create(null);this[rt]=e,e.path=this[Pt].replace(/\0.*/,"");break}case"NextFileHasLongLinkpath":{let e=this[rt]||Object.create(null);this[rt]=e,e.linkpath=this[Pt].replace(/\0.*/,"");break}default:throw new Error("unknown meta: "+t.type)}}abort(t){this[Dt]=!0,this.emit("abort",t),this.warn("TAR_ABORT",t,{recoverable:!1})}write(t,e,n){if(typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8")),this[Dt])return n?.(),!1;if((this[ee]===void 0||this.brotli===void 0&&this[ee]===!1)&&t){if(this[W]&&(t=Buffer.concat([this[W],t]),this[W]=void 0),t.length<ty)return this[W]=t,n?.(),!0;for(let o=0;this[ee]===void 0&&o<Pa.length;o++)t[o]!==Pa[o]&&(this[ee]=!1);let i=!1;if(this[ee]===!1&&this.zstd!==!1){i=!0;for(let o=0;o<Ca.length;o++)if(t[o]!==Ca[o]){i=!1;break}}let s=this.brotli===void 0&&!i;if(this[ee]===!1&&s)if(t.length<512)if(this[Ct])this.brotli=!0;else return this[W]=t,n?.(),!0;else try{new gn(t.subarray(0,512)),this.brotli=!1}catch{this.brotli=!0}if(this[ee]===void 0||this[ee]===!1&&(this.brotli||i)){let o=this[Ct];this[Ct]=!1,this[ee]=this[ee]===void 0?new bw({}):i?new Pw({}):new xw({}),this[ee].on("data",c=>this[ls](c)),this[ee].on("error",c=>this.abort(c)),this[ee].on("end",()=>{this[Ct]=!0,this[ls]()}),this[$n]=!0;let a=!!this[ee][o?"end":"write"](t);return this[$n]=!1,n?.(),a}}this[$n]=!0,this[ee]?this[ee].write(t):this[ls](t),this[$n]=!1;let r=this[_t].length>0?!1:this[yt]?this[yt].flowing:!0;return!r&&this[_t].length===0&&this[yt]?.once("drain",()=>this.emit("drain")),n?.(),r}[_a](t){t&&!this[Dt]&&(this[W]=this[W]?Buffer.concat([this[W],t]):t)}[us](){if(this[Ct]&&!this[wa]&&!this[Dt]&&!this[Ur]){this[wa]=!0;let t=this[cn];if(t&&t.blockRemain){let e=this[W]?this[W].length:0;this.warn("TAR_BAD_ARCHIVE",`Truncated input (needed ${t.blockRemain} more bytes, only ${e} available)`,{entry:t}),this[W]&&t.write(this[W]),t.end()}this[ln](fs)}}[ls](t){if(this[Ur]&&t)this[_a](t);else if(!t&&!this[W])this[us]();else if(t){if(this[Ur]=!0,this[W]){this[_a](t);let e=this[W];this[W]=void 0,this[ds](e)}else this[ds](t);for(;this[W]&&this[W]?.length>=512&&!this[Dt]&&!this[ps];){let e=this[W];this[W]=void 0,this[ds](e)}this[Ur]=!1}(!this[W]||this[Ct])&&this[us]()}[ds](t){let e=0,n=t.length;for(;e+512<=n&&!this[Dt]&&!this[ps];)switch(this[Me]){case"begin":case"header":this[Jd](t,e),e+=512;break;case"ignore":case"body":e+=this[ya](t,e);break;case"meta":e+=this[Vd](t,e);break;default:throw new Error("invalid state: "+this[Me])}e<n&&(this[W]=this[W]?Buffer.concat([t.subarray(e),this[W]]):t.subarray(e))}end(t,e,n){return typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,e)),n&&this.once("finish",n),this[Dt]||(this[ee]?(t&&this[ee].write(t),this[ee].end()):(this[Ct]=!0,(this.brotli===void 0||this.zstd===void 0)&&(t=t||Buffer.alloc(0)),t&&this.write(t),this[us]())),this}},Jr=t=>{let e=t.length-1,n=-1;for(;e>-1&&t.charAt(e)==="/";)n=e,e--;return n===-1?t:t.slice(0,n)},ry=t=>{let e=t.onReadEntry;t.onReadEntry=e?n=>{e(n),n.resume()}:n=>n.resume()},Ou=(t,e)=>{let n=new Map(e.map(s=>[Jr(s),!0])),r=t.filter,i=(s,o="")=>{let a=o||hw(s).root||".",c;if(s===a)c=!1;else{let l=n.get(s);c=l!==void 0?l:i(fw(s),a)}return n.set(s,c),c};t.filter=r?(s,o)=>r(s,o)&&i(Jr(s)):s=>i(Jr(s))},iy=t=>{let e=new ti(t),n=t.file,r;try{r=Vn.openSync(n,"r");let i=Vn.fstatSync(r),s=t.maxReadSize||16*1024*1024;if(i.size<s){let o=Buffer.allocUnsafe(i.size),a=Vn.readSync(r,o,0,i.size,0);e.end(a===o.byteLength?o:o.subarray(0,a))}else{let o=0,a=Buffer.allocUnsafe(s);for(;o<i.size;){let c=Vn.readSync(r,a,0,s,o);if(c===0)break;o+=c,e.write(a.subarray(0,c))}e.end()}}finally{if(typeof r=="number")try{Vn.closeSync(r)}catch{}}},sy=(t,e)=>{let n=new ti(t),r=t.maxReadSize||16*1024*1024,i=t.file;return new Promise((s,o)=>{n.on("error",o),n.on("end",s),Vn.stat(i,(a,c)=>{if(a)o(a);else{let l=new Ka(i,{readSize:r,size:c.size});l.on("error",o),l.pipe(n)}})})},Xn=ni(iy,sy,t=>new ti(t),t=>new ti(t),(t,e)=>{e?.length&&Ou(t,e),t.noResume||ry(t)}),Pu=(t,e,n)=>(t&=4095,n&&(t=(t|384)&-19),e&&(t&256&&(t|=64),t&32&&(t|=8),t&4&&(t|=1)),t),{isAbsolute:ay,parse:Xd}=oy,ec=t=>{let e="",n=Xd(t);for(;ay(t)||n.root;){let r=t.charAt(0)==="/"&&t.slice(0,4)!=="//?/"?"/":n.root;t=t.slice(r.length),e+=r,n=Xd(t)}return[e,t]},Fs=["|","<",">","?",":"],tc=Fs.map(t=>String.fromCodePoint(61440+Number(t.codePointAt(0)))),cy=new Map(Fs.map((t,e)=>[t,tc[e]])),ly=new Map(tc.map((t,e)=>[t,Fs[e]])),Yd=t=>Fs.reduce((e,n)=>e.split(n).join(cy.get(n)),t),dy=t=>tc.reduce((e,n)=>e.split(n).join(ly.get(n)),t),Cu=(t,e)=>e?(t=N(t).replace(/^\.(\/|$)/,""),Jr(e)+"/"+t):N(t),uy=16*1024*1024,Qd=Symbol("process"),eu=Symbol("file"),tu=Symbol("directory"),Da=Symbol("symlink"),nu=Symbol("hardlink"),zr=Symbol("header"),Es=Symbol("read"),Na=Symbol("lstat"),Ss=Symbol("onlstat"),La=Symbol("onread"),Fa=Symbol("onreadlink"),Ma=Symbol("openfile"),Ba=Symbol("onopenfile"),Bt=Symbol("close"),Os=Symbol("mode"),Ua=Symbol("awaitDrain"),Ea=Symbol("ondrain"),st=Symbol("prefix"),Du=class extends mn{path;portable;myuid=process.getuid&&process.getuid()||0;myuser=process.env.USER||"";maxReadSize;linkCache;statCache;preservePaths;cwd;strict;mtime;noPax;noMtime;prefix;fd;blockLen=0;blockRemain=0;buf;pos=0;remain=0;length=0;offset=0;win32;absolute;header;type;linkpath;stat;onWriteEntry;#e=!1;constructor(t,e={}){let n=Xa(e);super(),this.path=N(t),this.portable=!!n.portable,this.maxReadSize=n.maxReadSize||uy,this.linkCache=n.linkCache||new Map,this.statCache=n.statCache||new Map,this.preservePaths=!!n.preservePaths,this.cwd=N(n.cwd||process.cwd()),this.strict=!!n.strict,this.noPax=!!n.noPax,this.noMtime=!!n.noMtime,this.mtime=n.mtime,this.prefix=n.prefix?N(n.prefix):void 0,this.onWriteEntry=n.onWriteEntry,typeof n.onwarn=="function"&&this.on("warn",n.onwarn);let r=!1;if(!this.preservePaths){let[s,o]=ec(this.path);s&&typeof o=="string"&&(this.path=o,r=s)}this.win32=!!n.win32||process.platform==="win32",this.win32&&(this.path=dy(this.path.replaceAll(/\\/g,"/")),t=t.replaceAll(/\\/g,"/")),this.absolute=N(n.absolute||Kd.resolve(this.cwd,t)),this.path===""&&(this.path="./"),r&&this.warn("TAR_ENTRY_INFO",`stripping ${r} from absolute path`,{entry:this,path:r+this.path});let i=this.statCache.get(this.absolute);i?this[Ss](i):this[Na]()}warn(t,e,n={}){return Ls(this,t,e,n)}emit(t,...e){return t==="error"&&(this.#e=!0),super.emit(t,...e)}[Na](){it.lstat(this.absolute,(t,e)=>{if(t)return this.emit("error",t);this[Ss](e)})}[Ss](t){this.statCache.set(this.absolute,t),this.stat=t,t.isFile()||(t.size=0),this.type=py(t),this.emit("stat",t),this[Qd]()}[Qd](){switch(this.type){case"File":return this[eu]();case"Directory":return this[tu]();case"SymbolicLink":return this[Da]();default:return this.end()}}[Os](t){return Pu(t,this.type==="Directory",this.portable)}[st](t){return Cu(t,this.prefix)}[zr](){if(!this.stat)throw new Error("cannot write header before stat");this.type==="Directory"&&this.portable&&(this.noMtime=!0),this.onWriteEntry?.(this),this.header=new gn({path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,mode:this[Os](this.stat.mode),uid:this.portable?void 0:this.stat.uid,gid:this.portable?void 0:this.stat.gid,size:this.stat.size,mtime:this.noMtime?void 0:this.mtime||this.stat.mtime,type:this.type==="Unsupported"?void 0:this.type,uname:this.portable?void 0:this.stat.uid===this.myuid?this.myuser:"",atime:this.portable?void 0:this.stat.atime,ctime:this.portable?void 0:this.stat.ctime}),this.header.encode()&&!this.noPax&&super.write(new As({atime:this.portable?void 0:this.header.atime,ctime:this.portable?void 0:this.header.ctime,gid:this.portable?void 0:this.header.gid,mtime:this.noMtime?void 0:this.mtime||this.header.mtime,path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,size:this.header.size,uid:this.portable?void 0:this.header.uid,uname:this.portable?void 0:this.header.uname,dev:this.portable?void 0:this.stat.dev,ino:this.portable?void 0:this.stat.ino,nlink:this.portable?void 0:this.stat.nlink}).encode());let t=this.header?.block;if(!t)throw new Error("failed to encode header");super.write(t)}[tu](){if(!this.stat)throw new Error("cannot create directory entry without stat");this.path.slice(-1)!=="/"&&(this.path+="/"),this.stat.size=0,this[zr](),this.end()}[Da](){it.readlink(this.absolute,(t,e)=>{if(t)return this.emit("error",t);this[Fa](e)})}[Fa](t){this.linkpath=N(t),this[zr](),this.end()}[nu](t){if(!this.stat)throw new Error("cannot create link entry without stat");this.type="Link",this.linkpath=N(Kd.relative(this.cwd,t)),this.stat.size=0,this[zr](),this.end()}[eu](){if(!this.stat)throw new Error("cannot create file entry without stat");if(this.stat.nlink>1){let t=`${this.stat.dev}:${this.stat.ino}`,e=this.linkCache.get(t);if(e?.indexOf(this.cwd)===0)return this[nu](e);this.linkCache.set(t,this.absolute)}if(this[zr](),this.stat.size===0)return this.end();this[Ma]()}[Ma](){it.open(this.absolute,"r",(t,e)=>{if(t)return this.emit("error",t);this[Ba](e)})}[Ba](t){if(this.fd=t,this.#e)return this[Bt]();if(!this.stat)throw new Error("should stat before calling onopenfile");this.blockLen=512*Math.ceil(this.stat.size/512),this.blockRemain=this.blockLen;let e=Math.min(this.blockLen,this.maxReadSize);this.buf=Buffer.allocUnsafe(e),this.offset=0,this.pos=0,this.remain=this.stat.size,this.length=this.buf.length,this[Es]()}[Es](){let{fd:t,buf:e,offset:n,length:r,pos:i}=this;if(t===void 0||e===void 0)throw new Error("cannot read file without first opening");it.read(t,e,n,r,i,(s,o)=>{if(s)return this[Bt](()=>this.emit("error",s));this[La](o)})}[Bt](t=()=>{}){this.fd!==void 0&&it.close(this.fd,t)}[La](t){if(t<=0&&this.remain>0){let n=Object.assign(new Error("encountered unexpected EOF"),{path:this.absolute,syscall:"read",code:"EOF"});return this[Bt](()=>this.emit("error",n))}if(t>this.remain){let n=Object.assign(new Error("did not encounter expected EOF"),{path:this.absolute,syscall:"read",code:"EOF"});return this[Bt](()=>this.emit("error",n))}if(!this.buf)throw new Error("should have created buffer prior to reading");if(t===this.remain)for(let n=t;n<this.length&&t<this.blockRemain;n++)this.buf[n+this.offset]=0,t++,this.remain++;let e=this.offset===0&&t===this.buf.length?this.buf:this.buf.subarray(this.offset,this.offset+t);this.write(e)?this[Ea]():this[Ua](()=>this[Ea]())}[Ua](t){this.once("drain",t)}write(t,e,n){if(typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8")),this.blockRemain<t.length){let r=Object.assign(new Error("writing more data than expected"),{path:this.absolute});return this.emit("error",r)}return this.remain-=t.length,this.blockRemain-=t.length,this.pos+=t.length,this.offset+=t.length,super.write(t,null,n)}[Ea](){if(!this.remain)return this.blockRemain&&super.write(Buffer.alloc(this.blockRemain)),this[Bt](t=>t?this.emit("error",t):this.end());if(!this.buf)throw new Error("buffer lost somehow in ONDRAIN");this.offset>=this.length&&(this.buf=Buffer.allocUnsafe(Math.min(this.blockRemain,this.buf.length)),this.offset=0),this.length=this.buf.length-this.offset,this[Es]()}},fy=class extends Du{sync=!0;[Na](){this[Ss](it.lstatSync(this.absolute))}[Da](){this[Fa](it.readlinkSync(this.absolute))}[Ma](){this[Ba](it.openSync(this.absolute,"r"))}[Es](){let t=!0;try{let{fd:e,buf:n,offset:r,length:i,pos:s}=this;if(e===void 0||n===void 0)throw new Error("fd and buf must be set in READ method");let o=it.readSync(e,n,r,i,s);this[La](o),t=!1}finally{if(t)try{this[Bt](()=>{})}catch{}}}[Ua](t){t()}[Bt](t=()=>{}){this.fd!==void 0&&it.closeSync(this.fd),t()}},hy=class extends mn{blockLen=0;blockRemain=0;buf=0;pos=0;remain=0;length=0;preservePaths;portable;strict;noPax;noMtime;readEntry;type;prefix;path;mode;uid;gid;uname;gname;header;mtime;atime;ctime;linkpath;size;onWriteEntry;warn(t,e,n={}){return Ls(this,t,e,n)}constructor(t,e={}){let n=Xa(e);super(),this.preservePaths=!!n.preservePaths,this.portable=!!n.portable,this.strict=!!n.strict,this.noPax=!!n.noPax,this.noMtime=!!n.noMtime,this.onWriteEntry=n.onWriteEntry,this.readEntry=t;let{type:r}=t;if(r==="Unsupported")throw new Error("writing entry that should be ignored");this.type=r,this.type==="Directory"&&this.portable&&(this.noMtime=!0),this.prefix=n.prefix,this.path=N(t.path),this.mode=t.mode!==void 0?this[Os](t.mode):void 0,this.uid=this.portable?void 0:t.uid,this.gid=this.portable?void 0:t.gid,this.uname=this.portable?void 0:t.uname,this.gname=this.portable?void 0:t.gname,this.size=t.size,this.mtime=this.noMtime?void 0:n.mtime||t.mtime,this.atime=this.portable?void 0:t.atime,this.ctime=this.portable?void 0:t.ctime,this.linkpath=t.linkpath!==void 0?N(t.linkpath):void 0,typeof n.onwarn=="function"&&this.on("warn",n.onwarn);let i=!1;if(!this.preservePaths){let[o,a]=ec(this.path);o&&typeof a=="string"&&(this.path=a,i=o)}this.remain=t.size,this.blockRemain=t.startBlockSize,this.onWriteEntry?.(this),this.header=new gn({path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,mode:this.mode,uid:this.portable?void 0:this.uid,gid:this.portable?void 0:this.gid,size:this.size,mtime:this.noMtime?void 0:this.mtime,type:this.type,uname:this.portable?void 0:this.uname,atime:this.portable?void 0:this.atime,ctime:this.portable?void 0:this.ctime}),i&&this.warn("TAR_ENTRY_INFO",`stripping ${i} from absolute path`,{entry:this,path:i+this.path}),this.header.encode()&&!this.noPax&&super.write(new As({atime:this.portable?void 0:this.atime,ctime:this.portable?void 0:this.ctime,gid:this.portable?void 0:this.gid,mtime:this.noMtime?void 0:this.mtime,path:this[st](this.path),linkpath:this.type==="Link"&&this.linkpath!==void 0?this[st](this.linkpath):this.linkpath,size:this.size,uid:this.portable?void 0:this.uid,uname:this.portable?void 0:this.uname,dev:this.portable?void 0:this.readEntry.dev,ino:this.portable?void 0:this.readEntry.ino,nlink:this.portable?void 0:this.readEntry.nlink}).encode());let s=this.header?.block;if(!s)throw new Error("failed to encode header");super.write(s),t.pipe(this)}[st](t){return Cu(t,this.prefix)}[Os](t){return Pu(t,this.type==="Directory",this.portable)}write(t,e,n){typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,typeof e=="string"?e:"utf8"));let r=t.length;if(r>this.blockRemain)throw new Error("writing more to entry than is appropriate");return this.blockRemain-=r,super.write(t,n)}end(t,e,n){return this.blockRemain&&super.write(Buffer.alloc(this.blockRemain)),typeof t=="function"&&(n=t,e=void 0,t=void 0),typeof e=="function"&&(n=e,e=void 0),typeof t=="string"&&(t=Buffer.from(t,e??"utf8")),n&&this.once("finish",n),t?super.end(t,n):super.end(n),this}},py=t=>t.isFile()?"File":t.isDirectory()?"Directory":t.isSymbolicLink()?"SymbolicLink":"Unsupported",gy=class Jn{tail;head;length=0;static create(e=[]){return new Jn(e)}constructor(e=[]){for(let n of e)this.push(n)}*[Symbol.iterator](){for(let e=this.head;e;e=e.next)yield e.value}removeNode(e){if(e.list!==this)throw new Error("removing node which does not belong to this list");let n=e.next,r=e.prev;return n&&(n.prev=r),r&&(r.next=n),e===this.head&&(this.head=n),e===this.tail&&(this.tail=r),this.length--,e.next=void 0,e.prev=void 0,e.list=void 0,n}unshiftNode(e){if(e===this.head)return;e.list&&e.list.removeNode(e);let n=this.head;e.list=this,e.next=n,n&&(n.prev=e),this.head=e,this.tail||(this.tail=e),this.length++}pushNode(e){if(e===this.tail)return;e.list&&e.list.removeNode(e);let n=this.tail;e.list=this,e.prev=n,n&&(n.next=e),this.tail=e,this.head||(this.head=e),this.length++}push(...e){for(let n=0,r=e.length;n<r;n++)wy(this,e[n]);return this.length}unshift(...e){for(var n=0,r=e.length;n<r;n++)yy(this,e[n]);return this.length}pop(){if(!this.tail)return;let e=this.tail.value,n=this.tail;return this.tail=this.tail.prev,this.tail?this.tail.next=void 0:this.head=void 0,n.list=void 0,this.length--,e}shift(){if(!this.head)return;let e=this.head.value,n=this.head;return this.head=this.head.next,this.head?this.head.prev=void 0:this.tail=void 0,n.list=void 0,this.length--,e}forEach(e,n){n=n||this;for(let r=this.head,i=0;r;i++)e.call(n,r.value,i,this),r=r.next}forEachReverse(e,n){n=n||this;for(let r=this.tail,i=this.length-1;r;i--)e.call(n,r.value,i,this),r=r.prev}get(e){let n=0,r=this.head;for(;r&&n<e;n++)r=r.next;if(n===e&&r)return r.value}getReverse(e){let n=0,r=this.tail;for(;r&&n<e;n++)r=r.prev;if(n===e&&r)return r.value}map(e,n){n=n||this;let r=new Jn;for(let i=this.head;i;)r.push(e.call(n,i.value,this)),i=i.next;return r}mapReverse(e,n){n=n||this;var r=new Jn;for(let i=this.tail;i;)r.push(e.call(n,i.value,this)),i=i.prev;return r}reduce(e,n){let r,i=this.head;if(arguments.length>1)r=n;else if(this.head)i=this.head.next,r=this.head.value;else throw new TypeError("Reduce of empty list with no initial value");for(var s=0;i;s++)r=e(r,i.value,s),i=i.next;return r}reduceReverse(e,n){let r,i=this.tail;if(arguments.length>1)r=n;else if(this.tail)i=this.tail.prev,r=this.tail.value;else throw new TypeError("Reduce of empty list with no initial value");for(let s=this.length-1;i;s--)r=e(r,i.value,s),i=i.prev;return r}toArray(){let e=new Array(this.length);for(let n=0,r=this.head;r;n++)e[n]=r.value,r=r.next;return e}toArrayReverse(){let e=new Array(this.length);for(let n=0,r=this.tail;r;n++)e[n]=r.value,r=r.prev;return e}slice(e=0,n=this.length){n<0&&(n+=this.length),e<0&&(e+=this.length);let r=new Jn;if(n<e||n<0)return r;e<0&&(e=0),n>this.length&&(n=this.length);let i=this.head,s=0;for(s=0;i&&s<e;s++)i=i.next;for(;i&&s<n;s++,i=i.next)r.push(i.value);return r}sliceReverse(e=0,n=this.length){n<0&&(n+=this.length),e<0&&(e+=this.length);let r=new Jn;if(n<e||n<0)return r;e<0&&(e=0),n>this.length&&(n=this.length);let i=this.length,s=this.tail;for(;s&&i>n;i--)s=s.prev;for(;s&&i>e;i--,s=s.prev)r.push(s.value);return r}splice(e,n=0,...r){e>this.length&&(e=this.length-1),e<0&&(e=this.length+e);let i=this.head;for(let o=0;i&&o<e;o++)i=i.next;let s=[];for(let o=0;i&&o<n;o++)s.push(i.value),i=this.removeNode(i);i?i!==this.tail&&(i=i.prev):i=this.tail;for(let o of r)i=my(this,i,o);return s}reverse(){let e=this.head,n=this.tail;for(let r=e;r;r=r.prev){let i=r.prev;r.prev=r.next,r.next=i}return this.head=n,this.tail=e,this}};function my(t,e,n){let r=e,i=e?e.next:t.head,s=new nc(n,r,i,t);return s.next===void 0&&(t.tail=s),s.prev===void 0&&(t.head=s),t.length++,s}function wy(t,e){t.tail=new nc(e,t.tail,void 0,t),t.head||(t.head=t.tail),t.length++}function yy(t,e){t.head=new nc(e,void 0,t.head,t),t.tail||(t.tail=t.head),t.length++}var nc=class{list;next;prev;value;constructor(t,e,n,r){this.list=r,this.value=t,e?(e.next=this,this.prev=e):this.prev=void 0,n?(n.prev=this,this.next=n):this.next=void 0}},iu=class{path;absolute;entry;stat;readdir;pending=!1;pendingLink=!1;ignore=!1;piped=!1;constructor(t,e){this.path=t||"./",this.absolute=e}},su=Buffer.alloc(1024),vs=Symbol("onStat"),$r=Symbol("ended"),We=Symbol("queue"),Gr=Symbol("queue"),Nt=Symbol("current"),un=Symbol("process"),Hr=Symbol("processing"),gs=Symbol("processJob"),qe=Symbol("jobs"),Sa=Symbol("jobDone"),Is=Symbol("addFSEntry"),ou=Symbol("addTarEntry"),za=Symbol("stat"),$a=Symbol("readdir"),Ts=Symbol("onreaddir"),Rs=Symbol("pipe"),au=Symbol("entry"),va=Symbol("entryOpt"),ks=Symbol("writeEntryClass"),Nu=Symbol("write"),Ia=Symbol("ondrain"),Ms=class extends mn{sync=!1;opt;cwd;maxReadSize;preservePaths;strict;noPax;prefix;linkCache;statCache;file;portable;zip;readdirCache;noDirRecurse;follow;noMtime;mtime;filter;jobs;[ks];onWriteEntry;[We];[Gr]=new Map;[qe]=0;[Hr]=!1;[$r]=!1;constructor(t={}){if(super(),this.opt=t,this.file=t.file||"",this.cwd=t.cwd||process.cwd(),this.maxReadSize=t.maxReadSize,this.preservePaths=!!t.preservePaths,this.strict=!!t.strict,this.noPax=!!t.noPax,this.prefix=N(t.prefix||""),this.linkCache=t.linkCache||new Map,this.statCache=t.statCache||new Map,this.readdirCache=t.readdirCache||new Map,this.onWriteEntry=t.onWriteEntry,this[ks]=Du,typeof t.onwarn=="function"&&this.on("warn",t.onwarn),this.portable=!!t.portable,t.gzip||t.brotli||t.zstd){if((t.gzip?1:0)+(t.brotli?1:0)+(t.zstd?1:0)>1)throw new TypeError("gzip, brotli, zstd are mutually exclusive");if(t.gzip&&(typeof t.gzip!="object"&&(t.gzip={}),this.portable&&(t.gzip.portable=!0),this.zip=new kw(t.gzip)),t.brotli&&(typeof t.brotli!="object"&&(t.brotli={}),this.zip=new Aw(t.brotli)),t.zstd&&(typeof t.zstd!="object"&&(t.zstd={}),this.zip=new Ow(t.zstd)),!this.zip)throw new Error("impossible");let e=this.zip;e.on("data",n=>super.write(n)),e.on("end",()=>super.end()),e.on("drain",()=>this[Ia]()),this.on("resume",()=>e.resume())}else this.on("drain",this[Ia]);this.noDirRecurse=!!t.noDirRecurse,this.follow=!!t.follow,this.noMtime=!!t.noMtime,t.mtime&&(this.mtime=t.mtime),this.filter=typeof t.filter=="function"?t.filter:()=>!0,this[We]=new gy,this[qe]=0,this.jobs=Number(t.jobs)||4,this[Hr]=!1,this[$r]=!1}[Nu](t){return super.write(t)}add(t){return this.write(t),this}end(t,e,n){return typeof t=="function"&&(n=t,t=void 0),typeof e=="function"&&(n=e,e=void 0),t&&this.add(t),this[$r]=!0,this[un](),n&&n(),this}write(t){if(this[$r])throw new Error("write after end");return t instanceof xu?this[ou](t):this[Is](t),this.flowing}[ou](t){let e=N(ru.resolve(this.cwd,t.path));if(!this.filter(t.path,t))t.resume();else{let n=new iu(t.path,e);n.entry=new hy(t,this[va](n)),n.entry.on("end",()=>this[Sa](n)),this[qe]+=1,this[We].push(n)}this[un]()}[Is](t){let e=N(ru.resolve(this.cwd,t));this[We].push(new iu(t,e)),this[un]()}[za](t){t.pending=!0,this[qe]+=1;let e=this.follow?"stat":"lstat";xs[e](t.absolute,(n,r)=>{t.pending=!1,this[qe]-=1,n?this.emit("error",n):this[vs](t,r)})}[vs](t,e){if(this.statCache.set(t.absolute,e),t.stat=e,!this.filter(t.path,e))t.ignore=!0;else if(e.isFile()&&e.nlink>1&&!this.linkCache.get(`${e.dev}:${e.ino}`)&&!this.sync)if(t===this[Nt])this[gs](t);else{let n=`${e.dev}:${e.ino}`,r=this[Gr].get(n);r?r.push(t):this[Gr].set(n,[t]),t.pendingLink=!0,t.pending=!0}this[un]()}[$a](t){t.pending=!0,this[qe]+=1,xs.readdir(t.absolute,(e,n)=>{if(t.pending=!1,this[qe]-=1,e)return this.emit("error",e);this[Ts](t,n)})}[Ts](t,e){this.readdirCache.set(t.absolute,e),t.readdir=e,this[un]()}[un](){if(!this[Hr]){this[Hr]=!0;for(let t=this[We].head;t&&this[qe]<this.jobs;t=t.next)if(this[gs](t.value),t.value.ignore){let e=t.next;this[We].removeNode(t),t.next=e}this[Hr]=!1,this[$r]&&this[We].length===0&&this[qe]===0&&(this.zip?this.zip.end(su):(super.write(su),super.end()))}}get[Nt](){return this[We]&&this[We].head&&this[We].head.value}[Sa](t){this[We].shift(),this[qe]-=1;let{stat:e}=t;if(e&&e.isFile()&&e.nlink>1){let n=`${e.dev}:${e.ino}`,r=this[Gr].get(n);if(r){this[Gr].delete(n);for(let i of r)i.pending=!1,this[gs](i)}}this[un]()}[gs](t){if(t.pending&&t.pendingLink&&t===this[Nt]&&(t.pending=!1,t.pendingLink=!1),!t.pending){if(t.entry){t===this[Nt]&&!t.piped&&this[Rs](t);return}if(!t.stat){let e=this.statCache.get(t.absolute);e?this[vs](t,e):this[za](t)}if(t.stat&&!t.ignore){if(!this.noDirRecurse&&t.stat.isDirectory()&&!t.readdir){let e=this.readdirCache.get(t.absolute);if(e?this[Ts](t,e):this[$a](t),!t.readdir)return}if(t.entry=this[au](t),!t.entry){t.ignore=!0;return}t===this[Nt]&&!t.piped&&this[Rs](t)}}}[va](t){return{onwarn:(e,n,r)=>this.warn(e,n,r),noPax:this.noPax,cwd:this.cwd,absolute:t.absolute,preservePaths:this.preservePaths,maxReadSize:this.maxReadSize,strict:this.strict,portable:this.portable,linkCache:this.linkCache,statCache:this.statCache,noMtime:this.noMtime,mtime:this.mtime,prefix:this.prefix,onWriteEntry:this.onWriteEntry}}[au](t){this[qe]+=1;try{return new this[ks](t.path,this[va](t)).on("end",()=>this[Sa](t)).on("error",e=>this.emit("error",e))}catch(e){this.emit("error",e)}}[Ia](){this[Nt]&&this[Nt].entry&&this[Nt].entry.resume()}[Rs](t){t.piped=!0,t.readdir&&t.readdir.forEach(r=>{let i=t.path,s=i==="./"?"":i.replace(/\/*$/,"/");this[Is](s+r)});let e=t.entry,n=this.zip;if(!e)throw new Error("cannot pipe without source");n?e.on("data",r=>{n.write(r)||e.pause()}):e.on("data",r=>{super.write(r)||e.pause()})}pause(){return this.zip&&this.zip.pause(),super.pause()}warn(t,e,n={}){Ls(this,t,e,n)}},rc=class extends Ms{sync=!0;constructor(t){super(t),this[ks]=fy}pause(){}resume(){}[za](t){let e=this.follow?"statSync":"lstatSync";this[vs](t,xs[e](t.absolute))}[$a](t){this[Ts](t,xs.readdirSync(t.absolute))}[Rs](t){let e=t.entry,n=this.zip;if(t.readdir&&t.readdir.forEach(r=>{let i=t.path,s=i==="./"?"":i.replace(/\/*$/,"/");this[Is](s+r)}),!e)throw new Error("Cannot pipe without source");n?e.on("data",r=>{n.write(r)}):e.on("data",r=>{super[Nu](r)})}},_y=(t,e)=>{let n=new rc(t),r=new Su(t.file,{mode:t.mode||438});n.pipe(r),Lu(n,e)},Ey=(t,e)=>{let n=new Ms(t),r=new Ds(t.file,{mode:t.mode||438});n.pipe(r);let i=new Promise((s,o)=>{r.on("error",o),r.on("close",s),n.on("error",o)});return Fu(n,e).catch(s=>n.emit("error",s)),i},Lu=(t,e)=>{e.forEach(n=>{n.charAt(0)==="@"?Xn({file:vu.resolve(t.cwd,n.slice(1)),sync:!0,noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n)}),t.end()},Fu=async(t,e)=>{for(let n of e)n.charAt(0)==="@"?await Xn({file:vu.resolve(String(t.cwd),n.slice(1)),noResume:!0,onReadEntry:r=>{t.add(r)}}):t.add(n);t.end()},Sy=(t,e)=>{let n=new rc(t);return Lu(n,e),n},vy=(t,e)=>{let n=new Ms(t);return Fu(n,e).catch(r=>n.emit("error",r)),n},fk=ni(_y,Ey,Sy,vy,(t,e)=>{if(!e?.length)throw new TypeError("no paths specified to add to archive")}),Ty=process.env.__FAKE_PLATFORM__||process.platform,zu=Ty==="win32",{O_CREAT:$u,O_NOFOLLOW:cu,O_TRUNC:Gu,O_WRONLY:Hu}=Uu.constants,ju=Number(process.env.__FAKE_FS_O_FILENAME__)||Uu.constants.UV_FS_O_FILEMAP||0,Ry=zu&&!!ju,ky=512*1024,by=ju|Gu|$u|Hu,lu=!zu&&typeof cu=="number"?cu|Gu|$u|Hu:null,Wu=lu!==null?()=>lu:Ry?t=>t<ky?by:"w":()=>"w",Ga=(t,e,n)=>{try{return Bs.lchownSync(t,e,n)}catch(r){if(r?.code!=="ENOENT")throw r}},Ps=(t,e,n,r)=>{Bs.lchown(t,e,n,i=>{r(i&&i?.code!=="ENOENT"?i:null)})},Ay=(t,e,n,r,i)=>{if(e.isDirectory())qu(Zr.resolve(t,e.name),n,r,s=>{if(s)return i(s);let o=Zr.resolve(t,e.name);Ps(o,n,r,i)});else{let s=Zr.resolve(t,e.name);Ps(s,n,r,i)}},qu=(t,e,n,r)=>{Bs.readdir(t,{withFileTypes:!0},(i,s)=>{if(i){if(i.code==="ENOENT")return r();if(i.code!=="ENOTDIR"&&i.code!=="ENOTSUP")return r(i)}if(i||!s.length)return Ps(t,e,n,r);let o=s.length,a=null,c=l=>{if(!a){if(l)return r(a=l);if(--o===0)return Ps(t,e,n,r)}};for(let l of s)Ay(t,l,e,n,c)})},xy=(t,e,n,r)=>{e.isDirectory()&&Vu(Zr.resolve(t,e.name),n,r),Ga(Zr.resolve(t,e.name),n,r)},Vu=(t,e,n)=>{let r;try{r=Bs.readdirSync(t,{withFileTypes:!0})}catch(i){let s=i;if(s?.code==="ENOENT")return;if(s?.code==="ENOTDIR"||s?.code==="ENOTSUP")return Ga(t,e,n);throw s}for(let i of r)xy(t,i,e,n);return Ga(t,e,n)},Ju=class extends Error{path;code;syscall="chdir";constructor(t,e){super(`${e}: Cannot cd into '${t}'`),this.path=t,this.code=e}get name(){return"CwdError"}},Us=class extends Error{path;symlink;syscall="symlink";code="TAR_SYMLINK_ERROR";constructor(t,e){super("TAR_SYMLINK_ERROR: Cannot extract through symbolic link"),this.symlink=t,this.path=e}get name(){return"SymlinkError"}},Py=(t,e)=>{De.stat(t,(n,r)=>{(n||!r.isDirectory())&&(n=new Ju(t,n?.code||"ENOTDIR")),e(n)})},Cy=(t,e,n)=>{t=N(t);let r=e.umask??18,i=e.mode|448,s=(i&r)!==0,o=e.uid,a=e.gid,c=typeof o=="number"&&typeof a=="number"&&(o!==e.processUid||a!==e.processGid),l=e.preserve,d=e.unlink,p=N(e.cwd),m=(h,g)=>{h?n(h):g&&c?qu(g,o,a,w=>m(w)):s?De.chmod(t,i,n):n()};if(t===p)return Py(t,m);if(l)return Oy.mkdir(t,{mode:i,recursive:!0}).then(h=>m(null,h??void 0),m);let u=N(Cs.relative(p,t)).split("/");Ha(p,u,i,d,p,void 0,m)},Ha=(t,e,n,r,i,s,o)=>{if(e.length===0)return o(null,s);let a=e.shift(),c=N(Cs.resolve(t+"/"+a));De.mkdir(c,n,Zu(c,e,n,r,i,s,o))},Zu=(t,e,n,r,i,s,o)=>a=>{a?De.lstat(t,(c,l)=>{if(c)c.path=c.path&&N(c.path),o(c);else if(l.isDirectory())Ha(t,e,n,r,i,s,o);else if(r)De.unlink(t,d=>{if(d)return o(d);De.mkdir(t,n,Zu(t,e,n,r,i,s,o))});else{if(l.isSymbolicLink())return o(new Us(t,t+"/"+e.join("/")));o(a)}}):(s=s||t,Ha(t,e,n,r,i,s,o))},Dy=t=>{let e=!1,n;try{e=De.statSync(t).isDirectory()}catch(r){n=r?.code}finally{if(!e)throw new Ju(t,n??"ENOTDIR")}},Ny=(t,e)=>{t=N(t);let n=e.umask??18,r=e.mode|448,i=(r&n)!==0,s=e.uid,o=e.gid,a=typeof s=="number"&&typeof o=="number"&&(s!==e.processUid||o!==e.processGid),c=e.preserve,l=e.unlink,d=N(e.cwd),p=h=>{h&&a&&Vu(h,s,o),i&&De.chmodSync(t,r)};if(t===d)return Dy(d),p();if(c)return p(De.mkdirSync(t,{mode:r,recursive:!0})??void 0);let m=N(Cs.relative(d,t)).split("/"),u;for(let h=m.shift(),g=d;h&&(g+="/"+h);h=m.shift()){g=N(Cs.resolve(g));try{De.mkdirSync(g,r),u=u||g}catch{let w=De.lstatSync(g);if(w.isDirectory())continue;if(l){De.unlinkSync(g),De.mkdirSync(g,r),u=u||g;continue}else if(w.isSymbolicLink())return new Us(g,g+"/"+m.join("/"))}}return p(u)},Ta=Object.create(null),du=1e4,Gn=new Set,Ly=t=>{Gn.has(t)?Gn.delete(t):Ta[t]=t.normalize("NFD").toLocaleLowerCase("en").toLocaleUpperCase("en"),Gn.add(t);let e=Ta[t],n=Gn.size-du;if(n>du/10){for(let r of Gn)if(Gn.delete(r),delete Ta[r],--n<=0)break}return e},Fy=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,My=Fy==="win32",By=t=>t.split("/").slice(0,-1).reduce((e,n)=>{let r=e.at(-1);return r!==void 0&&(n=Ku(r,n)),e.push(n||"/"),e},[]),Uy=class{#e=new Map;#n=new Map;#r=new Set;reserve(t,e){t=My?["win32 parallelization disabled"]:t.map(r=>Jr(Ku(Ly(r))));let n=new Set(t.map(r=>By(r)).reduce((r,i)=>r.concat(i)));this.#n.set(e,{dirs:n,paths:t});for(let r of t){let i=this.#e.get(r);i?i.push(e):this.#e.set(r,[e])}for(let r of n){let i=this.#e.get(r);if(!i)this.#e.set(r,[new Set([e])]);else{let s=i.at(-1);s instanceof Set?s.add(e):i.push(new Set([e]))}}return this.#i(e)}#s(t){let e=this.#n.get(t);if(!e)throw new Error("function does not have any path reservations");return{paths:e.paths.map(n=>this.#e.get(n)),dirs:[...e.dirs].map(n=>this.#e.get(n))}}check(t){let{paths:e,dirs:n}=this.#s(t);return e.every(r=>r&&r[0]===t)&&n.every(r=>r&&r[0]instanceof Set&&r[0].has(t))}#i(t){return this.#r.has(t)||!this.check(t)?!1:(this.#r.add(t),t(()=>this.#t(t)),!0)}#t(t){if(!this.#r.has(t))return!1;let e=this.#n.get(t);if(!e)throw new Error("invalid reservation");let{paths:n,dirs:r}=e,i=new Set;for(let s of n){let o=this.#e.get(s);if(!o||o?.[0]!==t)continue;let a=o[1];if(!a){this.#e.delete(s);continue}if(o.shift(),typeof a=="function")i.add(a);else for(let c of a)i.add(c)}for(let s of r){let o=this.#e.get(s),a=o?.[0];if(!(!o||!(a instanceof Set)))if(a.size===1&&o.length===1){this.#e.delete(s);continue}else if(a.size===1){o.shift();let c=o[0];typeof c=="function"&&i.add(c)}else a.delete(t)}return this.#r.delete(t),i.forEach(s=>this.#i(s)),!0}},zy=()=>process.umask(),uu=Symbol("onEntry"),ja=Symbol("checkFs"),fu=Symbol("checkFs2"),Wa=Symbol("isReusable"),Be=Symbol("makeFs"),qa=Symbol("file"),Va=Symbol("directory"),bs=Symbol("link"),hu=Symbol("symlink"),pu=Symbol("hardlink"),qr=Symbol("ensureNoSymlink"),gu=Symbol("unsupported"),mu=Symbol("checkPath"),Ra=Symbol("stripAbsolutePath"),Ut=Symbol("mkdir"),he=Symbol("onError"),ms=Symbol("pending"),wu=Symbol("pend"),Hn=Symbol("unpend"),ka=Symbol("ended"),ba=Symbol("maybeClose"),Ja=Symbol("skip"),Kr=Symbol("doChown"),Xr=Symbol("uid"),Yr=Symbol("gid"),Qr=Symbol("checkedCwd"),$y=process.env.TESTING_TAR_FAKE_PLATFORM||process.platform,ei=$y==="win32",Gy=1024,Hy=(t,e)=>{if(!ei)return B.unlink(t,e);let n=t+".DELETE."+Bu(16).toString("hex");B.rename(t,n,r=>{if(r)return e(r);B.unlink(n,e)})},jy=t=>{if(!ei)return B.unlinkSync(t);let e=t+".DELETE."+Bu(16).toString("hex");B.renameSync(t,e),B.unlinkSync(e)},yu=(t,e,n)=>t!==void 0&&t===t>>>0?t:e!==void 0&&e===e>>>0?e:n,ic=class extends ti{[ka]=!1;[Qr]=!1;[ms]=0;reservations=new Uy;transform;writable=!0;readable=!1;uid;gid;setOwner;preserveOwner;processGid;processUid;maxDepth;forceChown;win32;newer;keep;noMtime;preservePaths;unlink;cwd;strip;processUmask;umask;dmode;fmode;chmod;constructor(t={}){if(t.ondone=()=>{this[ka]=!0,this[ba]()},super(t),this.transform=t.transform,this.chmod=!!t.chmod,typeof t.uid=="number"||typeof t.gid=="number"){if(typeof t.uid!="number"||typeof t.gid!="number")throw new TypeError("cannot set owner without number uid and gid");if(t.preserveOwner)throw new TypeError("cannot preserve owner in archive and also set owner explicitly");this.uid=t.uid,this.gid=t.gid,this.setOwner=!0}else this.uid=void 0,this.gid=void 0,this.setOwner=!1;this.preserveOwner=t.preserveOwner===void 0&&typeof t.uid!="number"?!!(process.getuid&&process.getuid()===0):!!t.preserveOwner,this.processUid=(this.preserveOwner||this.setOwner)&&process.getuid?process.getuid():void 0,this.processGid=(this.preserveOwner||this.setOwner)&&process.getgid?process.getgid():void 0,this.maxDepth=typeof t.maxDepth=="number"?t.maxDepth:Gy,this.forceChown=t.forceChown===!0,this.win32=!!t.win32||ei,this.newer=!!t.newer,this.keep=!!t.keep,this.noMtime=!!t.noMtime,this.preservePaths=!!t.preservePaths,this.unlink=!!t.unlink,this.cwd=N(ie.resolve(t.cwd||process.cwd())),this.strip=Number(t.strip)||0,this.processUmask=this.chmod?typeof t.processUmask=="number"?t.processUmask:zy():0,this.umask=typeof t.umask=="number"?t.umask:this.processUmask,this.dmode=t.dmode||511&~this.umask,this.fmode=t.fmode||438&~this.umask,this.on("entry",e=>this[uu](e))}warn(t,e,n={}){return(t==="TAR_BAD_ARCHIVE"||t==="TAR_ABORT")&&(n.recoverable=!1),super.warn(t,e,n)}[ba](){this[ka]&&this[ms]===0&&(this.emit("prefinish"),this.emit("finish"),this.emit("end"))}[Ra](t,e){let n=t[e],{type:r}=t;if(!n||this.preservePaths)return!0;let[i,s]=ec(n),o=s.replaceAll(/\\/g,"/").split("/");if(o.includes("..")||ei&&/^[a-z]:\.\.$/i.test(o[0]??"")){if(e==="path"||r==="Link")return this.warn("TAR_ENTRY_ERROR",`${e} contains '..'`,{entry:t,[e]:n}),!1;let a=ie.posix.dirname(t.path),c=ie.posix.normalize(ie.posix.join(a,o.join("/")));if(c.startsWith("../")||c==="..")return this.warn("TAR_ENTRY_ERROR",`${e} escapes extraction directory`,{entry:t,[e]:n}),!1}return i&&(t[e]=String(s),this.warn("TAR_ENTRY_INFO",`stripping ${i} from absolute ${e}`,{entry:t,[e]:n})),!0}[mu](t){let e=N(t.path),n=e.split("/");if(this.strip){if(n.length<this.strip)return!1;if(t.type==="Link"){let r=N(String(t.linkpath)).split("/");if(r.length>=this.strip)t.linkpath=r.slice(this.strip).join("/");else return!1}n.splice(0,this.strip),t.path=n.join("/")}if(isFinite(this.maxDepth)&&n.length>this.maxDepth)return this.warn("TAR_ENTRY_ERROR","path excessively deep",{entry:t,path:e,depth:n.length,maxDepth:this.maxDepth}),!1;if(!this[Ra](t,"path")||!this[Ra](t,"linkpath"))return!1;if(t.absolute=ie.isAbsolute(t.path)?N(ie.resolve(t.path)):N(ie.resolve(this.cwd,t.path)),!this.preservePaths&&typeof t.absolute=="string"&&t.absolute.indexOf(this.cwd+"/")!==0&&t.absolute!==this.cwd)return this.warn("TAR_ENTRY_ERROR","path escaped extraction target",{entry:t,path:N(t.path),resolvedPath:t.absolute,cwd:this.cwd}),!1;if(t.absolute===this.cwd&&t.type!=="Directory"&&t.type!=="GNUDumpDir")return!1;if(this.win32){let{root:r}=ie.win32.parse(String(t.absolute));t.absolute=r+Yd(String(t.absolute).slice(r.length));let{root:i}=ie.win32.parse(t.path);t.path=i+Yd(t.path.slice(i.length))}return!0}[uu](t){if(!this[mu](t))return t.resume();switch(Iy.equal(typeof t.absolute,"string"),t.type){case"Directory":case"GNUDumpDir":t.mode&&(t.mode=t.mode|448);case"File":case"OldFile":case"ContiguousFile":case"Link":case"SymbolicLink":return this[ja](t);default:return this[gu](t)}}[he](t,e){t.name==="CwdError"?this.emit("error",t):(this.warn("TAR_ENTRY_ERROR",t,{entry:e}),this[Hn](),e.resume())}[Ut](t,e,n){Cy(N(t),{uid:this.uid,gid:this.gid,processUid:this.processUid,processGid:this.processGid,umask:this.processUmask,preserve:this.preservePaths,unlink:this.unlink,cwd:this.cwd,mode:e},n)}[Kr](t){return this.forceChown||this.preserveOwner&&(typeof t.uid=="number"&&t.uid!==this.processUid||typeof t.gid=="number"&&t.gid!==this.processGid)||typeof this.uid=="number"&&this.uid!==this.processUid||typeof this.gid=="number"&&this.gid!==this.processGid}[Xr](t){return yu(this.uid,t.uid,this.processUid)}[Yr](t){return yu(this.gid,t.gid,this.processGid)}[qa](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.fmode,r=new Ds(String(t.absolute),{flags:Wu(t.size),mode:n,autoClose:!1});r.on("error",a=>{r.fd&&B.close(r.fd,()=>{}),r.write=()=>!0,this[he](a,t),e()});let i=1,s=a=>{if(a){r.fd&&B.close(r.fd,()=>{}),this[he](a,t),e();return}--i===0&&r.fd!==void 0&&B.close(r.fd,c=>{c?this[he](c,t):this[Hn](),e()})};r.on("finish",()=>{let a=String(t.absolute),c=r.fd;if(typeof c=="number"&&t.mtime&&!this.noMtime){i++;let l=t.atime||new Date,d=t.mtime;B.futimes(c,l,d,p=>p?B.utimes(a,l,d,m=>s(m&&p)):s())}if(typeof c=="number"&&this[Kr](t)){i++;let l=this[Xr](t),d=this[Yr](t);typeof l=="number"&&typeof d=="number"&&B.fchown(c,l,d,p=>p?B.chown(a,l,d,m=>s(m&&p)):s())}s()});let o=this.transform&&this.transform(t)||t;o!==t&&(o.on("error",a=>{this[he](a,t),e()}),t.pipe(o)),o.pipe(r)}[Va](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.dmode;this[Ut](String(t.absolute),n,r=>{if(r){this[he](r,t),e();return}let i=1,s=()=>{--i===0&&(e(),this[Hn](),t.resume())};t.mtime&&!this.noMtime&&(i++,B.utimes(String(t.absolute),t.atime||new Date,t.mtime,s)),this[Kr](t)&&(i++,B.chown(String(t.absolute),Number(this[Xr](t)),Number(this[Yr](t)),s)),s()})}[gu](t){t.unsupported=!0,this.warn("TAR_ENTRY_UNSUPPORTED",`unsupported entry type: ${t.type}`,{entry:t}),t.resume()}[hu](t,e){let n=N(ie.relative(this.cwd,ie.resolve(ie.dirname(String(t.absolute)),String(t.linkpath)))).split("/");this[qr](t,this.cwd,n,()=>this[bs](t,String(t.linkpath),"symlink",e),r=>{this[he](r,t),e()})}[pu](t,e){let n=N(ie.resolve(this.cwd,String(t.linkpath))),r=N(String(t.linkpath)).split("/");this[qr](t,this.cwd,r,()=>this[bs](t,n,"link",e),i=>{this[he](i,t),e()})}[qr](t,e,n,r,i){let s=n.shift();if(this.preservePaths||s===void 0)return r();let o=ie.resolve(e,s);B.lstat(o,(a,c)=>{if(a)return r();if(c?.isSymbolicLink())return i(new Us(o,ie.resolve(o,n.join("/"))));this[qr](t,o,n,r,i)})}[wu](){this[ms]++}[Hn](){this[ms]--,this[ba]()}[Ja](t){this[Hn](),t.resume()}[Wa](t,e){return t.type==="File"&&!this.unlink&&e.isFile()&&e.nlink<=1&&!ei}[ja](t){this[wu]();let e=[t.path];t.linkpath&&e.push(t.linkpath),this.reservations.reserve(e,n=>this[fu](t,n))}[fu](t,e){let n=o=>{e(o)},r=()=>{this[Ut](this.cwd,this.dmode,o=>{if(o){this[he](o,t),n();return}this[Qr]=!0,i()})},i=()=>{if(t.absolute!==this.cwd){let o=N(ie.dirname(String(t.absolute)));if(o!==this.cwd)return this[Ut](o,this.dmode,a=>{if(a){this[he](a,t),n();return}s()})}s()},s=()=>{B.lstat(String(t.absolute),(o,a)=>{if(a&&(this.keep||this.newer&&a.mtime>(t.mtime??a.mtime))){this[Ja](t),n();return}if(o||this[Wa](t,a))return this[Be](null,t,n);if(a.isDirectory()){if(t.type==="Directory"){let c=this.chmod&&t.mode&&(a.mode&4095)!==t.mode,l=d=>this[Be](d??null,t,n);return c?B.chmod(String(t.absolute),Number(t.mode),l):l()}if(t.absolute!==this.cwd)return B.rmdir(String(t.absolute),c=>this[Be](c??null,t,n))}if(t.absolute===this.cwd)return this[Be](null,t,n);Hy(String(t.absolute),c=>this[Be](c??null,t,n))})};this[Qr]?i():r()}[Be](t,e,n){if(t){this[he](t,e),n();return}switch(e.type){case"File":case"OldFile":case"ContiguousFile":return this[qa](e,n);case"Link":return this[pu](e,n);case"SymbolicLink":return this[hu](e,n);case"Directory":case"GNUDumpDir":return this[Va](e,n)}}[bs](t,e,n,r){B[n](e,String(t.absolute),i=>{i?this[he](i,t):(this[Hn](),t.resume()),r()})}},jr=t=>{try{return[null,t()]}catch(e){return[e,null]}},Xu=class extends ic{sync=!0;[Be](t,e){return super[Be](t,e,()=>{})}[ja](t){if(!this[Qr]){let i=this[Ut](this.cwd,this.dmode);if(i)return this[he](i,t);this[Qr]=!0}if(t.absolute!==this.cwd){let i=N(ie.dirname(String(t.absolute)));if(i!==this.cwd){let s=this[Ut](i,this.dmode);if(s)return this[he](s,t)}}let[e,n]=jr(()=>B.lstatSync(String(t.absolute)));if(n&&(this.keep||this.newer&&n.mtime>(t.mtime??n.mtime)))return this[Ja](t);if(e||this[Wa](t,n))return this[Be](null,t);if(n.isDirectory()){if(t.type==="Directory"){let s=this.chmod&&t.mode&&(n.mode&4095)!==t.mode,[o]=s?jr(()=>{B.chmodSync(String(t.absolute),Number(t.mode))}):[];return this[Be](o,t)}let[i]=jr(()=>B.rmdirSync(String(t.absolute)));this[Be](i,t)}let[r]=t.absolute===this.cwd?[]:jr(()=>jy(String(t.absolute)));this[Be](r,t)}[qa](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.fmode,r=o=>{let a;try{B.closeSync(i)}catch(c){a=c}(o||a)&&this[he](o||a,t),e()},i;try{i=B.openSync(String(t.absolute),Wu(t.size),n)}catch(o){return r(o)}let s=this.transform&&this.transform(t)||t;s!==t&&(s.on("error",o=>this[he](o,t)),t.pipe(s)),s.on("data",o=>{try{B.writeSync(i,o,0,o.length)}catch(a){r(a)}}),s.on("end",()=>{let o=null;if(t.mtime&&!this.noMtime){let a=t.atime||new Date,c=t.mtime;try{B.futimesSync(i,a,c)}catch(l){try{B.utimesSync(String(t.absolute),a,c)}catch{o=l}}}if(this[Kr](t)){let a=this[Xr](t),c=this[Yr](t);try{B.fchownSync(i,Number(a),Number(c))}catch(l){try{B.chownSync(String(t.absolute),Number(a),Number(c))}catch{o=o||l}}}r(o)})}[Va](t,e){let n=typeof t.mode=="number"?t.mode&4095:this.dmode,r=this[Ut](String(t.absolute),n);if(r){this[he](r,t),e();return}if(t.mtime&&!this.noMtime)try{B.utimesSync(String(t.absolute),t.atime||new Date,t.mtime)}catch{}if(this[Kr](t))try{B.chownSync(String(t.absolute),Number(this[Xr](t)),Number(this[Yr](t)))}catch{}e(),t.resume()}[Ut](t,e){try{return Ny(N(t),{uid:this.uid,gid:this.gid,processUid:this.processUid,processGid:this.processGid,umask:this.processUmask,preserve:this.preservePaths,unlink:this.unlink,cwd:this.cwd,mode:e})}catch(n){return n}}[qr](t,e,n,r,i){if(this.preservePaths||n.length===0)return r();let s=e;for(let o of n){s=ie.resolve(s,o);let[a,c]=jr(()=>B.lstatSync(s));if(a)return r();if(c.isSymbolicLink())return i(new Us(s,ie.resolve(e,n.join("/"))))}r()}[bs](t,e,n,r){let i=`${n}Sync`;try{B[i](e,String(t.absolute)),r(),t.resume()}catch(s){return this[he](s,t)}}},Wy=t=>{let e=new Xu(t),n=t.file,r=Mu.statSync(n),i=t.maxReadSize||16*1024*1024;new uw(n,{readSize:i,size:r.size}).pipe(e)},qy=(t,e)=>{let n=new ic(t),r=t.maxReadSize||16*1024*1024,i=t.file;return new Promise((s,o)=>{n.on("error",o),n.on("close",s),Mu.stat(i,(a,c)=>{if(a)o(a);else{let l=new Ka(i,{readSize:r,size:c.size});l.on("error",o),l.pipe(n)}})})},Yu=ni(Wy,qy,t=>new Xu(t),t=>new ic(t),(t,e)=>{e?.length&&Ou(t,e)}),Vy=(t,e)=>{let n=new rc(t),r=!0,i,s;try{try{i=Ce.openSync(t.file,"r+")}catch(c){if(c?.code==="ENOENT")i=Ce.openSync(t.file,"w+");else throw c}let o=Ce.fstatSync(i),a=Buffer.alloc(512);e:for(s=0;s<o.size;s+=512){for(let d=0,p=0;d<512;d+=p){if(p=Ce.readSync(i,a,d,a.length-d,s+d),s===0&&a[0]===31&&a[1]===139)throw new Error("cannot append to compressed archives");if(!p)break e}let c=new gn(a);if(!c.cksumValid)break;let l=512*Math.ceil((c.size||0)/512);if(s+l+512>o.size)break;s+=l,t.mtimeCache&&c.mtime&&t.mtimeCache.set(String(c.path),c.mtime)}r=!1,Jy(t,n,s,i,e)}finally{if(r)try{Ce.closeSync(i)}catch{}}},Jy=(t,e,n,r,i)=>{let s=new Su(t.file,{fd:r,start:n});e.pipe(s),Ky(e,i)},Zy=(t,e)=>{e=Array.from(e);let n=new Ms(t),r=(i,s,o)=>{let a=(m,u)=>{m?Ce.close(i,h=>o(m)):o(null,u)},c=0;if(s===0)return a(null,0);let l=0,d=Buffer.alloc(512),p=(m,u)=>{if(m||u===void 0)return a(m);if(l+=u,l<512&&u)return Ce.read(i,d,l,d.length-l,c+l,p);if(c===0&&d[0]===31&&d[1]===139)return a(new Error("cannot append to compressed archives"));if(l<512)return a(null,c);let h=new gn(d);if(!h.cksumValid)return a(null,c);let g=512*Math.ceil((h.size??0)/512);if(c+g+512>s||(c+=g+512,c>=s))return a(null,c);t.mtimeCache&&h.mtime&&t.mtimeCache.set(String(h.path),h.mtime),l=0,Ce.read(i,d,0,512,c,p)};Ce.read(i,d,0,512,c,p)};return new Promise((i,s)=>{n.on("error",s);let o="r+",a=(c,l)=>{if(c&&c.code==="ENOENT"&&o==="r+")return o="w+",Ce.open(t.file,o,a);if(c||!l)return s(c);Ce.fstat(l,(d,p)=>{if(d)return Ce.close(l,()=>s(d));r(l,p.size,(m,u)=>{if(m)return s(m);let h=new Ds(t.file,{fd:l,start:u});n.pipe(h),h.on("error",s),h.on("close",i),Xy(n,e)})})};Ce.open(t.file,o,a)})},Ky=(t,e)=>{e.forEach(n=>{n.charAt(0)==="@"?Xn({file:Qu.resolve(t.cwd,n.slice(1)),sync:!0,noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n)}),t.end()},Xy=async(t,e)=>{for(let n of e)n.charAt(0)==="@"?await Xn({file:Qu.resolve(String(t.cwd),n.slice(1)),noResume:!0,onReadEntry:r=>t.add(r)}):t.add(n);t.end()},Wr=ni(Vy,Zy,()=>{throw new TypeError("file is required")},()=>{throw new TypeError("file is required")},(t,e)=>{if(!_w(t))throw new TypeError("file is required");if(t.gzip||t.brotli||t.zstd||t.file.endsWith(".br")||t.file.endsWith(".tbr"))throw new TypeError("cannot append to compressed archives");if(!e?.length)throw new TypeError("no paths specified to add/replace")}),bk=ni(Wr.syncFile,Wr.asyncFile,Wr.syncNoFile,Wr.asyncNoFile,(t,e=[])=>{Wr.validate?.(t,e),Yy(t)}),Yy=t=>{let e=t.filter;t.mtimeCache||(t.mtimeCache=new Map),t.filter=e?(n,r)=>e(n,r)&&!((t.mtimeCache?.get(n)??r.mtime??0)>(r.mtime??0)):(n,r)=>!((t.mtimeCache?.get(n)??r.mtime??0)>(r.mtime??0))};At();var Ze={PAIR:"_agent/pair",CREATE:"_agent/create",HEALTH:"_agent/health",LIST_SKILLS:"_agent/listSkills",ADD_SKILLS:"_agent/addSkills",REMOVE_SKILLS:"_agent/removeSkills",GET_FILE_TREE:"_agent/getFileTree",GET_FILE_CONTENT:"_agent/getFileContent",DETAIL:"_agent/detail",UPDATE:"_agent/update",DISCONNECT:"_agent/disconnect",SWITCH_MODEL:"_agent/switchModel",GEN_MODEL_TOKEN:"_agent/genModelToken",RESET:"_agent/reset",REPAIR:"_agent/repair",DELETE:"_agent/delete"};function ri(t){return t?.cozeDeployType==="cloud"?"cloud":"local"}function ef(t){let e=t?.cozeAccountId?.trim();if(!(!e||e==="0"))return e}function sc(t){let e=t?.cozeGroupId?.trim();if(!(!e||e==="0"))return e}function tf(t){let{_meta:e,...n}=t;return{stripped:n,meta:e}}function Yn(t){if(!t?.cozeAgentId)throw new Error("missing _meta.cozeAgentId");return t.cozeAgentId}Te();L();le();Te();function vt(t,e){if(ri(t)!=="cloud")throw new _("OPERATION_NOT_ALLOWED_FOR_LOCAL",`${e} is not allowed for local agent`)}function zs(t){return t.startsWith("http://")||t.startsWith("https://")}function $s(t){return t.endsWith("/")?t.slice(0,-1):t}Te();L();var Gs="1008033",nf="1289";var rf="pbbp2",sf="https://www.coze.cn",of="/api/coze_claw/resource/get_frontier_key",e_="https://www.coze.cn",t_="wss://frontier.coze.cn";function Hs(t){return t??process.env.COZE_BRIDGE_HANDSHAKE_URL??e_}function af(t){return t??process.env.COZE_BRIDGE_FRONTIER_URL??t_}function Qn(t){let e={},n=t?.ttEnv??process.env.COZE_BRIDGE_TT_ENV,r=t?.usePpe??process.env.COZE_BRIDGE_USE_PPE;return n&&(e["x-tt-env"]=n),r&&(e["x-use-ppe"]=r),e}function si(t){return t?t.startsWith("boe_")?{ttEnv:t}:{ttEnv:t,usePpe:"1"}:{}}var ii=b("handshake");async function oc(t){let e=Hs(t.endpoint),n=t.timeoutMs??1e4,r=`${$s(e)}${of}?aid=${encodeURIComponent(Gs)}`,i={Authorization:`Bearer ${t.privatecode}`,Accept:"application/json",...Qn(t.ppeOverride)},s=new AbortController,o=setTimeout(()=>s.abort(),n);ii.info("frontier key handshake",{base:e});try{let a=await fetch(r,{method:"GET",headers:i,signal:s.signal}),c=a.headers.get("x-tt-logid")??"",l=a.headers.get("x-tt-trace-id")??"";if(!a.ok){let h=await a.text().catch(()=>"");throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake HTTP ${a.status} logid=${c}: ${h.slice(0,200)}`)}let d=await a.json();if(d.code!==void 0&&d.code!==0)throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake code=${d.code} msg=${d.msg??"-"} logid=${c}`);let p=d.data??{},m=typeof p.access_key=="string"&&p.access_key||typeof p.accessKey=="string"&&p.accessKey||void 0,u=typeof p.device_id=="string"&&p.device_id||typeof p.deviceId=="string"&&p.deviceId||void 0;if(!m||!u){let h=JSON.stringify(d).slice(0,500);throw new _("UPSTREAM_HANDSHAKE_FAILED",`handshake response missing access_key/device_id (also tried camelCase) logid=${c}: ${h}`)}return ii.info("handshake ok",{remoteDeviceId:u,logid:c,traceId:l}),{accessKey:m,deviceId:u}}catch(a){if(a instanceof _)throw ii.error("handshake failed (bridge error)",{base:e,message:a.message,code:a.code}),a;if(a.name==="AbortError")throw ii.warn("handshake timeout",{base:e,timeoutMs:n}),new _("UPSTREAM_HANDSHAKE_FAILED",`handshake timeout (${n}ms)`,{cause:a});let c=a.cause;throw ii.error("handshake error",{base:e,message:a instanceof Error?a.message:String(a),errno:c?.code,syscall:c?.syscall,cause:String(a).slice(0,300)}),new _("UPSTREAM_HANDSHAKE_FAILED",String(a),{cause:a})}finally{clearTimeout(o)}}var ac=process.env.COZE_BRIDGE_LLM_GATEWAY_URL?.trim()||"https://llm-gateway.coze.cn",Ke="auto",cf=2e5;function lf(t){return{model:cc(t.model)??Ke,...t.modelToken?{modelToken:t.modelToken}:{}}}function df(t){return!t||t===Ke}var n_=new Set(["auto","\u81EA\u52A8"]);function cc(t){let e=t?.trim();if(e)return n_.has(e.toLowerCase())?Ke:e}function uf(t){let e={};if(t.modelToken){e.ANTHROPIC_BASE_URL=ac,e.ANTHROPIC_AUTH_TOKEN=t.modelToken;let n=t.model||Ke;e.ANTHROPIC_MODEL=n,e.ANTHROPIC_SMALL_FAST_MODEL=n,t.modelInfo?.contextWindow&&(e.CLAUDE_CODE_MAX_CONTEXT_TOKENS=String(t.modelInfo.contextWindow))}else df(t.model)||(e.ANTHROPIC_MODEL=t.model);return e}function ff(t){let e=[];if(t.modelToken?e.push("-c",`model="${t.model||Ke}"`):df(t.model)||e.push("-c",`model="${t.model}"`),t.modelToken){e.push("-c",'model_providers.coze.name="coze"'),e.push("-c",`model_providers.coze.base_url="${ac}/v1"`),e.push("-c",'model_providers.coze.env_key="OPENAI_API_KEY"'),e.push("-c",'model_providers.coze.wire_api="responses"'),e.push("-c","model_providers.coze.requires_openai_auth=false"),e.push("-c","model_providers.coze.supports_websockets=false"),e.push("-c",'model_provider="coze"');let n=t.modelInfo?.contextWindow??cf;e.push("-c",`model_context_window=${n}`)}return e}function hf(t){return t.modelToken?{OPENAI_API_KEY:t.modelToken}:{}}function lc(t,e){let{ttEnv:n,usePpe:r}=si(t),i={};return n&&(i["x-tt-env"]=n),r&&(i["x-use-ppe"]=r),e&&(i["x-mock-scenario"]=e),i}function pf(t,e,n){if(!t.modelToken)return{};let r=lc(e,n);return Object.keys(r).length===0?{}:{ANTHROPIC_CUSTOM_HEADERS:Object.entries(r).map(([s,o])=>`${s}:${o}`).join(`
91
+ `)}}function dc(t){return`coze-session-${t.replace(/[^A-Za-z0-9_-]+/g,"-")}`}function gf(t,e,n){if(!t.modelToken)return null;let r=t.model||Ke,i=lc(e,n),s=["text"];t.modelInfo?.capabilities?.image===!0&&s.push("image");let o={baseUrl:`${ac}/v1`,api:"openai-completions",apiKey:t.modelToken,models:[{id:r,name:r,reasoning:!1,input:s,cost:{input:0,output:0,cacheRead:0,cacheWrite:0},contextWindow:t.modelInfo?.contextWindow??cf,maxTokens:8192,api:"openai-completions"}]};return Object.keys(i).length>0&&(o.headers=i),o}function mf(t,e,n){if(!t.modelToken)return[];let r=lc(e,n),i=[];for(let[s,o]of Object.entries(r))i.push("-c",`model_providers.coze.http_headers.${s}="${o}"`);return i}var se=b("agent-handlers"),wf=5*1024*1024,c_=1,l_=6,d_=new Set(["node_modules",".git",".coze","dist","build",".next"]),js=class{constructor(e){this.opts=e}opts;async listSkills(e){vt(e._meta,"_agent/listSkills");let n=Yn(e._meta),r=await this.loadAgentCfg(n),i=r?.workspace??be(n).workspace,s=r?.skills??[],o=[];for(let a of s){let c=at(i,a.relPath,"SKILL.md");await s_(c).then(d=>d.isFile()).catch(()=>!1)&&o.push(g_(a))}return{skills:o}}async addSkills(e){vt(e._meta,"_agent/addSkills");let n=Yn(e._meta),r=await this.requireAgentCfg(n),i=e.skills??[],s=[...r.skills??[]],o=new Map(s.map((c,l)=>[c.skillId,l])),a=[];for(let c of i){let l=await wc({agentId:n,workspace:r.workspace,framework:r.framework,skill:c});yc(s,o,l),a.push(c)}return await Zi(n,s),this.reloadAgentSessions(n,"skills-added"),{installedSkills:a}}async removeSkills(e){vt(e._meta,"_agent/removeSkills");let n=Yn(e._meta),r=await this.requireAgentCfg(n),i=new Set(e.skillIds??[]),s=r.skills??[],o=[];for(let a of s){if(!i.has(a.skillId)){o.push(a);continue}let c=at(r.workspace,a.relPath);await i_(c,{recursive:!0,force:!0}),se.info("skill removed",{agentId:n,skillId:a.skillId,relPath:a.relPath})}return await Zi(n,o),this.reloadAgentSessions(n,"skills-removed"),{ok:!0}}reloadAgentSessionsPublic(e,n){this.reloadAgentSessions(e,n)}reloadAgentSessions(e,n){let r=this.opts.agents.get(e);if(r)for(let[i,s]of r.sessions){if(!s.downstream)continue;let o=s.acpSessionId;if(o&&r.activeTriggers.has(o)||this.isRuntimePendingPermission(s)){s.reloadAfterTurn=!0,se.info("downstream busy, scheduling reload after turn",{reason:n,agentId:e,framework:r.framework,cloudId:i,acpId:o});continue}let c=s.downstream;s.downstream=void 0,se.info("killing downstream for workspace reload (idle)",{reason:n,agentId:e,framework:r.framework,cloudId:i,acpId:o}),c.stop(n).catch(l=>se.warn("downstream stop failed during reload (ignored)",{reason:n,agentId:e,cloudId:i,err:String(l)}))}}isRuntimePendingPermission(e){let n=this.opts.isRuntimePendingPermission;return!n||!e.downstream?!1:n(e.downstream)}async updateAgent(e){if(!e.cozeIdentity?.trim())return se.info("_agent/update: empty cozeIdentity, noop",{agentId:e.agentId}),{ok:!0};let n=e.agentId,r=await me(n);if(!r)throw new _("AGENT_NOT_FOUND",`agent not found: ${n}`);if(r.cozeIdentity===e.cozeIdentity)return se.info("_agent/update: cozeIdentity unchanged, noop",{agentId:n}),{ok:!0};try{await Ln(r.workspace,r.framework,e.cozeIdentity)}catch(i){throw se.error("_agent/update: writeInstructionFile failed, aborting update",{agentId:n,framework:r.framework,workspace:r.workspace,err:String(i)}),new _("AGENT_PROTOCOL_ERROR",`failed to write instruction file for agent ${n}: ${String(i)}`,{cause:i})}return r.cozeIdentity=e.cozeIdentity,await Ae(r),se.info("_agent/update: cozeIdentity rewritten",{agentId:n,framework:r.framework}),this.reloadAgentSessions(n,"identity-changed"),{ok:!0}}async disconnectAgent(e){let n=e.agentId;if(!n)throw new _("IPC_BAD_REQUEST","_agent/disconnect: missing agentId");let r=await me(n);return r?(r.disconnectedAt=Date.now(),r.disconnectReason=e.reason??"",await Ae(r),se.info("agent disconnected",{agentId:n,reason:e.reason??"",force:e.force??!1}),this.opts.disposeAndMarkDisconnected&&await this.opts.disposeAndMarkDisconnected(n,e.reason??"disconnect"),{ok:!0}):(se.warn("_agent/disconnect: agent not found, ignoring",{agentId:n}),{ok:!0})}async switchModel(e){if(vt(e._meta,"_agent/switchModel"),!e.agentId)throw new _("IPC_BAD_REQUEST","_agent/switchModel: missing agentId");let n=cc(e.model)??Ke,r=await me(e.agentId);if(!r)throw new _("AGENT_NOT_FOUND",`agent not found: ${e.agentId}`);r.model=n,e.modelInfo&&(r.modelInfo=e.modelInfo),await Ae(r),se.info("_agent/switchModel: model persisted",{agentId:e.agentId,model:n,reason:e.reason??""});let i=this.opts.agents.get(e.agentId);if(!i)return se.info("_agent/switchModel: agent not running, config persisted only",{agentId:e.agentId}),{ok:!0};i.model=n,e.modelInfo&&i.setModelInfo(e.modelInfo),this.opts.cleanupOpenclawProviders&&await this.opts.cleanupOpenclawProviders(i).catch(o=>se.warn("cleanupOpenclawProviders before switchModel failed (ignored)",{agentId:e.agentId,err:String(o)}));let s=[];for(let[o,a]of i.allSessionQueues())s.push(a.enqueue(async()=>{let c=i.sessions.get(o);c?.downstream&&(await c.downstream.stop(`switchModel: ${n}`).catch(()=>{}),c.downstream=void 0)}));return await Promise.all(s),se.info("_agent/switchModel: all session runtimes killed, next prompt will respawn",{agentId:e.agentId,model:n,cloudSessions:s.length}),{ok:!0}}async resetAgent(e){if(vt(e._meta,Ze.RESET),!e.agentId)throw new _("IPC_BAD_REQUEST",`${Ze.RESET}: missing agentId`);return await this.clearSessionMappings(e.agentId,Ze.RESET),await this.runDetailSync(e.agentId,Ze.RESET,e.reason),{ok:!0}}async clearSessionMappings(e,n){let r=this.opts.agents.get(e);if(!r){await this.clearPersistedAcpSessionIds(e),se.info("reset: agent not in memory, cleared persisted acpSessionIds only",{agentId:e});return}await r.killAllRuntimes(n);for(let s of r.sessions.values())s.acpSessionId=void 0,s.replySeq=0,s.loadingSession=!1,s.spawnFailCount=void 0,s.spawnFailedAt=void 0;let i=new Map;for(let[s,o]of r.sessions)i.set(s,{modelToken:o.modelToken,tokenGeneratedAt:o.tokenGeneratedAt});await Or(e,i)}async clearPersistedAcpSessionIds(e){let n=await me(e).catch(()=>null);if(!n?.sessions)return;let r=!1;for(let i of Object.values(n.sessions))i.acpSessionId&&(i.acpSessionId=void 0,r=!0);r&&await Ae(n)}async repairAgent(e){if(vt(e._meta,Ze.REPAIR),!e.agentId)throw new _("IPC_BAD_REQUEST",`${Ze.REPAIR}: missing agentId`);let n=await this.loadAgentCfg(e.agentId);if(n&&n.framework!=="openclaw")throw new _("IPC_BAD_REQUEST",`${Ze.REPAIR} only allowed for openclaw, got ${n.framework}`);if(n&&this.opts.openclawRepair)try{await this.opts.openclawRepair(e.agentId,n.workspace)}catch(r){se.warn("openclaw repair (delete+add) failed (ignored)",{agentId:e.agentId,reason:e.reason,err:String(r)})}return await this.runDetailSync(e.agentId,Ze.REPAIR,e.reason),{ok:!0}}async runDetailSync(e,n,r){if(!this.opts.detailSyncer){se.warn("detailSyncer not wired, skipping sync",{method:n,agentId:e});return}try{await this.opts.detailSyncer(e)}catch(i){se.warn("detail sync failed (ignored)",{method:n,agentId:e,reason:r,err:String(i)})}}async getFileTree(e){vt(e._meta,"_agent/getFileTree");let n=e._meta,r=Yn(n),i=await this.resolveWorkspace(r),s=e.filePath??"",o=this.safeJoin(i,s),a=await uc(o).catch(()=>null);if(!a)throw new _("IPC_BAD_REQUEST",`path not found: ${s}`);if(a.isSymbolicLink())throw new _("IPC_BAD_REQUEST",`symlink not allowed: ${s}`);if(!await xr(o,i))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${s}`);let c=k_(e.depth);return a.isDirectory()?{tree:await R_(i,o,s,c)}:{tree:[{name:b_(s),path:Tf(s||"."),isDir:!1,size:a.size,modifiedAt:Math.floor(a.mtimeMs)}]}}async getFileContent(e){vt(e._meta,"_agent/getFileContent");let n=Yn(e._meta),r=await this.resolveWorkspace(n);if(!e.filePath)throw new _("IPC_BAD_REQUEST","filePath required");let i=this.safeJoin(r,e.filePath),s=await uc(i).catch(()=>null);if(!s||!s.isFile())throw new _("IPC_BAD_REQUEST",`not a file: ${e.filePath}`);if(s.isSymbolicLink())throw new _("IPC_BAD_REQUEST",`symlink not allowed: ${e.filePath}`);if(!await xr(i,r))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${e.filePath}`);if(s.size>wf)throw new _("IPC_BAD_REQUEST",`file too large: ${s.size} bytes (max ${wf})`);let o=await yf(i);return o.includes(0)?{content:o.toString("base64"),encoding:"base64",size:s.size}:{content:o.toString("utf8"),encoding:"utf-8",size:s.size}}async resolveWorkspace(e){let n=this.opts.agents.get(e);return n?n.workspace:(await me(e).catch(()=>null))?.workspace??be(e).workspace}safeJoin(e,n){let r=pc(e,n||"."),i=mc(e,r);if(i.startsWith("..")||i===".."||i.startsWith(`..${_f}`))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${n}`);return r}loadAgentCfg(e){return me(e)}async requireAgentCfg(e){let n=await this.loadAgentCfg(e);if(!n)throw new _("AGENT_NOT_FOUND",`no config for agent: ${e}`);return n}};function u_(t){let e=t.trim().replace(/[\x00-\x1f<>:"|?*/\\]+/g,"-").replace(/^[\s.-]+|[\s.-]+$/g,"").slice(0,64);if(!e||e==="."||e==="..")throw new _("IPC_BAD_REQUEST",`invalid skill name: ${t}`);if(/^(con|prn|aux|nul|com[1-9]|lpt[1-9])$/i.test(e))throw new _("IPC_BAD_REQUEST",`reserved windows filename: ${t}`);return e}function f_(t){return t==="claude-code"?at(".claude","skills"):at(".agents","skills")}var h_=3e4,p_=50*1024*1024,er=3e4;async function wc(t){let{agentId:e,workspace:n,framework:r,skill:i}=t;if(!i.skillName)throw new _("IPC_BAD_REQUEST","skill missing skillName");let s=typeof i.content=="string"&&i.content.length>0,o=typeof i.downloadUrl=="string"&&i.downloadUrl.length>0;if(!s&&!o)throw new _("IPC_BAD_REQUEST",`skill ${i.skillId} missing both content and downloadUrl`);let a=u_(i.skillName),c=f_(r),l=at(c,a),d=at(n,l);if(await fc(d,{recursive:!0}),s){let m=Buffer.from(i.content,"utf8");oi(m.length),await hc(at(d,"SKILL.md"),m,"utf8")}else{let m=await m_(i.downloadUrl);y_(m)?await v_(m,d):__(m)?await E_(m,d):await hc(at(d,"SKILL.md"),m.toString("utf8"),"utf8")}let p={skillId:i.skillId,skillName:i.skillName,relPath:l,installedAt:Date.now(),...i.description?{description:i.description}:{},...i.icon?{icon:i.icon}:{},...i.version?{version:i.version}:{},...i.downloadUrl?{downloadUrl:i.downloadUrl}:{},...i.config?{config:i.config}:{},...i.builtin?{builtin:i.builtin}:{}};return se.info("skill installed",{agentId:e,skillId:i.skillId,skillName:i.skillName,relPath:l,source:s?"content":"downloadUrl"}),p}function yc(t,e,n){let r=e.get(n.skillId);if(r!==void 0){t[r]=n;return}e.set(n.skillId,t.length),t.push(n)}function g_(t){return{skillId:t.skillId,skillName:t.skillName,...t.description?{description:t.description}:{},...t.icon?{icon:t.icon}:{},...t.version?{version:t.version}:{},...t.config?{config:t.config}:{},...t.builtin?{builtin:t.builtin}:{}}}async function m_(t){if(!t)throw new _("IPC_BAD_REQUEST","skill missing downloadUrl");if(t.startsWith("data:")){let e=Math.floor(t.length*3/4);oi(e);let n=w_(t);return oi(n.length),n}if(t.startsWith("file:")){let e=new URL(t).pathname,n=await yf(e);return oi(n.length),n}if(zs(t)){let e=new AbortController,n=setTimeout(()=>e.abort(),h_);try{let r=await fetch(t,{signal:e.signal});if(!r.ok)throw new _("IPC_BAD_REQUEST",`fetch skill failed HTTP ${r.status} ${t}`);let i=await r.arrayBuffer();return oi(i.byteLength),Buffer.from(i)}finally{clearTimeout(n)}}throw new _("IPC_BAD_REQUEST",`unsupported downloadUrl scheme (\u8981 https/data/file): ${t.slice(0,80)}`)}function oi(t){if(t>p_)throw new _("IPC_BAD_REQUEST",`skill too large: ${t} bytes`)}function w_(t){let e=/^data:([^,;]*)(;base64)?,(.*)$/s.exec(t);if(!e)throw new _("IPC_BAD_REQUEST","bad data URL");let n=!!e[2],r=e[3]??"";return n?Buffer.from(r,"base64"):Buffer.from(decodeURIComponent(r),"utf8")}function y_(t){return t.length>=2&&t[0]===31&&t[1]===139}function __(t){if(t.length<4||t[0]!==80||t[1]!==75)return!1;let e=t[2],n=t[3];return e===3&&n===4||e===5&&n===6}function gc(t){return t==="__MACOSX"||t.startsWith("__MACOSX/")}async function E_(t,e){let n,r;try{n=new vf.default(t),r=n.getEntries()}catch(o){throw new _("IPC_BAD_REQUEST",`zip parse failed: ${o.message}`,{cause:o})}for(let o of r){let a=o.entryName;if(!a||gc(a))continue;if(a.startsWith("/")||/^[A-Za-z]:[\\/]/.test(a))throw new _("IPC_BAD_REQUEST",`zip entry absolute path: ${a}`);if(a.split(/[/\\]/).some(l=>l===".."))throw new _("IPC_BAD_REQUEST",`zip entry contains '..' (traversal): ${a}`);let c=o.header.attr>>>16&61440;if(c!==0&&c!==32768&&c!==16384)throw new _("IPC_BAD_REQUEST",`zip entry kind 0x${c.toString(16)} not allowed (symlink/hardlink/special): ${a}`)}let i=S_(r),s=pc(e);for(let o of r){if(gc(o.entryName))continue;let a=o.entryName;if(i&&a.startsWith(i)&&(a=a.slice(i.length)),!a)continue;let c=pc(e,a),l=mc(s,c);if(l.startsWith("..")||l==="..")throw new _("IPC_BAD_REQUEST",`zip entry escapes destDir: ${a}`);if(o.isDirectory){await fc(c,{recursive:!0});continue}await fc(o_(c),{recursive:!0});let d;try{d=o.getData()}catch(p){throw new _("IPC_BAD_REQUEST",`zip entry getData failed (${o.entryName}): ${p.message}`,{cause:p})}await hc(c,d)}}function S_(t){let e;for(let n of t){let r=n.entryName;if(!r||gc(r))continue;let i=r.indexOf("/");if(i<=0)return;let s=r.slice(0,i+1);if(e===void 0)e=s;else if(e!==s)return}return e}async function v_(t,e){await I_(t);let n=Yu({cwd:e,strip:1}),r=!1,i=setTimeout(()=>{r=!0,n.destroy(new _("IPC_BAD_REQUEST",`tar extract timeout (${er}ms)`))},er);try{await Sf(Ef.from(t),n)}catch(s){throw s instanceof _?s:r?new _("IPC_BAD_REQUEST",`tar extract timeout (${er}ms)`):new _("IPC_BAD_REQUEST",`tar extract failed: ${s.message??String(s)}`,{cause:s})}finally{clearTimeout(i)}}async function I_(t){let e=[],n=Xn({onReadEntry:s=>{let o=s.path,a=s.type;if(a!=="File"&&a!=="Directory"){e.push(`tar entry kind '${a}' not allowed (symlink/hardlink/special): ${o.slice(0,100)}`);return}if(o.startsWith("/")||o.startsWith("\\")||/^[a-zA-Z]:[\\/]/.test(o)){e.push(`tar entry absolute path: ${o}`);return}o.split(/[/\\]/).some(l=>l==="..")&&e.push(`tar entry contains '..': ${o}`)}}),r=!1,i=setTimeout(()=>{r=!0,n.destroy(new _("IPC_BAD_REQUEST",`tar list timeout (${er}ms)`))},er);try{await Sf(Ef.from(t),n)}catch(s){throw r?new _("IPC_BAD_REQUEST",`tar list timeout (${er}ms)`):new _("IPC_BAD_REQUEST",`tar list failed: ${s.message??String(s)}`,{cause:s})}finally{clearTimeout(i)}if(e.length>0)throw new _("IPC_BAD_REQUEST",e[0]??"tar entry validation failed")}var T_=5e3;async function R_(t,e,n,r){return If(t,e,n,r,{count:0})}async function If(t,e,n,r,i){if(r<=0)return[];let s;try{s=await r_(e,{withFileTypes:!0})}catch{return[]}let o=[];for(let a of s){if(d_.has(a.name)||a.isSymbolicLink())continue;if(i.count>=T_){o.push({name:"...",path:"...",isDir:!1,size:0,modifiedAt:0,hasMore:!0});break}let c=at(e,a.name),l=a_(at(n,a.name)),d=null;try{d=await uc(c)}catch{continue}if(d.isSymbolicLink())continue;i.count++;let p={name:a.name,path:Tf(mc(t,c)),isDir:d.isDirectory(),size:d.size,modifiedAt:Math.floor(d.mtimeMs)};d.isDirectory()&&r>1&&(p.children=await If(t,c,l,r-1,i)),o.push(p)}return o.sort((a,c)=>a.isDir!==c.isDir?a.isDir?-1:1:a.name.localeCompare(c.name)),o}function k_(t){return!t||t<=0?c_:Math.min(t,l_)}function b_(t){if(!t||t==="."||t==="/")return".";let e=t.split(/[/\\]/);return e[e.length-1]||"."}function Tf(t){return t.split(_f).join("/")}L();import{readFileSync as Mb}from"node:fs";import{dirname as Ub,join as zb}from"node:path";import{fileURLToPath as Gb}from"node:url";var tr="0.1.93-beta.0";var Gt=b("agent-health-reporter"),A_=1e4,ai=class{constructor(e){this.opts=e;this.intervalMs=e.intervalMs??A_}opts;timer=null;inFlight=!1;unsubscribeRegister=null;intervalMs;start(){this.timer||(this.timer=setInterval(()=>{this.tick()},this.intervalMs),this.timer.unref?.(),this.unsubscribeRegister=this.opts.core.onAgentRegister(()=>{this.tick()}),Gt.info("heartbeat started",{intervalMs:this.intervalMs}),this.tick())}stop(){this.timer&&(clearInterval(this.timer),this.timer=null,this.unsubscribeRegister&&(this.unsubscribeRegister(),this.unsubscribeRegister=null),Gt.info("heartbeat stopped"))}async tick(){if(this.inFlight){Gt.debug("previous tick still in-flight, skip");return}let e=this.opts.getDeviceId();if(!e){Gt.debug("deviceId not available, skip tick (\u5C1A\u672A pair)");return}this.inFlight=!0;try{let n=[];for(let o of this.opts.core.agents.values()){let a=x_(o);if(!a)continue;let c={agentId:o.agentId,status:a};o.patToken&&(c.patToken=o.patToken),o.accountId&&(c.accountId=o.accountId),n.push(c)}if(n.length===0)return;let r={agents:n,bridgeVersion:tr,_meta:{cozeDeviceId:e}},i;try{i=await this.opts.core.sendRequest("_agent/health",r,5e3)}catch(o){Gt.warn("heartbeat batch send failed",{count:n.length,err:String(o)})}let s=i?.authFailures;if(s&&s.length>0&&(Gt.warn("heartbeat received authFailures from cloud",{count:s.length,agentIds:s.map(o=>o.agentId)}),this.opts.onAuthFailures))try{await this.opts.onAuthFailures(s)}catch(o){Gt.warn("onAuthFailures callback failed (ignored)",{err:String(o)})}}finally{this.inFlight=!1}if(this.opts.onTickEnd)try{await this.opts.onTickEnd()}catch(n){Gt.warn("onTickEnd hook failed",{err:String(n)})}}};function x_(t){return t.status==="error"?"error":t.activeTriggers.size>0?"busy":t.status==="ok"?"online":null}At();import{chmod as lE,mkdir as Qs,rm as dE,stat as uE,writeFile as fE}from"node:fs/promises";import{homedir as hE}from"node:os";import{join as jf}from"node:path";tn();import{spawnSync as M_}from"node:child_process";function ci(t,e,n){return n===void 0?{jsonrpc:"2.0",id:t,method:e}:{jsonrpc:"2.0",id:t,method:e,params:n}}function nr(t,e){return e===void 0?{jsonrpc:"2.0",method:t}:{jsonrpc:"2.0",method:t,params:e}}function rr(t,e){return{jsonrpc:"2.0",id:t,result:e}}function Ht(t,e){return{jsonrpc:"2.0",id:t,error:e}}Te();var Ws=class extends Error{code;data;constructor(e){super(`JSON-RPC error code=${e.code} ${e.message}`),this.name="RemoteRpcError",this.code=e.code,e.data!==void 0&&(this.data=e.data)}},U={PARSE_ERROR:-32700,INVALID_REQUEST:-32600,METHOD_NOT_FOUND:-32601,INVALID_PARAMS:-32602,INTERNAL_ERROR:-32603,AGENT_NOT_FOUND:-32001,AGENT_BUSY:-32002,AGENT_TIMEOUT:-32003,AGENT_SPAWN_FAILED:-32004,OPERATION_NOT_ALLOWED_FOR_LOCAL:-32005,AGENT_DISCONNECTED:-32006,MODEL_TOKEN_GEN_FAILED:-32009,PATH_OUTSIDE_WORKSPACE:-32010,FILE_TOO_LARGE:-32011,UNSUPPORTED_MIME:-32012,UPLOAD_FAILED:-32013,UPSTREAM_NOT_READY:-32014,AGENT_FRAME_IDLE_TIMEOUT:-32016,MODEL_MODALITY_UNSUPPORTED:-32017,AGENT_DEPENDENCY_INSTALL_FAILED:-32018,AGENT_APPROVAL_TIMEOUT:-32019};function Rf(t){return"method"in t&&"id"in t&&t.id!==void 0}function kf(t){return"method"in t&&!("id"in t)}function qs(t){return!("method"in t)&&"id"in t}var O_={AGENT_NOT_FOUND:U.AGENT_NOT_FOUND,AGENT_BUSY:U.AGENT_BUSY,AGENT_DISCONNECTED:U.AGENT_DISCONNECTED,AGENT_TIMEOUT:U.AGENT_TIMEOUT,AGENT_FRAME_IDLE_TIMEOUT:U.AGENT_FRAME_IDLE_TIMEOUT,AGENT_SPAWN_FAILED:U.AGENT_SPAWN_FAILED,AGENT_PROTOCOL_ERROR:U.INTERNAL_ERROR,BRIDGE_CONFIG_INVALID:U.INTERNAL_ERROR,BRIDGE_INTERNAL:U.INTERNAL_ERROR,IPC_AUTH_FAILED:U.INTERNAL_ERROR,IPC_BAD_REQUEST:U.INVALID_REQUEST,MODEL_TOKEN_GEN_FAILED:U.MODEL_TOKEN_GEN_FAILED,MODEL_MODALITY_UNSUPPORTED:U.MODEL_MODALITY_UNSUPPORTED,OPERATION_NOT_ALLOWED_FOR_LOCAL:U.OPERATION_NOT_ALLOWED_FOR_LOCAL,UPSTREAM_DISCONNECTED:U.INTERNAL_ERROR,UPSTREAM_HANDSHAKE_FAILED:U.INTERNAL_ERROR,PATH_OUTSIDE_WORKSPACE:U.PATH_OUTSIDE_WORKSPACE,FILE_TOO_LARGE:U.FILE_TOO_LARGE,UNSUPPORTED_MIME:U.UNSUPPORTED_MIME,UPLOAD_FAILED:U.UPLOAD_FAILED,UPSTREAM_NOT_READY:U.UPSTREAM_NOT_READY,AGENT_DEPENDENCY_INSTALL_FAILED:U.AGENT_DEPENDENCY_INSTALL_FAILED,AGENT_APPROVAL_TIMEOUT:U.AGENT_APPROVAL_TIMEOUT};function P_(t){if(t!=null)return t instanceof Error?{name:t.name,message:li(t.message)}:typeof t=="string"?li(t):typeof t=="object"?D_(t):t}var C_=[[/\/Users\/[^/\s'"`)]+/g,"/Users/<redacted>"],[/\/home\/[^/\s'"`)]+/g,"/home/<redacted>"],[/[A-Za-z]:\\Users\\[^\\\s'"`)]+/g,"C:\\Users\\<redacted>"],[/(Bearer|Token|Authorization:)\s+[\w._-]+/gi,"$1 <redacted>"],[/\b(sk|pat|ak)[-_][A-Za-z0-9_-]{20,}\b/g,"<redacted-key>"]];function li(t){let e=t;for(let[n,r]of C_)e=e.replace(n,r);return e}function D_(t){let e={};for(let[n,r]of Object.entries(t))typeof r=="string"?e[n]=li(r):e[n]=r;return e}function di(t){if(t instanceof _){let e=P_(t.cause),n={bridgeCode:t.code,retriable:t.retriable};return e!==void 0&&(n.cause=e),{code:O_[t.code]??U.INTERNAL_ERROR,message:li(t.message),data:n}}return{code:U.INTERNAL_ERROR,message:li(t instanceof Error?t.message:String(t))}}function bf(t){let e=t.data,n=e?.bridgeCode??"AGENT_PROTOCOL_ERROR",r=!!e&&typeof e.message=="string"&&!!e.message,i=r?e?.message:t.message,s=t.data;if(r&&e){let{message:o,...a}=e;s=a}return new _(n,i,{retriable:e?.retriable??!1,cause:s})}function xf(t){return`${JSON.stringify(t)}
92
+ `}var Af=10*1024*1024,Vs=class{buffer="";onError;constructor(e={}){this.onError=e.onError}push(e){if(this.buffer+=typeof e=="string"?e:e.toString("utf8"),this.buffer.length>Af){let i=this.buffer.length;return this.buffer="",this.onError?.({line:`<buffer overflow: ${i} bytes, dropped>`,error:new Error(`LdjsonDecoder buffer exceeded ${Af} bytes`)}),[]}let n=this.buffer.split(`
93
+ `);this.buffer=n.pop()??"";let r=[];for(let i of n){let s=i.replace(/\r$/,"").trim();if(s)try{r.push(JSON.parse(s))}catch(o){this.onError?.({line:s,error:o})}}return r}flush(){if(!this.buffer)return[];let e=this.buffer.replace(/\r$/,"").trim();if(this.buffer="",!e)return[];try{return[JSON.parse(e)]}catch(n){return this.onError?.({line:e,error:n}),[]}}};var Pf={"session/prompt":"session.prompt","session/cancel":"session.cancel","session/new":"session.new","session/load":"session.load","_agent/create":"agent.create","_agent/health":"agent.health","_agent/pair":"agent.pair","_agent/listSkills":"agent.listSkills","_agent/addSkills":"agent.addSkills","_agent/removeSkills":"agent.removeSkills","_agent/getFileTree":"agent.getFileTree","_agent/getFileContent":"agent.getFileContent","_agent/detail":"agent.detail","_agent/update":"agent.update","_agent/disconnect":"agent.disconnect","_agent/switchModel":"agent.switchModel","_agent/genModelToken":"agent.genModelToken","_agent/reset":"agent.reset","_agent/repair":"agent.repair","session/request_permission":"session.requestPermission",initialize:"initialize"},Qb=Object.fromEntries(Object.entries(Pf).map(([t,e])=>[e,t])),N_={"session.prompt":["agentId","triggerMsgId","sessionId"],"session.cancel":["agentId","triggerMsgId","sessionId"],"session.new":["agentId"],"session.load":["agentId"],"agent.create":["agentId"],"agent.health":[],"agent.listSkills":["agentId"],"agent.addSkills":["agentId"],"agent.removeSkills":["agentId"],"agent.getFileTree":["agentId"],"agent.getFileContent":["agentId"],"agent.detail":["agentId"],"agent.update":["agentId"],"agent.disconnect":["agentId"],"agent.switchModel":["agentId"],"agent.genModelToken":["agentId","sessionId"],"agent.reset":["agentId"],"agent.repair":["agentId"],"session.requestPermission":["agentId","sessionId"],"agent.pair":[],initialize:[]},ir=class{seq=0;next(e,n){this.seq+=1;let r=Pf[e]??L_(e),i=N_[r]??[],s=[r,String(this.seq)];if(i.length>0){let o=i.map(c=>Of(n?.[c]??"")),a=F_(o).join(":");a&&s.push(a)}else n&&Object.values(n).some(o=>o)&&s.push(Object.values(n).filter(Boolean).map(o=>Of(String(o))).join(":"));return s.join("_")}reset(){this.seq=0}};function L_(t){return t.replace(/[\s/]+/g,".").replace(/_+/g,"-")}function Of(t){return t.replace(/[:_\s]+/g,"-")}function F_(t){let e=t.length;for(;e>0&&!t[e-1];)e-=1;return t.slice(0,e)}gt();Fi();Te();L();var B_=pt("COZE_BRIDGE_INITIALIZE_TIMEOUT_MS",3e4),U_=200,z_=pt("COZE_BRIDGE_SESSION_PROMPT_MAX_MS",3600*1e3),$_=pt("COZE_BRIDGE_SESSION_PROMPT_FRAME_IDLE_MS",600*1e3),G_=pt("COZE_BRIDGE_SESSION_PROMPT_APPROVAL_MAX_MS",1440*60*1e3),Cf=500;function H_(t){try{let e=JSON.stringify(t);return e===void 0||e.length<=Cf?t:`${e.slice(0,Cf)}...<truncated, total ${e.length} chars>`}catch{return"<unserializable>"}}function Df(t,e){if(!(typeof t!="number"||t<=0))try{if(process.platform==="win32"){let n=["/PID",String(t),"/T"];e==="SIGKILL"&&n.push("/F"),M_("taskkill",n,{stdio:"ignore",windowsHide:!0})}else process.kill(-t,e)}catch{}}var ct=class{constructor(e){this.opts=e;this.log=b(`downstream.${this.constructor.name}`,this.opts.agentId),this.decoder=new Vs({onError:n=>this.log.warn("decode line failed",{line:n.line})})}opts;child;decoder;pending=new Map;inflightAgentRequests=new Map;idAllocator=new ir;updateHandlers=[];agentRequestHandlers=[];exitHandlers=[];log;stopped=!1;stderrRing=[];sanitizeEnv(e){return e}async start(){if(this.child)throw new _("BRIDGE_INTERNAL","Downstream already started");let e=process.platform!=="win32",n=Fe(this.opts.command,this.opts.args,{cwd:this.opts.cwd,env:{...this.sanitizeEnv(process.env),...this.opts.env},stdio:["pipe","pipe","pipe"],detached:e});this.child=n,n.stdout?.setEncoding("utf8"),n.stdout?.on("data",r=>{try{for(let i of this.decoder.push(r))this.dispatch(i)}catch(i){this.log.warn("stdout dispatch threw, swallowed to keep daemon alive",{err:String(i)})}}),n.stderr?.setEncoding("utf8"),n.stderr?.on("data",r=>{let i=r.trimEnd();this.stderrRing.push(i),this.stderrRing.length>U_&&this.stderrRing.shift(),this.log.debug("stderr",{text:i})}),n.stdin?.on("error",r=>{this.log.warn("child stdin error",{err:String(r)})}),n.stdout?.on("error",r=>{this.log.warn("child stdout error",{err:String(r)})}),n.stderr?.on("error",r=>{this.log.warn("child stderr error",{err:String(r)})}),n.on("exit",(r,i)=>{this.stopped=!0,(r!==0||i!==null)&&this.stderrRing.length>0&&this.log.warn("downstream exited abnormally, recent stderr",{code:r,signal:i,recentStderr:[...this.stderrRing]});try{for(let o of this.decoder.flush())this.dispatch(o)}catch(o){this.log.debug("decoder.flush on exit threw (ignored)",{err:String(o)})}this.failAllPending(new _("AGENT_PROTOCOL_ERROR",`agent exited (${r}/${i})`));for(let o of this.exitHandlers)o(r,i)}),n.on("error",r=>{this.log.error("child error",{err:String(r)}),this.failAllPending(new _("AGENT_SPAWN_FAILED",String(r),{cause:r}))}),this.log.info("downstream started",{command:this.opts.command,pid:n.pid,cwd:this.opts.cwd})}async stop(e){if(!this.child||this.stopped)return;this.stopped=!0,this.log.info("downstream stopping",{reason:e});let n=this.child,r=new Promise(s=>n.once("exit",()=>s()));Df(n.pid,"SIGTERM");let i=setTimeout(()=>{n.killed||Df(n.pid,"SIGKILL")},5e3);try{await r}finally{clearTimeout(i)}}pid(){return this.child?.pid}isAlive(){return!!this.child&&!this.stopped}getStderrTail(){return[...this.stderrRing]}initialize(e){return this.call("initialize",e)}sessionNew(e){return this.call("session/new",{mcpServers:[],...e})}sessionLoad(e){return this.call("session/load",{mcpServers:[],...e})}sessionPrompt(e,n=z_,r=$_,i=G_){return this.call("session/prompt",e,n,r,i)}async sessionCancel(e){!this.child||this.stopped||this.writeFrame(nr("session/cancel",e))}onUpdate(e){this.updateHandlers.push(e)}onAgentRequest(e){this.agentRequestHandlers.push(e)}respondAgentRequest(e,n){if(this.inflightAgentRequests.delete(e),!(!this.child||this.stopped))try{this.writeFrame(rr(e,n))}catch(r){this.log.warn("respondAgentRequest write failed",{id:e,err:String(r)})}}respondAgentRequestError(e,n){if(this.inflightAgentRequests.delete(e),!(!this.child||this.stopped))try{this.writeFrame(Ht(e,n))}catch(r){this.log.warn("respondAgentRequestError write failed",{id:e,err:String(r)})}}onExit(e){this.exitHandlers.push(e)}call(e,n,r=B_,i=0,s=0){if(!this.child||this.stopped)return Promise.reject(new _("AGENT_PROTOCOL_ERROR","downstream not started"));let o=this.idAllocator.next(e),a=ci(o,e,n),c=(()=>{if(typeof n!="object"||n===null)return;let p=n.sessionId;return typeof p=="string"?p:void 0})(),l=r>0&&Number.isFinite(r),d=i>0&&Number.isFinite(i);return new Promise((p,m)=>{let u={resolve:p,reject:m,timer:null,frameIdleTimer:null,armFrameIdle:null,method:e},h=Date.now();if(l){let w=()=>{u.timer=setTimeout(()=>{let S=Date.now()-h;if(this.inflightAgentRequests.size>0&&S<s){this.log.debug("hard cap fired but agent request inflight, extending to approval cap",{id:o,method:e,elapsed:S,approvalMaxMs:s,...c?{sessionId:c}:{}}),w();return}this.pending.delete(o),u.frameIdleTimer&&clearTimeout(u.frameIdleTimer);let v=this.inflightAgentRequests.size>0;this.log.warn("downstream call timeout",{id:o,method:e,timeoutMs:r,approvalMaxMs:s,awaitingApproval:v,...c?{sessionId:c}:{}}),m(v?new _("AGENT_APPROVAL_TIMEOUT",`${e} awaiting permission timed out after ${s}ms`):new _("AGENT_TIMEOUT",`${e} timed out after ${r}ms`))},r)};w()}let g=d?()=>{u.frameIdleTimer&&clearTimeout(u.frameIdleTimer),u.frameIdleTimer=setTimeout(()=>{if(this.inflightAgentRequests.size>0){this.log.debug("frame-idle fired but agent request inflight, re-arming",{id:o,method:e,inflight:this.inflightAgentRequests.size,...c?{sessionId:c}:{}}),g?.();return}u.timer&&clearTimeout(u.timer),this.pending.delete(o),this.log.warn("frame-idle timeout, rejecting pending call",{id:o,method:e,frameIdleMs:i,...c?{sessionId:c}:{}}),m(new _("AGENT_FRAME_IDLE_TIMEOUT",`${e} no session/update for ${i}ms (no inflight agent request)`))},i)}:null;u.armFrameIdle=g,this.pending.set(o,u),g?.();try{this.writeFrame(a)}catch(w){u.timer&&clearTimeout(u.timer),u.frameIdleTimer&&clearTimeout(u.frameIdleTimer),this.pending.delete(o),m(w)}})}writeFrame(e){if(!this.child?.stdin||this.child.stdin.destroyed)throw new _("AGENT_PROTOCOL_ERROR","downstream stdin not writable");this.child.stdin.write(xf(e),n=>{n&&this.log.warn("stdin write callback err",{err:String(n)})})}dispatch(e){if(qs(e)){let n=e.id!==null?this.pending.get(e.id):void 0;if(!n){this.log.warn("orphan response",{id:e.id});return}this.pending.delete(e.id),n.timer&&clearTimeout(n.timer),n.frameIdleTimer&&clearTimeout(n.frameIdleTimer),e.error?(this.log.warn("downstream returned error frame",{id:e.id,method:n.method,code:e.error.code,message:e.error.message,data:e.error.data}),n.reject(bf(e.error))):e.result===void 0?(this.log.warn("downstream response missing both result and error",{id:e.id,method:n.method}),n.reject(new _("AGENT_PROTOCOL_ERROR",`${n.method} response missing both result and error`))):(this.log.info("downstream returned result",{id:e.id,method:n.method,result:H_(e.result)}),n.resolve(e.result));return}if(kf(e)){if(e.method==="session/update"){for(let n of this.pending.values())n.armFrameIdle?.();for(let n of this.updateHandlers)try{Promise.resolve(n(e.params)).catch(r=>this.log.warn("update handler failed (async)",{err:String(r)}))}catch(r){this.log.warn("update handler threw sync, swallowed",{err:String(r)})}}else this.log.info("unknown notification (drop, not forwarded)",{method:e.method});return}if(Rf(e)){let n=e;try{this.handleAgentRequest(n).catch(r=>this.log.error("agent request handler failed (async)",{method:n.method,err:String(r)}))}catch(r){this.log.warn("handleAgentRequest threw sync, swallowed",{method:n.method,err:String(r)})}}}async handleAgentRequest(e){if(this.agentRequestHandlers.length===0){this.writeFrame(Ht(e.id,{code:-32601,message:`method not handled by Bridge: ${e.method}`}));return}this.inflightAgentRequests.set(e.id,e.method);for(let n of this.agentRequestHandlers)try{await n(e)}catch(r){this.log.error("agentRequestHandler threw",{method:e.method,err:String(r)});try{this.writeFrame(Ht(e.id,di(r)))}catch{}this.inflightAgentRequests.delete(e.id)}}failAllPending(e){for(let n of this.pending.values())n.timer&&clearTimeout(n.timer),n.frameIdleTimer&&clearTimeout(n.frameIdleTimer),n.reject(e);this.pending.clear(),this.inflightAgentRequests.clear()}};function j_(t){let e={};for(let[n,r]of Object.entries(t))r!==void 0&&(n.startsWith("CLAUDE")||n==="AI_AGENT"||n==="BAGGAGE"||(e[n]=r));return e}var Js=class extends ct{framework="claude-code";constructor(e){let n=Ar("claude-code",e.command),r=e.args??[],i={command:n,args:r,cwd:e.cwd,agentId:e.agentId,...e.env?{env:e.env}:{}};super(i)}sanitizeEnv(e){return j_(e)}};tn();import{mkdtempSync as W_,rmSync as q_}from"node:fs";import{tmpdir as V_}from"node:os";import{join as J_}from"node:path";var Zs=class extends ct{framework="codex";authMethodId;codexHomeDir;constructor(e){let n=Ar("codex",e.command),r=e.args??[],i=e.extraArgs?[...r,...e.extraArgs]:r,s=e.isolateCodexHome?W_(J_(V_(),"coze-bridge-codex-home-")):void 0,o=s?{...e.env??{},CODEX_HOME:s}:e.env,a={command:n,args:i,cwd:e.cwd,agentId:e.agentId,...o?{env:o}:{}};super(a),this.authMethodId=e.authMethodId,this.codexHomeDir=s}async initialize(e){let n=await super.initialize(e);return this.authMethodId&&await this.call("authenticate",{methodId:this.authMethodId}),n}async stop(e){if(await super.stop(e),this.codexHomeDir)try{q_(this.codexHomeDir,{recursive:!0,force:!0})}catch{}}};var Z_=3e4,sr=class extends ct{framework="openclaw";agentId;sessionName;slashModelOnStart;constructor(e){let n=e.sessionName??"default",r=["acp","--session",`agent:${e.agentId}:${n}`];e.gatewayToken&&r.push("--token",e.gatewayToken);let i={command:e.command,args:r,cwd:e.cwd,agentId:e.agentId,...e.env?{env:e.env}:{}};super(i),this.agentId=e.agentId,this.sessionName=n,this.slashModelOnStart=e.slashModelOnStart}async afterSessionEstablished(e){this.slashModelOnStart&&(this.log.info("switching session to per-session provider via /model",{agentId:this.agentId,sessionName:this.sessionName,slash:this.slashModelOnStart}),await this.sessionPrompt({sessionId:e,prompt:[{type:"text",text:`/model ${this.slashModelOnStart}`}]},Z_))}get acpSessionName(){return this.sessionName}};Te();L();le();function _c(t){return t.replace(/[^A-Za-z0-9._-]+/g,"-")}tn();var jt=class{slots=[];running=!1;closed=!1;disposed=!1;enqueue(e){return this.disposed?Promise.reject(new Error("AsyncQueue disposed")):this.closed?Promise.reject(new Error("AsyncQueue closed")):new Promise((n,r)=>{this.slots.push({task:e,resolve:n,reject:r}),this.drain()})}close(){this.closed=!0}dispose(e=new Error("AsyncQueue disposed")){for(this.disposed=!0,this.closed=!0;this.slots.length>0;)this.slots.shift()?.reject(e)}get size(){return this.slots.length}get isRunning(){return this.running}get isDisposed(){return this.disposed}async drain(){if(!this.running){this.running=!0;try{for(;this.slots.length>0&&!this.disposed;){let e=this.slots.shift();if(!e)break;try{let n=await e.task();e.resolve(n)}catch(n){e.reject(n)}}}finally{this.running=!1}}}};var Ks=class{agentId;framework;workspace;deployType;accountId;patToken;modelInfo;sessions=new Map;sessionQueues=new Map;activeTriggers=new Map;activeGroupIds=new Map;status="ok";model;lastActiveAt=Date.now();constructor(e){this.agentId=e.agentId,this.framework=e.framework,this.workspace=e.workspace,this.model=e.model,this.deployType=e.deployType??"local",e.accountId&&(this.accountId=e.accountId),e.patToken&&(this.patToken=e.patToken),e.modelInfo&&(this.modelInfo=e.modelInfo)}setPatToken(e){this.patToken=e}setModelInfo(e){this.modelInfo=e}getSessionQueue(e){let n=this.sessionQueues.get(e);return(!n||n.isDisposed)&&(n=new jt,this.sessionQueues.set(e,n)),n}allSessionQueues(){return this.sessionQueues.entries()}hasSessionQueue(e){let n=this.sessionQueues.get(e);return!!n&&!n.isDisposed}async dispose(e){this.status="stopped";let n=new Error(`AgentSession disposed${e?`: ${e}`:""}`);for(let r of this.sessionQueues.values())r.dispose(n);this.sessionQueues.clear(),await this.killAllRuntimes(e??"dispose")}async killAllRuntimes(e){let n=[];for(let[,r]of this.sessions)ui(r),r.downstream&&(n.push(r.downstream.stop(e).catch(()=>{})),r.downstream=void 0);await Promise.all(n),this.activeTriggers.clear(),this.activeGroupIds.clear()}};function ui(t){t.idleTimer&&(clearTimeout(t.idleTimer),t.idleTimer=void 0)}gt();L();import{promises as Ec}from"node:fs";import{join as K_}from"node:path";var wn=b("agents.codex-sandbox-installer"),Nf="@openai/codex@0.135.0",Lf="https://registry.npmmirror.com",Sc="/usr/lib/node_modules/@openai/codex/node_modules/@openai/codex-linux-x64/vendor/x86_64-unknown-linux-musl/bin/codex",X_="/usr/bin",Ff=["apply_patch","applypatch","codex-execve-wrapper","codex-linux-sandbox"],Y_=9e4,Q_=5e3,fi=null,Mf=!1;async function Bf(t,e={}){if((e.platform??process.platform)!=="linux"||Mf)return;if(fi)return fi;let r=e.exec??Pn,i=e.statFile??(async a=>{try{return await Ec.stat(a),!0}catch{return!1}}),s=e.symlink??((a,c)=>Ec.symlink(a,c)),o=e.unlink??(a=>Ec.unlink(a));return fi=(async()=>{try{let a=!1;try{let{stdout:l}=await r("which",["codex"],{timeout:Q_});a=l.trim().length>0}catch{a=!1}if(a)wn.info("codex already present, skip install");else{wn.info("codex not found, installing",{package:Nf,registry:Lf});try{await r("npm",["i","-g",Nf,`--registry=${Lf}`],{timeout:Y_,maxBuffer:10*1024*1024,signal:t}),wn.info("codex install ok")}catch(l){wn.warn("codex install failed (skip symlinks)",{err:String(l)});return}}if(!await i(Sc)){wn.warn("codex vendor bin not found, skip symlinks",{target:Sc});return}let c=0;for(let l of Ff){let d=K_(X_,l);try{await o(d).catch(()=>{}),await s(Sc,d),c+=1,wn.info("codex sandbox symlink created",{link:d})}catch(p){wn.warn("codex sandbox symlink failed (ignored)",{link:d,err:String(p)})}}c===Ff.length&&(Mf=!0)}finally{fi=null}})(),fi}gt();L();import{constants as Uf,access as eE}from"node:fs/promises";import{delimiter as tE,join as nE}from"node:path";var Wt=b("framework-detector"),zf={"claude-code":"claude",codex:"codex",openclaw:"openclaw"},rE=[".exe",".cmd",".bat",".ps1"],qt=class{env;constructor(e={}){this.env={pathEnv:e.pathEnv??process.env.PATH??"",platform:e.platform??process.platform,spawn:e.spawn??Fe,access:e.access??eE}}async detect(e){let n=zf[e],r=await this.which(n);if(!r)return Wt.debug("framework binary not found",{framework:e,bin:n}),null;let i=e==="openclaw"?["--log-level","silent"]:[],[s,o]=await Promise.all([this.probeVersion(r,i),e==="openclaw"?this.probeOpenclawDefaultAgent(r):Promise.resolve(null)]),a={path:r,version:s};return o&&(a.defaultAgent=o),a}async detectAll(){let e=await Promise.all(Object.keys(zf).map(async r=>[r,await this.detect(r)])),n={};for(let[r,i]of e)i&&(n[r]=i);return n}async which(e){let n=this.env.pathEnv.split(tE).filter(Boolean),r=this.env.platform==="win32"?["",...rE]:[""];for(let i of n)for(let s of r){let o=nE(i,e+s);if(await this.isExecutable(o))return o}return null}async isExecutable(e){try{let n=this.env.platform==="win32"?Uf.F_OK:Uf.X_OK;return await this.env.access(e,n),!0}catch{return!1}}async probeOpenclawDefaultAgent(e){let n=await this.runProbe(e,["--log-level","silent","agents","list","--json"]);if(!n)return Wt.warn("openclaw default agent probe: runProbe returned null (spawn err / timeout)",{path:e}),null;if(n.code!==0)return Wt.warn("openclaw default agent probe: non-zero exit",{path:e,code:n.code,stdoutHead:n.stdout.slice(0,200)}),null;let r=n.stdout.match(/\[\s*\{[\s\S]*\}\s*\]/);if(!r)return Wt.warn("openclaw default agent probe: regex no match (no JSON array in stdout)",{path:e,stdoutHead:n.stdout.slice(0,200)}),null;try{let i=JSON.parse(r[0]);if(!Array.isArray(i))return Wt.warn("openclaw default agent probe: JSON parsed but not an array",{path:e}),null;let s=i.find(o=>o?.isDefault===!0);return s?!s.id||!s.workspace?(Wt.warn("openclaw default agent probe: default agent missing id or workspace",{path:e,hasId:!!s.id,hasWorkspace:!!s.workspace}),null):{id:s.id,workspace:s.workspace}:(Wt.info("openclaw default agent probe: no agent has isDefault=true",{path:e,agentCount:i.length}),null)}catch(i){return Wt.warn("openclaw default agent probe: JSON.parse failed",{path:e,err:String(i),matchHead:r[0].slice(0,200)}),null}}async probeVersion(e,n=[]){let r=await this.runProbe(e,[...n,"--version"]);return r&&(sE(r.stdout).split(/\r?\n/)[0]??"").trim()||"unknown"}runProbe(e,n){return new Promise(r=>{let i="",s=!1,o,a=c=>{s||(s=!0,o&&clearTimeout(o),r(c))};try{let c=this.env.spawn(e,n,{stdio:["ignore","pipe","pipe"]});o=setTimeout(()=>{c.kill("SIGKILL"),a(null)},15e3),c.stdout?.on("data",l=>{i+=l.toString("utf8")}),c.on("error",()=>a(null)),c.on("close",l=>a({code:l,stdout:i}))}catch{a(null)}})}},iE=new RegExp("\x1B\\[[0-9;]*[A-Za-z]","g");function sE(t){return t.replace(iE,"")}import{homedir as oE}from"node:os";import{join as aE}from"node:path";gt();Te();qi();L();async function Hf(){let t=aE(oE(),".openclaw/openclaw.json");return(await Nn(t))?.gateway?.auth?.token??""}var $f=b("openclaw.config"),cE=[0,5e3,5e3],Gf="models.providers.",Xs="agents.defaults.models",Ys=class{command;env;retryDelaysMs;queue=new jt;constructor(e){this.command=e.command,this.env=e.env??process.env,this.retryDelaysMs=e.retryDelaysMs??cE}async withRetry(e,n){let r;for(let i=0;i<this.retryDelaysMs.length;i++){let s=this.retryDelaysMs[i]??0;s>0&&await new Promise(o=>setTimeout(o,s));try{return await n()}catch(o){r=o,$f.warn("openclaw cli failed, will retry",{label:e,attempt:i+1,err:String(o)})}}throw new _("AGENT_SPAWN_FAILED",`openclaw cli ${e} failed after ${this.retryDelaysMs.length} attempts: ${r?.message??"unknown"}`)}runCli(e){return new Promise((n,r)=>{let i=Fe(this.command,e,{stdio:["ignore","pipe","pipe"],env:this.env}),s="";i.stderr?.on("data",o=>{s+=o.toString("utf8")}),i.on("error",r),i.on("close",o=>{o===0?n():r(new Error(`exit ${o}: ${s.trim().slice(0,500)}`))})})}async runCliTolerant(e,n){try{await this.runCli(e)}catch(r){let i=String(r);if(n.some(s=>i.includes(s)))return;throw r}}async bestEffortUnset(e,n){try{await this.queue.enqueue(()=>this.withRetry(e,()=>this.runCli(["config","unset",n])))}catch(r){$f.warn(`${e} failed (best-effort)`,{configPath:n,err:String(r)})}}ensureProvider(e,n){return this.queue.enqueue(()=>this.withRetry(`config set models.providers.${e}`,()=>this.runCli(["config","set",`${Gf}${e}`,JSON.stringify(n),"--strict-json","--merge"])))}removeProvider(e){return this.bestEffortUnset(`config unset models.providers.${e}`,`${Gf}${e}`)}addModelToAllowlist(e,n){let r={[e]:n?{alias:n}:{}};return this.queue.enqueue(()=>this.withRetry(`config set ${Xs}[${e}]`,()=>this.runCli(["config","set",Xs,JSON.stringify(r),"--strict-json","--merge"])))}removeModelFromAllowlist(e){return this.bestEffortUnset(`config unset ${Xs}[${e}]`,`${Xs}.${e}`)}ensureAgent(e,n,r){let i=["agents","add",e,"--workspace",n,"--non-interactive"];return r&&i.push("--model",r),this.queue.enqueue(()=>this.withRetry(`agents add ${e}`,()=>this.runCliTolerant(i,["already exists","already registered"])))}restartGateway(){return this.queue.enqueue(()=>this.withRetry("gateway restart",()=>this.runCli(["gateway","restart"])))}deleteAgent(e){return this.queue.enqueue(()=>this.withRetry(`agents delete ${e}`,()=>this.runCliTolerant(["agents","delete",e,"--force"],["not found","does not exist"])))}};var K=b("agent-manager"),pE=(t,e,n,r,i,s,o,a,c)=>{switch(t){case"claude-code":{let l={...i?{...uf(i),...pf(i,o,a)}:{},...c??{},IS_SANDBOX:"1"};return new Js({cwd:n,env:l,agentId:r})}case"codex":{let d=[...i?[...ff(i),...mf(i,o,a)]:[],"-c",'sandbox_mode="danger-full-access"',"-c",'approval_policy="never"'],p={...i?hf(i):{},...c??{}},m=!!i;return new Zs({cwd:n,agentId:r,...d.length>0?{extraArgs:d}:{},...Object.keys(p).length>0?{env:p}:{},...m?{authMethodId:"openai-api-key",isolateCodexHome:!0}:{}})}case"openclaw":return new sr({command:e,cwd:n,agentId:r,...s?{sessionName:_c(s)}:{}})}};function vc(t){return t==="claude-code"||t==="codex"}function gE(t){let e=[],n=Object.keys(t).sort();for(let r of n){let i=t[r];i!==void 0&&(mE(i)||e.push(`${r}=${i}`))}return e.length===0?"":`${e.join(`
94
94
  `)}
95
95
  `}function mE(t){if(t.includes(`
96
- `)||t.includes("\r")||t.includes("$")||t.includes("#"))return!0;let e=t[0];return e==="'"||e==='"'}var wE={path:"",version:"cloud-deployed"},yE={protocolVersion:1,clientCapabilities:{fs:{readTextFile:!0,writeTextFile:!0}}},_E=6e4,Qs=class{paths;config;registry;factory;createTimeoutMs;openclawConfigCache;ensuredProviders=new Set;detectorFactory;openclawEnvBootstrapPromise;openclawConfigFactory;openclawConfigDir;constructor(e){this.paths=e.paths,this.config=e.config,this.registry=e.registry,this.factory=e.downstreamFactory??pE,this.createTimeoutMs=e.createTimeoutMs??_E,this.detectorFactory=e.detectorFactory??(()=>new qt),this.openclawConfigFactory=e.openclawConfigFactory??(n=>new Xs({command:n})),this.openclawConfigDir=e.openclawConfigDir??jf(hE(),".openclaw")}buildBinShimPathEnv(){let e=process.platform==="win32"?";":":";return{PATH:`${this.paths.binDir}${e}${process.env.PATH??""}`}}getOpenclawConfig(){if(!this.openclawConfigCache){let e=this.config.frameworksCache?.openclaw;if(!e?.path)throw new _("AGENT_SPAWN_FAILED","openclaw binary not detected on this machine");this.openclawConfigCache=this.openclawConfigFactory(e.path)}return this.openclawConfigCache}bootstrapOpenclawEnvIfNeeded(){return this.openclawEnvBootstrapPromise?this.openclawEnvBootstrapPromise:(this.openclawEnvBootstrapPromise=this.doBootstrapOpenclawEnv().catch(e=>{K.warn("openclaw env bootstrap failed (ignored)",{err:String(e)}),this.openclawEnvBootstrapPromise=void 0}),this.openclawEnvBootstrapPromise)}async doBootstrapOpenclawEnv(){let e=this.openclawConfigDir,n=jf(e,".env");if(await uE(n).then(s=>s.isFile()).catch(()=>!1)){K.debug("openclaw .env exists, skip bootstrap",{envFile:n});return}await Ys(e,{recursive:!0});let i=gE(process.env);if(await fE(n,i,"utf8"),process.platform!=="win32")try{await lE(n,384)}catch(s){K.warn("chmod ~/.openclaw/.env to 0600 failed (ignored)",{err:String(s)})}K.info("openclaw .env bootstrapped",{envFile:n,bytes:i.length}),await this.getOpenclawConfig().restartGateway(),K.info("openclaw gateway restarted after env bootstrap")}async createAgent(e){if(!e.agentId)throw new _("IPC_BAD_REQUEST","agentId required");if(!e.framework)throw new _("IPC_BAD_REQUEST","framework required");let n=ni(e._meta)==="cloud";this.registry.reviveIfDisconnected?.(e.agentId);let r=this.registry.get(e.agentId);if(r){if(r.framework!==e.framework)throw new _("AGENT_BUSY",`agent ${e.agentId} exists with different framework (${r.framework})`);if(r.status==="error")K.warn("existing agent in error state, rebuilding",{agentId:e.agentId}),await r.dispose("rebuild after error").catch(h=>K.warn("dispose stale agent failed (ignored)",{err:String(h)})),this.registry.unregister(e.agentId);else{if(e.patToken&&e.patToken!==r.patToken){K.info("updating agent patToken on re-create (reconnect with new PAT)",{agentId:e.agentId}),r.setPatToken(e.patToken);let h=await me(e.agentId,this.paths).catch(()=>null);h&&(h.patToken=e.patToken,await Ae(h,this.paths))}if(r.deployType==="cloud"&&e.modelInfo){K.info("updating agent modelInfo on re-create",{agentId:e.agentId}),r.setModelInfo(e.modelInfo);let h=await me(e.agentId,this.paths).catch(()=>null);h&&(h.modelInfo=e.modelInfo,await Ae(h,this.paths))}return K.info("agent already exists, return current",{agentId:e.agentId}),{ok:!0,agentId:r.agentId,workspace:r.workspace,framework:r.framework}}}if(!n&&!this.config.frameworksCache?.[e.framework])throw new _("AGENT_SPAWN_FAILED",`framework ${e.framework} not detected on this machine; rerun daemon to refresh frameworks_cache`);let s=be(e.agentId,this.paths),o=ni(e._meta),a=e.framework==="openclaw"&&o==="local",c=a?this.config.frameworksCache?.openclaw?.defaultAgent?.workspace:void 0,l=e.workspace??c??s.workspace,d=new AbortController,p=setTimeout(()=>d.abort(new _("AGENT_TIMEOUT",`_agent/create timed out after ${this.createTimeoutMs}ms`)),this.createTimeoutMs),m,u=!1;try{n&&Ec(e.framework)&&(e.framework==="codex"?await Promise.all([en("codex",d.signal),Bf(d.signal)]):await en(e.framework,d.signal));let h=()=>{if(d.signal.aborted)throw d.signal.reason instanceof Error?d.signal.reason:new _("AGENT_TIMEOUT","_agent/create aborted")};await Ys(s.root,{recursive:!0}),await Ys(l,{recursive:!0}),await Ys(s.logs,{recursive:!0}),h(),a||await Ln(l,e.framework,e.cozeIdentity),e.framework==="claude-code"&&await sd(l),h();let g=await me(e.agentId,this.paths).catch(()=>null),w=lf({model:e.model??g?.model}),S=ef(e._meta)??g?.accountId,v=e.patToken??g?.patToken,f=o==="cloud"?e.modelInfo??g?.modelInfo:void 0;if(m=new Zs({agentId:e.agentId,framework:e.framework,workspace:l,model:w.model??Ke,deployType:o,...S?{accountId:S}:{},...v?{patToken:v}:{},...f?{modelInfo:f}:{}}),m.status="ok",g?.sessions){for(let[R,D]of Object.entries(g.sessions))m.sessions.set(R,{acpSessionId:D.acpSessionId,modelToken:D.modelToken,tokenGeneratedAt:D.tokenGeneratedAt,lastActiveAt:Date.now(),loadingSession:!1,replySeq:0});let T=Object.keys(g.sessions).length;T>0&&K.info("restored persisted session records (no spawn)",{agentId:e.agentId,count:T})}this.registry.register(m),u=!0;let y={agentId:e.agentId,framework:e.framework,workspace:l,cozeIdentity:e.cozeIdentity,createdAt:g?.createdAt??Date.now(),sessions:g?.sessions??{},model:w.model};o==="cloud"&&(y.deployType="cloud"),S&&(y.accountId=S),v&&(y.patToken=v),f&&(y.modelInfo=f),g?.skills&&(y.skills=g.skills),g?.agentName&&(y.agentName=g.agentName),g?.description&&(y.description=g.description),e.framework==="openclaw"&&o==="cloud"&&(this.config.frameworksCache?.openclaw?.path?(await this.bootstrapOpenclawEnvIfNeeded(),await this.getOpenclawConfig().ensureAgent(e.agentId,l)):K.warn("openclaw binary not on this machine, skip agents add (will fail at session/prompt)",{agentId:e.agentId}));let E=e.initialSkills??[];if(E.length>0){let T=[...y.skills??[]],R=new Map(T.map((G,M)=>[G.skillId,M])),D=await Promise.allSettled(E.map(G=>gc({agentId:e.agentId,workspace:l,framework:e.framework,skill:G}))),C=0;for(let[G,M]of D.entries()){let oe=E[G];oe&&(M.status==="fulfilled"?(mc(T,R,M.value),C++):K.warn("initialSkill install failed (skipping)",{agentId:e.agentId,skillId:oe.skillId,skillName:oe.skillName,err:String(M.reason)}))}C>0&&(y.skills=T,K.info("initialSkills installed",{agentId:e.agentId,installed:C,requested:E.length}))}return await Ae(y,this.paths),K.info("agent created (no spawn, lazy on first prompt)",{agentId:e.agentId,framework:e.framework,deployType:o}),{ok:!0,agentId:e.agentId,workspace:l,framework:e.framework}}catch(h){throw K.error("agent create failed, rolling back",{agentId:e.agentId,err:String(h)}),u&&m&&(await m.dispose("rollback").catch(()=>{}),this.registry.unregister(e.agentId)),await dE(s.root,{recursive:!0,force:!0}).catch(g=>K.warn("rm agent dir failed (ignored)",{err:String(g)})),h instanceof _?h:new _("AGENT_SPAWN_FAILED",String(h),{cause:h})}finally{clearTimeout(p)}}async spawnSessionDownstream(e,n,r,i,s){let a=this.config.frameworksCache?.[e.framework];if(!a)if(e.deployType==="cloud"&&Ec(e.framework))a=wE;else throw new _("AGENT_SPAWN_FAILED",`framework ${e.framework} not detected on this machine`);if(Ec(e.framework)&&!kr(e.framework)){let d=Vo(e.framework);K.info("spawn: ensuring acp wrapper installed",{agentId:e.agentId,framework:e.framework,reusingInFlight:!!d}),await en(e.framework)}let c=e.deployType==="cloud"?{model:e.model,modelToken:n,...e.modelInfo?{modelInfo:e.modelInfo}:{}}:void 0,l;e.framework==="openclaw"?l=await this.buildOpenclawDownstream({session:e,modelConfig:c,cloudSessionId:r,cozeEnv:i,mockScenario:s,command:a.path}):l=this.factory(e.framework,a.path,e.workspace,e.agentId,c,r,i,s,this.buildBinShimPathEnv());try{return await l.start(),await l.initialize(yE),l}catch(d){let p=l instanceof ct?l.getStderrTail():[];throw p.length>0&&K.warn("spawnSessionDownstream failed, recent stderr (D94)",{agentId:e.agentId,framework:e.framework,method:d instanceof _?d.code:"unknown",recentStderr:p}),await l.stop("spawnSessionDownstream failed").catch(()=>{}),d instanceof _?new _(d.code,d.message,{retriable:d.retriable,cause:d}):new _("AGENT_SPAWN_FAILED",d instanceof Error?d.message:String(d),{cause:d})}}async buildOpenclawDownstream(e){let{session:n,modelConfig:r,cloudSessionId:i,cozeEnv:s,mockScenario:o,command:a}=e,c=wc(i);if(n.deployType==="local"){let m=this.config.frameworksCache?.openclaw?.defaultAgent;if(!m?.id||!m.workspace){K.warn("openclaw default agent stale or missing, attempting lazy re-detect");let h=await this.detectorFactory().detect("openclaw");if(h?.defaultAgent?.id&&h?.defaultAgent?.workspace)K.info("openclaw lazy re-detect success",{agentId:h.defaultAgent.id,workspace:h.defaultAgent.workspace}),this.config.frameworksCache||(this.config.frameworksCache={}),this.config.frameworksCache.openclaw=h,m=h.defaultAgent;else throw new _("AGENT_SPAWN_FAILED","openclaw default agent \u672A\u63A2\u6D4B\u5230; \u8BF7\u5148\u8DD1 `openclaw setup` \u6216 `openclaw agents add` \u521B\u5EFA\u9ED8\u8BA4 agent")}return new sr({command:a,cwd:m.workspace,agentId:m.id,sessionName:c})}let l=await Hf(),d=r?gf(r,s,o):null,p;if(d){let m=cc(i),h=d.models[0]?.id??Ke,g=`${m}/${h}`;if(!this.ensuredProviders.has(g)){let w=this.getOpenclawConfig();await w.ensureProvider(m,d),await w.addModelToAllowlist(g),this.ensuredProviders.add(g)}p=g}return new sr({command:a,cwd:n.workspace,agentId:n.agentId,sessionName:c,...l?{gatewayToken:l}:{},...p?{slashModelOnStart:p}:{}})}async openclawRepair(e,n){let r=this.getOpenclawConfig();await r.deleteAgent(e),await r.ensureAgent(e,n)}async cleanupOpenclawSessionProviders(e){if(e.framework!=="openclaw"||!this.openclawConfigCache)return;let n=this.openclawConfigCache;for(let r of e.sessions.keys()){let i=cc(r),s=`${i}/${e.model}`,o=!0;try{await n.removeProvider(i)}catch(a){o=!1,K.warn("removeProvider failed, keeping ensuredProviders entry",{providerId:i,err:String(a)})}try{await n.removeModelFromAllowlist(s)}catch(a){o=!1,K.warn("removeModelFromAllowlist failed, keeping ensuredProviders entry",{fullModelId:s,err:String(a)})}o&&this.ensuredProviders.delete(s)}}};import{randomUUID as Zf}from"node:crypto";import{promises as bE}from"node:fs";import{basename as Kf}from"node:path";Te();L();import{promises as SE}from"node:fs";import{basename as vE}from"node:path";var Wf=b("file-upload"),IE="/api/coze_claw/file/agent_upload",TE=6e4;async function qf(t,e={}){let r=`${zs(Gs(e.handshakeBase))}${IE}`,i=e.timeoutMs??TE,s=await SE.readFile(t.path),o=new FormData;o.append("agent_id",t.agentId),o.append("session_id",t.sessionId),o.append("file_name",t.name),o.append("file_content",new Blob([s],{type:t.mimeType}),t.name);let a={Authorization:`Bearer ${t.patToken}`,Accept:"application/json","x-coze-version":"3.0",...Qn(e.ppeOverride),...t.accountId?{"x-coze-account":t.accountId}:{}},c=new AbortController,l=setTimeout(()=>c.abort(),i);Wf.info("file upload start",{url:r,agentId:t.agentId,sessionId:t.sessionId,name:t.name,bytes:t.sizeBytes,mime:t.mimeType});try{let d=await fetch(r,{method:"POST",headers:a,body:o,signal:c.signal}),p=d.headers.get("x-tt-logid")??"";if(!d.ok){let h=await d.text().catch(()=>"");throw new _("UPLOAD_FAILED",`upload HTTP ${d.status} logid=${p}: ${h.slice(0,200)}`)}let m=await d.json();if(m.code!==void 0&&m.code!==0)throw new _("UPLOAD_FAILED",`upload code=${m.code} msg=${m.msg??"-"} logid=${p}`);let u=m.data?.file?.file_url;if(!u)throw new _("UPLOAD_FAILED",`upload response missing data.file.file_url logid=${p}: ${JSON.stringify(m).slice(0,200)}`);return Wf.info("file upload ok",{uri:u,logid:p}),{uri:u}}catch(d){throw d instanceof _?d:d.name==="AbortError"?new _("UPLOAD_FAILED",`upload timeout (${i}ms) for ${vE(t.path)}`):new _("UPLOAD_FAILED",String(d),{cause:d})}finally{clearTimeout(l)}}Te();L();import{extname as RE}from"node:path";var kE={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp",".svg":"image/svg+xml",".bmp":"image/bmp",".ico":"image/x-icon",".heic":"image/heic",".heif":"image/heif",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".txt":"text/plain",".md":"text/markdown",".markdown":"text/markdown",".json":"application/json",".yaml":"text/yaml",".yml":"text/yaml",".csv":"text/csv",".html":"text/html",".htm":"text/html",".xml":"application/xml",".log":"text/plain",".zip":"application/zip",".tar":"application/x-tar",".gz":"application/gzip",".tgz":"application/gzip",".mp3":"audio/mpeg",".wav":"audio/wav",".mp4":"video/mp4",".mov":"video/quicktime",".webm":"video/webm"};async function Vf(t){let e=RE(t).toLowerCase();return kE[e]??"application/octet-stream"}le();var eo=b("agent-send"),Jf=50*1024*1024;function Xf(t,e,n){let r=t.get(e);if(!r)throw new _("AGENT_NOT_FOUND",`agent=${e}`);if(t.disconnectedAgents.has(e))throw new _("AGENT_DISCONNECTED",`agent=${e} was disconnected by cloud`);let i=r.sessions.get(n);if(!i)throw new _("AGENT_NOT_FOUND",`session=${n} not active in agent=${e}`);return{session:r,runtime:i}}async function Yf(t,e,n,r,i,s){let a;for(let c=0;c<=2;c++)try{await t.core.sendAgentFileUpdate(e,n,r,i);return}catch(l){a=l,c<2&&(eo.warn("sendAgentFileUpdate failed, retrying",{attempt:c+1,err:String(l)}),await new Promise(d=>setTimeout(d,5e3)))}throw new _("UPSTREAM_NOT_READY",`${s} after 3 attempts: ${String(a)}`,{cause:a})}async function Qf(t,e){let{session:n,runtime:r}=Xf(e.core,t.agentId,t.sessionId);if(!await Ar(t.path,n.workspace))throw new _("PATH_OUTSIDE_WORKSPACE",`path=${t.path} not under workspace=${n.workspace}`);let i=await bE.stat(t.path).catch(()=>null);if(!i||!i.isFile())throw new _("IPC_BAD_REQUEST",`path is not a regular file: ${t.path}`);if(i.size>Jf)throw new _("FILE_TOO_LARGE",`${i.size} bytes > limit ${Jf}`);let s=await Vf(t.path);if(t.kind==="image"&&!s.startsWith("image/"))throw new _("UNSUPPORTED_MIME",`kind=image but mime=${s}`);if(!e.core.upstream.isConnected())throw new _("UPSTREAM_NOT_READY","cloud WS not connected");let o=t.name??Kf(t.path),a;try{a=await qf({patToken:n.patToken??e.patToken,agentId:t.agentId,sessionId:t.sessionId,path:t.path,mimeType:s,name:o,sizeBytes:i.size,...n.accountId?{accountId:n.accountId}:{}},{handshakeBase:e.handshakeBase,ppeOverride:e.ppeOverride})}catch(l){throw eo.warn("agent file upload failed",{agentId:t.agentId,sessionId:t.sessionId,path:t.path,sizeBytes:i.size,mime:s,code:l instanceof _?l.code:"UNKNOWN",message:l instanceof Error?l.message:String(l)}),l}let c={sessionUpdate:"agent_file",messageId:Zf(),content:{type:t.kind==="image"?"image":"resource",uri:a.uri,mimeType:s,name:o,sizeBytes:i.size,...a.fileId!==void 0?{fileId:a.fileId}:{},...t.caption!==void 0?{caption:t.caption}:{}}};return await Yf(e,n,r,t.sessionId,c,"agent file uploaded to cloud but sendAgentFileUpdate failed"),eo.info("agent file sent",{agentId:t.agentId,sessionId:t.sessionId,kind:t.kind,name:o,bytes:i.size,mime:s,uri:a.uri}),{ok:!0,uri:a.uri,bytes:i.size,mimeType:s,...a.fileId!==void 0?{fileId:a.fileId}:{}}}async function eh(t,e){let{session:n,runtime:r}=Xf(e.core,t.agentId,t.sessionId);if(!t.mimeType)throw new _("IPC_BAD_REQUEST","group-file requires mimeType");if(!e.core.upstream.isConnected())throw new _("UPSTREAM_NOT_READY","cloud WS not connected");let i=t.name??Kf(t.path),s={sessionUpdate:"group_file",messageId:Zf(),content:{uri:t.path,name:i,mimeType:t.mimeType,...t.caption!==void 0?{caption:t.caption}:{}}};return await Yf(e,n,r,t.sessionId,s,"agent group file sendAgentFileUpdate failed"),eo.info("agent group file sent",{agentId:t.agentId,sessionId:t.sessionId,uri:t.path,name:i,mime:t.mimeType}),{ok:!0,uri:t.path,bytes:0,mimeType:t.mimeType}}function th(t,e){let n=t.split(".").map(Number),r=e.split(".").map(Number),i=Math.max(n.length,r.length);for(let s=0;s<i;s++){let o=n[s]??0,a=r[s]??0;if(o<a)return!0;if(o>a)return!1}return!1}tn();gt();L();var lt=b("coze-cli-installer"),nh="@coze/cli@latest",AE="coze",rh="0.1.8",xE=5e3,OE=5e3,PE=9e4,ih=1e4,fi=null,to=!1;async function Sc(t,e={}){if(to)return;if(fi)return fi;let n=e.exec??Pn;return fi=(async()=>{try{let r=await CE(AE,n),i=!1;if(r){let o=await DE(n);if(o===void 0)lt.warn("coze-cli found but version unparseable, fall through to full install",{path:r});else if(th(o,rh))lt.info("coze-cli version too old, upgrade-only (preserve user config + auth)",{path:r,version:o,min:rh}),i=!0;else{lt.info("coze-cli already on PATH with sufficient version, skip",{path:r,version:o}),to=!0;return}}let s=i?"upgrade-only":"full";lt.info("coze-cli install start",{package:nh,mode:s});try{await n("npm",["i","-g","--prefer-online",nh],{timeout:PE,maxBuffer:10*1024*1024}),lt.info("coze-cli install ok")}catch(o){lt.warn("coze-cli install failed (skip subsequent steps)",{err:String(o)});return}if(i){to=!0;return}if(t.env)try{await n("coze",["config","set","xTTEnv",t.env],{timeout:ih}),lt.info("coze config set xTTEnv ok",{env:t.env})}catch(o){lt.warn("coze config set failed (continue to auth login)",{err:String(o)})}try{await n("coze",["auth","login","--token",t.patToken],{timeout:ih}),lt.info("coze auth login ok")}catch(o){lt.warn("coze auth login failed",{err:String(o)});return}to=!0}finally{fi=null}})(),fi}async function CE(t,e){let n=process.platform==="win32"?"where":"which";try{let{stdout:r}=await e(n,[t],{timeout:xE});return Hi(r)}catch{return}}async function DE(t){try{let{stdout:e,stderr:n}=await t("coze",["--version"],{timeout:OE});return(e||n).match(/(\d+\.\d+\.\d+)/)?.[1]}catch{return}}Wi();le();var NE=10*6e4;function sh(t){let e=t?.sessionIdleTimeoutMs;return typeof e!="number"||!Number.isFinite(e)||e<=0?NE:e}function no(t){return Nn(t??F().configFile)}function or(t,e){return ji(e??F().configFile,t)}import{randomBytes as eS}from"node:crypto";Li();Te();L();import{createReadStream as LE}from"node:fs";import{mkdir as FE,readFile as ME,realpath as BE,stat as UE,writeFile as zE}from"node:fs/promises";import{basename as $E,dirname as vc,isAbsolute as GE,join as HE,relative as jE,resolve as oh,sep as WE}from"node:path";import{createInterface as qE}from"node:readline";var ch=b("fs-rpc"),hi=pt("COZE_BRIDGE_FS_RPC_MAX_BYTES",20*1024*1024);async function lh(t,e){let n=Buffer.byteLength(t.content,"utf8");if(n>hi)throw new _("IPC_BAD_REQUEST",`fs/write_text_file content too large: ${n} bytes > limit ${hi} bytes`);let r=await uh(t.path,e);return await FE(vc(r),{recursive:!0}),await zE(r,t.content,"utf8"),ch.info("fs/write_text_file ok",{path:r,size:t.content.length}),null}async function dh(t,e){let n=await uh(t.path,e),r=await UE(n),i=typeof t.line=="number"||typeof t.limit=="number";if(r.size>hi&&!i)throw new _("IPC_BAD_REQUEST",`fs/read_text_file too large without line/limit slicing: ${r.size} bytes > ${hi} bytes`);let s;if(i&&r.size>hi)s=await VE(n,t.line??1,t.limit);else{let o=await ME(n,"utf8");if(i){let a=o.split(`
96
+ `)||t.includes("\r")||t.includes("$")||t.includes("#"))return!0;let e=t[0];return e==="'"||e==='"'}var wE={path:"",version:"cloud-deployed"},yE={protocolVersion:1,clientCapabilities:{fs:{readTextFile:!0,writeTextFile:!0}}},_E=6e4,eo=class{paths;config;registry;factory;createTimeoutMs;openclawConfigCache;ensuredProviders=new Set;detectorFactory;openclawEnvBootstrapPromise;openclawConfigFactory;openclawConfigDir;constructor(e){this.paths=e.paths,this.config=e.config,this.registry=e.registry,this.factory=e.downstreamFactory??pE,this.createTimeoutMs=e.createTimeoutMs??_E,this.detectorFactory=e.detectorFactory??(()=>new qt),this.openclawConfigFactory=e.openclawConfigFactory??(n=>new Ys({command:n})),this.openclawConfigDir=e.openclawConfigDir??jf(hE(),".openclaw")}buildBinShimPathEnv(){let e=process.platform==="win32"?";":":";return{PATH:`${this.paths.binDir}${e}${process.env.PATH??""}`}}getOpenclawConfig(){if(!this.openclawConfigCache){let e=this.config.frameworksCache?.openclaw;if(!e?.path)throw new _("AGENT_SPAWN_FAILED","openclaw binary not detected on this machine");this.openclawConfigCache=this.openclawConfigFactory(e.path)}return this.openclawConfigCache}bootstrapOpenclawEnvIfNeeded(){return this.openclawEnvBootstrapPromise?this.openclawEnvBootstrapPromise:(this.openclawEnvBootstrapPromise=this.doBootstrapOpenclawEnv().catch(e=>{K.warn("openclaw env bootstrap failed (ignored)",{err:String(e)}),this.openclawEnvBootstrapPromise=void 0}),this.openclawEnvBootstrapPromise)}async doBootstrapOpenclawEnv(){let e=this.openclawConfigDir,n=jf(e,".env");if(await uE(n).then(s=>s.isFile()).catch(()=>!1)){K.debug("openclaw .env exists, skip bootstrap",{envFile:n});return}await Qs(e,{recursive:!0});let i=gE(process.env);if(await fE(n,i,"utf8"),process.platform!=="win32")try{await lE(n,384)}catch(s){K.warn("chmod ~/.openclaw/.env to 0600 failed (ignored)",{err:String(s)})}K.info("openclaw .env bootstrapped",{envFile:n,bytes:i.length}),await this.getOpenclawConfig().restartGateway(),K.info("openclaw gateway restarted after env bootstrap")}async createAgent(e){if(!e.agentId)throw new _("IPC_BAD_REQUEST","agentId required");if(!e.framework)throw new _("IPC_BAD_REQUEST","framework required");let n=ri(e._meta)==="cloud";this.registry.reviveIfDisconnected?.(e.agentId);let r=this.registry.get(e.agentId);if(r){if(r.framework!==e.framework)throw new _("AGENT_BUSY",`agent ${e.agentId} exists with different framework (${r.framework})`);if(r.status==="error")K.warn("existing agent in error state, rebuilding",{agentId:e.agentId}),await r.dispose("rebuild after error").catch(h=>K.warn("dispose stale agent failed (ignored)",{err:String(h)})),this.registry.unregister(e.agentId);else{if(e.patToken&&e.patToken!==r.patToken){K.info("updating agent patToken on re-create (reconnect with new PAT)",{agentId:e.agentId}),r.setPatToken(e.patToken);let h=await me(e.agentId,this.paths).catch(()=>null);h&&(h.patToken=e.patToken,await Ae(h,this.paths))}if(r.deployType==="cloud"&&e.modelInfo){K.info("updating agent modelInfo on re-create",{agentId:e.agentId}),r.setModelInfo(e.modelInfo);let h=await me(e.agentId,this.paths).catch(()=>null);h&&(h.modelInfo=e.modelInfo,await Ae(h,this.paths))}return K.info("agent already exists, return current",{agentId:e.agentId}),{ok:!0,agentId:r.agentId,workspace:r.workspace,framework:r.framework}}}if(!n&&!this.config.frameworksCache?.[e.framework])throw new _("AGENT_SPAWN_FAILED",`framework ${e.framework} not detected on this machine; rerun daemon to refresh frameworks_cache`);let s=be(e.agentId,this.paths),o=ri(e._meta),a=e.framework==="openclaw"&&o==="local",c=a?this.config.frameworksCache?.openclaw?.defaultAgent?.workspace:void 0,l=e.workspace??c??s.workspace,d=new AbortController,p=setTimeout(()=>d.abort(new _("AGENT_TIMEOUT",`_agent/create timed out after ${this.createTimeoutMs}ms`)),this.createTimeoutMs),m,u=!1;try{n&&vc(e.framework)&&(e.framework==="codex"?await Promise.all([en("codex",d.signal),Bf(d.signal)]):await en(e.framework,d.signal));let h=()=>{if(d.signal.aborted)throw d.signal.reason instanceof Error?d.signal.reason:new _("AGENT_TIMEOUT","_agent/create aborted")};await Qs(s.root,{recursive:!0}),await Qs(l,{recursive:!0}),await Qs(s.logs,{recursive:!0}),h(),a||await Ln(l,e.framework,e.cozeIdentity),e.framework==="claude-code"&&await sd(l),h();let g=await me(e.agentId,this.paths).catch(()=>null),w=lf({model:e.model??g?.model}),S=ef(e._meta)??g?.accountId,v=e.patToken??g?.patToken,f=o==="cloud"?e.modelInfo??g?.modelInfo:void 0;if(m=new Ks({agentId:e.agentId,framework:e.framework,workspace:l,model:w.model??Ke,deployType:o,...S?{accountId:S}:{},...v?{patToken:v}:{},...f?{modelInfo:f}:{}}),m.status="ok",g?.sessions){for(let[R,D]of Object.entries(g.sessions))m.sessions.set(R,{acpSessionId:D.acpSessionId,modelToken:D.modelToken,tokenGeneratedAt:D.tokenGeneratedAt,lastActiveAt:Date.now(),loadingSession:!1,replySeq:0});let T=Object.keys(g.sessions).length;T>0&&K.info("restored persisted session records (no spawn)",{agentId:e.agentId,count:T})}this.registry.register(m),u=!0;let y={agentId:e.agentId,framework:e.framework,workspace:l,cozeIdentity:e.cozeIdentity,createdAt:g?.createdAt??Date.now(),sessions:g?.sessions??{},model:w.model};o==="cloud"&&(y.deployType="cloud"),S&&(y.accountId=S),v&&(y.patToken=v),f&&(y.modelInfo=f),g?.skills&&(y.skills=g.skills),g?.agentName&&(y.agentName=g.agentName),g?.description&&(y.description=g.description),e.framework==="openclaw"&&o==="cloud"&&(this.config.frameworksCache?.openclaw?.path?(await this.bootstrapOpenclawEnvIfNeeded(),await this.getOpenclawConfig().ensureAgent(e.agentId,l)):K.warn("openclaw binary not on this machine, skip agents add (will fail at session/prompt)",{agentId:e.agentId}));let E=e.initialSkills??[];if(E.length>0){let T=[...y.skills??[]],R=new Map(T.map((G,M)=>[G.skillId,M])),D=await Promise.allSettled(E.map(G=>wc({agentId:e.agentId,workspace:l,framework:e.framework,skill:G}))),C=0;for(let[G,M]of D.entries()){let oe=E[G];oe&&(M.status==="fulfilled"?(yc(T,R,M.value),C++):K.warn("initialSkill install failed (skipping)",{agentId:e.agentId,skillId:oe.skillId,skillName:oe.skillName,err:String(M.reason)}))}C>0&&(y.skills=T,K.info("initialSkills installed",{agentId:e.agentId,installed:C,requested:E.length}))}return await Ae(y,this.paths),K.info("agent created (no spawn, lazy on first prompt)",{agentId:e.agentId,framework:e.framework,deployType:o}),{ok:!0,agentId:e.agentId,workspace:l,framework:e.framework}}catch(h){throw K.error("agent create failed, rolling back",{agentId:e.agentId,err:String(h)}),u&&m&&(await m.dispose("rollback").catch(()=>{}),this.registry.unregister(e.agentId)),await dE(s.root,{recursive:!0,force:!0}).catch(g=>K.warn("rm agent dir failed (ignored)",{err:String(g)})),h instanceof _?h:new _("AGENT_SPAWN_FAILED",String(h),{cause:h})}finally{clearTimeout(p)}}async spawnSessionDownstream(e,n,r,i,s){let a=this.config.frameworksCache?.[e.framework];if(!a)if(e.deployType==="cloud"&&vc(e.framework))a=wE;else throw new _("AGENT_SPAWN_FAILED",`framework ${e.framework} not detected on this machine`);if(vc(e.framework)&&!br(e.framework)){let d=Zo(e.framework);K.info("spawn: ensuring acp wrapper installed",{agentId:e.agentId,framework:e.framework,reusingInFlight:!!d}),await en(e.framework)}let c=e.deployType==="cloud"?{model:e.model,modelToken:n,...e.modelInfo?{modelInfo:e.modelInfo}:{}}:void 0,l;e.framework==="openclaw"?l=await this.buildOpenclawDownstream({session:e,modelConfig:c,cloudSessionId:r,cozeEnv:i,mockScenario:s,command:a.path}):l=this.factory(e.framework,a.path,e.workspace,e.agentId,c,r,i,s,this.buildBinShimPathEnv());try{return await l.start(),await l.initialize(yE),l}catch(d){let p=l instanceof ct?l.getStderrTail():[];throw p.length>0&&K.warn("spawnSessionDownstream failed, recent stderr (D94)",{agentId:e.agentId,framework:e.framework,method:d instanceof _?d.code:"unknown",recentStderr:p}),await l.stop("spawnSessionDownstream failed").catch(()=>{}),d instanceof _?new _(d.code,d.message,{retriable:d.retriable,cause:d}):new _("AGENT_SPAWN_FAILED",d instanceof Error?d.message:String(d),{cause:d})}}async buildOpenclawDownstream(e){let{session:n,modelConfig:r,cloudSessionId:i,cozeEnv:s,mockScenario:o,command:a}=e,c=_c(i);if(n.deployType==="local"){let m=this.config.frameworksCache?.openclaw?.defaultAgent;if(!m?.id||!m.workspace){K.warn("openclaw default agent stale or missing, attempting lazy re-detect");let h=await this.detectorFactory().detect("openclaw");if(h?.defaultAgent?.id&&h?.defaultAgent?.workspace)K.info("openclaw lazy re-detect success",{agentId:h.defaultAgent.id,workspace:h.defaultAgent.workspace}),this.config.frameworksCache||(this.config.frameworksCache={}),this.config.frameworksCache.openclaw=h,m=h.defaultAgent;else throw new _("AGENT_SPAWN_FAILED","openclaw default agent \u672A\u63A2\u6D4B\u5230; \u8BF7\u5148\u8DD1 `openclaw setup` \u6216 `openclaw agents add` \u521B\u5EFA\u9ED8\u8BA4 agent")}return new sr({command:a,cwd:m.workspace,agentId:m.id,sessionName:c})}let l=await Hf(),d=r?gf(r,s,o):null,p;if(d){let m=dc(i),h=d.models[0]?.id??Ke,g=`${m}/${h}`;if(!this.ensuredProviders.has(g)){let w=this.getOpenclawConfig();await w.ensureProvider(m,d),await w.addModelToAllowlist(g),this.ensuredProviders.add(g)}p=g}return new sr({command:a,cwd:n.workspace,agentId:n.agentId,sessionName:c,...l?{gatewayToken:l}:{},...p?{slashModelOnStart:p}:{}})}async openclawRepair(e,n){let r=this.getOpenclawConfig();await r.deleteAgent(e),await r.ensureAgent(e,n)}async cleanupOpenclawSessionProviders(e){if(e.framework!=="openclaw"||!this.openclawConfigCache)return;let n=this.openclawConfigCache;for(let r of e.sessions.keys()){let i=dc(r),s=`${i}/${e.model}`,o=!0;try{await n.removeProvider(i)}catch(a){o=!1,K.warn("removeProvider failed, keeping ensuredProviders entry",{providerId:i,err:String(a)})}try{await n.removeModelFromAllowlist(s)}catch(a){o=!1,K.warn("removeModelFromAllowlist failed, keeping ensuredProviders entry",{fullModelId:s,err:String(a)})}o&&this.ensuredProviders.delete(s)}}};import{randomUUID as Zf}from"node:crypto";import{promises as bE}from"node:fs";import{basename as Kf}from"node:path";Te();L();import{promises as SE}from"node:fs";import{basename as vE}from"node:path";var Wf=b("file-upload"),IE="/api/coze_claw/file/agent_upload",TE=6e4;async function qf(t,e={}){let r=`${$s(Hs(e.handshakeBase))}${IE}`,i=e.timeoutMs??TE,s=await SE.readFile(t.path),o=new FormData;o.append("agent_id",t.agentId),o.append("session_id",t.sessionId),o.append("file_name",t.name),o.append("file_content",new Blob([s],{type:t.mimeType}),t.name);let a={Authorization:`Bearer ${t.patToken}`,Accept:"application/json","x-coze-version":"3.0",...Qn(e.ppeOverride),...t.accountId?{"x-coze-account":t.accountId}:{}},c=new AbortController,l=setTimeout(()=>c.abort(),i);Wf.info("file upload start",{url:r,agentId:t.agentId,sessionId:t.sessionId,name:t.name,bytes:t.sizeBytes,mime:t.mimeType});try{let d=await fetch(r,{method:"POST",headers:a,body:o,signal:c.signal}),p=d.headers.get("x-tt-logid")??"";if(!d.ok){let h=await d.text().catch(()=>"");throw new _("UPLOAD_FAILED",`upload HTTP ${d.status} logid=${p}: ${h.slice(0,200)}`)}let m=await d.json();if(m.code!==void 0&&m.code!==0)throw new _("UPLOAD_FAILED",`upload code=${m.code} msg=${m.msg??"-"} logid=${p}`);let u=m.data?.file?.file_url;if(!u)throw new _("UPLOAD_FAILED",`upload response missing data.file.file_url logid=${p}: ${JSON.stringify(m).slice(0,200)}`);return Wf.info("file upload ok",{uri:u,logid:p}),{uri:u}}catch(d){throw d instanceof _?d:d.name==="AbortError"?new _("UPLOAD_FAILED",`upload timeout (${i}ms) for ${vE(t.path)}`):new _("UPLOAD_FAILED",String(d),{cause:d})}finally{clearTimeout(l)}}Te();L();import{extname as RE}from"node:path";var kE={".png":"image/png",".jpg":"image/jpeg",".jpeg":"image/jpeg",".gif":"image/gif",".webp":"image/webp",".svg":"image/svg+xml",".bmp":"image/bmp",".ico":"image/x-icon",".heic":"image/heic",".heif":"image/heif",".pdf":"application/pdf",".doc":"application/msword",".docx":"application/vnd.openxmlformats-officedocument.wordprocessingml.document",".xls":"application/vnd.ms-excel",".xlsx":"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet",".ppt":"application/vnd.ms-powerpoint",".pptx":"application/vnd.openxmlformats-officedocument.presentationml.presentation",".txt":"text/plain",".md":"text/markdown",".markdown":"text/markdown",".json":"application/json",".yaml":"text/yaml",".yml":"text/yaml",".csv":"text/csv",".html":"text/html",".htm":"text/html",".xml":"application/xml",".log":"text/plain",".zip":"application/zip",".tar":"application/x-tar",".gz":"application/gzip",".tgz":"application/gzip",".mp3":"audio/mpeg",".wav":"audio/wav",".mp4":"video/mp4",".mov":"video/quicktime",".webm":"video/webm"};async function Vf(t){let e=RE(t).toLowerCase();return kE[e]??"application/octet-stream"}le();var to=b("agent-send"),Jf=50*1024*1024;function Xf(t,e,n){let r=t.get(e);if(!r)throw new _("AGENT_NOT_FOUND",`agent=${e}`);if(t.disconnectedAgents.has(e))throw new _("AGENT_DISCONNECTED",`agent=${e} was disconnected by cloud`);let i=r.sessions.get(n);if(!i)throw new _("AGENT_NOT_FOUND",`session=${n} not active in agent=${e}`);return{session:r,runtime:i}}async function Yf(t,e,n,r,i,s){let a;for(let c=0;c<=2;c++)try{await t.core.sendAgentFileUpdate(e,n,r,i);return}catch(l){a=l,c<2&&(to.warn("sendAgentFileUpdate failed, retrying",{attempt:c+1,err:String(l)}),await new Promise(d=>setTimeout(d,5e3)))}throw new _("UPSTREAM_NOT_READY",`${s} after 3 attempts: ${String(a)}`,{cause:a})}async function Qf(t,e){let{session:n,runtime:r}=Xf(e.core,t.agentId,t.sessionId);if(!await xr(t.path,n.workspace))throw new _("PATH_OUTSIDE_WORKSPACE",`path=${t.path} not under workspace=${n.workspace}`);let i=await bE.stat(t.path).catch(()=>null);if(!i||!i.isFile())throw new _("IPC_BAD_REQUEST",`path is not a regular file: ${t.path}`);if(i.size>Jf)throw new _("FILE_TOO_LARGE",`${i.size} bytes > limit ${Jf}`);let s=await Vf(t.path);if(t.kind==="image"&&!s.startsWith("image/"))throw new _("UNSUPPORTED_MIME",`kind=image but mime=${s}`);if(!e.core.upstream.isConnected())throw new _("UPSTREAM_NOT_READY","cloud WS not connected");let o=t.name??Kf(t.path),a;try{a=await qf({patToken:n.patToken??e.patToken,agentId:t.agentId,sessionId:t.sessionId,path:t.path,mimeType:s,name:o,sizeBytes:i.size,...n.accountId?{accountId:n.accountId}:{}},{handshakeBase:e.handshakeBase,ppeOverride:e.ppeOverride})}catch(l){throw to.warn("agent file upload failed",{agentId:t.agentId,sessionId:t.sessionId,path:t.path,sizeBytes:i.size,mime:s,code:l instanceof _?l.code:"UNKNOWN",message:l instanceof Error?l.message:String(l)}),l}let c={sessionUpdate:"agent_file",messageId:Zf(),content:{type:t.kind==="image"?"image":"resource",uri:a.uri,mimeType:s,name:o,sizeBytes:i.size,...a.fileId!==void 0?{fileId:a.fileId}:{},...t.caption!==void 0?{caption:t.caption}:{}}};return await Yf(e,n,r,t.sessionId,c,"agent file uploaded to cloud but sendAgentFileUpdate failed"),to.info("agent file sent",{agentId:t.agentId,sessionId:t.sessionId,kind:t.kind,name:o,bytes:i.size,mime:s,uri:a.uri}),{ok:!0,uri:a.uri,bytes:i.size,mimeType:s,...a.fileId!==void 0?{fileId:a.fileId}:{}}}async function eh(t,e){let{session:n,runtime:r}=Xf(e.core,t.agentId,t.sessionId);if(!t.mimeType)throw new _("IPC_BAD_REQUEST","group-file requires mimeType");if(!e.core.upstream.isConnected())throw new _("UPSTREAM_NOT_READY","cloud WS not connected");let i=t.name??Kf(t.path),s={sessionUpdate:"group_file",messageId:Zf(),content:{uri:t.path,name:i,mimeType:t.mimeType,...t.caption!==void 0?{caption:t.caption}:{}}};return await Yf(e,n,r,t.sessionId,s,"agent group file sendAgentFileUpdate failed"),to.info("agent group file sent",{agentId:t.agentId,sessionId:t.sessionId,uri:t.path,name:i,mime:t.mimeType}),{ok:!0,uri:t.path,bytes:0,mimeType:t.mimeType}}function th(t,e){let n=t.split(".").map(Number),r=e.split(".").map(Number),i=Math.max(n.length,r.length);for(let s=0;s<i;s++){let o=n[s]??0,a=r[s]??0;if(o<a)return!0;if(o>a)return!1}return!1}tn();gt();L();var lt=b("coze-cli-installer"),nh="@coze/cli@latest",AE="coze",rh="0.1.8",xE=5e3,OE=5e3,PE=9e4,ih=1e4,hi=null,no=!1;async function Ic(t,e={}){if(no)return;if(hi)return hi;let n=e.exec??Pn;return hi=(async()=>{try{let r=await CE(AE,n),i=!1;if(r){let o=await DE(n);if(o===void 0)lt.warn("coze-cli found but version unparseable, fall through to full install",{path:r});else if(th(o,rh))lt.info("coze-cli version too old, upgrade-only (preserve user config + auth)",{path:r,version:o,min:rh}),i=!0;else{lt.info("coze-cli already on PATH with sufficient version, skip",{path:r,version:o}),no=!0;return}}let s=i?"upgrade-only":"full";lt.info("coze-cli install start",{package:nh,mode:s});try{await n("npm",["i","-g","--prefer-online",nh],{timeout:PE,maxBuffer:10*1024*1024}),lt.info("coze-cli install ok")}catch(o){lt.warn("coze-cli install failed (skip subsequent steps)",{err:String(o)});return}if(i){no=!0;return}if(t.env)try{await n("coze",["config","set","xTTEnv",t.env],{timeout:ih}),lt.info("coze config set xTTEnv ok",{env:t.env})}catch(o){lt.warn("coze config set failed (continue to auth login)",{err:String(o)})}try{await n("coze",["auth","login","--token",t.patToken],{timeout:ih}),lt.info("coze auth login ok")}catch(o){lt.warn("coze auth login failed",{err:String(o)});return}no=!0}finally{hi=null}})(),hi}async function CE(t,e){let n=process.platform==="win32"?"where":"which";try{let{stdout:r}=await e(n,[t],{timeout:xE});return ji(r)}catch{return}}async function DE(t){try{let{stdout:e,stderr:n}=await t("coze",["--version"],{timeout:OE});return(e||n).match(/(\d+\.\d+\.\d+)/)?.[1]}catch{return}}qi();le();var NE=10*6e4;function sh(t){let e=t?.sessionIdleTimeoutMs;return typeof e!="number"||!Number.isFinite(e)||e<=0?NE:e}function ro(t){return Nn(t??F().configFile)}function or(t,e){return Wi(e??F().configFile,t)}import{randomBytes as eS}from"node:crypto";Fi();Te();L();import{createReadStream as LE}from"node:fs";import{mkdir as FE,readFile as ME,realpath as BE,stat as UE,writeFile as zE}from"node:fs/promises";import{basename as $E,dirname as Tc,isAbsolute as GE,join as HE,relative as jE,resolve as oh,sep as WE}from"node:path";import{createInterface as qE}from"node:readline";var ch=b("fs-rpc"),pi=pt("COZE_BRIDGE_FS_RPC_MAX_BYTES",20*1024*1024);async function lh(t,e){let n=Buffer.byteLength(t.content,"utf8");if(n>pi)throw new _("IPC_BAD_REQUEST",`fs/write_text_file content too large: ${n} bytes > limit ${pi} bytes`);let r=await uh(t.path,e);return await FE(Tc(r),{recursive:!0}),await zE(r,t.content,"utf8"),ch.info("fs/write_text_file ok",{path:r,size:t.content.length}),null}async function dh(t,e){let n=await uh(t.path,e),r=await UE(n),i=typeof t.line=="number"||typeof t.limit=="number";if(r.size>pi&&!i)throw new _("IPC_BAD_REQUEST",`fs/read_text_file too large without line/limit slicing: ${r.size} bytes > ${pi} bytes`);let s;if(i&&r.size>pi)s=await VE(n,t.line??1,t.limit);else{let o=await ME(n,"utf8");if(i){let a=o.split(`
97
97
  `),c=Math.max(0,(t.line??1)-1),l=typeof t.limit=="number"?c+t.limit:void 0;s=a.slice(c,l).join(`
98
98
  `)}else s=o}return ch.info("fs/read_text_file ok",{path:n,size:s.length}),{content:s}}async function VE(t,e,n){let r=qE({input:LE(t,{encoding:"utf8"}),crlfDelay:Number.POSITIVE_INFINITY}),i=Math.max(0,e-1),s=typeof n=="number"?i+n:Number.POSITIVE_INFINITY,o=[],a=0;try{for await(let c of r)if(a>=i&&a<s&&o.push(c),a++,a>=s)break}finally{r.close()}return o.join(`
99
- `)}async function uh(t,e){if(typeof t!="string"||t.length===0)throw new _("IPC_BAD_REQUEST","path must be a non-empty string");let[n,r]=await Promise.all([ah(oh(e)),ah(oh(t))]),i=jE(n,r);if(JE(i,WE,GE(i)))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${t}`);return r}function JE(t,e,n){return t===""?!1:n?!0:t===".."||t.startsWith(`..${e}`)}async function ah(t){let e=[],n=t;for(;n!==vc(n);)try{let r=await BE(n);return e.length?HE(r,...e.reverse()):r}catch{e.push($E(n)),n=vc(n)}return t}L();var fh=b("prompt-multimodal"),hh=10*1024*1024,ZE=15e3,KE=6;async function ph(t){let e=new Array(t.length),n=0;async function r(){for(;n<t.length;){let s=n++,o=t[s];o!==void 0&&(e[s]=await XE(o))}}let i=Array.from({length:Math.min(KE,t.length)},()=>r());return await Promise.all(i),e}function gh(t){return t.some(e=>e.type==="image")}async function XE(t){if(t.type!=="image")return t;let e=t;if(e.data||!e.uri||!Us(e.uri))return t;try{let{buf:n,contentType:r}=await QE(e.uri),i=e.mimeType||YE(r)||"application/octet-stream";return fh.info("image uri fetched and inlined",{uri:e.uri,bytes:n.length,mimeType:i}),{type:"image",data:n.toString("base64"),mimeType:i}}catch(n){return fh.warn("image fetch failed, degrading to text block",{uri:e.uri,err:String(n)}),{type:"text",text:`[image load failed: ${e.uri}]`}}}function YE(t){if(!t)return;let e=t.indexOf(";");return(e===-1?t:t.slice(0,e)).trim()||void 0}async function QE(t){let e=new AbortController,n=setTimeout(()=>e.abort(),ZE);try{let r=await fetch(t,{signal:e.signal});if(!r.ok)throw new Error(`HTTP ${r.status} ${r.statusText}`);let i=await r.arrayBuffer();if(i.byteLength>hh)throw new Error(`image too large: ${i.byteLength} bytes (max ${hh})`);return{buf:Buffer.from(i),contentType:r.headers.get("content-type")??void 0}}finally{clearTimeout(n)}}At();Te();L();var P=b("core"),tS=3e4,nS=/^(boe|ppe)_[A-Za-z0-9_-]+$/,rS="\u6211\u6B63\u5728\u7B49\u5F85\u5BA1\u6279\uFF0C\u8BF7\u7A0D\u540E\u518D\u8054\u7CFB\u6211",iS="\u5BA1\u6279\u5DF2\u8D85\u65F6",sS=3e4,ro=class{upstream;agents=new Map;disconnectedAgents=new Set;extensions;paths;sessionSpawner;sessionIdleTimeoutMs;upstreamIds=new ir;pendingUpstream=new Map;pendingBridge=new Map;currentCozeEnv;currentMockScenario;constructor(e){this.upstream=e.upstream,this.extensions=e.extensions??{},this.paths=e.paths,this.sessionSpawner=e.sessionSpawner,this.sessionIdleTimeoutMs=sh(e.bridgeConfig)}registerExtension(e,n){this.extensions[e]=n}getCozeEnv(){return this.currentCozeEnv}getMockScenario(){return this.currentMockScenario}setMockScenario(e){this.currentMockScenario=e&&e.length>0?e:void 0}async start(){this.upstream.onFrame(e=>this.handleFrame(e)),this.upstream.onConnect?.(({initial:e})=>{e||this.rejectAllPendingOnReconnect()}),await this.upstream.start(),P.info("Core started",{extensions:Object.keys(this.extensions)})}async stop(e){P.info("Core stopping",{reason:e}),await Promise.all([...this.agents.values()].map(n=>n.dispose(e))),this.agents.clear(),await this.upstream.stop(e)}get(e){return this.agents.get(e)}register(e){this.agents.set(e.agentId,e),P.info("agent registered",{agentId:e.agentId,framework:e.framework});for(let n of this.registerHandlers)try{n(e.agentId)}catch(r){P.warn("onAgentRegister handler threw (ignored)",{agentId:e.agentId,err:String(r)})}}onAgentRegister(e){return this.registerHandlers.add(e),()=>this.registerHandlers.delete(e)}registerHandlers=new Set;unregister(e){this.agents.delete(e)}reviveIfDisconnected(e){this.disconnectedAgents.delete(e)&&P.info("agent revived from disconnect",{agentId:e})}attachRuntimeHooks(e,n,r){let i=r.downstream;i&&(i.onUpdate(s=>{r.loadingSession||this.forwardUpdate(e,s)}),i.onAgentRequest(s=>{this.handleAgentRequest(e,i,s)}),i.onExit((s,o)=>{P.info("session runtime exited",{agentId:e.agentId,cloudId:n,code:s,signal:o}),di(r),r.downstream=void 0,r.replySeq=0,r.acpSessionId&&e.activeTriggers.delete(r.acpSessionId),this.rejectPendingForDownstream(i,"downstream exited")}))}hasPendingPermissionFor(e){for(let n of this.pendingUpstream.values())if(n.downstream===e)return!0;return!1}rejectPendingForDownstream(e,n){let r=[];for(let[i,s]of this.pendingUpstream)s.downstream===e&&r.push(i);if(r.length!==0){P.info("reject pendingUpstream entries (downstream gone)",{reason:n,count:r.length});for(let i of r){let s=this.pendingUpstream.get(i);if(s){this.pendingUpstream.delete(i),this.upstream.send(Ht(i,{code:U.INTERNAL_ERROR,message:`bridge downstream gone: ${n}`})).catch(o=>P.debug("send error response to upstream failed (ignored)",{err:String(o)}));try{s.downstream.respondAgentRequestError(s.agentRequestId,{code:U.INTERNAL_ERROR,message:`bridge: ${n}`})}catch{}}}}}rejectAllPendingOnReconnect(){let e=this.pendingUpstream.size,n=this.pendingBridge.size;if(!(e===0&&n===0)){P.warn("upstream reconnected, rejecting stale pending requests",{pendingUpstream:e,pendingBridge:n});for(let[,r]of this.pendingUpstream){try{r.downstream.respondAgentRequestError(r.agentRequestId,{code:U.INTERNAL_ERROR,message:"upstream reconnected; please retry"})}catch{}this.clearPendingPermissionFor(r)}this.pendingUpstream.clear();for(let[,r]of this.pendingBridge)clearTimeout(r.timer),r.reject(new _("UPSTREAM_DISCONNECTED",`${r.method} aborted: upstream reconnected`));this.pendingBridge.clear()}}async handleFrame(e){if(Ws(e)){this.handleUpstreamResponse(e);return}if(!("method"in e)||typeof e.method!="string")return;let n="id"in e&&e.id!==void 0?e.id:null,r=e.params?._meta?.cozeEnv;r&&nS.test(r)?this.currentCozeEnv=r:r&&P.warn("rejecting cozeEnv with invalid shape, keeping previous",{rejected:r});try{if(e.method.startsWith("_agent/")){let i=this.extensions[e.method];if(!i){n!==null?await this.sendError(n,U.METHOD_NOT_FOUND,`extension not registered: ${e.method}`):P.warn("drop notification: extension not registered",{method:e.method});return}let s=await i(e,this);n!==null&&await this.upstream.send(rr(n,s));return}if(e.method.startsWith("session/")){let i=await this.routeSessionMethod(e);n!==null&&await this.upstream.send(rr(n,i));return}if(e.method==="initialize"){n!==null&&await this.upstream.send(rr(n,{protocolVersion:1,agentCapabilities:{loadSession:!0}}));return}n!==null?await this.sendError(n,U.METHOD_NOT_FOUND,`method not implemented: ${e.method}`):P.warn("drop unknown notification",{method:e.method})}catch(i){P.error("handleFrame failed",{method:e.method,err:String(i)}),n!==null&&await this.upstream.send(Ht(n,li(i)))}}async routeSessionMethod(e){if(!e.params||typeof e.params!="object")throw new _("IPC_BAD_REQUEST",`${e.method} requires params`);let n=e.params,r=n._meta?.cozeAgentId;if(!r)throw new _("IPC_BAD_REQUEST",`${e.method}: missing _meta.cozeAgentId`);let i=this.agents.get(r);if(!i)throw this.disconnectedAgents.has(r)?new _("AGENT_DISCONNECTED",`agent ${r} has been disconnected; cloud must _agent/create to revive`):new _("AGENT_NOT_FOUND",`agent not found: ${r}`);let s=typeof n.sessionId=="string"?n.sessionId:void 0;if(e.method==="session/cancel"||e.method==="session/new"||!s)return this.dispatchSessionCall(i,e.method,n);if(e.method==="session/prompt"){let c=i.sessions.get(s);if(c?.pendingPermission){let l=n._meta?.cozeTriggerMsgId,d=rc(n._meta);return P.info("session in pendingPermission, bouncing new prompt",{agentId:i.agentId,cloudSessionId:s}),this.synthesizePromptReply(i,c,s,rS,l,d)}}let o=Date.now(),a=!1;try{let c=await i.getSessionQueue(s).enqueue(()=>this.dispatchSessionCall(i,e.method,n));return a=!0,c}finally{P.info("session call done",{agentId:i.agentId,method:e.method,durationMs:Date.now()-o,ok:a})}}async dispatchSessionCall(e,n,r){e.lastActiveAt=Date.now();let{stripped:i}=tf(r);switch(n){case"session/new":{let s=oS();return P.info("session/new ack (lazy spawn)",{agentId:e.agentId,cloudId:s}),{sessionId:s}}case"session/load":{let s=i;return P.info("session/load ack (lazy spawn)",{agentId:e.agentId,cloudId:s.sessionId}),{}}case"session/prompt":{let s=i,o=s.sessionId;if(!o)throw new _("IPC_BAD_REQUEST","session/prompt: missing sessionId");let a=await this.ensureRuntime(e,o);if(a.replySeq=0,await this.ensureDownstream(e,o,a),!a.downstream||!a.acpSessionId)throw new _("BRIDGE_INTERNAL","session runtime not ready after ensureDownstream");let c=r._meta?.cozeTriggerMsgId;c?e.activeTriggers.set(a.acpSessionId,c):e.activeTriggers.delete(a.acpSessionId);let l=rc(r._meta);if(l?e.activeGroupIds.set(a.acpSessionId,l):e.activeGroupIds.delete(a.acpSessionId),e.deployType==="cloud"&&e.modelInfo?.capabilities?.image===!1&&gh(s.prompt))throw new _("MODEL_MODALITY_UNSUPPORTED",`model=${e.modelInfo.id??e.model} does not support image input`);let d=await ph(s.prompt);try{let p=await a.downstream.sessionPrompt({...s,sessionId:a.acpSessionId,prompt:d});return a.lastActiveAt=Date.now(),p}catch(p){if(p instanceof _&&p.code==="AGENT_APPROVAL_TIMEOUT"){let m=a.pendingPermission;m&&(m.downstream.respondAgentRequest(m.agentRequestId,{outcome:{outcome:"cancelled"}}),this.pendingUpstream.delete(m.upstreamId),a.pendingPermission=void 0);let u=a.acpSessionId,h=u?e.activeTriggers.get(u):void 0,g=u?e.activeGroupIds.get(u):void 0;return P.warn("approval timed out, synthesizing \u5BA1\u6279\u5DF2\u8D85\u65F6 reply + recovering session",{agentId:e.agentId,cloudId:o}),await this.synthesizePromptReply(e,a,o,iS,h,g)}throw p}finally{if(e.activeTriggers.delete(a.acpSessionId),e.activeGroupIds.delete(a.acpSessionId),a.pendingPermission=void 0,a.reloadAfterTurn){a.reloadAfterTurn=!1;let p=a.downstream;p&&(a.downstream=void 0,P.info("reloadAfterTurn: stopping downstream",{agentId:e.agentId,cloudId:o,acpId:a.acpSessionId}),p.stop("reload-after-turn").catch(m=>P.warn("reload-after-turn stop failed (ignored)",{agentId:e.agentId,cloudId:o,err:String(m)})))}else a.downstream?.isAlive()&&this.armIdleTimer(e,o,a)}}case"session/cancel":{let o=i.sessionId;if(!o)throw new _("IPC_BAD_REQUEST","session/cancel: missing sessionId");let a=e.sessions.get(o);if(e.hasSessionQueue(o)){let c=e.getSessionQueue(o);c.size>0&&(P.info("session/cancel: draining queued tasks",{agentId:e.agentId,cloudId:o,queuedCount:c.size}),c.dispose(new _("AGENT_PROTOCOL_ERROR",`cancelled by session/cancel on ${o}`)))}return a?.downstream?.isAlive()&&a.acpSessionId&&await a.downstream.sessionCancel({sessionId:a.acpSessionId}),{ok:!0}}default:throw new _("IPC_BAD_REQUEST",`session method not supported: ${n}`)}}async ensureRuntime(e,n){let r=e.sessions.get(n);if(r)return r;let s={modelToken:e.deployType==="cloud"?await this.requestSessionToken(e.agentId,n):"",tokenGeneratedAt:Date.now(),lastActiveAt:Date.now(),loadingSession:!1,replySeq:0};return e.sessions.set(n,s),await this.persistSessionMapping(e),s}async requestSessionToken(e,n){let r={sessionId:n,_meta:{cozeAgentId:e}};try{let i=await this.sendRequest(Ze.GEN_MODEL_TOKEN,r,sS);if(!i?.modelToken)throw new _("MODEL_TOKEN_GEN_FAILED",`cloud returned empty modelToken (agentId=${e}, cloudSessionId=${n})`);return i.modelToken}catch(i){throw i instanceof _&&i.code==="MODEL_TOKEN_GEN_FAILED"?i:new _("MODEL_TOKEN_GEN_FAILED",i instanceof Error?i.message:String(i),{cause:i})}}async ensureDownstream(e,n,r){if(di(r),r.downstream?.isAlive())return;if(!this.sessionSpawner)throw new _("AGENT_SPAWN_FAILED","sessionSpawner not wired (cannot spawn per-session downstream)");let i=3,s=3e4,o=r.spawnFailCount??0,a=r.spawnFailedAt??0;if(o>=i&&Date.now()-a<s)throw new _("AGENT_SPAWN_FAILED",`agent ${e.agentId} session ${n} spawn failed ${o} times in a row; please check framework binary / network and retry after ${Math.ceil((s-(Date.now()-a))/1e3)}s`);let c;try{c=await this.sessionSpawner(e,r.modelToken,n,this.currentCozeEnv,this.currentMockScenario)}catch(l){throw r.spawnFailCount=o+1,r.spawnFailedAt=Date.now(),r.spawnFailCount>=i&&r.acpSessionId&&(P.warn("clearing stale acpSessionId after repeated spawn failures",{agentId:e.agentId,cloudId:n,staleAcpId:r.acpSessionId}),r.acpSessionId=void 0),l}if(r.spawnFailCount=0,r.spawnFailedAt=void 0,r.downstream=c,this.attachRuntimeHooks(e,n,r),r.acpSessionId){r.loadingSession=!0;try{await c.sessionLoad({sessionId:r.acpSessionId,cwd:e.workspace}),P.info("session restored via session/load",{agentId:e.agentId,cloudId:n,acpId:r.acpSessionId})}catch(l){P.warn("session/load failed, fallback to session/new",{agentId:e.agentId,cloudId:n,acpId:r.acpSessionId,err:String(l)}),r.acpSessionId=void 0;let d=await c.sessionNew({cwd:e.workspace});r.acpSessionId=d.sessionId,await this.persistSessionMapping(e)}finally{r.loadingSession=!1}}else{let l=await c.sessionNew({cwd:e.workspace});r.acpSessionId=l.sessionId,await this.persistSessionMapping(e)}c.afterSessionEstablished&&r.acpSessionId&&await c.afterSessionEstablished(r.acpSessionId)}armIdleTimer(e,n,r){if(di(r),this.isRuntimeBusy(e,r)){P.debug("skip idle timer: runtime busy (in-flight turn / pending permission)",{agentId:e.agentId,cloudId:n});return}r.idleTimer=setTimeout(()=>{if(r.idleTimer=void 0,this.isRuntimeBusy(e,r)){P.info("idle reaper fired but runtime busy, re-arming",{agentId:e.agentId,cloudId:n}),this.armIdleTimer(e,n,r);return}P.info("session runtime idle timeout, killing downstream",{agentId:e.agentId,cloudId:n});let i=r.downstream;r.downstream=void 0,r.acpSessionId&&e.activeTriggers.delete(r.acpSessionId),i&&i.stop("idle timeout").catch(s=>P.warn("idle stop failed (ignored)",{agentId:e.agentId,cloudId:n,err:String(s)}))},this.sessionIdleTimeoutMs),r.idleTimer.unref?.()}isRuntimeBusy(e,n){if(n.acpSessionId&&e.activeTriggers.has(n.acpSessionId))return!0;let r=n.downstream;if(!r)return!1;for(let i of this.pendingUpstream.values())if(i.downstream===r)return!0;return!1}async sendAgentFileUpdate(e,n,r,i){let s={cozeAgentId:e.agentId,cozeReplySeqID:++n.replySeq};if(n.acpSessionId){let o=e.activeTriggers.get(n.acpSessionId);o&&(s.cozeTriggerMsgId=o);let a=e.activeGroupIds.get(n.acpSessionId);a&&(s.cozeGroupId=a)}await this.upstream.send(nr("session/update",{sessionId:r,update:i,_meta:s}))}async synthesizePromptReply(e,n,r,i,s,o){let a={cozeAgentId:e.agentId,cozeReplySeqID:++n.replySeq};return s&&(a.cozeTriggerMsgId=s),o&&(a.cozeGroupId=o),await this.upstream.send(nr("session/update",{sessionId:r,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:i}},_meta:a})).catch(c=>P.warn("synthesizePromptReply update send failed (ignored)",{err:String(c)})),{stopReason:"end_turn"}}forwardUpdate(e,n){let r=n.sessionId,i=this.reverseSessionId(e,r);if(!i){P.debug("drop update for unknown session",{agentId:e.agentId,acpId:r});return}let s=e.sessions.get(i);if(!s){P.debug("drop update: runtime gone",{agentId:e.agentId,cloudId:i});return}if(cS(n)){P.debug("drop codex metadata-warn chunk",{agentId:e.agentId,acpId:r});return}let o={cozeAgentId:e.agentId,cozeReplySeqID:++s.replySeq},a=e.activeTriggers.get(r);a&&(o.cozeTriggerMsgId=a);let c=e.activeGroupIds.get(r);c&&(o.cozeGroupId=c),this.upstream.send(nr("session/update",{...n,sessionId:i,_meta:o})).catch(l=>P.warn("forward update failed",{agentId:e.agentId,err:String(l)}))}handleAgentRequest(e,n,r){if(r.method==="session/request_permission"){this.forwardPermissionRequest(e,n,r);return}if(r.method==="fs/write_text_file"||r.method==="fs/read_text_file"){this.handleFsRpcRequest(e,n,r);return}P.warn("unhandled agent request,returning method_not_found",{agentId:e.agentId,method:r.method}),n.respondAgentRequestError(r.id,{code:U.METHOD_NOT_FOUND,message:`method not handled by Bridge: ${r.method}`})}async handleFsRpcRequest(e,n,r){try{let i=e.workspace;if(r.method==="fs/write_text_file"){let s=r.params??{},o=await lh(s,i);n.respondAgentRequest(r.id,o)}else{let s=r.params??{},o=await dh(s,i);n.respondAgentRequest(r.id,o)}}catch(i){P.warn("fs rpc handler failed",{agentId:e.agentId,method:r.method,err:String(i)}),n.respondAgentRequestError(r.id,li(i))}}clearPendingPermissionFor(e){if(e.method!=="session/request_permission"||!e.cloudSessionId)return;let n=this.agents.get(e.agentId)?.sessions.get(e.cloudSessionId);n&&(n.pendingPermission=void 0)}forwardPermissionRequest(e,n,r){let i=this.upstreamIds.next("session/request_permission"),s=r.params??{},a=s.sessionId,c=a?e.activeTriggers.get(a):void 0,l={cozeAgentId:e.agentId};c&&(l.cozeTriggerMsgId=c);let d=a?e.activeGroupIds.get(a):void 0;d&&(l.cozeGroupId=d);let p=a?this.reverseSessionId(e,a):void 0,m=p?e.sessions.get(p):void 0;m&&(m.pendingPermission={downstream:n,agentRequestId:r.id,upstreamId:i});let u={...s,...p?{sessionId:p}:{},_meta:l};this.pendingUpstream.set(i,{agentRequestId:r.id,agentId:e.agentId,downstream:n,method:r.method,cloudSessionId:p}),P.info("forward permission_request \u2192 upstream",{agentId:e.agentId,upstreamId:i,acpSessionId:a,cloudSessionId:p,toolCallId:s.toolCall?.toolCallId,options:s.options?.map(h=>({optionId:h.optionId,kind:h.kind,name:h.name}))}),this.upstream.send(ai(i,"session/request_permission",u)).catch(h=>{this.pendingUpstream.delete(i),P.error("forward permission request failed",{agentId:e.agentId,err:String(h)}),n.respondAgentRequestError(r.id,{code:U.INTERNAL_ERROR,message:`upstream send failed: ${String(h)}`})})}handleUpstreamResponse(e){if(e.id===null)return;let n=this.lookupPending(this.pendingUpstream,e.id,"upstream");if(n){this.pendingUpstream.delete(n.key);let i=n.value;this.clearPendingPermissionFor(i),e.error?(P.info("upstream \u2192 permission response (error)",{agentId:i.agentId,upstreamId:e.id,method:i.method,error:e.error}),i.downstream.respondAgentRequestError(i.agentRequestId,e.error)):(i.method==="session/request_permission"&&aS(e.result,i),P.info("upstream \u2192 permission response (result)",{agentId:i.agentId,upstreamId:e.id,method:i.method,result:e.result}),i.downstream.respondAgentRequest(i.agentRequestId,e.result));return}let r=this.lookupPending(this.pendingBridge,e.id,"bridge");if(r){this.pendingBridge.delete(r.key),clearTimeout(r.value.timer),e.error?r.value.reject(new js(e.error)):r.value.resolve(e.result);return}P.debug("orphan upstream response (no pending)",{id:e.id})}lookupPending(e,n,r){let i=e.get(n);if(i)return{value:i,key:n};if(typeof n=="number"){let s=String(n),o=e.get(s);if(o)return P.warn(`${r} id type mismatch: number received but Bridge expected string`,{rawId:n,normalizedId:s}),{value:o,key:s}}}sendRequest(e,n,r=tS){let i=this.upstreamIds.next(e);return new Promise((s,o)=>{let a=setTimeout(()=>{this.pendingBridge.delete(i),o(new _("AGENT_TIMEOUT",`${e} timed out after ${r}ms`))},r);this.pendingBridge.set(i,{method:e,resolve:s,reject:o,timer:a}),this.upstream.send(ai(i,e,n)).catch(c=>{let l=this.pendingBridge.get(i);l&&(clearTimeout(l.timer),this.pendingBridge.delete(i)),o(c)})})}async persistSessionMapping(e){if(this.paths)try{let n=new Map;for(let[r,i]of e.sessions){let s={modelToken:i.modelToken,tokenGeneratedAt:i.tokenGeneratedAt};i.acpSessionId&&(s.acpSessionId=i.acpSessionId),n.set(r,s)}await xr(e.agentId,n,this.paths)}catch(n){P.warn("persist session mapping failed",{agentId:e.agentId,err:String(n)})}}reverseSessionId(e,n){for(let[r,i]of e.sessions.entries())if(i.acpSessionId===n)return r}sendError(e,n,r){return this.upstream.send(Ht(e,{code:n,message:r,data:{bridgeVersion:tr}}))}};function oS(){return eS(16).toString("hex")}function aS(t,e){if(!t||typeof t!="object"){P.warn("permission response: result not an object (suspicious)",{agentId:e.agentId,result:t});return}let n=t;if("kind"in n&&!("outcome"in n)){P.warn('permission response: top-level "kind" field (D66 historical bug shape)',{agentId:e.agentId,result:t});return}let r=n.outcome;if(!r||typeof r!="object"){P.warn("permission response: missing or non-object outcome field",{agentId:e.agentId,result:t});return}let s=r.outcome;(typeof s!="string"||s!=="selected"&&s!=="cancelled")&&P.warn("permission response: unknown outcome discriminant",{agentId:e.agentId,outcomeValue:s,result:t})}function cS(t){let e=t.update;if(e?.sessionUpdate!=="agent_message_chunk")return!1;let n=e.content;if(!n||typeof n!="object")return!1;let r=n;return r.type!=="text"||typeof r.text!="string"?!1:r.text.startsWith("Model metadata for `")}L();le();import{randomBytes as lS}from"node:crypto";import{chmod as dS,mkdir as uS,writeFile as mh}from"node:fs/promises";import{createServer as fS}from"node:http";import{dirname as hS}from"node:path";var pS=1e6,Ic=b("ipc"),io=class{server=null;port=0;token="";routes;paths;constructor(e){this.routes=new Map(e.routes.map(n=>[`${n.method} ${n.path}`,n])),this.paths=e.paths??F()}async start(){this.token=lS(32).toString("hex");let e=fS((r,i)=>{this.dispatch(r,i)});this.server=e,await new Promise((r,i)=>{e.once("error",i),e.listen(0,"127.0.0.1",()=>r())});let n=e.address();if(!n||typeof n!="object")throw new Error("failed to obtain IPC port");return this.port=n.port,await this.persistAuthFiles(),Ic.info("IPC listening",{port:this.port}),{port:this.port,token:this.token}}async stop(){let e=this.server;e&&(await new Promise((n,r)=>{e.close(i=>i?r(i):n())}),this.server=null)}async persistAuthFiles(){await uS(hS(this.paths.portFile),{recursive:!0}),await mh(this.paths.portFile,String(this.port),"utf8"),await mh(this.paths.tokenFile,this.token,{encoding:"utf8",mode:384});try{await dS(this.paths.tokenFile,384)}catch(e){Ic.warn("chmod token file failed (non-POSIX?)",{err:String(e)})}}async dispatch(e,n){if(e.headers.authorization!==`Bearer ${this.token}`){pi(n,401,{error:"unauthorized"});return}let i=`${e.method} ${(e.url??"").split("?")[0]}`,s=this.routes.get(i);if(!s){pi(n,404,{error:"not found"});return}let o=null;if(e.method==="POST")try{o=await gS(e)}catch(a){pi(n,400,{error:"invalid json",detail:String(a)});return}try{let a=await s.handler(o,e);pi(n,200,a??{ok:!0})}catch(a){Ic.error("IPC handler failed",{key:i,err:String(a)}),pi(n,500,{error:a instanceof Error?a.message:String(a)})}}};function pi(t,e,n){t.statusCode=e,t.setHeader("content-type","application/json"),t.end(JSON.stringify(n))}async function gS(t){let e=[],n=0;for await(let i of t){let s=i;if(n+=s.length,n>pS)throw new Error("body too large");e.push(s)}let r=Buffer.concat(e).toString("utf8");return r?JSON.parse(r):null}var Rh="";function bS(t=""){let n=`${Date.now()}`,r=Rh||(Rh=PS(t)),i=Math.random().toString(16).slice(-6);return"02"+n+r+i}function AS(){return 1e4*Date.now()+Math.floor(1e4*Math.random())}function xS(t){return(Array(8).join("0")+parseInt(t,10).toString(2)).slice(-8)}function kh(t){return(Array(4).join("0")+parseInt(t,2).toString(16)).slice(-4)}function OS(t){let e=t.split(/\./).map(i=>xS(i)),n=[];return n[0]=kh(e[0]+e[1]),n[1]=kh(e[2]+e[3]),["0000","0000","0000","0000","0000","ffff",n[0],n[1]].join("")}function PS(t){let e=/(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}/.test(t),n=/(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))/.test(t);return e?OS(t):n?CS(t):"00000000000000000000000000000000"}function CS(t){let e="",n=[],r=0,i=0,s=!0,o="0000";if(t.indexOf("::")>-1){let a=t.split("::");for(let l=0;l<a.length;l++){let d=a[l];if(d.indexOf(":")>0){let p=d.split(":");s&&(r=p.length),i+=p.length;for(let m=0;m<p.length;m++)if(p[m].length!==4){let h=o.substring(0,4-p[m].length).concat(p[m]);n.push(h)}else n.push(p[m]);s=!1}else{if(d.length!==4){let m=o.substring(0,4-d.length).concat(d);n.push(m)}else n.push(d);s&&(r+=1),i+=1,s=!1}}let c="";for(let l=0;l<8-i;l++)c=c.concat(o);for(let l=0;l<n.length;l++)l===r&&(e=e.concat(c)),e=e.concat(n[l]);return e}{let a=t.split(":");for(let c=0;c<a.length;c++){let l=a[c];if(a[c].length!==4){let p=o.substring(0,4-a[c].length).concat(l);e=e.concat(p)}else e=e.concat(l)}return e}}function DS(t,e){let n=t.key;n!==void 0&&(ye(e,10),En(e,n));let r=t.value;r!==void 0&&(ye(e,18),En(e,r))}function NS(t){let e={};e:for(;!zh(t);){let n=ke(t);switch(n>>>3){case 0:break e;case 1:e.key=_n(t,ke(t));break;case 2:e.value=_n(t,ke(t));break;default:Mh(t,7&n)}}if(e.key===void 0)throw new Error("Missing required field: key");if(e.value===void 0)throw new Error("Missing required field: value");return e}function Fh(t){let e=Uh();return LS(t,e),$S(e)}function LS(t,e){let n=t.SeqID;n!==void 0&&(ye(e,8),mi(e,n));let r=t.LogID;r!==void 0&&(ye(e,16),mi(e,r));let i=t.service;i!==void 0&&(ye(e,24),mi(e,Oc(i)));let s=t.method;s!==void 0&&(ye(e,32),mi(e,Oc(s)));let o=t.headers;if(o!==void 0)for(let h of o){ye(e,42);let g=Uh();DS(h,g),ye(e,g.limit),jS(e,g),US(g)}let a=t.payloadEncoding;a!==void 0&&(ye(e,50),En(e,a));let c=t.payloadType;c!==void 0&&(ye(e,58),En(e,c));let l=t.payload;l!==void 0&&(ye(e,66),ye(e,l.length),HS(e,l));let d=t.LogIDNew;d!==void 0&&(ye(e,74),En(e,d));let p=t.serverTiming;p!==void 0&&(ye(e,82),En(e,p));let m=t.msgID;m!==void 0&&(ye(e,90),En(e,m));let u=t.frameType;u!==void 0&&(ye(e,96),mi(e,Oc(u)))}function FS(t){return MS(zS(t))}function MS(t){let e={};e:for(;!zh(t);){let n=ke(t);switch(n>>>3){case 0:break e;case 1:e.SeqID=Ah(t,!0);break;case 2:e.LogID=Ah(t,!0);break;case 3:e.service=ke(t);break;case 4:e.method=ke(t);break;case 5:{let r=BS(t);(e.headers||(e.headers=[])).push(NS(t)),t.limit=r;break}case 6:e.payloadEncoding=_n(t,ke(t));break;case 7:e.payloadType=_n(t,ke(t));break;case 8:e.payload=GS(t,ke(t));break;case 9:e.LogIDNew=_n(t,ke(t));break;case 10:e.serverTiming=_n(t,ke(t));break;case 11:e.msgID=_n(t,ke(t));break;case 12:e.frameType=ke(t);break;default:Mh(t,7&n)}}if(e.SeqID===void 0)throw new Error("Missing required field: SeqID");if(e.LogID===void 0)throw new Error("Missing required field: LogID");if(e.service===void 0)throw new Error("Missing required field: service");if(e.method===void 0)throw new Error("Missing required field: method");return e}function BS(t){let e=ke(t),n=t.limit;return t.limit=t.offset+e,n}function Mh(t,e){switch(e){case 0:for(;128&ze(t););break;case 2:Pc(t,ke(t));break;case 5:Pc(t,4);break;case 1:Pc(t,8);break;default:throw new Error("Unimplemented type: "+e)}}function Oc(t){return t|=0,{low:t,high:t>>31,unsigned:t>=0}}var Bh=[];function Uh(){let t=Bh.pop();return t?(t.offset=t.limit=0,t):{bytes:new Uint8Array(64),offset:0,limit:0}}function US(t){Bh.push(t)}function zS(t){return{bytes:t,offset:0,limit:t.length}}function $S(t){let e=t.bytes,n=t.limit;return e.length===n?e:e.subarray(0,n)}function Pc(t,e){if(t.offset+e>t.limit)throw new Error("Skip past limit");t.offset+=e}function zh(t){return t.offset>=t.limit}function _i(t,e){let n=t.bytes,r=t.offset,i=t.limit,s=r+e;if(s>n.length){let o=new Uint8Array(2*s);o.set(n),t.bytes=o}return t.offset=s,s>i&&(t.limit=s),r}function Zc(t,e){let n=t.offset;if(n+e>t.limit)throw new Error("Read past limit");return t.offset+=e,n}function GS(t,e){let n=Zc(t,e);return t.bytes.subarray(n,n+e)}function HS(t,e){let n=_i(t,e.length);t.bytes.set(e,n)}function _n(t,e){let n=Zc(t,e),r=String.fromCharCode,i=t.bytes,s="\uFFFD",o="";for(let a=0;a<e;a++){let c=i[a+n],l,d,p,m;(128&c)===0?o+=r(c):(224&c)===192?a+1>=e?o+=s:(l=i[a+n+1],(192&l)!==128?o+=s:(m=(31&c)<<6|63&l,m<128?o+=s:(o+=r(m),a++))):(240&c)==224?a+2>=e?o+=s:(l=i[a+n+1],d=i[a+n+2],((l|d<<8)&49344)!==32896?o+=s:(m=(15&c)<<12|(63&l)<<6|63&d,m<2048||m>=55296&&m<=57343?o+=s:(o+=r(m),a+=2))):(248&c)==240?a+3>=e?o+=s:(l=i[a+n+1],d=i[a+n+2],p=i[a+n+3],((l|d<<8|p<<16)&12632256)!==8421504?o+=s:(m=(7&c)<<18|(63&l)<<12|(63&d)<<6|63&p,m<65536||m>1114111?o+=s:(m-=65536,o+=r((m>>10)+55296,(1023&m)+56320),a+=3))):o+=s}return o}function En(t,e){let n=e.length,r=0;for(let o=0;o<n;o++){let a=e.charCodeAt(o);a>=55296&&a<=56319&&o+1<n&&(a=(a<<10)+e.charCodeAt(++o)-56613888),r+=a<128?1:a<2048?2:a<65536?3:4}ye(t,r);let i=_i(t,r),s=t.bytes;for(let o=0;o<n;o++){let a=e.charCodeAt(o);a>=55296&&a<=56319&&o+1<n&&(a=(a<<10)+e.charCodeAt(++o)-56613888),a<128?s[i++]=a:(a<2048?s[i++]=a>>6&31|192:(a<65536?s[i++]=a>>12&15|224:(s[i++]=a>>18&7|240,s[i++]=a>>12&63|128),s[i++]=a>>6&63|128),s[i++]=63&a|128)}}function jS(t,e){let n=_i(t,e.limit),r=t.bytes,i=e.bytes;for(let s=0,o=e.limit;s<o;s++)r[s+n]=i[s]}function ze(t){return t.bytes[Zc(t,1)]}function bh(t,e){let n=_i(t,1);t.bytes[n]=e}function ke(t){let e=0,n=0,r;do r=ze(t),e<32&&(n|=(127&r)<<e),e+=7;while(128&r);return n}function ye(t,e){for(e>>>=0;e>=128;)bh(t,127&e|128),e>>>=7;bh(t,e)}function Ah(t,e){let n=0,r=0,i=0,s;return s=ze(t),n=127&s,128&s&&(s=ze(t),n|=(127&s)<<7,128&s&&(s=ze(t),n|=(127&s)<<14,128&s&&(s=ze(t),n|=(127&s)<<21,128&s&&(s=ze(t),r=127&s,128&s&&(s=ze(t),r|=(127&s)<<7,128&s&&(s=ze(t),r|=(127&s)<<14,128&s&&(s=ze(t),r|=(127&s)<<21,128&s&&(s=ze(t),i=127&s,128&s&&(s=ze(t),i|=(127&s)<<7))))))))),{low:n|r<<28,high:r>>>4|i<<24,unsigned:e}}function mi(t,e){let n=e.low>>>0,r=(e.low>>>28|e.high<<4)>>>0,i=e.high>>>24,s=i===0?r===0?n<16384?n<128?1:2:n<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:i<128?9:10,o=_i(t,s),a=t.bytes;switch(s){case 10:a[o+9]=i>>>7&1;case 9:a[o+8]=s!==9?128|i:127&i;case 8:a[o+7]=s!==8?r>>>21|128:r>>>21&127;case 7:a[o+6]=s!==7?r>>>14|128:r>>>14&127;case 6:a[o+5]=s!==6?r>>>7|128:r>>>7&127;case 5:a[o+4]=s!==5?128|r:127&r;case 4:a[o+3]=s!==4?n>>>21|128:n>>>21&127;case 3:a[o+2]=s!==3?n>>>14|128:n>>>14&127;case 2:a[o+1]=s!==2?n>>>7|128:n>>>7&127;case 1:a[o]=s!==1?128|n:127&n}}function WS(t){return FS(t)}function xh(t){return Fh(t)}var Oh=65536,qS="\0\0\0\0\0\0\0\0",ar=Oh*Oh,$h=ar*ar,Ph=$h/2,Vt=String.prototype.charCodeAt,Ne=class t{constructor(e,n,r){this.isLong=!0,this.low=0|e,this.high=0|n,this.unsigned=!!r}static isLong(e){return e&&e.isLong===!0}static fromBits(e,n,r){return new t(e,n,r)}static fromBytes(e,n,r){return r?t.fromBytesLE(e,n):t.fromBytesBE(e,n)}static fromBytesLE(e,n){return new t(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,n)}static fromBytesBE(e,n){return new t(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],n)}static fromHash(e){return e===qS?Ch:new t((Vt.call(e,0)|Vt.call(e,1)<<8|Vt.call(e,2)<<16|Vt.call(e,3)<<24)>>>0,(Vt.call(e,4)|Vt.call(e,5)<<8|Vt.call(e,6)<<16|Vt.call(e,7)<<24)>>>0,!0)}toHash(){return String.fromCharCode(255&this.low,this.low>>>8&255,this.low>>>16&255,this.low>>>24,255&this.high,this.high>>>8&255,this.high>>>16&255,this.high>>>24)}static fromNumber(e,n=!0){if(isNaN(e))return n?VS:Ch;if(n){if(e>=$h)return ZS}else{if(e<=-Ph)return KS;if(e+1>=Ph)return JS}return t.fromBits(e%ar|0,e/ar|0,n)}toNumber(){return this.unsigned?(this.high>>>0)*ar+(this.low>>>0):this.high*ar+(this.low>>>0)}isZero(){return this.high===0&&this.low===0}add(e){t.isLong(e)||(e=t.fromNumber(e));let n=this.high>>>16,r=65535&this.high,i=this.low>>>16,s=65535&this.low,o=e.high>>>16,a=65535&e.high,c=e.low>>>16,l=65535&e.low,d=0,p=0,m=0,u=0;return u+=s+l,m+=u>>>16,u&=65535,m+=i+c,p+=m>>>16,m&=65535,p+=r+a,d+=p>>>16,p&=65535,d+=n+o,d&=65535,t.fromBits(m<<16|u,d<<16|p,this.unsigned)}equals(e){return t.isLong(e)||(e=t.fromNumber(e)),this.unsigned!==e.unsigned&&this.high>>>31===1&&e.high>>>31===1?!1:this.high===e.high&&this.low===e.low}addOne(){return this.low===-1&&this.high===-1?t.fromBits(0,0,this.unsigned):this.low===-1?t.fromBits(0,this.high+1,this.unsigned):t.fromBits(this.low+1,this.high,this.unsigned)}toBytes(e){return e?this.toBytesLE():this.toBytesBE()}toBytesLE(){let e=this.high,n=this.low;return[255&n,n>>>8&255,n>>>16&255,n>>>24,255&e,e>>>8&255,e>>>16&255,e>>>24]}toBytesBE(){let e=this.high,n=this.low;return[e>>>24,e>>>16&255,e>>>8&255,255&e,n>>>24,n>>>16&255,n>>>8&255,255&n]}},Ch=new Ne(0,0,!1),VS=new Ne(0,0,!0),JS=Ne.fromBits(-1,2147483647,!1),ZS=Ne.fromBits(-1,-1,!0),KS=Ne.fromBits(0,-2147483648,!1),yn=(function(t){return t[t.NATIVE_ERROR=5001]="NATIVE_ERROR",t[t.CONNECTING_ERROR=5002]="CONNECTING_ERROR",t[t.MAX_RETRIES_ERROR=5003]="MAX_RETRIES_ERROR",t[t.MESSAGE_ERROR=5004]="MESSAGE_ERROR",t[t.OPEN_ERROR=5005]="OPEN_ERROR",t})({}),Sn=class{constructor(e){this.type=e,this.target=null}},Dc=class extends Sn{constructor(e,n){super(e),this.message=n&&n.message||null}},Nc=class extends Sn{constructor(e,n){super(e),this.error=n&&n.error||null,this.colno=n&&n.colno||0,this.filename=n&&n.filename||"",this.lineno=n&&n.lineno||0,this.message=n&&n.message||"",this.code=n&&n.code||5001}},Lc=class extends Sn{constructor(e,n){super(e),this.code=n&&n.code||0,this.reason=n&&n.reason||"",this.wasClean=n&&n.wasClean||!1,this.willReconnect=n&&n.willReconnect||!1}},Fc=class extends Sn{constructor(e,n){super(e),this.data=n&&n.data||null}},Mc=class extends Fc{constructor(e,n){super(e),this.data=n&&n.data||null,this.message=n&&n.message||null}},Bc=class extends Sn{constructor(e,n){super(e),this.data=n&&n.data||null}};function Xe(t,{message:e,code:n,error:r}){return new Nc(t,{message:e,code:n,error:r})}function dt(t,{code:e,reason:n,wasClean:r,willReconnect:i}){return new Lc(t,{code:e,reason:n,wasClean:r,willReconnect:i})}function XS(t,{data:e,message:n}){return new Mc(t,{data:e,message:n})}function YS(t,{data:e}){return new Bc(t,{data:e})}function Dh(t,{message:e}){return new Dc(t,{message:e})}var so=class{constructor(e,n){this.endpoints=e,this.maxRetries=n,this.currentIndex=0,this.currentEndpointTriesCount=0}resetEndpointConfig(){this.currentIndex=0,this.currentEndpointTriesCount=0}resetTries(){this.currentEndpointTriesCount=0}getCurrentEndpoint(){return this.endpoints[this.currentIndex]}getCurrentEndpointTriesCount(){return this.currentEndpointTriesCount}checkReachMaxTries(){return this.currentIndex>=this.endpoints.length||this.currentIndex===this.endpoints.length-1&&this.currentEndpointTriesCount===this.maxRetries}checkCurrentEndpointReachedMaxRetries(){return this.currentIndex==this.endpoints.length?!0:this.currentEndpointTriesCount>this.maxRetries}replaceBackupEndpointAndUpdateCount(){return this.currentEndpointTriesCount=1,this.currentIndex++,this.endpoints[this.currentIndex]}getCurrentEndpointAndUpdateCount(){return this.currentEndpointTriesCount++,this.getCurrentEndpoint()}},lr=(typeof globalThis<"u"&&globalThis.constructor.name==="Window"||typeof window<"u"&&window.constructor.name==="Window")&&typeof document<"u",vn=typeof globalThis<"u"&&(globalThis.constructor.name==="Object"||globalThis.constructor.name==="DedicatedWorkerGlobalScope")&&typeof tt<"u",Ei=(typeof globalThis<"u"&&globalThis.constructor.name==="Object"||typeof globalThis>"u"||typeof globalThis<"u"&&!!globalThis.WeixinJSBridge)&&typeof wx<"u",wi=typeof globalThis<"u"&&(globalThis.constructor.name==="DedicatedWorkerGlobalScope"||globalThis.constructor.name==="SharedWorkerGlobalScope"||globalThis.constructor.name==="ServiceWorkerGlobalScope")&&typeof self<"u",QS=typeof globalThis<"u"&&globalThis.constructor.name==="Object"&&typeof global<"u"&&global.constructor.name==="Object"&&typeof process<"u"&&!!process.version,yi=class{constructor(){this._listeners={}}emit(e,...n){let r=this._listeners[e];if(r)r.slice().forEach(i=>i.fn.apply(i.ctx,n));else if(e==="error"&&!this.onerror){let i=n.length&&n[0];if(i instanceof Error)throw i;let s=new Error("Unhandled error."+(i?" ("+i.message+")":""));throw s.context=i,i}return this}off(e,n){if(e===void 0)this._listeners={};else if(n===void 0)this._listeners[e]=null;else{let r=this._listeners[e];if(r)for(let i=0;i<r.length;)r[i].fn===n?r.splice(i,1):++i}return this}on(e,n,r){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:n,ctx:r||this}),this}},Uc=class extends yi{_formatErrorMessage(e){return e.errMsg||e.errNo?`message: ${e.errMsg||""} code: ${e.errNo||""}`.trim():JSON.stringify(e)}constructor(e,n,r){super(),this._socket=null,Ei&&wx.connectSocket&&(this._socket=wx.connectSocket({url:e,protocols:n,header:r,fail:this._createSocketFailHandler.bind(this),success:this._createSocketSuccessHandler.bind(this)})),vn&&tt.connectSocket&&(this._socket=tt.connectSocket({url:e,protocols:n,header:r,fail:this._createSocketFailHandler.bind(this),success:this._createSocketSuccessHandler.bind(this)}))}_createSocketSuccessHandler(){Promise.resolve().then(()=>{this._addWsListeners()})}_createSocketFailHandler(e){Promise.resolve().then(()=>{let n=Xe("error",{message:this._formatErrorMessage(e)});this.emit("error",n);let r=dt("close",{reason:this._formatErrorMessage(e)});this.emit("close",r)})}_addWsListeners(){this._socket.onOpen(e=>{this.emit("open",YS("open",{...e,data:e.errMsg||""}))}),this._socket.onClose(e=>{this.emit("close",dt("close",{...e}))}),this._socket.onMessage(e=>{this.emit("message",XS("message",{...e}))}),this._socket.onError(e=>{this.emit("error",Xe("error",{...e,message:e.errMsg||""}))})}send(e){if(e instanceof Uint8Array){let n=e.buffer.slice(e.byteOffset,e.byteLength+e.byteOffset);this._socket&&this._socket.send({data:n,fail:r=>{this.emit("error",Xe("error",{message:this._formatErrorMessage(r)}))}})}else this._socket&&this._socket.send({data:e,fail:n=>{this.emit("error",Xe("error",{message:this._formatErrorMessage(n)}))}})}close(e,n){this._socket&&this._socket.close({code:e,reason:n})}addEventListener(e,n){this.on(e,n)}removeEventListener(e,n){this.off(e,n)}get readyState(){return this._socket.readyState}get binaryType(){return this._socket.binaryType}set binaryType(e){}get url(){return this._socket.url}get protocol(){return this._socket.protocol}get extensions(){return this._socket.extensions}get bufferedAmount(){return 0}};function e0(t,e){if(e)return new e(t.url,t.protocol);if(Ei||vn)return new Uc(t.url,t.protocol,t.headers);if((lr||wi)&&typeof WebSocket<"u"&&WebSocket)return new WebSocket(t.url,t.protocols)}function t0(t){return!!(t||Ei&&wx.connectSocket||vn&&tt.connectSocket||(lr||wi)&&typeof WebSocket<"u"&&WebSocket)}function Nh(t,e,n){let r=-1;async function i(s){return s<=r?Promise.reject(new Error("next() called multiple times in process")):(r=s,s===n.length?Promise.resolve():n[s].bind(t)(e,i.bind(null,s+1)))}i(0)}function Gh(t){let e=0,n=0;for(let r=0;r<t.length;++r)n=t.charCodeAt(r),n<128?e+=1:n<2048?e+=2:(64512&n)===55296&&(64512&t.charCodeAt(r+1))===56320?(++r,e+=4):e+=3;return e}function Hh(t,e,n){if(n-e<1)return"";let r="";for(let i=e;i<n;){let s=t[i++];if(s<=127)r+=String.fromCharCode(s);else if(s>=192&&s<224)r+=String.fromCharCode((31&s)<<6|63&t[i++]);else if(s>=224&&s<240)r+=String.fromCharCode((15&s)<<12|(63&t[i++])<<6|63&t[i++]);else if(s>=240){let o=((7&s)<<18|(63&t[i++])<<12|(63&t[i++])<<6|63&t[i++])-65536;r+=String.fromCharCode(55296+(o>>10)),r+=String.fromCharCode(56320+(1023&o))}}return r}function zc(t,e,n){let r=n,i,s;for(let o=0;o<t.length;++o)i=t.charCodeAt(o),i<128?e[n++]=i:i<2048?(e[n++]=i>>6|192,e[n++]=63&i|128):(64512&i)===55296&&(64512&(s=t.charCodeAt(o+1)))===56320?(i=65536+((1023&i)<<10)+(1023&s),++o,e[n++]=i>>18|240,e[n++]=i>>12&63|128,e[n++]=i>>6&63|128,e[n++]=63&i|128):(e[n++]=i>>12|224,e[n++]=i>>6&63|128,e[n++]=63&i|128);return n-r}async function jh(t){if(typeof t=="string"){let e=new Uint8Array(Gh(t));return zc(t,e,0),e}return t instanceof ArrayBuffer?new Uint8Array(t):new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}function n0(t){try{return typeof t!="string"&&(t instanceof ArrayBuffer||t.buffer&&t.buffer instanceof ArrayBuffer)||typeof t!="string"?"":(JSON.parse(t),"application/json")}catch{return typeof t=="string"?"text/plain;charset=utf-8":""}}var r0=(t,e)=>{switch(t){case"boe":case"ppe":return{[`x-use-${t}`]:1,"x-tt-env":e};default:return{}}},$c=class{constructor(e){this.maxLossCount=e,this.count=0}addCount(){this.count++}checkReachMaxCount(){return this.count>=this.maxLossCount}resetCounter(e=0){this.maxLossCount=e,this.count=0}};async function i0(t){return new Promise(e=>{if(!lr)return e("unknown reason");try{let n=document.createElement("script");window.frontierJSONP=r=>{document.body.removeChild(n),window.frontierJSONP=void 0,e(r&&r.msg||"unknown reason")},n.type="text/javascript",n.src=t.replace(/^ws/,"http")+"&jscallback=frontierJSONP";try{document.body.appendChild(n)}catch{document.body.removeChild(n)}}catch{window.frontierJSONP=void 0,e("unknown reason")}})}function Jt(t,e,n){return!!t?.find(r=>r.key===e&&r.value===n)}function cr(t,e){return t?.find(n=>n.key===e)?.value}var Cc=null;async function s0(){return Cc||(Cc=Promise.resolve().then(()=>(Th(),Ih))),Cc}var Gc=class extends yi{constructor(e,n){super(),this._dbName=e,this._keyPath=n,this._qosDB=void 0,this._initPromise=null}async openDB(){await this._init()}async _init(){if(!this._qosDB){if(this._initPromise)return this._initPromise;try{let e=this._dbName,n=this._keyPath;this._initPromise=(async()=>{let{openDB:r}=await s0();this._qosDB=await r(`frontier_${e}`,1,{upgrade(i){i.createObjectStore(e,{keyPath:n})}})})(),await this._initPromise}catch(e){console.log(e)}finally{this._initPromise=null}}}async get(e){try{return await this._init(),this._qosDB?.get(this._dbName,e)}catch(n){console.log(n)}}async set(e,n){return await this._init(),this._qosDB?.put(this._dbName,e)}async del(e){try{return await this._init(),this._qosDB?.delete(this._dbName,e)}catch(n){console.log(n)}}async clear(){try{return await this._init(),this._qosDB?.clear(this._dbName)}catch(e){console.log(e)}}async keys(){return await this._init(),this._qosDB?.getAllKeys(this._dbName)}async getAll(){return await this._init(),this._qosDB?.getAll(this._dbName)}async closeDB(){try{this._qosDB?.close(),this._qosDB=void 0}catch(e){console.log(e)}}get isReady(){try{return!!this._qosDB}catch(e){return console.log(e),!1}}},Hc=class{constructor(e,n){this._DBName=e,this._pathKey=n,this._qosDB=localStorage}async openDB(){}get _prefix(){return`frontier_${this._DBName}`}async get(e){let n=this._qosDB.getItem(this._prefix);return JSON.parse(n||"{}")[e]}async set(e,n){let r=this._qosDB.getItem(this._prefix),i=JSON.parse(r||"{}");return i[n||e[this._pathKey]]=e,this._qosDB.setItem(this._prefix,JSON.stringify(i)),n||e[this._pathKey]}async del(e){let n=this._qosDB.getItem(this._prefix),r=JSON.parse(n||"{}");return r[e]=void 0,this._qosDB.setItem(this._prefix,JSON.stringify(r))}async clear(){return this._qosDB.clear()}async keys(){let e=this._qosDB.getItem(this._prefix),n=JSON.parse(e||"{}");return Object.keys(n)}async getAll(){let e=this._qosDB.getItem(this._prefix),n=JSON.parse(e||"{}");return Object.values(n)}closeDB(){return Promise.resolve()}get isReady(){return!!this._qosDB}},jc=class{constructor(e,n){this._DBName=e,this._pathKey=n,this._qosDB=vn?tt:Ei?wx:null}async openDB(){}get _prefix(){return`frontier_${this._DBName}`}async get(e){let n=this._qosDB.getStorageSync(this._prefix);return JSON.parse(n||"{}")[e]}async set(e,n){let r=this._qosDB.getStorageSync(this._prefix),i=JSON.parse(r||"{}");return i[n||e[this._pathKey]]=e,this._qosDB.setStorageSync(this._prefix,JSON.stringify(i)),n||e[this._pathKey]}async del(e){let n=this._qosDB.getStorageSync(this._prefix),r=JSON.parse(n||"{}");return r[e]=void 0,this._qosDB.setStorageSync(this._prefix,JSON.stringify(r))}async clear(){return this._qosDB.clearStorageSync()}async keys(){let e=this._qosDB.getStorageInfoSync(this._prefix),n=JSON.parse(e||"{}");return Object.keys(n)}async getAll(){let e=this._qosDB.getStorageInfoSync(this._prefix),n=JSON.parse(e||"{}");return Object.values(n)}closeDB(){return Promise.resolve()}get isReady(){return!!this._qosDB}};function Wh(t,e){if(vn||vn)return new jc(t,e);if((lr||wi)&&typeof indexedDB<"u")return new Gc(t,e);if((lr||wi)&&typeof localStorage<"u")return new Hc(t,e);throw new Error("init QoSDB failed")}var Wc=class{constructor(){this._intervalTimeoutId=null,this._interval=36e5,this._qosDB=Wh("qos","message_id")}async _intervalFlush(){clearInterval(this._intervalTimeoutId),this._intervalTimeoutId=setInterval(()=>{this.flushExpired()},this._interval)}async openDB(){await this._qosDB.openDB().then(()=>{this._intervalFlush()})}async flushExpired(){(await this._qosDB?.getAll()||[]).filter(({timestamp:r})=>r<Date.now()).forEach(r=>{this._qosDB?.del(r.message_id)})}async del(e){return this._qosDB?.del(e)}async set(e,n){return this._qosDB?.set({message_id:e,timestamp:n})}async get(e){return this._qosDB?.get(e)}async closeDB(){clearInterval(this._intervalTimeoutId),await this._qosDB?.closeDB()}get isReady(){return this._qosDB?.isReady}};function Kc(t){let e=!!this._options.enableQoS;if(!e)return{enabled:e,isQoSMessage:!1,isQoSAck:!1,isAckCleanupMessage:!1,ackMsgIds:[]};let n=Jt(t.message.headers,"x_frontier_qos","2"),r=n&&Jt(t.message.headers,"x_frontier_qos_ack","1"),i=n&&Jt(t.message.headers,"x_frontier_is_ack","1"),s=i?cr(t.message.headers,"x_frontier_ack_msgid")?.split(",").filter(Boolean)||[]:[];return{enabled:e,isQoSMessage:n,isQoSAck:r,isAckCleanupMessage:i,ackMsgIds:s}}async function qh(){return this._QoSManager||(this._QoSManager=new Wc),this._QoSManager.isReady||await this._QoSManager.openDB(),this._QoSManager}async function o0(t,e){let{enableAutoAck:n}=this._options,r=Jt(t.message.headers,"need_ack","1"),i=Jt(t.message.headers,"is_ack","1"),s=Kc.call(this,t);if(n&&r){let{SeqID:o,LogID:a,service:c,LogIDNew:l,method:d}=t.message;this._sendAck({SeqID:o,LogID:a,LogIDNew:l,service:c,method:d,headers:[{key:"is_ack",value:"1"},{key:"ack_id",value:l||""},{key:"ack_code",value:"0"}]})}i&&!s.isQoSAck&&this._dispatchAckMessageEvent(t),e()}async function a0(t,e){this._debug("received",t.message),e()}async function c0(t,e){let n=WS(await jh(t.data));try{if(n.payload instanceof Uint8Array){let r=this._options.payloadEncoding instanceof Object?{force:!!this._options.payloadEncoding.force,encoding:this._options.payloadEncoding.encoding?this._options.payloadEncoding.encoding.replace(/\s/g,"").toLowerCase():""}:{force:!1,encoding:this._options.payloadEncoding?this._options.payloadEncoding.replace(/\s/g,"").toLowerCase():""},i=n.payloadEncoding?n.payloadEncoding.replace(/\s/g,"").toLowerCase():"",s=this._options.payloadType instanceof Object?{force:!!this._options.payloadType.force,type:this._options.payloadType.type?this._options.payloadType.type.replace(/\s/g,"").toLowerCase():""}:{force:!1,type:this._options.payloadType?this._options.payloadType.replace(/\s/g,"").toLowerCase():""},o=n.payloadType?n.payloadType.replace(/\s/g,"").toLowerCase():"",a=s.force?s.type:o||s.type,c=r.force?r.encoding:i||r.encoding,l=["text/plain;charset=utf-8","application/json","application/json;charset=utf-8","string"],d=["none_none","binary"];this._options.enableTransformTextPayload&&l.includes(a)&&(!c||d.includes(c))?n.textPayload=Hh(n.payload,0,n.payload.byteLength):n.textPayload=""}else n.textPayload=""}catch(r){n.textPayload="",console.log(r)}t.message=n,e()}function l0(t,e,n){let r=n||8192,i=r>>>1,s=null,o=r;return function(a){if(a<1||a>i)return t(a);o+a>r&&(s=t(r),o=0);let c=e.call(s,o,o+=a);return 7&o&&(o=(7|o)+1),c}}var d0=4294967295;function u0(t,e,n){if(n>d0)throw new Error("integer too large");let r=3;for(;r>=0;){let i=255&n;Vc(i,t,e+r),n>>>=8,r--}return e+4}function f0(t,e){let n=0,r=e,i=e+4;for(;r<i;){let{value:s,offset:o}=qc(t,r);r=o,n=n<<8>>>0,n+=s}return{value:n,offset:i}}function h0(t,e,n){return t?t.length<40?zc(t,e,n)+n:e.utf8Write?e.utf8Write(t,n)+n:e.write?e.write(t,n)+n:zc(t,e,n)+n:n}function p0(t,e){let n=new Ne(t[e+4]<<24|t[e+5]<<16|t[e+6]<<8|t[e+7],t[e+0]<<24|t[e+1]<<16|t[e+2]<<8|t[e+3],!0);return e+=8,{value:n,offset:e+8}}function g0(t,e,n){let r=t.low,i=t.high;return e[n]=i>>>24,e[n+1]=i>>>16&255,e[n+2]=i>>>8&255,e[n+3]=255&i,e[n+4]=r>>>24,e[n+5]=r>>>16&255,e[n+6]=r>>>8&255,e[n+7]=255&r,n+=8,n}function qc(t,e){return t.readUInt8?{value:t.readUInt8(e),offset:e+1}:{value:255&t[e],offset:e+1}}function Vc(t,e,n){return e.writeUint8?e.writeUint8(t,n):e[n]=255&t,n+1}var m0=function(t){return new Uint8Array(t)},w0=typeof Buffer<"u"?Buffer.allocUnsafe:l0(m0,Uint8Array.prototype.subarray),y0=16,Xc=32;function _0(t){let e=0,n={};for(let r=0;r<t.length;r++)n[t[r].cursor_name]=Gh(t[r].cursor_name),e+=14+n[t[r].cursor_name];return[e,n]}function Lh(t,e,n){let[r,i]=_0(t),s=w0(r),o=0;return t.forEach(a=>{console.log("cursor.service",a,a.service),o=Vc(0,s,o),console.log("header",o),o=u0(s,o,a.service||0),console.log("service",o),o=Vc(i[a.cursor_name],s,o),console.log("service-name",o),o=h0(a.cursor_name,s,o),console.log("name",o),o=g0(Ne.fromNumber(a.cursor||e),s,o),console.log("curvalue",o)}),{frameType:Xc,headers:[{key:"cursor_file_name",value:n}],payload:s}}function E0(t){let e=0,n=[];for(;e<t.byteLength;){let{offset:r}=qc(t,e);e=r;let i={cursor_name:"",cursor:0,service:0},{value:s,offset:o}=f0(t,e);i.service=s,e=o;let{value:a,offset:c}=qc(t,e);e=c,i.cursor_name=Hh(t,e,e+a),e+=a;let{value:l,offset:d}=p0(t,e);i.cursor=l.toNumber(),e=d,n.push(i)}return n}function S0(){return{frameType:Xc,headers:[{key:"cursor_file_name",value:"FILE_NOT_EXIST"}],payload:void 0}}var Jc=class{constructor(e,n,r){this._cursorNameSpace=e,this._cursorFileName=n,this._messageStrategy=r,this._qosDB=Wh(this._cursorNameSpace,"cursor_name")}async openDB(){await this._qosDB.openDB()}async getCursors(){if(!this._qosDB.isReady)return;let e=this._messageStrategy,n=await this._qosDB.getAll();switch(console.log("allCursorValues",n),e){case"ALL":return n&&n.length?Lh(n,0,this._cursorFileName):void 0;case"INSTANT":return;case"CONTINUE":return n&&n.length?Lh(n,0,this._cursorFileName):S0()}}async set(e,n,r){return console.log("setdb",e,n,r),this._qosDB.set({cursor_name:e,cursor:n,service:r})}async setCursors(e){let n=E0(e);for(let r of n)console.log("setcursor",n),await this._qosDB.set(r)}async get(e){return(await this._qosDB.get(e))?.cursor}async closeDB(){await this._qosDB.closeDB()}updateCursorFileName(e){this._cursorFileName=e}get isReady(){return this._qosDB.isReady}},v0="__x_msg_qos__";async function Vh(t){if(!this._options.enableQoS)return null;let{aID:e,fpID:n,messageStrategy:r}=this._options,i=t||v0;try{return this._cursorManager?t&&this._cursorManager.updateCursorFileName(t):this._cursorManager=new Jc(`${n}_${e}_${i}`,i,r),this._cursorManager.isReady||await this._cursorManager.openDB(),this._cursorManager}catch{return null}}async function I0(t,e){let n=Jt(t.message.headers,"code","-1"),r=Jt(t.message.headers,"is_ack","1"),i=cr(t.message.headers,"x_frontier_msgid"),s=Number(cr(t.message.headers,"x_frontier_ttl"))||0,o=Kc.call(this,t),a=Jt(t.message.headers,"x-msg-qos","2"),c=cr(t.message.headers,"x-msg-cursor_name"),l=Number(cr(t.message.headers,"x-msg-cursor_value"));if(o.isQoSAck)return e();let d=o.isQoSMessage?await qh.call(this):null;if(t.message.service>0&&r&&!n||t.message.service>0){if(i&&o.isQoSMessage&&d)return await d.get(i)||(this._dispatchMessageEvent(t),await d.set(i,Date.now()+s)),e();if(a){let p=await Vh.call(this);if(!p)return this._dispatchMessageEvent(t),e();let m=await p.get(c)??-1;if(m<l)this._dispatchMessageEvent(t),p.set(c,l,t.message.service);else throw new Error(`recevied message cursor ${l} larger than local cursor ${m}`);return e()}return this._dispatchMessageEvent(t),e()}}async function T0(t,e){let n=Kc.call(this,t);if(!n.isQoSMessage)return e();let r=await qh.call(this);if(n.isAckCleanupMessage&&n.ackMsgIds.length)for(let i of n.ackMsgIds)await r.del(i);e()}async function R0(t,e){let n=t.message.frameType===y0,r=t.message.frameType===Xc;if(!n&&!r)return e();let i=cr(t.message.headers,"cursor_file_name");if(!i)return e();let s=await Vh.call(this,i);if(!s)return e();if(n){let o=await s.getCursors(),a={frameType:o?.frameType,SeqID:Ne.fromNumber(this._seqId++),LogID:Ne.fromNumber(this._options.logIDGenerator()),service:9e3,method:5,headers:o?.headers,payload:o?.payload},c=Fh(a);this._ws&&this._ws.readyState&&this._ws.send(c)}if(r){let o=t.message.payload;o&&s.setCursors(o)}}var k0=async function(t,e){this._isInit=!1,clearTimeout(this._connectionTimeoutId),e()},b0=async function(t,e){let n=this._endpointManager?.getCurrentEndpoint();this._debug(`open ${n}`),e()},A0=async function(t,e){if(!this._ws||this._ws.readyState!==this.OPEN)return e();let{pingInterval:n}=this._options;this._endpointManager?.resetEndpointConfig();for(let i=0;i<this._messageQueue.length;i++){let s=this._messageQueue[i];if(this._ws.readyState===this.OPEN&&s!==null)this._ws&&this._ws.send(s),this._messageQueue[i]=null;else break}this._messageQueue=this._messageQueue.filter(i=>!!i),this._pingPongTimeoutId=setTimeout(()=>this._ping(),n),this._dispatchOpenEvent(t),this._isBrowser&&this._ws&&(this._ws.binaryType=this._binaryType);let r=this._endpointManager?.getCurrentEndpoint();this._debug(`open ${r} success`),e()},oo=class extends yi{constructor(e){super(),this._miniNavigatorOnline=!0,this._isBrowser=lr,this._isNode=QS,this._isMiniTT=vn,this._isMiniWX=Ei,this._isWorker=wi,this._messageQueue=[],this._endpointManager=null,this._readyClosed=!1,this._binaryType="arraybuffer",this._connectLock=!1,this._connectionTimeoutId=null,this._reconnectTimeoutId=null,this._pingPongTimeoutId=null,this._seqId=0,this._isInit=!1,this._url="",this._QoSManager=null,this._cursorManager=null,this._pingLossCounter=null,this._protocols="pbbp2",this.CLOSED=3,this.CONNECTING=0,this.OPEN=1,this.CLOSING=2,this._onOpen=s=>{try{Nh(this,s,[k0,A0,b0])}catch(o){let a=Xe("error",{message:o.message,code:yn.OPEN_ERROR,error:o});this._dispatchErrorEvent(a)}},this._onMessage=async s=>{let{pingInterval:o,pingFrequency:a}=this._options;if((s.data==="hi"&&a==="always"||a==="auto")&&(this._clearPingTimer(),this.emit("ping_once_success","success"),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),o)),s.data!=="hi")try{Nh(this,s,[c0,o0,T0,R0,I0,a0])}catch(c){let l=Xe("error",{message:c.message,code:yn.MESSAGE_ERROR,error:c});this._dispatchErrorEvent(l)}},this._onError=s=>{let o=this._endpointManager?.checkReachMaxTries(),a=this._endpointManager?.getCurrentEndpoint();if(o&&!s.message){let c=`connect ${a} fail, max retries reached`;this._dispatchErrorEvent(Xe("error",{message:c,code:yn.MAX_RETRIES_ERROR,error:s}));return}this._ws&&this._ws.readyState===this.OPEN&&this._disconnect(),this._dispatchErrorEvent(Xe("error",{message:s.message,code:yn.NATIVE_ERROR,error:s}))},this._onClose=async s=>{this._clearTimer(),this._clearPingTimer(),this._removeWsListeners(),this._ws=null,this._connectLock=!1;let o=this._endpointManager?.checkReachMaxTries();if(!o&&this._navigatorOnline()&&!this._readyClosed){let a=this._endpointManager?.getCurrentEndpoint(),c=this._options.reconnectInterceptor(s.code,s.reason);this._dispatchCloseEvent(dt("close",{code:1006,reason:s.reason||`connecting failed, unknown reason, hostname: ${a}`,willReconnect:c})),c&&this._connect();return}if(s.code!==1e3&&this._readyClosed){this._dispatchCloseEvent(dt("close",{code:1e3,reason:"bye"})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}if(s.code!==1e3&&o){let a=this._endpointManager?.getCurrentEndpoint(),c=s.reason;c||(c=await i0(this._url)),c=`connecting failed, ${c}, hostname: ${a}, max retries reached`,this._dispatchCloseEvent(dt("close",{code:s.code,reason:c}));let l=`connect ${a} fail, max retries reached`;this._dispatchErrorEvent(Xe("error",{message:l,code:yn.MAX_RETRIES_ERROR})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}if(s.code!==1e3&&!s.reason){let a=this._endpointManager?.getCurrentEndpoint();this._dispatchCloseEvent(dt("close",{code:s.code,reason:`connecting failed, unknown reason, hostname: ${a}`})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}this._dispatchCloseEvent(s),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter()},this.onclose=null,this.onerror=null,this.onmessage=null,this.onopen=null,this.onStartReconnect=null,this.onReceiveAck=null,this.onStopImmediatelyReconnect=null,this._handleOnLine=this._handleOnLine.bind(this),this._handleOffLine=this._handleOffLine.bind(this),this._handlePageHide=this._handlePageHide.bind(this),this._handlePageShow=this._handlePageShow.bind(this),this._options={url:"",automaticOpen:!0,initReconnectInterval:1e3,maxReconnectInterval:1e4,reconnectIntervalGrowFactor:2,timeoutInterval:5e3,maxRetries:5,debug:!1,maxMessageQueueLength:1/0,service:0,logIDGenerator:AS,headers:void 0,payloadEncoding:"",payloadType:"",fpID:"",deviceID:"",accessKey:"",ttwID:"",bddID:"",aID:"",disableAutoReconnect:!1,customParams:{},pingInterval:15e3,pingTimeoutInterval:4e3,pingFrequency:"auto",pingLossCount:2,enableTransformTextPayload:!1,logIDNewConfig:{enableAutoGenerateLogIDNew:!1,userIp:""},miniProgramParams:{customHttpHeader:{}},enableAutoAck:!1,reconnectInterceptor:()=>!0,enableQoS:!1,QoSLevel:2,messageStrategy:"CONTINUE",env:{xTTEnv:"",xUseEnv:""},listenNetworkChanged:!0};let{url:n,ws:r}=e,i=Array.isArray(n)?n:typeof n=="string"?[n]:[];if(!i||i.length===0)throw new Error("please provide valid url");if(!t0(r))throw new Error("please provide ws params, WebSocket constructor is undefined");Object.assign(this._options,e),this._endpointManager=new so(i,this._options.maxRetries),this._pingLossCounter=new $c(this._options.pingLossCount),this._options.automaticOpen&&(this._isInit=!0,this._connect()),this._options.listenNetworkChanged&&(this._isMiniTT||this._isMiniWX?this._onPageNetWorkChange():this._isBrowser&&this._initGlobalEventListener())}_handleOnLine(){this._options.disableAutoReconnect||this._readyClosed||this._handleReconnect()}_handleOffLine(){this._destroyWebSocket();let e=Dh("reconnect",{message:"stop immediately reconnect"});this.onStopImmediatelyReconnect&&this.onStopImmediatelyReconnect(e)}_initGlobalEventListener(){this._isBrowser&&window.addEventListener("online",this._handleOnLine),this._isBrowser&&window.addEventListener("offline",this._handleOffLine),this._isBrowser&&window.addEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.addEventListener("pageshow",this._handlePageShow)}_dropGlobalEventListener(){this._isBrowser&&window.removeEventListener("online",this._handleOnLine),this._isBrowser&&window.removeEventListener("offline",this._handleOffLine),this._isBrowser&&window.removeEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.removeEventListener("pageshow",this._handlePageShow)}_handlePageHide(e){e.persisted||(this._isBrowser&&window.removeEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.removeEventListener("pageshow",this._handlePageShow),this.close()),this._isBrowser&&window.removeEventListener("online",this._handleOnLine),this._isBrowser&&window.removeEventListener("offline",this._handleOffLine)}_handlePageShow(e){e.persisted&&(this._navigatorOnline()&&(!this._ws||this._ws.readyState!==this.OPEN||this._ws.readyState!==this.CONNECTING)&&this._handleOnLine(),this._isBrowser&&window.addEventListener("online",this._handleOnLine),this._isBrowser&&window.addEventListener("offline",this._handleOffLine))}async _generateUrl(e){let{fpID:n,deviceID:r,bddID:i,ttwID:s,accessKey:o,aID:a,customParams:c={},enableAutoAck:l,enableQoS:d,QoSLevel:p,env:m}=this._options,u,h,g;this._isBrowser||this._isMiniWX||this._isMiniTT?(u=location&&location.protocol=="https:"?"wss://":"ws://",h=e.replace(/((^ws)|(^http))((?:[s]*:\/\/))/,""),g=/^wss(.*:\/\/)/.test(e)?e:`${u}${h}`):(u="wss://",h=e.replace(/(^http)((?:[s]*:\/\/))/,""),g=/(^ws)((?:[s]*:\/\/))/.test(h)?h:`${u}${h}`);let w=i?"bd_did":s?"ttwid":"device_id",S=i||s||r;if(!S||!w)throw new Error("please provide bddID, deviceID or ttwID");let v=typeof c=="function"?await c():c,f=m?r0(m.xUseEnv,m.xTTEnv):{},y=Object.assign({device_platform:"web",version_code:"fws_1.0.0",access_key:o,fpid:n,aid:a,[w]:S,xsack:l?1:0,xaack:l?1:0,xsqos:d?1:0,qos_level:d?p:void 0,qos_sdk_version:2,...f},v),E=Object.keys(y).reduce((T,R)=>y[R]!==void 0?`${T}${T?"&":"?"}${R}=${y[R]}`:T,"");return`${g}/ws/v2${E}`}async _connect(){if(!(this._connectLock||this._readyClosed)){this._connectLock=!0;try{let e=this._endpointManager?.checkCurrentEndpointReachedMaxRetries(),{timeoutInterval:n}=this._options;if(e){let i=this._endpointManager?.getCurrentEndpoint(),s=this._endpointManager?.replaceBackupEndpointAndUpdateCount(),o=this._endpointManager?.getCurrentEndpointTriesCount();if(s){let a=`connect ${i} timeout, max retries reached, will use backup endpoint ${s} to retry`,c=Xe("error",{message:a,code:yn.MAX_RETRIES_ERROR});this._debug(a),this._dispatchErrorEvent(c),this._url=await this._generateUrl(s),this._debug(`connect ${s} ${o} times`),this._removeWsListeners()}else{let a=`connect ${i} timeout, max retries reached`;this._debug(a),this._dispatchErrorEvent(Xe("error",{message:a,code:yn.MAX_RETRIES_ERROR}));return}}else{let i=this._endpointManager?.getCurrentEndpointAndUpdateCount(),s=this._endpointManager?.getCurrentEndpointTriesCount();this._url=await this._generateUrl(i||""),this._debug(`connect ${i} ${s} times`),this._removeWsListeners()}if(this._isInit)this._isInit=!1;else{let i=Dh("reconnect",{message:"start"});this.onStartReconnect&&this.onStartReconnect(i)}let r=this._endpointManager?.getCurrentEndpointTriesCount()||0;r>1&&await this._wait(r-1),this._debug(`connecting url: ${this._url} protocols: ${this._protocols}`),this._ws=e0({url:this._url,protocols:[this._protocols],headers:this._options.miniProgramParams.customHttpHeader},this._options.ws),(this._isBrowser||this._isWorker)&&this._ws&&(this._ws.binaryType=this._binaryType),this._addWsListeners(),this._connectionTimeoutId=setTimeout(this._onTimeout.bind(this),n)}catch(e){throw this._connectLock=!1,e}}}_clearTimer(){clearTimeout(this._connectionTimeoutId),this._connectionTimeoutId=null}_clearPingTimer(){clearTimeout(this._pingPongTimeoutId),clearTimeout(this._reconnectTimeoutId),this._pingPongTimeoutId=null,this._reconnectTimeoutId=null}_debug(...e){this._options.debug&&console.log.apply(console,["FRONTIER>",...e])}_getIntervalValue(e){let{initReconnectInterval:n,maxReconnectInterval:r,reconnectIntervalGrowFactor:i}=this._options,s=n*Math.pow(i,e-1);return s>r?r:s}_ping(){if(this._ws&&this._ws.readyState===this.CONNECTING){this._clearPingTimer(),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),this._options.pingInterval);return}if(!this._ws||this._ws.readyState!==this.OPEN)return void this._handleReconnect();this._ws&&this._ws.send("hi"),this._reconnectTimeoutId=setTimeout(this._handleReconnectTimeout.bind(this),this._options.pingTimeoutInterval)}_handleReconnectTimeout(){this._pingLossCounter?.addCount(),this.emit("ping_once_timeout","timeout"),this._pingLossCounter?.checkReachMaxCount()?this._handleReconnect():this._ping()}_navigatorOnline(){return this._isMiniTT||this._isMiniWX?this._miniNavigatorOnline:(this._isBrowser||this._isWorker)&&this._options.listenNetworkChanged?navigator.onLine:!0}_handleReconnect(){!this._navigatorOnline()||this._readyClosed||(this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(),this._ws?this._disconnect(1001,"going away, try reconnecting server",!0):this._connect())}_onPageNetWorkChange(){this._isMiniTT?tt.onNetworkStatusChange(({isConnected:e})=>{this._miniNavigatorOnline=e,e?this._handleOnLine():this._handleOffLine()}):this._isMiniWX&&wx.onNetworkStatusChange(({isConnected:e})=>{this._miniNavigatorOnline=e,e?this._handleOnLine():this._handleOffLine()})}_wait(e){return new Promise(n=>{setTimeout(n,this._getIntervalValue(e))})}_disconnect(e=1e3,n="",r=!1){this._ws&&this._destroyWebSocket(e,n,r)}_onTimeout(){let e=this._endpointManager?.getCurrentEndpoint();this._debug(`connect ${e} timeout`),this._disconnect(1001,"timeout, try reconnecting",!0)}_sendAck(e){let n=xh(e);this._ws&&this._ws.readyState===this.OPEN&&(this._ws&&this._ws.send(n),this._debug("send_ack",e))}_removeWsListeners(){this._ws&&(this._ws.removeEventListener("open",this._onOpen),this._ws.removeEventListener("close",this._onClose),this._ws.removeEventListener("message",this._onMessage),this._ws.removeEventListener("error",this._onError))}_addWsListeners(){this._ws&&(this._ws.addEventListener("open",this._onOpen),this._ws.addEventListener("close",this._onClose),this._ws.addEventListener("message",this._onMessage),this._ws.addEventListener("error",this._onError))}_wsInstanceClose(e=1e3,n=""){try{this._ws&&this._ws.close(e,n)}catch{}}_destroyWebSocket(e=1e3,n="",r=!1){if(this._clearPingTimer(),this._clearTimer(),this._removeWsListeners(),this._wsInstanceClose(1e3,n),this._connectLock=!1,r&&this._navigatorOnline()&&!this._readyClosed){if(this._endpointManager?.checkReachMaxTries()){let s=this._endpointManager?.getCurrentEndpoint();this._dispatchCloseEvent(dt("close",{code:1006,reason:`connect ${s} timeout, max retries reached`,wasClean:!0}))}else{let s=this._options.reconnectInterceptor(e,n);this._dispatchCloseEvent(dt("close",{code:e,reason:n,wasClean:!0,willReconnect:s})),s&&this._connect()}return}this._navigatorOnline()||this._readyClosed?this._dispatchCloseEvent(dt("close",{code:e,reason:"bye"})):this._dispatchCloseEvent(dt("close",{code:1006,reason:"going away, network offline"})),this._ws=null,this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter()}_dispatchOpenEvent(e){this.emit("open",e),this.onopen&&this.onopen(e)}_dispatchMessageEvent(e){this.emit("message",e),this.onmessage&&this.onmessage(e)}_dispatchAckMessageEvent(e){this.emit("ack",e),this.onReceiveAck&&this.onReceiveAck(e)}_dispatchErrorEvent(e){this.emit("error",e),this.onerror&&this.onerror(e)}_dispatchCloseEvent(e){this.emit("close",e),this.onclose&&this.onclose(e)}get binaryType(){return this._ws?this._ws.binaryType:this._binaryType}set binaryType(e){this._binaryType=e,this._ws&&(this._ws.binaryType=e)}get retryCount(){return this._endpointManager?.getCurrentEndpointTriesCount()||0}get bufferedAmount(){return this._messageQueue.reduce((n,r)=>(n+=r&&r.byteLength||0,n),0)+(this._ws?this._ws.bufferedAmount:0)}get extensions(){return this._ws?this._ws.extensions:""}get protocol(){return this._ws?this._ws.protocol:""}get readyState(){return this._ws?this._ws.readyState:this._options.automaticOpen?this.CONNECTING:this.CLOSED}get url(){return this._ws?this._ws.url:this._url}close(e=1e3,n){if(this._readyClosed=!0,this._clearTimer(),this._clearPingTimer(),this._dropGlobalEventListener(),this._QoSManager?.closeDB(),!this._ws)return void this._debug("close, ws instance not initialized");if(this._ws.readyState===this.CLOSED||this._ws.readyState===this.CLOSING)return void this._debug("close, ws already closed");this._destroyWebSocket(e,n)}async send(e,n){if(e==null)throw new Error("please provide a valid data, data must be a string or an arraybuffer");typeof e=="number"&&(e=JSON.stringify(e)),typeof e!="string"&&!(e instanceof ArrayBuffer)&&!(e.buffer&&e.buffer instanceof ArrayBuffer)&&(e=JSON.stringify(e));let r=await jh(e),i=n0(e),{method:s=0,service:o=this._options.service,logID:a=this._options.logIDGenerator(),headers:c=this._options.headers,payloadEncoding:l=this._options.payloadEncoding,payloadType:d=this._options.payloadType,logIDNew:p=this._options.logIDNewConfig.enableAutoGenerateLogIDNew?bS(this._options.logIDNewConfig.userIp):""}=n||{};if(!o)throw new Error("please provide a valid service");let m={SeqID:Ne.fromNumber(this._seqId++),LogID:Ne.fromNumber(a),service:o,method:s,headers:c,payloadEncoding:l instanceof Object?l.encoding?l.encoding:"":l,payloadType:d instanceof Object?d.type?d.type:i:d||i,payload:r,LogIDNew:p},u=xh(m);return this._ws&&this._ws.readyState===this.OPEN?(this._ws&&this._ws.send(u),this._debug("sent",m)):this._messageQueue.length<this._options.maxMessageQueueLength?(this._messageQueue.push(u),this._debug("enqueue",m)):(this._messageQueue.shift(),this._messageQueue.push(u)),{seqID:this._seqId,logID:a,logIDNew:p}}async reconnect(e){let{url:n}=e||{},r=Array.isArray(n)?n:typeof n=="string"?[n]:[];e&&Object.assign(this._options,e),r&&r.length?this._endpointManager=new so(r,this._options.maxRetries):this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(this._options.pingLossCount),this._readyClosed=!1,this._ws&&this._ws.readyState!==this.CLOSED?this._disconnect(1e3,"manual reconnecting",!0):(this._isInit=!0,this._connect())}async connect(){this._connectLock||(this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(),this._readyClosed=!1,this._isInit=!0,this._connect())}addEventListener(e,n){this.on(e,n)}dispatchEvent(e){let{type:n}=e;this.emit(n,e)}removeEventListener(e,n){this.off(e,n)}pingOnce(){return new Promise((e,n)=>{this._clearPingTimer(),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),this._options.pingInterval);let r=()=>{e("success"),this.off("ping_once_success",r),this.off("ping_once_timeout",i)},i=()=>{n("timeout"),this.off("ping_once_success",r),this.off("ping_once_timeout",i)};this.on("ping_once_success",r),this.on("ping_once_timeout",i),this._ping()})}};var Jv=ht(Gp(),1),Zv=ht(mo(),1),Kv=ht(fr(),1),Xv=ht(cl(),1),Yv=ht(ul(),1),Qv=ht(wl(),1),Xp=ht(Eo(),1),eI=ht(Kp(),1);var Yp=Xp.default;Te();L();var te=b("upstream.frontier"),eg="application/json",tg="none",nI=15e3;function rI(t){class e extends Yp{constructor(r){super(r,rf,{headers:t})}guardTeardown(){this.listenerCount("error")===0&&this.on("error",r=>te.warn("frontier ws error during teardown (handled, prevents daemon crash)",{err:r instanceof Error?r.message:String(r)}))}close(r,i){this.guardTeardown(),super.close(r,i)}terminate(){this.guardTeardown(),super.terminate()}send(r,...i){if(Ml("debug"))try{let s;typeof r=="string"?s=Buffer.from(r,"utf8"):r instanceof Buffer?s=r:r instanceof ArrayBuffer?s=new Uint8Array(r):ArrayBuffer.isView(r)?s=new Uint8Array(r.buffer,r.byteOffset,r.byteLength):s=new Uint8Array(0);let o=Buffer.from(s.slice(0,128)).toString("hex");te.debug("WS raw frame out",{bytes:s.byteLength,headHex:o})}catch(s){te.warn("WS raw frame dump failed",{err:String(s)})}super.send(r,...i)}}return e}var Ai=class{constructor(e){this.opts=e}opts;fws=null;handler=null;connectHandlers=[];opened=!1;lastSendRefusedLogAt=0;sendRefusedSuppressed=0;openCount=0;async start(){if(this.fws){te.warn("start called on already-started FrontierUpstream; noop");return}let e={Authorization:`Bearer ${this.opts.privatecode}`,Origin:sf,...Qn(this.opts.ppeOverride)},n=rI(e),r=af(this.opts.urlOverride),i={url:r,ws:n,fpID:nf,aID:$s,accessKey:this.opts.handshake.accessKey,deviceID:this.opts.handshake.deviceId,payloadType:{type:eg,force:!0},payloadEncoding:{encoding:tg,force:!0},enableTransformTextPayload:!0,enableQoS:!1,enableAutoAck:!1,automaticOpen:!1,maxRetries:Number.POSITIVE_INFINITY,debug:this.opts.debug??!1},s=new oo(i),o=!1,a=null,c,l,d=new Promise((u,h)=>{c=u,l=h}),p=u=>{o||(o=!0,a&&(clearTimeout(a),a=null),u?l(u):c())};s.onopen=()=>{this.opened=!0,this.openCount+=1;let u=this.openCount===1;te.info("frontier opened",{url:r,remoteDeviceId:this.opts.handshake.deviceId,initial:u,openCount:this.openCount}),u&&p();for(let h of this.connectHandlers)Promise.resolve(h({initial:u})).catch(g=>te.warn("onConnect handler threw (ignored)",{err:String(g)}))},s.onclose=u=>{this.opened=!1,te.info("frontier closed",{code:u.code,reason:u.reason,willReconnect:u.willReconnect})},s.onerror=u=>{te.warn("frontier error",{code:u.code,msg:u.message}),p(new _("UPSTREAM_DISCONNECTED",`frontier connect error before open: code=${u.code} msg=${u.message??""}`))},s.onmessage=u=>this.handleMessage(u),this.fws=s;let m=this.opts.openTimeoutMs??nI;a=setTimeout(()=>{p(new _("UPSTREAM_DISCONNECTED",`frontier ws open timeout after ${m}ms (handshake or upgrade slow)`))},m),await s.connect();try{await d}catch(u){try{s.close(1e3,"open failed")}catch(h){te.warn("fws close during start failure threw (ignored)",{err:String(h)})}throw this.fws=null,this.opened=!1,u}}async stop(e){let n=this.fws;if(n){this.fws=null,this.opened=!1;try{n.close(1e3,e??"bridge shutdown")}catch(r){te.warn("frontier close threw (ignored)",{err:String(r)})}}}async send(e){let n=this.fws,r=e.method;if(!n)throw te.warn("frontier send refused: upstream not started",{method:r}),new _("UPSTREAM_DISCONNECTED","frontier upstream not started");if(!this.isConnected()){let a=Date.now();throw a-this.lastSendRefusedLogAt>1e3?(te.warn("frontier send refused: ws not open",{method:r,opened:this.opened,readyState:n.readyState,...this.sendRefusedSuppressed>0?{suppressedSinceLast:this.sendRefusedSuppressed}:{}}),this.lastSendRefusedLogAt=a,this.sendRefusedSuppressed=0):this.sendRefusedSuppressed+=1,new _("UPSTREAM_DISCONNECTED",`frontier ws not open (opened=${this.opened}, readyState=${n.readyState}); refusing to silently buffer`)}this.injectAgentPatToken(e);let i=JSON.stringify(e),s=e;ng(s)||te.info("frontier frame out",{method:s.method,jsonrpcId:s.id,size:i.length});try{await n.send(i,{service:33555712,method:1,payloadType:eg,payloadEncoding:tg})}catch(a){throw te.warn("frontier frame send failed",{method:s.method,jsonrpcId:s.id,err:String(a)}),new _("UPSTREAM_DISCONNECTED",`frontier send failed: ${String(a)}`,{cause:a})}}onFrame(e){this.handler=e}onConnect(e){this.connectHandlers.push(e)}isConnected(){return this.opened&&this.fws?.readyState===1}injectAgentPatToken(e){let n=this.opts.getPatTokenForAgent;if(!n)return;let r=e.params?._meta;if(!r?.cozeAgentId)return;let i=n(r.cozeAgentId);i&&(r.cozePatToken=i)}handleMessage(e){let n=e.message?.service;if(n!==33555712){te.debug("drop non-adapter frontier frame",{service:n});return}let r=oI(e);if(!r){te.debug("frontier message without text payload, drop",{payloadType:e.message?.payloadType});return}if(!this.handler){te.debug("frame received but no onFrame handler",{size:r.length});return}let i;try{i=JSON.parse(r)}catch(o){te.warn("frontier message JSON parse failed",{err:String(o),head:r.slice(0,80)});return}let s=i;ng(s)||te.info("frontier frame in",{logid:sI(e.message?.LogID),logidNew:e.message?.LogIDNew,msgId:e.message?.msgID,jsonrpcId:s.id,method:s.method,body:iI(r)}),Promise.resolve(this.handler(i)).catch(o=>te.warn("frontier frame handler threw",{err:String(o)}))}};function ng(t){return t.method==="_agent/health"?!0:typeof t.id=="string"&&t.id.startsWith("agent.health_")}var rg=2e3;function iI(t){return t.length<=rg?t:`${t.slice(0,rg)}...<truncated, total ${t.length} chars>`}function sI(t){return t?t.high===0?String(t.low>>>0):`${t.high.toString(16)}${(t.low>>>0).toString(16).padStart(8,"0")}`:""}function oI(t){let e=t.message;if(e?.textPayload)return e.textPayload;let n=e?.payload;if(!n)return null;try{return Buffer.from(n).toString("utf8")}catch{return null}}L();var _l=b("upstream.switchable"),vo=class{inner;handler=null;connectHandlers=[];constructor(e){this.inner=e}async swap(e,n){if(this.inner===e)return;_l.info("swap upstream",{reason:n});let r=this.inner;if(this.inner=e,this.handler&&e.onFrame(this.handler),e.onConnect)for(let i of this.connectHandlers)e.onConnect(i);try{await e.start()}catch(i){throw _l.error("swap target start failed, reverting",{err:String(i)}),this.inner=r,i}await r.stop(n??"swapped").catch(i=>_l.warn("previous upstream stop threw (ignored)",{err:String(i)}))}current(){return this.inner}start(){return this.inner.start()}stop(e){return this.inner.stop(e)}send(e){return this.inner.send(e)}onFrame(e){this.handler=e,this.inner.onFrame(e)}onConnect(e){this.connectHandlers.push(e),this.inner.onConnect?.(e)}isConnected(){return this.inner.isConnected()}};L();var El=b("upstream"),yr=class{handler=null;async start(){El.info("NoopUpstream started (M1 skeleton; real Frontier wired in M4)")}async stop(e){El.info("NoopUpstream stopped",{reason:e})}async send(e){El.debug("NoopUpstream.send (dropped)",{method:"method"in e?e.method:void 0})}onFrame(e){this.handler=e}isConnected(){return!1}async injectFrame(e){this.handler&&await this.handler(e)}};Te();L();L();le();import{promises as Sl}from"node:fs";import{dirname as aI}from"node:path";var cI=b("pat-token-store");async function Io(t=F()){try{let n=(await Sl.readFile(t.patTokenFile,"utf8")).trim();return n.length>0?n:null}catch(e){let n=e?.code;return n!=="ENOENT"&&cI.warn("read pat-token failed (treating as missing)",{path:t.patTokenFile,code:n,message:e.message}),null}}async function xi(t,e=F()){if(!t)throw new Error("writePatToken: empty patToken");await Sl.mkdir(aI(e.patTokenFile),{recursive:!0}),await Sl.writeFile(e.patTokenFile,t,{encoding:"utf8",mode:384})}le();le();import{promises as To}from"node:fs";import{join as lI}from"node:path";function dI(t,e){return`#!/bin/sh
99
+ `)}async function uh(t,e){if(typeof t!="string"||t.length===0)throw new _("IPC_BAD_REQUEST","path must be a non-empty string");let[n,r]=await Promise.all([ah(oh(e)),ah(oh(t))]),i=jE(n,r);if(JE(i,WE,GE(i)))throw new _("IPC_BAD_REQUEST",`path escapes workspace: ${t}`);return r}function JE(t,e,n){return t===""?!1:n?!0:t===".."||t.startsWith(`..${e}`)}async function ah(t){let e=[],n=t;for(;n!==Tc(n);)try{let r=await BE(n);return e.length?HE(r,...e.reverse()):r}catch{e.push($E(n)),n=Tc(n)}return t}L();var fh=b("prompt-multimodal"),hh=10*1024*1024,ZE=15e3,KE=6;async function ph(t){let e=new Array(t.length),n=0;async function r(){for(;n<t.length;){let s=n++,o=t[s];o!==void 0&&(e[s]=await XE(o))}}let i=Array.from({length:Math.min(KE,t.length)},()=>r());return await Promise.all(i),e}function gh(t){return t.some(e=>e.type==="image")}async function XE(t){if(t.type!=="image")return t;let e=t;if(e.data||!e.uri||!zs(e.uri))return t;try{let{buf:n,contentType:r}=await QE(e.uri),i=e.mimeType||YE(r)||"application/octet-stream";return fh.info("image uri fetched and inlined",{uri:e.uri,bytes:n.length,mimeType:i}),{type:"image",data:n.toString("base64"),mimeType:i}}catch(n){return fh.warn("image fetch failed, degrading to text block",{uri:e.uri,err:String(n)}),{type:"text",text:`[image load failed: ${e.uri}]`}}}function YE(t){if(!t)return;let e=t.indexOf(";");return(e===-1?t:t.slice(0,e)).trim()||void 0}async function QE(t){let e=new AbortController,n=setTimeout(()=>e.abort(),ZE);try{let r=await fetch(t,{signal:e.signal});if(!r.ok)throw new Error(`HTTP ${r.status} ${r.statusText}`);let i=await r.arrayBuffer();if(i.byteLength>hh)throw new Error(`image too large: ${i.byteLength} bytes (max ${hh})`);return{buf:Buffer.from(i),contentType:r.headers.get("content-type")??void 0}}finally{clearTimeout(n)}}At();Te();L();var P=b("core"),tS=3e4,nS=/^(boe|ppe)_[A-Za-z0-9_-]+$/,rS="\u6211\u6B63\u5728\u7B49\u5F85\u5BA1\u6279\uFF0C\u8BF7\u7A0D\u540E\u518D\u8054\u7CFB\u6211",iS="\u5BA1\u6279\u5DF2\u8D85\u65F6",sS=3e4,io=class{upstream;agents=new Map;disconnectedAgents=new Set;extensions;paths;sessionSpawner;sessionIdleTimeoutMs;upstreamIds=new ir;pendingUpstream=new Map;pendingBridge=new Map;currentCozeEnv;currentMockScenario;constructor(e){this.upstream=e.upstream,this.extensions=e.extensions??{},this.paths=e.paths,this.sessionSpawner=e.sessionSpawner,this.sessionIdleTimeoutMs=sh(e.bridgeConfig)}registerExtension(e,n){this.extensions[e]=n}getCozeEnv(){return this.currentCozeEnv}getMockScenario(){return this.currentMockScenario}setMockScenario(e){this.currentMockScenario=e&&e.length>0?e:void 0}async start(){this.upstream.onFrame(e=>this.handleFrame(e)),this.upstream.onConnect?.(({initial:e})=>{e||this.rejectAllPendingOnReconnect()}),await this.upstream.start(),P.info("Core started",{extensions:Object.keys(this.extensions)})}async stop(e){P.info("Core stopping",{reason:e}),await Promise.all([...this.agents.values()].map(n=>n.dispose(e))),this.agents.clear(),await this.upstream.stop(e)}get(e){return this.agents.get(e)}register(e){this.agents.set(e.agentId,e),P.info("agent registered",{agentId:e.agentId,framework:e.framework});for(let n of this.registerHandlers)try{n(e.agentId)}catch(r){P.warn("onAgentRegister handler threw (ignored)",{agentId:e.agentId,err:String(r)})}}onAgentRegister(e){return this.registerHandlers.add(e),()=>this.registerHandlers.delete(e)}registerHandlers=new Set;unregister(e){this.agents.delete(e)}reviveIfDisconnected(e){this.disconnectedAgents.delete(e)&&P.info("agent revived from disconnect",{agentId:e})}attachRuntimeHooks(e,n,r){let i=r.downstream;i&&(i.onUpdate(s=>{r.loadingSession||this.forwardUpdate(e,s)}),i.onAgentRequest(s=>{this.handleAgentRequest(e,i,s)}),i.onExit((s,o)=>{P.info("session runtime exited",{agentId:e.agentId,cloudId:n,code:s,signal:o}),ui(r),r.downstream=void 0,r.replySeq=0,r.acpSessionId&&e.activeTriggers.delete(r.acpSessionId),this.rejectPendingForDownstream(i,"downstream exited")}))}hasPendingPermissionFor(e){for(let n of this.pendingUpstream.values())if(n.downstream===e)return!0;return!1}rejectPendingForDownstream(e,n){let r=[];for(let[i,s]of this.pendingUpstream)s.downstream===e&&r.push(i);if(r.length!==0){P.info("reject pendingUpstream entries (downstream gone)",{reason:n,count:r.length});for(let i of r){let s=this.pendingUpstream.get(i);if(s){this.pendingUpstream.delete(i),this.upstream.send(Ht(i,{code:U.INTERNAL_ERROR,message:`bridge downstream gone: ${n}`})).catch(o=>P.debug("send error response to upstream failed (ignored)",{err:String(o)}));try{s.downstream.respondAgentRequestError(s.agentRequestId,{code:U.INTERNAL_ERROR,message:`bridge: ${n}`})}catch{}}}}}rejectAllPendingOnReconnect(){let e=this.pendingUpstream.size,n=this.pendingBridge.size;if(!(e===0&&n===0)){P.warn("upstream reconnected, rejecting stale pending requests",{pendingUpstream:e,pendingBridge:n});for(let[,r]of this.pendingUpstream){try{r.downstream.respondAgentRequestError(r.agentRequestId,{code:U.INTERNAL_ERROR,message:"upstream reconnected; please retry"})}catch{}this.clearPendingPermissionFor(r)}this.pendingUpstream.clear();for(let[,r]of this.pendingBridge)clearTimeout(r.timer),r.reject(new _("UPSTREAM_DISCONNECTED",`${r.method} aborted: upstream reconnected`));this.pendingBridge.clear()}}async handleFrame(e){if(qs(e)){this.handleUpstreamResponse(e);return}if(!("method"in e)||typeof e.method!="string")return;let n="id"in e&&e.id!==void 0?e.id:null,r=e.params?._meta?.cozeEnv;r&&nS.test(r)?this.currentCozeEnv=r:r&&P.warn("rejecting cozeEnv with invalid shape, keeping previous",{rejected:r});try{if(e.method.startsWith("_agent/")){let i=this.extensions[e.method];if(!i){n!==null?await this.sendError(n,U.METHOD_NOT_FOUND,`extension not registered: ${e.method}`):P.warn("drop notification: extension not registered",{method:e.method});return}let s=await i(e,this);n!==null&&await this.upstream.send(rr(n,s));return}if(e.method.startsWith("session/")){let i=await this.routeSessionMethod(e);n!==null&&await this.upstream.send(rr(n,i));return}if(e.method==="initialize"){n!==null&&await this.upstream.send(rr(n,{protocolVersion:1,agentCapabilities:{loadSession:!0}}));return}n!==null?await this.sendError(n,U.METHOD_NOT_FOUND,`method not implemented: ${e.method}`):P.warn("drop unknown notification",{method:e.method})}catch(i){P.error("handleFrame failed",{method:e.method,err:String(i)}),n!==null&&await this.upstream.send(Ht(n,di(i)))}}async routeSessionMethod(e){if(!e.params||typeof e.params!="object")throw new _("IPC_BAD_REQUEST",`${e.method} requires params`);let n=e.params,r=n._meta?.cozeAgentId;if(!r)throw new _("IPC_BAD_REQUEST",`${e.method}: missing _meta.cozeAgentId`);let i=this.agents.get(r);if(!i)throw this.disconnectedAgents.has(r)?new _("AGENT_DISCONNECTED",`agent ${r} has been disconnected; cloud must _agent/create to revive`):new _("AGENT_NOT_FOUND",`agent not found: ${r}`);let s=typeof n.sessionId=="string"?n.sessionId:void 0;if(e.method==="session/cancel"||e.method==="session/new"||!s)return this.dispatchSessionCall(i,e.method,n);if(e.method==="session/prompt"){let c=i.sessions.get(s);if(c?.pendingPermission){let l=n._meta?.cozeTriggerMsgId,d=sc(n._meta);return P.info("session in pendingPermission, bouncing new prompt",{agentId:i.agentId,cloudSessionId:s}),this.synthesizePromptReply(i,c,s,rS,l,d)}}let o=Date.now(),a=!1;try{let c=await i.getSessionQueue(s).enqueue(()=>this.dispatchSessionCall(i,e.method,n));return a=!0,c}finally{P.info("session call done",{agentId:i.agentId,method:e.method,durationMs:Date.now()-o,ok:a})}}async dispatchSessionCall(e,n,r){e.lastActiveAt=Date.now();let{stripped:i}=tf(r);switch(n){case"session/new":{let s=oS();return P.info("session/new ack (lazy spawn)",{agentId:e.agentId,cloudId:s}),{sessionId:s}}case"session/load":{let s=i;return P.info("session/load ack (lazy spawn)",{agentId:e.agentId,cloudId:s.sessionId}),{}}case"session/prompt":{let s=i,o=s.sessionId;if(!o)throw new _("IPC_BAD_REQUEST","session/prompt: missing sessionId");let a=await this.ensureRuntime(e,o);if(a.replySeq=0,await this.ensureDownstream(e,o,a),!a.downstream||!a.acpSessionId)throw new _("BRIDGE_INTERNAL","session runtime not ready after ensureDownstream");let c=r._meta?.cozeTriggerMsgId;c?e.activeTriggers.set(a.acpSessionId,c):e.activeTriggers.delete(a.acpSessionId);let l=sc(r._meta);if(l?e.activeGroupIds.set(a.acpSessionId,l):e.activeGroupIds.delete(a.acpSessionId),e.deployType==="cloud"&&e.modelInfo?.capabilities?.image===!1&&gh(s.prompt))throw new _("MODEL_MODALITY_UNSUPPORTED",`model=${e.modelInfo.id??e.model} does not support image input`);let d=await ph(s.prompt);try{let p=await a.downstream.sessionPrompt({...s,sessionId:a.acpSessionId,prompt:d});return a.lastActiveAt=Date.now(),p}catch(p){if(p instanceof _&&p.code==="AGENT_APPROVAL_TIMEOUT"){let m=a.pendingPermission;m&&(m.downstream.respondAgentRequest(m.agentRequestId,{outcome:{outcome:"cancelled"}}),this.pendingUpstream.delete(m.upstreamId),a.pendingPermission=void 0);let u=a.acpSessionId,h=u?e.activeTriggers.get(u):void 0,g=u?e.activeGroupIds.get(u):void 0;return P.warn("approval timed out, synthesizing \u5BA1\u6279\u5DF2\u8D85\u65F6 reply + recovering session",{agentId:e.agentId,cloudId:o}),await this.synthesizePromptReply(e,a,o,iS,h,g)}throw p}finally{if(e.activeTriggers.delete(a.acpSessionId),e.activeGroupIds.delete(a.acpSessionId),a.pendingPermission=void 0,a.reloadAfterTurn){a.reloadAfterTurn=!1;let p=a.downstream;p&&(a.downstream=void 0,P.info("reloadAfterTurn: stopping downstream",{agentId:e.agentId,cloudId:o,acpId:a.acpSessionId}),p.stop("reload-after-turn").catch(m=>P.warn("reload-after-turn stop failed (ignored)",{agentId:e.agentId,cloudId:o,err:String(m)})))}else a.downstream?.isAlive()&&this.armIdleTimer(e,o,a)}}case"session/cancel":{let o=i.sessionId;if(!o)throw new _("IPC_BAD_REQUEST","session/cancel: missing sessionId");let a=e.sessions.get(o);if(e.hasSessionQueue(o)){let c=e.getSessionQueue(o);c.size>0&&(P.info("session/cancel: draining queued tasks",{agentId:e.agentId,cloudId:o,queuedCount:c.size}),c.dispose(new _("AGENT_PROTOCOL_ERROR",`cancelled by session/cancel on ${o}`)))}return a?.downstream?.isAlive()&&a.acpSessionId&&await a.downstream.sessionCancel({sessionId:a.acpSessionId}),{ok:!0}}default:throw new _("IPC_BAD_REQUEST",`session method not supported: ${n}`)}}async ensureRuntime(e,n){let r=e.sessions.get(n);if(r)return r;let s={modelToken:e.deployType==="cloud"?await this.requestSessionToken(e.agentId,n):"",tokenGeneratedAt:Date.now(),lastActiveAt:Date.now(),loadingSession:!1,replySeq:0};return e.sessions.set(n,s),await this.persistSessionMapping(e),s}async requestSessionToken(e,n){let r={sessionId:n,_meta:{cozeAgentId:e}};try{let i=await this.sendRequest(Ze.GEN_MODEL_TOKEN,r,sS);if(!i?.modelToken)throw new _("MODEL_TOKEN_GEN_FAILED",`cloud returned empty modelToken (agentId=${e}, cloudSessionId=${n})`);return i.modelToken}catch(i){throw i instanceof _&&i.code==="MODEL_TOKEN_GEN_FAILED"?i:new _("MODEL_TOKEN_GEN_FAILED",i instanceof Error?i.message:String(i),{cause:i})}}async ensureDownstream(e,n,r){if(ui(r),r.downstream?.isAlive())return;if(!this.sessionSpawner)throw new _("AGENT_SPAWN_FAILED","sessionSpawner not wired (cannot spawn per-session downstream)");let i=3,s=3e4,o=r.spawnFailCount??0,a=r.spawnFailedAt??0;if(o>=i&&Date.now()-a<s)throw new _("AGENT_SPAWN_FAILED",`agent ${e.agentId} session ${n} spawn failed ${o} times in a row; please check framework binary / network and retry after ${Math.ceil((s-(Date.now()-a))/1e3)}s`);let c;try{c=await this.sessionSpawner(e,r.modelToken,n,this.currentCozeEnv,this.currentMockScenario)}catch(l){throw r.spawnFailCount=o+1,r.spawnFailedAt=Date.now(),r.spawnFailCount>=i&&r.acpSessionId&&(P.warn("clearing stale acpSessionId after repeated spawn failures",{agentId:e.agentId,cloudId:n,staleAcpId:r.acpSessionId}),r.acpSessionId=void 0),l}if(r.spawnFailCount=0,r.spawnFailedAt=void 0,r.downstream=c,this.attachRuntimeHooks(e,n,r),r.acpSessionId){r.loadingSession=!0;try{await c.sessionLoad({sessionId:r.acpSessionId,cwd:e.workspace}),P.info("session restored via session/load",{agentId:e.agentId,cloudId:n,acpId:r.acpSessionId})}catch(l){P.warn("session/load failed, fallback to session/new",{agentId:e.agentId,cloudId:n,acpId:r.acpSessionId,err:String(l)}),r.acpSessionId=void 0;let d=await c.sessionNew({cwd:e.workspace});r.acpSessionId=d.sessionId,await this.persistSessionMapping(e)}finally{r.loadingSession=!1}}else{let l=await c.sessionNew({cwd:e.workspace});r.acpSessionId=l.sessionId,await this.persistSessionMapping(e)}c.afterSessionEstablished&&r.acpSessionId&&await c.afterSessionEstablished(r.acpSessionId)}armIdleTimer(e,n,r){if(ui(r),this.isRuntimeBusy(e,r)){P.debug("skip idle timer: runtime busy (in-flight turn / pending permission)",{agentId:e.agentId,cloudId:n});return}r.idleTimer=setTimeout(()=>{if(r.idleTimer=void 0,this.isRuntimeBusy(e,r)){P.info("idle reaper fired but runtime busy, re-arming",{agentId:e.agentId,cloudId:n}),this.armIdleTimer(e,n,r);return}P.info("session runtime idle timeout, killing downstream",{agentId:e.agentId,cloudId:n});let i=r.downstream;r.downstream=void 0,r.acpSessionId&&e.activeTriggers.delete(r.acpSessionId),i&&i.stop("idle timeout").catch(s=>P.warn("idle stop failed (ignored)",{agentId:e.agentId,cloudId:n,err:String(s)}))},this.sessionIdleTimeoutMs),r.idleTimer.unref?.()}isRuntimeBusy(e,n){if(n.acpSessionId&&e.activeTriggers.has(n.acpSessionId))return!0;let r=n.downstream;if(!r)return!1;for(let i of this.pendingUpstream.values())if(i.downstream===r)return!0;return!1}async sendAgentFileUpdate(e,n,r,i){let s={cozeAgentId:e.agentId,cozeReplySeqID:++n.replySeq};if(n.acpSessionId){let o=e.activeTriggers.get(n.acpSessionId);o&&(s.cozeTriggerMsgId=o);let a=e.activeGroupIds.get(n.acpSessionId);a&&(s.cozeGroupId=a)}await this.upstream.send(nr("session/update",{sessionId:r,update:i,_meta:s}))}async synthesizePromptReply(e,n,r,i,s,o){let a={cozeAgentId:e.agentId,cozeReplySeqID:++n.replySeq};return s&&(a.cozeTriggerMsgId=s),o&&(a.cozeGroupId=o),await this.upstream.send(nr("session/update",{sessionId:r,update:{sessionUpdate:"agent_message_chunk",content:{type:"text",text:i}},_meta:a})).catch(c=>P.warn("synthesizePromptReply update send failed (ignored)",{err:String(c)})),{stopReason:"end_turn"}}forwardUpdate(e,n){let r=n.sessionId,i=this.reverseSessionId(e,r);if(!i){P.debug("drop update for unknown session",{agentId:e.agentId,acpId:r});return}let s=e.sessions.get(i);if(!s){P.debug("drop update: runtime gone",{agentId:e.agentId,cloudId:i});return}if(cS(n)){P.debug("drop codex metadata-warn chunk",{agentId:e.agentId,acpId:r});return}let o={cozeAgentId:e.agentId,cozeReplySeqID:++s.replySeq},a=e.activeTriggers.get(r);a&&(o.cozeTriggerMsgId=a);let c=e.activeGroupIds.get(r);c&&(o.cozeGroupId=c),this.upstream.send(nr("session/update",{...n,sessionId:i,_meta:o})).catch(l=>P.warn("forward update failed",{agentId:e.agentId,err:String(l)}))}handleAgentRequest(e,n,r){if(r.method==="session/request_permission"){this.forwardPermissionRequest(e,n,r);return}if(r.method==="fs/write_text_file"||r.method==="fs/read_text_file"){this.handleFsRpcRequest(e,n,r);return}P.warn("unhandled agent request,returning method_not_found",{agentId:e.agentId,method:r.method}),n.respondAgentRequestError(r.id,{code:U.METHOD_NOT_FOUND,message:`method not handled by Bridge: ${r.method}`})}async handleFsRpcRequest(e,n,r){try{let i=e.workspace;if(r.method==="fs/write_text_file"){let s=r.params??{},o=await lh(s,i);n.respondAgentRequest(r.id,o)}else{let s=r.params??{},o=await dh(s,i);n.respondAgentRequest(r.id,o)}}catch(i){P.warn("fs rpc handler failed",{agentId:e.agentId,method:r.method,err:String(i)}),n.respondAgentRequestError(r.id,di(i))}}clearPendingPermissionFor(e){if(e.method!=="session/request_permission"||!e.cloudSessionId)return;let n=this.agents.get(e.agentId)?.sessions.get(e.cloudSessionId);n&&(n.pendingPermission=void 0)}forwardPermissionRequest(e,n,r){let i=this.upstreamIds.next("session/request_permission"),s=r.params??{},a=s.sessionId,c=a?e.activeTriggers.get(a):void 0,l={cozeAgentId:e.agentId};c&&(l.cozeTriggerMsgId=c);let d=a?e.activeGroupIds.get(a):void 0;d&&(l.cozeGroupId=d);let p=a?this.reverseSessionId(e,a):void 0,m=p?e.sessions.get(p):void 0;m&&(m.pendingPermission={downstream:n,agentRequestId:r.id,upstreamId:i});let u={...s,...p?{sessionId:p}:{},_meta:l};this.pendingUpstream.set(i,{agentRequestId:r.id,agentId:e.agentId,downstream:n,method:r.method,cloudSessionId:p}),P.info("forward permission_request \u2192 upstream",{agentId:e.agentId,upstreamId:i,acpSessionId:a,cloudSessionId:p,toolCallId:s.toolCall?.toolCallId,options:s.options?.map(h=>({optionId:h.optionId,kind:h.kind,name:h.name}))}),this.upstream.send(ci(i,"session/request_permission",u)).catch(h=>{this.pendingUpstream.delete(i),P.error("forward permission request failed",{agentId:e.agentId,err:String(h)}),n.respondAgentRequestError(r.id,{code:U.INTERNAL_ERROR,message:`upstream send failed: ${String(h)}`})})}handleUpstreamResponse(e){if(e.id===null)return;let n=this.lookupPending(this.pendingUpstream,e.id,"upstream");if(n){this.pendingUpstream.delete(n.key);let i=n.value;this.clearPendingPermissionFor(i),e.error?(P.info("upstream \u2192 permission response (error)",{agentId:i.agentId,upstreamId:e.id,method:i.method,error:e.error}),i.downstream.respondAgentRequestError(i.agentRequestId,e.error)):(i.method==="session/request_permission"&&aS(e.result,i),P.info("upstream \u2192 permission response (result)",{agentId:i.agentId,upstreamId:e.id,method:i.method,result:e.result}),i.downstream.respondAgentRequest(i.agentRequestId,e.result));return}let r=this.lookupPending(this.pendingBridge,e.id,"bridge");if(r){this.pendingBridge.delete(r.key),clearTimeout(r.value.timer),e.error?r.value.reject(new Ws(e.error)):r.value.resolve(e.result);return}P.debug("orphan upstream response (no pending)",{id:e.id})}lookupPending(e,n,r){let i=e.get(n);if(i)return{value:i,key:n};if(typeof n=="number"){let s=String(n),o=e.get(s);if(o)return P.warn(`${r} id type mismatch: number received but Bridge expected string`,{rawId:n,normalizedId:s}),{value:o,key:s}}}sendRequest(e,n,r=tS){let i=this.upstreamIds.next(e);return new Promise((s,o)=>{let a=setTimeout(()=>{this.pendingBridge.delete(i),o(new _("AGENT_TIMEOUT",`${e} timed out after ${r}ms`))},r);this.pendingBridge.set(i,{method:e,resolve:s,reject:o,timer:a}),this.upstream.send(ci(i,e,n)).catch(c=>{let l=this.pendingBridge.get(i);l&&(clearTimeout(l.timer),this.pendingBridge.delete(i)),o(c)})})}async persistSessionMapping(e){if(this.paths)try{let n=new Map;for(let[r,i]of e.sessions){let s={modelToken:i.modelToken,tokenGeneratedAt:i.tokenGeneratedAt};i.acpSessionId&&(s.acpSessionId=i.acpSessionId),n.set(r,s)}await Or(e.agentId,n,this.paths)}catch(n){P.warn("persist session mapping failed",{agentId:e.agentId,err:String(n)})}}reverseSessionId(e,n){for(let[r,i]of e.sessions.entries())if(i.acpSessionId===n)return r}sendError(e,n,r){return this.upstream.send(Ht(e,{code:n,message:r,data:{bridgeVersion:tr}}))}};function oS(){return eS(16).toString("hex")}function aS(t,e){if(!t||typeof t!="object"){P.warn("permission response: result not an object (suspicious)",{agentId:e.agentId,result:t});return}let n=t;if("kind"in n&&!("outcome"in n)){P.warn('permission response: top-level "kind" field (D66 historical bug shape)',{agentId:e.agentId,result:t});return}let r=n.outcome;if(!r||typeof r!="object"){P.warn("permission response: missing or non-object outcome field",{agentId:e.agentId,result:t});return}let s=r.outcome;(typeof s!="string"||s!=="selected"&&s!=="cancelled")&&P.warn("permission response: unknown outcome discriminant",{agentId:e.agentId,outcomeValue:s,result:t})}function cS(t){let e=t.update;if(e?.sessionUpdate!=="agent_message_chunk")return!1;let n=e.content;if(!n||typeof n!="object")return!1;let r=n;return r.type!=="text"||typeof r.text!="string"?!1:r.text.startsWith("Model metadata for `")}L();le();import{randomBytes as lS}from"node:crypto";import{chmod as dS,mkdir as uS,writeFile as mh}from"node:fs/promises";import{createServer as fS}from"node:http";import{dirname as hS}from"node:path";var pS=1e6,Rc=b("ipc"),so=class{server=null;port=0;token="";routes;paths;constructor(e){this.routes=new Map(e.routes.map(n=>[`${n.method} ${n.path}`,n])),this.paths=e.paths??F()}async start(){this.token=lS(32).toString("hex");let e=fS((r,i)=>{this.dispatch(r,i)});this.server=e,await new Promise((r,i)=>{e.once("error",i),e.listen(0,"127.0.0.1",()=>r())});let n=e.address();if(!n||typeof n!="object")throw new Error("failed to obtain IPC port");return this.port=n.port,await this.persistAuthFiles(),Rc.info("IPC listening",{port:this.port}),{port:this.port,token:this.token}}async stop(){let e=this.server;e&&(await new Promise((n,r)=>{e.close(i=>i?r(i):n())}),this.server=null)}async persistAuthFiles(){await uS(hS(this.paths.portFile),{recursive:!0}),await mh(this.paths.portFile,String(this.port),"utf8"),await mh(this.paths.tokenFile,this.token,{encoding:"utf8",mode:384});try{await dS(this.paths.tokenFile,384)}catch(e){Rc.warn("chmod token file failed (non-POSIX?)",{err:String(e)})}}async dispatch(e,n){if(e.headers.authorization!==`Bearer ${this.token}`){gi(n,401,{error:"unauthorized"});return}let i=`${e.method} ${(e.url??"").split("?")[0]}`,s=this.routes.get(i);if(!s){gi(n,404,{error:"not found"});return}let o=null;if(e.method==="POST")try{o=await gS(e)}catch(a){gi(n,400,{error:"invalid json",detail:String(a)});return}try{let a=await s.handler(o,e);gi(n,200,a??{ok:!0})}catch(a){Rc.error("IPC handler failed",{key:i,err:String(a)}),gi(n,500,{error:a instanceof Error?a.message:String(a)})}}};function gi(t,e,n){t.statusCode=e,t.setHeader("content-type","application/json"),t.end(JSON.stringify(n))}async function gS(t){let e=[],n=0;for await(let i of t){let s=i;if(n+=s.length,n>pS)throw new Error("body too large");e.push(s)}let r=Buffer.concat(e).toString("utf8");return r?JSON.parse(r):null}var Rh="";function bS(t=""){let n=`${Date.now()}`,r=Rh||(Rh=PS(t)),i=Math.random().toString(16).slice(-6);return"02"+n+r+i}function AS(){return 1e4*Date.now()+Math.floor(1e4*Math.random())}function xS(t){return(Array(8).join("0")+parseInt(t,10).toString(2)).slice(-8)}function kh(t){return(Array(4).join("0")+parseInt(t,2).toString(16)).slice(-4)}function OS(t){let e=t.split(/\./).map(i=>xS(i)),n=[];return n[0]=kh(e[0]+e[1]),n[1]=kh(e[2]+e[3]),["0000","0000","0000","0000","0000","ffff",n[0],n[1]].join("")}function PS(t){let e=/(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)(\.(25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}/.test(t),n=/(([0-9a-fA-F]{1,4}:){7,7}[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,7}:|([0-9a-fA-F]{1,4}:){1,6}:[0-9a-fA-F]{1,4}|([0-9a-fA-F]{1,4}:){1,5}(:[0-9a-fA-F]{1,4}){1,2}|([0-9a-fA-F]{1,4}:){1,4}(:[0-9a-fA-F]{1,4}){1,3}|([0-9a-fA-F]{1,4}:){1,3}(:[0-9a-fA-F]{1,4}){1,4}|([0-9a-fA-F]{1,4}:){1,2}(:[0-9a-fA-F]{1,4}){1,5}|[0-9a-fA-F]{1,4}:((:[0-9a-fA-F]{1,4}){1,6})|:((:[0-9a-fA-F]{1,4}){1,7}|:)|fe80:(:[0-9a-fA-F]{0,4}){0,4}%[0-9a-zA-Z]{1,}|::(ffff(:0{1,4}){0,1}:){0,1}((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])|([0-9a-fA-F]{1,4}:){1,4}:((25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9])\.){3,3}(25[0-5]|(2[0-4]|1{0,1}[0-9]){0,1}[0-9]))/.test(t);return e?OS(t):n?CS(t):"00000000000000000000000000000000"}function CS(t){let e="",n=[],r=0,i=0,s=!0,o="0000";if(t.indexOf("::")>-1){let a=t.split("::");for(let l=0;l<a.length;l++){let d=a[l];if(d.indexOf(":")>0){let p=d.split(":");s&&(r=p.length),i+=p.length;for(let m=0;m<p.length;m++)if(p[m].length!==4){let h=o.substring(0,4-p[m].length).concat(p[m]);n.push(h)}else n.push(p[m]);s=!1}else{if(d.length!==4){let m=o.substring(0,4-d.length).concat(d);n.push(m)}else n.push(d);s&&(r+=1),i+=1,s=!1}}let c="";for(let l=0;l<8-i;l++)c=c.concat(o);for(let l=0;l<n.length;l++)l===r&&(e=e.concat(c)),e=e.concat(n[l]);return e}{let a=t.split(":");for(let c=0;c<a.length;c++){let l=a[c];if(a[c].length!==4){let p=o.substring(0,4-a[c].length).concat(l);e=e.concat(p)}else e=e.concat(l)}return e}}function DS(t,e){let n=t.key;n!==void 0&&(ye(e,10),En(e,n));let r=t.value;r!==void 0&&(ye(e,18),En(e,r))}function NS(t){let e={};e:for(;!zh(t);){let n=ke(t);switch(n>>>3){case 0:break e;case 1:e.key=_n(t,ke(t));break;case 2:e.value=_n(t,ke(t));break;default:Mh(t,7&n)}}if(e.key===void 0)throw new Error("Missing required field: key");if(e.value===void 0)throw new Error("Missing required field: value");return e}function Fh(t){let e=Uh();return LS(t,e),$S(e)}function LS(t,e){let n=t.SeqID;n!==void 0&&(ye(e,8),wi(e,n));let r=t.LogID;r!==void 0&&(ye(e,16),wi(e,r));let i=t.service;i!==void 0&&(ye(e,24),wi(e,Cc(i)));let s=t.method;s!==void 0&&(ye(e,32),wi(e,Cc(s)));let o=t.headers;if(o!==void 0)for(let h of o){ye(e,42);let g=Uh();DS(h,g),ye(e,g.limit),jS(e,g),US(g)}let a=t.payloadEncoding;a!==void 0&&(ye(e,50),En(e,a));let c=t.payloadType;c!==void 0&&(ye(e,58),En(e,c));let l=t.payload;l!==void 0&&(ye(e,66),ye(e,l.length),HS(e,l));let d=t.LogIDNew;d!==void 0&&(ye(e,74),En(e,d));let p=t.serverTiming;p!==void 0&&(ye(e,82),En(e,p));let m=t.msgID;m!==void 0&&(ye(e,90),En(e,m));let u=t.frameType;u!==void 0&&(ye(e,96),wi(e,Cc(u)))}function FS(t){return MS(zS(t))}function MS(t){let e={};e:for(;!zh(t);){let n=ke(t);switch(n>>>3){case 0:break e;case 1:e.SeqID=Ah(t,!0);break;case 2:e.LogID=Ah(t,!0);break;case 3:e.service=ke(t);break;case 4:e.method=ke(t);break;case 5:{let r=BS(t);(e.headers||(e.headers=[])).push(NS(t)),t.limit=r;break}case 6:e.payloadEncoding=_n(t,ke(t));break;case 7:e.payloadType=_n(t,ke(t));break;case 8:e.payload=GS(t,ke(t));break;case 9:e.LogIDNew=_n(t,ke(t));break;case 10:e.serverTiming=_n(t,ke(t));break;case 11:e.msgID=_n(t,ke(t));break;case 12:e.frameType=ke(t);break;default:Mh(t,7&n)}}if(e.SeqID===void 0)throw new Error("Missing required field: SeqID");if(e.LogID===void 0)throw new Error("Missing required field: LogID");if(e.service===void 0)throw new Error("Missing required field: service");if(e.method===void 0)throw new Error("Missing required field: method");return e}function BS(t){let e=ke(t),n=t.limit;return t.limit=t.offset+e,n}function Mh(t,e){switch(e){case 0:for(;128&ze(t););break;case 2:Dc(t,ke(t));break;case 5:Dc(t,4);break;case 1:Dc(t,8);break;default:throw new Error("Unimplemented type: "+e)}}function Cc(t){return t|=0,{low:t,high:t>>31,unsigned:t>=0}}var Bh=[];function Uh(){let t=Bh.pop();return t?(t.offset=t.limit=0,t):{bytes:new Uint8Array(64),offset:0,limit:0}}function US(t){Bh.push(t)}function zS(t){return{bytes:t,offset:0,limit:t.length}}function $S(t){let e=t.bytes,n=t.limit;return e.length===n?e:e.subarray(0,n)}function Dc(t,e){if(t.offset+e>t.limit)throw new Error("Skip past limit");t.offset+=e}function zh(t){return t.offset>=t.limit}function Ei(t,e){let n=t.bytes,r=t.offset,i=t.limit,s=r+e;if(s>n.length){let o=new Uint8Array(2*s);o.set(n),t.bytes=o}return t.offset=s,s>i&&(t.limit=s),r}function Xc(t,e){let n=t.offset;if(n+e>t.limit)throw new Error("Read past limit");return t.offset+=e,n}function GS(t,e){let n=Xc(t,e);return t.bytes.subarray(n,n+e)}function HS(t,e){let n=Ei(t,e.length);t.bytes.set(e,n)}function _n(t,e){let n=Xc(t,e),r=String.fromCharCode,i=t.bytes,s="\uFFFD",o="";for(let a=0;a<e;a++){let c=i[a+n],l,d,p,m;(128&c)===0?o+=r(c):(224&c)===192?a+1>=e?o+=s:(l=i[a+n+1],(192&l)!==128?o+=s:(m=(31&c)<<6|63&l,m<128?o+=s:(o+=r(m),a++))):(240&c)==224?a+2>=e?o+=s:(l=i[a+n+1],d=i[a+n+2],((l|d<<8)&49344)!==32896?o+=s:(m=(15&c)<<12|(63&l)<<6|63&d,m<2048||m>=55296&&m<=57343?o+=s:(o+=r(m),a+=2))):(248&c)==240?a+3>=e?o+=s:(l=i[a+n+1],d=i[a+n+2],p=i[a+n+3],((l|d<<8|p<<16)&12632256)!==8421504?o+=s:(m=(7&c)<<18|(63&l)<<12|(63&d)<<6|63&p,m<65536||m>1114111?o+=s:(m-=65536,o+=r((m>>10)+55296,(1023&m)+56320),a+=3))):o+=s}return o}function En(t,e){let n=e.length,r=0;for(let o=0;o<n;o++){let a=e.charCodeAt(o);a>=55296&&a<=56319&&o+1<n&&(a=(a<<10)+e.charCodeAt(++o)-56613888),r+=a<128?1:a<2048?2:a<65536?3:4}ye(t,r);let i=Ei(t,r),s=t.bytes;for(let o=0;o<n;o++){let a=e.charCodeAt(o);a>=55296&&a<=56319&&o+1<n&&(a=(a<<10)+e.charCodeAt(++o)-56613888),a<128?s[i++]=a:(a<2048?s[i++]=a>>6&31|192:(a<65536?s[i++]=a>>12&15|224:(s[i++]=a>>18&7|240,s[i++]=a>>12&63|128),s[i++]=a>>6&63|128),s[i++]=63&a|128)}}function jS(t,e){let n=Ei(t,e.limit),r=t.bytes,i=e.bytes;for(let s=0,o=e.limit;s<o;s++)r[s+n]=i[s]}function ze(t){return t.bytes[Xc(t,1)]}function bh(t,e){let n=Ei(t,1);t.bytes[n]=e}function ke(t){let e=0,n=0,r;do r=ze(t),e<32&&(n|=(127&r)<<e),e+=7;while(128&r);return n}function ye(t,e){for(e>>>=0;e>=128;)bh(t,127&e|128),e>>>=7;bh(t,e)}function Ah(t,e){let n=0,r=0,i=0,s;return s=ze(t),n=127&s,128&s&&(s=ze(t),n|=(127&s)<<7,128&s&&(s=ze(t),n|=(127&s)<<14,128&s&&(s=ze(t),n|=(127&s)<<21,128&s&&(s=ze(t),r=127&s,128&s&&(s=ze(t),r|=(127&s)<<7,128&s&&(s=ze(t),r|=(127&s)<<14,128&s&&(s=ze(t),r|=(127&s)<<21,128&s&&(s=ze(t),i=127&s,128&s&&(s=ze(t),i|=(127&s)<<7))))))))),{low:n|r<<28,high:r>>>4|i<<24,unsigned:e}}function wi(t,e){let n=e.low>>>0,r=(e.low>>>28|e.high<<4)>>>0,i=e.high>>>24,s=i===0?r===0?n<16384?n<128?1:2:n<2097152?3:4:r<16384?r<128?5:6:r<2097152?7:8:i<128?9:10,o=Ei(t,s),a=t.bytes;switch(s){case 10:a[o+9]=i>>>7&1;case 9:a[o+8]=s!==9?128|i:127&i;case 8:a[o+7]=s!==8?r>>>21|128:r>>>21&127;case 7:a[o+6]=s!==7?r>>>14|128:r>>>14&127;case 6:a[o+5]=s!==6?r>>>7|128:r>>>7&127;case 5:a[o+4]=s!==5?128|r:127&r;case 4:a[o+3]=s!==4?n>>>21|128:n>>>21&127;case 3:a[o+2]=s!==3?n>>>14|128:n>>>14&127;case 2:a[o+1]=s!==2?n>>>7|128:n>>>7&127;case 1:a[o]=s!==1?128|n:127&n}}function WS(t){return FS(t)}function xh(t){return Fh(t)}var Oh=65536,qS="\0\0\0\0\0\0\0\0",ar=Oh*Oh,$h=ar*ar,Ph=$h/2,Vt=String.prototype.charCodeAt,Ne=class t{constructor(e,n,r){this.isLong=!0,this.low=0|e,this.high=0|n,this.unsigned=!!r}static isLong(e){return e&&e.isLong===!0}static fromBits(e,n,r){return new t(e,n,r)}static fromBytes(e,n,r){return r?t.fromBytesLE(e,n):t.fromBytesBE(e,n)}static fromBytesLE(e,n){return new t(e[0]|e[1]<<8|e[2]<<16|e[3]<<24,e[4]|e[5]<<8|e[6]<<16|e[7]<<24,n)}static fromBytesBE(e,n){return new t(e[4]<<24|e[5]<<16|e[6]<<8|e[7],e[0]<<24|e[1]<<16|e[2]<<8|e[3],n)}static fromHash(e){return e===qS?Ch:new t((Vt.call(e,0)|Vt.call(e,1)<<8|Vt.call(e,2)<<16|Vt.call(e,3)<<24)>>>0,(Vt.call(e,4)|Vt.call(e,5)<<8|Vt.call(e,6)<<16|Vt.call(e,7)<<24)>>>0,!0)}toHash(){return String.fromCharCode(255&this.low,this.low>>>8&255,this.low>>>16&255,this.low>>>24,255&this.high,this.high>>>8&255,this.high>>>16&255,this.high>>>24)}static fromNumber(e,n=!0){if(isNaN(e))return n?VS:Ch;if(n){if(e>=$h)return ZS}else{if(e<=-Ph)return KS;if(e+1>=Ph)return JS}return t.fromBits(e%ar|0,e/ar|0,n)}toNumber(){return this.unsigned?(this.high>>>0)*ar+(this.low>>>0):this.high*ar+(this.low>>>0)}isZero(){return this.high===0&&this.low===0}add(e){t.isLong(e)||(e=t.fromNumber(e));let n=this.high>>>16,r=65535&this.high,i=this.low>>>16,s=65535&this.low,o=e.high>>>16,a=65535&e.high,c=e.low>>>16,l=65535&e.low,d=0,p=0,m=0,u=0;return u+=s+l,m+=u>>>16,u&=65535,m+=i+c,p+=m>>>16,m&=65535,p+=r+a,d+=p>>>16,p&=65535,d+=n+o,d&=65535,t.fromBits(m<<16|u,d<<16|p,this.unsigned)}equals(e){return t.isLong(e)||(e=t.fromNumber(e)),this.unsigned!==e.unsigned&&this.high>>>31===1&&e.high>>>31===1?!1:this.high===e.high&&this.low===e.low}addOne(){return this.low===-1&&this.high===-1?t.fromBits(0,0,this.unsigned):this.low===-1?t.fromBits(0,this.high+1,this.unsigned):t.fromBits(this.low+1,this.high,this.unsigned)}toBytes(e){return e?this.toBytesLE():this.toBytesBE()}toBytesLE(){let e=this.high,n=this.low;return[255&n,n>>>8&255,n>>>16&255,n>>>24,255&e,e>>>8&255,e>>>16&255,e>>>24]}toBytesBE(){let e=this.high,n=this.low;return[e>>>24,e>>>16&255,e>>>8&255,255&e,n>>>24,n>>>16&255,n>>>8&255,255&n]}},Ch=new Ne(0,0,!1),VS=new Ne(0,0,!0),JS=Ne.fromBits(-1,2147483647,!1),ZS=Ne.fromBits(-1,-1,!0),KS=Ne.fromBits(0,-2147483648,!1),yn=(function(t){return t[t.NATIVE_ERROR=5001]="NATIVE_ERROR",t[t.CONNECTING_ERROR=5002]="CONNECTING_ERROR",t[t.MAX_RETRIES_ERROR=5003]="MAX_RETRIES_ERROR",t[t.MESSAGE_ERROR=5004]="MESSAGE_ERROR",t[t.OPEN_ERROR=5005]="OPEN_ERROR",t})({}),Sn=class{constructor(e){this.type=e,this.target=null}},Lc=class extends Sn{constructor(e,n){super(e),this.message=n&&n.message||null}},Fc=class extends Sn{constructor(e,n){super(e),this.error=n&&n.error||null,this.colno=n&&n.colno||0,this.filename=n&&n.filename||"",this.lineno=n&&n.lineno||0,this.message=n&&n.message||"",this.code=n&&n.code||5001}},Mc=class extends Sn{constructor(e,n){super(e),this.code=n&&n.code||0,this.reason=n&&n.reason||"",this.wasClean=n&&n.wasClean||!1,this.willReconnect=n&&n.willReconnect||!1}},Bc=class extends Sn{constructor(e,n){super(e),this.data=n&&n.data||null}},Uc=class extends Bc{constructor(e,n){super(e),this.data=n&&n.data||null,this.message=n&&n.message||null}},zc=class extends Sn{constructor(e,n){super(e),this.data=n&&n.data||null}};function Xe(t,{message:e,code:n,error:r}){return new Fc(t,{message:e,code:n,error:r})}function dt(t,{code:e,reason:n,wasClean:r,willReconnect:i}){return new Mc(t,{code:e,reason:n,wasClean:r,willReconnect:i})}function XS(t,{data:e,message:n}){return new Uc(t,{data:e,message:n})}function YS(t,{data:e}){return new zc(t,{data:e})}function Dh(t,{message:e}){return new Lc(t,{message:e})}var oo=class{constructor(e,n){this.endpoints=e,this.maxRetries=n,this.currentIndex=0,this.currentEndpointTriesCount=0}resetEndpointConfig(){this.currentIndex=0,this.currentEndpointTriesCount=0}resetTries(){this.currentEndpointTriesCount=0}getCurrentEndpoint(){return this.endpoints[this.currentIndex]}getCurrentEndpointTriesCount(){return this.currentEndpointTriesCount}checkReachMaxTries(){return this.currentIndex>=this.endpoints.length||this.currentIndex===this.endpoints.length-1&&this.currentEndpointTriesCount===this.maxRetries}checkCurrentEndpointReachedMaxRetries(){return this.currentIndex==this.endpoints.length?!0:this.currentEndpointTriesCount>this.maxRetries}replaceBackupEndpointAndUpdateCount(){return this.currentEndpointTriesCount=1,this.currentIndex++,this.endpoints[this.currentIndex]}getCurrentEndpointAndUpdateCount(){return this.currentEndpointTriesCount++,this.getCurrentEndpoint()}},lr=(typeof globalThis<"u"&&globalThis.constructor.name==="Window"||typeof window<"u"&&window.constructor.name==="Window")&&typeof document<"u",vn=typeof globalThis<"u"&&(globalThis.constructor.name==="Object"||globalThis.constructor.name==="DedicatedWorkerGlobalScope")&&typeof tt<"u",Si=(typeof globalThis<"u"&&globalThis.constructor.name==="Object"||typeof globalThis>"u"||typeof globalThis<"u"&&!!globalThis.WeixinJSBridge)&&typeof wx<"u",yi=typeof globalThis<"u"&&(globalThis.constructor.name==="DedicatedWorkerGlobalScope"||globalThis.constructor.name==="SharedWorkerGlobalScope"||globalThis.constructor.name==="ServiceWorkerGlobalScope")&&typeof self<"u",QS=typeof globalThis<"u"&&globalThis.constructor.name==="Object"&&typeof global<"u"&&global.constructor.name==="Object"&&typeof process<"u"&&!!process.version,_i=class{constructor(){this._listeners={}}emit(e,...n){let r=this._listeners[e];if(r)r.slice().forEach(i=>i.fn.apply(i.ctx,n));else if(e==="error"&&!this.onerror){let i=n.length&&n[0];if(i instanceof Error)throw i;let s=new Error("Unhandled error."+(i?" ("+i.message+")":""));throw s.context=i,i}return this}off(e,n){if(e===void 0)this._listeners={};else if(n===void 0)this._listeners[e]=null;else{let r=this._listeners[e];if(r)for(let i=0;i<r.length;)r[i].fn===n?r.splice(i,1):++i}return this}on(e,n,r){return(this._listeners[e]||(this._listeners[e]=[])).push({fn:n,ctx:r||this}),this}},$c=class extends _i{_formatErrorMessage(e){return e.errMsg||e.errNo?`message: ${e.errMsg||""} code: ${e.errNo||""}`.trim():JSON.stringify(e)}constructor(e,n,r){super(),this._socket=null,Si&&wx.connectSocket&&(this._socket=wx.connectSocket({url:e,protocols:n,header:r,fail:this._createSocketFailHandler.bind(this),success:this._createSocketSuccessHandler.bind(this)})),vn&&tt.connectSocket&&(this._socket=tt.connectSocket({url:e,protocols:n,header:r,fail:this._createSocketFailHandler.bind(this),success:this._createSocketSuccessHandler.bind(this)}))}_createSocketSuccessHandler(){Promise.resolve().then(()=>{this._addWsListeners()})}_createSocketFailHandler(e){Promise.resolve().then(()=>{let n=Xe("error",{message:this._formatErrorMessage(e)});this.emit("error",n);let r=dt("close",{reason:this._formatErrorMessage(e)});this.emit("close",r)})}_addWsListeners(){this._socket.onOpen(e=>{this.emit("open",YS("open",{...e,data:e.errMsg||""}))}),this._socket.onClose(e=>{this.emit("close",dt("close",{...e}))}),this._socket.onMessage(e=>{this.emit("message",XS("message",{...e}))}),this._socket.onError(e=>{this.emit("error",Xe("error",{...e,message:e.errMsg||""}))})}send(e){if(e instanceof Uint8Array){let n=e.buffer.slice(e.byteOffset,e.byteLength+e.byteOffset);this._socket&&this._socket.send({data:n,fail:r=>{this.emit("error",Xe("error",{message:this._formatErrorMessage(r)}))}})}else this._socket&&this._socket.send({data:e,fail:n=>{this.emit("error",Xe("error",{message:this._formatErrorMessage(n)}))}})}close(e,n){this._socket&&this._socket.close({code:e,reason:n})}addEventListener(e,n){this.on(e,n)}removeEventListener(e,n){this.off(e,n)}get readyState(){return this._socket.readyState}get binaryType(){return this._socket.binaryType}set binaryType(e){}get url(){return this._socket.url}get protocol(){return this._socket.protocol}get extensions(){return this._socket.extensions}get bufferedAmount(){return 0}};function e0(t,e){if(e)return new e(t.url,t.protocol);if(Si||vn)return new $c(t.url,t.protocol,t.headers);if((lr||yi)&&typeof WebSocket<"u"&&WebSocket)return new WebSocket(t.url,t.protocols)}function t0(t){return!!(t||Si&&wx.connectSocket||vn&&tt.connectSocket||(lr||yi)&&typeof WebSocket<"u"&&WebSocket)}function Nh(t,e,n){let r=-1;async function i(s){return s<=r?Promise.reject(new Error("next() called multiple times in process")):(r=s,s===n.length?Promise.resolve():n[s].bind(t)(e,i.bind(null,s+1)))}i(0)}function Gh(t){let e=0,n=0;for(let r=0;r<t.length;++r)n=t.charCodeAt(r),n<128?e+=1:n<2048?e+=2:(64512&n)===55296&&(64512&t.charCodeAt(r+1))===56320?(++r,e+=4):e+=3;return e}function Hh(t,e,n){if(n-e<1)return"";let r="";for(let i=e;i<n;){let s=t[i++];if(s<=127)r+=String.fromCharCode(s);else if(s>=192&&s<224)r+=String.fromCharCode((31&s)<<6|63&t[i++]);else if(s>=224&&s<240)r+=String.fromCharCode((15&s)<<12|(63&t[i++])<<6|63&t[i++]);else if(s>=240){let o=((7&s)<<18|(63&t[i++])<<12|(63&t[i++])<<6|63&t[i++])-65536;r+=String.fromCharCode(55296+(o>>10)),r+=String.fromCharCode(56320+(1023&o))}}return r}function Gc(t,e,n){let r=n,i,s;for(let o=0;o<t.length;++o)i=t.charCodeAt(o),i<128?e[n++]=i:i<2048?(e[n++]=i>>6|192,e[n++]=63&i|128):(64512&i)===55296&&(64512&(s=t.charCodeAt(o+1)))===56320?(i=65536+((1023&i)<<10)+(1023&s),++o,e[n++]=i>>18|240,e[n++]=i>>12&63|128,e[n++]=i>>6&63|128,e[n++]=63&i|128):(e[n++]=i>>12|224,e[n++]=i>>6&63|128,e[n++]=63&i|128);return n-r}async function jh(t){if(typeof t=="string"){let e=new Uint8Array(Gh(t));return Gc(t,e,0),e}return t instanceof ArrayBuffer?new Uint8Array(t):new Uint8Array(t.buffer,t.byteOffset,t.byteLength)}function n0(t){try{return typeof t!="string"&&(t instanceof ArrayBuffer||t.buffer&&t.buffer instanceof ArrayBuffer)||typeof t!="string"?"":(JSON.parse(t),"application/json")}catch{return typeof t=="string"?"text/plain;charset=utf-8":""}}var r0=(t,e)=>{switch(t){case"boe":case"ppe":return{[`x-use-${t}`]:1,"x-tt-env":e};default:return{}}},Hc=class{constructor(e){this.maxLossCount=e,this.count=0}addCount(){this.count++}checkReachMaxCount(){return this.count>=this.maxLossCount}resetCounter(e=0){this.maxLossCount=e,this.count=0}};async function i0(t){return new Promise(e=>{if(!lr)return e("unknown reason");try{let n=document.createElement("script");window.frontierJSONP=r=>{document.body.removeChild(n),window.frontierJSONP=void 0,e(r&&r.msg||"unknown reason")},n.type="text/javascript",n.src=t.replace(/^ws/,"http")+"&jscallback=frontierJSONP";try{document.body.appendChild(n)}catch{document.body.removeChild(n)}}catch{window.frontierJSONP=void 0,e("unknown reason")}})}function Jt(t,e,n){return!!t?.find(r=>r.key===e&&r.value===n)}function cr(t,e){return t?.find(n=>n.key===e)?.value}var Nc=null;async function s0(){return Nc||(Nc=Promise.resolve().then(()=>(Th(),Ih))),Nc}var jc=class extends _i{constructor(e,n){super(),this._dbName=e,this._keyPath=n,this._qosDB=void 0,this._initPromise=null}async openDB(){await this._init()}async _init(){if(!this._qosDB){if(this._initPromise)return this._initPromise;try{let e=this._dbName,n=this._keyPath;this._initPromise=(async()=>{let{openDB:r}=await s0();this._qosDB=await r(`frontier_${e}`,1,{upgrade(i){i.createObjectStore(e,{keyPath:n})}})})(),await this._initPromise}catch(e){console.log(e)}finally{this._initPromise=null}}}async get(e){try{return await this._init(),this._qosDB?.get(this._dbName,e)}catch(n){console.log(n)}}async set(e,n){return await this._init(),this._qosDB?.put(this._dbName,e)}async del(e){try{return await this._init(),this._qosDB?.delete(this._dbName,e)}catch(n){console.log(n)}}async clear(){try{return await this._init(),this._qosDB?.clear(this._dbName)}catch(e){console.log(e)}}async keys(){return await this._init(),this._qosDB?.getAllKeys(this._dbName)}async getAll(){return await this._init(),this._qosDB?.getAll(this._dbName)}async closeDB(){try{this._qosDB?.close(),this._qosDB=void 0}catch(e){console.log(e)}}get isReady(){try{return!!this._qosDB}catch(e){return console.log(e),!1}}},Wc=class{constructor(e,n){this._DBName=e,this._pathKey=n,this._qosDB=localStorage}async openDB(){}get _prefix(){return`frontier_${this._DBName}`}async get(e){let n=this._qosDB.getItem(this._prefix);return JSON.parse(n||"{}")[e]}async set(e,n){let r=this._qosDB.getItem(this._prefix),i=JSON.parse(r||"{}");return i[n||e[this._pathKey]]=e,this._qosDB.setItem(this._prefix,JSON.stringify(i)),n||e[this._pathKey]}async del(e){let n=this._qosDB.getItem(this._prefix),r=JSON.parse(n||"{}");return r[e]=void 0,this._qosDB.setItem(this._prefix,JSON.stringify(r))}async clear(){return this._qosDB.clear()}async keys(){let e=this._qosDB.getItem(this._prefix),n=JSON.parse(e||"{}");return Object.keys(n)}async getAll(){let e=this._qosDB.getItem(this._prefix),n=JSON.parse(e||"{}");return Object.values(n)}closeDB(){return Promise.resolve()}get isReady(){return!!this._qosDB}},qc=class{constructor(e,n){this._DBName=e,this._pathKey=n,this._qosDB=vn?tt:Si?wx:null}async openDB(){}get _prefix(){return`frontier_${this._DBName}`}async get(e){let n=this._qosDB.getStorageSync(this._prefix);return JSON.parse(n||"{}")[e]}async set(e,n){let r=this._qosDB.getStorageSync(this._prefix),i=JSON.parse(r||"{}");return i[n||e[this._pathKey]]=e,this._qosDB.setStorageSync(this._prefix,JSON.stringify(i)),n||e[this._pathKey]}async del(e){let n=this._qosDB.getStorageSync(this._prefix),r=JSON.parse(n||"{}");return r[e]=void 0,this._qosDB.setStorageSync(this._prefix,JSON.stringify(r))}async clear(){return this._qosDB.clearStorageSync()}async keys(){let e=this._qosDB.getStorageInfoSync(this._prefix),n=JSON.parse(e||"{}");return Object.keys(n)}async getAll(){let e=this._qosDB.getStorageInfoSync(this._prefix),n=JSON.parse(e||"{}");return Object.values(n)}closeDB(){return Promise.resolve()}get isReady(){return!!this._qosDB}};function Wh(t,e){if(vn||vn)return new qc(t,e);if((lr||yi)&&typeof indexedDB<"u")return new jc(t,e);if((lr||yi)&&typeof localStorage<"u")return new Wc(t,e);throw new Error("init QoSDB failed")}var Vc=class{constructor(){this._intervalTimeoutId=null,this._interval=36e5,this._qosDB=Wh("qos","message_id")}async _intervalFlush(){clearInterval(this._intervalTimeoutId),this._intervalTimeoutId=setInterval(()=>{this.flushExpired()},this._interval)}async openDB(){await this._qosDB.openDB().then(()=>{this._intervalFlush()})}async flushExpired(){(await this._qosDB?.getAll()||[]).filter(({timestamp:r})=>r<Date.now()).forEach(r=>{this._qosDB?.del(r.message_id)})}async del(e){return this._qosDB?.del(e)}async set(e,n){return this._qosDB?.set({message_id:e,timestamp:n})}async get(e){return this._qosDB?.get(e)}async closeDB(){clearInterval(this._intervalTimeoutId),await this._qosDB?.closeDB()}get isReady(){return this._qosDB?.isReady}};function Yc(t){let e=!!this._options.enableQoS;if(!e)return{enabled:e,isQoSMessage:!1,isQoSAck:!1,isAckCleanupMessage:!1,ackMsgIds:[]};let n=Jt(t.message.headers,"x_frontier_qos","2"),r=n&&Jt(t.message.headers,"x_frontier_qos_ack","1"),i=n&&Jt(t.message.headers,"x_frontier_is_ack","1"),s=i?cr(t.message.headers,"x_frontier_ack_msgid")?.split(",").filter(Boolean)||[]:[];return{enabled:e,isQoSMessage:n,isQoSAck:r,isAckCleanupMessage:i,ackMsgIds:s}}async function qh(){return this._QoSManager||(this._QoSManager=new Vc),this._QoSManager.isReady||await this._QoSManager.openDB(),this._QoSManager}async function o0(t,e){let{enableAutoAck:n}=this._options,r=Jt(t.message.headers,"need_ack","1"),i=Jt(t.message.headers,"is_ack","1"),s=Yc.call(this,t);if(n&&r){let{SeqID:o,LogID:a,service:c,LogIDNew:l,method:d}=t.message;this._sendAck({SeqID:o,LogID:a,LogIDNew:l,service:c,method:d,headers:[{key:"is_ack",value:"1"},{key:"ack_id",value:l||""},{key:"ack_code",value:"0"}]})}i&&!s.isQoSAck&&this._dispatchAckMessageEvent(t),e()}async function a0(t,e){this._debug("received",t.message),e()}async function c0(t,e){let n=WS(await jh(t.data));try{if(n.payload instanceof Uint8Array){let r=this._options.payloadEncoding instanceof Object?{force:!!this._options.payloadEncoding.force,encoding:this._options.payloadEncoding.encoding?this._options.payloadEncoding.encoding.replace(/\s/g,"").toLowerCase():""}:{force:!1,encoding:this._options.payloadEncoding?this._options.payloadEncoding.replace(/\s/g,"").toLowerCase():""},i=n.payloadEncoding?n.payloadEncoding.replace(/\s/g,"").toLowerCase():"",s=this._options.payloadType instanceof Object?{force:!!this._options.payloadType.force,type:this._options.payloadType.type?this._options.payloadType.type.replace(/\s/g,"").toLowerCase():""}:{force:!1,type:this._options.payloadType?this._options.payloadType.replace(/\s/g,"").toLowerCase():""},o=n.payloadType?n.payloadType.replace(/\s/g,"").toLowerCase():"",a=s.force?s.type:o||s.type,c=r.force?r.encoding:i||r.encoding,l=["text/plain;charset=utf-8","application/json","application/json;charset=utf-8","string"],d=["none_none","binary"];this._options.enableTransformTextPayload&&l.includes(a)&&(!c||d.includes(c))?n.textPayload=Hh(n.payload,0,n.payload.byteLength):n.textPayload=""}else n.textPayload=""}catch(r){n.textPayload="",console.log(r)}t.message=n,e()}function l0(t,e,n){let r=n||8192,i=r>>>1,s=null,o=r;return function(a){if(a<1||a>i)return t(a);o+a>r&&(s=t(r),o=0);let c=e.call(s,o,o+=a);return 7&o&&(o=(7|o)+1),c}}var d0=4294967295;function u0(t,e,n){if(n>d0)throw new Error("integer too large");let r=3;for(;r>=0;){let i=255&n;Zc(i,t,e+r),n>>>=8,r--}return e+4}function f0(t,e){let n=0,r=e,i=e+4;for(;r<i;){let{value:s,offset:o}=Jc(t,r);r=o,n=n<<8>>>0,n+=s}return{value:n,offset:i}}function h0(t,e,n){return t?t.length<40?Gc(t,e,n)+n:e.utf8Write?e.utf8Write(t,n)+n:e.write?e.write(t,n)+n:Gc(t,e,n)+n:n}function p0(t,e){let n=new Ne(t[e+4]<<24|t[e+5]<<16|t[e+6]<<8|t[e+7],t[e+0]<<24|t[e+1]<<16|t[e+2]<<8|t[e+3],!0);return e+=8,{value:n,offset:e+8}}function g0(t,e,n){let r=t.low,i=t.high;return e[n]=i>>>24,e[n+1]=i>>>16&255,e[n+2]=i>>>8&255,e[n+3]=255&i,e[n+4]=r>>>24,e[n+5]=r>>>16&255,e[n+6]=r>>>8&255,e[n+7]=255&r,n+=8,n}function Jc(t,e){return t.readUInt8?{value:t.readUInt8(e),offset:e+1}:{value:255&t[e],offset:e+1}}function Zc(t,e,n){return e.writeUint8?e.writeUint8(t,n):e[n]=255&t,n+1}var m0=function(t){return new Uint8Array(t)},w0=typeof Buffer<"u"?Buffer.allocUnsafe:l0(m0,Uint8Array.prototype.subarray),y0=16,Qc=32;function _0(t){let e=0,n={};for(let r=0;r<t.length;r++)n[t[r].cursor_name]=Gh(t[r].cursor_name),e+=14+n[t[r].cursor_name];return[e,n]}function Lh(t,e,n){let[r,i]=_0(t),s=w0(r),o=0;return t.forEach(a=>{console.log("cursor.service",a,a.service),o=Zc(0,s,o),console.log("header",o),o=u0(s,o,a.service||0),console.log("service",o),o=Zc(i[a.cursor_name],s,o),console.log("service-name",o),o=h0(a.cursor_name,s,o),console.log("name",o),o=g0(Ne.fromNumber(a.cursor||e),s,o),console.log("curvalue",o)}),{frameType:Qc,headers:[{key:"cursor_file_name",value:n}],payload:s}}function E0(t){let e=0,n=[];for(;e<t.byteLength;){let{offset:r}=Jc(t,e);e=r;let i={cursor_name:"",cursor:0,service:0},{value:s,offset:o}=f0(t,e);i.service=s,e=o;let{value:a,offset:c}=Jc(t,e);e=c,i.cursor_name=Hh(t,e,e+a),e+=a;let{value:l,offset:d}=p0(t,e);i.cursor=l.toNumber(),e=d,n.push(i)}return n}function S0(){return{frameType:Qc,headers:[{key:"cursor_file_name",value:"FILE_NOT_EXIST"}],payload:void 0}}var Kc=class{constructor(e,n,r){this._cursorNameSpace=e,this._cursorFileName=n,this._messageStrategy=r,this._qosDB=Wh(this._cursorNameSpace,"cursor_name")}async openDB(){await this._qosDB.openDB()}async getCursors(){if(!this._qosDB.isReady)return;let e=this._messageStrategy,n=await this._qosDB.getAll();switch(console.log("allCursorValues",n),e){case"ALL":return n&&n.length?Lh(n,0,this._cursorFileName):void 0;case"INSTANT":return;case"CONTINUE":return n&&n.length?Lh(n,0,this._cursorFileName):S0()}}async set(e,n,r){return console.log("setdb",e,n,r),this._qosDB.set({cursor_name:e,cursor:n,service:r})}async setCursors(e){let n=E0(e);for(let r of n)console.log("setcursor",n),await this._qosDB.set(r)}async get(e){return(await this._qosDB.get(e))?.cursor}async closeDB(){await this._qosDB.closeDB()}updateCursorFileName(e){this._cursorFileName=e}get isReady(){return this._qosDB.isReady}},v0="__x_msg_qos__";async function Vh(t){if(!this._options.enableQoS)return null;let{aID:e,fpID:n,messageStrategy:r}=this._options,i=t||v0;try{return this._cursorManager?t&&this._cursorManager.updateCursorFileName(t):this._cursorManager=new Kc(`${n}_${e}_${i}`,i,r),this._cursorManager.isReady||await this._cursorManager.openDB(),this._cursorManager}catch{return null}}async function I0(t,e){let n=Jt(t.message.headers,"code","-1"),r=Jt(t.message.headers,"is_ack","1"),i=cr(t.message.headers,"x_frontier_msgid"),s=Number(cr(t.message.headers,"x_frontier_ttl"))||0,o=Yc.call(this,t),a=Jt(t.message.headers,"x-msg-qos","2"),c=cr(t.message.headers,"x-msg-cursor_name"),l=Number(cr(t.message.headers,"x-msg-cursor_value"));if(o.isQoSAck)return e();let d=o.isQoSMessage?await qh.call(this):null;if(t.message.service>0&&r&&!n||t.message.service>0){if(i&&o.isQoSMessage&&d)return await d.get(i)||(this._dispatchMessageEvent(t),await d.set(i,Date.now()+s)),e();if(a){let p=await Vh.call(this);if(!p)return this._dispatchMessageEvent(t),e();let m=await p.get(c)??-1;if(m<l)this._dispatchMessageEvent(t),p.set(c,l,t.message.service);else throw new Error(`recevied message cursor ${l} larger than local cursor ${m}`);return e()}return this._dispatchMessageEvent(t),e()}}async function T0(t,e){let n=Yc.call(this,t);if(!n.isQoSMessage)return e();let r=await qh.call(this);if(n.isAckCleanupMessage&&n.ackMsgIds.length)for(let i of n.ackMsgIds)await r.del(i);e()}async function R0(t,e){let n=t.message.frameType===y0,r=t.message.frameType===Qc;if(!n&&!r)return e();let i=cr(t.message.headers,"cursor_file_name");if(!i)return e();let s=await Vh.call(this,i);if(!s)return e();if(n){let o=await s.getCursors(),a={frameType:o?.frameType,SeqID:Ne.fromNumber(this._seqId++),LogID:Ne.fromNumber(this._options.logIDGenerator()),service:9e3,method:5,headers:o?.headers,payload:o?.payload},c=Fh(a);this._ws&&this._ws.readyState&&this._ws.send(c)}if(r){let o=t.message.payload;o&&s.setCursors(o)}}var k0=async function(t,e){this._isInit=!1,clearTimeout(this._connectionTimeoutId),e()},b0=async function(t,e){let n=this._endpointManager?.getCurrentEndpoint();this._debug(`open ${n}`),e()},A0=async function(t,e){if(!this._ws||this._ws.readyState!==this.OPEN)return e();let{pingInterval:n}=this._options;this._endpointManager?.resetEndpointConfig();for(let i=0;i<this._messageQueue.length;i++){let s=this._messageQueue[i];if(this._ws.readyState===this.OPEN&&s!==null)this._ws&&this._ws.send(s),this._messageQueue[i]=null;else break}this._messageQueue=this._messageQueue.filter(i=>!!i),this._pingPongTimeoutId=setTimeout(()=>this._ping(),n),this._dispatchOpenEvent(t),this._isBrowser&&this._ws&&(this._ws.binaryType=this._binaryType);let r=this._endpointManager?.getCurrentEndpoint();this._debug(`open ${r} success`),e()},ao=class extends _i{constructor(e){super(),this._miniNavigatorOnline=!0,this._isBrowser=lr,this._isNode=QS,this._isMiniTT=vn,this._isMiniWX=Si,this._isWorker=yi,this._messageQueue=[],this._endpointManager=null,this._readyClosed=!1,this._binaryType="arraybuffer",this._connectLock=!1,this._connectionTimeoutId=null,this._reconnectTimeoutId=null,this._pingPongTimeoutId=null,this._seqId=0,this._isInit=!1,this._url="",this._QoSManager=null,this._cursorManager=null,this._pingLossCounter=null,this._protocols="pbbp2",this.CLOSED=3,this.CONNECTING=0,this.OPEN=1,this.CLOSING=2,this._onOpen=s=>{try{Nh(this,s,[k0,A0,b0])}catch(o){let a=Xe("error",{message:o.message,code:yn.OPEN_ERROR,error:o});this._dispatchErrorEvent(a)}},this._onMessage=async s=>{let{pingInterval:o,pingFrequency:a}=this._options;if((s.data==="hi"&&a==="always"||a==="auto")&&(this._clearPingTimer(),this.emit("ping_once_success","success"),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),o)),s.data!=="hi")try{Nh(this,s,[c0,o0,T0,R0,I0,a0])}catch(c){let l=Xe("error",{message:c.message,code:yn.MESSAGE_ERROR,error:c});this._dispatchErrorEvent(l)}},this._onError=s=>{let o=this._endpointManager?.checkReachMaxTries(),a=this._endpointManager?.getCurrentEndpoint();if(o&&!s.message){let c=`connect ${a} fail, max retries reached`;this._dispatchErrorEvent(Xe("error",{message:c,code:yn.MAX_RETRIES_ERROR,error:s}));return}this._ws&&this._ws.readyState===this.OPEN&&this._disconnect(),this._dispatchErrorEvent(Xe("error",{message:s.message,code:yn.NATIVE_ERROR,error:s}))},this._onClose=async s=>{this._clearTimer(),this._clearPingTimer(),this._removeWsListeners(),this._ws=null,this._connectLock=!1;let o=this._endpointManager?.checkReachMaxTries();if(!o&&this._navigatorOnline()&&!this._readyClosed){let a=this._endpointManager?.getCurrentEndpoint(),c=this._options.reconnectInterceptor(s.code,s.reason);this._dispatchCloseEvent(dt("close",{code:1006,reason:s.reason||`connecting failed, unknown reason, hostname: ${a}`,willReconnect:c})),c&&this._connect();return}if(s.code!==1e3&&this._readyClosed){this._dispatchCloseEvent(dt("close",{code:1e3,reason:"bye"})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}if(s.code!==1e3&&o){let a=this._endpointManager?.getCurrentEndpoint(),c=s.reason;c||(c=await i0(this._url)),c=`connecting failed, ${c}, hostname: ${a}, max retries reached`,this._dispatchCloseEvent(dt("close",{code:s.code,reason:c}));let l=`connect ${a} fail, max retries reached`;this._dispatchErrorEvent(Xe("error",{message:l,code:yn.MAX_RETRIES_ERROR})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}if(s.code!==1e3&&!s.reason){let a=this._endpointManager?.getCurrentEndpoint();this._dispatchCloseEvent(dt("close",{code:s.code,reason:`connecting failed, unknown reason, hostname: ${a}`})),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter();return}this._dispatchCloseEvent(s),this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter()},this.onclose=null,this.onerror=null,this.onmessage=null,this.onopen=null,this.onStartReconnect=null,this.onReceiveAck=null,this.onStopImmediatelyReconnect=null,this._handleOnLine=this._handleOnLine.bind(this),this._handleOffLine=this._handleOffLine.bind(this),this._handlePageHide=this._handlePageHide.bind(this),this._handlePageShow=this._handlePageShow.bind(this),this._options={url:"",automaticOpen:!0,initReconnectInterval:1e3,maxReconnectInterval:1e4,reconnectIntervalGrowFactor:2,timeoutInterval:5e3,maxRetries:5,debug:!1,maxMessageQueueLength:1/0,service:0,logIDGenerator:AS,headers:void 0,payloadEncoding:"",payloadType:"",fpID:"",deviceID:"",accessKey:"",ttwID:"",bddID:"",aID:"",disableAutoReconnect:!1,customParams:{},pingInterval:15e3,pingTimeoutInterval:4e3,pingFrequency:"auto",pingLossCount:2,enableTransformTextPayload:!1,logIDNewConfig:{enableAutoGenerateLogIDNew:!1,userIp:""},miniProgramParams:{customHttpHeader:{}},enableAutoAck:!1,reconnectInterceptor:()=>!0,enableQoS:!1,QoSLevel:2,messageStrategy:"CONTINUE",env:{xTTEnv:"",xUseEnv:""},listenNetworkChanged:!0};let{url:n,ws:r}=e,i=Array.isArray(n)?n:typeof n=="string"?[n]:[];if(!i||i.length===0)throw new Error("please provide valid url");if(!t0(r))throw new Error("please provide ws params, WebSocket constructor is undefined");Object.assign(this._options,e),this._endpointManager=new oo(i,this._options.maxRetries),this._pingLossCounter=new Hc(this._options.pingLossCount),this._options.automaticOpen&&(this._isInit=!0,this._connect()),this._options.listenNetworkChanged&&(this._isMiniTT||this._isMiniWX?this._onPageNetWorkChange():this._isBrowser&&this._initGlobalEventListener())}_handleOnLine(){this._options.disableAutoReconnect||this._readyClosed||this._handleReconnect()}_handleOffLine(){this._destroyWebSocket();let e=Dh("reconnect",{message:"stop immediately reconnect"});this.onStopImmediatelyReconnect&&this.onStopImmediatelyReconnect(e)}_initGlobalEventListener(){this._isBrowser&&window.addEventListener("online",this._handleOnLine),this._isBrowser&&window.addEventListener("offline",this._handleOffLine),this._isBrowser&&window.addEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.addEventListener("pageshow",this._handlePageShow)}_dropGlobalEventListener(){this._isBrowser&&window.removeEventListener("online",this._handleOnLine),this._isBrowser&&window.removeEventListener("offline",this._handleOffLine),this._isBrowser&&window.removeEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.removeEventListener("pageshow",this._handlePageShow)}_handlePageHide(e){e.persisted||(this._isBrowser&&window.removeEventListener("pagehide",this._handlePageHide),this._isBrowser&&window.removeEventListener("pageshow",this._handlePageShow),this.close()),this._isBrowser&&window.removeEventListener("online",this._handleOnLine),this._isBrowser&&window.removeEventListener("offline",this._handleOffLine)}_handlePageShow(e){e.persisted&&(this._navigatorOnline()&&(!this._ws||this._ws.readyState!==this.OPEN||this._ws.readyState!==this.CONNECTING)&&this._handleOnLine(),this._isBrowser&&window.addEventListener("online",this._handleOnLine),this._isBrowser&&window.addEventListener("offline",this._handleOffLine))}async _generateUrl(e){let{fpID:n,deviceID:r,bddID:i,ttwID:s,accessKey:o,aID:a,customParams:c={},enableAutoAck:l,enableQoS:d,QoSLevel:p,env:m}=this._options,u,h,g;this._isBrowser||this._isMiniWX||this._isMiniTT?(u=location&&location.protocol=="https:"?"wss://":"ws://",h=e.replace(/((^ws)|(^http))((?:[s]*:\/\/))/,""),g=/^wss(.*:\/\/)/.test(e)?e:`${u}${h}`):(u="wss://",h=e.replace(/(^http)((?:[s]*:\/\/))/,""),g=/(^ws)((?:[s]*:\/\/))/.test(h)?h:`${u}${h}`);let w=i?"bd_did":s?"ttwid":"device_id",S=i||s||r;if(!S||!w)throw new Error("please provide bddID, deviceID or ttwID");let v=typeof c=="function"?await c():c,f=m?r0(m.xUseEnv,m.xTTEnv):{},y=Object.assign({device_platform:"web",version_code:"fws_1.0.0",access_key:o,fpid:n,aid:a,[w]:S,xsack:l?1:0,xaack:l?1:0,xsqos:d?1:0,qos_level:d?p:void 0,qos_sdk_version:2,...f},v),E=Object.keys(y).reduce((T,R)=>y[R]!==void 0?`${T}${T?"&":"?"}${R}=${y[R]}`:T,"");return`${g}/ws/v2${E}`}async _connect(){if(!(this._connectLock||this._readyClosed)){this._connectLock=!0;try{let e=this._endpointManager?.checkCurrentEndpointReachedMaxRetries(),{timeoutInterval:n}=this._options;if(e){let i=this._endpointManager?.getCurrentEndpoint(),s=this._endpointManager?.replaceBackupEndpointAndUpdateCount(),o=this._endpointManager?.getCurrentEndpointTriesCount();if(s){let a=`connect ${i} timeout, max retries reached, will use backup endpoint ${s} to retry`,c=Xe("error",{message:a,code:yn.MAX_RETRIES_ERROR});this._debug(a),this._dispatchErrorEvent(c),this._url=await this._generateUrl(s),this._debug(`connect ${s} ${o} times`),this._removeWsListeners()}else{let a=`connect ${i} timeout, max retries reached`;this._debug(a),this._dispatchErrorEvent(Xe("error",{message:a,code:yn.MAX_RETRIES_ERROR}));return}}else{let i=this._endpointManager?.getCurrentEndpointAndUpdateCount(),s=this._endpointManager?.getCurrentEndpointTriesCount();this._url=await this._generateUrl(i||""),this._debug(`connect ${i} ${s} times`),this._removeWsListeners()}if(this._isInit)this._isInit=!1;else{let i=Dh("reconnect",{message:"start"});this.onStartReconnect&&this.onStartReconnect(i)}let r=this._endpointManager?.getCurrentEndpointTriesCount()||0;r>1&&await this._wait(r-1),this._debug(`connecting url: ${this._url} protocols: ${this._protocols}`),this._ws=e0({url:this._url,protocols:[this._protocols],headers:this._options.miniProgramParams.customHttpHeader},this._options.ws),(this._isBrowser||this._isWorker)&&this._ws&&(this._ws.binaryType=this._binaryType),this._addWsListeners(),this._connectionTimeoutId=setTimeout(this._onTimeout.bind(this),n)}catch(e){throw this._connectLock=!1,e}}}_clearTimer(){clearTimeout(this._connectionTimeoutId),this._connectionTimeoutId=null}_clearPingTimer(){clearTimeout(this._pingPongTimeoutId),clearTimeout(this._reconnectTimeoutId),this._pingPongTimeoutId=null,this._reconnectTimeoutId=null}_debug(...e){this._options.debug&&console.log.apply(console,["FRONTIER>",...e])}_getIntervalValue(e){let{initReconnectInterval:n,maxReconnectInterval:r,reconnectIntervalGrowFactor:i}=this._options,s=n*Math.pow(i,e-1);return s>r?r:s}_ping(){if(this._ws&&this._ws.readyState===this.CONNECTING){this._clearPingTimer(),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),this._options.pingInterval);return}if(!this._ws||this._ws.readyState!==this.OPEN)return void this._handleReconnect();this._ws&&this._ws.send("hi"),this._reconnectTimeoutId=setTimeout(this._handleReconnectTimeout.bind(this),this._options.pingTimeoutInterval)}_handleReconnectTimeout(){this._pingLossCounter?.addCount(),this.emit("ping_once_timeout","timeout"),this._pingLossCounter?.checkReachMaxCount()?this._handleReconnect():this._ping()}_navigatorOnline(){return this._isMiniTT||this._isMiniWX?this._miniNavigatorOnline:(this._isBrowser||this._isWorker)&&this._options.listenNetworkChanged?navigator.onLine:!0}_handleReconnect(){!this._navigatorOnline()||this._readyClosed||(this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(),this._ws?this._disconnect(1001,"going away, try reconnecting server",!0):this._connect())}_onPageNetWorkChange(){this._isMiniTT?tt.onNetworkStatusChange(({isConnected:e})=>{this._miniNavigatorOnline=e,e?this._handleOnLine():this._handleOffLine()}):this._isMiniWX&&wx.onNetworkStatusChange(({isConnected:e})=>{this._miniNavigatorOnline=e,e?this._handleOnLine():this._handleOffLine()})}_wait(e){return new Promise(n=>{setTimeout(n,this._getIntervalValue(e))})}_disconnect(e=1e3,n="",r=!1){this._ws&&this._destroyWebSocket(e,n,r)}_onTimeout(){let e=this._endpointManager?.getCurrentEndpoint();this._debug(`connect ${e} timeout`),this._disconnect(1001,"timeout, try reconnecting",!0)}_sendAck(e){let n=xh(e);this._ws&&this._ws.readyState===this.OPEN&&(this._ws&&this._ws.send(n),this._debug("send_ack",e))}_removeWsListeners(){this._ws&&(this._ws.removeEventListener("open",this._onOpen),this._ws.removeEventListener("close",this._onClose),this._ws.removeEventListener("message",this._onMessage),this._ws.removeEventListener("error",this._onError))}_addWsListeners(){this._ws&&(this._ws.addEventListener("open",this._onOpen),this._ws.addEventListener("close",this._onClose),this._ws.addEventListener("message",this._onMessage),this._ws.addEventListener("error",this._onError))}_wsInstanceClose(e=1e3,n=""){try{this._ws&&this._ws.close(e,n)}catch{}}_destroyWebSocket(e=1e3,n="",r=!1){if(this._clearPingTimer(),this._clearTimer(),this._removeWsListeners(),this._wsInstanceClose(1e3,n),this._connectLock=!1,r&&this._navigatorOnline()&&!this._readyClosed){if(this._endpointManager?.checkReachMaxTries()){let s=this._endpointManager?.getCurrentEndpoint();this._dispatchCloseEvent(dt("close",{code:1006,reason:`connect ${s} timeout, max retries reached`,wasClean:!0}))}else{let s=this._options.reconnectInterceptor(e,n);this._dispatchCloseEvent(dt("close",{code:e,reason:n,wasClean:!0,willReconnect:s})),s&&this._connect()}return}this._navigatorOnline()||this._readyClosed?this._dispatchCloseEvent(dt("close",{code:e,reason:"bye"})):this._dispatchCloseEvent(dt("close",{code:1006,reason:"going away, network offline"})),this._ws=null,this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter()}_dispatchOpenEvent(e){this.emit("open",e),this.onopen&&this.onopen(e)}_dispatchMessageEvent(e){this.emit("message",e),this.onmessage&&this.onmessage(e)}_dispatchAckMessageEvent(e){this.emit("ack",e),this.onReceiveAck&&this.onReceiveAck(e)}_dispatchErrorEvent(e){this.emit("error",e),this.onerror&&this.onerror(e)}_dispatchCloseEvent(e){this.emit("close",e),this.onclose&&this.onclose(e)}get binaryType(){return this._ws?this._ws.binaryType:this._binaryType}set binaryType(e){this._binaryType=e,this._ws&&(this._ws.binaryType=e)}get retryCount(){return this._endpointManager?.getCurrentEndpointTriesCount()||0}get bufferedAmount(){return this._messageQueue.reduce((n,r)=>(n+=r&&r.byteLength||0,n),0)+(this._ws?this._ws.bufferedAmount:0)}get extensions(){return this._ws?this._ws.extensions:""}get protocol(){return this._ws?this._ws.protocol:""}get readyState(){return this._ws?this._ws.readyState:this._options.automaticOpen?this.CONNECTING:this.CLOSED}get url(){return this._ws?this._ws.url:this._url}close(e=1e3,n){if(this._readyClosed=!0,this._clearTimer(),this._clearPingTimer(),this._dropGlobalEventListener(),this._QoSManager?.closeDB(),!this._ws)return void this._debug("close, ws instance not initialized");if(this._ws.readyState===this.CLOSED||this._ws.readyState===this.CLOSING)return void this._debug("close, ws already closed");this._destroyWebSocket(e,n)}async send(e,n){if(e==null)throw new Error("please provide a valid data, data must be a string or an arraybuffer");typeof e=="number"&&(e=JSON.stringify(e)),typeof e!="string"&&!(e instanceof ArrayBuffer)&&!(e.buffer&&e.buffer instanceof ArrayBuffer)&&(e=JSON.stringify(e));let r=await jh(e),i=n0(e),{method:s=0,service:o=this._options.service,logID:a=this._options.logIDGenerator(),headers:c=this._options.headers,payloadEncoding:l=this._options.payloadEncoding,payloadType:d=this._options.payloadType,logIDNew:p=this._options.logIDNewConfig.enableAutoGenerateLogIDNew?bS(this._options.logIDNewConfig.userIp):""}=n||{};if(!o)throw new Error("please provide a valid service");let m={SeqID:Ne.fromNumber(this._seqId++),LogID:Ne.fromNumber(a),service:o,method:s,headers:c,payloadEncoding:l instanceof Object?l.encoding?l.encoding:"":l,payloadType:d instanceof Object?d.type?d.type:i:d||i,payload:r,LogIDNew:p},u=xh(m);return this._ws&&this._ws.readyState===this.OPEN?(this._ws&&this._ws.send(u),this._debug("sent",m)):this._messageQueue.length<this._options.maxMessageQueueLength?(this._messageQueue.push(u),this._debug("enqueue",m)):(this._messageQueue.shift(),this._messageQueue.push(u)),{seqID:this._seqId,logID:a,logIDNew:p}}async reconnect(e){let{url:n}=e||{},r=Array.isArray(n)?n:typeof n=="string"?[n]:[];e&&Object.assign(this._options,e),r&&r.length?this._endpointManager=new oo(r,this._options.maxRetries):this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(this._options.pingLossCount),this._readyClosed=!1,this._ws&&this._ws.readyState!==this.CLOSED?this._disconnect(1e3,"manual reconnecting",!0):(this._isInit=!0,this._connect())}async connect(){this._connectLock||(this._endpointManager?.resetEndpointConfig(),this._pingLossCounter?.resetCounter(),this._readyClosed=!1,this._isInit=!0,this._connect())}addEventListener(e,n){this.on(e,n)}dispatchEvent(e){let{type:n}=e;this.emit(n,e)}removeEventListener(e,n){this.off(e,n)}pingOnce(){return new Promise((e,n)=>{this._clearPingTimer(),this._pingPongTimeoutId=setTimeout(this._ping.bind(this),this._options.pingInterval);let r=()=>{e("success"),this.off("ping_once_success",r),this.off("ping_once_timeout",i)},i=()=>{n("timeout"),this.off("ping_once_success",r),this.off("ping_once_timeout",i)};this.on("ping_once_success",r),this.on("ping_once_timeout",i),this._ping()})}};var Jv=ht(Gp(),1),Zv=ht(wo(),1),Kv=ht(fr(),1),Xv=ht(dl(),1),Yv=ht(hl(),1),Qv=ht(_l(),1),Xp=ht(So(),1),eI=ht(Kp(),1);var Yp=Xp.default;Te();L();var te=b("upstream.frontier"),eg="application/json",tg="none",nI=15e3;function rI(t){class e extends Yp{constructor(r){super(r,rf,{headers:t})}guardTeardown(){this.listenerCount("error")===0&&this.on("error",r=>te.warn("frontier ws error during teardown (handled, prevents daemon crash)",{err:r instanceof Error?r.message:String(r)}))}close(r,i){this.guardTeardown(),super.close(r,i)}terminate(){this.guardTeardown(),super.terminate()}send(r,...i){if(Ml("debug"))try{let s;typeof r=="string"?s=Buffer.from(r,"utf8"):r instanceof Buffer?s=r:r instanceof ArrayBuffer?s=new Uint8Array(r):ArrayBuffer.isView(r)?s=new Uint8Array(r.buffer,r.byteOffset,r.byteLength):s=new Uint8Array(0);let o=Buffer.from(s.slice(0,128)).toString("hex");te.debug("WS raw frame out",{bytes:s.byteLength,headHex:o})}catch(s){te.warn("WS raw frame dump failed",{err:String(s)})}super.send(r,...i)}}return e}var xi=class{constructor(e){this.opts=e}opts;fws=null;handler=null;connectHandlers=[];opened=!1;lastSendRefusedLogAt=0;sendRefusedSuppressed=0;openCount=0;async start(){if(this.fws){te.warn("start called on already-started FrontierUpstream; noop");return}let e={Authorization:`Bearer ${this.opts.privatecode}`,Origin:sf,...Qn(this.opts.ppeOverride)},n=rI(e),r=af(this.opts.urlOverride),i={url:r,ws:n,fpID:nf,aID:Gs,accessKey:this.opts.handshake.accessKey,deviceID:this.opts.handshake.deviceId,payloadType:{type:eg,force:!0},payloadEncoding:{encoding:tg,force:!0},enableTransformTextPayload:!0,enableQoS:!1,enableAutoAck:!1,automaticOpen:!1,maxRetries:Number.POSITIVE_INFINITY,debug:this.opts.debug??!1},s=new ao(i),o=!1,a=null,c,l,d=new Promise((u,h)=>{c=u,l=h}),p=u=>{o||(o=!0,a&&(clearTimeout(a),a=null),u?l(u):c())};s.onopen=()=>{this.opened=!0,this.openCount+=1;let u=this.openCount===1;te.info("frontier opened",{url:r,remoteDeviceId:this.opts.handshake.deviceId,initial:u,openCount:this.openCount}),u&&p();for(let h of this.connectHandlers)Promise.resolve(h({initial:u})).catch(g=>te.warn("onConnect handler threw (ignored)",{err:String(g)}))},s.onclose=u=>{this.opened=!1,te.info("frontier closed",{code:u.code,reason:u.reason,willReconnect:u.willReconnect})},s.onerror=u=>{te.warn("frontier error",{code:u.code,msg:u.message}),p(new _("UPSTREAM_DISCONNECTED",`frontier connect error before open: code=${u.code} msg=${u.message??""}`))},s.onmessage=u=>this.handleMessage(u),this.fws=s;let m=this.opts.openTimeoutMs??nI;a=setTimeout(()=>{p(new _("UPSTREAM_DISCONNECTED",`frontier ws open timeout after ${m}ms (handshake or upgrade slow)`))},m),await s.connect();try{await d}catch(u){try{s.close(1e3,"open failed")}catch(h){te.warn("fws close during start failure threw (ignored)",{err:String(h)})}throw this.fws=null,this.opened=!1,u}}async stop(e){let n=this.fws;if(n){this.fws=null,this.opened=!1;try{n.close(1e3,e??"bridge shutdown")}catch(r){te.warn("frontier close threw (ignored)",{err:String(r)})}}}async send(e){let n=this.fws,r=e.method;if(!n)throw te.warn("frontier send refused: upstream not started",{method:r}),new _("UPSTREAM_DISCONNECTED","frontier upstream not started");if(!this.isConnected()){let a=Date.now();throw a-this.lastSendRefusedLogAt>1e3?(te.warn("frontier send refused: ws not open",{method:r,opened:this.opened,readyState:n.readyState,...this.sendRefusedSuppressed>0?{suppressedSinceLast:this.sendRefusedSuppressed}:{}}),this.lastSendRefusedLogAt=a,this.sendRefusedSuppressed=0):this.sendRefusedSuppressed+=1,new _("UPSTREAM_DISCONNECTED",`frontier ws not open (opened=${this.opened}, readyState=${n.readyState}); refusing to silently buffer`)}this.injectAgentPatToken(e);let i=JSON.stringify(e),s=e;ng(s)||te.info("frontier frame out",{method:s.method,jsonrpcId:s.id,size:i.length});try{await n.send(i,{service:33555712,method:1,payloadType:eg,payloadEncoding:tg})}catch(a){throw te.warn("frontier frame send failed",{method:s.method,jsonrpcId:s.id,err:String(a)}),new _("UPSTREAM_DISCONNECTED",`frontier send failed: ${String(a)}`,{cause:a})}}onFrame(e){this.handler=e}onConnect(e){this.connectHandlers.push(e)}isConnected(){return this.opened&&this.fws?.readyState===1}injectAgentPatToken(e){let n=this.opts.getPatTokenForAgent;if(!n)return;let r=e.params?._meta;if(!r?.cozeAgentId)return;let i=n(r.cozeAgentId);i&&(r.cozePatToken=i)}handleMessage(e){let n=e.message?.service;if(n!==33555712){te.debug("drop non-adapter frontier frame",{service:n});return}let r=oI(e);if(!r){te.debug("frontier message without text payload, drop",{payloadType:e.message?.payloadType});return}if(!this.handler){te.debug("frame received but no onFrame handler",{size:r.length});return}let i;try{i=JSON.parse(r)}catch(o){te.warn("frontier message JSON parse failed",{err:String(o),head:r.slice(0,80)});return}let s=i;ng(s)||te.info("frontier frame in",{logid:sI(e.message?.LogID),logidNew:e.message?.LogIDNew,msgId:e.message?.msgID,jsonrpcId:s.id,method:s.method,body:iI(r)}),Promise.resolve(this.handler(i)).catch(o=>te.warn("frontier frame handler threw",{err:String(o)}))}};function ng(t){return t.method==="_agent/health"?!0:typeof t.id=="string"&&t.id.startsWith("agent.health_")}var rg=2e3;function iI(t){return t.length<=rg?t:`${t.slice(0,rg)}...<truncated, total ${t.length} chars>`}function sI(t){return t?t.high===0?String(t.low>>>0):`${t.high.toString(16)}${(t.low>>>0).toString(16).padStart(8,"0")}`:""}function oI(t){let e=t.message;if(e?.textPayload)return e.textPayload;let n=e?.payload;if(!n)return null;try{return Buffer.from(n).toString("utf8")}catch{return null}}L();var Sl=b("upstream.switchable"),Io=class{inner;handler=null;connectHandlers=[];constructor(e){this.inner=e}async swap(e,n){if(this.inner===e)return;Sl.info("swap upstream",{reason:n});let r=this.inner;if(this.inner=e,this.handler&&e.onFrame(this.handler),e.onConnect)for(let i of this.connectHandlers)e.onConnect(i);try{await e.start()}catch(i){throw Sl.error("swap target start failed, reverting",{err:String(i)}),this.inner=r,i}await r.stop(n??"swapped").catch(i=>Sl.warn("previous upstream stop threw (ignored)",{err:String(i)}))}current(){return this.inner}start(){return this.inner.start()}stop(e){return this.inner.stop(e)}send(e){return this.inner.send(e)}onFrame(e){this.handler=e,this.inner.onFrame(e)}onConnect(e){this.connectHandlers.push(e),this.inner.onConnect?.(e)}isConnected(){return this.inner.isConnected()}};L();var vl=b("upstream"),yr=class{handler=null;async start(){vl.info("NoopUpstream started (M1 skeleton; real Frontier wired in M4)")}async stop(e){vl.info("NoopUpstream stopped",{reason:e})}async send(e){vl.debug("NoopUpstream.send (dropped)",{method:"method"in e?e.method:void 0})}onFrame(e){this.handler=e}isConnected(){return!1}async injectFrame(e){this.handler&&await this.handler(e)}};Te();L();L();le();import{promises as Il}from"node:fs";import{dirname as aI}from"node:path";var cI=b("pat-token-store");async function To(t=F()){try{let n=(await Il.readFile(t.patTokenFile,"utf8")).trim();return n.length>0?n:null}catch(e){let n=e?.code;return n!=="ENOENT"&&cI.warn("read pat-token failed (treating as missing)",{path:t.patTokenFile,code:n,message:e.message}),null}}async function Oi(t,e=F()){if(!t)throw new Error("writePatToken: empty patToken");await Il.mkdir(aI(e.patTokenFile),{recursive:!0}),await Il.writeFile(e.patTokenFile,t,{encoding:"utf8",mode:384})}le();le();import{promises as Ro}from"node:fs";import{join as lI}from"node:path";function dI(t,e){return`#!/bin/sh
100
100
  exec ${JSON.stringify(e)} ${JSON.stringify(t)} "$@"
101
101
  `}function uI(t,e){return`@echo off\r
102
102
  "${e}" "${t}" %*\r
103
- `}async function ig(t,e=F()){let n=e.binDir;await To.mkdir(n,{recursive:!0});let r=lI(n,process.platform==="win32"?"coze-bridge.cmd":"coze-bridge"),i=process.execPath,s=process.platform==="win32"?uI(t,i):dI(t,i);return await To.readFile(r,"utf8").catch(()=>null)===s||(await To.writeFile(r,s,"utf8"),process.platform!=="win32"&&await To.chmod(r,493)),n}L();le();import{execSync as sg}from"node:child_process";import{readFileSync as og,unlinkSync as fI}from"node:fs";import{mkdir as hI,readFile as ag,unlink as cg,writeFile as pI}from"node:fs/promises";import{dirname as gI}from"node:path";function Ro(t){try{return process.kill(t,0),!0}catch(e){return e.code==="EPERM"}}var mI=b("single-instance"),ko=class{pidFile;acquired=!1;constructor(e={}){this.pidFile=e.pidFile??F().pidFile,e.processTitle&&(process.title=e.processTitle)}async acquire(){let e=await this.readExistingPid();return e!==null&&this.isAlive(e)?{kind:"already-running",pid:e}:(e!==null&&(mI.warn("removing stale pid file",{stalePid:e}),await cg(this.pidFile).catch(()=>{})),await hI(gI(this.pidFile),{recursive:!0}),await pI(this.pidFile,String(process.pid),"utf8"),this.acquired=!0,this.installCleanupHooks(),{kind:"acquired"})}async release(){if(this.acquired){try{(await ag(this.pidFile,"utf8")).trim()===String(process.pid)&&await cg(this.pidFile)}catch{}this.acquired=!1}}async readExistingPid(){try{let e=await ag(this.pidFile,"utf8"),n=Number.parseInt(e.trim(),10);return Number.isFinite(n)&&n>0?n:null}catch(e){if(e.code==="ENOENT")return null;throw e}}isAlive(e){return Ro(e)?this.matchesDaemonTitle(e):!1}matchesDaemonTitle(e){if(process.platform==="win32")return this.matchesDaemonTitleWindows(e);try{let n=og(`/proc/${e}/cmdline`,"utf8").replace(/\0/g," ");return!!(n.includes("coze-bridge-daemon")||n.includes("lib/index.js"))}catch{}try{let n=sg(`ps -o command= -p ${e}`,{stdio:["ignore","pipe","ignore"],timeout:1e3}).toString();return n.trim()?n.includes("coze-bridge-daemon")||n.includes("lib/index.js"):!1}catch{return!0}}matchesDaemonTitleWindows(e){try{let r=sg(`tasklist /FI "PID eq ${e}" /FO CSV /NH`,{stdio:["ignore","pipe","ignore"],timeout:2e3}).toString().trim();if(!r||/^(INFO|信息)[::]/.test(r))return!1;let i=r.split(",",1)[0]?.replace(/^"|"$/g,"").toLowerCase()??"";return i.includes("node")||i.includes("coze-bridge")}catch{return!0}}installCleanupHooks(){process.once("exit",()=>{if(this.acquired)try{og(this.pidFile,"utf8").trim()===String(process.pid)&&fI(this.pidFile)}catch{}})}};bo();L();var An=b("daemon.upstream-watchdog"),TI=12e4,RI=9e5,kI=3e4;function Il(t,e){let n=process.env[t];if(!n)return e;let r=Number(n);return Number.isFinite(r)&&r>0?r:e}var Ao=class{constructor(e){this.opts=e;this.softMs=e.softMs??Il("COZE_BRIDGE_UPSTREAM_WATCHDOG_SOFT_MS",TI),this.hardMs=e.hardMs??Il("COZE_BRIDGE_UPSTREAM_WATCHDOG_HARD_MS",RI),this.intervalMs=e.intervalMs??Il("COZE_BRIDGE_UPSTREAM_WATCHDOG_INTERVAL_MS",kI),this.now=e.now??Date.now}opts;softMs;hardMs;intervalMs;now;timer=null;downSince=null;forcedAt=null;forcing=!1;lastTickAt=null;start(){this.timer||(this.timer=setInterval(()=>this.tick(),this.intervalMs),this.timer.unref?.(),An.info("upstream watchdog started",{softMs:this.softMs,hardMs:this.hardMs,intervalMs:this.intervalMs}))}stop(){this.timer&&(clearInterval(this.timer),this.timer=null),this.downSince=null,this.forcedAt=null,this.lastTickAt=null}tick(){let e=this.now();if(this.lastTickAt!==null&&e-this.lastTickAt>this.intervalMs*3&&(this.downSince!==null&&An.warn("upstream watchdog: large tick gap (likely sleep/suspend), resetting downSince",{gapMs:e-this.lastTickAt}),this.downSince=null,this.forcedAt=null),this.lastTickAt=e,this.opts.isConnected()){this.downSince!==null&&An.info("upstream watchdog: reconnected, reset",{downMs:this.now()-this.downSince}),this.downSince=null,this.forcedAt=null;return}if(this.downSince===null){this.downSince=e,An.warn("upstream watchdog: disconnect detected, arming",{softMs:this.softMs,hardMs:this.hardMs});return}let n=e-this.downSince;if(n>=this.hardMs){An.error("upstream watchdog: disconnected too long, exiting for supervisor restart",{downMs:n,hardMs:this.hardMs}),this.opts.onFatal(n);return}n>=this.softMs&&this.shouldForceNow(e)&&(this.forcedAt=e,this.forcing=!0,An.warn("upstream watchdog: forcing reconnect",{downMs:n,softMs:this.softMs}),Promise.resolve().then(()=>this.opts.forceReconnect()).catch(r=>An.warn("upstream watchdog: forceReconnect error (ignored)",{err:String(r)})).finally(()=>{this.forcing=!1}))}shouldForceNow(e){return!(this.forcing||this.forcedAt!==null&&e-this.forcedAt<this.softMs)}};var A=b("daemon"),bI="coze-bridge-daemon";async function ug(){let t=F();process.env.COZE_BRIDGE_LOG_MODE!=="legacy"&&Ll({bridgeLogsDir:t.bridgeLogsDir,agentLogsDir:I=>be(I,t).logs,listAgentIds:()=>qi(t)});let e=new ko({processTitle:bI}),n=await e.acquire();if(n.kind==="already-running")throw new Error(`coze-bridge daemon already running (pid=${n.pid})`);let r=await no(),i=r??{};zi({pid:process.pid}),A.info(r?"loaded bridge config":"initialized bridge config");try{let I=new qt;i.frameworksCache=await I.detectAll(),A.info("refreshed frameworks_cache",{detected:Object.keys(i.frameworksCache)})}catch(I){A.warn("framework detection failed",{err:String(I)})}await or(i);let s=new vo(new yr),o=null,a=new ro({upstream:s,paths:t,bridgeConfig:i,sessionSpawner:async(I,x,O,ae)=>{if(!o)throw new Error("agentManager not ready");return o.spawnSessionDownstream(I,x,O,ae)}});await xI(t,a);let c=new Qs({paths:t,config:i,registry:a});o=c;let l,d,p=null,m={},u,h=null,g=null,w=null,S=new jt;function v(I,x){return S.enqueue(()=>y(I,x))}function f(){g||(g=new Ao({isConnected:()=>s.isConnected(),forceReconnect:()=>w?v(w,{force:!0}):void 0,onFatal:I=>{if(process.env[Oi]==="1"){A.error("upstream watchdog fatal, but daemon is unmanaged (CLI-spawned) \u2014 staying alive for soft-reconnect instead of exiting",{downMs:I});return}A.error("upstream watchdog fatal: exiting for supervisor restart",{downMs:I}),process.exit(1)}})),g.start()}async function y(I,x){let O=I,ae=O?.privatecode;if(!ae)throw new _("IPC_BAD_REQUEST","/connect requires privatecode");let He=ii(O.env),ft=O.handshake_url,Yt=O.frontier_url,Qt=dg(O.env,ft,Yt);if(w=O,!x?.force&&l===ae&&d===Qt){let Se=await AI(t);return a.agents.size===0&&Se?(A.warn("/connect noop but core.agents empty with configs on disk; re-running auto-revive"),Oo(t,c).catch(ge=>A.warn("connect-noop auto-revive error (ignored)",{err:String(ge)}))):A.info("/connect: already connected with same PAT + env, noop"),{ok:!0,note:"already connected"}}let Sr=!!l&&l!==ae,vr=d!==void 0&&d!==Qt,Ir=Sr||vr,Tr=await ic({privatecode:ae,...ft?{endpoint:ft}:{},ppeOverride:He});if(Ir){A.warn("connect config switched, resetting agents",{pcChanged:Sr,envChanged:vr,previousPc:l?xo(l):"",nextPc:xo(ae)});for(let Se of[...a.agents.values()])await Se.dispose("connect config switch").catch(()=>{}),a.agents.delete(Se.agentId);a.disconnectedAgents.size>0&&(A.info("clearing disconnectedAgents set on connect config switch",{count:a.disconnectedAgents.size}),a.disconnectedAgents.clear()),await s.swap(new yr,"connect switch").catch(()=>{})}p=Tr.deviceId,zi({deviceId:p,pid:process.pid}),Sc({patToken:ae,env:O.env}).catch(Se=>A.warn("coze-cli setup error (ignored)",{err:String(Se)}));let Uo=new Ai({handshake:Tr,privatecode:ae,...Yt?{urlOverride:Yt}:{},ppeOverride:He,getPatTokenForAgent:Se=>a.agents.get(Se)?.patToken});return await s.swap(Uo,"connect"),l=ae,d=Qt,m=He,u=ft,O.mock_scenario!==void 0&&(a.setMockScenario(O.mock_scenario),A.info("mock scenario set",{scenario:O.mock_scenario})),h||(h=new oi({core:a,getDeviceId:()=>p??"",onTickEnd:()=>R.retryPending().catch(Se=>A.warn("detailSync.retryPending failed (ignored)",{err:String(Se)})),onAuthFailures:D})),h.start(),f(),Ir&&Oo(t,c).catch(Se=>A.warn("post-connect-switch auto-revive error (ignored)",{err:String(Se)})),xi(ae,t).catch(Se=>A.warn("writePatToken after /connect failed (ignored)",{err:String(Se)})),A.info("/connect: WS established",{deviceId:p}),{ok:!0,note:"connected"}}a.registerExtension("_agent/create",async I=>c.createAgent(I.params)),a.registerExtension("_agent/health",async()=>({ok:!0}));let E={},T=new Hs({agents:a.agents,disposeAndMarkDisconnected:async(I,x)=>{let O=a.agents.get(I);if(O){await c.cleanupOpenclawSessionProviders(O).catch(He=>A.warn("cleanup openclaw providers failed (ignored)",{agentId:I,err:String(He)}));let ae=!0;try{await O.dispose(`disconnect: ${x}`)}catch(He){ae=!1,A.error("dispose during disconnect FAILED, leaving agent in error state",{agentId:I,err:String(He)}),O.status="error"}ae&&(O.status="disconnected",a.unregister(I),a.disconnectedAgents.add(I))}else a.disconnectedAgents.add(I)},detailSyncer:async I=>{if(!E.ref)throw new Error("agent-detail-sync not initialized yet");await E.ref.syncOne(I)},cleanupOpenclawProviders:async I=>{await c.cleanupOpenclawSessionProviders(I)},openclawRepair:async(I,x)=>{await c.openclawRepair(I,x)},isRuntimePendingPermission:I=>a.hasPendingPermissionFor(I)});a.registerExtension("_agent/listSkills",I=>T.listSkills(I.params)),a.registerExtension("_agent/addSkills",I=>T.addSkills(I.params)),a.registerExtension("_agent/removeSkills",I=>T.removeSkills(I.params)),a.registerExtension("_agent/getFileTree",I=>T.getFileTree(I.params)),a.registerExtension("_agent/getFileContent",I=>T.getFileContent(I.params)),a.registerExtension("_agent/update",I=>T.updateAgent(I.params)),a.registerExtension("_agent/disconnect",I=>T.disconnectAgent(I.params)),a.registerExtension("_agent/switchModel",I=>T.switchModel(I.params)),a.registerExtension("_agent/reset",I=>T.resetAgent(I.params)),a.registerExtension("_agent/repair",I=>T.repairAgent(I.params));let R=new Ki({paths:t,handlers:T,sendDetail:I=>a.sendRequest("_agent/detail",I)});E.ref=R;let D=async I=>{await Promise.allSettled(I.map(async x=>{try{await T.disconnectAgent({agentId:x.agentId,reason:`auth_failure: code=${x.code} ${x.message}`}),A.info("agent disconnected due to auth failure from heartbeat response",{agentId:x.agentId,code:x.code,message:x.message})}catch(O){A.warn("disconnect during authFailure handling failed (ignored)",{agentId:x.agentId,err:String(O)})}}))};s.onConnect(({initial:I})=>{A.info("frontier upstream connected, triggering detail sync",{initial:I}),R.syncAll(I?"initial-connect":"reconnect").catch(x=>A.warn("detail sync top-level error (ignored)",{err:String(x)}))});let C=new io({paths:t,routes:[{method:"GET",path:"/status",handler:async()=>{let I=a.getMockScenario();return{running:!0,pid:process.pid,spawnedBy:process.env[Oi]==="1"?"manual":"supervisor",agents:[...a.agents.keys()],deviceId:p??"",frameworksCache:i.frameworksCache??{},...I?{mockScenario:I}:{}}}},{method:"POST",path:"/pair",handler:async I=>{let x=I,O=x?.privatecode,ae=x?.pairing_code;if(!O||!ae)throw new _("IPC_BAD_REQUEST","/pair requires privatecode + pairing_code");let He=ii(x.env),ft=x.handshake_url,Yt=x.frontier_url,Qt=dg(x.env,ft,Yt),Sr=!!l&&l!==O,vr=d!==void 0&&d!==Qt,Ir=Sr||vr,Tr=await ic({privatecode:O,...ft?{endpoint:ft}:{},ppeOverride:He});if(Ir){A.warn("pair config switched, resetting agents",{pcChanged:Sr,envChanged:vr,previousPc:l?xo(l):"",nextPc:xo(O),previousEnvKey:d??"",nextEnvKey:Qt});for(let ge of[...a.agents.values()])await ge.dispose("pair config switch").catch(()=>{}),a.agents.delete(ge.agentId);a.disconnectedAgents.size>0&&(A.info("clearing disconnectedAgents set on pair config switch",{count:a.disconnectedAgents.size}),a.disconnectedAgents.clear()),await s.swap(new yr,"pair switch").catch(()=>{})}p=Tr.deviceId,zi({deviceId:p,pid:process.pid}),Sc({patToken:O,env:x.env}).catch(ge=>A.warn("coze-cli setup error (ignored)",{err:String(ge)}));let Uo=new Ai({handshake:Tr,privatecode:O,...Yt?{urlOverride:Yt}:{},ppeOverride:He,getPatTokenForAgent:ge=>a.agents.get(ge)?.patToken});await s.swap(Uo,"pair");try{let ge=new qt;i.frameworksCache=await ge.detectAll(),await or(i),A.info("frameworks_cache refreshed before pair",{detected:Object.keys(i.frameworksCache)})}catch(ge){A.warn("frameworks_cache refresh failed (ignored, using cached)",{err:String(ge)})}let Se=Object.keys(i.frameworksCache??{});try{let ge=await a.sendRequest("_agent/pair",{pairCode:ae,patToken:O,frameworks:Se,_meta:{cozeDeviceId:p}});A.info("_agent/pair ok",{pairResult:ge}),l=O,d=Qt,m=He,u=ft,x.mock_scenario!==void 0&&(a.setMockScenario(x.mock_scenario),A.info("mock scenario set",{scenario:x.mock_scenario})),xi(O,t).catch(Qe=>A.warn("writePatToken after /pair failed (ignored)",{err:String(Qe)})),h||(h=new oi({core:a,getDeviceId:()=>p??"",onTickEnd:()=>R.retryPending().catch(Qe=>A.warn("detailSync.retryPending failed (ignored)",{err:String(Qe)})),onAuthFailures:D})),h.start(),f(),Ir&&Oo(t,c).catch(Qe=>A.warn("post-pair-switch auto-revive error (ignored)",{err:String(Qe)}));let zo;return x.agent_id&&(zo=await OI(x.agent_id,t,c,Qe=>a.sendRequest("_agent/detail",Qe),O).catch(Qe=>(A.error("--agent-id ensureAgent failed",{agentId:x.agent_id,err:String(Qe)}),{ok:!1,agentId:x.agent_id??"",note:String(Qe)}))),{ok:!0,note:"paired with cloud",...zo?{agent:zo}:{}}}catch(ge){return A.error("_agent/pair failed",{err:String(ge)}),{ok:!1,note:`pair failed: ${String(ge)}`}}}},{method:"POST",path:"/connect",handler:I=>v(I)},{method:"POST",path:"/_agent/create",handler:async I=>{let x=I;return{ok:!0,result:await c.createAgent(x)}}},{method:"POST",path:"/agent/send",handler:async I=>{let x=I;if(!x?.agentId||!x?.sessionId||!x?.kind||!x?.path)throw new _("IPC_BAD_REQUEST","/agent/send requires agentId, sessionId, kind, path");if(!l)throw new _("UPSTREAM_NOT_READY","daemon not yet paired with cloud (run --pair-code first)");try{let O=x;return await(O.groupFile?eh:Qf)(O,{core:a,patToken:l,handshakeBase:u,ppeOverride:m})}catch(O){if(O instanceof _)return{ok:!1,code:O.code,message:O.message};throw O}}},{method:"POST",path:"/refresh",handler:async()=>{A.info("IPC /refresh: re-detecting frameworks");let I=new qt;return i.frameworksCache=await I.detectAll(),await or(i),{ok:!0,frameworks:i.frameworksCache}}},{method:"POST",path:"/shutdown",handler:async()=>(A.info("IPC /shutdown received"),setImmediate(()=>{Ee.shutdown("ipc /shutdown")}),{ok:!0})}]}),{port:G,token:M}=await C.start();try{await ig(t.libEntry,t)}catch(I){A.warn("bin shim install failed (D72 send \u547D\u4EE4\u53EF\u80FD\u4E0D\u53EF\u7528)",{err:String(I)})}await a.start(),Oo(t,c).catch(I=>A.warn("auto-revive top-level error (ignored)",{err:String(I)})),Xl().then(async()=>{let{probeAcpVersion:I}=await Promise.resolve().then(()=>(tn(),Zl));for(let x of["claude-code","codex"]){let O=await I(x);O&&A.info("acp wrapper version",{framework:x,version:O})}}).catch(I=>A.warn("acp wrapper warmup / probe top-level error (ignored)",{err:String(I)}));let oe=null,Ee={port:G,token:M,core:a,ipc:C,shutdown(I){return oe||(A.info("daemon shutdown",{reason:I}),oe=(async()=>{h?.stop(),g?.stop(),await a.stop(I),await C.stop(),await e.release()})(),oe)}};for(let I of["SIGTERM","SIGINT"])process.on(I,()=>{Ee.shutdown(I).then(()=>process.exit(0))});return process.on("unhandledRejection",I=>{A.error("unhandledRejection",{reason:I instanceof Error?I.message:String(I),stack:I instanceof Error?I.stack:void 0})}),process.on("uncaughtException",I=>{A.error("uncaughtException (will exit, supervisor will restart)",{message:I.message,stack:I.stack,name:I.name});try{process.stderr.write(`FATAL uncaughtException: ${I.stack??I.message}
104
- `)}catch{}process.exit(1)}),A.info("daemon ready",{port:G,pid:process.pid,nodeVersion:process.version,platform:process.platform,frameworks:Object.keys(i.frameworksCache??{}),libVersion:i.libVersion??"dev"}),PI({cliSpawned:process.env[Oi]==="1",readPatToken:()=>Io(t),connect:v}).catch(I=>A.warn("maybeAutoConnectOnStartup error (ignored)",{err:String(I)})),Ee}async function AI(t){return qi(t).length>0}function xo(t){return t.length<=8?"***":`${t.slice(0,4)}***${t.slice(-4)}`}function dg(t,e,n){return`${t??""}|${e??""}|${n??""}`}async function xI(t,e){let n=qi(t);if(n.length===0)return;let{loadAgentConfig:r,enforceAgentConfigMode:i}=await Promise.resolve().then(()=>(At(),Zi));for(let s of n){await i(s,t).catch(o=>A.warn("enforceAgentConfigMode failed (ignored)",{agentId:s,err:String(o)}));try{let o=await r(s,t);o?.disconnectedAt&&(e.disconnectedAgents.add(s),A.info("agent marked disconnected on startup",{agentId:s,disconnectedAt:o.disconnectedAt,reason:o.disconnectReason??""}))}catch(o){A.warn("failed to load agent config on startup, skipping",{agentId:s,err:String(o)})}}}async function OI(t,e,n,r,i){let{loadAgentConfig:s}=await Promise.resolve().then(()=>(At(),Zi)),o=await s(t,e);if(o){A.info("--agent-id: local config found, reconnecting",{agentId:t,framework:o.framework,hadDisconnect:!!o.disconnectedAt});let d={agentId:o.agentId,framework:o.framework,...o.cozeIdentity?{cozeIdentity:o.cozeIdentity}:{},...o.model?{model:o.model}:{},...i?{patToken:i}:{}};return await n.createAgent(d),{ok:!0,agentId:t,note:o.disconnectedAt?"revived from local config":"connected from local config"}}A.info("--agent-id: local config missing, pulling _agent/detail from cloud",{agentId:t});let a=await r({_meta:{cozeAgentId:t}});if(!a.framework)throw new _("AGENT_NOT_FOUND",`agent ${t} \u4E0D\u5728\u672C\u5730; \u4E91\u7AEF _agent/detail \u54CD\u5E94\u7F3A framework \u5B57\u6BB5 (D36 \u534F\u8BAE\u6269\u5C55\u672A\u751F\u6548), \u65E0\u6CD5\u5728\u672C\u673A\u65B0\u5EFA`);let c={agentId:a.agentId,framework:a.framework,...a.cozeIdentity?{cozeIdentity:a.cozeIdentity}:{},...a.model?{model:a.model}:{},...i?{patToken:i}:{},...a.deployType?{_meta:{cozeDeployType:a.deployType}}:{}};await n.createAgent(c);let l=a.deployType==="cloud"&&a.framework==="openclaw";return{ok:!0,agentId:t,note:l?"cloud agent acknowledged":"created from cloud detail"}}async function Oo(t,e){let{readdir:n}=await import("node:fs/promises"),r;try{r=await n(t.agentsRoot)}catch{return{revived:0,skipped:0,total:0}}if(r.length===0)return{revived:0,skipped:0,total:0};let{loadAgentConfig:i}=await Promise.resolve().then(()=>(At(),Zi));A.info("auto-revive: scanning local agents on startup",{count:r.length});let s=0,o=0;for(let a of r){let c;try{c=await i(a,t)}catch(l){A.warn("auto-revive: load config failed (skipping)",{agentId:a,err:String(l)}),o+=1;continue}if(!c){o+=1;continue}if(c.disconnectedAt){A.info("auto-revive: skip disconnected agent",{agentId:a,disconnectedAt:c.disconnectedAt}),o+=1;continue}try{A.info("auto-revive: re-registering agent (D44 no spawn)",{agentId:a,framework:c.framework});let l=CI(c);await e.createAgent({agentId:c.agentId,framework:c.framework,...c.cozeIdentity?{cozeIdentity:c.cozeIdentity}:{},...c.model?{model:c.model}:{},...l?{_meta:l}:{}}),s+=1}catch(l){A.warn("auto-revive: createAgent failed (skipping)",{agentId:a,framework:c.framework,err:String(l)}),o+=1}}return A.info("auto-revive: done",{revived:s,skipped:o,total:r.length}),{revived:s,skipped:o,total:r.length}}async function PI(t){let e=t.logger??A;if(t.cliSpawned)return"skipped-cli";let n=await t.readPatToken();return n?(e.info("supervisor-spawned daemon, auto-connecting with stored PAT"),t.connect({privatecode:n}).catch(r=>e.warn("startup auto-connect failed (staying idle)",{err:String(r)})),"connecting"):(e.info("no stored PAT, skip startup auto-connect"),"skipped-no-pat")}function CI(t){let e={};return t.deployType&&(e.cozeDeployType=t.deployType),t.accountId&&(e.cozeAccountId=t.accountId),Object.keys(e).length>0?e:void 0}bo();le();import{readFile as fg}from"node:fs/promises";var bt=class{paths;constructor(e){this.paths=e??F()}async probe(e=1e3){let n=await Po(this.paths);if(!n)return{kind:"not-running"};try{let r=await this.fetch(n,{method:"GET",path:"/status",timeoutMs:e});return r.status===200?{kind:"connected",...n}:{kind:"stale",reason:`unexpected status ${r.status}`}}catch(r){return{kind:"stale",reason:NI(r)}}}async request(e){let n=await Po(this.paths);if(!n)throw new Error("coze-bridge daemon not running (no port/token files)");return this.fetch(n,e)}async fetch(e,n){let r=n.body!==void 0,i={Authorization:`Bearer ${e.token}`};r&&(i["content-type"]="application/json");let s=new AbortController,o=setTimeout(()=>s.abort(),n.timeoutMs??5e3);try{let a=await fetch(`http://127.0.0.1:${e.port}${n.path}`,{method:n.method,headers:i,body:r?JSON.stringify(n.body):void 0,signal:s.signal}),c=await a.text();return{status:a.status,body:DI(c)}}finally{clearTimeout(o)}}};async function Po(t){try{let[e,n]=await Promise.all([fg(t.portFile,"utf8"),fg(t.tokenFile,"utf8")]),r=Number.parseInt(e.trim(),10),i=n.trim();return!Number.isFinite(r)||r<=0||!i?null:{port:r,token:i}}catch(e){if(e.code==="ENOENT")return null;throw e}}function DI(t){if(!t)return null;try{return JSON.parse(t)}catch{return t}}function NI(t){return t instanceof Error?t.message:String(t)}gt();L();le();function Xt(t,...e){let n=[],r;for(let i=0;i<t.length;i++){let s=t[i],o=!1;for(let a of e){if(s===a){r=t[i+1],i+=1,o=!0;break}if(s.startsWith(`${a}=`)){r=s.slice(a.length+1),o=!0;break}}o||n.push(s)}return{value:r,rest:n}}import{copyFile as hg,mkdir as LI,readFile as Tl,writeFile as FI}from"node:fs/promises";import{homedir as iC}from"node:os";import{dirname as MI,resolve as Rl,sep as Co}from"node:path";import{fileURLToPath as BI}from"node:url";L();le();var pg=b("dist-install");function UI(t){let e=BI(t),n=MI(e),r=`${Co}src${Co}`;if(n.includes(r)||n.endsWith(`${Co}src${Co}cli`))return null;let i=Rl(n,"index.js"),s=Rl(n,"..","package.json");return{dist:i,pkgJson:s}}async function kl(t={}){let e=t.paths??F(),n=UI(import.meta.url),r=t.sourceDist??n?.dist,i=t.sourcePackageJson??n?.pkgJson;if(!r||!i)return{kind:"dev-mode-skip",reason:"running from src/(tsx loader);no dist/ to install"};if(r===e.libEntry)return{kind:"dev-mode-skip",reason:"running from installed lib path; no re-install needed"};let s;try{s=JSON.parse(await Tl(i,"utf8")).version??"unknown"}catch(p){return pg.warn("cannot read source package.json,skip dist install",{err:String(p)}),{kind:"dev-mode-skip",reason:`package.json read failed: ${String(p)}`}}let o=await no(e.configFile)??{},a=o.libVersion;if(a===s)try{return await Tl(e.libEntry),{kind:"already-current",libVersion:s}}catch{}await LI(e.libDir,{recursive:!0}),await hg(r,e.libEntry),await hg(`${r}.map`,`${e.libEntry}.map`).catch(()=>{});let c=Rl(e.libDir,"package.json"),l=`${JSON.stringify({type:"module"},null,2)}
105
- `;return await Tl(c,"utf8").catch(()=>null)!==l&&await FI(c,l),o.libVersion=s,await or(o,e.configFile),pg.info("dist installed",{libEntry:e.libEntry,fromVersion:a,toVersion:s}),a?{kind:"version-changed",fromVersion:a,toVersion:s,libEntry:e.libEntry}:{kind:"first-install",libVersion:s,libEntry:e.libEntry}}Ho();L();le();import{closeSync as mg,fstatSync as wg,openSync as yg,readFileSync as zI,readSync as $I,readdirSync as GI,statSync as HI}from"node:fs";import{join as Do}from"node:path";var jI=new Set(["debug","info","warn","error"]);function _g(t){let e=t,n=Xt(e,"--agent-id");e=n.rest;let r=Xt(e,"--date");e=r.rest;let i=Xt(e,"-n","--lines");e=i.rest;let s=Xt(e,"--level");e=s.rest;let o=Xt(e,"--grep");e=o.rest;let a=i.value===void 0?200:Number(i.value),c=Number.isInteger(a)&&a>=0?a:200,l=s.value&&jI.has(s.value)?s.value:void 0,d={lines:c,follow:e.includes("-f")||e.includes("--follow"),raw:e.includes("--raw"),list:e.includes("--list")};return n.value&&(d.agentId=n.value),r.value&&(d.date=r.value),l&&(d.level=l),o.value&&(d.grep=o.value),d}function WI(t,e){return t.agentId?Do(be(t.agentId,e).logs,Fi("agent",t.date)):Do(e.bridgeLogsDir,Fi("bridge",t.date))}function qI(t,e){return e<=0||e>=t.length?t:t.slice(t.length-e)}function VI(t,e){let n;try{n=GI(t)}catch{return[]}let r=[];for(let i of n){let s=Go(i,e);if(!s)continue;let o=0;try{o=HI(Do(t,i)).size}catch{}r.push({file:Do(t,i),date:s,size:o})}return r.sort((i,s)=>s.date.localeCompare(i.date)),r}function Eg(t,e){if(e.grep&&!t.includes(e.grep))return!1;if(e.level){let n;try{n=JSON.parse(t).level}catch{return!0}if(typeof n=="string"&&!Bl(n,e.level))return!1}return!0}var gg={debug:"90",info:"36",warn:"33",error:"31"},JI=new Set(["ts","level","module","msg"]);function ZI(t){if(typeof t!="string")return"";let e=t.split("T")[1];return e?e.slice(0,12):""}function Sg(t,e){if(e.raw)return t;let n;try{n=JSON.parse(t)}catch{return t}let r=ZI(n.ts),i=typeof n.level=="string"?n.level:"",s=i.toUpperCase().padEnd(5);e.color&&gg[i]&&(s=`\x1B[${gg[i]}m${s}\x1B[0m`);let o=typeof n.module=="string"?n.module:"",a=typeof n.msg=="string"?n.msg:"",c=Object.entries(n).filter(([l])=>!JI.has(l)).map(([l,d])=>` ${l}=${typeof d=="string"?d:JSON.stringify(d)}`).join("");return`${r} ${s} ${o} ${a}${c}`}function KI(t,e,n){let s=zI(t,"utf8").split(`
103
+ `}async function ig(t,e=F()){let n=e.binDir;await Ro.mkdir(n,{recursive:!0});let r=lI(n,process.platform==="win32"?"coze-bridge.cmd":"coze-bridge"),i=process.execPath,s=process.platform==="win32"?uI(t,i):dI(t,i);return await Ro.readFile(r,"utf8").catch(()=>null)===s||(await Ro.writeFile(r,s,"utf8"),process.platform!=="win32"&&await Ro.chmod(r,493)),n}L();le();import{execSync as sg}from"node:child_process";import{readFileSync as og,unlinkSync as fI}from"node:fs";import{mkdir as hI,readFile as ag,unlink as cg,writeFile as pI}from"node:fs/promises";import{dirname as gI}from"node:path";function ko(t){try{return process.kill(t,0),!0}catch(e){return e.code==="EPERM"}}var mI=b("single-instance"),bo=class{pidFile;acquired=!1;constructor(e={}){this.pidFile=e.pidFile??F().pidFile,e.processTitle&&(process.title=e.processTitle)}async acquire(){let e=await this.readExistingPid();return e!==null&&this.isAlive(e)?{kind:"already-running",pid:e}:(e!==null&&(mI.warn("removing stale pid file",{stalePid:e}),await cg(this.pidFile).catch(()=>{})),await hI(gI(this.pidFile),{recursive:!0}),await pI(this.pidFile,String(process.pid),"utf8"),this.acquired=!0,this.installCleanupHooks(),{kind:"acquired"})}async release(){if(this.acquired){try{(await ag(this.pidFile,"utf8")).trim()===String(process.pid)&&await cg(this.pidFile)}catch{}this.acquired=!1}}async readExistingPid(){try{let e=await ag(this.pidFile,"utf8"),n=Number.parseInt(e.trim(),10);return Number.isFinite(n)&&n>0?n:null}catch(e){if(e.code==="ENOENT")return null;throw e}}isAlive(e){return ko(e)?this.matchesDaemonTitle(e):!1}matchesDaemonTitle(e){if(process.platform==="win32")return this.matchesDaemonTitleWindows(e);try{let n=og(`/proc/${e}/cmdline`,"utf8").replace(/\0/g," ");return!!(n.includes("coze-bridge-daemon")||n.includes("lib/index.js"))}catch{}try{let n=sg(`ps -o command= -p ${e}`,{stdio:["ignore","pipe","ignore"],timeout:1e3}).toString();return n.trim()?n.includes("coze-bridge-daemon")||n.includes("lib/index.js"):!1}catch{return!0}}matchesDaemonTitleWindows(e){try{let r=sg(`tasklist /FI "PID eq ${e}" /FO CSV /NH`,{stdio:["ignore","pipe","ignore"],timeout:2e3}).toString().trim();if(!r||/^(INFO|信息)[::]/.test(r))return!1;let i=r.split(",",1)[0]?.replace(/^"|"$/g,"").toLowerCase()??"";return i.includes("node")||i.includes("coze-bridge")}catch{return!0}}installCleanupHooks(){process.once("exit",()=>{if(this.acquired)try{og(this.pidFile,"utf8").trim()===String(process.pid)&&fI(this.pidFile)}catch{}})}};Ao();L();var An=b("daemon.upstream-watchdog"),TI=12e4,RI=9e5,kI=3e4;function Rl(t,e){let n=process.env[t];if(!n)return e;let r=Number(n);return Number.isFinite(r)&&r>0?r:e}var xo=class{constructor(e){this.opts=e;this.softMs=e.softMs??Rl("COZE_BRIDGE_UPSTREAM_WATCHDOG_SOFT_MS",TI),this.hardMs=e.hardMs??Rl("COZE_BRIDGE_UPSTREAM_WATCHDOG_HARD_MS",RI),this.intervalMs=e.intervalMs??Rl("COZE_BRIDGE_UPSTREAM_WATCHDOG_INTERVAL_MS",kI),this.now=e.now??Date.now}opts;softMs;hardMs;intervalMs;now;timer=null;downSince=null;forcedAt=null;forcing=!1;lastTickAt=null;start(){this.timer||(this.timer=setInterval(()=>this.tick(),this.intervalMs),this.timer.unref?.(),An.info("upstream watchdog started",{softMs:this.softMs,hardMs:this.hardMs,intervalMs:this.intervalMs}))}stop(){this.timer&&(clearInterval(this.timer),this.timer=null),this.downSince=null,this.forcedAt=null,this.lastTickAt=null}tick(){let e=this.now();if(this.lastTickAt!==null&&e-this.lastTickAt>this.intervalMs*3&&(this.downSince!==null&&An.warn("upstream watchdog: large tick gap (likely sleep/suspend), resetting downSince",{gapMs:e-this.lastTickAt}),this.downSince=null,this.forcedAt=null),this.lastTickAt=e,this.opts.isConnected()){this.downSince!==null&&An.info("upstream watchdog: reconnected, reset",{downMs:this.now()-this.downSince}),this.downSince=null,this.forcedAt=null;return}if(this.downSince===null){this.downSince=e,An.warn("upstream watchdog: disconnect detected, arming",{softMs:this.softMs,hardMs:this.hardMs});return}let n=e-this.downSince;if(n>=this.hardMs){An.error("upstream watchdog: disconnected too long, exiting for supervisor restart",{downMs:n,hardMs:this.hardMs}),this.opts.onFatal(n);return}n>=this.softMs&&this.shouldForceNow(e)&&(this.forcedAt=e,this.forcing=!0,An.warn("upstream watchdog: forcing reconnect",{downMs:n,softMs:this.softMs}),Promise.resolve().then(()=>this.opts.forceReconnect()).catch(r=>An.warn("upstream watchdog: forceReconnect error (ignored)",{err:String(r)})).finally(()=>{this.forcing=!1}))}shouldForceNow(e){return!(this.forcing||this.forcedAt!==null&&e-this.forcedAt<this.softMs)}};var A=b("daemon"),bI="coze-bridge-daemon";async function ug(){let t=F();process.env.COZE_BRIDGE_LOG_MODE!=="legacy"&&Ll({bridgeLogsDir:t.bridgeLogsDir,agentLogsDir:I=>be(I,t).logs,listAgentIds:()=>Vi(t)});let e=new bo({processTitle:bI}),n=await e.acquire();if(n.kind==="already-running")throw new Error(`coze-bridge daemon already running (pid=${n.pid})`);let r=await ro(),i=r??{};$i({pid:process.pid}),A.info(r?"loaded bridge config":"initialized bridge config");try{let I=new qt;i.frameworksCache=await I.detectAll(),A.info("refreshed frameworks_cache",{detected:Object.keys(i.frameworksCache)})}catch(I){A.warn("framework detection failed",{err:String(I)})}await or(i);let s=new Io(new yr),o=null,a=new io({upstream:s,paths:t,bridgeConfig:i,sessionSpawner:async(I,x,O,ae)=>{if(!o)throw new Error("agentManager not ready");return o.spawnSessionDownstream(I,x,O,ae)}});await xI(t,a);let c=new eo({paths:t,config:i,registry:a});o=c;let l,d,p=null,m={},u,h=null,g=null,w=null,S=new jt;function v(I,x){return S.enqueue(()=>y(I,x))}function f(){g||(g=new xo({isConnected:()=>s.isConnected(),forceReconnect:()=>w?v(w,{force:!0}):void 0,onFatal:I=>{if(process.env[Pi]==="1"){A.error("upstream watchdog fatal, but daemon is unmanaged (CLI-spawned) \u2014 staying alive for soft-reconnect instead of exiting",{downMs:I});return}A.error("upstream watchdog fatal: exiting for supervisor restart",{downMs:I}),process.exit(1)}})),g.start()}async function y(I,x){let O=I,ae=O?.privatecode;if(!ae)throw new _("IPC_BAD_REQUEST","/connect requires privatecode");let He=si(O.env),ft=O.handshake_url,Yt=O.frontier_url,Qt=dg(O.env,ft,Yt);if(w=O,!x?.force&&l===ae&&d===Qt){let Se=await AI(t);return a.agents.size===0&&Se?(A.warn("/connect noop but core.agents empty with configs on disk; re-running auto-revive"),Po(t,c).catch(ge=>A.warn("connect-noop auto-revive error (ignored)",{err:String(ge)}))):A.info("/connect: already connected with same PAT + env, noop"),{ok:!0,note:"already connected"}}let vr=!!l&&l!==ae,Ir=d!==void 0&&d!==Qt,Tr=vr||Ir,Rr=await oc({privatecode:ae,...ft?{endpoint:ft}:{},ppeOverride:He});if(Tr){A.warn("connect config switched, resetting agents",{pcChanged:vr,envChanged:Ir,previousPc:l?Oo(l):"",nextPc:Oo(ae)});for(let Se of[...a.agents.values()])await Se.dispose("connect config switch").catch(()=>{}),a.agents.delete(Se.agentId);a.disconnectedAgents.size>0&&(A.info("clearing disconnectedAgents set on connect config switch",{count:a.disconnectedAgents.size}),a.disconnectedAgents.clear()),await s.swap(new yr,"connect switch").catch(()=>{})}p=Rr.deviceId,$i({deviceId:p,pid:process.pid}),Ic({patToken:ae,env:O.env}).catch(Se=>A.warn("coze-cli setup error (ignored)",{err:String(Se)}));let $o=new xi({handshake:Rr,privatecode:ae,...Yt?{urlOverride:Yt}:{},ppeOverride:He,getPatTokenForAgent:Se=>a.agents.get(Se)?.patToken});return await s.swap($o,"connect"),l=ae,d=Qt,m=He,u=ft,O.mock_scenario!==void 0&&(a.setMockScenario(O.mock_scenario),A.info("mock scenario set",{scenario:O.mock_scenario})),h||(h=new ai({core:a,getDeviceId:()=>p??"",onTickEnd:()=>R.retryPending().catch(Se=>A.warn("detailSync.retryPending failed (ignored)",{err:String(Se)})),onAuthFailures:D})),h.start(),f(),Tr&&Po(t,c).catch(Se=>A.warn("post-connect-switch auto-revive error (ignored)",{err:String(Se)})),Oi(ae,t).catch(Se=>A.warn("writePatToken after /connect failed (ignored)",{err:String(Se)})),A.info("/connect: WS established",{deviceId:p}),{ok:!0,note:"connected"}}a.registerExtension("_agent/create",async I=>c.createAgent(I.params)),a.registerExtension("_agent/health",async()=>({ok:!0}));let E={},T=new js({agents:a.agents,disposeAndMarkDisconnected:async(I,x)=>{let O=a.agents.get(I);if(O){await c.cleanupOpenclawSessionProviders(O).catch(He=>A.warn("cleanup openclaw providers failed (ignored)",{agentId:I,err:String(He)}));let ae=!0;try{await O.dispose(`disconnect: ${x}`)}catch(He){ae=!1,A.error("dispose during disconnect FAILED, leaving agent in error state",{agentId:I,err:String(He)}),O.status="error"}ae&&(O.status="disconnected",a.unregister(I),a.disconnectedAgents.add(I))}else a.disconnectedAgents.add(I)},detailSyncer:async I=>{if(!E.ref)throw new Error("agent-detail-sync not initialized yet");await E.ref.syncOne(I)},cleanupOpenclawProviders:async I=>{await c.cleanupOpenclawSessionProviders(I)},openclawRepair:async(I,x)=>{await c.openclawRepair(I,x)},isRuntimePendingPermission:I=>a.hasPendingPermissionFor(I)});a.registerExtension("_agent/listSkills",I=>T.listSkills(I.params)),a.registerExtension("_agent/addSkills",I=>T.addSkills(I.params)),a.registerExtension("_agent/removeSkills",I=>T.removeSkills(I.params)),a.registerExtension("_agent/getFileTree",I=>T.getFileTree(I.params)),a.registerExtension("_agent/getFileContent",I=>T.getFileContent(I.params)),a.registerExtension("_agent/update",I=>T.updateAgent(I.params)),a.registerExtension("_agent/disconnect",I=>T.disconnectAgent(I.params)),a.registerExtension("_agent/switchModel",I=>T.switchModel(I.params)),a.registerExtension("_agent/reset",I=>T.resetAgent(I.params)),a.registerExtension("_agent/repair",I=>T.repairAgent(I.params));let R=new Xi({paths:t,handlers:T,sendDetail:I=>a.sendRequest("_agent/detail",I)});E.ref=R;let D=async I=>{await Promise.allSettled(I.map(async x=>{try{await T.disconnectAgent({agentId:x.agentId,reason:`auth_failure: code=${x.code} ${x.message}`}),A.info("agent disconnected due to auth failure from heartbeat response",{agentId:x.agentId,code:x.code,message:x.message})}catch(O){A.warn("disconnect during authFailure handling failed (ignored)",{agentId:x.agentId,err:String(O)})}}))};s.onConnect(({initial:I})=>{A.info("frontier upstream connected, triggering detail sync",{initial:I}),R.syncAll(I?"initial-connect":"reconnect").catch(x=>A.warn("detail sync top-level error (ignored)",{err:String(x)}))});let C=new so({paths:t,routes:[{method:"GET",path:"/status",handler:async()=>{let I=a.getMockScenario();return{running:!0,pid:process.pid,spawnedBy:process.env[Pi]==="1"?"manual":"supervisor",agents:[...a.agents.keys()],deviceId:p??"",frameworksCache:i.frameworksCache??{},...I?{mockScenario:I}:{}}}},{method:"POST",path:"/pair",handler:async I=>{let x=I,O=x?.privatecode,ae=x?.pairing_code;if(!O||!ae)throw new _("IPC_BAD_REQUEST","/pair requires privatecode + pairing_code");let He=si(x.env),ft=x.handshake_url,Yt=x.frontier_url,Qt=dg(x.env,ft,Yt),vr=!!l&&l!==O,Ir=d!==void 0&&d!==Qt,Tr=vr||Ir,Rr=await oc({privatecode:O,...ft?{endpoint:ft}:{},ppeOverride:He});if(Tr){A.warn("pair config switched, resetting agents",{pcChanged:vr,envChanged:Ir,previousPc:l?Oo(l):"",nextPc:Oo(O),previousEnvKey:d??"",nextEnvKey:Qt});for(let ge of[...a.agents.values()])await ge.dispose("pair config switch").catch(()=>{}),a.agents.delete(ge.agentId);a.disconnectedAgents.size>0&&(A.info("clearing disconnectedAgents set on pair config switch",{count:a.disconnectedAgents.size}),a.disconnectedAgents.clear()),await s.swap(new yr,"pair switch").catch(()=>{})}p=Rr.deviceId,$i({deviceId:p,pid:process.pid}),Ic({patToken:O,env:x.env}).catch(ge=>A.warn("coze-cli setup error (ignored)",{err:String(ge)}));let $o=new xi({handshake:Rr,privatecode:O,...Yt?{urlOverride:Yt}:{},ppeOverride:He,getPatTokenForAgent:ge=>a.agents.get(ge)?.patToken});await s.swap($o,"pair");try{let ge=new qt;i.frameworksCache=await ge.detectAll(),await or(i),A.info("frameworks_cache refreshed before pair",{detected:Object.keys(i.frameworksCache)})}catch(ge){A.warn("frameworks_cache refresh failed (ignored, using cached)",{err:String(ge)})}let Se=Object.keys(i.frameworksCache??{});try{let ge=await a.sendRequest("_agent/pair",{pairCode:ae,patToken:O,frameworks:Se,_meta:{cozeDeviceId:p}});A.info("_agent/pair ok",{pairResult:ge}),l=O,d=Qt,m=He,u=ft,x.mock_scenario!==void 0&&(a.setMockScenario(x.mock_scenario),A.info("mock scenario set",{scenario:x.mock_scenario})),Oi(O,t).catch(Qe=>A.warn("writePatToken after /pair failed (ignored)",{err:String(Qe)})),h||(h=new ai({core:a,getDeviceId:()=>p??"",onTickEnd:()=>R.retryPending().catch(Qe=>A.warn("detailSync.retryPending failed (ignored)",{err:String(Qe)})),onAuthFailures:D})),h.start(),f(),Tr&&Po(t,c).catch(Qe=>A.warn("post-pair-switch auto-revive error (ignored)",{err:String(Qe)}));let Go;return x.agent_id&&(Go=await OI(x.agent_id,t,c,Qe=>a.sendRequest("_agent/detail",Qe),O).catch(Qe=>(A.error("--agent-id ensureAgent failed",{agentId:x.agent_id,err:String(Qe)}),{ok:!1,agentId:x.agent_id??"",note:String(Qe)}))),{ok:!0,note:"paired with cloud",...Go?{agent:Go}:{}}}catch(ge){return A.error("_agent/pair failed",{err:String(ge)}),{ok:!1,note:`pair failed: ${String(ge)}`}}}},{method:"POST",path:"/connect",handler:I=>v(I)},{method:"POST",path:"/_agent/create",handler:async I=>{let x=I;return{ok:!0,result:await c.createAgent(x)}}},{method:"POST",path:"/agent/send",handler:async I=>{let x=I;if(!x?.agentId||!x?.sessionId||!x?.kind||!x?.path)throw new _("IPC_BAD_REQUEST","/agent/send requires agentId, sessionId, kind, path");if(!l)throw new _("UPSTREAM_NOT_READY","daemon not yet paired with cloud (run --pair-code first)");try{let O=x;return await(O.groupFile?eh:Qf)(O,{core:a,patToken:l,handshakeBase:u,ppeOverride:m})}catch(O){if(O instanceof _)return{ok:!1,code:O.code,message:O.message};throw O}}},{method:"POST",path:"/refresh",handler:async()=>{A.info("IPC /refresh: re-detecting frameworks");let I=new qt;return i.frameworksCache=await I.detectAll(),await or(i),{ok:!0,frameworks:i.frameworksCache}}},{method:"POST",path:"/shutdown",handler:async()=>(A.info("IPC /shutdown received"),setImmediate(()=>{Ee.shutdown("ipc /shutdown")}),{ok:!0})}]}),{port:G,token:M}=await C.start();try{await ig(t.libEntry,t)}catch(I){A.warn("bin shim install failed (D72 send \u547D\u4EE4\u53EF\u80FD\u4E0D\u53EF\u7528)",{err:String(I)})}await a.start(),Po(t,c).catch(I=>A.warn("auto-revive top-level error (ignored)",{err:String(I)})),Xl().then(async()=>{let{probeAcpVersion:I}=await Promise.resolve().then(()=>(tn(),Zl));for(let x of["claude-code","codex"]){let O=await I(x);O&&A.info("acp wrapper version",{framework:x,version:O})}}).catch(I=>A.warn("acp wrapper warmup / probe top-level error (ignored)",{err:String(I)}));let oe=null,Ee={port:G,token:M,core:a,ipc:C,shutdown(I){return oe||(A.info("daemon shutdown",{reason:I}),oe=(async()=>{h?.stop(),g?.stop(),await a.stop(I),await C.stop(),await e.release()})(),oe)}};for(let I of["SIGTERM","SIGINT"])process.on(I,()=>{Ee.shutdown(I).then(()=>process.exit(0))});return process.on("unhandledRejection",I=>{A.error("unhandledRejection",{reason:I instanceof Error?I.message:String(I),stack:I instanceof Error?I.stack:void 0})}),process.on("uncaughtException",I=>{A.error("uncaughtException (will exit, supervisor will restart)",{message:I.message,stack:I.stack,name:I.name});try{process.stderr.write(`FATAL uncaughtException: ${I.stack??I.message}
104
+ `)}catch{}process.exit(1)}),A.info("daemon ready",{port:G,pid:process.pid,nodeVersion:process.version,platform:process.platform,frameworks:Object.keys(i.frameworksCache??{}),libVersion:i.libVersion??"dev"}),PI({cliSpawned:process.env[Pi]==="1",readPatToken:()=>To(t),connect:v}).catch(I=>A.warn("maybeAutoConnectOnStartup error (ignored)",{err:String(I)})),Ee}async function AI(t){return Vi(t).length>0}function Oo(t){return t.length<=8?"***":`${t.slice(0,4)}***${t.slice(-4)}`}function dg(t,e,n){return`${t??""}|${e??""}|${n??""}`}async function xI(t,e){let n=Vi(t);if(n.length===0)return;let{loadAgentConfig:r,enforceAgentConfigMode:i}=await Promise.resolve().then(()=>(At(),Ki));for(let s of n){await i(s,t).catch(o=>A.warn("enforceAgentConfigMode failed (ignored)",{agentId:s,err:String(o)}));try{let o=await r(s,t);o?.disconnectedAt&&(e.disconnectedAgents.add(s),A.info("agent marked disconnected on startup",{agentId:s,disconnectedAt:o.disconnectedAt,reason:o.disconnectReason??""}))}catch(o){A.warn("failed to load agent config on startup, skipping",{agentId:s,err:String(o)})}}}async function OI(t,e,n,r,i){let{loadAgentConfig:s}=await Promise.resolve().then(()=>(At(),Ki)),o=await s(t,e);if(o){A.info("--agent-id: local config found, reconnecting",{agentId:t,framework:o.framework,hadDisconnect:!!o.disconnectedAt});let d={agentId:o.agentId,framework:o.framework,...o.cozeIdentity?{cozeIdentity:o.cozeIdentity}:{},...o.model?{model:o.model}:{},...i?{patToken:i}:{}};return await n.createAgent(d),{ok:!0,agentId:t,note:o.disconnectedAt?"revived from local config":"connected from local config"}}A.info("--agent-id: local config missing, pulling _agent/detail from cloud",{agentId:t});let a=await r({_meta:{cozeAgentId:t}});if(!a.framework)throw new _("AGENT_NOT_FOUND",`agent ${t} \u4E0D\u5728\u672C\u5730; \u4E91\u7AEF _agent/detail \u54CD\u5E94\u7F3A framework \u5B57\u6BB5 (D36 \u534F\u8BAE\u6269\u5C55\u672A\u751F\u6548), \u65E0\u6CD5\u5728\u672C\u673A\u65B0\u5EFA`);let c={agentId:a.agentId,framework:a.framework,...a.cozeIdentity?{cozeIdentity:a.cozeIdentity}:{},...a.model?{model:a.model}:{},...i?{patToken:i}:{},...a.deployType?{_meta:{cozeDeployType:a.deployType}}:{}};await n.createAgent(c);let l=a.deployType==="cloud"&&a.framework==="openclaw";return{ok:!0,agentId:t,note:l?"cloud agent acknowledged":"created from cloud detail"}}async function Po(t,e){let{readdir:n}=await import("node:fs/promises"),r;try{r=await n(t.agentsRoot)}catch{return{revived:0,skipped:0,total:0}}if(r.length===0)return{revived:0,skipped:0,total:0};let{loadAgentConfig:i}=await Promise.resolve().then(()=>(At(),Ki));A.info("auto-revive: scanning local agents on startup",{count:r.length});let s=0,o=0;for(let a of r){let c;try{c=await i(a,t)}catch(l){A.warn("auto-revive: load config failed (skipping)",{agentId:a,err:String(l)}),o+=1;continue}if(!c){o+=1;continue}if(c.disconnectedAt){A.info("auto-revive: skip disconnected agent",{agentId:a,disconnectedAt:c.disconnectedAt}),o+=1;continue}try{A.info("auto-revive: re-registering agent (D44 no spawn)",{agentId:a,framework:c.framework});let l=CI(c);await e.createAgent({agentId:c.agentId,framework:c.framework,...c.cozeIdentity?{cozeIdentity:c.cozeIdentity}:{},...c.model?{model:c.model}:{},...l?{_meta:l}:{}}),s+=1}catch(l){A.warn("auto-revive: createAgent failed (skipping)",{agentId:a,framework:c.framework,err:String(l)}),o+=1}}return A.info("auto-revive: done",{revived:s,skipped:o,total:r.length}),{revived:s,skipped:o,total:r.length}}async function PI(t){let e=t.logger??A;if(t.cliSpawned)return"skipped-cli";let n=await t.readPatToken();return n?(e.info("supervisor-spawned daemon, auto-connecting with stored PAT"),t.connect({privatecode:n}).catch(r=>e.warn("startup auto-connect failed (staying idle)",{err:String(r)})),"connecting"):(e.info("no stored PAT, skip startup auto-connect"),"skipped-no-pat")}function CI(t){let e={};return t.deployType&&(e.cozeDeployType=t.deployType),t.accountId&&(e.cozeAccountId=t.accountId),Object.keys(e).length>0?e:void 0}Ao();le();import{readFile as fg}from"node:fs/promises";var bt=class{paths;constructor(e){this.paths=e??F()}async probe(e=1e3){let n=await Co(this.paths);if(!n)return{kind:"not-running"};try{let r=await this.fetch(n,{method:"GET",path:"/status",timeoutMs:e});return r.status===200?{kind:"connected",...n}:{kind:"stale",reason:`unexpected status ${r.status}`}}catch(r){return{kind:"stale",reason:NI(r)}}}async request(e){let n=await Co(this.paths);if(!n)throw new Error("coze-bridge daemon not running (no port/token files)");return this.fetch(n,e)}async fetch(e,n){let r=n.body!==void 0,i={Authorization:`Bearer ${e.token}`};r&&(i["content-type"]="application/json");let s=new AbortController,o=setTimeout(()=>s.abort(),n.timeoutMs??5e3);try{let a=await fetch(`http://127.0.0.1:${e.port}${n.path}`,{method:n.method,headers:i,body:r?JSON.stringify(n.body):void 0,signal:s.signal}),c=await a.text();return{status:a.status,body:DI(c)}}finally{clearTimeout(o)}}};async function Co(t){try{let[e,n]=await Promise.all([fg(t.portFile,"utf8"),fg(t.tokenFile,"utf8")]),r=Number.parseInt(e.trim(),10),i=n.trim();return!Number.isFinite(r)||r<=0||!i?null:{port:r,token:i}}catch(e){if(e.code==="ENOENT")return null;throw e}}function DI(t){if(!t)return null;try{return JSON.parse(t)}catch{return t}}function NI(t){return t instanceof Error?t.message:String(t)}gt();L();le();function Xt(t,...e){let n=[],r;for(let i=0;i<t.length;i++){let s=t[i],o=!1;for(let a of e){if(s===a){r=t[i+1],i+=1,o=!0;break}if(s.startsWith(`${a}=`)){r=s.slice(a.length+1),o=!0;break}}o||n.push(s)}return{value:r,rest:n}}import{copyFile as hg,mkdir as LI,readFile as kl,writeFile as FI}from"node:fs/promises";import{homedir as sC}from"node:os";import{dirname as MI,resolve as bl,sep as Do}from"node:path";import{fileURLToPath as BI}from"node:url";L();le();var pg=b("dist-install");function UI(t){let e=BI(t),n=MI(e),r=`${Do}src${Do}`;if(n.includes(r)||n.endsWith(`${Do}src${Do}cli`))return null;let i=bl(n,"index.js"),s=bl(n,"..","package.json");return{dist:i,pkgJson:s}}async function Al(t={}){let e=t.paths??F(),n=UI(import.meta.url),r=t.sourceDist??n?.dist,i=t.sourcePackageJson??n?.pkgJson;if(!r||!i)return{kind:"dev-mode-skip",reason:"running from src/(tsx loader);no dist/ to install"};if(r===e.libEntry)return{kind:"dev-mode-skip",reason:"running from installed lib path; no re-install needed"};let s;try{s=JSON.parse(await kl(i,"utf8")).version??"unknown"}catch(p){return pg.warn("cannot read source package.json,skip dist install",{err:String(p)}),{kind:"dev-mode-skip",reason:`package.json read failed: ${String(p)}`}}let o=await ro(e.configFile)??{},a=o.libVersion;if(a===s)try{return await kl(e.libEntry),{kind:"already-current",libVersion:s}}catch{}await LI(e.libDir,{recursive:!0}),await hg(r,e.libEntry),await hg(`${r}.map`,`${e.libEntry}.map`).catch(()=>{});let c=bl(e.libDir,"package.json"),l=`${JSON.stringify({type:"module"},null,2)}
105
+ `;return await kl(c,"utf8").catch(()=>null)!==l&&await FI(c,l),o.libVersion=s,await or(o,e.configFile),pg.info("dist installed",{libEntry:e.libEntry,fromVersion:a,toVersion:s}),a?{kind:"version-changed",fromVersion:a,toVersion:s,libEntry:e.libEntry}:{kind:"first-install",libVersion:s,libEntry:e.libEntry}}Wo();L();le();import{closeSync as mg,fstatSync as wg,openSync as yg,readFileSync as zI,readSync as $I,readdirSync as GI,statSync as HI}from"node:fs";import{join as No}from"node:path";var jI=new Set(["debug","info","warn","error"]);function _g(t){let e=t,n=Xt(e,"--agent-id");e=n.rest;let r=Xt(e,"--date");e=r.rest;let i=Xt(e,"-n","--lines");e=i.rest;let s=Xt(e,"--level");e=s.rest;let o=Xt(e,"--grep");e=o.rest;let a=i.value===void 0?200:Number(i.value),c=Number.isInteger(a)&&a>=0?a:200,l=s.value&&jI.has(s.value)?s.value:void 0,d={lines:c,follow:e.includes("-f")||e.includes("--follow"),raw:e.includes("--raw"),list:e.includes("--list")};return n.value&&(d.agentId=n.value),r.value&&(d.date=r.value),l&&(d.level=l),o.value&&(d.grep=o.value),d}function WI(t,e){return t.agentId?No(be(t.agentId,e).logs,Mi("agent",t.date)):No(e.bridgeLogsDir,Mi("bridge",t.date))}function qI(t,e){return e<=0||e>=t.length?t:t.slice(t.length-e)}function VI(t,e){let n;try{n=GI(t)}catch{return[]}let r=[];for(let i of n){let s=jo(i,e);if(!s)continue;let o=0;try{o=HI(No(t,i)).size}catch{}r.push({file:No(t,i),date:s,size:o})}return r.sort((i,s)=>s.date.localeCompare(i.date)),r}function Eg(t,e){if(e.grep&&!t.includes(e.grep))return!1;if(e.level){let n;try{n=JSON.parse(t).level}catch{return!0}if(typeof n=="string"&&!Bl(n,e.level))return!1}return!0}var gg={debug:"90",info:"36",warn:"33",error:"31"},JI=new Set(["ts","level","module","msg"]);function ZI(t){if(typeof t!="string")return"";let e=t.split("T")[1];return e?e.slice(0,12):""}function Sg(t,e){if(e.raw)return t;let n;try{n=JSON.parse(t)}catch{return t}let r=ZI(n.ts),i=typeof n.level=="string"?n.level:"",s=i.toUpperCase().padEnd(5);e.color&&gg[i]&&(s=`\x1B[${gg[i]}m${s}\x1B[0m`);let o=typeof n.module=="string"?n.module:"",a=typeof n.msg=="string"?n.msg:"",c=Object.entries(n).filter(([l])=>!JI.has(l)).map(([l,d])=>` ${l}=${typeof d=="string"?d:JSON.stringify(d)}`).join("");return`${r} ${s} ${o} ${a}${c}`}function KI(t,e,n){let s=zI(t,"utf8").split(`
106
106
  `).filter(o=>o.length>0).filter(o=>Eg(o,{level:e.level,grep:e.grep}));for(let o of qI(s,e.lines))process.stdout.write(`${Sg(o,{raw:e.raw,color:n})}
107
107
  `)}async function vg(t,e){let n=e.paths??F(),r=process.stdout.isTTY===!0;if(t.list){let o=t.agentId?be(t.agentId,n).logs:n.bridgeLogsDir,a=t.agentId?"agent":"bridge",c=VI(o,a);if(c.length===0)return process.stderr.write(`coze-bridge log: \u65E0\u65E5\u5FD7\u6587\u4EF6\u4E8E ${o}
108
108
  `),1;for(let l of c)process.stdout.write(`${l.date} ${(l.size/1024).toFixed(1)}KB ${l.file}
@@ -113,14 +113,14 @@ exec ${JSON.stringify(e)} ${JSON.stringify(t)} "$@"
113
113
  `);i=c.pop()??"";for(let l of c)l.length>0&&Eg(l,{level:e.level,grep:e.grep})&&process.stdout.write(`${Sg(l,{raw:e.raw,color:n})}
114
114
  `)}await new Promise(c=>setTimeout(c,XI))}}finally{process.off("SIGINT",o)}}import{basename as eT,resolve as tT}from"node:path";le();var nT=9e4,rT={PATH_OUTSIDE_WORKSPACE:3,FILE_TOO_LARGE:3,UNSUPPORTED_MIME:3,MODEL_MODALITY_UNSUPPORTED:3,IPC_BAD_REQUEST:3,AGENT_NOT_FOUND:4,IPC_AUTH_FAILED:4,AGENT_DISCONNECTED:5,UPLOAD_FAILED:5,UPSTREAM_NOT_READY:5,UPSTREAM_DISCONNECTED:5,UPSTREAM_HANDSHAKE_FAILED:5,AGENT_BUSY:1,AGENT_SPAWN_FAILED:1,AGENT_TIMEOUT:1,AGENT_FRAME_IDLE_TIMEOUT:1,AGENT_PROTOCOL_ERROR:1,BRIDGE_CONFIG_INVALID:1,BRIDGE_INTERNAL:1,MODEL_TOKEN_GEN_FAILED:1,OPERATION_NOT_ALLOWED_FOR_LOCAL:1,AGENT_DEPENDENCY_INSTALL_FAILED:1,AGENT_APPROVAL_TIMEOUT:1};function iT(t){return rT[t]??1}async function Ig(t,e={}){let n=e.paths??F();if(!t.agentId||!t.sessionId)return process.stderr.write(`Error: missing --agent-id and/or --session-id. These IDs come from the <coze-context> block injected at the top of each prompt \u2014 extract agentId and sessionId from there and pass them as flags. Example: coze-bridge send image x.png --agent-id <id> --session-id <id>
115
115
  `),4;if(t.groupFile&&!t.mimeType)return process.stderr.write(`Error: --group-file requires --mime <mimeType> (e.g. application/pdf, image/png). No local file is read in group-file mode, mime cannot be auto-detected.
116
- `),3;let r=await Po(n).catch(()=>null);if(!r)return process.stderr.write(`Error: coze-bridge daemon not running (cannot read ${n.portFile} / ${n.tokenFile}). Make sure you are inside an agent session spawned by the daemon.
116
+ `),3;let r=await Co(n).catch(()=>null);if(!r)return process.stderr.write(`Error: coze-bridge daemon not running (cannot read ${n.portFile} / ${n.tokenFile}). Make sure you are inside an agent session spawned by the daemon.
117
117
  `),4;let i={agentId:t.agentId,sessionId:t.sessionId,kind:t.kind,path:t.groupFile?t.path:tT(process.cwd(),t.path),...t.caption?{caption:t.caption}:{},...t.name?{name:t.name}:{},...t.groupFile?{groupFile:!0}:{},...t.mimeType?{mimeType:t.mimeType}:{}},s;try{s=await sT(r,"/agent/send",i,nT)}catch(o){return process.stderr.write(`Error: daemon IPC failed: ${o instanceof Error?o.message:String(o)}
118
118
  `),4}if(!s.ok)return process.stderr.write(`Error: ${s.code}: ${s.message}
119
119
  `),iT(s.code);if(t.json)process.stdout.write(`${JSON.stringify(s)}
120
120
  `);else{let o=t.name??eT(i.path);if(t.groupFile){let a=s.uri.length>60?`${s.uri.slice(0,57)}...`:s.uri;process.stdout.write(`Sent group file ${o} (uri=${a})
121
121
  `)}else process.stdout.write(`Sent ${t.kind} ${o} (${oT(s.bytes)})
122
- `)}return 0}async function sT(t,e,n,r){let i=new AbortController,s=setTimeout(()=>i.abort(),r);try{let o=await fetch(`http://127.0.0.1:${t.port}${e}`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`,"content-type":"application/json"},body:JSON.stringify(n),signal:i.signal}),a=await o.text(),c=a?JSON.parse(a):null;return c&&typeof c=="object"&&"ok"in c?c:{ok:!1,code:"BRIDGE_INTERNAL",message:`unexpected daemon response (status=${o.status}): ${a.slice(0,200)}`}}finally{clearTimeout(s)}}function oT(t){return t<1024?`${t}B`:t<1024*1024?`${(t/1024).toFixed(1)}KB`:`${(t/1024/1024).toFixed(1)}MB`}var Bo=b("cli");function _e(t,e){let{value:n,rest:r}=Xt(t,e);return{value:n,rest:r}}function Ci(t,e){process.stderr.write(`[deprecated] '${t}' will be removed in a future release, use '${e}' instead
123
- `)}function xT(t){let e=t.slice(2);if(e.includes("--version")||e.includes("-v"))return{mode:"version"};if(e.includes("--daemon"))return{mode:"daemon"};if(e[0]==="status")return{mode:"status"};if(e[0]==="stop")return{mode:"stop"};if(e[0]==="refresh")return{mode:"refresh"};if(e[0]==="update")return{mode:"update"};if(e[0]==="purge")return{mode:"purge"};if(e[0]==="service")return e[1]==="install"?{mode:"service-install"}:e[1]==="uninstall"?{mode:"service-uninstall"}:{mode:"help"};if(e[0]==="send")return OT(e.slice(1));if(e[0]==="log")return{mode:"log",..._g(e.slice(1))};if(e[0]==="connect")return PT(e.slice(1));if(e.includes("--status"))return Ci("--status","coze-bridge status"),{mode:"status"};if(e.includes("--stop"))return Ci("--stop","coze-bridge stop"),{mode:"stop"};if(e.includes("--refresh"))return Ci("--refresh","coze-bridge refresh"),{mode:"refresh"};if(e.includes("--uninstall"))return Ci("--uninstall","coze-bridge purge"),{mode:"purge"};if(e.includes("--install-service"))return Ci("--install-service","coze-bridge service install"),{mode:"service-install"};if(e.includes("--help")||e.includes("-h")||e.length===0)return{mode:"help"};let n=e,{value:r,rest:i}=_e(n,"--pat-token");n=i;let{value:s,rest:o}=_e(n,"--pair-code");n=o;let{value:a,rest:c}=_e(n,"--env");n=c;let{value:l,rest:d}=_e(n,"--handshake-url");n=d;let{value:p,rest:m}=_e(n,"--frontier-url");n=m;let{value:u,rest:h}=_e(n,"--mock-scenario");n=h;let{value:g}=_e(n,"--agent-id");if(!r||!s)return{mode:"help"};let w={mode:"pair",privatecode:r,pairingCode:s};return a&&(w.env=a),l&&(w.handshakeUrl=l),p&&(w.frontierUrl=p),u&&(w.mockScenario=u),g&&(w.agentId=g),w}function OT(t){let e=t[0],n=t[1];if(e!=="image"&&e!=="file")return{mode:"help"};if(!n||n.startsWith("--"))return{mode:"help"};let r=t.slice(2),{value:i,rest:s}=_e(r,"--caption");r=s;let{value:o,rest:a}=_e(r,"--name");r=a;let{value:c,rest:l}=_e(r,"--agent-id");r=l;let{value:d,rest:p}=_e(r,"--session-id");r=p;let{value:m,rest:u}=_e(r,"--mime");r=u;let h=r.includes("--group-file");r=r.filter(S=>S!=="--group-file");let g=r.includes("--json"),w={mode:"send",kind:e,path:n,json:g};return i&&(w.caption=i),o&&(w.name=o),c&&(w.agentId=c),d&&(w.sessionId=d),h&&(w.groupFile=!0),m&&(w.mimeType=m),w}function PT(t){let e=t,{value:n,rest:r}=_e(e,"--pat-token");e=r;let{value:i,rest:s}=_e(e,"--env");e=s;let{value:o,rest:a}=_e(e,"--handshake-url");e=a;let{value:c,rest:l}=_e(e,"--frontier-url");e=l;let{value:d,rest:p}=_e(e,"--mock-scenario");e=p;let m={mode:"connect"};return n&&(m.privatecode=n),i&&(m.env=i),o&&(m.handshakeUrl=o),c&&(m.frontierUrl=c),d&&(m.mockScenario=d),m}var CT=`
122
+ `)}return 0}async function sT(t,e,n,r){let i=new AbortController,s=setTimeout(()=>i.abort(),r);try{let o=await fetch(`http://127.0.0.1:${t.port}${e}`,{method:"POST",headers:{Authorization:`Bearer ${t.token}`,"content-type":"application/json"},body:JSON.stringify(n),signal:i.signal}),a=await o.text(),c=a?JSON.parse(a):null;return c&&typeof c=="object"&&"ok"in c?c:{ok:!1,code:"BRIDGE_INTERNAL",message:`unexpected daemon response (status=${o.status}): ${a.slice(0,200)}`}}finally{clearTimeout(s)}}function oT(t){return t<1024?`${t}B`:t<1024*1024?`${(t/1024).toFixed(1)}KB`:`${(t/1024/1024).toFixed(1)}MB`}var zo=b("cli");function _e(t,e){let{value:n,rest:r}=Xt(t,e);return{value:n,rest:r}}function Di(t,e){process.stderr.write(`[deprecated] '${t}' will be removed in a future release, use '${e}' instead
123
+ `)}function OT(t){let e=t.slice(2);if(e.includes("--version")||e.includes("-v"))return{mode:"version"};if(e.includes("--daemon"))return{mode:"daemon"};if(e[0]==="status")return{mode:"status"};if(e[0]==="stop")return{mode:"stop"};if(e[0]==="refresh")return{mode:"refresh"};if(e[0]==="update")return{mode:"update"};if(e[0]==="purge")return{mode:"purge"};if(e[0]==="service")return e[1]==="install"?{mode:"service-install"}:e[1]==="uninstall"?{mode:"service-uninstall"}:{mode:"help"};if(e[0]==="send")return PT(e.slice(1));if(e[0]==="log")return{mode:"log",..._g(e.slice(1))};if(e[0]==="connect")return CT(e.slice(1));if(e.includes("--status"))return Di("--status","coze-bridge status"),{mode:"status"};if(e.includes("--stop"))return Di("--stop","coze-bridge stop"),{mode:"stop"};if(e.includes("--refresh"))return Di("--refresh","coze-bridge refresh"),{mode:"refresh"};if(e.includes("--uninstall"))return Di("--uninstall","coze-bridge purge"),{mode:"purge"};if(e.includes("--install-service"))return Di("--install-service","coze-bridge service install"),{mode:"service-install"};if(e.includes("--help")||e.includes("-h")||e.length===0)return{mode:"help"};let n=e,{value:r,rest:i}=_e(n,"--pat-token");n=i;let{value:s,rest:o}=_e(n,"--pair-code");n=o;let{value:a,rest:c}=_e(n,"--env");n=c;let{value:l,rest:d}=_e(n,"--handshake-url");n=d;let{value:p,rest:m}=_e(n,"--frontier-url");n=m;let{value:u,rest:h}=_e(n,"--mock-scenario");n=h;let{value:g}=_e(n,"--agent-id");if(!r||!s)return{mode:"help"};let w={mode:"pair",privatecode:r,pairingCode:s};return a&&(w.env=a),l&&(w.handshakeUrl=l),p&&(w.frontierUrl=p),u&&(w.mockScenario=u),g&&(w.agentId=g),w}function PT(t){let e=t[0],n=t[1];if(e!=="image"&&e!=="file")return{mode:"help"};if(!n||n.startsWith("--"))return{mode:"help"};let r=t.slice(2),{value:i,rest:s}=_e(r,"--caption");r=s;let{value:o,rest:a}=_e(r,"--name");r=a;let{value:c,rest:l}=_e(r,"--agent-id");r=l;let{value:d,rest:p}=_e(r,"--session-id");r=p;let{value:m,rest:u}=_e(r,"--mime");r=u;let h=r.includes("--group-file");r=r.filter(S=>S!=="--group-file");let g=r.includes("--json"),w={mode:"send",kind:e,path:n,json:g};return i&&(w.caption=i),o&&(w.name=o),c&&(w.agentId=c),d&&(w.sessionId=d),h&&(w.groupFile=!0),m&&(w.mimeType=m),w}function CT(t){let e=t,{value:n,rest:r}=_e(e,"--pat-token");e=r;let{value:i,rest:s}=_e(e,"--env");e=s;let{value:o,rest:a}=_e(e,"--handshake-url");e=a;let{value:c,rest:l}=_e(e,"--frontier-url");e=l;let{value:d,rest:p}=_e(e,"--mock-scenario");e=p;let m={mode:"connect"};return n&&(m.privatecode=n),i&&(m.env=i),o&&(m.handshakeUrl=o),c&&(m.frontierUrl=c),d&&(m.mockScenario=d),m}var DT=`
124
124
  coze-bridge - local bridge daemon for cloud Agent Service
125
125
 
126
126
  Pair (paste from cloud UI; start/reuse daemon and deliver pair-code):
@@ -199,50 +199,50 @@ Deprecated flags (still work, but emit a warning; will be removed in a future re
199
199
 
200
200
  Internal:
201
201
  <node> <entry> --daemon daemon mode (OS supervisor only)
202
- `.trimStart();async function Cg(t=process.argv,e={}){let n=xT(t);switch(n.mode){case"help":return process.stdout.write(CT),0;case"version":return process.stdout.write(`${tr}
203
- `),0;case"daemon":{try{await ug()}catch(r){return Bo.error("daemon start failed",{err:String(r)}),1}return new Promise(()=>{})}case"status":return DT(e);case"stop":return Ng(e);case"refresh":return FT(e);case"log":return vg(n,e);case"update":return NT(e);case"purge":return MT(e);case"service-install":return BT(e);case"service-uninstall":return UT(e);case"pair":{let r={};return n.env&&(r.env=n.env),n.handshakeUrl&&(r.handshakeUrl=n.handshakeUrl),n.frontierUrl&&(r.frontierUrl=n.frontierUrl),n.mockScenario&&(r.mockScenario=n.mockScenario),zT(n.privatecode,n.pairingCode,e,r,n.agentId)}case"connect":{let r={};return n.env&&(r.env=n.env),n.handshakeUrl&&(r.handshakeUrl=n.handshakeUrl),n.frontierUrl&&(r.frontierUrl=n.frontierUrl),n.mockScenario&&(r.mockScenario=n.mockScenario),$T(n.privatecode,e,r)}case"send":return Ig({kind:n.kind,path:n.path,...n.agentId?{agentId:n.agentId}:{},...n.sessionId?{sessionId:n.sessionId}:{},...n.caption?{caption:n.caption}:{},...n.name?{name:n.name}:{},...n.groupFile?{groupFile:!0}:{},...n.mimeType?{mimeType:n.mimeType}:{},json:n.json},e)}}async function Dg(t){let{unlink:e}=await import("node:fs/promises");await Promise.all([e(t.pidFile).catch(()=>{}),e(t.portFile).catch(()=>{}),e(t.tokenFile).catch(()=>{})])}async function DT(t){let e=t.paths??F(),n=new bt(e),r=await n.probe();if(r.kind==="not-running")return process.stdout.write(`coze-bridge: not running
202
+ `.trimStart();async function Cg(t=process.argv,e={}){let n=OT(t);switch(n.mode){case"help":return process.stdout.write(DT),0;case"version":return process.stdout.write(`${tr}
203
+ `),0;case"daemon":{try{await ug()}catch(r){return zo.error("daemon start failed",{err:String(r)}),1}return new Promise(()=>{})}case"status":return NT(e);case"stop":return Ng(e);case"refresh":return MT(e);case"log":return vg(n,e);case"update":return LT(e);case"purge":return BT(e);case"service-install":return UT(e);case"service-uninstall":return zT(e);case"pair":{let r={};return n.env&&(r.env=n.env),n.handshakeUrl&&(r.handshakeUrl=n.handshakeUrl),n.frontierUrl&&(r.frontierUrl=n.frontierUrl),n.mockScenario&&(r.mockScenario=n.mockScenario),$T(n.privatecode,n.pairingCode,e,r,n.agentId)}case"connect":{let r={};return n.env&&(r.env=n.env),n.handshakeUrl&&(r.handshakeUrl=n.handshakeUrl),n.frontierUrl&&(r.frontierUrl=n.frontierUrl),n.mockScenario&&(r.mockScenario=n.mockScenario),GT(n.privatecode,e,r)}case"send":return Ig({kind:n.kind,path:n.path,...n.agentId?{agentId:n.agentId}:{},...n.sessionId?{sessionId:n.sessionId}:{},...n.caption?{caption:n.caption}:{},...n.name?{name:n.name}:{},...n.groupFile?{groupFile:!0}:{},...n.mimeType?{mimeType:n.mimeType}:{},json:n.json},e)}}async function Dg(t){let{unlink:e}=await import("node:fs/promises");await Promise.all([e(t.pidFile).catch(()=>{}),e(t.portFile).catch(()=>{}),e(t.tokenFile).catch(()=>{})])}async function NT(t){let e=t.paths??F(),n=new bt(e),r=await n.probe();if(r.kind==="not-running")return process.stdout.write(`coze-bridge: not running
204
204
  `),1;if(r.kind==="stale")return await Dg(e),process.stdout.write(`coze-bridge: not running (cleaned stale state)
205
205
  `),1;let i=await n.request({method:"GET",path:"/status"});return process.stdout.write(`coze-bridge: running
206
206
  ${JSON.stringify(i.body,null,2)}
207
- `),0}async function Ng(t){let e=t.paths??F(),n=new bt(e),r=await Di(t),i=!1;if(r)try{await r.uninstall(),i=!0}catch(o){process.stderr.write(`coze-bridge: supervisor uninstall failed (continuing): ${String(o)}
207
+ `),0}async function Ng(t){let e=t.paths??F(),n=new bt(e),r=await Ni(t),i=!1;if(r)try{await r.uninstall(),i=!0}catch(o){process.stderr.write(`coze-bridge: supervisor uninstall failed (continuing): ${String(o)}
208
208
  `)}let s=await n.probe();if(s.kind==="not-running")return process.stdout.write(i?`coze-bridge: stopped
209
209
  `:`coze-bridge: not running
210
210
  `),0;if(s.kind==="stale")return await Dg(e),process.stdout.write(`coze-bridge: not running (cleaned stale state)
211
211
  `),0;try{return await n.request({method:"POST",path:"/shutdown"}),process.stdout.write(`coze-bridge: stopped
212
212
  `),0}catch(o){return(await n.probe()).kind!=="connected"?(process.stdout.write(`coze-bridge: stopped
213
213
  `),0):(process.stdout.write(`coze-bridge: stop failed: ${String(o)}
214
- `),1)}}async function NT(t){return await Ng(t),(t.spawnNpx??LT)(["-y","--ignore-existing","coze-bridge@latest","connect"])}function LT(t){return new Promise(e=>{let n=Fe("npx",t,{stdio:"inherit"});n.on("exit",r=>e(r??1)),n.on("error",r=>{process.stderr.write(`coze-bridge: spawn npx failed: ${String(r)}
215
- `),e(1)})})}async function FT(t){let e=new bt(t.paths);if((await e.probe()).kind==="not-running")return process.stdout.write(`coze-bridge: not running (start daemon first)
214
+ `),1)}}async function LT(t){return await Ng(t),(t.spawnNpx??FT)(["-y","--ignore-existing","coze-bridge@latest","connect"])}function FT(t){return new Promise(e=>{let n=Fe("npx",t,{stdio:"inherit"});n.on("exit",r=>e(r??1)),n.on("error",r=>{process.stderr.write(`coze-bridge: spawn npx failed: ${String(r)}
215
+ `),e(1)})})}async function MT(t){let e=new bt(t.paths);if((await e.probe()).kind==="not-running")return process.stdout.write(`coze-bridge: not running (start daemon first)
216
216
  `),1;try{let r=await e.request({method:"POST",path:"/refresh",timeoutMs:35e3});return r.status===200?(process.stdout.write(`coze-bridge: refreshed
217
217
  ${JSON.stringify(r.body,null,2)}
218
218
  `),0):(process.stderr.write(`coze-bridge: refresh failed: ${JSON.stringify(r.body)}
219
219
  `),1)}catch(r){return process.stderr.write(`coze-bridge: refresh failed: ${String(r)}
220
- `),1}}async function Di(t){if(t.supervisor){let s=t.supervisor,o={nodeBin:"",entry:"",logFile:"",homeDir:"",userName:""};return{platform:s.platform,install:a=>s.install(o,a),uninstall:()=>s.uninstall(o)}}if(t.skipSupervisor)return;let{getSupervisor:e,buildContext:n}=await Promise.resolve().then(()=>(Og(),xg)),r=e(),i=n();return{platform:r.platform,install:s=>r.install(i,s),uninstall:()=>r.uninstall(i)}}async function Lg(t,e){let n=await e.probe();if(n.kind==="connected")return n;let r=t.spawnDaemon??lg,i=t.waitTimeoutMs??15e3,s=t.sleep??HT,o=t.paths??F(),a=await Di(t);if(a&&(a.platform==="darwin"||a.platform==="linux")){try{await a.install({activate:!0});let c=await Pg(e,i,s);if(c.kind==="connected")return c;Bo.warn("supervisor \u8D77 daemon \u8D85\u65F6, \u56DE\u9000\u624B\u52A8 spawn (\u672C\u6B21\u65E0\u5D29\u6E83\u4FDD\u6D3B)",{waitMs:i})}catch(c){Bo.warn("supervisor \u63A5\u7BA1\u5931\u8D25, \u56DE\u9000\u624B\u52A8 spawn",{err:String(c)})}await a.uninstall().catch(()=>{}),await GT(o.pidFile,s)}else a&&await a.install({activate:!1}).catch(c=>process.stderr.write(`coze-bridge: \u81EA\u542F\u6CE8\u518C\u5931\u8D25(\u4E0D\u5F71\u54CD\u672C\u6B21): ${String(c)}
220
+ `),1}}async function Ni(t){if(t.supervisor){let s=t.supervisor,o={nodeBin:"",entry:"",logFile:"",homeDir:"",userName:""};return{platform:s.platform,install:a=>s.install(o,a),uninstall:()=>s.uninstall(o)}}if(t.skipSupervisor)return;let{getSupervisor:e,buildContext:n}=await Promise.resolve().then(()=>(Og(),xg)),r=e(),i=n();return{platform:r.platform,install:s=>r.install(i,s),uninstall:()=>r.uninstall(i)}}async function Lg(t,e){let n=await e.probe();if(n.kind==="connected")return n;let r=t.spawnDaemon??lg,i=t.waitTimeoutMs??15e3,s=t.sleep??jT,o=t.paths??F(),a=await Ni(t);if(a&&(a.platform==="darwin"||a.platform==="linux")){try{await a.install({activate:!0});let c=await Pg(e,i,s);if(c.kind==="connected")return c;zo.warn("supervisor \u8D77 daemon \u8D85\u65F6, \u56DE\u9000\u624B\u52A8 spawn (\u672C\u6B21\u65E0\u5D29\u6E83\u4FDD\u6D3B)",{waitMs:i})}catch(c){zo.warn("supervisor \u63A5\u7BA1\u5931\u8D25, \u56DE\u9000\u624B\u52A8 spawn",{err:String(c)})}await a.uninstall().catch(()=>{}),await HT(o.pidFile,s)}else a&&await a.install({activate:!1}).catch(c=>process.stderr.write(`coze-bridge: \u81EA\u542F\u6CE8\u518C\u5931\u8D25(\u4E0D\u5F71\u54CD\u672C\u6B21): ${String(c)}
221
221
  `));return process.stdout.write(`coze-bridge: starting daemon...
222
- `),await r({paths:t.paths}),Pg(e,i,s)}async function MT(t){let e=new bt(t.paths);if((await e.probe()).kind==="connected"){process.stdout.write(`coze-bridge: stopping daemon...
222
+ `),await r({paths:t.paths}),Pg(e,i,s)}async function BT(t){let e=new bt(t.paths);if((await e.probe()).kind==="connected"){process.stdout.write(`coze-bridge: stopping daemon...
223
223
  `);try{await e.request({method:"POST",path:"/shutdown"})}catch(o){process.stderr.write(`coze-bridge: stop failed (continuing): ${String(o)}
224
- `)}await new Promise(o=>setTimeout(o,500))}let r=await Di(t);if(r)try{await r.uninstall(),process.stdout.write(`coze-bridge: ${r.platform} supervisor unregistered
224
+ `)}await new Promise(o=>setTimeout(o,500))}let r=await Ni(t);if(r)try{await r.uninstall(),process.stdout.write(`coze-bridge: ${r.platform} supervisor unregistered
225
225
  `)}catch(o){process.stderr.write(`coze-bridge: supervisor uninstall failed (continuing): ${String(o)}
226
226
  `)}let i=t.paths??F(),{rm:s}=await import("node:fs/promises");try{await s(i.bridgeRoot,{recursive:!0,force:!0}),process.stdout.write(`coze-bridge: removed ${i.bridgeRoot}
227
227
  `)}catch(o){return process.stderr.write(`coze-bridge: remove failed: ${String(o)}
228
228
  `),1}return process.stdout.write(`coze-bridge: purged (agents workspaces preserved under ~/.coze/agents)
229
- `),0}async function BT(t){let e=await Di(t);if(!e)return 0;try{return process.stdout.write(`coze-bridge: installing ${e.platform} supervisor...
229
+ `),0}async function UT(t){let e=await Ni(t);if(!e)return 0;try{return process.stdout.write(`coze-bridge: installing ${e.platform} supervisor...
230
230
  `),await e.install(),process.stdout.write(`coze-bridge: supervisor installed (daemon will auto-start on login)
231
231
  `),0}catch(n){return process.stderr.write(`coze-bridge: service install failed: ${String(n)}
232
- `),1}}async function UT(t){let e=await Di(t);if(!e)return 0;try{return await e.uninstall(),process.stdout.write(`coze-bridge: ${e.platform} supervisor unregistered
232
+ `),1}}async function zT(t){let e=await Ni(t);if(!e)return 0;try{return await e.uninstall(),process.stdout.write(`coze-bridge: ${e.platform} supervisor unregistered
233
233
  `),0}catch(n){return process.stderr.write(`coze-bridge: service uninstall failed: ${String(n)}
234
- `),1}}async function zT(t,e,n,r={},i){let s=new bt(n.paths);if(!n.skipDistInstall){let c=await kl({paths:n.paths});c.kind==="version-changed"?(process.stdout.write(`coze-bridge: upgraded ${c.fromVersion} \u2192 ${c.toVersion}
234
+ `),1}}async function $T(t,e,n,r={},i){let s=new bt(n.paths);if(!n.skipDistInstall){let c=await Al({paths:n.paths});c.kind==="version-changed"?(process.stdout.write(`coze-bridge: upgraded ${c.fromVersion} \u2192 ${c.toVersion}
235
235
  `),(await s.probe()).kind==="connected"&&(await s.request({method:"POST",path:"/shutdown"}).catch(()=>{}),await new Promise(d=>setTimeout(d,500)))):c.kind==="first-install"&&process.stdout.write(`coze-bridge: installed ${c.libVersion}
236
236
  `)}let o=await Lg(n,s);if(o.kind!=="connected")return process.stderr.write(`coze-bridge: daemon did not come up: ${o.kind}
237
237
  `),1;let a={privatecode:t,pairing_code:e};r.env&&(a.env=r.env),r.handshakeUrl&&(a.handshake_url=r.handshakeUrl),r.frontierUrl&&(a.frontier_url=r.frontierUrl),r.mockScenario&&(a.mock_scenario=r.mockScenario),i&&(a.agent_id=i);try{let c=await s.request({method:"POST",path:"/pair",body:a,timeoutMs:35e3});if(c.status===200&&c.body?.ok){let l=c.body.agent;return l&&!l.ok?(process.stderr.write(`coze-bridge: paired but agent ensure failed (agentId=${l.agentId}): ${l.note}
238
238
  `),1):(process.stdout.write(`\u5DF2\u914D\u5BF9\u8FDE\u63A5\u5B8C\u6210\uFF0C\u8BF7\u8FD4\u56DE\u5230 coze \u5E73\u53F0\u4E0A\u70B9\u51FB "\u6211\u5DF2\u6267\u884C"
239
239
  `),0)}return process.stderr.write(`coze-bridge: pair failed: ${JSON.stringify(c.body)}
240
240
  `),1}catch(c){return process.stderr.write(`coze-bridge: pair failed: ${String(c)}
241
- `),1}}async function $T(t,e,n={}){let r=e.paths??F(),i=t??await Io(r);if(!i)return process.stderr.write("coze-bridge: \u627E\u4E0D\u5230 patToken \u2014 \u5148\u8DD1\u4E00\u6B21 `coze-bridge --pat-token=<sat_xxx> --pair-code=<xxx>` \u914D\u5BF9, \u6216\u672C\u6B21\u7528 `--pat-token` \u6307\u5B9A\n"),1;let s=new bt(e.paths);if(!e.skipDistInstall){let c=await kl({paths:e.paths});c.kind==="version-changed"?(process.stdout.write(`coze-bridge: upgraded ${c.fromVersion} \u2192 ${c.toVersion}
241
+ `),1}}async function GT(t,e,n={}){let r=e.paths??F(),i=t??await To(r);if(!i)return process.stderr.write("coze-bridge: \u627E\u4E0D\u5230 patToken \u2014 \u5148\u8DD1\u4E00\u6B21 `coze-bridge --pat-token=<sat_xxx> --pair-code=<xxx>` \u914D\u5BF9, \u6216\u672C\u6B21\u7528 `--pat-token` \u6307\u5B9A\n"),1;let s=new bt(e.paths);if(!e.skipDistInstall){let c=await Al({paths:e.paths});c.kind==="version-changed"?(process.stdout.write(`coze-bridge: upgraded ${c.fromVersion} \u2192 ${c.toVersion}
242
242
  `),(await s.probe()).kind==="connected"&&(await s.request({method:"POST",path:"/shutdown"}).catch(()=>{}),await new Promise(d=>setTimeout(d,500)))):c.kind==="first-install"&&process.stdout.write(`coze-bridge: installed ${c.libVersion}
243
243
  `)}let o=await Lg(e,s);if(o.kind!=="connected")return process.stderr.write(`coze-bridge: daemon did not come up: ${o.kind}
244
244
  `),1;let a={privatecode:i};n.env&&(a.env=n.env),n.handshakeUrl&&(a.handshake_url=n.handshakeUrl),n.frontierUrl&&(a.frontier_url=n.frontierUrl),n.mockScenario&&(a.mock_scenario=n.mockScenario);try{let c=await s.request({method:"POST",path:"/connect",body:a,timeoutMs:35e3});return c.status===200&&c.body?.ok?(process.stdout.write(`coze-bridge: connected (${c.body.note??"ok"})
245
- `),await xi(i,r).catch(l=>Bo.warn("writePatToken after connect failed (ignored)",{err:String(l)})),0):(process.stderr.write(`coze-bridge: connect failed: ${JSON.stringify(c.body)}
245
+ `),await Oi(i,r).catch(l=>zo.warn("writePatToken after connect failed (ignored)",{err:String(l)})),0):(process.stderr.write(`coze-bridge: connect failed: ${JSON.stringify(c.body)}
246
246
  `),1)}catch(c){return process.stderr.write(`coze-bridge: connect failed: ${String(c)}
247
- `),1}}async function Pg(t,e,n){let r=Date.now()+e;for(;Date.now()<r;){let i=await t.probe(500);if(i.kind==="connected")return i;await n(200)}return t.probe(500)}async function GT(t,e,n=15,r=200){let{readFile:i}=await import("node:fs/promises");for(let s=0;s<n;s++){let o;try{o=await i(t,"utf8")}catch{return}let a=Number.parseInt(o.trim(),10);if(!Number.isFinite(a)||a<=0||!Ro(a))return;await e(r)}}function HT(t){return new Promise(e=>setTimeout(e,t))}L();!process.argv.includes("--daemon")&&!process.env.COZE_BRIDGE_LOG_LEVEL&&Fl("warn");Cg(process.argv).then(t=>process.exit(t),t=>{process.stderr.write(`fatal: ${t instanceof Error?t.stack??t.message:String(t)}
247
+ `),1}}async function Pg(t,e,n){let r=Date.now()+e;for(;Date.now()<r;){let i=await t.probe(500);if(i.kind==="connected")return i;await n(200)}return t.probe(500)}async function HT(t,e,n=60,r=200){let{readFile:i}=await import("node:fs/promises");for(let s=0;s<n;s++){let o;try{o=await i(t,"utf8")}catch{return}let a=Number.parseInt(o.trim(),10);if(!Number.isFinite(a)||a<=0||!ko(a))return;await e(r)}}function jT(t){return new Promise(e=>setTimeout(e,t))}L();!process.argv.includes("--daemon")&&!process.env.COZE_BRIDGE_LOG_LEVEL&&Fl("warn");Cg(process.argv).then(t=>process.exit(t),t=>{process.stderr.write(`fatal: ${t instanceof Error?t.stack??t.message:String(t)}
248
248
  `),process.exit(1)});