phala 1.1.18 → 1.1.20-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/api/index.js CHANGED
@@ -1,49 +1,44 @@
1
1
  import { createRequire } from 'module';const require = createRequire(import.meta.url);
2
- var is=Object.create;var ln=Object.defineProperty;var cs=Object.getOwnPropertyDescriptor;var ls=Object.getOwnPropertyNames;var us=Object.getPrototypeOf,ps=Object.prototype.hasOwnProperty;var Oe=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,n)=>(typeof require<"u"?require:t)[n]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')});var ge=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var ds=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of ls(t))!ps.call(e,s)&&s!==n&&ln(e,s,{get:()=>t[s],enumerable:!(r=cs(t,s))||r.enumerable});return e};var ct=(e,t,n)=>(n=e!=null?is(us(e)):{},ds(t||!e||!e.__esModule?ln(n,"default",{value:e,enumerable:!0}):n,e));var pn=ge((qu,un)=>{var Me=1e3,Ke=Me*60,Ge=Ke*60,De=Ge*24,ms=De*7,fs=De*365.25;un.exports=function(e,t){t=t||{};var n=typeof e;if(n==="string"&&e.length>0)return gs(e);if(n==="number"&&isFinite(e))return t.long?bs(e):hs(e);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(e))};function gs(e){if(e=String(e),!(e.length>100)){var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(e);if(t){var n=parseFloat(t[1]),r=(t[2]||"ms").toLowerCase();switch(r){case"years":case"year":case"yrs":case"yr":case"y":return n*fs;case"weeks":case"week":case"w":return n*ms;case"days":case"day":case"d":return n*De;case"hours":case"hour":case"hrs":case"hr":case"h":return n*Ge;case"minutes":case"minute":case"mins":case"min":case"m":return n*Ke;case"seconds":case"second":case"secs":case"sec":case"s":return n*Me;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return n;default:return}}}}function hs(e){var t=Math.abs(e);return t>=De?Math.round(e/De)+"d":t>=Ge?Math.round(e/Ge)+"h":t>=Ke?Math.round(e/Ke)+"m":t>=Me?Math.round(e/Me)+"s":e+"ms"}function bs(e){var t=Math.abs(e);return t>=De?ht(e,t,De,"day"):t>=Ge?ht(e,t,Ge,"hour"):t>=Ke?ht(e,t,Ke,"minute"):t>=Me?ht(e,t,Me,"second"):e+" ms"}function ht(e,t,n,r){var s=t>=n*1.5;return Math.round(e/n)+" "+r+(s?"s":"")}});var Ot=ge((Fu,dn)=>{function vs(e){n.debug=n,n.default=n,n.coerce=l,n.disable=a,n.enable=s,n.enabled=i,n.humanize=pn(),n.destroy=m,Object.keys(e).forEach(u=>{n[u]=e[u]}),n.names=[],n.skips=[],n.formatters={};function t(u){let f=0;for(let g=0;g<u.length;g++)f=(f<<5)-f+u.charCodeAt(g),f|=0;return n.colors[Math.abs(f)%n.colors.length]}n.selectColor=t;function n(u){let f,g=null,y,S;function x(...N){if(!x.enabled)return;let Y=x,fe=Number(new Date),Pe=fe-(f||fe);Y.diff=Pe,Y.prev=f,Y.curr=fe,f=fe,N[0]=n.coerce(N[0]),typeof N[0]!="string"&&N.unshift("%O");let Se=0;N[0]=N[0].replace(/%([a-zA-Z%])/g,(Ve,gt)=>{if(Ve==="%%")return"%";Se++;let cn=n.formatters[gt];if(typeof cn=="function"){let as=N[Se];Ve=cn.call(Y,as),N.splice(Se,1),Se--}return Ve}),n.formatArgs.call(Y,N),(Y.log||n.log).apply(Y,N)}return x.namespace=u,x.useColors=n.useColors(),x.color=n.selectColor(u),x.extend=r,x.destroy=n.destroy,Object.defineProperty(x,"enabled",{enumerable:!0,configurable:!1,get:()=>g!==null?g:(y!==n.namespaces&&(y=n.namespaces,S=n.enabled(u)),S),set:N=>{g=N}}),typeof n.init=="function"&&n.init(x),x}function r(u,f){let g=n(this.namespace+(typeof f>"u"?":":f)+u);return g.log=this.log,g}function s(u){n.save(u),n.namespaces=u,n.names=[],n.skips=[];let f=(typeof u=="string"?u:"").trim().replace(/\s+/g,",").split(",").filter(Boolean);for(let g of f)g[0]==="-"?n.skips.push(g.slice(1)):n.names.push(g)}function o(u,f){let g=0,y=0,S=-1,x=0;for(;g<u.length;)if(y<f.length&&(f[y]===u[g]||f[y]==="*"))f[y]==="*"?(S=y,x=g,y++):(g++,y++);else if(S!==-1)y=S+1,x++,g=x;else return!1;for(;y<f.length&&f[y]==="*";)y++;return y===f.length}function a(){let u=[...n.names,...n.skips.map(f=>"-"+f)].join(",");return n.enable(""),u}function i(u){for(let f of n.skips)if(o(u,f))return!1;for(let f of n.names)if(o(u,f))return!0;return!1}function l(u){return u instanceof Error?u.stack||u.message:u}function m(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return n.enable(n.load()),n}dn.exports=vs});var mn=ge((ie,bt)=>{ie.formatArgs=_s;ie.save=ws;ie.load=Cs;ie.useColors=ys;ie.storage=ks();ie.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();ie.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function ys(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let e;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(e=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(e[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function _s(e){if(e[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+e[0]+(this.useColors?"%c ":" ")+"+"+bt.exports.humanize(this.diff),!this.useColors)return;let t="color: "+this.color;e.splice(1,0,t,"color: inherit");let n=0,r=0;e[0].replace(/%[a-zA-Z%]/g,s=>{s!=="%%"&&(n++,s==="%c"&&(r=n))}),e.splice(r,0,t)}ie.log=console.debug||console.log||(()=>{});function ws(e){try{e?ie.storage.setItem("debug",e):ie.storage.removeItem("debug")}catch{}}function Cs(){let e;try{e=ie.storage.getItem("debug")||ie.storage.getItem("DEBUG")}catch{}return!e&&typeof process<"u"&&"env"in process&&(e=process.env.DEBUG),e}function ks(){try{return localStorage}catch{}}bt.exports=Ot()(ie);var{formatters:Ss}=bt.exports;Ss.j=function(e){try{return JSON.stringify(e)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var gn=ge((M,yt)=>{var Es=Oe("tty"),vt=Oe("util");M.init=js;M.log=Rs;M.formatArgs=Is;M.save=Ts;M.load=Ps;M.useColors=As;M.destroy=vt.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");M.colors=[6,2,3,4,5,1];try{let e=Oe("supports-color");e&&(e.stderr||e).level>=2&&(M.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}M.inspectOpts=Object.keys(process.env).filter(e=>/^debug_/i.test(e)).reduce((e,t)=>{let n=t.substring(6).toLowerCase().replace(/_([a-z])/g,(s,o)=>o.toUpperCase()),r=process.env[t];return/^(yes|on|true|enabled)$/i.test(r)?r=!0:/^(no|off|false|disabled)$/i.test(r)?r=!1:r==="null"?r=null:r=Number(r),e[n]=r,e},{});function As(){return"colors"in M.inspectOpts?!!M.inspectOpts.colors:Es.isatty(process.stderr.fd)}function Is(e){let{namespace:t,useColors:n}=this;if(n){let r=this.color,s="\x1B[3"+(r<8?r:"8;5;"+r),o=` ${s};1m${t} \x1B[0m`;e[0]=o+e[0].split(`
2
+ var Rr=Object.create;var Mt=Object.defineProperty;var xr=Object.getOwnPropertyDescriptor;var Tr=Object.getOwnPropertyNames;var Pr=Object.getPrototypeOf,jr=Object.prototype.hasOwnProperty;var _t=(e=>typeof require<"u"?require:typeof Proxy<"u"?new Proxy(e,{get:(t,n)=>(typeof require<"u"?require:t)[n]}):e)(function(e){if(typeof require<"u")return require.apply(this,arguments);throw Error('Dynamic require of "'+e+'" is not supported')});var tt=(e,t)=>()=>(t||e((t={exports:{}}).exports,t),t.exports);var $r=(e,t,n,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let s of Tr(t))!jr.call(e,s)&&s!==n&&Mt(e,s,{get:()=>t[s],enumerable:!(r=xr(t,s))||r.enumerable});return e};var qr=(e,t,n)=>(n=e!=null?Rr(Pr(e)):{},$r(t||!e||!e.__esModule?Mt(n,"default",{value:e,enumerable:!0}):n,e));var Ht=tt((Pl,Kt)=>{var Fe=1e3,Ue=Fe*60,Le=Ue*60,qe=Le*24,Or=qe*7,Nr=qe*365.25;Kt.exports=function(e,t){t=t||{};var n=typeof e;if(n==="string"&&e.length>0)return zr(e);if(n==="number"&&isFinite(e))return t.long?Ur(e):Fr(e);throw new Error("val is not a non-empty string or a valid number. val="+JSON.stringify(e))};function zr(e){if(e=String(e),!(e.length>100)){var t=/^(-?(?:\d+)?\.?\d+) *(milliseconds?|msecs?|ms|seconds?|secs?|s|minutes?|mins?|m|hours?|hrs?|h|days?|d|weeks?|w|years?|yrs?|y)?$/i.exec(e);if(t){var n=parseFloat(t[1]),r=(t[2]||"ms").toLowerCase();switch(r){case"years":case"year":case"yrs":case"yr":case"y":return n*Nr;case"weeks":case"week":case"w":return n*Or;case"days":case"day":case"d":return n*qe;case"hours":case"hour":case"hrs":case"hr":case"h":return n*Le;case"minutes":case"minute":case"mins":case"min":case"m":return n*Ue;case"seconds":case"second":case"secs":case"sec":case"s":return n*Fe;case"milliseconds":case"millisecond":case"msecs":case"msec":case"ms":return n;default:return}}}}function Fr(e){var t=Math.abs(e);return t>=qe?Math.round(e/qe)+"d":t>=Le?Math.round(e/Le)+"h":t>=Ue?Math.round(e/Ue)+"m":t>=Fe?Math.round(e/Fe)+"s":e+"ms"}function Ur(e){var t=Math.abs(e);return t>=qe?at(e,t,qe,"day"):t>=Le?at(e,t,Le,"hour"):t>=Ue?at(e,t,Ue,"minute"):t>=Fe?at(e,t,Fe,"second"):e+" ms"}function at(e,t,n,r){var s=t>=n*1.5;return Math.round(e/n)+" "+r+(s?"s":"")}});var wt=tt((jl,Gt)=>{function Lr(e){n.debug=n,n.default=n,n.coerce=u,n.disable=c,n.enable=s,n.enabled=i,n.humanize=Ht(),n.destroy=f,Object.keys(e).forEach(m=>{n[m]=e[m]}),n.names=[],n.skips=[],n.formatters={};function t(m){let d=0;for(let h=0;h<m.length;h++)d=(d<<5)-d+m.charCodeAt(h),d|=0;return n.colors[Math.abs(d)%n.colors.length]}n.selectColor=t;function n(m){let d,h=null,_,k;function R(...q){if(!R.enabled)return;let te=R,fe=Number(new Date),Ie=fe-(d||fe);te.diff=Ie,te.prev=d,te.curr=fe,d=fe,q[0]=n.coerce(q[0]),typeof q[0]!="string"&&q.unshift("%O");let Ce=0;q[0]=q[0].replace(/%([a-zA-Z%])/g,(ze,ot)=>{if(ze==="%%")return"%";Ce++;let Vt=n.formatters[ot];if(typeof Vt=="function"){let Ir=q[Ce];ze=Vt.call(te,Ir),q.splice(Ce,1),Ce--}return ze}),n.formatArgs.call(te,q),(te.log||n.log).apply(te,q)}return R.namespace=m,R.useColors=n.useColors(),R.color=n.selectColor(m),R.extend=r,R.destroy=n.destroy,Object.defineProperty(R,"enabled",{enumerable:!0,configurable:!1,get:()=>h!==null?h:(_!==n.namespaces&&(_=n.namespaces,k=n.enabled(m)),k),set:q=>{h=q}}),typeof n.init=="function"&&n.init(R),R}function r(m,d){let h=n(this.namespace+(typeof d>"u"?":":d)+m);return h.log=this.log,h}function s(m){n.save(m),n.namespaces=m,n.names=[],n.skips=[];let d=(typeof m=="string"?m:"").trim().replace(/\s+/g,",").split(",").filter(Boolean);for(let h of d)h[0]==="-"?n.skips.push(h.slice(1)):n.names.push(h)}function o(m,d){let h=0,_=0,k=-1,R=0;for(;h<m.length;)if(_<d.length&&(d[_]===m[h]||d[_]==="*"))d[_]==="*"?(k=_,R=h,_++):(h++,_++);else if(k!==-1)_=k+1,R++,h=R;else return!1;for(;_<d.length&&d[_]==="*";)_++;return _===d.length}function c(){let m=[...n.names,...n.skips.map(d=>"-"+d)].join(",");return n.enable(""),m}function i(m){for(let d of n.skips)if(o(m,d))return!1;for(let d of n.names)if(o(m,d))return!0;return!1}function u(m){return m instanceof Error?m.stack||m.message:m}function f(){console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.")}return n.enable(n.load()),n}Gt.exports=Lr});var Bt=tt((ae,it)=>{ae.formatArgs=Vr;ae.save=Mr;ae.load=Kr;ae.useColors=Dr;ae.storage=Hr();ae.destroy=(()=>{let e=!1;return()=>{e||(e=!0,console.warn("Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`."))}})();ae.colors=["#0000CC","#0000FF","#0033CC","#0033FF","#0066CC","#0066FF","#0099CC","#0099FF","#00CC00","#00CC33","#00CC66","#00CC99","#00CCCC","#00CCFF","#3300CC","#3300FF","#3333CC","#3333FF","#3366CC","#3366FF","#3399CC","#3399FF","#33CC00","#33CC33","#33CC66","#33CC99","#33CCCC","#33CCFF","#6600CC","#6600FF","#6633CC","#6633FF","#66CC00","#66CC33","#9900CC","#9900FF","#9933CC","#9933FF","#99CC00","#99CC33","#CC0000","#CC0033","#CC0066","#CC0099","#CC00CC","#CC00FF","#CC3300","#CC3333","#CC3366","#CC3399","#CC33CC","#CC33FF","#CC6600","#CC6633","#CC9900","#CC9933","#CCCC00","#CCCC33","#FF0000","#FF0033","#FF0066","#FF0099","#FF00CC","#FF00FF","#FF3300","#FF3333","#FF3366","#FF3399","#FF33CC","#FF33FF","#FF6600","#FF6633","#FF9900","#FF9933","#FFCC00","#FFCC33"];function Dr(){if(typeof window<"u"&&window.process&&(window.process.type==="renderer"||window.process.__nwjs))return!0;if(typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/(edge|trident)\/(\d+)/))return!1;let e;return typeof document<"u"&&document.documentElement&&document.documentElement.style&&document.documentElement.style.WebkitAppearance||typeof window<"u"&&window.console&&(window.console.firebug||window.console.exception&&window.console.table)||typeof navigator<"u"&&navigator.userAgent&&(e=navigator.userAgent.toLowerCase().match(/firefox\/(\d+)/))&&parseInt(e[1],10)>=31||typeof navigator<"u"&&navigator.userAgent&&navigator.userAgent.toLowerCase().match(/applewebkit\/(\d+)/)}function Vr(e){if(e[0]=(this.useColors?"%c":"")+this.namespace+(this.useColors?" %c":" ")+e[0]+(this.useColors?"%c ":" ")+"+"+it.exports.humanize(this.diff),!this.useColors)return;let t="color: "+this.color;e.splice(1,0,t,"color: inherit");let n=0,r=0;e[0].replace(/%[a-zA-Z%]/g,s=>{s!=="%%"&&(n++,s==="%c"&&(r=n))}),e.splice(r,0,t)}ae.log=console.debug||console.log||(()=>{});function Mr(e){try{e?ae.storage.setItem("debug",e):ae.storage.removeItem("debug")}catch{}}function Kr(){let e;try{e=ae.storage.getItem("debug")||ae.storage.getItem("DEBUG")}catch{}return!e&&typeof process<"u"&&"env"in process&&(e=process.env.DEBUG),e}function Hr(){try{return localStorage}catch{}}it.exports=wt()(ae);var{formatters:Gr}=it.exports;Gr.j=function(e){try{return JSON.stringify(e)}catch(t){return"[UnexpectedJSONParseError]: "+t.message}}});var Xt=tt((G,lt)=>{var Br=_t("tty"),ct=_t("util");G.init=es;G.log=Zr;G.formatArgs=Xr;G.save=Qr;G.load=Yr;G.useColors=Wr;G.destroy=ct.deprecate(()=>{},"Instance method `debug.destroy()` is deprecated and no longer does anything. It will be removed in the next major version of `debug`.");G.colors=[6,2,3,4,5,1];try{let e=_t("supports-color");e&&(e.stderr||e).level>=2&&(G.colors=[20,21,26,27,32,33,38,39,40,41,42,43,44,45,56,57,62,63,68,69,74,75,76,77,78,79,80,81,92,93,98,99,112,113,128,129,134,135,148,149,160,161,162,163,164,165,166,167,168,169,170,171,172,173,178,179,184,185,196,197,198,199,200,201,202,203,204,205,206,207,208,209,214,215,220,221])}catch{}G.inspectOpts=Object.keys(process.env).filter(e=>/^debug_/i.test(e)).reduce((e,t)=>{let n=t.substring(6).toLowerCase().replace(/_([a-z])/g,(s,o)=>o.toUpperCase()),r=process.env[t];return/^(yes|on|true|enabled)$/i.test(r)?r=!0:/^(no|off|false|disabled)$/i.test(r)?r=!1:r==="null"?r=null:r=Number(r),e[n]=r,e},{});function Wr(){return"colors"in G.inspectOpts?!!G.inspectOpts.colors:Br.isatty(process.stderr.fd)}function Xr(e){let{namespace:t,useColors:n}=this;if(n){let r=this.color,s="\x1B[3"+(r<8?r:"8;5;"+r),o=` ${s};1m${t} \x1B[0m`;e[0]=o+e[0].split(`
3
3
  `).join(`
4
- `+o),e.push(s+"m+"+yt.exports.humanize(this.diff)+"\x1B[0m")}else e[0]=xs()+t+" "+e[0]}function xs(){return M.inspectOpts.hideDate?"":new Date().toISOString()+" "}function Rs(...e){return process.stderr.write(vt.formatWithOptions(M.inspectOpts,...e)+`
5
- `)}function Ts(e){e?process.env.DEBUG=e:delete process.env.DEBUG}function Ps(){return process.env.DEBUG}function js(e){e.inspectOpts={};let t=Object.keys(M.inspectOpts);for(let n=0;n<t.length;n++)e.inspectOpts[t[n]]=M.inspectOpts[t[n]]}yt.exports=Ot()(M);var{formatters:fn}=yt.exports;fn.o=function(e){return this.inspectOpts.colors=this.useColors,vt.inspect(e,this.inspectOpts).split(`
6
- `).map(t=>t.trim()).join(" ")};fn.O=function(e){return this.inspectOpts.colors=this.useColors,vt.inspect(e,this.inspectOpts)}});var hn=ge((Uu,$t)=>{typeof process>"u"||process.type==="renderer"||process.browser===!0||process.__nwjs?$t.exports=mn():$t.exports=gn()});var qt=ge(lt=>{"use strict";var Os=lt&&lt.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(lt,"__esModule",{value:!0});lt.encryptEnvVars=Ns;var Lt=Oe("@noble/curves/ed25519"),Nt=Os(Oe("crypto"));function $s(e){var t,n;return e=e.startsWith("0x")?e.slice(2):e,new Uint8Array((n=(t=e.match(/.{1,2}/g))===null||t===void 0?void 0:t.map(r=>parseInt(r,16)))!==null&&n!==void 0?n:[])}function Ls(e){return Array.from(e).map(t=>t.toString(16).padStart(2,"0")).join("")}async function Ns(e,t){let n=JSON.stringify({env:e}),r=Lt.x25519.utils.randomPrivateKey(),s=Lt.x25519.getPublicKey(r),o=$s(t),a=Lt.x25519.getSharedSecret(r,o),i=await Nt.default.subtle.importKey("raw",a,{name:"AES-GCM",length:256},!0,["encrypt"]),l=Nt.default.getRandomValues(new Uint8Array(12)),m=await Nt.default.subtle.encrypt({name:"AES-GCM",iv:l},i,new TextEncoder().encode(n)),u=new Uint8Array(s.length+l.length+m.byteLength);return u.set(s),u.set(l,s.length),u.set(new Uint8Array(m),s.length+l.length),Ls(u)}});var vn=ge(ut=>{"use strict";var qs=ut&&ut.__importDefault||function(e){return e&&e.__esModule?e:{default:e}};Object.defineProperty(ut,"__esModule",{value:!0});ut.getComposeHash=Ds;var Fs=qs(Oe("crypto"));function Ft(e){return e==null?e:Array.isArray(e)?e.map(Ft):e&&typeof e=="object"&&e.constructor===Object?Object.keys(e).sort().reduce((t,n)=>{let r=e[n];return t[n]=Ft(r),t},{}):e}function Us(e){let t={...e};return t.runner==="bash"&&"docker_compose_file"in t?delete t.docker_compose_file:t.runner==="docker-compose"&&"bash_script"in t&&delete t.bash_script,"pre_launch_script"in t&&!t.pre_launch_script&&delete t.pre_launch_script,t}function zs(e){let t=Ft(e);return JSON.stringify(t,(n,r)=>typeof r=="number"&&(isNaN(r)||!isFinite(r))?null:r)}function Ds(e,t=!1){t&&(e=Us(e));let n=zs(e);return Fs.default.createHash("sha256").update(n,"utf8").digest("hex")}});var zn=ge(w=>{"use strict";Object.defineProperty(w,"__esModule",{value:!0});w.toBig=w.shrSL=w.shrSH=w.rotrSL=w.rotrSH=w.rotrBL=w.rotrBH=w.rotr32L=w.rotr32H=w.rotlSL=w.rotlSH=w.rotlBL=w.rotlBH=w.add5L=w.add5H=w.add4L=w.add4H=w.add3L=w.add3H=void 0;w.add=On;w.fromBig=zt;w.split=yn;var _t=BigInt(2**32-1),Ut=BigInt(32);function zt(e,t=!1){return t?{h:Number(e&_t),l:Number(e>>Ut&_t)}:{h:Number(e>>Ut&_t)|0,l:Number(e&_t)|0}}function yn(e,t=!1){let n=e.length,r=new Uint32Array(n),s=new Uint32Array(n);for(let o=0;o<n;o++){let{h:a,l:i}=zt(e[o],t);[r[o],s[o]]=[a,i]}return[r,s]}var _n=(e,t)=>BigInt(e>>>0)<<Ut|BigInt(t>>>0);w.toBig=_n;var wn=(e,t,n)=>e>>>n;w.shrSH=wn;var Cn=(e,t,n)=>e<<32-n|t>>>n;w.shrSL=Cn;var kn=(e,t,n)=>e>>>n|t<<32-n;w.rotrSH=kn;var Sn=(e,t,n)=>e<<32-n|t>>>n;w.rotrSL=Sn;var En=(e,t,n)=>e<<64-n|t>>>n-32;w.rotrBH=En;var An=(e,t,n)=>e>>>n-32|t<<64-n;w.rotrBL=An;var In=(e,t)=>t;w.rotr32H=In;var xn=(e,t)=>e;w.rotr32L=xn;var Rn=(e,t,n)=>e<<n|t>>>32-n;w.rotlSH=Rn;var Tn=(e,t,n)=>t<<n|e>>>32-n;w.rotlSL=Tn;var Pn=(e,t,n)=>t<<n-32|e>>>64-n;w.rotlBH=Pn;var jn=(e,t,n)=>e<<n-32|t>>>64-n;w.rotlBL=jn;function On(e,t,n,r){let s=(t>>>0)+(r>>>0);return{h:e+n+(s/2**32|0)|0,l:s|0}}var $n=(e,t,n)=>(e>>>0)+(t>>>0)+(n>>>0);w.add3L=$n;var Ln=(e,t,n,r)=>t+n+r+(e/2**32|0)|0;w.add3H=Ln;var Nn=(e,t,n,r)=>(e>>>0)+(t>>>0)+(n>>>0)+(r>>>0);w.add4L=Nn;var qn=(e,t,n,r,s)=>t+n+r+s+(e/2**32|0)|0;w.add4H=qn;var Fn=(e,t,n,r,s)=>(e>>>0)+(t>>>0)+(n>>>0)+(r>>>0)+(s>>>0);w.add5L=Fn;var Un=(e,t,n,r,s,o)=>t+n+r+s+o+(e/2**32|0)|0;w.add5H=Un;var Hs={fromBig:zt,split:yn,toBig:_n,shrSH:wn,shrSL:Cn,rotrSH:kn,rotrSL:Sn,rotrBH:En,rotrBL:An,rotr32H:In,rotr32L:xn,rotlSH:Rn,rotlSL:Tn,rotlBH:Pn,rotlBL:jn,add:On,add3L:$n,add3H:Ln,add4L:Nn,add4H:qn,add5H:Un,add5L:Fn};w.default=Hs});var Dn=ge(wt=>{"use strict";Object.defineProperty(wt,"__esModule",{value:!0});wt.crypto=void 0;var $e=Oe("crypto");wt.crypto=$e&&typeof $e=="object"&&"webcrypto"in $e?$e.webcrypto:$e&&typeof $e=="object"&&"randomBytes"in $e?$e:void 0});var Xn=ge(v=>{"use strict";Object.defineProperty(v,"__esModule",{value:!0});v.wrapXOFConstructorWithOpts=v.wrapConstructorWithOpts=v.wrapConstructor=v.Hash=v.nextTick=v.swap32IfBE=v.byteSwapIfBE=v.swap8IfBE=v.isLE=void 0;v.isBytes=Bn;v.anumber=Dt;v.abytes=Xe;v.ahash=Bs;v.aexists=Vs;v.aoutput=Ms;v.u8=Ks;v.u32=Gs;v.clean=Ws;v.createView=Xs;v.rotr=Js;v.rotl=Zs;v.byteSwap=Bt;v.byteSwap32=Vn;v.bytesToHex=Ys;v.hexToBytes=eo;v.asyncLoop=no;v.utf8ToBytes=Vt;v.bytesToUtf8=ro;v.toBytes=Ct;v.kdfInputToBytes=so;v.concatBytes=oo;v.checkOpts=ao;v.createHasher=Kn;v.createOptHasher=Gn;v.createXOFer=Wn;v.randomBytes=io;var We=Dn();function Bn(e){return e instanceof Uint8Array||ArrayBuffer.isView(e)&&e.constructor.name==="Uint8Array"}function Dt(e){if(!Number.isSafeInteger(e)||e<0)throw new Error("positive integer expected, got "+e)}function Xe(e,...t){if(!Bn(e))throw new Error("Uint8Array expected");if(t.length>0&&!t.includes(e.length))throw new Error("Uint8Array expected of length "+t+", got length="+e.length)}function Bs(e){if(typeof e!="function"||typeof e.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");Dt(e.outputLen),Dt(e.blockLen)}function Vs(e,t=!0){if(e.destroyed)throw new Error("Hash instance has been destroyed");if(t&&e.finished)throw new Error("Hash#digest() has already been called")}function Ms(e,t){Xe(e);let n=t.outputLen;if(e.length<n)throw new Error("digestInto() expects output buffer of length at least "+n)}function Ks(e){return new Uint8Array(e.buffer,e.byteOffset,e.byteLength)}function Gs(e){return new Uint32Array(e.buffer,e.byteOffset,Math.floor(e.byteLength/4))}function Ws(...e){for(let t=0;t<e.length;t++)e[t].fill(0)}function Xs(e){return new DataView(e.buffer,e.byteOffset,e.byteLength)}function Js(e,t){return e<<32-t|e>>>t}function Zs(e,t){return e<<t|e>>>32-t>>>0}v.isLE=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Bt(e){return e<<24&4278190080|e<<8&16711680|e>>>8&65280|e>>>24&255}v.swap8IfBE=v.isLE?e=>e:e=>Bt(e);v.byteSwapIfBE=v.swap8IfBE;function Vn(e){for(let t=0;t<e.length;t++)e[t]=Bt(e[t]);return e}v.swap32IfBE=v.isLE?e=>e:Vn;var Mn=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",Qs=Array.from({length:256},(e,t)=>t.toString(16).padStart(2,"0"));function Ys(e){if(Xe(e),Mn)return e.toHex();let t="";for(let n=0;n<e.length;n++)t+=Qs[e[n]];return t}var Re={_0:48,_9:57,A:65,F:70,a:97,f:102};function Hn(e){if(e>=Re._0&&e<=Re._9)return e-Re._0;if(e>=Re.A&&e<=Re.F)return e-(Re.A-10);if(e>=Re.a&&e<=Re.f)return e-(Re.a-10)}function eo(e){if(typeof e!="string")throw new Error("hex string expected, got "+typeof e);if(Mn)return Uint8Array.fromHex(e);let t=e.length,n=t/2;if(t%2)throw new Error("hex string expected, got unpadded hex of length "+t);let r=new Uint8Array(n);for(let s=0,o=0;s<n;s++,o+=2){let a=Hn(e.charCodeAt(o)),i=Hn(e.charCodeAt(o+1));if(a===void 0||i===void 0){let l=e[o]+e[o+1];throw new Error('hex string expected, got non-hex character "'+l+'" at index '+o)}r[s]=a*16+i}return r}var to=async()=>{};v.nextTick=to;async function no(e,t,n){let r=Date.now();for(let s=0;s<e;s++){n(s);let o=Date.now()-r;o>=0&&o<t||(await(0,v.nextTick)(),r+=o)}}function Vt(e){if(typeof e!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(e))}function ro(e){return new TextDecoder().decode(e)}function Ct(e){return typeof e=="string"&&(e=Vt(e)),Xe(e),e}function so(e){return typeof e=="string"&&(e=Vt(e)),Xe(e),e}function oo(...e){let t=0;for(let r=0;r<e.length;r++){let s=e[r];Xe(s),t+=s.length}let n=new Uint8Array(t);for(let r=0,s=0;r<e.length;r++){let o=e[r];n.set(o,s),s+=o.length}return n}function ao(e,t){if(t!==void 0&&{}.toString.call(t)!=="[object Object]")throw new Error("options should be object or undefined");return Object.assign(e,t)}var Ht=class{};v.Hash=Ht;function Kn(e){let t=r=>e().update(Ct(r)).digest(),n=e();return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=()=>e(),t}function Gn(e){let t=(r,s)=>e(s).update(Ct(r)).digest(),n=e({});return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=r=>e(r),t}function Wn(e){let t=(r,s)=>e(s).update(Ct(r)).digest(),n=e({});return t.outputLen=n.outputLen,t.blockLen=n.blockLen,t.create=r=>e(r),t}v.wrapConstructor=Kn;v.wrapConstructorWithOpts=Gn;v.wrapXOFConstructorWithOpts=Wn;function io(e=32){if(We.crypto&&typeof We.crypto.getRandomValues=="function")return We.crypto.getRandomValues(new Uint8Array(e));if(We.crypto&&typeof We.crypto.randomBytes=="function")return Uint8Array.from(We.crypto.randomBytes(e));throw new Error("crypto.getRandomValues must be defined")}});var sr=ge($=>{"use strict";Object.defineProperty($,"__esModule",{value:!0});$.shake256=$.shake128=$.keccak_512=$.keccak_384=$.keccak_256=$.keccak_224=$.sha3_512=$.sha3_384=$.sha3_256=$.sha3_224=$.Keccak=void 0;$.keccakP=nr;var dt=zn(),Z=Xn(),co=BigInt(0),pt=BigInt(1),lo=BigInt(2),uo=BigInt(7),po=BigInt(256),mo=BigInt(113),Qn=[],Yn=[],er=[];for(let e=0,t=pt,n=1,r=0;e<24;e++){[n,r]=[r,(2*n+3*r)%5],Qn.push(2*(5*r+n)),Yn.push((e+1)*(e+2)/2%64);let s=co;for(let o=0;o<7;o++)t=(t<<pt^(t>>uo)*mo)%po,t&lo&&(s^=pt<<(pt<<BigInt(o))-pt);er.push(s)}var tr=(0,dt.split)(er,!0),fo=tr[0],go=tr[1],Jn=(e,t,n)=>n>32?(0,dt.rotlBH)(e,t,n):(0,dt.rotlSH)(e,t,n),Zn=(e,t,n)=>n>32?(0,dt.rotlBL)(e,t,n):(0,dt.rotlSL)(e,t,n);function nr(e,t=24){let n=new Uint32Array(10);for(let r=24-t;r<24;r++){for(let a=0;a<10;a++)n[a]=e[a]^e[a+10]^e[a+20]^e[a+30]^e[a+40];for(let a=0;a<10;a+=2){let i=(a+8)%10,l=(a+2)%10,m=n[l],u=n[l+1],f=Jn(m,u,1)^n[i],g=Zn(m,u,1)^n[i+1];for(let y=0;y<50;y+=10)e[a+y]^=f,e[a+y+1]^=g}let s=e[2],o=e[3];for(let a=0;a<24;a++){let i=Yn[a],l=Jn(s,o,i),m=Zn(s,o,i),u=Qn[a];s=e[u],o=e[u+1],e[u]=l,e[u+1]=m}for(let a=0;a<50;a+=10){for(let i=0;i<10;i++)n[i]=e[a+i];for(let i=0;i<10;i++)e[a+i]^=~n[(i+2)%10]&n[(i+4)%10]}e[0]^=fo[r],e[1]^=go[r]}(0,Z.clean)(n)}var mt=class e extends Z.Hash{constructor(t,n,r,s=!1,o=24){if(super(),this.pos=0,this.posOut=0,this.finished=!1,this.destroyed=!1,this.enableXOF=!1,this.blockLen=t,this.suffix=n,this.outputLen=r,this.enableXOF=s,this.rounds=o,(0,Z.anumber)(r),!(0<t&&t<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=(0,Z.u32)(this.state)}clone(){return this._cloneInto()}keccak(){(0,Z.swap32IfBE)(this.state32),nr(this.state32,this.rounds),(0,Z.swap32IfBE)(this.state32),this.posOut=0,this.pos=0}update(t){(0,Z.aexists)(this),t=(0,Z.toBytes)(t),(0,Z.abytes)(t);let{blockLen:n,state:r}=this,s=t.length;for(let o=0;o<s;){let a=Math.min(n-this.pos,s-o);for(let i=0;i<a;i++)r[this.pos++]^=t[o++];this.pos===n&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;let{state:t,suffix:n,pos:r,blockLen:s}=this;t[r]^=n,(n&128)!==0&&r===s-1&&this.keccak(),t[s-1]^=128,this.keccak()}writeInto(t){(0,Z.aexists)(this,!1),(0,Z.abytes)(t),this.finish();let n=this.state,{blockLen:r}=this;for(let s=0,o=t.length;s<o;){this.posOut>=r&&this.keccak();let a=Math.min(r-this.posOut,o-s);t.set(n.subarray(this.posOut,this.posOut+a),s),this.posOut+=a,s+=a}return t}xofInto(t){if(!this.enableXOF)throw new Error("XOF is not possible for this instance");return this.writeInto(t)}xof(t){return(0,Z.anumber)(t),this.xofInto(new Uint8Array(t))}digestInto(t){if((0,Z.aoutput)(t,this),this.finished)throw new Error("digest() was already called");return this.writeInto(t),this.destroy(),t}digest(){return this.digestInto(new Uint8Array(this.outputLen))}destroy(){this.destroyed=!0,(0,Z.clean)(this.state)}_cloneInto(t){let{blockLen:n,suffix:r,outputLen:s,rounds:o,enableXOF:a}=this;return t||(t=new e(n,r,s,a,o)),t.state32.set(this.state32),t.pos=this.pos,t.posOut=this.posOut,t.finished=this.finished,t.rounds=o,t.suffix=r,t.outputLen=s,t.enableXOF=a,t.destroyed=this.destroyed,t}};$.Keccak=mt;var Le=(e,t,n)=>(0,Z.createHasher)(()=>new mt(t,e,n));$.sha3_224=Le(6,144,224/8);$.sha3_256=Le(6,136,256/8);$.sha3_384=Le(6,104,384/8);$.sha3_512=Le(6,72,512/8);$.keccak_224=Le(1,144,224/8);$.keccak_256=Le(1,136,256/8);$.keccak_384=Le(1,104,384/8);$.keccak_512=Le(1,72,512/8);var rr=(e,t,n)=>(0,Z.createXOFer)((r={})=>new mt(t,e,r.dkLen===void 0?n:r.dkLen,!0));$.shake128=rr(31,168,128/8);$.shake256=rr(31,136,256/8)});var or=ge(Mt=>{"use strict";Object.defineProperty(Mt,"__esModule",{value:!0});Mt.verifyEnvEncryptPublicKey=vo;var ho=sr(),bo=Oe("@noble/curves/secp256k1");function vo(e,t,n){if(t.length!==65)return null;let r=Buffer.from("dstack-env-encrypt-pubkey","utf8"),s=n;n.startsWith("0x")&&(s=n.slice(2));let o=Buffer.from(s,"hex"),a=Buffer.from(":","utf8"),i=Buffer.concat([r,a,o,Buffer.from(e)]),l=(0,ho.keccak_256)(i);try{let m=t.slice(0,32),u=t.slice(32,64),f=t[64],g=new Uint8Array(64);g.set(m,0),g.set(u,32);let y=bo.secp256k1.Signature.fromCompact(g).addRecoveryBit(f).recoverPublicKey(l);return"0x"+Buffer.from(y.toRawBytes(!0)).toString("hex")}catch(m){return console.error("signature verification failed:",m),null}}});var br=ct(hn(),1);import{ofetch as yo}from"ofetch";function bn(e){return{all:e=e||new Map,on:function(t,n){var r=e.get(t);r?r.push(n):e.set(t,[n])},off:function(t,n){var r=e.get(t);r&&(n?r.splice(r.indexOf(n)>>>0,1):e.set(t,[]))},emit:function(t,n){var r=e.get(t);r&&r.slice().map(function(s){s(n)}),(r=e.get("*"))&&r.slice().map(function(s){s(t,n)})}}}var od=ct(qt(),1),au=ct(qt(),1),iu=ct(vn(),1),cu=ct(or(),1);import{z as K}from"zod";import{z as L}from"zod";import{z as Ne}from"zod";import{z as k}from"zod";import{z as qe}from"zod";import{anvil as ir,base as cr,mainnet as lr}from"viem/chains";import{z as H}from"zod";import{z as re}from"zod";import{z as p}from"zod";import{z as d}from"zod";import{z as Ze}from"zod";import{z as Qe}from"zod";import{z as C}from"zod";import{z as G}from"zod";import{z as E}from"zod";import qa from"crypto";import{z as ye}from"zod";import{z as be}from"zod";import{z as J}from"zod";import{z as le}from"zod";import{z as ue}from"zod";import{z as hi}from"zod";import{z as pr}from"zod";import{z as Ie}from"zod";import{z as ot}from"zod";import{z as Be}from"zod";import{z as O}from"zod";import{z as Vi}from"zod";import{z as Wi}from"zod";import{z as P}from"zod";import{z as Ae}from"zod";import{z as lc}from"zod";import{z as D}from"zod";import{z as _}from"zod";import{z as rt}from"zod";import{z as Wt}from"zod";import{z as Q}from"zod";import{z as zr}from"zod";import{z as Ee}from"zod";import{z as ce}from"zod";import{z as Fe}from"zod";import{z as Xt}from"zod";import{z as Zt}from"zod";import{z as He}from"zod";import{z as X}from"zod";import{z as B}from"zod";import{z as h}from"zod";import{z as R}from"zod";import{z as I}from"zod";import{z as V}from"zod";import{createPublicClient as Qp,createWalletClient as Yp,http as ed,parseEventLogs as td,parseEther as nd}from"viem";import{privateKeyToAccount as sd}from"viem/accounts";import{isHex as cd}from"viem";import{createPublicClient as ud,createWalletClient as pd,http as dd,custom as md}from"viem";import{privateKeyToAccount as gd}from"viem/accounts";import{z as q}from"zod";import{createPublicClient as _d,createWalletClient as wd,http as Cd,parseEventLogs as kd,parseEther as Sd}from"viem";import{privateKeyToAccount as Ad}from"viem/accounts";import{z as F}from"zod";import{createPublicClient as Pd,createWalletClient as jd,http as Od,parseEther as $d}from"viem";import{privateKeyToAccount as Nd}from"viem/accounts";import{z as U}from"zod";import{createPublicClient as Dd,createWalletClient as Hd,http as Bd,parseEther as Vd}from"viem";import{privateKeyToAccount as Kd}from"viem/accounts";import{z}from"zod";import{createPublicClient as Zd,createWalletClient as Qd,http as Yd,parseEther as em}from"viem";import{privateKeyToAccount as nm}from"viem/accounts";import{z as Ye}from"zod";import{createPublicClient as im,http as cm}from"viem";import{createPublicClient as pm,http as dm}from"viem";import{createPublicClient as fm,http as gm}from"viem";import{createPublicClient as bm,http as vm}from"viem";import{z as et}from"zod";import{z as _e}from"zod";import{z as Tl}from"zod";import{z as tt}from"zod";import{z as A}from"zod";import{z as It}from"zod";import{z as at}from"zod";import{z as ve}from"zod";import{z as W}from"zod";import{z as te}from"zod";import{z as ft}from"zod";import{z as ne}from"zod";import{z as nt}from"zod";import{z as he}from"zod";import{z as de}from"zod";import{z as fr}from"zod";import{z as gr}from"zod";import{z as Te}from"zod";import{z as se}from"zod";import{z as kt}from"zod";import{z as St}from"zod";import{z as ee}from"zod";import{z as T}from"zod";var _o=K.object({detail:K.union([K.string(),K.array(K.object({msg:K.string(),type:K.string().optional(),ctx:K.record(K.unknown()).optional(),loc:K.array(K.union([K.string(),K.number()])).optional(),input:K.unknown().optional()}).passthrough()),K.record(K.unknown())]).optional(),type:K.string().optional(),code:K.string().optional()}),we=class extends Error{constructor(e,t){super(e),this.name=this.constructor.name,this.status=t.status,this.statusText=t.statusText,this.detail=t.detail,Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor)}},Kt=class Et extends we{constructor(t,n){super(t,{status:n?.status??0,statusText:n?.statusText??"Unknown Error",detail:n?.detail||t}),this.name="RequestError",this.isRequestError=!0,this.data=n?.data,this.request=n?.request,this.response=n?.response,this.code=n?.code,this.type=n?.type}static fromFetchError(t){let n=_o.safeParse(t.data);if(n.success){let r=n.data.detail??(t.data&&typeof t.data=="object"&&"error_code"in t.data?t.data:void 0);return new Et(t.message,{status:t.status??void 0,statusText:t.statusText??void 0,data:t.data,request:t.request??void 0,response:t.response??void 0,detail:r,code:n.data.code??void 0,type:n.data.type??void 0})}return new Et(t.message,{status:t.status??void 0,statusText:t.statusText??void 0,data:t.data,request:t.request??void 0,response:t.response??void 0,detail:t.data?.detail||"Unknown API error",code:t.status?.toString()??void 0})}static fromError(t,n){return new Et(t.message,{request:n??void 0,detail:t.message})}},wo=class extends we{constructor(e,t){super(e,t),this.isValidationError=!0,this.validationErrors=t.validationErrors}},Co=class extends we{constructor(){super(...arguments),this.isAuthError=!0}},vr=class extends we{constructor(){super(...arguments),this.isBusinessError=!0}},ko=class extends we{constructor(){super(...arguments),this.isServerError=!0}},So=class extends we{constructor(){super(...arguments),this.isUnknownError=!0}};function Eo(e){if(!e||!Array.isArray(e))return"unknown";let t=e.filter(n=>typeof n=="string"?!["body","query","path","header"].includes(n):!0);return t.length>0?t.join("."):"unknown"}function yr(e){if(!Array.isArray(e))return{errors:[],message:typeof e=="string"?e:"Validation error"};let t=e.map((s,o)=>{let a=Eo(s.loc),i=a;return a==="unknown"&&s.type&&(i=s.type==="missing"?"required field":s.type),{field:i,message:s.msg,type:s.type,context:s.ctx}}),n=t.length,r=n===1?`Validation failed: ${t[0].message}`:`Validation failed (${n} issue${n>1?"s":""})`;return{errors:t,message:r}}function Ao(e){return e===422?"validation":e===401||e===403?"auth":e>=400&&e<500?"business":e>=500?"server":"unknown"}function Io(e,t,n){if(e===422&&Array.isArray(t)){let{message:r}=yr(t);return r}if(typeof t=="string")return t;if(t&&typeof t=="object"&&"message"in t){let r=t.message;if(typeof r=="string")return r}return n}function xo(e){let t=e.status??0,n=e.statusText??"Unknown Error",r=e.detail,s=To(r);if(s)return new Ro(s.message,{status:t,statusText:n,detail:r,errorCode:s.error_code,structuredDetails:s.details,suggestions:s.suggestions,links:s.links});let o=Ao(t),a=Io(t,r,e.message),i={status:t,statusText:n,detail:r};if(o==="validation"&&Array.isArray(r)){let{errors:l}=yr(r);return new wo(a,{...i,validationErrors:l})}return o==="auth"?new Co(a,i):o==="business"?new vr(a,i):o==="server"?new ko(a,i):new So(a,i)}var Ro=class extends vr{constructor(e,t){super(e,t),this.isResourceError=!0,this.errorCode=t.errorCode,this.structuredDetails=t.structuredDetails,this.suggestions=t.suggestions,this.links=t.links}};function To(e){if(!e||typeof e!="object")return null;let t=e;return t.error_code&&typeof t.error_code=="string"&&t.message&&typeof t.message=="string"?{error_code:t.error_code,message:t.message,details:t.details,suggestions:t.suggestions,links:t.links}:null}var xt=["2025-10-28","2026-01-21"],Po="2026-01-21",Je=(0,br.default)("phala::api-client");function jo(e){return Object.entries(e).map(([t,n])=>` -H "${t}: ${n}"`).join(`
7
- `)}function Oo(e){return e?` -d '${(typeof e=="string"?e:JSON.stringify(e,null,2)).replace(/'/g,"\\'")}'`:""}function ar(e,t,n,r){let s=[];n.forEach((i,l)=>{s.push(`${l}: ${i}`)});let o=s.join(`
8
- `),a=typeof r=="string"?r:JSON.stringify(r,null,2);return[`< HTTP/1.1 ${e} ${t}`,o?`< ${o.replace(/\n/g,`
9
- < `)}`:"","",a].filter(Boolean).join(`
10
- `)}var $o=class _r{constructor(t={}){this.emitter=bn();let n=t.apiKey||process?.env?.PHALA_CLOUD_API_KEY,r=t.baseURL||process?.env?.PHALA_CLOUD_API_PREFIX||"https://cloud-api.phala.com/api/v1",s=t.version&&xt.includes(t.version)?t.version:Po;this.config={...t,apiKey:n,baseURL:r,version:s};let{apiKey:o,baseURL:a,timeout:i,headers:l,useCookieAuth:m,onResponseError:u,...f}=this.config,g={"X-Phala-Version":s,"Content-Type":"application/json"};l&&typeof l=="object"&&Object.entries(l).forEach(([y,S])=>{typeof S=="string"&&(g[y]=S)}),!m&&o&&(g["X-API-Key"]=o),this.fetchInstance=yo.create({baseURL:a,timeout:i||3e4,headers:g,...m?{credentials:"include"}:{},...f,onRequest({request:y,options:S}){if(S.body instanceof FormData){let x=S.headers;x instanceof Headers?x.delete("content-type"):x&&typeof x=="object"&&!Array.isArray(x)&&(delete x["Content-Type"],delete x["content-type"])}if(Je.enabled){let x=S.method||"GET",N=typeof y=="string"?y:y.url,Y=N.startsWith("http")?N:`${a}${N}`,fe={};S.headers&&typeof S.headers=="object"&&Object.entries(S.headers).forEach(([Se,je])=>{typeof je=="string"&&(fe[Se]=je)});let Pe=[`> curl -X ${x} "${Y}"`,jo(fe),S.body?Oo(S.body):""].filter(Boolean).join(`
11
- `);Je(`
4
+ `+o),e.push(s+"m+"+lt.exports.humanize(this.diff)+"\x1B[0m")}else e[0]=Jr()+t+" "+e[0]}function Jr(){return G.inspectOpts.hideDate?"":new Date().toISOString()+" "}function Zr(...e){return process.stderr.write(ct.formatWithOptions(G.inspectOpts,...e)+`
5
+ `)}function Qr(e){e?process.env.DEBUG=e:delete process.env.DEBUG}function Yr(){return process.env.DEBUG}function es(e){e.inspectOpts={};let t=Object.keys(G.inspectOpts);for(let n=0;n<t.length;n++)e.inspectOpts[t[n]]=G.inspectOpts[t[n]]}lt.exports=wt()(G);var{formatters:Wt}=lt.exports;Wt.o=function(e){return this.inspectOpts.colors=this.useColors,ct.inspect(e,this.inspectOpts).split(`
6
+ `).map(t=>t.trim()).join(" ")};Wt.O=function(e){return this.inspectOpts.colors=this.useColors,ct.inspect(e,this.inspectOpts)}});var Jt=tt(($l,Ct)=>{typeof process>"u"||process.type==="renderer"||process.browser===!0||process.__nwjs?Ct.exports=Bt():Ct.exports=Xt()});var un=qr(Jt(),1);import{ofetch as ts}from"ofetch";function Zt(e){return{all:e=e||new Map,on:function(t,n){var r=e.get(t);r?r.push(n):e.set(t,[n])},off:function(t,n){var r=e.get(t);r&&(n?r.splice(r.indexOf(n)>>>0,1):e.set(t,[]))},emit:function(t,n){var r=e.get(t);r&&r.slice().map(function(s){s(n)}),(r=e.get("*"))&&r.slice().map(function(s){s(t,n)})}}}import{z as B}from"zod";import{z as $}from"zod";import{z as xe}from"zod";import{z as S}from"zod";import{z as l}from"zod";import{z as p}from"zod";import{z as Te}from"zod";import{anvil as Yt,base as en,mainnet as tn}from"viem/chains";import{z as b}from"zod";import{z as D}from"zod";import{z as Y}from"zod";import{z as Ve}from"zod";import{z as Me}from"zod";import{z as g}from"zod";import{z as x}from"zod";import{z as w}from"zod";import xo from"crypto";import{z as ye}from"zod";import{z as ve}from"zod";import{z as J}from"zod";import{z as ce}from"zod";import{z as le}from"zod";import{z as ca}from"zod";import{z as Ke}from"zod";import{z as de}from"zod";import{z as rn}from"zod";import{z as Ae}from"zod";import{z as Ze}from"zod";import{z as Ne}from"zod";import{z as P}from"zod";import{z as Ka}from"zod";import{z as Ba}from"zod";import{z as T}from"zod";import{z as Ee}from"zod";import{z as ci}from"zod";import{z as L}from"zod";import{z as v}from"zod";import{z as Xe}from"zod";import{z as Et}from"zod";import{z as Q}from"zod";import{z as Yn}from"zod";import{z as Se}from"zod";import{z as ie}from"zod";import{z as Pe}from"zod";import{z as At}from"zod";import{z as Rt}from"zod";import{z as Oe}from"zod";import{z as X}from"zod";import{z as V}from"zod";import{z as C}from"zod";import{z as O}from"zod";import{z as I}from"zod";import{z as M}from"zod";import{createPublicClient as ep,createWalletClient as tp,http as np,parseEventLogs as rp,parseEther as sp}from"viem";import{privateKeyToAccount as ap}from"viem/accounts";import{x25519 as Nl}from"@noble/curves/ed25519";import{keccak256 as up,toBytes as pp,toHex as mp}from"viem";import{isHex as fp}from"viem";import{createPublicClient as hp,createWalletClient as bp,http as vp,custom as yp}from"viem";import{privateKeyToAccount as wp}from"viem/accounts";import{z as N}from"zod";import{createPublicClient as Ap,createWalletClient as Ip,http as Rp,parseEventLogs as xp,parseEther as Tp}from"viem";import{privateKeyToAccount as jp}from"viem/accounts";import{z}from"zod";import{createPublicClient as zp,createWalletClient as Fp,http as Up,parseEther as Lp}from"viem";import{privateKeyToAccount as Vp}from"viem/accounts";import{z as F}from"zod";import{createPublicClient as Bp,createWalletClient as Wp,http as Xp,parseEther as Jp}from"viem";import{privateKeyToAccount as Qp}from"viem/accounts";import{z as U}from"zod";import{createPublicClient as rm,createWalletClient as sm,http as om,parseEther as am}from"viem";import{privateKeyToAccount as cm}from"viem/accounts";import{z as He}from"zod";import{createPublicClient as dm,http as fm}from"viem";import{createPublicClient as bm,http as vm}from"viem";import{createPublicClient as _m,http as wm}from"viem";import{createPublicClient as Sm,http as km}from"viem";import{z as Ge}from"zod";import{z as _e}from"zod";import{z as xc}from"zod";import{z as Be}from"zod";import{z as A}from"zod";import{z as dt}from"zod";import{z as Qe}from"zod";import{z as me}from"zod";import{z as K}from"zod";import{z as re}from"zod";import{z as nt}from"zod";import{z as W}from"zod";import{z as We}from"zod";import{z as Z}from"zod";import{z as pe}from"zod";import{z as an}from"zod";import{z as cn}from"zod";import{z as ke}from"zod";import{z as H}from"zod";import{z as ut}from"zod";import{z as pt}from"zod";import{z as ne}from"zod";import{z as E}from"zod";import{secp256k1 as Ll}from"@noble/curves/secp256k1";var ns=B.object({detail:B.union([B.string(),B.array(B.object({msg:B.string(),type:B.string().optional(),ctx:B.record(B.unknown()).optional(),loc:B.array(B.union([B.string(),B.number()])).optional(),input:B.unknown().optional()}).passthrough()),B.record(B.unknown())]).optional(),type:B.string().optional(),code:B.string().optional()});function rs(e){if(!e||typeof e!="object")return;let t=e.request_id;return typeof t=="string"?t:void 0}function ss(e){return e?.headers?.get("X-Request-ID")??void 0}var ge=class extends Error{constructor(e,t){super(e),this.name=this.constructor.name,this.status=t.status,this.statusText=t.statusText,this.detail=t.detail,this.requestId=t.requestId,this.code=t.code,Error.captureStackTrace&&Error.captureStackTrace(this,this.constructor)}},St=class rt extends ge{constructor(t,n){super(t,{status:n?.status??0,statusText:n?.statusText??"Unknown Error",detail:n?.detail||t,requestId:n?.requestId,code:n?.code}),this.name="RequestError",this.isRequestError=!0,this.data=n?.data,this.request=n?.request,this.response=n?.response,this.type=n?.type}static fromFetchError(t){let n=rs(t.data),r=ss(t.response),s=n??r,o=ns.safeParse(t.data);if(o.success){let i=o.data.detail??(t.data&&typeof t.data=="object"&&"error_code"in t.data?t.data:void 0);return new rt(t.message,{status:t.status??void 0,statusText:t.statusText??void 0,data:t.data,request:t.request??void 0,response:t.response??void 0,detail:i,code:o.data.code??void 0,type:o.data.type??void 0,requestId:s})}if(t.cause?.name==="TimeoutError"||t.message?.includes("[TimeoutError]")){let i="Request timed out. The server did not respond in time.";return new rt(i,{status:0,statusText:"Request Timeout",data:t.data,request:t.request??void 0,response:t.response??void 0,detail:i,code:"TIMEOUT",requestId:s})}return new rt(t.message,{status:t.status??void 0,statusText:t.statusText??void 0,data:t.data,request:t.request??void 0,response:t.response??void 0,detail:t.data?.detail||t.message||"Unknown API error",code:t.status?.toString()??void 0,requestId:s})}static fromError(t,n){return new rt(t.message,{request:n??void 0,detail:t.message})}},os=class extends ge{constructor(e,t){super(e,t),this.isValidationError=!0,this.validationErrors=t.validationErrors}},as=class extends ge{constructor(){super(...arguments),this.isAuthError=!0}},pn=class extends ge{constructor(){super(...arguments),this.isBusinessError=!0}},is=class extends ge{constructor(){super(...arguments),this.isServerError=!0}},cs=class extends ge{constructor(){super(...arguments),this.isUnknownError=!0}};function ls(e){if(!e||!Array.isArray(e))return"unknown";let t=e.filter(n=>typeof n=="string"?!["body","query","path","header"].includes(n):!0);return t.length>0?t.join("."):"unknown"}function mn(e){if(!Array.isArray(e))return{errors:[],message:typeof e=="string"?e:"Validation error"};let t=e.map((s,o)=>{let c=ls(s.loc),i=c;return c==="unknown"&&s.type&&(i=s.type==="missing"?"required field":s.type),{field:i,message:s.msg,type:s.type,context:s.ctx}}),n=t.length,r=n===1?`Validation failed: ${t[0].message}`:`Validation failed (${n} issue${n>1?"s":""})`;return{errors:t,message:r}}function us(e){return e===422?"validation":e===401||e===403?"auth":e>=400&&e<500?"business":e>=500?"server":"unknown"}function ps(e,t,n){if(e===422&&Array.isArray(t)){let{message:r}=mn(t);return r}if(typeof t=="string")return t;if(t&&typeof t=="object"&&"message"in t){let r=t.message;if(typeof r=="string")return r}return n}function ms(e){let t=e.status??0,n=e.statusText??"Unknown Error",r=e.detail,s=fs(r);if(s)return new ds(s.message,{status:t,statusText:n,detail:r,requestId:s.request_id??e.requestId,errorCode:s.error_code,structuredDetails:s.details,suggestions:s.suggestions,links:s.links});let o=us(t),c=ps(t,r,e.message),i={status:t,statusText:n,detail:r,requestId:e.requestId,code:e.code};if(o==="validation"&&Array.isArray(r)){let{errors:u}=mn(r);return new os(c,{...i,validationErrors:u})}return o==="auth"?new as(c,i):o==="business"?new pn(c,i):o==="server"?new is(c,i):new cs(c,i)}var ds=class extends pn{constructor(e,t){super(e,t),this.isResourceError=!0,this.errorCode=t.errorCode,this.structuredDetails=t.structuredDetails,this.suggestions=t.suggestions,this.links=t.links}};function fs(e){if(!e||typeof e!="object")return null;let t=e;return t.error_code&&typeof t.error_code=="string"&&t.message&&typeof t.message=="string"?{error_code:t.error_code,message:t.message,request_id:typeof t.request_id=="string"?t.request_id:void 0,details:t.details,suggestions:t.suggestions,links:t.links}:null}var ft=["2025-10-28","2026-01-21","2026-05-22"],gs="2026-05-22",De=(0,un.default)("phala::api-client");function hs(e){return Object.entries(e).map(([t,n])=>` -H "${t}: ${n}"`).join(`
7
+ `)}function bs(e){return e?` -d '${(typeof e=="string"?e:JSON.stringify(e,null,2)).replace(/'/g,"\\'")}'`:""}function Qt(e,t,n,r){let s=[];n.forEach((i,u)=>{s.push(`${u}: ${i}`)});let o=s.join(`
8
+ `),c=typeof r=="string"?r:JSON.stringify(r,null,2);return[`< HTTP/1.1 ${e} ${t}`,o?`< ${o.replace(/\n/g,`
9
+ < `)}`:"","",c].filter(Boolean).join(`
10
+ `)}var vs=class dn{constructor(t={}){this.emitter=Zt();let n=t.apiKey||process?.env?.PHALA_CLOUD_API_KEY,r=t.baseURL||process?.env?.PHALA_CLOUD_API_PREFIX||"https://cloud-api.phala.com/api/v1",s=t.version&&ft.includes(t.version)?t.version:gs;this.config={...t,apiKey:n,baseURL:r,version:s};let{apiKey:o,baseURL:c,timeout:i,headers:u,useCookieAuth:f,onResponseError:m,...d}=this.config,h={"X-Phala-Version":s,"Content-Type":"application/json"};u&&typeof u=="object"&&Object.entries(u).forEach(([_,k])=>{typeof k=="string"&&(h[_]=k)}),!f&&o&&(h["X-API-Key"]=o),this.fetchInstance=ts.create({baseURL:c,timeout:i||6e4,headers:h,...f?{credentials:"include"}:{},...d,onRequest({request:_,options:k}){if(k.body instanceof FormData){let R=k.headers;R instanceof Headers?R.delete("content-type"):R&&typeof R=="object"&&!Array.isArray(R)&&(delete R["Content-Type"],delete R["content-type"])}if(De.enabled){let R=k.method||"GET",q=typeof _=="string"?_:_.url,te=q.startsWith("http")?q:`${c}${q}`,fe={};k.headers&&typeof k.headers=="object"&&Object.entries(k.headers).forEach(([Ce,Re])=>{typeof Re=="string"&&(fe[Ce]=Re)});let Ie=[`> curl -X ${R} "${te}"`,hs(fe),k.body?bs(k.body):""].filter(Boolean).join(`
11
+ `);De(`
12
12
  === REQUEST ===
13
13
  %s
14
- `,Pe)}},onResponse({request:y,response:S,options:x}){if(Je.enabled){let N=x.method||"GET",Y=typeof y=="string"?y:y.url;Je(`
14
+ `,Ie)}},onResponse({request:_,response:k,options:R}){if(De.enabled){let q=R.method||"GET",te=typeof _=="string"?_:_.url;De(`
15
15
  === RESPONSE [%s %s] (%dms) ===
16
16
  %s
17
- `,N,Y,S.headers.get("x-response-time")||"?",ar(S.status,S.statusText,S.headers,S._data))}},onResponseError:({request:y,response:S,options:x})=>{if(Je.enabled){console.warn(`HTTP ${S.status}: ${S.url}`);let N=x.method||"GET",Y=typeof y=="string"?y:y.url;Je(`
17
+ `,q,te,k.headers.get("x-response-time")||"?",Qt(k.status,k.statusText,k.headers,k._data))}},onResponseError:({request:_,response:k,options:R})=>{if(De.enabled){console.warn(`HTTP ${k.status}: ${k.url}`);let q=R.method||"GET",te=typeof _=="string"?_:_.url;De(`
18
18
  === ERROR RESPONSE [%s %s] ===
19
19
  %s
20
- `,N,Y,ar(S.status,S.statusText,S.headers,S._data))}u&&u({request:y,response:S,options:x})}})}get raw(){return this.fetchInstance}on(t,n){this.emitter.on(t,n)}off(t,n){this.emitter.off(t,n)}once(t,n){let r=s=>{n(s),this.emitter.off(t,r)};this.emitter.on(t,r)}async request(t,n){try{let r=n?.method||"GET";return await this.fetchInstance(t,{...n,method:r})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}async requestFull(t,n){try{let r=n?.method||"GET",s=await this.fetchInstance.raw(t,{...n,method:r,ignoreResponseError:!0});return{status:s.status,statusText:s.statusText,headers:s.headers,data:s._data,ok:s.ok}}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}async get(t,n){try{return await this.fetchInstance(t,{...n,method:"GET"})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}buildRequestOptions(t,n,r){let s={...r,method:t,body:n};if(n instanceof FormData){let o=s.headers;s.headers={...o,"Content-Type":""}}return s}async post(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("POST",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async put(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("PUT",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async patch(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("PATCH",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async delete(t,n){try{return await this.fetchInstance(t,{...n,method:"DELETE"})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}convertToRequestError(t){return t&&typeof t=="object"&&"data"in t?Kt.fromFetchError(t):t instanceof Error?Kt.fromError(t):new Kt("Unknown error occurred",{detail:"Unknown error occurred"})}emitError(t){let n=xo(t);return this.emitter.emit("error",n),n}async safeRequest(t){try{return{success:!0,data:await t()}}catch(n){if(n instanceof we)return{success:!1,error:n};let r=this.convertToRequestError(n);return this.emitError(r),{success:!1,error:r}}}async safeGet(t,n){return this.safeRequest(()=>this.get(t,n))}async safePost(t,n,r){return this.safeRequest(()=>this.post(t,n,r))}async safePut(t,n,r){return this.safeRequest(()=>this.put(t,n,r))}async safePatch(t,n,r){return this.safeRequest(()=>this.patch(t,n,r))}async safeDelete(t,n){return this.safeRequest(()=>this.delete(t,n))}async safeRequestMethod(t,n){return this.safeRequest(()=>this.request(t,n))}async safeRequestFull(t,n){return this.safeRequest(()=>this.requestFull(t,n))}withVersion(t){return new _r({...this.config,version:t})}extend(t){let n=typeof t=="function"?t(this):t,r=Object.create(this);for(let[s,o]of Object.entries(n))typeof o=="function"&&(r[s]=(...a)=>o(this,...a));return r}};function Lo(e={}){return new $o(e)}var No=L.object({username:L.string(),email:L.string(),role:L.enum(["admin","user"]),avatar:L.string(),email_verified:L.boolean(),totp_enabled:L.boolean(),has_backup_codes:L.boolean(),flag_has_password:L.boolean()}).passthrough(),qo=L.object({id:L.string(),name:L.string(),slug:L.string().nullable(),tier:L.string(),role:L.string(),avatar:L.string().nullable().optional()}).passthrough(),Fo=L.object({balance:L.string().or(L.number()),granted_balance:L.string().or(L.number()),is_post_paid:L.boolean(),outstanding_amount:L.string().or(L.number()).nullable()}).passthrough(),Uo=L.object({user:No,workspace:qo,credits:Fo}).passthrough(),zo=Ne.object({username:Ne.string(),email:Ne.string(),credits:Ne.number(),granted_credits:Ne.number(),avatar:Ne.string(),team_name:Ne.string(),team_tier:Ne.string()}).passthrough();function Do(e){return e==="2025-10-28"?zo:Uo}async function wr(e,t){let n=await e.get("/auth/me");return t?.schema===!1?n:(t?.schema||Do(e.config.version)).parse(n)}async function Ho(e,t){try{return{success:!0,data:await wr(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var Cr={[lr.id]:lr,[cr.id]:cr,[ir.id]:ir},Bo=qe.object({id:qe.string(),slug:qe.string().nullable(),url:qe.string(),version:qe.string(),chain_id:qe.number().nullable(),kms_contract_address:qe.string().nullable().transform(e=>e),gateway_app_id:qe.string().nullable().transform(e=>e)}).passthrough(),Ce=Bo.transform(e=>{if(e.chain_id!=null){let t=Cr[e.chain_id];if(t)return{...e,chain:t}}return e});function kr(e){if(e?.schema!==void 0&&e?.schema!==!1&&(typeof e.schema!="object"||e.schema===null||!("parse"in e.schema)||typeof e.schema.parse!="function"))throw new Error("Invalid schema: must be a Zod schema object, false, or undefined")}function Sr(e){if(e?.schema!==void 0&&e?.schema!==!1&&(typeof e.schema!="object"||e.schema===null||!("parse"in e.schema)||typeof e.schema.parse!="function"))return{success:!1,error:{name:"ZodError",message:"Invalid schema: must be a Zod schema object, false, or undefined",issues:[{code:"invalid_type",expected:"object",received:typeof e.schema,path:["schema"],message:"Invalid schema: must be a Zod schema object, false, or undefined"}]}}}function Er(e,t){function n(a,i){return r(a,i)}async function r(a,i){kr(i);let l=await t(a);return i?.schema===!1?l:(i?.schema||e).parse(l)}function s(a,i){return o(a,i)}async function o(a,i){let l=Sr(i);if(l)return l;let m=await(async()=>{try{return{success:!0,data:await t(a)}}catch(f){return f&&typeof f=="object"&&"status"in f?{success:!1,error:f}:f&&typeof f=="object"&&"issues"in f?{success:!1,error:f}:{success:!1,error:{name:"Error",message:f instanceof Error?f.message:String(f)}}}})();return m.success?i?.schema===!1?{success:!0,data:m.data}:(i?.schema||e).safeParse(m.data):m}return{action:n,safeAction:s}}function b(e,t){function n(a,...i){let[l,m]=i;return r(a,l,m)}async function r(a,i,l){kr(l);let m=await t(a,i);return l?.schema===!1?m:(l?.schema||e).parse(m)}function s(a,...i){let[l,m]=i;return o(a,l,m)}async function o(a,i,l){let m=Sr(l);if(m)return m;let u=await(async()=>{try{return{success:!0,data:await t(a,i)}}catch(g){return g&&typeof g=="object"&&"status"in g?{success:!1,error:g}:g&&typeof g=="object"&&"issues"in g?{success:!1,error:g}:{success:!1,error:{name:"Error",message:g instanceof Error?g.message:String(g)}}}})();return u.success?l?.schema===!1?{success:!0,data:u.data}:(l?.schema||e).safeParse(u.data):u}return{action:n,safeAction:s}}var Vo=k.object({name:k.string(),is_dev:k.boolean(),version:k.union([k.tuple([k.number(),k.number(),k.number()]),k.tuple([k.number(),k.number(),k.number(),k.number()])]),os_image_hash:k.string().nullable().optional()}).passthrough(),Mo=k.object({teepod_id:k.number(),name:k.string(),listed:k.boolean(),resource_score:k.number(),remaining_vcpu:k.number(),remaining_memory:k.number(),remaining_cvm_slots:k.number(),images:k.array(Vo),support_onchain_kms:k.boolean().optional(),fmspc:k.string().nullable().optional(),device_id:k.string().nullable().optional(),region_identifier:k.string().nullable().optional(),default_kms:k.string().nullable().optional(),kms_list:k.array(k.string()).default([])}).passthrough(),Ko=k.object({max_instances:k.number().nullable().optional(),max_vcpu:k.number().nullable().optional(),max_memory:k.number().nullable().optional(),max_disk:k.number().nullable().optional()}).passthrough(),Go=k.object({tier:k.string(),capacity:Ko,nodes:k.array(Mo),kms_list:k.array(Ce)}).passthrough(),{action:Wo,safeAction:Xo}=Er(Go,async e=>await e.get("/teepods/available")),Ar=H.object({id:H.string(),name:H.string(),description:H.string(),vcpu:H.number(),memory_mb:H.number(),hourly_rate:H.string(),requires_gpu:H.boolean(),default_disk_size_gb:H.number().default(20),family:H.string().nullable()}).passthrough(),Jo=H.object({name:H.string(),items:H.array(Ar),total:H.number()}).strict(),Zo=H.object({result:H.array(Jo)}).strict(),Qo=H.object({items:H.array(Ar),total:H.number(),family:H.string()}).strict(),Yo=H.object({family:H.string()}).strict(),{action:ea,safeAction:ta}=b(Zo,async e=>await e.get("/instance-types")),{action:na,safeAction:ra}=b(Qo,async(e,t)=>{let n=Yo.parse(t);return await e.get(`/instance-types/${n.family}`)}),Ir=re.object({id:re.string(),name:re.string(),slug:re.string().nullable(),tier:re.string(),role:re.string(),is_default:re.boolean(),created_at:re.string(),confidential_models_enabled:re.boolean().optional()}).passthrough(),sa=re.object({has_more:re.boolean(),next_cursor:re.string().nullable(),total:re.number().nullable()}).passthrough(),oa=re.object({data:re.array(Ir),pagination:sa}).passthrough(),{action:aa,safeAction:ia}=b(oa,async(e,t)=>{let n=new URLSearchParams;t?.cursor&&n.append("cursor",t.cursor),t?.limit&&n.append("limit",t.limit.toString());let r=n.toString()?`/workspaces?${n.toString()}`:"/workspaces";return await e.get(r)}),{action:ca,safeAction:la}=b(Ir,async(e,t)=>await e.get(`/workspaces/${t}`)),ua=p.object({id:p.string(),name:p.string(),status:p.string(),uptime:p.string(),app_url:p.string().nullable(),app_id:p.string(),instance_id:p.string().nullable(),configuration:p.any().optional(),exited_at:p.string().nullable(),boot_progress:p.string().nullable(),boot_error:p.string().nullable(),shutdown_progress:p.string().nullable(),image_version:p.string().nullable()}),pa=p.object({id:p.number(),username:p.string()}),xr=p.object({id:p.number(),name:p.string(),region_identifier:p.string().nullable().optional()}),Qt=p.object({vcpu:p.number(),memory:p.number(),disk_size:p.number(),gpu_count:p.number().default(0)}),Yt=p.object({app:p.string(),instance:p.string()}),da=p.object({hosted:ua,name:p.string(),managed_user:pa.nullable(),node:xr.nullable(),listed:p.boolean().default(!1),status:p.string(),in_progress:p.boolean().default(!1),dapp_dashboard_url:p.string().nullable(),syslog_endpoint:p.string().nullable(),allow_upgrade:p.boolean().default(!1),project_id:p.string().nullable(),project_type:p.string().nullable(),billing_period:p.string().nullable(),kms_info:Ce.nullable(),vcpu:p.number().nullable(),memory:p.number().nullable(),disk_size:p.number().nullable(),gateway_domain:p.string().nullable(),public_urls:p.array(Yt),machine_info:Qt.nullable().optional(),updated_at:p.string().nullable().optional()}),Rr=p.object({id:p.number(),name:p.string(),status:p.string(),in_progress:p.boolean().optional().default(!1),teepod_id:p.number().nullable(),teepod:xr.optional().nullable(),app_id:p.string(),vm_uuid:p.string().nullable(),instance_id:p.string().nullable(),vcpu:p.number(),memory:p.number(),disk_size:p.number(),base_image:p.string().nullable(),encrypted_env_pubkey:p.string().nullable(),listed:p.boolean().optional().default(!1),project_id:p.string().optional().nullable(),project_type:p.string().optional().nullable(),instance_type:p.string().optional().nullable(),public_sysinfo:p.boolean().optional().default(!1),public_logs:p.boolean().optional().default(!1),dapp_dashboard_url:p.string().optional().nullable(),syslog_endpoint:p.string().optional().nullable(),kms_info:Ce.optional().nullable(),contract_address:p.string().optional().nullable(),deployer_address:p.string().optional().nullable(),scheduled_delete_at:p.string().optional().nullable(),public_urls:p.array(Yt).optional().default([]),gateway_domain:p.string().optional().nullable(),machine_info:Qt.optional().nullable(),updated_at:p.string().optional().nullable()}),ma=p.object({items:p.array(da),total:p.number(),page:p.number(),page_size:p.number(),pages:p.number()}),fa=d.enum(["skip","hourly","monthly"]),ga=d.enum(["phala","ethereum","base","legacy"]),en=d.object({object_type:d.literal("user"),id:d.string().nullable().optional(),username:d.string().nullable().optional(),avatar_url:d.string().nullable().optional()}),tn=d.object({object_type:d.literal("workspace"),id:d.string(),name:d.string(),slug:d.string().nullable().optional(),avatar_url:d.string().nullable().optional()}),ha=d.object({instance_type:d.string().nullable().optional(),vcpu:d.number().int().nullable().optional(),memory_in_gb:d.number().nullable().optional(),disk_in_gb:d.number().int().nullable().optional(),gpus:d.number().int().nullable().optional(),compute_billing_price:d.string().nullable().optional(),billing_period:fa.nullable().optional()}),ba=d.object({name:d.string().nullable().optional(),version:d.string().nullable().optional(),is_dev:d.boolean().nullable().optional(),os_image_hash:d.string().nullable().optional()}),va=d.object({chain_id:d.number().int().nullable().optional(),dstack_kms_address:d.string().nullable().optional(),dstack_app_address:d.string().nullable().optional(),deployer_address:d.string().nullable().optional(),rpc_endpoint:d.string().nullable().optional(),encrypted_env_pubkey:d.string().nullable().optional()}),ya=va.transform(e=>{if(e.chain_id!=null){let t=Cr[e.chain_id];if(t)return{...e,chain:t}}return e}),_a=d.object({target:d.string().nullable().optional(),started_at:d.string().nullable().optional(),correlation_id:d.string().nullable().optional()}),wa=d.object({base_domain:d.string().nullable().optional(),cname:d.string().nullable().optional()}),Tr=d.object({object_type:d.literal("node"),id:d.number().int().nullable().optional(),name:d.string().nullable().optional(),region:d.string().nullable().optional(),device_id:d.string().nullable().optional(),ppid:d.string().nullable().optional(),status:d.string().nullable().optional(),version:d.string().nullable().optional()});var At=d.object({id:d.string(),name:d.string(),app_id:d.string().nullable().optional(),vm_uuid:d.string().nullable().optional(),instance_id:d.string().nullable().optional(),resource:ha,node_info:Tr.nullable().optional(),os:ba.nullable().optional(),kms_type:ga.nullable().optional(),kms_info:ya.nullable().optional(),status:d.string(),progress:_a.nullable().optional(),compose_hash:d.string().nullable().optional(),gateway:wa,services:d.array(d.record(d.any())).optional().default([]),endpoints:d.array(Yt).nullable().optional(),public_logs:d.boolean().optional(),public_sysinfo:d.boolean().optional(),public_tcbinfo:d.boolean().optional(),gateway_enabled:d.boolean().optional(),secure_time:d.boolean().optional(),listed:d.boolean().optional().default(!1),storage_fs:d.string().optional(),workspace:tn.nullable().optional(),creator:en.nullable().optional()}),Ca=At.extend({compose_file:d.union([d.record(d.any()),d.string()]).nullable().optional()}),ka=d.object({items:d.array(At),total:d.number(),page:d.number(),page_size:d.number(),pages:d.number()});function Pr(e){return typeof e!="string"||e.length<5||e.length>63?!1:/^[a-zA-Z](?!.*--)([a-zA-Z0-9-]*[a-zA-Z0-9])?$/.test(e)}var oe=Ze.object({id:Ze.string().optional(),uuid:Ze.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i,"Invalid UUID format").optional(),app_id:Ze.string().optional(),instance_id:Ze.string().optional(),name:Ze.string().refine(Pr,{message:"Name must be 5-63 characters, start with letter, and contain only letters/numbers/hyphens"}).optional()}),me=e=>e.refine(t=>{let n=t;return!!(n.id||n.uuid||n.app_id||n.instance_id||n.name)},{message:"One of id, uuid, app_id, instance_id, or name must be provided"}),Sa=me(oe),j=Sa.transform(e=>{let t;if(e.id)t=e.id;else if(e.uuid)t=e.uuid;else if(e.app_id)t=e.app_id;else if(e.instance_id)t=e.instance_id;else{if(e.name)return{cvmId:e.name};throw new Error("No valid identifier provided")}let n=/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i,r=/^[0-9a-f]{40}$/i,s;return n.test(t)?s=t.replace(/-/g,""):r.test(t)?s=`app_${t}`:s=t,{cvmId:s}}),Ea=j;function Aa(e){return e==="2025-10-28"?Rr:Ca}async function jr(e,t){let{cvmId:n}=Ea.parse(t),r=await e.get(`/cvms/${n}`);return Aa(e.config.version).parse(r)}async function Rt(e,t){try{return{success:!0,data:await jr(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var Ia=Qe.object({page:Qe.number().int().min(1).optional(),page_size:Qe.number().int().min(1).optional(),node_id:Qe.number().int().min(1).optional(),teepod_id:Qe.number().int().min(1).optional(),user_id:Qe.string().optional()}).strict();function xa(e){return e==="2025-10-28"?ma:ka}async function Or(e,t){let n=Ia.parse(t??{}),r=await e.get("/cvms/paginated",{params:n});return xa(e.config.version).parse(r)}async function nn(e,t){try{return{success:!0,data:await Or(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var ur=200*1024;function $r(e,t,n){let r=new TextEncoder,s=e?r.encode(e).byteLength:0,o=t?r.encode(t).byteLength:0,a=s+o;if(a>ur){let i=ur/1024,l=Math.ceil(a/1024);n.addIssue({code:G.ZodIssueCode.custom,message:`Combined size of docker_compose_file and pre_launch_script must not exceed ${i}KB (current: ${l}KB)`})}}var Lr=G.object({allowed_envs:G.array(G.string()).optional(),docker_compose_file:G.string(),features:G.array(G.string()).optional(),name:G.string().optional(),manifest_version:G.number().optional(),kms_enabled:G.boolean().optional(),public_logs:G.boolean().optional(),public_sysinfo:G.boolean().optional(),tproxy_enabled:G.boolean().optional(),storage_fs:G.enum(["ext4","zfs"]).optional(),pre_launch_script:G.string().optional(),env_pubkey:G.string().optional(),salt:G.string().optional().nullable()}).passthrough().superRefine((e,t)=>{$r(e.docker_compose_file,e.pre_launch_script,t)}),Ra=C.object({app_id:C.string().nullable().optional(),app_env_encrypt_pubkey:C.string().nullable().optional(),compose_hash:C.string(),kms_info:Ce.nullable().optional(),fmspc:C.string().nullable().optional(),device_id:C.string().nullable().optional(),os_image_hash:C.string().nullable().optional(),instance_type:C.string().nullable().optional(),teepod_id:C.number().nullable().optional(),node_id:C.number().nullable().optional(),kms_id:C.string().nullable().optional()}).passthrough().transform(e=>{if("teepod_id"in e&&e.teepod_id!==void 0){let{teepod_id:t,...n}=e;return{...n,node_id:t}}return e}),Gt="Name must be 5-63 characters, start with letter, and contain only letters/numbers/hyphens",Ta=C.object({node_id:C.number().optional(),teepod_id:C.number().optional(),region:C.string().optional(),name:C.string().min(5,Gt).max(63,Gt).refine(e=>Pr(e),Gt),instance_type:C.string().optional(),image:C.string().optional(),vcpu:C.number().optional(),memory:C.number().optional(),disk_size:C.number().optional(),compose_file:C.object({allowed_envs:C.array(C.string()).optional(),pre_launch_script:C.string().optional(),docker_compose_file:C.string().optional(),name:C.string().optional().default(""),kms_enabled:C.boolean().optional(),public_logs:C.boolean().optional(),public_sysinfo:C.boolean().optional(),gateway_enabled:C.boolean().optional(),tproxy_enabled:C.boolean().optional(),storage_fs:C.enum(["ext4","zfs"]).optional()}).superRefine((e,t)=>{$r(e.docker_compose_file,e.pre_launch_script,t)}),listed:C.boolean().optional(),kms_id:C.string().optional(),kms:C.enum(["PHALA","ETHEREUM","BASE"]).optional(),kms_contract:C.string().optional(),env_keys:C.array(C.string()).optional(),nonce:C.number().optional(),app_id:C.string().optional()}).passthrough().transform(e=>!e.instance_type&&!e.vcpu&&!e.memory?{...e,instance_type:"tdx.small"}:e);function Pa(e){if(!e.compose_file)return e;let t={...e.compose_file};return typeof t.gateway_enabled=="boolean"&&typeof t.tproxy_enabled=="boolean"?delete t.tproxy_enabled:typeof t.tproxy_enabled=="boolean"&&typeof t.gateway_enabled>"u"&&(t.gateway_enabled=t.tproxy_enabled,delete t.tproxy_enabled,(typeof window<"u"?window.console:globalThis.console)&&console.warn("[phala/cloud] tproxy_enabled is deprecated, please use gateway_enabled instead. See docs for migration.")),{...e,compose_file:t}}var{action:ja,safeAction:Oa}=b(Ra,async(e,t)=>{let n=Ta.parse(t),r=Pa(n),s={...r};return typeof r.node_id=="number"?(s={...r,teepod_id:r.node_id},delete s.node_id):typeof r.teepod_id=="number"&&console.warn("[phala/cloud] teepod_id is deprecated, please use node_id instead."),await e.post("/cvms/provision",s)}),$a=E.object({id:E.number(),name:E.string(),status:E.string(),teepod_id:E.number(),teepod:E.object({id:E.number(),name:E.string()}).nullable(),user_id:E.number().nullable(),app_id:E.string().nullable(),vm_uuid:E.string().nullable(),instance_id:E.string().nullable(),app_url:E.string().nullable().default(null),base_image:E.string().nullable(),vcpu:E.number(),memory:E.number(),disk_size:E.number(),manifest_version:E.number().nullable().default(2),version:E.string().nullable().default("1.0.0"),runner:E.string().nullable().default("docker-compose"),docker_compose_file:E.string().nullable(),features:E.array(E.string()).nullable().default(["kms","tproxy-net"]),created_at:E.string(),encrypted_env_pubkey:E.string().nullable().optional(),app_auth_contract_address:E.string().nullable().optional(),deployer_address:E.string().nullable().optional()}).passthrough(),pp=E.object({encrypted_env:E.string().optional().nullable(),app_id:E.string(),compose_hash:E.string(),kms_id:E.string().optional(),contract_address:E.string().optional(),deployer_address:E.string().optional(),env_keys:E.array(E.string()).optional().nullable()}).passthrough(),{action:La,safeAction:Na}=b($a,async(e,t)=>await e.post("/cvms",t));function Jt(e){return e==null?e:Array.isArray(e)?e.map(Jt):e&&typeof e=="object"&&e.constructor===Object?Object.keys(e).sort().reduce((t,n)=>{let r=e[n];return t[n]=Jt(r),t},{}):e}function Nr(e){let t={...e};return t.runner==="bash"&&"docker_compose_file"in t?delete t.docker_compose_file:t.runner==="docker-compose"&&"bash_script"in t&&delete t.bash_script,"pre_launch_script"in t&&!t.pre_launch_script&&delete t.pre_launch_script,t}function qr(e){let t=Jt(e),n=JSON.stringify(t,null,4);return n=n.replace(/": /g,'":'),n}function Fa(e){let t=Nr(e),n=qr(t);return qa.createHash("sha256").update(n,"utf8").digest("hex")}function Ua(e){let t=e;return{...e,getHash:()=>Fa(t),toString:()=>qr(Nr(t))}}var za=Lr.transform(e=>Ua(e)),Da=j,{action:Ha,safeAction:Ba}=b(za,async(e,t)=>{let{cvmId:n}=Da.parse(t);return await e.get(`/cvms/${n}/compose_file`)}),Va=ye.object({id:ye.string().optional(),uuid:ye.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i).optional(),app_id:ye.string().refine(e=>!e.startsWith("app_")&&e.length===40,"app_id should be 40 characters without prefix").transform(e=>e.startsWith("app_")?e:`app_${e}`).optional(),instance_id:ye.string().refine(e=>!e.startsWith("instance_")&&e.length===40,"instance_id should be 40 characters without prefix").transform(e=>e.startsWith("instance_")?e:`instance_${e}`).optional(),app_compose:Lr,update_env_vars:ye.boolean().optional().nullable()}).refine(e=>!!(e.id||e.uuid||e.app_id||e.instance_id),"One of id, uuid, app_id, or instance_id must be provided").transform(e=>({cvmId:e.id||e.uuid||e.app_id||e.instance_id,request:{...e.app_compose,update_env_vars:e.update_env_vars},_raw:e})),Ma=ye.object({app_id:ye.string().nullable(),device_id:ye.string().nullable(),compose_hash:ye.string(),kms_info:Ce.nullable().optional(),compose_hash_registered:ye.boolean().optional().default(!1)}).passthrough(),{action:Ka,safeAction:Ga}=b(Ma,async(e,t)=>{let n=Va.parse(t);return await e.post(`/cvms/${n.cvmId}/compose_file/provision`,n.request)}),Wa=be.object({id:be.string().optional(),uuid:be.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i).optional(),app_id:be.string().refine(e=>!e.startsWith("app_")&&e.length===40,"app_id should be 40 characters without prefix").transform(e=>e.startsWith("app_")?e:`app_${e}`).optional(),instance_id:be.string().refine(e=>!e.startsWith("instance_")&&e.length===40,"instance_id should be 40 characters without prefix").transform(e=>e.startsWith("instance_")?e:`instance_${e}`).optional(),compose_hash:be.string().min(1,"Compose hash is required"),encrypted_env:be.string().optional(),env_keys:be.array(be.string()).optional(),update_env_vars:be.boolean().optional().nullable()}).refine(e=>!!(e.id||e.uuid||e.app_id||e.instance_id),"One of id, uuid, app_id, or instance_id must be provided").transform(e=>({cvmId:e.id||e.uuid||e.app_id||e.instance_id,compose_hash:e.compose_hash,encrypted_env:e.encrypted_env,env_keys:e.env_keys,update_env_vars:e.update_env_vars??void 0,_raw:e})),Xa=be.any().transform(()=>{}),{action:Ja,safeAction:Za}=b(Xa,async(e,t)=>{let n=Wa.parse(t);return await e.patch(`/cvms/${n.cvmId}/compose_file`,{compose_hash:n.compose_hash,encrypted_env:n.encrypted_env,env_keys:n.env_keys,update_env_vars:n.update_env_vars})}),Qa=me(oe.extend({encrypted_env:J.string().describe("Encrypted environment variables (hex string)"),env_keys:J.array(J.string()).optional().describe("List of allowed environment variable keys"),compose_hash:J.string().optional().describe("Compose hash for verification (Phase 2, required when env_keys changes)"),transaction_hash:J.string().optional().describe("On-chain transaction hash for verification (Phase 2, required when env_keys changes)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{encrypted_env:e.encrypted_env,env_keys:e.env_keys,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),Ya=J.object({status:J.literal("in_progress"),message:J.string(),correlation_id:J.string(),allowed_envs_changed:J.boolean()}),ei=J.object({status:J.literal("precondition_required"),message:J.string(),compose_hash:J.string(),app_id:J.string(),device_id:J.string(),kms_info:Ce}),ti=J.union([Ya,ei]),{action:ni,safeAction:ri}=b(ti,async(e,t)=>{let n=Qa.parse(t);try{return await e.patch(`/cvms/${n.cvmId}/envs`,n.request)}catch(r){if(r instanceof we&&r.status===465){let s=r.detail;if(s&&typeof s=="object"){let o=s,a=o.details;if(a&&Array.isArray(a)){let i=new Map(a.map(g=>[g.field,g.value])),l=i.get("compose_hash"),m=i.get("app_id"),u=i.get("device_id"),f=i.get("kms_info");if(l&&m)return{status:"precondition_required",message:o.message||"Compose hash verification required",compose_hash:l,app_id:m,device_id:u||"",kms_info:f}}}}throw r}}),si=me(oe.extend({docker_compose_file:le.string().describe("Docker Compose YAML content"),compose_hash:le.string().optional().describe("Compose hash for verification (Phase 2, contract-owned KMS only)"),transaction_hash:le.string().optional().describe("On-chain transaction hash for verification (Phase 2, contract-owned KMS only)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{docker_compose_file:e.docker_compose_file,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),oi=le.object({status:le.literal("in_progress"),message:le.string(),correlation_id:le.string()}),ai=le.object({status:le.literal("precondition_required"),message:le.string(),compose_hash:le.string(),app_id:le.string(),device_id:le.string(),kms_info:Ce}),ii=le.union([oi,ai]),{action:ci,safeAction:li}=b(ii,async(e,t)=>{let n=si.parse(t),r={"Content-Type":"text/yaml"};n.request.compose_hash&&(r["X-Compose-Hash"]=n.request.compose_hash),n.request.transaction_hash&&(r["X-Transaction-Hash"]=n.request.transaction_hash);try{return await e.patch(`/cvms/${n.cvmId}/docker-compose`,n.request.docker_compose_file,{headers:r})}catch(s){if(s instanceof we&&s.status===465){let o=s.detail;if(o&&typeof o=="object"){let a=o,i=a.details;if(i&&Array.isArray(i)){let l=new Map(i.map(y=>[y.field,y.value])),m=l.get("compose_hash"),u=l.get("app_id"),f=l.get("device_id"),g=l.get("kms_info");if(m&&u)return{status:"precondition_required",message:a.message||"Compose hash verification required",compose_hash:m,app_id:u,device_id:f||"",kms_info:g}}}}throw s}}),ui=me(oe.extend({pre_launch_script:ue.string().describe("Pre-launch script content (shell script)"),compose_hash:ue.string().optional().describe("Compose hash for verification (Phase 2, contract-owned KMS only)"),transaction_hash:ue.string().optional().describe("On-chain transaction hash for verification (Phase 2, contract-owned KMS only)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{pre_launch_script:e.pre_launch_script,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),pi=ue.object({status:ue.literal("in_progress"),message:ue.string(),correlation_id:ue.string()}),di=ue.object({status:ue.literal("precondition_required"),message:ue.string(),compose_hash:ue.string(),app_id:ue.string(),device_id:ue.string(),kms_info:Ce}),mi=ue.union([pi,di]),{action:fi,safeAction:gi}=b(mi,async(e,t)=>{let n=ui.parse(t),r={"Content-Type":"text/plain"};n.request.compose_hash&&(r["X-Compose-Hash"]=n.request.compose_hash),n.request.transaction_hash&&(r["X-Transaction-Hash"]=n.request.transaction_hash);try{return await e.patch(`/cvms/${n.cvmId}/pre-launch-script`,n.request.pre_launch_script,{headers:r})}catch(s){if(s instanceof we&&s.status===465){let o=s.detail;if(o&&typeof o=="object"){let a=o,i=a.details;if(i&&Array.isArray(i)){let l=new Map(i.map(y=>[y.field,y.value])),m=l.get("compose_hash"),u=l.get("app_id"),f=l.get("device_id"),g=l.get("kms_info");if(m&&u)return{status:"precondition_required",message:a.message||"Compose hash verification required",compose_hash:m,app_id:u,device_id:f||"",kms_info:g}}}}throw s}}),bi=j,{action:vi,safeAction:yi}=b(hi.string(),async(e,t)=>{let{cvmId:n}=bi.parse(t);return await e.get(`/cvms/${n}/pre-launch-script`)}),_i=pr.object({kms_id:pr.string().min(1,"KMS ID is required")}),{action:wi,safeAction:Ci}=b(Ce,async(e,t)=>{let n=_i.parse(t);return await e.get(`/kms/${n.kms_id}`)}),ki=Ie.object({page:Ie.number().int().min(1).optional(),page_size:Ie.number().int().min(1).optional(),is_onchain:Ie.boolean().optional()}).strict(),Si=Ie.object({items:Ie.array(Ce),total:Ie.number(),page:Ie.number(),page_size:Ie.number(),pages:Ie.number()}).strict(),{action:Ei,safeAction:Ai}=b(Si,async(e,t)=>{let n=ki.parse(t??{});return await e.get("/kms",{params:n})}),Ii=ot.object({kms:ot.string().min(1,"KMS ID or slug is required"),app_id:ot.string().refine(e=>e.length===40||e.startsWith("0x")&&e.length===42,"App ID must be exactly 40 characters or 42 characters with 0x prefix")}).strict(),xi=ot.object({public_key:ot.string(),signature:ot.string()}).strict(),{action:Ri,safeAction:Ti}=b(xi,async(e,t)=>{let n=Ii.parse(t);return await e.get(`/kms/${n.kms}/pubkey/${n.app_id}`)}),Pi=Be.object({counts:Be.number().int().min(1).max(20).optional().default(1)}).strict(),ji=Be.object({app_ids:Be.array(Be.object({app_id:Be.string(),nonce:Be.number().int().min(0)}))}).strict(),{action:Oi,safeAction:$i}=b(ji,async(e,t)=>{let n=Pi.parse(t??{}),r=new URLSearchParams;return r.append("counts",n.counts.toString()),await e.get(`/kms/phala/next_app_id?${r.toString()}`)}),it=O.object({id:O.number(),name:O.string(),status:O.string(),teepod_id:O.number(),teepod:O.object({id:O.number(),name:O.string(),region_identifier:O.string().nullable().optional()}).optional().nullable(),user_id:O.number().optional().nullable(),app_id:O.string(),vm_uuid:O.string().nullable(),instance_id:O.string().nullable(),app_url:O.string().optional().nullable(),base_image:O.string().optional().nullable(),vcpu:O.number(),memory:O.number(),disk_size:O.number(),manifest_version:O.number().optional().nullable(),version:O.string().optional().nullable(),runner:O.string().optional().nullable(),docker_compose_file:O.string().optional().nullable(),features:O.array(O.string()).optional().nullable(),created_at:O.string(),encrypted_env_pubkey:O.string().nullable()}),Li=j,{action:Ni,safeAction:qi}=b(it,async(e,t)=>{let{cvmId:n}=Li.parse(t);return await e.post(`/cvms/${n}/start`)}),Fi=j,{action:Ui,safeAction:zi}=b(it,async(e,t)=>{let{cvmId:n}=Fi.parse(t);return await e.post(`/cvms/${n}/stop`)}),Di=j,{action:Hi,safeAction:Bi}=b(it,async(e,t)=>{let{cvmId:n}=Di.parse(t);return await e.post(`/cvms/${n}/shutdown`)}),Mi=me(oe.extend({force:Vi.boolean().optional()})),{action:Ki,safeAction:Gi}=b(it,async(e,t)=>{let n=Mi.parse(t),{cvmId:r}=j.parse(n),{force:s=!1}=n;return await e.post(`/cvms/${r}/restart`,{force:s})}),Xi=j,{action:Ji,safeAction:Zi}=b(Wi.void(),async(e,t)=>{let{cvmId:n}=Xi.parse(t);await e.delete(`/cvms/${n}`)}),Qi=P.object({name:P.string(),mount_point:P.string(),total_size:P.number(),free_size:P.number()}),Yi=P.object({os_name:P.string(),os_version:P.string(),kernel_version:P.string(),cpu_model:P.string(),num_cpus:P.number(),total_memory:P.number(),available_memory:P.number(),used_memory:P.number(),free_memory:P.number(),total_swap:P.number(),used_swap:P.number(),free_swap:P.number(),uptime:P.number(),loadavg_one:P.number(),loadavg_five:P.number(),loadavg_fifteen:P.number(),disks:P.array(Qi)}),ec=P.object({is_online:P.boolean(),is_public:P.boolean().default(!1),error:P.string().nullable(),sysinfo:Yi.nullable(),status:P.string().nullable(),in_progress:P.boolean().default(!1),boot_progress:P.string().nullable(),boot_error:P.string().nullable()}),tc=j,{action:nc,safeAction:rc}=b(ec,async(e,t)=>{let{cvmId:n}=tc.parse(t);return await e.get(`/cvms/${n}/stats`)}),sc=Ae.object({app:Ae.string(),instance:Ae.string()}),oc=Ae.object({is_online:Ae.boolean(),is_public:Ae.boolean().default(!0),error:Ae.string().nullable(),internal_ip:Ae.string().nullable(),latest_handshake:Ae.string().nullable(),public_urls:Ae.array(sc).nullable()}),ac=j,{action:ic,safeAction:cc}=b(oc,async(e,t)=>{let{cvmId:n}=ac.parse(t);return await e.get(`/cvms/${n}/network`)}),uc=j,{action:pc,safeAction:dc}=b(lc.string(),async(e,t)=>{let{cvmId:n}=uc.parse(t);return await e.get(`/cvms/${n}/docker-compose.yml`)}),mc=D.object({id:D.string(),names:D.array(D.string()),image:D.string(),image_id:D.string(),command:D.string().nullable().optional(),created:D.number(),state:D.string(),status:D.string(),log_endpoint:D.string().nullable()}),fc=D.object({is_online:D.boolean(),is_public:D.boolean().default(!0),error:D.string().nullable(),docker_compose_file:D.string().nullable(),manifest_version:D.number().nullable(),version:D.string().nullable(),runner:D.string().nullable(),features:D.array(D.string()).nullable(),containers:D.array(mc).nullable()}),gc=j,{action:hc,safeAction:bc}=b(fc,async(e,t)=>{let{cvmId:n}=gc.parse(t);return await e.get(`/cvms/${n}/composition`)}),vc=_.object({common_name:_.string().nullable(),organization:_.string().nullable(),country:_.string().nullable(),state:_.string().nullable(),locality:_.string().nullable()}),yc=_.object({common_name:_.string().nullable(),organization:_.string().nullable(),country:_.string().nullable()}),Fr=_.object({subject:vc,issuer:yc,serial_number:_.string(),not_before:_.string(),not_after:_.string(),version:_.string(),fingerprint:_.string(),signature_algorithm:_.string(),sans:_.array(_.string()).nullable(),is_ca:_.boolean(),position_in_chain:_.number().nullable(),quote:_.string().nullable(),app_id:_.string().nullable().optional(),cert_usage:_.string().nullable().optional()}),_c=_.object({imr:_.number(),event_type:_.number(),digest:_.string(),event:_.string(),event_payload:_.string()}),Ur=_.object({mrtd:_.string(),rootfs_hash:_.string().nullable().optional(),rtmr0:_.string(),rtmr1:_.string(),rtmr2:_.string(),rtmr3:_.string(),event_log:_.array(_c),app_compose:_.string()}),wc=_.object({name:_.string().nullable(),is_online:_.boolean(),is_public:_.boolean().default(!0),error:_.string().nullable(),app_certificates:_.array(Fr).nullable(),tcb_info:Ur.nullable(),compose_file:_.string().nullable()}),Cc=j,{action:kc,safeAction:Sc}=b(wc,async(e,t)=>{let{cvmId:n}=Cc.parse(t);return await e.get(`/cvms/${n}/attestation`)}),Ec=me(oe.extend({vcpu:rt.number().optional(),memory:rt.number().optional(),disk_size:rt.number().optional(),instance_type:rt.string().optional(),allow_restart:rt.boolean().optional()})),{action:Ac,safeAction:Ic}=b(rt.void(),async(e,t)=>{let n=Ec.parse(t),{cvmId:r}=j.parse(n),{...s}=n;await e.patch(`/cvms/${r}/resources`,s)}),xc=me(oe.extend({public_sysinfo:Wt.boolean(),public_logs:Wt.boolean(),public_tcbinfo:Wt.boolean().optional()})),{action:Rc,safeAction:Tc}=b(Rr,async(e,t)=>{let n=xc.parse(t),{cvmId:r}=j.parse(n),{public_sysinfo:s,public_logs:o,public_tcbinfo:a}=n;return await e.patch(`/cvms/${r}/visibility`,{public_sysinfo:s,public_logs:o,public_tcbinfo:a})}),dr=Q.object({name:Q.string(),os_image_hash:Q.string().nullable(),is_current:Q.boolean()}),Pc=Q.object({version:Q.union([Q.tuple([Q.number(),Q.number(),Q.number(),Q.number()]),Q.tuple([Q.number(),Q.number(),Q.number()])]),prod:dr.nullable(),dev:dr.nullable()}),jc=Q.array(Pc),Oc=j,{action:$c,safeAction:Lc}=b(jc,async(e,t)=>{let{cvmId:n}=Oc.parse(t);return await e.get(`/cvms/${n}/available-os-images`)}),Nc=me(oe.extend({os_image_name:zr.string().min(1,"OS image name is required")})),{action:qc,safeAction:Fc}=b(zr.void(),async(e,t)=>{let n=Nc.parse(t),{cvmId:r}=j.parse(n),{os_image_name:s}=n;await e.patch(`/cvms/${r}/os-image`,{os_image_name:s})}),Uc=Ee.object({id:Ee.string().optional(),instance_id:Ee.string().optional(),name:Ee.string(),status:Ee.string(),uptime:Ee.string().optional(),exited_at:Ee.string().optional(),boot_progress:Ee.string().optional(),boot_error:Ee.string().optional(),shutdown_progress:Ee.string().optional()}),zc=j,{action:Dc,safeAction:Hc}=b(Uc,async(e,t)=>{let{cvmId:n}=zc.parse(t);return await e.get(`/cvms/${n}/state`)}),Dr=ce.object({id:ce.string(),user_id:ce.string(),name:ce.string(),public_key:ce.string(),fingerprint:ce.string(),key_type:ce.string(),source:ce.string(),key_metadata:ce.record(ce.unknown()).nullable().optional(),last_synced_at:ce.string().nullable().optional(),created_at:ce.string(),updated_at:ce.string()}),Bc=ce.array(Dr);async function Hr(e){let t=await e.get("/user/ssh-keys");return Bc.parse(t)}async function Vc(e){try{return{success:!0,data:await Hr(e)}}catch(t){return t&&typeof t=="object"&&("status"in t||"issues"in t)?{success:!1,error:t}:{success:!1,error:{name:"Error",message:t instanceof Error?t.message:String(t)}}}}var Mc=Fe.object({github_username:Fe.string().min(1)}),Kc=Fe.object({github_username:Fe.string(),keys_added:Fe.number().int(),keys_skipped:Fe.number().int(),errors:Fe.array(Fe.string()).default([])}),{action:Gc,safeAction:Wc}=b(Kc,async(e,t)=>{let{github_username:n}=Mc.parse(t);return await e.post("/user/ssh-keys/github-profile",{github_username:n})}),Xc=Xt.object({name:Xt.string().min(1),public_key:Xt.string().min(1)}),{action:Jc,safeAction:Zc}=b(Dr,async(e,t)=>{let{name:n,public_key:r}=Xc.parse(t);return await e.post("/user/ssh-keys",{name:n,public_key:r})}),Qc=Zt.object({keyId:Zt.string().min(1)}),{action:Yc,safeAction:el}=b(Zt.void(),async(e,t)=>{let{keyId:n}=Qc.parse(t);await e.delete(`/user/ssh-keys/${n}`)}),tl=He.object({synced_count:He.number().int(),keys_added:He.number().int(),keys_updated:He.number().int(),keys_removed:He.number().int(),errors:He.array(He.string()).default([])}),{action:nl,safeAction:rl}=Er(tl,async e=>await e.post("/user/ssh-keys/github-sync",{})),sl=X.object({name:X.string(),slug:X.string(),version:X.string(),os_image_hash:X.string().nullable(),is_dev:X.boolean(),requires_gpu:X.boolean()}).passthrough(),ol=X.object({page:X.number().int().min(1).optional(),page_size:X.number().int().min(1).optional(),is_dev:X.boolean().optional()}).strict(),al=X.object({items:X.array(sl),total:X.number(),page:X.number(),page_size:X.number(),pages:X.number()}).passthrough(),{action:il,safeAction:cl}=b(al,async(e,t)=>{let n=ol.parse(t??{});return await e.get("/os-images",{params:n})}),ll=B.object({device_id:B.string(),node_name:B.string().nullable().optional(),on_chain_allowed:B.boolean().nullable()}).passthrough(),ul=B.object({name:B.string(),version:B.string(),os_image_hash:B.string().nullable(),on_chain_allowed:B.boolean().nullable()}).passthrough(),pl=B.object({contract_address:B.string(),chain_id:B.number(),chain_name:B.string(),devices:B.array(ll),os_images:B.array(ul)}).passthrough(),dl=B.object({chain_name:B.string(),chain_id:B.number(),contracts:B.array(pl)}).passthrough(),ml=B.object({chain:B.string()}).strict(),{action:fl,safeAction:gl}=b(dl,async(e,t)=>{let{chain:n}=ml.parse(t);return await e.get(`/kms/on-chain/${n}`)});function Br(e={}){let t=Lo(e),n={getCurrentUser:wr,safeGetCurrentUser:Ho,getAvailableNodes:Wo,safeGetAvailableNodes:Xo,listAllInstanceTypeFamilies:ea,safeListAllInstanceTypeFamilies:ta,listFamilyInstanceTypes:na,safeListFamilyInstanceTypes:ra,listWorkspaces:aa,safeListWorkspaces:ia,getWorkspace:ca,safeGetWorkspace:la,getCvmInfo:jr,safeGetCvmInfo:Rt,getCvmList:Or,safeGetCvmList:nn,provisionCvm:ja,safeProvisionCvm:Oa,commitCvmProvision:La,safeCommitCvmProvision:Na,getCvmComposeFile:Ha,safeGetCvmComposeFile:Ba,provisionCvmComposeFileUpdate:Ka,safeProvisionCvmComposeFileUpdate:Ga,commitCvmComposeFileUpdate:Ja,safeCommitCvmComposeFileUpdate:Za,updateCvmEnvs:ni,safeUpdateCvmEnvs:ri,updateDockerCompose:ci,safeUpdateDockerCompose:li,updatePreLaunchScript:fi,safeUpdatePreLaunchScript:gi,getCvmPreLaunchScript:vi,safeGetCvmPreLaunchScript:yi,startCvm:Ni,safeStartCvm:qi,stopCvm:Ui,safeStopCvm:zi,shutdownCvm:Hi,safeShutdownCvm:Bi,restartCvm:Ki,safeRestartCvm:Gi,deleteCvm:Ji,safeDeleteCvm:Zi,getCvmStats:nc,safeGetCvmStats:rc,getCvmNetwork:ic,safeGetCvmNetwork:cc,getCvmDockerCompose:pc,safeGetCvmDockerCompose:dc,getCvmContainersStats:hc,safeGetCvmContainersStats:bc,getCvmAttestation:kc,safeGetCvmAttestation:Sc,updateCvmResources:Ac,safeUpdateCvmResources:Ic,updateCvmVisibility:Rc,safeUpdateCvmVisibility:Tc,getAvailableOsImages:$c,safeGetAvailableOsImages:Lc,updateOsImage:qc,safeUpdateOsImage:Fc,getKmsInfo:wi,safeGetKmsInfo:Ci,getKmsList:Ei,safeGetKmsList:Ai,getAppEnvEncryptPubKey:Ri,safeGetAppEnvEncryptPubKey:Ti,nextAppIds:Oi,safeNextAppIds:$i,getCvmState:Dc,safeGetCvmState:Hc,listSshKeys:Hr,safeListSshKeys:Vc,importGithubProfileSshKeys:Gc,safeImportGithubProfileSshKeys:Wc,createSshKey:Jc,safeCreateSshKey:Zc,deleteSshKey:Yc,safeDeleteSshKey:el,syncGithubSshKeys:nl,safeSyncGithubSshKeys:rl,getOsImages:il,safeGetOsImages:cl,getKmsOnChainDetail:fl,safeGetKmsOnChainDetail:gl};return t.extend(n)}var mr=h.object({vm_uuid:h.string().nullable(),app_id:h.string(),name:h.string().default(""),status:h.string(),vcpu:h.number().int(),memory:h.number().int(),disk_size:h.number().int(),teepod_id:h.number().int(),teepod_name:h.string(),region_identifier:h.string().nullable().optional(),kms_type:h.string().nullable().optional(),instance_type:h.string().nullable().optional(),listed:h.boolean().nullable().optional(),base_image:h.string().nullable().optional(),kms_slug:h.string().nullable().optional(),kms_id:h.string().nullable().optional(),instance_id:h.string().nullable().optional(),machine_info:Qt.nullable().optional(),updated_at:h.string().nullable().optional()}),hl=h.object({display_name:h.string().nullable().optional(),avatar_url:h.string().nullable().optional(),description:h.string().nullable().optional(),custom_domain:h.string().nullable().optional()}),bl=h.object({id:h.string(),name:h.string(),app_id:h.string(),app_provision_type:h.string().nullable().optional(),app_icon_url:h.string().nullable().optional(),created_at:h.string(),kms_type:h.string(),profile:hl.nullable().optional(),current_cvm:mr.nullable().optional(),cvms:h.array(mr).default([]),cvm_count:h.number().int().default(0)}),vl=h.object({id:h.null().optional(),app_id:h.string(),name:h.null().optional(),app_provision_type:h.null().optional(),app_icon_url:h.null().optional(),created_at:h.null().optional(),kms_type:h.null().optional(),current_cvm:h.null().optional(),cvms:h.null().optional(),cvm_count:h.null().optional()}),yl=h.union([bl,vl]),Vp=h.object({dstack_apps:h.array(yl),page:h.number().int(),page_size:h.number().int(),total:h.number().int(),total_pages:h.number().int()}),_l=R.object({id:R.string(),name:R.string(),app_id:R.string(),app_provision_type:R.string().nullable().optional(),app_icon_url:R.string().nullable().optional(),created_at:R.string(),kms_type:R.string(),profile:R.object({display_name:R.string().nullable().optional(),avatar_url:R.string().nullable().optional(),description:R.string().nullable().optional(),custom_domain:R.string().nullable().optional()}).nullable().optional(),current_cvm:At.nullable().optional(),cvms:R.array(At).default([]),cvm_count:R.number().int().default(0)}),wl=R.object({id:R.null().optional(),app_id:R.string(),name:R.null().optional(),app_provision_type:R.null().optional(),app_icon_url:R.null().optional(),created_at:R.null().optional(),kms_type:R.null().optional(),current_cvm:R.null().optional(),cvms:R.null().optional(),cvm_count:R.null().optional()}),Cl=R.union([_l,wl]),Kp=R.object({dstack_apps:R.array(Cl),page:R.number().int(),page_size:R.number().int(),total:R.number().int(),total_pages:R.number().int()}),Vr=I.object({object_type:I.literal("cvm"),id:I.string().nullable().optional(),name:I.string().nullable().optional(),app_id:I.string().nullable().optional(),vm_uuid:I.string().nullable().optional()}),kl=I.object({revision_id:I.string(),app_id:I.string(),vm_uuid:I.string(),compose_hash:I.string(),created_at:I.string(),trace_id:I.string().nullable().optional(),operation_type:I.string(),triggered_by:en.nullable().optional(),cvm:Vr.nullable().optional(),workspace:tn.nullable().optional()}),Wp=I.object({revision_id:I.string(),app_id:I.string(),vm_uuid:I.string(),compose_hash:I.string(),compose_file:I.union([I.record(I.any()),I.string()]).nullable().optional(),encrypted_env:I.string(),user_config:I.string(),created_at:I.string(),trace_id:I.string().nullable().optional(),operation_type:I.string(),triggered_by:en.nullable().optional(),cvm:Vr.nullable().optional(),workspace:tn.nullable().optional()}),Xp=I.object({revisions:I.array(kl),total:I.number().int(),page:I.number().int(),page_size:I.number().int(),total_pages:I.number().int()});var Sl=V.object({chain:V.unknown().optional(),rpcUrl:V.string().optional(),kmsContractAddress:V.string(),privateKey:V.string().optional(),walletClient:V.unknown().optional(),publicClient:V.unknown().optional(),allowAnyDevice:V.boolean().optional().default(!1),deviceId:V.string().optional().default("0000000000000000000000000000000000000000000000000000000000000000"),composeHash:V.string().optional().default("0000000000000000000000000000000000000000000000000000000000000000"),disableUpgrades:V.boolean().optional().default(!1),skipPrerequisiteChecks:V.boolean().optional().default(!1),minBalance:V.string().optional()}).passthrough(),hd=Sl.refine(e=>{let t=!!e.privateKey,n=!!e.walletClient;return t!==n},{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>{let t=!!e.publicClient,n=!!e.walletClient,r=!!e.chain;return t&&n?!0:r},{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),bd=V.object({appId:V.string(),appAuthAddress:V.string(),deployer:V.string(),transactionHash:V.string(),blockNumber:V.bigint().optional(),gasUsed:V.bigint().optional()}).passthrough();var Id=q.object({chain:q.unknown().optional(),rpcUrl:q.string().optional(),appId:q.string(),composeHash:q.string(),privateKey:q.string().optional(),walletClient:q.unknown().optional(),publicClient:q.unknown().optional(),skipPrerequisiteChecks:q.boolean().optional().default(!1),minBalance:q.string().optional(),timeout:q.number().optional().default(12e4),retryOptions:q.unknown().optional(),signal:q.unknown().optional(),onTransactionStateChange:q.function().optional(),onTransactionSubmitted:q.function().optional(),onTransactionConfirmed:q.function().optional()}).passthrough().refine(e=>{let t=!!e.privateKey,n=!!e.walletClient;return t!==n},{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>{let t=!!e.publicClient,n=!!e.walletClient,r=!!e.chain;return t&&n?!0:r},{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),xd=q.object({composeHash:q.string(),appId:q.string(),transactionHash:q.string(),blockNumber:q.bigint().optional(),gasUsed:q.bigint().optional()}).passthrough();var qd=F.object({chain:F.unknown().optional(),rpcUrl:F.string().optional(),appAddress:F.string(),deviceId:F.string(),privateKey:F.string().optional(),walletClient:F.unknown().optional(),publicClient:F.unknown().optional(),skipPrerequisiteChecks:F.boolean().optional().default(!1),minBalance:F.string().optional(),timeout:F.number().optional().default(12e4),retryOptions:F.unknown().optional(),signal:F.unknown().optional(),onTransactionStateChange:F.function().optional(),onTransactionSubmitted:F.function().optional(),onTransactionConfirmed:F.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),Fd=F.object({appAddress:F.string(),deviceId:F.string(),transactionHash:F.string(),blockNumber:F.bigint().optional(),gasUsed:F.bigint().optional()}).passthrough();var Gd=U.object({chain:U.unknown().optional(),rpcUrl:U.string().optional(),appAddress:U.string(),deviceId:U.string(),privateKey:U.string().optional(),walletClient:U.unknown().optional(),publicClient:U.unknown().optional(),skipPrerequisiteChecks:U.boolean().optional().default(!1),minBalance:U.string().optional(),timeout:U.number().optional().default(12e4),retryOptions:U.unknown().optional(),signal:U.unknown().optional(),onTransactionStateChange:U.function().optional(),onTransactionSubmitted:U.function().optional(),onTransactionConfirmed:U.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),Wd=U.object({appAddress:U.string(),deviceId:U.string(),transactionHash:U.string(),blockNumber:U.bigint().optional(),gasUsed:U.bigint().optional()}).passthrough();var rm=z.object({chain:z.unknown().optional(),rpcUrl:z.string().optional(),appAddress:z.string(),allow:z.boolean(),privateKey:z.string().optional(),walletClient:z.unknown().optional(),publicClient:z.unknown().optional(),skipPrerequisiteChecks:z.boolean().optional().default(!1),minBalance:z.string().optional(),timeout:z.number().optional().default(12e4),retryOptions:z.unknown().optional(),signal:z.unknown().optional(),onTransactionStateChange:z.function().optional(),onTransactionSubmitted:z.function().optional(),onTransactionConfirmed:z.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),sm=z.object({appAddress:z.string(),allow:z.boolean(),transactionHash:z.string(),blockNumber:z.bigint().optional(),gasUsed:z.bigint().optional()}).passthrough();var lm=Ye.object({appAddress:Ye.string(),owner:Ye.string(),allowAnyDevice:Ye.boolean(),devices:Ye.array(Ye.string())});var El=Tr;var Al=et.object({items:et.array(El),total:et.number(),page:et.number(),page_size:et.number(),pages:et.number()}).passthrough(),{action:_m,safeAction:wm}=b(Al,async(e,t)=>{let{teamSlug:n,page:r,pageSize:s}=t,o=new URLSearchParams;r!==void 0&&o.append("page",r.toString()),s!==void 0&&o.append("page_size",s.toString());let a=o.toString()?`/workspaces/${n}/nodes?${o.toString()}`:`/workspaces/${n}/nodes`;return await e.get(a)}),st=_e.object({limit:_e.number(),remaining:_e.number()}).passthrough(),Il=_e.object({vm_slots:st,vcpu:st,memory_mb:st,disk_gb:st}).passthrough(),xl=_e.object({gpus:st,in_use:_e.number(),misconfigured:_e.number()}).passthrough(),Rl=_e.object({team_slug:_e.string(),tier:_e.string(),quotas:Il,reserved_nodes:st,reserved_gpu:xl,as_of:_e.string()}).passthrough(),{action:km,safeAction:Sm}=b(Rl,async(e,t)=>await e.get(`/workspaces/${t.teamSlug}/quotas`)),Pl=me(oe.extend({node_id:Tl.number().optional()})),{action:Am,safeAction:Im}=b(it,async(e,t)=>{let n=Pl.parse(t),{cvmId:r}=j.parse(n),{node_id:s}=n;return await e.post(`/cvms/${r}/replicas`,{node_id:s})}),Rm=tt.object({target:tt.string().describe("Target status to wait for (e.g., 'running', 'stopped')"),interval:tt.number().min(5).max(30).default(5).describe("Polling interval in seconds"),timeout:tt.number().min(10).max(600).default(300).describe("Timeout per attempt in seconds"),maxRetries:tt.number().min(0).default(Number.POSITIVE_INFINITY).describe("Maximum number of retry attempts (Infinity for unlimited)"),retryDelay:tt.number().min(0).default(5e3).describe("Delay between retries in milliseconds")});var jl=me(oe.extend({docker_compose_file:A.string().optional(),pre_launch_script:A.string().optional(),allowed_envs:A.array(A.string()).optional(),public_logs:A.boolean().optional(),public_sysinfo:A.boolean().optional(),public_tcbinfo:A.boolean().optional(),encrypted_env:A.string().optional(),user_config:A.string().optional(),gpus:A.object({count:A.number(),product_name:A.string().optional()}).optional(),vcpu:A.number().optional(),memory:A.number().optional(),disk_size:A.number().optional(),image:A.string().optional(),shutdown_timeout:A.number().optional(),allow_force_stop:A.boolean().optional(),prepareOnly:A.boolean().optional()})),Ol=A.object({requiresOnChainHash:A.literal(!1),correlationId:A.string()}),$l=A.object({requiresOnChainHash:A.literal(!0),composeHash:A.string(),appId:A.string(),deviceId:A.string(),kmsInfo:Ce,commitToken:A.string().optional(),commitUrl:A.string().optional(),apiCommitUrl:A.string().optional(),onchainStatus:A.object({compose_hash_allowed:A.boolean(),device_id_allowed:A.boolean(),is_allowed:A.boolean()}).optional()}),Ll=A.discriminatedUnion("requiresOnChainHash",[Ol,$l]);function Nl(e){let t={};if(!e||typeof e!="object")return t;let r=e.details;if(!Array.isArray(r))return t;for(let s of r)s&&typeof s=="object"&&"field"in s&&"value"in s&&(t[s.field]=s.value);return t}var{action:Pm,safeAction:jm}=b(Ll,async(e,t)=>{let n=jl.parse(t),{cvmId:r}=j.parse(n),{id:s,uuid:o,app_id:a,instance_id:i,name:l,prepareOnly:m,...u}=n;try{return{requiresOnChainHash:!1,correlationId:(m?await e.patch(`/cvms/${r}`,u,{headers:{"X-Prepare-Only":"true"}}):await e.patch(`/cvms/${r}`,u)).correlation_id}}catch(f){if(f instanceof we&&f.status===465){let g=Nl(f.detail);return{requiresOnChainHash:!0,composeHash:g.compose_hash,appId:String(g.app_id),deviceId:g.device_id,kmsInfo:g.kms_info,commitToken:g.commit_token,commitUrl:g.commit_url,apiCommitUrl:g.api_commit_url,onchainStatus:g.onchain_status}}throw f}}),ql=me(oe.extend({composeHash:It.string().describe("Compose hash from patchCvm Phase 1 response"),transactionHash:It.string().describe("Transaction hash proving on-chain registration")})),Fl=It.object({correlationId:It.string()}),{action:$m,safeAction:Lm}=b(Fl,async(e,t)=>{let n=ql.parse(t),{cvmId:r}=j.parse(n);return{correlationId:(await e.patch(`/cvms/${r}`,{},{headers:{"X-Compose-Hash":n.composeHash,"X-Transaction-Hash":n.transactionHash}})).correlation_id}}),Ul=me(oe.extend({token:at.string().describe("One-time commit token from prepare-only flow"),composeHash:at.string().describe("Compose hash from Phase 1 response"),transactionHash:at.string().describe("Transaction hash proving on-chain registration")})),zl=at.object({correlationId:at.string(),status:at.string()}),{action:qm,safeAction:Fm}=b(zl,async(e,t)=>{let n=Ul.parse(t),{cvmId:r}=j.parse(n),s=await e.post(`/cvms/${r}/commit-update`,{token:n.token,compose_hash:n.composeHash,transaction_hash:n.transactionHash});return{correlationId:s.correlation_id,status:s.status}}),Mr=ve.object({cvm_id:ve.number().int(),identifier:ve.string(),status:ve.enum(["updated","unchanged","skipped","conflict","error"]),old_instance_id:ve.string().nullable().optional(),new_instance_id:ve.string().nullable().optional(),source:ve.enum(["teepod_state","teepod_info","gateway","none"]),verified_with_gateway:ve.boolean(),reason:ve.string().nullable().optional()}),Dl=me(oe.extend({overwrite:ve.boolean().optional(),dry_run:ve.boolean().optional()})),{action:zm,safeAction:Dm}=b(Mr,async(e,t)=>{let n=Dl.parse(t),{cvmId:r}=j.parse(n),{overwrite:s,dry_run:o}=n;return await e.patch(`/cvms/${r}/instance-id`,{overwrite:s,dry_run:o})}),Hl=W.object({cvm_ids:W.array(W.string()).optional(),running_only:W.boolean().optional(),missing_only:W.boolean().optional(),overwrite:W.boolean().optional(),limit:W.number().int().min(1).max(500).optional(),dry_run:W.boolean().optional()}).strict(),Bl=W.object({total:W.number().int(),scanned:W.number().int(),updated:W.number().int(),unchanged:W.number().int(),skipped:W.number().int(),conflicts:W.number().int(),errors:W.number().int(),items:W.array(Mr)}),{action:Bm,safeAction:Vm}=b(Bl,async(e,t)=>{let n=Hl.parse(t);return await e.patch("/cvms/instance-ids",n)}),Vl=te.object({vm_uuid:te.string(),status:te.string(),uptime:te.string().nullable().optional(),in_progress:te.boolean(),boot_progress:te.string().nullable().optional(),boot_error:te.string().nullable().optional(),operation_type:te.string().nullable().optional(),operation_started_at:te.string().nullable().optional(),correlation_id:te.string().nullable().optional()}),Ml=te.record(te.string(),Vl),Kl=te.object({vmUuids:te.array(te.string())}),{action:Km,safeAction:Gm}=b(Ml,async(e,t)=>{let{vmUuids:n}=Kl.parse(t);return await e.post("/status/batch",{vm_uuids:n})}),Gl=ft.object({hostname:ft.string().nullable().optional(),ssh_authorized_keys:ft.array(ft.string()).default([]),default_gateway_domain:ft.string().nullable().optional()}),Wl=j,{action:Xm,safeAction:Jm}=b(Gl,async(e,t)=>{let{cvmId:n}=Wl.parse(t);return await e.get(`/cvms/${n}/user_config`)}),rn=ne.object({cvm_id:ne.number().optional(),app_contract_address:ne.string(),compose_hash:ne.string(),device_id:ne.string(),compose_hash_allowed:ne.boolean(),allow_any_device:ne.boolean(),device_id_allowed:ne.boolean().nullable().optional(),is_allowed:ne.boolean(),error:ne.string().nullable().optional()}),Xl=ne.object({cvmId:ne.string().min(1),compose_hash:ne.string().optional(),node_id:ne.number().optional(),device_id:ne.string().optional()}),Jl=Xl,{action:Qm,safeAction:Ym}=b(rn,async(e,t)=>{let{cvmId:n,...r}=Jl.parse(t);return await e.post(`/cvms/${n}/is-allowed`,r)}),Zl=nt.object({appId:nt.string().min(1),compose_hash:nt.string(),node_id:nt.number().optional(),device_id:nt.string().optional(),chain_id:nt.number().optional()}),{action:tf,safeAction:nf}=b(rn,async(e,t)=>{let{appId:n,...r}=Zl.parse(t);return await e.post(`/apps/${n}/is-allowed`,r)}),Ql=he.object({is_onchain:he.boolean(),results:he.array(rn.extend({cvm_id:he.number()})).default([]),total:he.number().default(0),allowed_count:he.number().default(0),denied_count:he.number().default(0),error_count:he.number().default(0),skipped_cvm_ids:he.array(he.number()).default([])}),Yl=he.object({appId:he.string().min(1)}),{action:sf,safeAction:of}=b(Ql,async(e,t)=>{let{appId:n}=Yl.parse(t);return await e.post(`/apps/${n}/cvms/is-allowed`,{})}),cf=de.object({page:de.number().int().min(1).optional(),page_size:de.number().int().min(1).max(100).optional(),search:de.string().optional(),status:de.array(de.string()).optional(),listed:de.boolean().optional(),base_image:de.string().optional(),instance_type:de.string().optional(),kms_slug:de.string().optional(),kms_type:de.string().optional(),node:de.string().optional(),region:de.string().optional()}).strict();var uf=fr.object({appId:fr.string().min(1)}).strict();var df=gr.object({appId:gr.string().min(1)}).strict();var eu=Te.object({appId:Te.string().min(1),node_id:Te.number().optional(),docker_compose_file:Te.string().optional(),pre_launch_script:Te.string().optional(),encrypted_env:Te.string().optional(),compose_hash:Te.string().optional(),token:Te.string().optional(),transaction_hash:Te.string().optional()}).strict(),{action:ff,safeAction:gf}=b(it,async(e,t)=>{let n=eu.parse(t),{appId:r,...s}=n;return await e.post(`/apps/${r}/instances`,s)}),tu=se.object({device_id:se.string(),node_name:se.string().nullable(),cvm_ids:se.array(se.number()),allowed_onchain:se.boolean(),status:se.string()}),bf=se.object({is_onchain_kms:se.boolean(),allow_any_device:se.boolean().nullable().optional(),chain_id:se.number().nullable().optional(),app_contract_address:se.string().nullable().optional(),devices:se.array(tu).optional().default([])}),vf=se.object({appId:se.string().min(1)}).strict();var _f=kt.object({appId:kt.string().min(1),page:kt.number().int().min(1).optional(),page_size:kt.number().int().min(1).max(1e3).optional()}).strict();var Cf=St.object({appId:St.string().min(1),revisionId:St.string().min(1),rawComposeFile:St.boolean().optional()}).strict();var Sf=ee.object({statuses:ee.array(ee.string()),image_versions:ee.array(ee.string()),instance_types:ee.array(ee.string()),kms_slugs:ee.array(ee.string()),kms_types:ee.array(ee.string()),regions:ee.array(ee.string()),nodes:ee.array(ee.string())});var nu=T.object({contract_address:T.string(),chain_id:T.string().nullable(),version:T.string(),url:T.string(),gateway_app_id:T.string().nullable(),gateway_app_url:T.string(),kms_type:T.string()}),hr=T.object({app_id:T.string().optional(),instance_id:T.string().optional(),app_name:T.string().optional(),device_id:T.string().optional()}).passthrough().nullable(),ru=T.object({vm_uuid:T.string().nullable().optional(),name:T.string().optional(),instance_id:T.string().nullable().optional(),status:T.string().optional(),image_version:T.string().nullable().optional(),quote:T.string().nullable().optional(),ppid:T.string().optional(),device_id:T.string().optional(),tcb_info:Ur.nullable().optional(),app_certificates:T.array(Fr).nullable().optional(),compose_file:T.string().nullable().optional(),error:T.string().nullable().optional()}),su=T.object({app_id:T.string(),contract_address:T.string(),kms_info:nu,instances:T.array(ru),kms_guest_agent_info:hr,gateway_guest_agent_info:hr,qemu_version:T.string().nullable()}),ou=T.object({appId:T.string().min(1)}).strict(),{action:Af,safeAction:If}=b(su,async(e,t)=>{let{appId:n}=ou.parse(t);return await e.get(`/apps/${n}/attestations`)});var lu;function Kr(){return lu}import fu from"path";import sn from"fs-extra";import gu from"@iarna/toml";import{z as xe}from"zod";import ae from"chalk";import pu from"ora";var uu=!1;function ke(){return uu}function du(e,t){let n=e.split(/\s+/),r=[],s="";for(let o of n){let a=s.length===0?o:`${s} ${o}`;a.length<=t?s=a:(s.length>0&&r.push(s),s=o)}return s.length>0&&r.push(s),r}function mu(e,t){if(e.length<=t)return[e];let n=[],r=0;for(;r<e.length;)n.push(e.slice(r,r+t)),r+=t;return n}function Gr(e,t){let n=[];for(let r of e.split(`
21
- `)){if(r.length<=t){n.push(r);continue}if(r.indexOf(" ")===-1){n.push(...mu(r,t));continue}let s=du(r,t);n.push(...s)}if(n.length===0){let r=e.trim();n.push(r)}return n}var Ue={error:(e,...t)=>{ke()||(process.stderr.write(`${ae.red("\u2717")} ${ae.red(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
22
- `))},warn:(e,...t)=>{ke()||(process.stderr.write(`${ae.yellow("\u26A0")} ${ae.yellow(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
23
- `))},info:(e,...t)=>{ke()||(process.stderr.write(`${ae.blue("\u2139")} ${ae.blue(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
24
- `))},success:(e,...t)=>{ke()||(process.stderr.write(`${ae.green("\u2713")} ${ae.green(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
25
- `))},debug:(e,...t)=>{ke()||process.env.DEBUG&&(process.stderr.write(`${ae.gray("\u{1F50D}")} ${ae.gray(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
26
- `))},table:(e,t)=>{if(!ke()){if(e.length===0){console.log(ae.yellow("No data to display"));return}if(t){let n;typeof t[0]=="string"?n=t.map(a=>({key:a,header:a})):n=t;let r={};for(let a of n){let i=a.header||String(a.key);r[String(a.key)]=i.length}for(let a of e)for(let i of n){let l=String(typeof i.key=="string"&&!(i.key in a)?"":a[String(i.key)]??"");r[String(i.key)]=Math.max(r[String(i.key)],l.length)}let s=[];for(let a of n){let i=a.header||String(a.key);s.push(ae.bold(i.padEnd(r[String(a.key)])))}console.log(s.join(" "));let o=[];for(let a of n)o.push("-".repeat(r[String(a.key)]));console.log(o.join(" "));for(let a of e){let i=[];for(let l of n){let m=String(typeof l.key=="string"&&!(l.key in a)?"":a[String(l.key)]??"");i.push(m.padEnd(r[String(l.key)]))}console.log(i.join(" "))}}else{let n=e[0],r=Object.keys(n),s={};for(let i of r)s[i]=i.length;for(let i of e)for(let l of r){let m=String(i[l]??"");s[l]=Math.max(s[l],m.length)}let o=[];for(let i of r)o.push(ae.bold(i.padEnd(s[i])));console.log(o.join(" "));let a=[];for(let i of r)a.push("-".repeat(s[i]));console.log(a.join(" "));for(let i of e){let l=[];for(let m of r){let u=String(i[m]??"");l.push(u.padEnd(s[m]))}console.log(l.join(" "))}}}},keyValueTable:(e,t)=>{if(ke())return;let{borderStyle:n="single",keyColor:r=ae.blue,valueColor:s=ae.white,maxWidth:o=process.stdout.columns||80}=t||{},i={single:{topLeft:"\u250C",topRight:"\u2510",bottomLeft:"\u2514",bottomRight:"\u2518",horizontal:"\u2500",vertical:"\u2502",cross:"\u253C",leftT:"\u251C",rightT:"\u2524"},double:{topLeft:"\u2554",topRight:"\u2557",bottomLeft:"\u255A",bottomRight:"\u255D",horizontal:"\u2550",vertical:"\u2551",cross:"\u256C",leftT:"\u2560",rightT:"\u2563"},rounded:{topLeft:"\u256D",topRight:"\u256E",bottomLeft:"\u2570",bottomRight:"\u256F",horizontal:"\u2500",vertical:"\u2502",cross:"\u253C",leftT:"\u251C",rightT:"\u2524"},bold:{topLeft:"\u250F",topRight:"\u2513",bottomLeft:"\u2517",bottomRight:"\u251B",horizontal:"\u2501",vertical:"\u2503",cross:"\u254B",leftT:"\u2523",rightT:"\u252B"},none:{topLeft:"",topRight:"",bottomLeft:"",bottomRight:"",horizontal:"",vertical:"",cross:"",leftT:"",rightT:""}}[n],l=0,m=0;for(let[S,x]of Object.entries(e)){l=Math.max(l,S.length);let N=String(x??"");m=Math.max(m,N.length)}let u=4,f=1,g=o-u-f;if(l+m>g){let S=l/(l+m);l=Math.floor(g*S),m=g-l}let y=l+m+u+f;n!=="none"&&console.log(i.topLeft+i.horizontal.repeat(y-2)+i.topRight);for(let[S,x]of Object.entries(e)){let N=S,Y=String(x??""),fe=Gr(N,l),Pe=Gr(Y,m),Se=Math.max(fe.length,Pe.length);for(;fe.length<Se;)fe.push("");for(;Pe.length<Se;)Pe.push("");for(let je=0;je<Se;je++){let Ve=fe[je].padEnd(l),gt=Pe[je].padEnd(m);console.log(n!=="none"?`${i.vertical} ${r(Ve)} ${i.vertical} ${s(gt)} ${i.vertical}`:`${r(Ve)} : ${s(gt)}`)}}n!=="none"&&console.log(i.bottomLeft+i.horizontal.repeat(y-2)+i.bottomRight)},break:()=>{ke()||process.stderr.write(`
27
- `)},startSpinner:e=>{if(ke())return{stop:()=>{}};let t=pu(e).start();return{stop:(n=!0,r)=>{r&&(t.text=r),n?t.succeed():t.fail()}}},logDetailedError(e,t){if(ke())return;let n=t?`[${t}] `:"",r=o=>o!==null&&typeof o=="object"&&"isRequestError"in o&&o.isRequestError===!0&&"status"in o&&"message"in o&&"data"in o,s=o=>o!==null&&typeof o=="object"&&"issues"in o&&Array.isArray(o.issues);if(r(e)){process.stderr.write(`${n}HTTP ${e.status}: ${e.message}
28
- `),e.data!==void 0&&e.data!==null&&process.stderr.write(`${JSON.stringify(e.data,null,2)}
29
- `);return}if(s(e)){process.stderr.write(`${n}Validation error: ${JSON.stringify(e.issues)}
20
+ `,q,te,Qt(k.status,k.statusText,k.headers,k._data))}m&&m({request:_,response:k,options:R})}})}get raw(){return this.fetchInstance}on(t,n){this.emitter.on(t,n)}off(t,n){this.emitter.off(t,n)}once(t,n){let r=s=>{n(s),this.emitter.off(t,r)};this.emitter.on(t,r)}async request(t,n){try{let r=n?.method||"GET";return await this.fetchInstance(t,{...n,method:r})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}async requestFull(t,n){try{let r=n?.method||"GET",s=await this.fetchInstance.raw(t,{...n,method:r,ignoreResponseError:!0});return{status:s.status,statusText:s.statusText,headers:s.headers,data:s._data,ok:s.ok}}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}async get(t,n){try{return await this.fetchInstance(t,{...n,method:"GET"})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}buildRequestOptions(t,n,r){let s={...r,method:t,body:n};if(n instanceof FormData){let o=s.headers;s.headers={...o,"Content-Type":""}}return s}async post(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("POST",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async put(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("PUT",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async patch(t,n,r){try{return await this.fetchInstance(t,this.buildRequestOptions("PATCH",n,r))}catch(s){let o=this.convertToRequestError(s);throw this.emitError(o)}}async delete(t,n){try{return await this.fetchInstance(t,{...n,method:"DELETE"})}catch(r){let s=this.convertToRequestError(r);throw this.emitError(s)}}convertToRequestError(t){return t&&typeof t=="object"&&"data"in t?St.fromFetchError(t):t instanceof Error?St.fromError(t):new St("Unknown error occurred",{detail:"Unknown error occurred"})}emitError(t){let n=ms(t);return this.emitter.emit("error",n),n}async safeRequest(t){try{return{success:!0,data:await t()}}catch(n){if(n instanceof ge)return{success:!1,error:n};let r=this.convertToRequestError(n);return this.emitError(r),{success:!1,error:r}}}async safeGet(t,n){return this.safeRequest(()=>this.get(t,n))}async safePost(t,n,r){return this.safeRequest(()=>this.post(t,n,r))}async safePut(t,n,r){return this.safeRequest(()=>this.put(t,n,r))}async safePatch(t,n,r){return this.safeRequest(()=>this.patch(t,n,r))}async safeDelete(t,n){return this.safeRequest(()=>this.delete(t,n))}async safeRequestMethod(t,n){return this.safeRequest(()=>this.request(t,n))}async safeRequestFull(t,n){return this.safeRequest(()=>this.requestFull(t,n))}withVersion(t){return new dn({...this.config,version:t})}extend(t){let n=typeof t=="function"?t(this):t,r=Object.create(this);for(let[s,o]of Object.entries(n))typeof o=="function"&&(r[s]=(...c)=>o(this,...c));return r}};function ys(e={}){return new vs(e)}var _s=$.object({username:$.string(),email:$.string(),role:$.enum(["admin","user"]),avatar:$.string(),email_verified:$.boolean(),totp_enabled:$.boolean(),has_backup_codes:$.boolean(),flag_has_password:$.boolean()}).passthrough(),ws=$.object({id:$.string(),name:$.string(),slug:$.string().nullable(),tier:$.string(),role:$.string(),avatar:$.string().nullable().optional()}).passthrough(),Cs=$.object({balance:$.string().or($.number()),granted_balance:$.string().or($.number()),is_post_paid:$.boolean(),outstanding_amount:$.string().or($.number()).nullable()}).passthrough(),Ss=$.object({user:_s,workspace:ws,credits:Cs}).passthrough(),ks=xe.object({username:xe.string(),email:xe.string(),credits:xe.number(),granted_credits:xe.number(),avatar:xe.string(),team_name:xe.string(),team_tier:xe.string()}).passthrough();function Es(e){return e==="2025-10-28"?ks:Ss}async function fn(e,t){let n=await e.get("/auth/me");return t?.schema===!1?n:(t?.schema||Es(e.config.version)).parse(n)}async function As(e,t){try{return{success:!0,data:await fn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var gn={[tn.id]:tn,[en.id]:en,[Yt.id]:Yt},Is=Te.object({id:Te.string(),slug:Te.string().nullable(),url:Te.string(),version:Te.string(),chain_id:Te.number().nullable(),kms_contract_address:Te.string().nullable().transform(e=>e),gateway_app_id:Te.string().nullable().transform(e=>e)}).passthrough(),he=Is.transform(e=>{if(e.chain_id!=null){let t=gn[e.chain_id];if(t)return{...e,chain:t}}return e}),hn=p.union([p.number(),p.string()]),Rs=p.object({id:p.string(),name:p.string(),status:p.string(),uptime:p.string(),app_url:p.string().nullable(),app_id:p.string(),instance_id:p.string().nullable(),configuration:p.any().optional(),exited_at:p.string().nullable(),boot_progress:p.string().nullable(),boot_error:p.string().nullable(),shutdown_progress:p.string().nullable(),image_version:p.string().nullable()}),xs=p.object({id:hn,username:p.string()}),bn=p.object({id:p.number(),name:p.string(),region_identifier:p.string().nullable().optional()}),xt=p.object({vcpu:p.number(),memory:p.number(),disk_size:p.number(),gpu_count:p.number().default(0)}),Tt=p.object({app:p.string(),instance:p.string()}),Ts=p.object({hosted:Rs,name:p.string(),managed_user:xs.nullable(),node:bn.nullable(),listed:p.boolean().default(!1),status:p.string(),in_progress:p.boolean().default(!1),dapp_dashboard_url:p.string().nullable(),syslog_endpoint:p.string().nullable(),allow_upgrade:p.boolean().default(!1),project_id:p.string().nullable(),project_type:p.string().nullable(),billing_period:p.string().nullable(),kms_info:he.nullable(),vcpu:p.number().nullable(),memory:p.number().nullable(),disk_size:p.number().nullable(),gateway_domain:p.string().nullable(),public_urls:p.array(Tt),machine_info:xt.nullable().optional(),updated_at:p.string().nullable().optional()}),vn=p.object({id:hn,name:p.string(),status:p.string(),in_progress:p.boolean().optional().default(!1),teepod_id:p.number().nullable(),teepod:bn.optional().nullable(),app_id:p.string(),vm_uuid:p.string().nullable(),instance_id:p.string().nullable(),vcpu:p.number(),memory:p.number(),disk_size:p.number(),base_image:p.string().nullable(),encrypted_env_pubkey:p.string().nullable(),listed:p.boolean().optional().default(!1),project_id:p.string().optional().nullable(),project_type:p.string().optional().nullable(),instance_type:p.string().optional().nullable(),public_sysinfo:p.boolean().optional().default(!1),public_logs:p.boolean().optional().default(!1),dapp_dashboard_url:p.string().optional().nullable(),syslog_endpoint:p.string().optional().nullable(),kms_info:he.optional().nullable(),contract_address:p.string().optional().nullable(),deployer_address:p.string().optional().nullable(),scheduled_delete_at:p.string().optional().nullable(),public_urls:p.array(Tt).optional().default([]),gateway_domain:p.string().optional().nullable(),machine_info:xt.optional().nullable(),updated_at:p.string().optional().nullable()}),Ps=p.object({items:p.array(Ts),total:p.number(),page:p.number(),page_size:p.number(),pages:p.number()}),js=l.enum(["skip","hourly","monthly"]),$s=l.enum(["phala","ethereum","base","legacy"]),Pt=l.object({object_type:l.literal("user"),id:l.string().nullable().optional(),username:l.string().nullable().optional(),avatar_url:l.string().nullable().optional()}),jt=l.object({object_type:l.literal("workspace"),id:l.string(),name:l.string(),slug:l.string().nullable().optional(),avatar_url:l.string().nullable().optional()}),qs=l.object({instance_type:l.string().nullable().optional(),vcpu:l.number().int().nullable().optional(),memory_in_gb:l.number().nullable().optional(),disk_in_gb:l.number().int().nullable().optional(),gpus:l.number().int().nullable().optional(),compute_billing_price:l.string().nullable().optional(),billing_period:js.nullable().optional()}),Os=l.object({name:l.string().nullable().optional(),version:l.string().nullable().optional(),is_dev:l.boolean().nullable().optional(),os_image_hash:l.string().nullable().optional()}),Ns=l.object({chain_id:l.number().int().nullable().optional(),dstack_kms_address:l.string().nullable().optional(),dstack_app_address:l.string().nullable().optional(),deployer_address:l.string().nullable().optional(),rpc_endpoint:l.string().nullable().optional(),encrypted_env_pubkey:l.string().nullable().optional()}),zs=Ns.transform(e=>{if(e.chain_id!=null){let t=gn[e.chain_id];if(t)return{...e,chain:t}}return e}),Fs=l.object({target:l.string().nullable().optional(),started_at:l.string().nullable().optional(),correlation_id:l.string().nullable().optional()}),Us=l.object({base_domain:l.string().nullable().optional(),cname:l.string().nullable().optional()}),Ls=l.object({serial:l.string().nullable().optional(),stdout:l.string().nullable().optional(),stderr:l.string().nullable().optional(),container_log_base:l.string().nullable().optional()}),yn=l.object({device_id:l.string(),algorithm_version:l.string(),enabled:l.boolean()}),_n=l.object({object_type:l.literal("node"),id:l.number().int().nullable().optional(),name:l.string().nullable().optional(),region:l.string().nullable().optional(),device_id:l.string().nullable().optional(),device_ids:l.array(yn).default([]),ppid:l.string().nullable().optional(),status:l.string().nullable().optional(),version:l.string().nullable().optional()});var st=l.object({id:l.string(),name:l.string(),app_id:l.string().nullable().optional(),vm_uuid:l.string().nullable().optional(),instance_id:l.string().nullable().optional(),resource:qs,node_info:_n.nullable().optional(),os:Os.nullable().optional(),kms_type:$s.nullable().optional(),kms_info:zs.nullable().optional(),status:l.string(),in_progress:l.boolean().optional().default(!1),progress:Fs.nullable().optional(),compose_hash:l.string().nullable().optional(),docker_compose_hash:l.string().nullable().optional(),pre_launch_script_hash:l.string().nullable().optional(),gateway:Us,logs:Ls.optional().default({}),services:l.array(l.record(l.any())).optional().default([]),endpoints:l.array(Tt).nullable().optional(),public_logs:l.boolean().optional(),public_sysinfo:l.boolean().optional(),public_tcbinfo:l.boolean().optional(),gateway_enabled:l.boolean().optional(),secure_time:l.boolean().optional(),listed:l.boolean().optional().default(!1),storage_fs:l.string().optional(),workspace:jt.nullable().optional(),creator:Pt.nullable().optional(),created_at:l.string().nullable().optional(),deleted_at:l.string().nullable().optional(),project_type:l.string().nullable().optional()}),mt=st.extend({id:l.string()}),Ds=st.extend({compose_file:l.union([l.record(l.any()),l.string()]).nullable().optional()}),Vs=mt.extend({compose_file:l.union([l.record(l.any()),l.string()]).nullable().optional()}),wn=l.object({items:l.array(st),total:l.number(),page:l.number(),page_size:l.number(),pages:l.number()}),Ms=wn.extend({items:l.array(mt)});function Cn(e){if(e?.schema!==void 0&&e?.schema!==!1&&(typeof e.schema!="object"||e.schema===null||!("parse"in e.schema)||typeof e.schema.parse!="function"))throw new Error("Invalid schema: must be a Zod schema object, false, or undefined")}function Sn(e){if(e?.schema!==void 0&&e?.schema!==!1&&(typeof e.schema!="object"||e.schema===null||!("parse"in e.schema)||typeof e.schema.parse!="function"))return{success:!1,error:{name:"ZodError",message:"Invalid schema: must be a Zod schema object, false, or undefined",issues:[{code:"invalid_type",expected:"object",received:typeof e.schema,path:["schema"],message:"Invalid schema: must be a Zod schema object, false, or undefined"}]}}}function kn(e,t){function n(c,i){return r(c,i)}async function r(c,i){Cn(i);let u=await t(c);return i?.schema===!1?u:(i?.schema||e).parse(u)}function s(c,i){return o(c,i)}async function o(c,i){let u=Sn(i);if(u)return u;let f=await(async()=>{try{return{success:!0,data:await t(c)}}catch(d){return d&&typeof d=="object"&&"status"in d?{success:!1,error:d}:d&&typeof d=="object"&&"issues"in d?{success:!1,error:d}:{success:!1,error:{name:"Error",message:d instanceof Error?d.message:String(d)}}}})();return f.success?i?.schema===!1?{success:!0,data:f.data}:(i?.schema||e).safeParse(f.data):f}return{action:n,safeAction:s}}function y(e,t){function n(c,...i){let[u,f]=i;return r(c,u,f)}async function r(c,i,u){Cn(u);let f=await t(c,i);return u?.schema===!1?f:(u?.schema||e).parse(f)}function s(c,...i){let[u,f]=i;return o(c,u,f)}async function o(c,i,u){let f=Sn(u);if(f)return f;let m=await(async()=>{try{return{success:!0,data:await t(c,i)}}catch(h){return h&&typeof h=="object"&&"status"in h?{success:!1,error:h}:h&&typeof h=="object"&&"issues"in h?{success:!1,error:h}:{success:!1,error:{name:"Error",message:h instanceof Error?h.message:String(h)}}}})();return m.success?u?.schema===!1?{success:!0,data:m.data}:(u?.schema||e).safeParse(m.data):m}return{action:n,safeAction:s}}var Ks=S.object({name:S.string(),is_dev:S.boolean(),version:S.union([S.tuple([S.number(),S.number(),S.number()]),S.tuple([S.number(),S.number(),S.number(),S.number()])]),os_image_hash:S.string().nullable().optional()}).passthrough(),En=S.object({teepod_id:S.number(),name:S.string(),listed:S.boolean(),resource_score:S.number(),remaining_vcpu:S.number(),remaining_memory:S.number(),remaining_cvm_slots:S.number(),images:S.array(Ks),support_onchain_kms:S.boolean().optional(),fmspc:S.string().nullable().optional(),device_id:S.string().nullable().optional(),device_ids:S.array(yn).default([]),region_identifier:S.string().nullable().optional(),default_kms:S.string().nullable().optional(),kms_list:S.array(S.string()).default([])}).passthrough(),An=S.object({max_instances:S.number().nullable().optional(),max_vcpu:S.number().nullable().optional(),max_memory:S.number().nullable().optional(),max_disk:S.number().nullable().optional()}).passthrough(),Hs=S.object({tier:S.string(),capacity:An,nodes:S.array(En),kms_list:S.array(he)}).passthrough(),{action:Gs,safeAction:Bs}=kn(Hs,async e=>await e.get("/teepods/available")),Ye=b.union([b.number(),b.string()]),et=b.string(),Ws=b.object({has_reserved_gpus:b.boolean(),reserved_gpu_count:b.number(),has_public_gpus:b.boolean(),public_gpu_count:b.number()}).passthrough(),In=b.object({id:Ye,slug:b.string().nullable().optional(),url:b.string(),version:b.string().nullable().optional(),kms_type:b.string(),chain_id:b.number().nullable().optional(),kms_contract_id:Ye.nullable().optional(),kms_contract_address:b.string().nullable().optional(),gateway_app_id:b.string().nullable().optional(),supported_os_images:b.array(b.string()).default([])}).passthrough(),Rn=b.object({teepod_id:b.number(),kms_id:Ye,kms_type:b.string(),kms_contract_id:Ye.nullable().optional(),kms_contract_address:b.string().nullable().optional(),supported_os_images:b.array(b.string()).default([])}).passthrough(),xn=b.object({id:Ye,teepod_id:b.number().nullable().optional(),kms_contract_id:Ye,rpc_url:b.string().nullable().optional(),domain_suffix:b.string().nullable().optional(),enabled:b.boolean()}).passthrough(),Xs=In.extend({id:et,kms_contract_id:et.nullable().optional()}),Js=Rn.extend({kms_id:et,kms_contract_id:et.nullable().optional()}),Zs=xn.extend({id:et,kms_contract_id:et}),Qs=b.object({id:b.string(),name:b.string(),vcpu:b.number(),memory_mb:b.number(),default_disk_size_gb:b.number(),requires_gpu:b.boolean(),requires_gpu_count:b.number(),family:b.string().nullable().optional(),display_order:b.number().nullable().optional()}).passthrough(),Tn=b.object({tier:b.string(),capacity:An,nodes:b.array(En),kms_nodes:b.array(In),node_kms_relations:b.array(Rn),gateway_nodes:b.array(xn),instance_types:b.array(Qs),gpu_availability:Ws}).passthrough(),Ys=Tn.extend({kms_nodes:b.array(Xs),node_kms_relations:b.array(Js),gateway_nodes:b.array(Zs)});function Pn(e){return e==="2026-01-21"?Tn:Ys}async function eo(e,t){let n=await e.get("/teepods/cvm-create-resources");return t?.schema===!1?n:(t?.schema||Pn(e.config.version)).parse(n)}async function to(e,t){try{let n=await e.get("/teepods/cvm-create-resources");return t?.schema===!1?{success:!0,data:n}:{success:!0,data:(t?.schema||Pn(e.config.version)).parse(n)}}catch(n){return{success:!1,error:n}}}var jn=D.object({id:D.string(),name:D.string(),description:D.string(),vcpu:D.number(),memory_mb:D.number(),hourly_rate:D.string(),requires_gpu:D.boolean(),default_disk_size_gb:D.number().default(20),family:D.string().nullable()}).passthrough(),no=D.object({name:D.string(),items:D.array(jn),total:D.number()}).strict(),ro=D.object({result:D.array(no)}).strict(),so=D.object({items:D.array(jn),total:D.number(),family:D.string()}).strict(),oo=D.object({family:D.string()}).strict(),{action:ao,safeAction:io}=y(ro,async e=>await e.get("/instance-types")),{action:co,safeAction:lo}=y(so,async(e,t)=>{let n=oo.parse(t);return await e.get(`/instance-types/${n.family}`)}),$n=Y.object({id:Y.string(),name:Y.string(),slug:Y.string().nullable(),avatar_url:Y.string().nullable().optional(),tier:Y.string(),role:Y.string(),is_default:Y.boolean(),created_at:Y.string(),confidential_models_enabled:Y.boolean().optional()}).passthrough(),uo=Y.object({has_more:Y.boolean(),next_cursor:Y.string().nullable(),total:Y.number().nullable()}).passthrough(),po=Y.object({data:Y.array($n),pagination:uo}).passthrough(),{action:mo,safeAction:fo}=y(po,async(e,t)=>{let n=new URLSearchParams;t?.cursor&&n.append("cursor",t.cursor),t?.limit&&n.append("limit",t.limit.toString());let r=n.toString()?`/workspaces?${n.toString()}`:"/workspaces";return await e.get(r)}),{action:go,safeAction:ho}=y($n,async(e,t)=>await e.get(`/workspaces/${t}`));function qn(e){return typeof e!="string"||e.length<5||e.length>63?!1:/^[a-zA-Z](?!.*--)([a-zA-Z0-9-]*[a-zA-Z0-9])?$/.test(e)}var ee=Ve.object({id:Ve.string().optional(),uuid:Ve.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i,"Invalid UUID format").optional(),app_id:Ve.string().optional(),instance_id:Ve.string().optional(),name:Ve.string().refine(qn,{message:"Name must be 5-63 characters, start with letter, and contain only letters/numbers/hyphens"}).optional()}),ue=e=>e.refine(t=>{let n=t;return!!(n.id||n.uuid||n.app_id||n.instance_id||n.name)},{message:"One of id, uuid, app_id, instance_id, or name must be provided"}),bo=ue(ee),j=bo.transform(e=>{let t;if(e.id)t=e.id;else if(e.uuid)t=e.uuid;else if(e.app_id)t=e.app_id;else if(e.instance_id)t=e.instance_id;else{if(e.name)return{cvmId:e.name};throw new Error("No valid identifier provided")}let n=/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i,r=/^[0-9a-f]{40}$/i,s;return n.test(t)?s=t.replace(/-/g,""):r.test(t)?s=`app_${t}`:s=t,{cvmId:s}}),vo=j;function yo(e){return e==="2025-10-28"?vn:e==="2026-01-21"?Ds:Vs}async function On(e,t){let{cvmId:n}=vo.parse(t),r=await e.get(`/cvms/${n}`);return yo(e.config.version).parse(r)}async function gt(e,t){try{return{success:!0,data:await On(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var _o=Me.object({page:Me.number().int().min(1).optional(),page_size:Me.number().int().min(1).optional(),node_id:Me.number().int().min(1).optional(),teepod_id:Me.number().int().min(1).optional(),user_id:Me.string().optional()}).strict();function wo(e){return e==="2025-10-28"?Ps:e==="2026-01-21"?wn:Ms}async function Nn(e,t){let n=_o.parse(t??{}),r=await e.get("/cvms/paginated",{params:n});return wo(e.config.version).parse(r)}async function $t(e,t){try{return{success:!0,data:await Nn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var nn=200*1024;function zn(e,t,n){let r=new TextEncoder,s=e?r.encode(e).byteLength:0,o=t?r.encode(t).byteLength:0,c=s+o;if(c>nn){let i=nn/1024,u=Math.ceil(c/1024);n.addIssue({code:x.ZodIssueCode.custom,message:`Combined size of docker_compose_file and pre_launch_script must not exceed ${i}KB (current: ${u}KB)`})}}var Fn=x.object({allowed_envs:x.array(x.string()).optional(),docker_compose_file:x.string(),features:x.array(x.string()).optional(),name:x.string().optional(),manifest_version:x.number().optional(),runner:x.string().optional(),kms_enabled:x.boolean().optional(),gateway_enabled:x.boolean().optional(),tproxy_enabled:x.boolean().optional(),local_key_provider_enabled:x.boolean().optional(),key_provider:x.enum(["none","kms","local","tpm"]).optional(),key_provider_id:x.string().optional(),public_logs:x.boolean().optional(),public_sysinfo:x.boolean().optional(),public_tcbinfo:x.boolean().optional(),no_instance_id:x.boolean().optional(),secure_time:x.boolean().optional(),port_policy:x.object({ports:x.array(x.object({port:x.number().int().min(1).max(65535),pp:x.boolean()})),restrict_mode:x.boolean()}).optional(),storage_fs:x.enum(["ext4","zfs"]).optional(),swap_size:x.string().optional(),pre_launch_script:x.string().optional(),env_pubkey:x.string().optional(),salt:x.string().optional().nullable()}).passthrough().superRefine((e,t)=>{zn(e.docker_compose_file,e.pre_launch_script,t)}),Co=g.object({app_id:g.string().nullable().optional(),app_env_encrypt_pubkey:g.string().nullable().optional(),compose_hash:g.string(),kms_info:he.nullable().optional(),fmspc:g.string().nullable().optional(),device_id:g.string().nullable().optional(),os_image_hash:g.string().nullable().optional(),instance_type:g.string().nullable().optional(),teepod_id:g.number().nullable().optional(),node_id:g.number().nullable().optional(),kms_id:g.string().nullable().optional(),kms_contract_id:g.union([g.string(),g.number()]).nullable().optional()}).passthrough().transform(e=>{if("teepod_id"in e&&e.teepod_id!==void 0){let{teepod_id:t,...n}=e;return{...n,node_id:t}}return e}),kt="Name must be 5-63 characters, start with letter, and contain only letters/numbers/hyphens",So=g.object({node_id:g.number().optional(),teepod_id:g.number().optional(),region:g.string().optional(),name:g.string().min(5,kt).max(63,kt).refine(e=>qn(e),kt),instance_type:g.string().optional(),image:g.string().optional(),vcpu:g.number().optional(),memory:g.number().optional(),disk_size:g.number().optional(),compose_file:g.object({allowed_envs:g.array(g.string()).optional(),pre_launch_script:g.string().optional(),docker_compose_file:g.string().optional(),name:g.string().optional().default(""),kms_enabled:g.boolean().optional(),gateway_enabled:g.boolean().optional(),tproxy_enabled:g.boolean().optional(),local_key_provider_enabled:g.boolean().optional(),key_provider:g.enum(["none","kms","local","tpm"]).optional(),key_provider_id:g.string().optional(),public_logs:g.boolean().optional(),public_sysinfo:g.boolean().optional(),public_tcbinfo:g.boolean().optional(),no_instance_id:g.boolean().optional(),secure_time:g.boolean().optional(),storage_fs:g.enum(["ext4","zfs"]).optional(),swap_size:g.string().optional(),port_policy:g.object({ports:g.array(g.object({port:g.number(),pp:g.boolean()})),restrict_mode:g.boolean()}).optional()}).passthrough().superRefine((e,t)=>{zn(e.docker_compose_file,e.pre_launch_script,t)}),listed:g.boolean().optional(),kms_id:g.string().optional(),kms:g.enum(["PHALA","ETHEREUM","BASE"]).optional(),kms_contract:g.string().optional(),kms_contract_id:g.union([g.string(),g.number()]).optional(),key_provider_mode:g.enum(["kms","local"]).optional(),skip_gateway:g.boolean().optional(),env_keys:g.array(g.string()).optional(),nonce:g.number().optional(),app_id:g.string().optional()}).passthrough().transform(e=>!e.instance_type&&!e.vcpu&&!e.memory?{...e,instance_type:"tdx.small"}:e);function ko(e){if(!e.compose_file)return e;let t={...e.compose_file};return typeof t.gateway_enabled=="boolean"&&typeof t.tproxy_enabled=="boolean"?delete t.tproxy_enabled:typeof t.tproxy_enabled=="boolean"&&typeof t.gateway_enabled>"u"&&(t.gateway_enabled=t.tproxy_enabled,delete t.tproxy_enabled,(typeof window<"u"?window.console:globalThis.console)&&console.warn("[phala/cloud] tproxy_enabled is deprecated, please use gateway_enabled instead. See docs for migration.")),{...e,compose_file:t}}var{action:Eo,safeAction:Ao}=y(Co,async(e,t)=>{let n=So.parse(t),r=ko(n);return typeof r.teepod_id=="number"&&typeof r.node_id!="number"&&console.warn("[phala/cloud] teepod_id is deprecated, please use node_id instead."),await e.post("/cvms/provision",r)}),Un=w.object({name:w.string(),status:w.string(),teepod_id:w.number(),teepod:w.object({id:w.number(),name:w.string()}).nullable(),app_id:w.string().nullable(),vm_uuid:w.string().nullable(),instance_id:w.string().nullable(),app_url:w.string().nullable().default(null),base_image:w.string().nullable(),vcpu:w.number(),memory:w.number(),disk_size:w.number(),manifest_version:w.number().nullable().default(2),version:w.string().nullable().default("1.0.0"),runner:w.string().nullable().default("docker-compose"),docker_compose_file:w.string().nullable(),features:w.array(w.string()).nullable().default(["kms","tproxy-net"]),created_at:w.string(),encrypted_env_pubkey:w.string().nullable().optional(),app_auth_contract_address:w.string().nullable().optional(),deployer_address:w.string().nullable().optional()}).passthrough(),Ln=Un.extend({id:w.number(),user_id:w.number().nullable()}),Dn=Un.extend({id:w.string(),user_id:w.string().nullable()}),lu=w.union([Ln,Dn]);var uu=w.object({encrypted_env:w.string().optional().nullable(),app_id:w.string(),compose_hash:w.string(),kms_id:w.string().optional(),kms_contract_id:w.union([w.string(),w.number()]).optional(),contract_address:w.string().optional(),deployer_address:w.string().optional(),env_keys:w.array(w.string()).optional().nullable()}).passthrough();function Io(e){return e==="2026-01-21"?Ln:Dn}async function Vn(e,t){let n=await e.post("/cvms",t);return Io(e.config.version).parse(n)}async function Ro(e,t){try{return{success:!0,data:await Vn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}function It(e){return e==null?e:Array.isArray(e)?e.map(It):e&&typeof e=="object"&&e.constructor===Object?Object.keys(e).sort().reduce((t,n)=>{let r=e[n];return t[n]=It(r),t},{}):e}function Mn(e){let t={...e};return t.runner==="bash"&&"docker_compose_file"in t?delete t.docker_compose_file:t.runner==="docker-compose"&&"bash_script"in t&&delete t.bash_script,"pre_launch_script"in t&&!t.pre_launch_script&&delete t.pre_launch_script,t}function Kn(e){let t=It(e),n=JSON.stringify(t,null,4);return n=n.replace(/": /g,'":'),n}function To(e){let t=Mn(e),n=Kn(t);return xo.createHash("sha256").update(n,"utf8").digest("hex")}function Po(e){let t=e;return{...e,getHash:()=>To(t),toString:()=>Kn(Mn(t))}}var jo=Fn.transform(e=>Po(e)),$o=j,{action:qo,safeAction:Oo}=y(jo,async(e,t)=>{let{cvmId:n}=$o.parse(t);return await e.get(`/cvms/${n}/compose_file`)}),No=ye.object({id:ye.string().optional(),uuid:ye.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i).optional(),app_id:ye.string().refine(e=>!e.startsWith("app_")&&e.length===40,"app_id should be 40 characters without prefix").transform(e=>e.startsWith("app_")?e:`app_${e}`).optional(),instance_id:ye.string().refine(e=>!e.startsWith("instance_")&&e.length===40,"instance_id should be 40 characters without prefix").transform(e=>e.startsWith("instance_")?e:`instance_${e}`).optional(),app_compose:Fn,update_env_vars:ye.boolean().optional().nullable()}).refine(e=>!!(e.id||e.uuid||e.app_id||e.instance_id),"One of id, uuid, app_id, or instance_id must be provided").transform(e=>({cvmId:e.id||e.uuid||e.app_id||e.instance_id,request:{...e.app_compose,update_env_vars:e.update_env_vars},_raw:e})),zo=ye.object({app_id:ye.string().nullable(),device_id:ye.string().nullable(),compose_hash:ye.string(),kms_info:he.nullable().optional(),compose_hash_registered:ye.boolean().optional().default(!1)}).passthrough(),{action:Fo,safeAction:Uo}=y(zo,async(e,t)=>{let n=No.parse(t);return await e.post(`/cvms/${n.cvmId}/compose_file/provision`,n.request)}),Lo=ve.object({id:ve.string().optional(),uuid:ve.string().regex(/^[0-9a-f]{8}[-]?[0-9a-f]{4}[-]?4[0-9a-f]{3}[-]?[89ab][0-9a-f]{3}[-]?[0-9a-f]{12}$/i).optional(),app_id:ve.string().refine(e=>!e.startsWith("app_")&&e.length===40,"app_id should be 40 characters without prefix").transform(e=>e.startsWith("app_")?e:`app_${e}`).optional(),instance_id:ve.string().refine(e=>!e.startsWith("instance_")&&e.length===40,"instance_id should be 40 characters without prefix").transform(e=>e.startsWith("instance_")?e:`instance_${e}`).optional(),compose_hash:ve.string().min(1,"Compose hash is required"),encrypted_env:ve.string().optional(),env_keys:ve.array(ve.string()).optional(),update_env_vars:ve.boolean().optional().nullable()}).refine(e=>!!(e.id||e.uuid||e.app_id||e.instance_id),"One of id, uuid, app_id, or instance_id must be provided").transform(e=>({cvmId:e.id||e.uuid||e.app_id||e.instance_id,compose_hash:e.compose_hash,encrypted_env:e.encrypted_env,env_keys:e.env_keys,update_env_vars:e.update_env_vars??void 0,_raw:e})),Do=ve.any().transform(()=>{}),{action:Vo,safeAction:Mo}=y(Do,async(e,t)=>{let n=Lo.parse(t);return await e.patch(`/cvms/${n.cvmId}/compose_file`,{compose_hash:n.compose_hash,encrypted_env:n.encrypted_env,env_keys:n.env_keys,update_env_vars:n.update_env_vars})}),Ko=ue(ee.extend({encrypted_env:J.string().describe("Encrypted environment variables (hex string)"),env_keys:J.array(J.string()).optional().describe("List of allowed environment variable keys"),compose_hash:J.string().optional().describe("Compose hash for verification (Phase 2, required when env_keys changes)"),transaction_hash:J.string().optional().describe("On-chain transaction hash for verification (Phase 2, required when env_keys changes)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{encrypted_env:e.encrypted_env,env_keys:e.env_keys,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),Ho=J.object({status:J.literal("in_progress"),message:J.string(),correlation_id:J.string(),allowed_envs_changed:J.boolean()}),Go=J.object({status:J.literal("precondition_required"),message:J.string(),compose_hash:J.string(),app_id:J.string(),device_id:J.string(),kms_info:he}),Bo=J.union([Ho,Go]),{action:Wo,safeAction:Xo}=y(Bo,async(e,t)=>{let n=Ko.parse(t);try{return await e.patch(`/cvms/${n.cvmId}/envs`,n.request)}catch(r){if(r instanceof ge&&r.status===465){let s=r.detail;if(s&&typeof s=="object"){let o=s,c=o.details;if(c&&Array.isArray(c)){let i=new Map(c.map(h=>[h.field,h.value])),u=i.get("compose_hash"),f=i.get("app_id"),m=i.get("device_id"),d=i.get("kms_info");if(u&&f)return{status:"precondition_required",message:o.message||"Compose hash verification required",compose_hash:u,app_id:f,device_id:m||"",kms_info:d}}}}throw r}}),Jo=ue(ee.extend({docker_compose_file:ce.string().describe("Docker Compose YAML content"),compose_hash:ce.string().optional().describe("Compose hash for verification (Phase 2, contract-owned KMS only)"),transaction_hash:ce.string().optional().describe("On-chain transaction hash for verification (Phase 2, contract-owned KMS only)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{docker_compose_file:e.docker_compose_file,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),Zo=ce.object({status:ce.literal("in_progress"),message:ce.string(),correlation_id:ce.string()}),Qo=ce.object({status:ce.literal("precondition_required"),message:ce.string(),compose_hash:ce.string(),app_id:ce.string(),device_id:ce.string(),kms_info:he}),Yo=ce.union([Zo,Qo]),{action:ea,safeAction:ta}=y(Yo,async(e,t)=>{let n=Jo.parse(t),r={"Content-Type":"text/yaml"};n.request.compose_hash&&(r["X-Compose-Hash"]=n.request.compose_hash),n.request.transaction_hash&&(r["X-Transaction-Hash"]=n.request.transaction_hash);try{return await e.patch(`/cvms/${n.cvmId}/docker-compose`,n.request.docker_compose_file,{headers:r})}catch(s){if(s instanceof ge&&s.status===465){let o=s.detail;if(o&&typeof o=="object"){let c=o,i=c.details;if(i&&Array.isArray(i)){let u=new Map(i.map(_=>[_.field,_.value])),f=u.get("compose_hash"),m=u.get("app_id"),d=u.get("device_id"),h=u.get("kms_info");if(f&&m)return{status:"precondition_required",message:c.message||"Compose hash verification required",compose_hash:f,app_id:m,device_id:d||"",kms_info:h}}}}throw s}}),na=ue(ee.extend({pre_launch_script:le.string().describe("Pre-launch script content (shell script)"),compose_hash:le.string().optional().describe("Compose hash for verification (Phase 2, contract-owned KMS only)"),transaction_hash:le.string().optional().describe("On-chain transaction hash for verification (Phase 2, contract-owned KMS only)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{pre_launch_script:e.pre_launch_script,compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),ra=le.object({status:le.literal("in_progress"),message:le.string(),correlation_id:le.string()}),sa=le.object({status:le.literal("precondition_required"),message:le.string(),compose_hash:le.string(),app_id:le.string(),device_id:le.string(),kms_info:he}),oa=le.union([ra,sa]),{action:aa,safeAction:ia}=y(oa,async(e,t)=>{let n=na.parse(t),r={"Content-Type":"text/plain"};n.request.compose_hash&&(r["X-Compose-Hash"]=n.request.compose_hash),n.request.transaction_hash&&(r["X-Transaction-Hash"]=n.request.transaction_hash);try{return await e.patch(`/cvms/${n.cvmId}/pre-launch-script`,n.request.pre_launch_script,{headers:r})}catch(s){if(s instanceof ge&&s.status===465){let o=s.detail;if(o&&typeof o=="object"){let c=o,i=c.details;if(i&&Array.isArray(i)){let u=new Map(i.map(_=>[_.field,_.value])),f=u.get("compose_hash"),m=u.get("app_id"),d=u.get("device_id"),h=u.get("kms_info");if(f&&m)return{status:"precondition_required",message:c.message||"Compose hash verification required",compose_hash:f,app_id:m,device_id:d||"",kms_info:h}}}}throw s}}),la=j,{action:ua,safeAction:pa}=y(ca.string(),async(e,t)=>{let{cvmId:n}=la.parse(t);return await e.get(`/cvms/${n}/pre-launch-script`)}),ma=j,da=Ke.object({current_hash:Ke.string().nullable(),latest_official_hash:Ke.string(),is_official:Ke.boolean(),is_latest:Ke.boolean(),can_upgrade:Ke.boolean()}),{action:fa,safeAction:ga}=y(da,async(e,t)=>{let{cvmId:n}=ma.parse(t);return await e.get(`/cvms/${n}/pre-launch-script/upgrade-status`)}),ha=ue(ee.extend({compose_hash:de.string().optional().describe("Compose hash for verification (Phase 2, contract-owned KMS only)"),transaction_hash:de.string().optional().describe("On-chain transaction hash for verification (Phase 2, contract-owned KMS only)")})).transform(e=>{let{cvmId:t}=j.parse(e);return{cvmId:t,request:{compose_hash:e.compose_hash,transaction_hash:e.transaction_hash},_raw:e}}),ba=de.object({status:de.literal("in_progress"),message:de.string(),correlation_id:de.string()}),va=de.object({status:de.literal("precondition_required"),message:de.string(),compose_hash:de.string(),app_id:de.string(),device_id:de.string(),kms_info:he}),ya=de.union([ba,va]),{action:_a,safeAction:wa}=y(ya,async(e,t)=>{let n=ha.parse(t),r={};n.request.compose_hash&&(r["X-Compose-Hash"]=n.request.compose_hash),n.request.transaction_hash&&(r["X-Transaction-Hash"]=n.request.transaction_hash);try{return await e.post(`/cvms/${n.cvmId}/pre-launch-script/upgrade-to-latest-official`,void 0,{headers:r})}catch(s){if(s instanceof ge&&s.status===465){let o=s.detail;if(o&&typeof o=="object"){let c=o,i=c.details;if(i&&Array.isArray(i)){let u=new Map(i.map(_=>[_.field,_.value])),f=u.get("compose_hash"),m=u.get("app_id"),d=u.get("device_id"),h=u.get("kms_info");if(f&&m)return{status:"precondition_required",message:c.message||"Compose hash verification required",compose_hash:f,app_id:m,device_id:d||"",kms_info:h}}}}throw s}}),Ca=rn.object({kms_id:rn.string().min(1,"KMS ID is required")}),{action:Sa,safeAction:ka}=y(he,async(e,t)=>{let n=Ca.parse(t);return await e.get(`/kms/${n.kms_id}`)}),Ea=Ae.object({page:Ae.number().int().min(1).optional(),page_size:Ae.number().int().min(1).optional(),is_onchain:Ae.boolean().optional()}).strict(),Aa=Ae.object({items:Ae.array(he),total:Ae.number(),page:Ae.number(),page_size:Ae.number(),pages:Ae.number()}).strict(),{action:Ia,safeAction:Ra}=y(Aa,async(e,t)=>{let n=Ea.parse(t??{});return await e.get("/kms",{params:n})}),xa=Ze.object({kms:Ze.string().min(1,"KMS ID or slug is required"),app_id:Ze.string().refine(e=>e.length===40||e.startsWith("0x")&&e.length===42,"App ID must be exactly 40 characters or 42 characters with 0x prefix")}).strict(),Ta=Ze.object({public_key:Ze.string(),signature:Ze.string()}).strict(),{action:Pa,safeAction:ja}=y(Ta,async(e,t)=>{let n=xa.parse(t);return await e.get(`/kms/${n.kms}/pubkey/${n.app_id}`)}),$a=Ne.object({counts:Ne.number().int().min(1).max(20).optional().default(1)}).strict(),qa=Ne.object({app_ids:Ne.array(Ne.object({app_id:Ne.string(),nonce:Ne.number().int().min(0)}))}).strict(),{action:Oa,safeAction:Na}=y(qa,async(e,t)=>{let n=$a.parse(t??{}),r=new URLSearchParams;return r.append("counts",n.counts.toString()),await e.get(`/kms/phala/next_app_id?${r.toString()}`)}),Hn=P.object({name:P.string(),status:P.string(),teepod_id:P.number(),teepod:P.object({id:P.number(),name:P.string(),region_identifier:P.string().nullable().optional()}).optional().nullable(),app_id:P.string(),vm_uuid:P.string().nullable(),instance_id:P.string().nullable(),app_url:P.string().optional().nullable(),base_image:P.string().optional().nullable(),vcpu:P.number(),memory:P.number(),disk_size:P.number(),manifest_version:P.number().optional().nullable(),version:P.string().optional().nullable(),runner:P.string().optional().nullable(),docker_compose_file:P.string().optional().nullable(),features:P.array(P.string()).optional().nullable(),created_at:P.string(),encrypted_env_pubkey:P.string().nullable()}),Gn=Hn.extend({id:P.number(),user_id:P.number().optional().nullable()}),qt=Hn.extend({id:P.string(),user_id:P.string().optional().nullable()}),Eu=P.union([Gn,qt]),za=qt;function ht(e){return e==="2026-01-21"?Gn:qt}var Fa=j;async function Bn(e,t){let{cvmId:n}=Fa.parse(t),r=await e.post(`/cvms/${n}/start`);return ht(e.config.version).parse(r)}async function Ua(e,t){try{return{success:!0,data:await Bn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var La=j;async function Wn(e,t){let{cvmId:n}=La.parse(t),r=await e.post(`/cvms/${n}/stop`);return ht(e.config.version).parse(r)}async function Da(e,t){try{return{success:!0,data:await Wn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var Va=j;async function Xn(e,t){let{cvmId:n}=Va.parse(t),r=await e.post(`/cvms/${n}/shutdown`);return ht(e.config.version).parse(r)}async function Ma(e,t){try{return{success:!0,data:await Xn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var Ha=ue(ee.extend({force:Ka.boolean().optional()}));async function Jn(e,t){let n=Ha.parse(t),{cvmId:r}=j.parse(n),{force:s=!1}=n,o=await e.post(`/cvms/${r}/restart`,{force:s});return ht(e.config.version).parse(o)}async function Ga(e,t){try{return{success:!0,data:await Jn(e,t)}}catch(n){return n&&typeof n=="object"&&("status"in n||"issues"in n)?{success:!1,error:n}:{success:!1,error:{name:"Error",message:n instanceof Error?n.message:String(n)}}}}var Wa=j,{action:Xa,safeAction:Ja}=y(Ba.void(),async(e,t)=>{let{cvmId:n}=Wa.parse(t);await e.delete(`/cvms/${n}`)}),Za=T.object({name:T.string(),mount_point:T.string(),total_size:T.number(),free_size:T.number()}),Qa=T.object({os_name:T.string(),os_version:T.string(),kernel_version:T.string(),cpu_model:T.string(),num_cpus:T.number(),total_memory:T.number(),available_memory:T.number(),used_memory:T.number(),free_memory:T.number(),total_swap:T.number(),used_swap:T.number(),free_swap:T.number(),uptime:T.number(),loadavg_one:T.number(),loadavg_five:T.number(),loadavg_fifteen:T.number(),disks:T.array(Za)}),Ya=T.object({is_online:T.boolean(),is_public:T.boolean().default(!1),error:T.string().nullable(),sysinfo:Qa.nullable(),status:T.string().nullable(),in_progress:T.boolean().default(!1),boot_progress:T.string().nullable(),boot_error:T.string().nullable()}),ei=j,{action:ti,safeAction:ni}=y(Ya,async(e,t)=>{let{cvmId:n}=ei.parse(t);return await e.get(`/cvms/${n}/stats`)}),ri=Ee.object({app:Ee.string(),instance:Ee.string()}),si=Ee.object({is_online:Ee.boolean(),is_public:Ee.boolean().default(!0),error:Ee.string().nullable(),internal_ip:Ee.string().nullable(),latest_handshake:Ee.string().nullable(),public_urls:Ee.array(ri).nullable()}),oi=j,{action:ai,safeAction:ii}=y(si,async(e,t)=>{let{cvmId:n}=oi.parse(t);return await e.get(`/cvms/${n}/network`)}),li=j,{action:ui,safeAction:pi}=y(ci.string(),async(e,t)=>{let{cvmId:n}=li.parse(t);return await e.get(`/cvms/${n}/docker-compose.yml`)}),mi=L.object({id:L.string(),names:L.array(L.string()),image:L.string(),image_id:L.string(),command:L.string().nullable().optional(),created:L.number(),state:L.string(),status:L.string(),log_endpoint:L.string().nullable()}),di=L.object({is_online:L.boolean(),is_public:L.boolean().default(!0),error:L.string().nullable(),docker_compose_file:L.string().nullable(),manifest_version:L.number().nullable(),version:L.string().nullable(),runner:L.string().nullable(),features:L.array(L.string()).nullable(),containers:L.array(mi).nullable()}),fi=j,{action:gi,safeAction:hi}=y(di,async(e,t)=>{let{cvmId:n}=fi.parse(t);return await e.get(`/cvms/${n}/composition`)}),bi=v.object({common_name:v.string().nullable(),organization:v.string().nullable(),country:v.string().nullable(),state:v.string().nullable(),locality:v.string().nullable()}),vi=v.object({common_name:v.string().nullable(),organization:v.string().nullable(),country:v.string().nullable()}),Zn=v.object({subject:bi,issuer:vi,serial_number:v.string(),not_before:v.string(),not_after:v.string(),version:v.string(),fingerprint:v.string(),signature_algorithm:v.string(),sans:v.array(v.string()).nullable(),is_ca:v.boolean(),position_in_chain:v.number().nullable(),quote:v.string().nullable(),app_id:v.string().nullable().optional(),cert_usage:v.string().nullable().optional()}),yi=v.object({imr:v.number(),event_type:v.number(),digest:v.string(),event:v.string(),event_payload:v.string()}),Qn=v.object({mrtd:v.string(),rootfs_hash:v.string().nullable().optional(),rtmr0:v.string(),rtmr1:v.string(),rtmr2:v.string(),rtmr3:v.string(),event_log:v.array(yi),app_compose:v.string()}),_i=v.object({name:v.string().nullable(),is_online:v.boolean(),is_public:v.boolean().default(!0),error:v.string().nullable(),app_certificates:v.array(Zn).nullable(),tcb_info:Qn.nullable(),compose_file:v.string().nullable()}),wi=j,{action:Ci,safeAction:Si}=y(_i,async(e,t)=>{let{cvmId:n}=wi.parse(t);return await e.get(`/cvms/${n}/attestation`)}),ki=ue(ee.extend({vcpu:Xe.number().optional(),memory:Xe.number().optional(),disk_size:Xe.number().optional(),instance_type:Xe.string().optional(),allow_restart:Xe.boolean().optional()})),{action:Ei,safeAction:Ai}=y(Xe.void(),async(e,t)=>{let n=ki.parse(t),{cvmId:r}=j.parse(n),{...s}=n;await e.patch(`/cvms/${r}/resources`,s)}),Ii=ue(ee.extend({public_sysinfo:Et.boolean(),public_logs:Et.boolean(),public_tcbinfo:Et.boolean().optional()})),{action:Ri,safeAction:xi}=y(vn,async(e,t)=>{let n=Ii.parse(t),{cvmId:r}=j.parse(n),{public_sysinfo:s,public_logs:o,public_tcbinfo:c}=n;return await e.patch(`/cvms/${r}/visibility`,{public_sysinfo:s,public_logs:o,public_tcbinfo:c})}),sn=Q.object({name:Q.string(),os_image_hash:Q.string().nullable(),is_current:Q.boolean()}),Ti=Q.object({version:Q.union([Q.tuple([Q.number(),Q.number(),Q.number(),Q.number()]),Q.tuple([Q.number(),Q.number(),Q.number()])]),prod:sn.nullable(),dev:sn.nullable()}),Pi=Q.array(Ti),ji=j,{action:$i,safeAction:qi}=y(Pi,async(e,t)=>{let{cvmId:n}=ji.parse(t);return await e.get(`/cvms/${n}/available-os-images`)}),Oi=ue(ee.extend({os_image_name:Yn.string().min(1,"OS image name is required")})),{action:Ni,safeAction:zi}=y(Yn.void(),async(e,t)=>{let n=Oi.parse(t),{cvmId:r}=j.parse(n),{os_image_name:s}=n;await e.patch(`/cvms/${r}/os-image`,{os_image_name:s})}),Fi=Se.object({id:Se.string().optional(),instance_id:Se.string().optional(),name:Se.string(),status:Se.string(),uptime:Se.string().optional(),exited_at:Se.string().optional(),boot_progress:Se.string().optional(),boot_error:Se.string().optional(),shutdown_progress:Se.string().optional()}),Ui=j,{action:Li,safeAction:Di}=y(Fi,async(e,t)=>{let{cvmId:n}=Ui.parse(t);return await e.get(`/cvms/${n}/state`)}),er=ie.object({id:ie.string(),user_id:ie.string(),name:ie.string(),public_key:ie.string(),fingerprint:ie.string(),key_type:ie.string(),source:ie.string(),key_metadata:ie.record(ie.unknown()).nullable().optional(),last_synced_at:ie.string().nullable().optional(),created_at:ie.string(),updated_at:ie.string()}),Vi=ie.array(er);async function tr(e){let t=await e.get("/user/ssh-keys");return Vi.parse(t)}async function Mi(e){try{return{success:!0,data:await tr(e)}}catch(t){return t&&typeof t=="object"&&("status"in t||"issues"in t)?{success:!1,error:t}:{success:!1,error:{name:"Error",message:t instanceof Error?t.message:String(t)}}}}var Ki=Pe.object({github_username:Pe.string().min(1)}),Hi=Pe.object({github_username:Pe.string(),keys_added:Pe.number().int(),keys_skipped:Pe.number().int(),errors:Pe.array(Pe.string()).default([])}),{action:Gi,safeAction:Bi}=y(Hi,async(e,t)=>{let{github_username:n}=Ki.parse(t);return await e.post("/user/ssh-keys/github-profile",{github_username:n})}),Wi=At.object({name:At.string().min(1),public_key:At.string().min(1)}),{action:Xi,safeAction:Ji}=y(er,async(e,t)=>{let{name:n,public_key:r}=Wi.parse(t);return await e.post("/user/ssh-keys",{name:n,public_key:r})}),Zi=Rt.object({keyId:Rt.string().min(1)}),{action:Qi,safeAction:Yi}=y(Rt.void(),async(e,t)=>{let{keyId:n}=Zi.parse(t);await e.delete(`/user/ssh-keys/${n}`)}),ec=Oe.object({synced_count:Oe.number().int(),keys_added:Oe.number().int(),keys_updated:Oe.number().int(),keys_removed:Oe.number().int(),errors:Oe.array(Oe.string()).default([])}),{action:tc,safeAction:nc}=kn(ec,async e=>await e.post("/user/ssh-keys/github-sync",{})),rc=X.object({name:X.string(),slug:X.string(),version:X.string(),os_image_hash:X.string().nullable(),is_dev:X.boolean(),requires_gpu:X.boolean()}).passthrough(),sc=X.object({page:X.number().int().min(1).optional(),page_size:X.number().int().min(1).optional(),is_dev:X.boolean().optional()}).strict(),oc=X.object({items:X.array(rc),total:X.number(),page:X.number(),page_size:X.number(),pages:X.number()}).passthrough(),{action:ac,safeAction:ic}=y(oc,async(e,t)=>{let n=sc.parse(t??{});return await e.get("/os-images",{params:n})}),cc=V.object({device_id:V.string(),node_name:V.string().nullable().optional(),on_chain_allowed:V.boolean().nullable()}).passthrough(),lc=V.object({name:V.string(),version:V.string(),os_image_hash:V.string().nullable(),on_chain_allowed:V.boolean().nullable()}).passthrough(),uc=V.object({contract_address:V.string(),chain_id:V.number(),chain_name:V.string(),devices:V.array(cc),os_images:V.array(lc)}).passthrough(),pc=V.object({chain_name:V.string(),chain_id:V.number(),contracts:V.array(uc)}).passthrough(),mc=V.object({chain:V.string()}).strict(),{action:dc,safeAction:fc}=y(pc,async(e,t)=>{let{chain:n}=mc.parse(t);return await e.get(`/kms/on-chain/${n}`)});function nr(e={}){let t=ys(e),n={getCurrentUser:fn,safeGetCurrentUser:As,getAvailableNodes:Gs,safeGetAvailableNodes:Bs,getCvmCreateResources:eo,safeGetCvmCreateResources:to,listAllInstanceTypeFamilies:ao,safeListAllInstanceTypeFamilies:io,listFamilyInstanceTypes:co,safeListFamilyInstanceTypes:lo,listWorkspaces:mo,safeListWorkspaces:fo,getWorkspace:go,safeGetWorkspace:ho,getCvmInfo:On,safeGetCvmInfo:gt,getCvmList:Nn,safeGetCvmList:$t,provisionCvm:Eo,safeProvisionCvm:Ao,commitCvmProvision:Vn,safeCommitCvmProvision:Ro,getCvmComposeFile:qo,safeGetCvmComposeFile:Oo,provisionCvmComposeFileUpdate:Fo,safeProvisionCvmComposeFileUpdate:Uo,commitCvmComposeFileUpdate:Vo,safeCommitCvmComposeFileUpdate:Mo,updateCvmEnvs:Wo,safeUpdateCvmEnvs:Xo,updateDockerCompose:ea,safeUpdateDockerCompose:ta,updatePreLaunchScript:aa,safeUpdatePreLaunchScript:ia,getCvmPreLaunchScript:ua,safeGetCvmPreLaunchScript:pa,getPreLaunchScriptUpgradeStatus:fa,safeGetPreLaunchScriptUpgradeStatus:ga,upgradePreLaunchScript:_a,safeUpgradePreLaunchScript:wa,startCvm:Bn,safeStartCvm:Ua,stopCvm:Wn,safeStopCvm:Da,shutdownCvm:Xn,safeShutdownCvm:Ma,restartCvm:Jn,safeRestartCvm:Ga,deleteCvm:Xa,safeDeleteCvm:Ja,getCvmStats:ti,safeGetCvmStats:ni,getCvmNetwork:ai,safeGetCvmNetwork:ii,getCvmDockerCompose:ui,safeGetCvmDockerCompose:pi,getCvmContainersStats:gi,safeGetCvmContainersStats:hi,getCvmAttestation:Ci,safeGetCvmAttestation:Si,updateCvmResources:Ei,safeUpdateCvmResources:Ai,updateCvmVisibility:Ri,safeUpdateCvmVisibility:xi,getAvailableOsImages:$i,safeGetAvailableOsImages:qi,updateOsImage:Ni,safeUpdateOsImage:zi,getKmsInfo:Sa,safeGetKmsInfo:ka,getKmsList:Ia,safeGetKmsList:Ra,getAppEnvEncryptPubKey:Pa,safeGetAppEnvEncryptPubKey:ja,nextAppIds:Oa,safeNextAppIds:Na,getCvmState:Li,safeGetCvmState:Di,listSshKeys:tr,safeListSshKeys:Mi,importGithubProfileSshKeys:Gi,safeImportGithubProfileSshKeys:Bi,createSshKey:Xi,safeCreateSshKey:Ji,deleteSshKey:Qi,safeDeleteSshKey:Yi,syncGithubSshKeys:tc,safeSyncGithubSshKeys:nc,getOsImages:ac,safeGetOsImages:ic,getKmsOnChainDetail:dc,safeGetKmsOnChainDetail:fc};return t.extend(n)}var on=C.object({vm_uuid:C.string().nullable(),app_id:C.string(),name:C.string().default(""),status:C.string(),vcpu:C.number().int(),memory:C.number().int(),disk_size:C.number().int(),teepod_id:C.number().int(),teepod_name:C.string(),region_identifier:C.string().nullable().optional(),kms_type:C.string().nullable().optional(),instance_type:C.string().nullable().optional(),listed:C.boolean().nullable().optional(),base_image:C.string().nullable().optional(),kms_slug:C.string().nullable().optional(),kms_id:C.string().nullable().optional(),kms_contract_id:C.string().nullable().optional(),instance_id:C.string().nullable().optional(),machine_info:xt.nullable().optional(),updated_at:C.string().nullable().optional()}),gc=C.object({display_name:C.string().nullable().optional(),avatar_url:C.string().nullable().optional(),description:C.string().nullable().optional(),custom_domain:C.string().nullable().optional()}),hc=C.object({id:C.string(),name:C.string(),app_id:C.string(),app_provision_type:C.string().nullable().optional(),app_icon_url:C.string().nullable().optional(),created_at:C.string(),kms_type:C.string(),profile:gc.nullable().optional(),current_cvm:on.nullable().optional(),cvms:C.array(on).default([]),cvm_count:C.number().int().default(0)}),bc=hc,Gu=C.object({dstack_apps:C.array(bc),page:C.number().int(),page_size:C.number().int(),total:C.number().int(),total_pages:C.number().int()}),rr=O.object({id:O.string(),name:O.string(),app_id:O.string(),app_provision_type:O.string().nullable().optional(),app_icon_url:O.string().nullable().optional(),created_at:O.string(),kms_type:O.string(),profile:O.object({display_name:O.string().nullable().optional(),avatar_url:O.string().nullable().optional(),description:O.string().nullable().optional(),custom_domain:O.string().nullable().optional()}).nullable().optional(),current_cvm:st.nullable().optional(),cvms:O.array(st).default([]),cvm_count:O.number().int().default(0)}),vc=rr.extend({current_cvm:mt.nullable().optional(),cvms:O.array(mt).default([])}),yc=rr,_c=vc,wc=O.object({dstack_apps:O.array(yc),page:O.number().int(),page_size:O.number().int(),total:O.number().int(),total_pages:O.number().int()}),Wu=wc.extend({dstack_apps:O.array(_c)}),sr=I.object({object_type:I.literal("cvm"),id:I.string().nullable().optional(),name:I.string().nullable().optional(),app_id:I.string().nullable().optional(),vm_uuid:I.string().nullable().optional()}),Cc=I.object({revision_id:I.string(),app_id:I.string(),vm_uuid:I.string(),compose_hash:I.string(),created_at:I.string(),trace_id:I.string().nullable().optional(),operation_type:I.string(),triggered_by:Pt.nullable().optional(),cvm:sr.nullable().optional(),workspace:jt.nullable().optional()}),Ju=I.object({revision_id:I.string(),app_id:I.string(),vm_uuid:I.string(),compose_hash:I.string(),compose_file:I.union([I.record(I.any()),I.string()]).nullable().optional(),encrypted_env:I.string(),user_config:I.string(),created_at:I.string(),trace_id:I.string().nullable().optional(),operation_type:I.string(),triggered_by:Pt.nullable().optional(),cvm:sr.nullable().optional(),workspace:jt.nullable().optional()}),Zu=I.object({revisions:I.array(Cc),total:I.number().int(),page:I.number().int(),page_size:I.number().int(),total_pages:I.number().int()});var Sc=M.object({chain:M.unknown().optional(),rpcUrl:M.string().optional(),kmsContractAddress:M.string(),privateKey:M.string().optional(),walletClient:M.unknown().optional(),publicClient:M.unknown().optional(),allowAnyDevice:M.boolean().optional().default(!1),deviceId:M.string().optional().default("0000000000000000000000000000000000000000000000000000000000000000"),composeHash:M.string().optional().default("0000000000000000000000000000000000000000000000000000000000000000"),disableUpgrades:M.boolean().optional().default(!1),skipPrerequisiteChecks:M.boolean().optional().default(!1),minBalance:M.string().optional()}).passthrough(),Cp=Sc.refine(e=>{let t=!!e.privateKey,n=!!e.walletClient;return t!==n},{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>{let t=!!e.publicClient,n=!!e.walletClient,r=!!e.chain;return t&&n?!0:r},{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),Sp=M.object({appId:M.string(),appAuthAddress:M.string(),deployer:M.string(),transactionHash:M.string(),blockNumber:M.bigint().optional(),gasUsed:M.bigint().optional()}).passthrough();var $p=N.object({chain:N.unknown().optional(),rpcUrl:N.string().optional(),appId:N.string(),composeHash:N.string(),privateKey:N.string().optional(),walletClient:N.unknown().optional(),publicClient:N.unknown().optional(),skipPrerequisiteChecks:N.boolean().optional().default(!1),minBalance:N.string().optional(),timeout:N.number().optional().default(12e4),retryOptions:N.unknown().optional(),signal:N.unknown().optional(),onTransactionStateChange:N.function().optional(),onTransactionSubmitted:N.function().optional(),onTransactionConfirmed:N.function().optional()}).passthrough().refine(e=>{let t=!!e.privateKey,n=!!e.walletClient;return t!==n},{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>{let t=!!e.publicClient,n=!!e.walletClient,r=!!e.chain;return t&&n?!0:r},{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),qp=N.object({composeHash:N.string(),appId:N.string(),transactionHash:N.string(),blockNumber:N.bigint().optional(),gasUsed:N.bigint().optional()}).passthrough();var Mp=z.object({chain:z.unknown().optional(),rpcUrl:z.string().optional(),appAddress:z.string(),deviceId:z.string(),privateKey:z.string().optional(),walletClient:z.unknown().optional(),publicClient:z.unknown().optional(),skipPrerequisiteChecks:z.boolean().optional().default(!1),minBalance:z.string().optional(),timeout:z.number().optional().default(12e4),retryOptions:z.unknown().optional(),signal:z.unknown().optional(),onTransactionStateChange:z.function().optional(),onTransactionSubmitted:z.function().optional(),onTransactionConfirmed:z.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),Kp=z.object({appAddress:z.string(),deviceId:z.string(),transactionHash:z.string(),blockNumber:z.bigint().optional(),gasUsed:z.bigint().optional()}).passthrough();var Yp=F.object({chain:F.unknown().optional(),rpcUrl:F.string().optional(),appAddress:F.string(),deviceId:F.string(),privateKey:F.string().optional(),walletClient:F.unknown().optional(),publicClient:F.unknown().optional(),skipPrerequisiteChecks:F.boolean().optional().default(!1),minBalance:F.string().optional(),timeout:F.number().optional().default(12e4),retryOptions:F.unknown().optional(),signal:F.unknown().optional(),onTransactionStateChange:F.function().optional(),onTransactionSubmitted:F.function().optional(),onTransactionConfirmed:F.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),em=F.object({appAddress:F.string(),deviceId:F.string(),transactionHash:F.string(),blockNumber:F.bigint().optional(),gasUsed:F.bigint().optional()}).passthrough();var lm=U.object({chain:U.unknown().optional(),rpcUrl:U.string().optional(),appAddress:U.string(),allow:U.boolean(),privateKey:U.string().optional(),walletClient:U.unknown().optional(),publicClient:U.unknown().optional(),skipPrerequisiteChecks:U.boolean().optional().default(!1),minBalance:U.string().optional(),timeout:U.number().optional().default(12e4),retryOptions:U.unknown().optional(),signal:U.unknown().optional(),onTransactionStateChange:U.function().optional(),onTransactionSubmitted:U.function().optional(),onTransactionConfirmed:U.function().optional()}).passthrough().refine(e=>!!e.privateKey!=!!e.walletClient,{message:"Either 'privateKey' or 'walletClient' must be provided, but not both",path:["privateKey","walletClient"]}).refine(e=>e.publicClient&&e.walletClient?!0:!!e.chain,{message:"Chain is required when publicClient or walletClient is not provided",path:["chain"]}),um=U.object({appAddress:U.string(),allow:U.boolean(),transactionHash:U.string(),blockNumber:U.bigint().optional(),gasUsed:U.bigint().optional()}).passthrough();var gm=He.object({appAddress:He.string(),owner:He.string(),allowAnyDevice:He.boolean(),devices:He.array(He.string())});var kc=_n;var Ec=Ge.object({items:Ge.array(kc),total:Ge.number(),page:Ge.number(),page_size:Ge.number(),pages:Ge.number()}).passthrough(),{action:Am,safeAction:Im}=y(Ec,async(e,t)=>{let{teamSlug:n,page:r,pageSize:s}=t,o=new URLSearchParams;r!==void 0&&o.append("page",r.toString()),s!==void 0&&o.append("page_size",s.toString());let c=o.toString()?`/workspaces/${n}/nodes?${o.toString()}`:`/workspaces/${n}/nodes`;return await e.get(c)}),Je=_e.object({limit:_e.number(),remaining:_e.number()}).passthrough(),Ac=_e.object({vm_slots:Je,vcpu:Je,memory_mb:Je,disk_gb:Je}).passthrough(),Ic=_e.object({gpus:Je,in_use:_e.number(),misconfigured:_e.number()}).passthrough(),Rc=_e.object({team_slug:_e.string(),tier:_e.string(),quotas:Ac,reserved_nodes:Je,reserved_gpu:Ic,as_of:_e.string()}).passthrough(),{action:xm,safeAction:Tm}=y(Rc,async(e,t)=>await e.get(`/workspaces/${t.teamSlug}/quotas`)),jm=ue(ee.extend({node_id:xc.number().optional()}));var qm=Be.object({target:Be.string().describe("Target status to wait for (e.g., 'running', 'stopped')"),interval:Be.number().min(5).max(30).default(5).describe("Polling interval in seconds"),timeout:Be.number().min(10).max(600).default(300).describe("Timeout per attempt in seconds"),maxRetries:Be.number().min(0).default(Number.POSITIVE_INFINITY).describe("Maximum number of retry attempts (Infinity for unlimited)"),retryDelay:Be.number().min(0).default(5e3).describe("Delay between retries in milliseconds")});var Tc=ue(ee.extend({docker_compose_file:A.string().optional(),pre_launch_script:A.string().optional(),allowed_envs:A.array(A.string()).optional(),public_logs:A.boolean().optional(),public_sysinfo:A.boolean().optional(),public_tcbinfo:A.boolean().optional(),encrypted_env:A.string().optional(),user_config:A.string().optional(),gpus:A.object({count:A.number(),product_name:A.string().optional()}).optional(),vcpu:A.number().optional(),memory:A.number().optional(),disk_size:A.number().optional(),image:A.string().optional(),shutdown_timeout:A.number().optional(),allow_force_stop:A.boolean().optional(),prepareOnly:A.boolean().optional()})),Pc=A.object({requiresOnChainHash:A.literal(!1),correlationId:A.string()}),jc=A.object({requiresOnChainHash:A.literal(!0),composeHash:A.string(),appId:A.string(),deviceId:A.string(),kmsInfo:he,commitToken:A.string().optional(),commitUrl:A.string().optional(),apiCommitUrl:A.string().optional(),onchainStatus:A.object({compose_hash_allowed:A.boolean(),device_id_allowed:A.boolean(),is_allowed:A.boolean()}).optional()}),$c=A.discriminatedUnion("requiresOnChainHash",[Pc,jc]);function qc(e){let t={};if(!e||typeof e!="object")return t;let r=e.details;if(!Array.isArray(r))return t;for(let s of r)s&&typeof s=="object"&&"field"in s&&"value"in s&&(t[s.field]=s.value);return t}var{action:Nm,safeAction:zm}=y($c,async(e,t)=>{let n=Tc.parse(t),{cvmId:r}=j.parse(n),{id:s,uuid:o,app_id:c,instance_id:i,name:u,prepareOnly:f,...m}=n;try{return{requiresOnChainHash:!1,correlationId:(f?await e.patch(`/cvms/${r}`,m,{headers:{"X-Prepare-Only":"true"}}):await e.patch(`/cvms/${r}`,m)).correlation_id}}catch(d){if(d instanceof ge&&d.status===465){let h=qc(d.detail);return{requiresOnChainHash:!0,composeHash:h.compose_hash,appId:String(h.app_id),deviceId:h.device_id,kmsInfo:h.kms_info,commitToken:h.commit_token,commitUrl:h.commit_url,apiCommitUrl:h.api_commit_url,onchainStatus:h.onchain_status}}throw d}}),Oc=ue(ee.extend({composeHash:dt.string().describe("Compose hash from patchCvm Phase 1 response"),transactionHash:dt.string().describe("Transaction hash proving on-chain registration")})),Nc=dt.object({correlationId:dt.string()}),{action:Um,safeAction:Lm}=y(Nc,async(e,t)=>{let n=Oc.parse(t),{cvmId:r}=j.parse(n);return{correlationId:(await e.patch(`/cvms/${r}`,{},{headers:{"X-Compose-Hash":n.composeHash,"X-Transaction-Hash":n.transactionHash}})).correlation_id}}),zc=ue(ee.extend({token:Qe.string().describe("One-time commit token from prepare-only flow"),composeHash:Qe.string().describe("Compose hash from Phase 1 response"),transactionHash:Qe.string().describe("Transaction hash proving on-chain registration")})),Fc=Qe.object({correlationId:Qe.string(),status:Qe.string()}),{action:Vm,safeAction:Mm}=y(Fc,async(e,t)=>{let n=zc.parse(t),{cvmId:r}=j.parse(n),s=await e.post(`/cvms/${r}/commit-update`,{token:n.token,compose_hash:n.composeHash,transaction_hash:n.transactionHash});return{correlationId:s.correlation_id,status:s.status}}),or=me.object({identifier:me.string(),status:me.enum(["updated","unchanged","skipped","conflict","error"]),old_instance_id:me.string().nullable().optional(),new_instance_id:me.string().nullable().optional(),source:me.enum(["teepod_state","teepod_info","gateway","none"]),verified_with_gateway:me.boolean(),reason:me.string().nullable().optional()}),Ot=or.extend({cvm_id:me.number().nullable()}),Nt=or.extend({cvm_id:me.string().nullable()}),Hm=me.union([Ot,Nt]);var Gm=ue(ee.extend({overwrite:me.boolean().optional(),dry_run:me.boolean().optional()}));var Wm=K.object({cvm_ids:K.array(K.string()).optional(),running_only:K.boolean().optional(),missing_only:K.boolean().optional(),overwrite:K.boolean().optional(),limit:K.number().int().min(1).max(500).optional(),dry_run:K.boolean().optional()}).strict(),zt=K.object({total:K.number().int(),scanned:K.number().int(),updated:K.number().int(),unchanged:K.number().int(),skipped:K.number().int(),conflicts:K.number().int(),errors:K.number().int()}),Xm=zt.extend({items:K.array(Ot)}),Jm=zt.extend({items:K.array(Nt)}),Zm=zt.extend({items:K.array(K.union([Ot,Nt]))});var Uc=re.object({vm_uuid:re.string(),status:re.string(),uptime:re.string().nullable().optional(),in_progress:re.boolean(),boot_progress:re.string().nullable().optional(),boot_error:re.string().nullable().optional(),operation_type:re.string().nullable().optional(),operation_started_at:re.string().nullable().optional(),correlation_id:re.string().nullable().optional()}),Lc=re.record(re.string(),Uc),Dc=re.object({vmUuids:re.array(re.string())}),{action:Ym,safeAction:ed}=y(Lc,async(e,t)=>{let{vmUuids:n}=Dc.parse(t);return await e.post("/status/batch",{vm_uuids:n})}),Vc=nt.object({hostname:nt.string().nullable().optional(),ssh_authorized_keys:nt.array(nt.string()).default([]),default_gateway_domain:nt.string().nullable().optional()}),Mc=j,{action:nd,safeAction:rd}=y(Vc,async(e,t)=>{let{cvmId:n}=Mc.parse(t);return await e.get(`/cvms/${n}/user_config`)}),ar=W.object({app_contract_address:W.string(),compose_hash:W.string(),device_id:W.string(),compose_hash_allowed:W.boolean(),allow_any_device:W.boolean(),device_id_allowed:W.boolean().nullable().optional(),is_allowed:W.boolean(),error:W.string().nullable().optional()}),ir=ar.extend({cvm_id:W.number().optional()}),Ft=ar.extend({cvm_id:W.string().optional()}),od=W.union([ir,Ft]),Kc=Ft,ad=W.object({cvmId:W.string().min(1),compose_hash:W.string().optional(),node_id:W.number().optional(),device_id:W.string().optional()});var Hc=We.object({appId:We.string().min(1),compose_hash:We.string(),node_id:We.number().optional(),device_id:We.string().optional(),chain_id:We.number().optional()}),{action:cd,safeAction:ld}=y(Kc,async(e,t)=>{let{appId:n,...r}=Hc.parse(t);return await e.post(`/apps/${n}/is-allowed`,r)}),cr=Z.object({is_onchain:Z.boolean(),total:Z.number().default(0),allowed_count:Z.number().default(0),denied_count:Z.number().default(0),error_count:Z.number().default(0)}),Gc=cr.extend({results:Z.array(ir.extend({cvm_id:Z.number()})).default([]),skipped_cvm_ids:Z.array(Z.number()).default([])}),Bc=cr.extend({results:Z.array(Ft.extend({cvm_id:Z.string()})).default([]),skipped_cvm_ids:Z.array(Z.string()).default([])}),pd=Z.union([Gc,Bc]);var md=Z.object({appId:Z.string().min(1)});var fd=pe.object({page:pe.number().int().min(1).optional(),page_size:pe.number().int().min(1).max(100).optional(),search:pe.string().optional(),status:pe.array(pe.string()).optional(),listed:pe.boolean().optional(),base_image:pe.string().optional(),instance_type:pe.string().optional(),kms_slug:pe.string().optional(),kms_type:pe.string().optional(),node:pe.string().optional(),region:pe.string().optional()}).strict();var hd=an.object({appId:an.string().min(1)}).strict();var vd=cn.object({appId:cn.string().min(1)}).strict();var Wc=ke.object({appId:ke.string().min(1),name:ke.string().optional(),node_id:ke.number().optional(),docker_compose_file:ke.string().optional(),pre_launch_script:ke.string().optional(),encrypted_env:ke.string().optional(),compose_hash:ke.string().optional(),token:ke.string().optional(),transaction_hash:ke.string().optional()}).strict(),{action:_d,safeAction:wd}=y(za,async(e,t)=>{let n=Wc.parse(t),{appId:r,...s}=n;return await e.post(`/apps/${r}/instances`,s)}),lr=H.object({device_id:H.string(),node_name:H.string().nullable(),allowed_onchain:H.boolean(),status:H.string()}),ur=lr.extend({cvm_ids:H.array(H.number())}),pr=lr.extend({cvm_ids:H.array(H.string())}),mr=H.object({is_onchain_kms:H.boolean(),allow_any_device:H.boolean().nullable().optional(),chain_id:H.number().nullable().optional(),app_contract_address:H.string().nullable().optional()}),Xc=mr.extend({devices:H.array(ur).optional().default([])}),Jc=mr.extend({devices:H.array(pr).optional().default([])}),Sd=H.union([ur,pr]),kd=H.union([Xc,Jc]);var Ed=H.object({appId:H.string().min(1)}).strict();var Id=ut.object({appId:ut.string().min(1),page:ut.number().int().min(1).optional(),page_size:ut.number().int().min(1).max(1e3).optional()}).strict();var xd=pt.object({appId:pt.string().min(1),revisionId:pt.string().min(1),rawComposeFile:pt.boolean().optional()}).strict();var Pd=ne.object({statuses:ne.array(ne.string()),image_versions:ne.array(ne.string()),instance_types:ne.array(ne.string()),kms_slugs:ne.array(ne.string()),kms_types:ne.array(ne.string()),regions:ne.array(ne.string()),nodes:ne.array(ne.string())});var Zc=E.object({contract_address:E.string(),chain_id:E.number().nullable(),version:E.string(),url:E.string(),gateway_app_id:E.string().nullable(),gateway_app_url:E.string(),kms_type:E.string()}),ln=E.object({app_id:E.string().optional(),instance_id:E.string().optional(),app_name:E.string().optional(),device_id:E.string().optional()}).passthrough().nullable(),Qc=E.object({vm_uuid:E.string().nullable().optional(),name:E.string().optional(),instance_id:E.string().nullable().optional(),status:E.string().optional(),image_version:E.string().nullable().optional(),quote:E.string().nullable().optional(),ppid:E.string().optional(),ppid_sha256:E.string().nullable().optional(),device_id:E.string().optional(),fmspc:E.string().nullable().optional(),tee_tcb_svn:E.string().nullable().optional(),mr_config_id:E.string().nullable().optional(),cpusvn:E.string().nullable().optional(),pcesvn:E.number().nullable().optional(),tcb_info:Qn.nullable().optional(),app_certificates:E.array(Zn).nullable().optional(),compose_file:E.string().nullable().optional(),error:E.string().nullable().optional()}),Yc=E.object({app_id:E.string(),contract_address:E.string(),kms_info:Zc,instances:E.array(Qc),kms_guest_agent_info:ln,gateway_guest_agent_info:ln,qemu_version:E.string().nullable()}),el=E.object({appId:E.string().min(1)}).strict(),{action:$d,safeAction:qd}=y(Yc,async(e,t)=>{let{appId:n}=el.parse(t);return await e.get(`/apps/${n}/attestations`)});var tl;function dr(){return tl}import al from"path";import Ut from"fs-extra";import il from"@iarna/toml";import{z as be}from"zod";import se from"chalk";import rl from"ora";var nl=!1;function we(){return nl}function sl(e,t){let n=e.split(/\s+/),r=[],s="";for(let o of n){let c=s.length===0?o:`${s} ${o}`;c.length<=t?s=c:(s.length>0&&r.push(s),s=o)}return s.length>0&&r.push(s),r}function ol(e,t){if(e.length<=t)return[e];let n=[],r=0;for(;r<e.length;)n.push(e.slice(r,r+t)),r+=t;return n}function fr(e,t){let n=[];for(let r of e.split(`
21
+ `)){if(r.length<=t){n.push(r);continue}if(r.indexOf(" ")===-1){n.push(...ol(r,t));continue}let s=sl(r,t);n.push(...s)}if(n.length===0){let r=e.trim();n.push(r)}return n}var je={error:(e,...t)=>{we()||(process.stderr.write(`${se.red("\u2717")} ${se.red(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
22
+ `))},warn:(e,...t)=>{we()||(process.stderr.write(`${se.yellow("\u26A0")} ${se.yellow(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
23
+ `))},info:(e,...t)=>{we()||(process.stderr.write(`${se.blue("\u2139")} ${se.blue(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
24
+ `))},success:(e,...t)=>{we()||(process.stderr.write(`${se.green("\u2713")} ${se.green(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
25
+ `))},debug:(e,...t)=>{we()||process.env.DEBUG&&(process.stderr.write(`${se.gray("\u{1F50D}")} ${se.gray(e)}`),t.length>0&&process.stderr.write(` ${t.map(String).join(" ")}`),process.stderr.write(`
26
+ `))},table:(e,t)=>{if(!we()){if(e.length===0){console.log(se.yellow("No data to display"));return}if(t){let n;typeof t[0]=="string"?n=t.map(c=>({key:c,header:c})):n=t;let r={};for(let c of n){let i=c.header||String(c.key);r[String(c.key)]=i.length}for(let c of e)for(let i of n){let u=String(typeof i.key=="string"&&!(i.key in c)?"":c[String(i.key)]??"");r[String(i.key)]=Math.max(r[String(i.key)],u.length)}let s=[];for(let c of n){let i=c.header||String(c.key);s.push(se.bold(i.padEnd(r[String(c.key)])))}console.log(s.join(" "));let o=[];for(let c of n)o.push("-".repeat(r[String(c.key)]));console.log(o.join(" "));for(let c of e){let i=[];for(let u of n){let f=String(typeof u.key=="string"&&!(u.key in c)?"":c[String(u.key)]??"");i.push(f.padEnd(r[String(u.key)]))}console.log(i.join(" "))}}else{let n=e[0],r=Object.keys(n),s={};for(let i of r)s[i]=i.length;for(let i of e)for(let u of r){let f=String(i[u]??"");s[u]=Math.max(s[u],f.length)}let o=[];for(let i of r)o.push(se.bold(i.padEnd(s[i])));console.log(o.join(" "));let c=[];for(let i of r)c.push("-".repeat(s[i]));console.log(c.join(" "));for(let i of e){let u=[];for(let f of r){let m=String(i[f]??"");u.push(m.padEnd(s[f]))}console.log(u.join(" "))}}}},keyValueTable:(e,t)=>{if(we())return;let{borderStyle:n="single",keyColor:r=se.blue,valueColor:s=se.white,maxWidth:o=process.stdout.columns||80}=t||{},i={single:{topLeft:"\u250C",topRight:"\u2510",bottomLeft:"\u2514",bottomRight:"\u2518",horizontal:"\u2500",vertical:"\u2502",cross:"\u253C",leftT:"\u251C",rightT:"\u2524"},double:{topLeft:"\u2554",topRight:"\u2557",bottomLeft:"\u255A",bottomRight:"\u255D",horizontal:"\u2550",vertical:"\u2551",cross:"\u256C",leftT:"\u2560",rightT:"\u2563"},rounded:{topLeft:"\u256D",topRight:"\u256E",bottomLeft:"\u2570",bottomRight:"\u256F",horizontal:"\u2500",vertical:"\u2502",cross:"\u253C",leftT:"\u251C",rightT:"\u2524"},bold:{topLeft:"\u250F",topRight:"\u2513",bottomLeft:"\u2517",bottomRight:"\u251B",horizontal:"\u2501",vertical:"\u2503",cross:"\u254B",leftT:"\u2523",rightT:"\u252B"},none:{topLeft:"",topRight:"",bottomLeft:"",bottomRight:"",horizontal:"",vertical:"",cross:"",leftT:"",rightT:""}}[n],u=0,f=0;for(let[k,R]of Object.entries(e)){u=Math.max(u,k.length);let q=String(R??"");f=Math.max(f,q.length)}let m=4,d=1,h=o-m-d;if(u+f>h){let k=u/(u+f);u=Math.floor(h*k),f=h-u}let _=u+f+m+d;n!=="none"&&console.log(i.topLeft+i.horizontal.repeat(_-2)+i.topRight);for(let[k,R]of Object.entries(e)){let q=k,te=String(R??""),fe=fr(q,u),Ie=fr(te,f),Ce=Math.max(fe.length,Ie.length);for(;fe.length<Ce;)fe.push("");for(;Ie.length<Ce;)Ie.push("");for(let Re=0;Re<Ce;Re++){let ze=fe[Re].padEnd(u),ot=Ie[Re].padEnd(f);console.log(n!=="none"?`${i.vertical} ${r(ze)} ${i.vertical} ${s(ot)} ${i.vertical}`:`${r(ze)} : ${s(ot)}`)}}n!=="none"&&console.log(i.bottomLeft+i.horizontal.repeat(_-2)+i.bottomRight)},break:()=>{we()||process.stderr.write(`
27
+ `)},startSpinner:e=>{if(we())return{stop:()=>{}};let t=rl(e).start();return{stop:(n=!0,r)=>{r&&(t.text=r),n?t.succeed():t.fail()}}},logDetailedError(e,t){if(we())return;let n=t?`[${t}] `:"",r=o=>o!==null&&typeof o=="object"&&("status"in o||"detail"in o||"requestId"in o);if((o=>o!==null&&typeof o=="object"&&"issues"in o&&Array.isArray(o.issues))(e)){process.stderr.write(`${n}Validation error: ${JSON.stringify(e.issues)}
28
+ `);return}if(r(e)){let o=[];if(typeof e.status=="number"&&e.status>0){let c=e.statusText??"";o.push(`${n}HTTP ${e.status}${c?` ${c}`:""}`)}typeof e.requestId=="string"&&e.requestId.length>0&&o.push(`${n}Request ID: ${e.requestId}`),e.data!==void 0&&e.data!==null&&o.push(JSON.stringify(e.data,null,2)),o.length>0&&process.stderr.write(`${o.join(`
29
+ `)}
30
30
  `);return}e instanceof Error?process.stderr.write(`${n}${e.message}
31
31
  `):process.stderr.write(`${n}${String(e)}
32
- `)}};var hu=oe.extend({profile:xe.string().optional(),api_version:xe.enum(xt).optional(),gateway_domain:xe.string().optional(),gateway_port:xe.number().int().positive().optional(),compose_file:xe.string().optional(),env_file:xe.string().optional(),public_logs:xe.boolean().optional(),public_sysinfo:xe.boolean().optional(),listed:xe.boolean().optional()}),on="phala.toml";function Wr(){return fu.join(process.cwd(),on)}function bu(){return sn.existsSync(Wr())}function vu(){let e=Wr();if(!sn.existsSync(e))throw new Error(`Project configuration file not found: ${on}
33
- Run 'phala init' to create one.`);try{let t=sn.readFileSync(e,"utf8"),n=gu.parse(t),r=hu.parse(n);if(r.id||r.uuid||r.app_id||r.instance_id||r.name){let{cvmId:s}=j.parse(r);return{...r,cvm_id:s}}return r}catch(t){if(t instanceof xe.ZodError){let n=t.issues.map(r=>` - ${r.path.join(".")}: ${r.message}`).join(`
32
+ `)}};var cl=ee.extend({profile:be.string().optional(),api_version:be.enum(ft).optional(),gateway_domain:be.string().optional(),gateway_port:be.number().int().positive().optional(),compose_file:be.string().optional(),env_file:be.string().optional(),public_logs:be.boolean().optional(),public_sysinfo:be.boolean().optional(),public_tcbinfo:be.boolean().optional(),secure_time:be.boolean().optional(),listed:be.boolean().optional()}),Lt="phala.toml";function gr(){return al.join(process.cwd(),Lt)}function ll(){return Ut.existsSync(gr())}function ul(){let e=gr();if(!Ut.existsSync(e))throw new Error(`Project configuration file not found: ${Lt}
33
+ Run 'phala init' to create one.`);try{let t=Ut.readFileSync(e,"utf8"),n=il.parse(t),r=cl.parse(n);if(r.id||r.uuid||r.app_id||r.instance_id||r.name){let{cvmId:s}=j.parse(r);return{...r,cvm_id:s}}return r}catch(t){if(t instanceof be.ZodError){let n=t.issues.map(r=>` - ${r.path.join(".")}: ${r.message}`).join(`
34
34
  `);throw new Error(`Invalid project configuration:
35
- ${n}`)}throw new Error(`Failed to parse ${on}: ${t instanceof Error?t.message:String(t)}`)}}function Xr(){return bu()?vu():{}}import Jr from"fs";import yu from"os";import Qr from"path";var Zr="https://cloud-api.phala.com/api/v1";function _u(){let e=process.env.PHALA_CLOUD_DIR;return typeof e=="string"&&e.trim().length>0?e:Qr.join(yu.homedir(),".phala-cloud")}function wu(){return Qr.join(_u(),"credentials.json")}function Tt(e){return typeof e=="string"&&e.trim().length>0}function Cu(e){let t=e.trim();return t.length===0?"default":t}function ku(){try{let e=wu();if(!Jr.existsSync(e))return null;let t=Jr.readFileSync(e,"utf8"),n=JSON.parse(t);if(!n||typeof n!="object")return null;let r=n;return r.schema_version!==1||!Tt(r.current_profile)||!r.profiles||typeof r.profiles!="object"?null:r}catch(e){return Ue.error("Failed to read credentials file:",e),null}}function Yr(e){let t=ku(),n=Cu(e.profile||e.projectProfile||t?.current_profile||"default"),r=n;if(t&&!t.profiles[r]){let m=Object.entries(t.profiles).find(([,u])=>u?.workspace?.slug===n);if(m)r=m[0];else{let u=Object.entries(t.profiles).find(([,f])=>f?.workspace?.name===n);u&&(r=u[0])}}let s=e.env.PHALA_CLOUD_API_PREFIX,o=t?.profiles?.[r]?.api_prefix,a=(s&&s.trim().length>0?s:o&&o.trim().length>0?o:Zr)??Zr,i=s?"env":o?"file":"default";if(Tt(e.apiToken))return{apiKey:e.apiToken,baseURL:a,profileName:r,tokenSource:"flag",apiPrefixSource:i};if(Tt(e.env.PHALA_CLOUD_API_KEY))return{apiKey:e.env.PHALA_CLOUD_API_KEY,baseURL:a,profileName:r,tokenSource:"env",apiPrefixSource:i};let l=t?.profiles?.[r]?.token;return Tt(l)?{apiKey:l,baseURL:a,profileName:r,tokenSource:"file",apiPrefixSource:i}:{apiKey:null,baseURL:a,profileName:r,tokenSource:"none",apiPrefixSource:i}}var Su="2026-01-21";function Eu(){return{env:process.env,projectConfig:Xr()}}function Au(e,t){let n=e??Eu();return Yr({env:n.env,apiToken:t?.apiToken??n.globalOptions?.apiToken,profile:t?.profile??n.globalOptions?.profile,projectProfile:n.projectConfig.profile})}async function pe(e,t){let n=Au(e,t),r=Kr()??Su;return Br({apiKey:n.apiKey??void 0,baseURL:n.baseURL,version:r})}import{z as c}from"zod";var Iu=c.object({password:c.string(),registry:c.string().nullable(),username:c.string()}),lg=c.object({docker_compose_file:c.string(),docker_config:Iu.optional().nullable(),features:c.array(c.string()),kms_enabled:c.boolean(),manifest_version:c.number(),name:c.string(),public_logs:c.boolean(),public_sysinfo:c.boolean(),runner:c.string().optional(),salt:c.string().nullable().optional(),tproxy_enabled:c.boolean(),version:c.string().optional()}).passthrough(),es=c.object({id:c.number(),name:c.string(),status:c.string(),teepod_id:c.number().nullable(),teepod:c.object({id:c.number(),name:c.string()}).nullable(),user_id:c.number().nullable(),app_id:c.string(),vm_uuid:c.string().nullable(),instance_id:c.string().nullable(),app_url:c.string().nullable(),base_image:c.string().nullable(),vcpu:c.number(),memory:c.number(),disk_size:c.number(),manifest_version:c.number().nullable(),version:c.string().nullable(),runner:c.string().nullable(),docker_compose_file:c.string().nullable(),features:c.array(c.string()).nullable(),created_at:c.string(),encrypted_env_pubkey:c.string().nullable()}),ug=c.object({key:c.string(),value:c.string()}),ts=c.object({is_online:c.boolean(),is_public:c.boolean(),error:c.string().nullable(),internal_ip:c.string(),latest_handshake:c.string(),public_urls:c.array(c.object({app:c.string(),instance:c.string()}))}),ns=c.object({id:c.number(),name:c.string(),status:c.string(),teepod_id:c.number(),teepod:c.object({id:c.number(),name:c.string()}),user_id:c.number().nullable().optional(),app_id:c.string(),vm_uuid:c.string().nullable().optional(),instance_id:c.string().nullable().optional(),app_url:c.string().nullable().optional(),base_image:c.string().nullable().optional(),vcpu:c.number(),memory:c.number(),disk_size:c.number(),manifest_version:c.number().nullable().optional(),version:c.string().nullable().optional(),runner:c.string().nullable().optional(),docker_compose_file:c.string().nullable().optional(),features:c.array(c.string()).nullable().optional(),created_at:c.string(),encrypted_env_pubkey:c.string().nullable().optional()}),rs=c.object({is_online:c.boolean(),is_public:c.boolean(),error:c.string().nullable(),app_certificates:c.array(c.object({subject:c.object({common_name:c.string().nullable(),organization:c.string().nullable(),country:c.string().nullable(),state:c.string().nullable().optional(),locality:c.string().nullable().optional()}),issuer:c.object({common_name:c.string().nullable(),organization:c.string().nullable(),country:c.string().nullable()}),serial_number:c.string(),not_before:c.string(),not_after:c.string(),version:c.string(),fingerprint:c.string(),signature_algorithm:c.string(),sans:c.string().nullable(),is_ca:c.boolean(),position_in_chain:c.number(),quote:c.string().nullable()})).nullable(),tcb_info:c.object({mrtd:c.string(),rootfs_hash:c.string(),rtmr0:c.string(),rtmr1:c.string(),rtmr2:c.string(),rtmr3:c.string(),event_log:c.array(c.object({imr:c.number(),event_type:c.number(),digest:c.string(),event:c.string(),event_payload:c.string()}))}).nullable(),compose_file:c.string().nullable()}),xu=c.object({name:c.string(),description:c.string().optional(),version:c.array(c.number()).optional(),is_dev:c.boolean().optional(),os_image_hash:c.string().nullable().optional(),rootfs_hash:c.string().optional(),shared_ro:c.boolean().optional(),cmdline:c.string().optional(),kernel:c.string().optional(),initrd:c.string().optional(),hda:c.string().nullable().optional(),rootfs:c.string().optional(),bios:c.string().optional()}),pg=c.object({teepod_id:c.number().nullable(),id:c.number().optional(),name:c.string(),listed:c.boolean().optional(),resource_score:c.number().optional(),remaining_vcpu:c.number().optional(),remaining_memory:c.number().optional(),remaining_cvm_slots:c.number().optional(),images:c.array(xu).optional(),region_identifier:c.string().optional(),dedicated_for_team_id:c.number().nullable().optional(),support_onchain_kms:c.boolean().optional(),fmspc:c.string().nullable().optional(),device_id:c.string().nullable().optional()});import Ru from"inquirer";async function vg(e){let t=await pe(),n=e.replace(/^app_/,""),r=await Rt(t,{app_id:n});if(!r.success)throw new Error(r.error.message);return r.data}async function yg(e){let t=await pe(),n=e.replace(/^app_/,""),r=await t.get(`cvms/app_${n}/network`);return ts.parse(r)}async function _g(){let e=Ue.startSpinner("Fetching available CVMs"),t=await pe(),n=await nn(t);if(e.stop(!0),!n.success){Ue.error(`Failed to fetch CVMs: ${n.error.message}`);return}let{items:r}=n.data;if(r.length===0){Ue.info("No CVMs found for your account");return}let s=r.map(a=>({name:`${a.name} (${a.app_id??a.id}) - ${a.status}`,value:a.app_id??a.id})),{selectedCvm:o}=await Ru.prompt([{type:"list",name:"selectedCvm",message:"Select a CVM:",choices:s}]);return o}async function wg(e){let t=await pe(),n=e.replace(/^app_/,""),r=await t.get(`cvms/app_${n}/attestation`);try{return rs.parse(r)}catch(s){return Ue.debug(`Validation error: ${s instanceof Error?s.message:String(s)}`),{is_online:!!r?.is_online,is_public:!!r?.is_public,error:typeof r?.error=="string"?r.error:null,app_certificates:Array.isArray(r?.app_certificates)?r.app_certificates:null,tcb_info:r?.tcb_info||null,compose_file:typeof r?.compose_file=="string"?r.compose_file:null}}}async function Cg(e,t,n){let r=await pe(),s=e.replace(/^app_/,""),o=await r.post(`apps/${s}/cvms/${t}/replicas`,n);return ns.parse(o)}async function kg(e,t,n,r,s){let o=await pe(),a=e.replace(/^app_/,""),i={};if(t!==void 0&&(i.vcpu=t),n!==void 0&&(i.memory=n),r!==void 0&&(i.disk_size=r),s!==void 0&&(i.allow_restart=s),Object.keys(i).length===0)throw new Error("At least one resource parameter must be provided");return await o.patch(`cvms/app_${a}/resources`,i),!0}async function Sg(e){return await(await pe()).post("cvms/pubkey/from_cvm_configuration",e)}async function Eg(e){let n=await(await pe()).post("cvms/from_cvm_configuration",e);return es.parse(n)}async function Ag(e,t){let n=await pe(),r=e.replace(/^app_/,"");return await n.put(`cvms/app_${r}/compose`,t)}async function Ig(e=!1){let t=await pe(),n="teepods/available";return e&&(n+="?v03x_only=1"),await t.get(n)}function ze(e,t){let n=[];t.since&&n.push(`since=${encodeURIComponent(t.since)}`),t.until&&n.push(`until=${encodeURIComponent(t.until)}`),t.follow&&n.push("follow"),t.text&&n.push("text"),t.bare&&n.push("bare"),t.tail!==void 0&&(n.push(`tail=${t.tail}`),n.push(`lines=${t.tail}`)),t.timestamps&&n.push("timestamps"),(t.ansi??!0)&&n.push("ansi");let r=e.includes("?")?"&":"?";return e+r+n.join("&")}async function ss(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder;for(;;){let{done:s,value:o}=await n.read();if(s)break;t(r.decode(o,{stream:!0}))}}function Tu(e){return!e||/\s/.test(e)||e.length%4!==0?!1:/^[A-Za-z0-9+/]+={0,2}$/.test(e)}function Pu(e){if(!Tu(e))return e;try{return Buffer.from(e,"base64").toString("utf-8")}catch{return e}}function Pt(e){let t=e.trim();if(!t)return null;try{let n=JSON.parse(t);return typeof n.message!="string"?null:{channel:n.channel==="stderr"?"stderr":"stdout",message:Pu(n.message)}}catch{return null}}function ju(e){let t=e.split(/\r?\n/),n=[];for(let r of t){if(!r.trim())continue;let s=Pt(r);if(s){n.push(s);continue}n.push({channel:"stdout",message:`${r}
36
- `})}return n}function Ou(e){let t=e.split(/\r?\n/),n="";for(let r of t){let s=Pt(r);if(s){n+=s.message;continue}r.trim()&&(n+=`${r}
37
- `)}return n}async function $u(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder,s="",o="unknown",a=i=>{let l=Pt(i);if(l){t(l.message);return}i.trim()&&t(`${i}
38
- `)};for(;;){let{done:i,value:l}=await n.read();if(i)break;let m=r.decode(l,{stream:!0});if(o==="raw"){t(m);continue}if(s+=m,o==="unknown")if(s.trimStart().startsWith("{"))o="structured";else{o="raw",t(s),s="";continue}let u=s.indexOf(`
39
- `);for(;u>=0;){let f=s.slice(0,u);s=s.slice(u+1),a(f),u=s.indexOf(`
40
- `)}}o==="structured"&&s.trim()?a(s):o==="raw"&&s&&t(s)}async function Lu(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder,s="",o="unknown",a=i=>{let l=Pt(i);if(l){t(l);return}i.trim()&&t({channel:"stdout",message:`${i}
41
- `})};for(;;){let{done:i,value:l}=await n.read();if(i)break;let m=r.decode(l,{stream:!0});if(o==="raw"){t({channel:"stdout",message:m});continue}if(s+=m,o==="unknown")if(s.trimStart().startsWith("{"))o="structured";else{o="raw",t({channel:"stdout",message:s}),s="";continue}let u=s.indexOf(`
42
- `);for(;u>=0;){let f=s.slice(0,u);s=s.slice(u+1),a(f),u=s.indexOf(`
43
- `)}}o==="structured"&&s.trim()?a(s):o==="raw"&&s&&t({channel:"stdout",message:s})}async function an(e,t){let r=await(await pe()).get(`cvms/${e}`,{headers:{"X-Phala-Version":"2025-10-28"}});if(!r.syslog_endpoint)throw new Error(`No syslog endpoint available for CVM '${e}'`);return`${r.syslog_endpoint}&ch=${t}`}async function os(e){return an(e,"serial")}async function jt(e,t,n=!0){let s=await(await pe()).get(`cvms/${e}/composition`);if(!s.containers?.length)throw new Error(`No containers found for CVM '${e}'`);let o=s.containers;if(t&&(o=o.filter(i=>i.names.some(m=>m===t||m===`/${t}`)?!0:n?i.id.startsWith(t):!1),!o.length))throw new Error(`Container '${t}' not found in CVM '${e}'`);let a=o.find(i=>i.log_endpoint);if(!a?.log_endpoint)throw new Error(`No log endpoints available for CVM '${e}'`);return a.log_endpoint}async function xg(e,t={}){let n=await os(e),r=ze(n,t),s=await fetch(r);if(!s.ok)throw new Error(`Failed to fetch serial logs: ${s.status} ${s.statusText}`);return s.text()}async function Rg(e,t={}){let n=await jt(e,t.container,t.matchContainerIdPrefix??!0),r=t.text??!0,s=t.bare??!0,o=ze(n,{...t,text:r,bare:s}),a=await fetch(o);if(!a.ok)throw new Error(`Failed to fetch container logs: ${a.status} ${a.statusText}`);let i=await a.text();return i.trimStart().startsWith("{")?Ou(i):i}async function Tg(e,t={}){let n=await jt(e,t.container,t.matchContainerIdPrefix??!0),r=ze(n,{...t,text:!1,bare:!1}),s=await fetch(r);if(!s.ok)throw new Error(`Failed to fetch container logs: ${s.status} ${s.statusText}`);let o=await s.text();return o.trimStart().startsWith("{")?ju(o):[{channel:"stdout",message:o}]}async function Pg(e,t,n={},r){let s=await jt(e,n.container,n.matchContainerIdPrefix??!0),o=ze(s,{...n,follow:!0,text:!1,bare:!1}),a=await fetch(o,{signal:r});if(!a.ok)throw new Error(`Failed to stream container logs: ${a.status} ${a.statusText}`);await Lu(a,t)}async function jg(e,t,n={},r){let s=await os(e),o=ze(s,{...n,follow:!0}),a=await fetch(o,{signal:r});if(!a.ok)throw new Error(`Failed to stream serial logs: ${a.status} ${a.statusText}`);await ss(a,t)}async function Og(e,t,n={},r){let s=await jt(e,n.container,n.matchContainerIdPrefix??!0),o=n.text??!0,a=n.bare??!0,i=ze(s,{...n,follow:!0,text:o,bare:a}),l=await fetch(i,{signal:r});if(!l.ok)throw new Error(`Failed to stream container logs: ${l.status} ${l.statusText}`);await $u(l,t)}async function $g(e,t,n={}){let r=await an(e,t),s=ze(r,n),o=await fetch(s);if(!o.ok)throw new Error(`Failed to fetch CVM ${t} logs: ${o.status} ${o.statusText}`);return o.text()}async function Lg(e,t,n,r={},s){let o=await an(e,t),a=ze(o,{...r,follow:!0}),i=await fetch(a,{signal:s});if(!i.ok)throw new Error(`Failed to stream CVM ${t} logs: ${i.status} ${i.statusText}`);await ss(i,n)}async function Ng(e){let t=await pe(),n=e.replace(/^app_/,""),r=await Rt(t,{app_id:n});if(!r.success)throw new Error(r.error.message);return r.data.status}export{lg as composeFileSchema,Eg as createCvm,rs as cvmAttestationResponseSchema,Iu as dockerConfigSchema,ug as encryptedEnvItemSchema,Rg as fetchContainerLogs,Tg as fetchContainerLogsEntries,$g as fetchCvmChannelLogs,xg as fetchSerialLogs,wg as getCvmAttestation,vg as getCvmByAppId,an as getCvmLogEndpoint,yg as getCvmNetwork,ts as getCvmNetworkResponseSchema,Ng as getCvmStatus,Sg as getPubkeyFromCvm,Ig as getTeepods,xu as imageSchema,es as postCvmResponseSchema,Cg as replicateCvm,ns as replicateCvmResponseSchema,kg as resizeCvm,_g as selectCvm,Og as streamContainerLogs,Pg as streamContainerLogsEntries,Lg as streamCvmChannelLogs,jg as streamSerialLogs,pg as teepodSchema,Ag as upgradeCvm};
44
- /*! Bundled license information:
45
-
46
- @noble/hashes/utils.js:
47
- (*! noble-hashes - MIT License (c) 2022 Paul Miller (paulmillr.com) *)
48
- */
35
+ ${n}`)}throw new Error(`Failed to parse ${Lt}: ${t instanceof Error?t.message:String(t)}`)}}function hr(){return ll()?ul():{}}import br from"fs";import pl from"os";import yr from"path";var vr="https://cloud-api.phala.com/api/v1";function ml(){let e=process.env.PHALA_CLOUD_DIR;return typeof e=="string"&&e.trim().length>0?e:yr.join(pl.homedir(),".phala-cloud")}function dl(){return yr.join(ml(),"credentials.json")}function bt(e){return typeof e=="string"&&e.trim().length>0}function fl(e){let t=e.trim();return t.length===0?"default":t}function gl(){try{let e=dl();if(!br.existsSync(e))return null;let t=br.readFileSync(e,"utf8"),n=JSON.parse(t);if(!n||typeof n!="object")return null;let r=n;return r.schema_version!==1||!bt(r.current_profile)||!r.profiles||typeof r.profiles!="object"?null:r}catch(e){return je.error("Failed to read credentials file:",e),null}}function _r(e){let t=gl(),n=fl(e.profile||e.projectProfile||t?.current_profile||"default"),r=n;if(t&&!t.profiles[r]){let f=Object.entries(t.profiles).find(([,m])=>m?.workspace?.slug===n);if(f)r=f[0];else{let m=Object.entries(t.profiles).find(([,d])=>d?.workspace?.name===n);m&&(r=m[0])}}let s=e.env.PHALA_CLOUD_API_PREFIX,o=t?.profiles?.[r]?.api_prefix,c=(s&&s.trim().length>0?s:o&&o.trim().length>0?o:vr)??vr,i=s?"env":o?"file":"default";if(bt(e.apiToken))return{apiKey:e.apiToken,baseURL:c,profileName:r,tokenSource:"flag",apiPrefixSource:i};if(bt(e.env.PHALA_CLOUD_API_KEY))return{apiKey:e.env.PHALA_CLOUD_API_KEY,baseURL:c,profileName:r,tokenSource:"env",apiPrefixSource:i};let u=t?.profiles?.[r]?.token;return bt(u)?{apiKey:u,baseURL:c,profileName:r,tokenSource:"file",apiPrefixSource:i}:{apiKey:null,baseURL:c,profileName:r,tokenSource:"none",apiPrefixSource:i}}var hl="2026-05-22",bl=60;function vl(e){return e?.globalOptions?.timeout??bl}function yl(){return{env:process.env,projectConfig:hr()}}function _l(e,t){let n=e??yl();return _r({env:n.env,apiToken:t?.apiToken??n.globalOptions?.apiToken,profile:t?.profile??n.globalOptions?.profile,projectProfile:n.projectConfig.profile})}async function oe(e,t){let n=_l(e,t),r=dr()??hl,s=vl(e);return nr({apiKey:n.apiKey??void 0,baseURL:n.baseURL,version:r,timeout:s*1e3})}import{z as a}from"zod";var wl=a.object({password:a.string(),registry:a.string().nullable(),username:a.string()}),_f=a.object({docker_compose_file:a.string(),docker_config:wl.optional().nullable(),features:a.array(a.string()),kms_enabled:a.boolean(),manifest_version:a.number(),name:a.string(),public_logs:a.boolean(),public_sysinfo:a.boolean(),runner:a.string().optional(),salt:a.string().nullable().optional(),tproxy_enabled:a.boolean(),version:a.string().optional()}).passthrough(),wr=a.object({id:a.string(),name:a.string(),status:a.string(),teepod_id:a.number().nullable(),teepod:a.object({id:a.number(),name:a.string()}).nullable(),user_id:a.string().nullable(),app_id:a.string(),vm_uuid:a.string().nullable(),instance_id:a.string().nullable(),app_url:a.string().nullable(),base_image:a.string().nullable(),vcpu:a.number(),memory:a.number(),disk_size:a.number(),manifest_version:a.number().nullable(),version:a.string().nullable(),runner:a.string().nullable(),docker_compose_file:a.string().nullable(),features:a.array(a.string()).nullable(),created_at:a.string(),encrypted_env_pubkey:a.string().nullable()}),wf=a.object({key:a.string(),value:a.string()}),Cr=a.object({is_online:a.boolean(),is_public:a.boolean(),error:a.string().nullable(),internal_ip:a.string(),latest_handshake:a.string(),public_urls:a.array(a.object({app:a.string(),instance:a.string()}))}),Sr=a.object({id:a.string(),name:a.string(),status:a.string(),teepod_id:a.number(),teepod:a.object({id:a.number(),name:a.string()}),user_id:a.string().nullable().optional(),app_id:a.string(),vm_uuid:a.string().nullable().optional(),instance_id:a.string().nullable().optional(),app_url:a.string().nullable().optional(),base_image:a.string().nullable().optional(),vcpu:a.number(),memory:a.number(),disk_size:a.number(),manifest_version:a.number().nullable().optional(),version:a.string().nullable().optional(),runner:a.string().nullable().optional(),docker_compose_file:a.string().nullable().optional(),features:a.array(a.string()).nullable().optional(),created_at:a.string(),encrypted_env_pubkey:a.string().nullable().optional()}),kr=a.object({is_online:a.boolean(),is_public:a.boolean(),error:a.string().nullable(),app_certificates:a.array(a.object({subject:a.object({common_name:a.string().nullable(),organization:a.string().nullable(),country:a.string().nullable(),state:a.string().nullable().optional(),locality:a.string().nullable().optional()}),issuer:a.object({common_name:a.string().nullable(),organization:a.string().nullable(),country:a.string().nullable()}),serial_number:a.string(),not_before:a.string(),not_after:a.string(),version:a.string(),fingerprint:a.string(),signature_algorithm:a.string(),sans:a.string().nullable(),is_ca:a.boolean(),position_in_chain:a.number(),quote:a.string().nullable()})).nullable(),tcb_info:a.object({mrtd:a.string(),rootfs_hash:a.string(),rtmr0:a.string(),rtmr1:a.string(),rtmr2:a.string(),rtmr3:a.string(),event_log:a.array(a.object({imr:a.number(),event_type:a.number(),digest:a.string(),event:a.string(),event_payload:a.string()}))}).nullable(),compose_file:a.string().nullable()}),Cl=a.object({name:a.string(),description:a.string().optional(),version:a.array(a.number()).optional(),is_dev:a.boolean().optional(),os_image_hash:a.string().nullable().optional(),rootfs_hash:a.string().optional(),shared_ro:a.boolean().optional(),cmdline:a.string().optional(),kernel:a.string().optional(),initrd:a.string().optional(),hda:a.string().nullable().optional(),rootfs:a.string().optional(),bios:a.string().optional()}),Cf=a.object({teepod_id:a.number().nullable(),id:a.number().optional(),name:a.string(),listed:a.boolean().optional(),resource_score:a.number().optional(),remaining_vcpu:a.number().optional(),remaining_memory:a.number().optional(),remaining_cvm_slots:a.number().optional(),images:a.array(Cl).optional(),region_identifier:a.string().optional(),dedicated_for_team_id:a.number().nullable().optional(),support_onchain_kms:a.boolean().optional(),fmspc:a.string().nullable().optional(),device_id:a.string().nullable().optional()});import Sl from"inquirer";async function xf(e){let t=await oe(),n=e.replace(/^app_/,""),r=await gt(t,{app_id:n});if(!r.success)throw new Error(r.error.message);return r.data}async function Tf(e){let t=await oe(),n=e.replace(/^app_/,""),r=await t.get(`cvms/app_${n}/network`);return Cr.parse(r)}async function Pf(){let e=je.startSpinner("Fetching available CVMs"),t=await oe(),n=await $t(t);if(e.stop(!0),!n.success){je.error(`Failed to fetch CVMs: ${n.error.message}`);return}let{items:r}=n.data;if(r.length===0){je.info("No CVMs found for your account");return}let s=r.map(c=>({name:`${c.name} (${c.app_id??c.id}) - ${c.status}`,value:c.app_id??c.id})),{selectedCvm:o}=await Sl.prompt([{type:"list",name:"selectedCvm",message:"Select a CVM:",choices:s}]);return o}async function jf(e){let t=await oe(),n=e.replace(/^app_/,""),r=await t.get(`cvms/app_${n}/attestation`);try{return kr.parse(r)}catch(s){return je.debug(`Validation error: ${s instanceof Error?s.message:String(s)}`),{is_online:!!r?.is_online,is_public:!!r?.is_public,error:typeof r?.error=="string"?r.error:null,app_certificates:Array.isArray(r?.app_certificates)?r.app_certificates:null,tcb_info:r?.tcb_info||null,compose_file:typeof r?.compose_file=="string"?r.compose_file:null}}}async function $f(e,t,n){let r=await oe(),s=e.replace(/^app_/,""),o=await r.post(`apps/${s}/cvms/${t}/replicas`,n);return Sr.parse(o)}async function qf(e,t,n,r,s){let o=await oe(),c=e.replace(/^app_/,""),i={};if(t!==void 0&&(i.vcpu=t),n!==void 0&&(i.memory=n),r!==void 0&&(i.disk_size=r),s!==void 0&&(i.allow_restart=s),Object.keys(i).length===0)throw new Error("At least one resource parameter must be provided");return await o.patch(`cvms/app_${c}/resources`,i),!0}async function Of(e){return await(await oe()).post("cvms/pubkey/from_cvm_configuration",e)}async function Nf(e){let n=await(await oe()).post("cvms/from_cvm_configuration",e);return wr.parse(n)}async function zf(e,t){let n=await oe(),r=e.replace(/^app_/,"");return await n.put(`cvms/app_${r}/compose`,t)}async function Ff(e=!1){let t=await oe(),n="teepods/available";return e&&(n+="?v03x_only=1"),await t.get(n)}async function Uf(){return await(await oe()).get("teepods/cvm-create-resources")}function $e(e,t){let n=[];t.since&&n.push(`since=${encodeURIComponent(t.since)}`),t.until&&n.push(`until=${encodeURIComponent(t.until)}`),t.follow&&n.push("follow"),t.text&&n.push("text"),t.bare&&n.push("bare"),t.tail!==void 0&&(n.push(`tail=${t.tail}`),n.push(`lines=${t.tail}`)),t.timestamps&&n.push("timestamps"),(t.ansi??!0)&&n.push("ansi");let r=e.includes("?")?"&":"?";return e+r+n.join("&")}async function Er(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder;for(;;){let{done:s,value:o}=await n.read();if(s)break;t(r.decode(o,{stream:!0}))}}function kl(e){return!e||/\s/.test(e)||e.length%4!==0?!1:/^[A-Za-z0-9+/]+={0,2}$/.test(e)}function El(e){if(!kl(e))return e;try{return Buffer.from(e,"base64").toString("utf-8")}catch{return e}}function vt(e){let t=e.trim();if(!t)return null;try{let n=JSON.parse(t);return typeof n.message!="string"?null:{channel:n.channel==="stderr"?"stderr":"stdout",message:El(n.message)}}catch{return null}}function Al(e){let t=e.split(/\r?\n/),n=[];for(let r of t){if(!r.trim())continue;let s=vt(r);if(s){n.push(s);continue}n.push({channel:"stdout",message:`${r}
36
+ `})}return n}function Il(e){let t=e.split(/\r?\n/),n="";for(let r of t){let s=vt(r);if(s){n+=s.message;continue}r.trim()&&(n+=`${r}
37
+ `)}return n}async function Rl(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder,s="",o="unknown",c=i=>{let u=vt(i);if(u){t(u.message);return}i.trim()&&t(`${i}
38
+ `)};for(;;){let{done:i,value:u}=await n.read();if(i)break;let f=r.decode(u,{stream:!0});if(o==="raw"){t(f);continue}if(s+=f,o==="unknown")if(s.trimStart().startsWith("{"))o="structured";else{o="raw",t(s),s="";continue}let m=s.indexOf(`
39
+ `);for(;m>=0;){let d=s.slice(0,m);s=s.slice(m+1),c(d),m=s.indexOf(`
40
+ `)}}o==="structured"&&s.trim()?c(s):o==="raw"&&s&&t(s)}async function xl(e,t){let n=e.body?.getReader();if(!n)throw new Error("No response body available for streaming");let r=new TextDecoder,s="",o="unknown",c=i=>{let u=vt(i);if(u){t(u);return}i.trim()&&t({channel:"stdout",message:`${i}
41
+ `})};for(;;){let{done:i,value:u}=await n.read();if(i)break;let f=r.decode(u,{stream:!0});if(o==="raw"){t({channel:"stdout",message:f});continue}if(s+=f,o==="unknown")if(s.trimStart().startsWith("{"))o="structured";else{o="raw",t({channel:"stdout",message:s}),s="";continue}let m=s.indexOf(`
42
+ `);for(;m>=0;){let d=s.slice(0,m);s=s.slice(m+1),c(d),m=s.indexOf(`
43
+ `)}}o==="structured"&&s.trim()?c(s):o==="raw"&&s&&t({channel:"stdout",message:s})}async function Dt(e,t){let r=await(await oe()).get(`cvms/${e}`,{headers:{"X-Phala-Version":"2025-10-28"}});if(!r.syslog_endpoint)throw new Error(`No syslog endpoint available for CVM '${e}'`);return`${r.syslog_endpoint}&ch=${t}`}async function Ar(e){return Dt(e,"serial")}async function yt(e,t,n=!0){let s=await(await oe()).get(`cvms/${e}/composition`);if(!s.containers?.length)throw new Error(`No containers found for CVM '${e}'`);let o=s.containers;if(t&&(o=o.filter(i=>i.names.some(f=>f===t||f===`/${t}`)?!0:n?i.id.startsWith(t):!1),!o.length))throw new Error(`Container '${t}' not found in CVM '${e}'`);let c=o.find(i=>i.log_endpoint);if(!c?.log_endpoint)throw new Error(`No log endpoints available for CVM '${e}'`);return c.log_endpoint}async function Lf(e,t={}){let n=await Ar(e),r=$e(n,t),s=await fetch(r);if(!s.ok)throw new Error(`Failed to fetch serial logs: ${s.status} ${s.statusText}`);return s.text()}async function Df(e,t={}){let n=await yt(e,t.container,t.matchContainerIdPrefix??!0),r=t.text??!0,s=t.bare??!0,o=$e(n,{...t,text:r,bare:s}),c=await fetch(o);if(!c.ok)throw new Error(`Failed to fetch container logs: ${c.status} ${c.statusText}`);let i=await c.text();return i.trimStart().startsWith("{")?Il(i):i}async function Vf(e,t={}){let n=await yt(e,t.container,t.matchContainerIdPrefix??!0),r=$e(n,{...t,text:!1,bare:!1}),s=await fetch(r);if(!s.ok)throw new Error(`Failed to fetch container logs: ${s.status} ${s.statusText}`);let o=await s.text();return o.trimStart().startsWith("{")?Al(o):[{channel:"stdout",message:o}]}async function Mf(e,t,n={},r){let s=await yt(e,n.container,n.matchContainerIdPrefix??!0),o=$e(s,{...n,follow:!0,text:!1,bare:!1}),c=await fetch(o,{signal:r});if(!c.ok)throw new Error(`Failed to stream container logs: ${c.status} ${c.statusText}`);await xl(c,t)}async function Kf(e,t,n={},r){let s=await Ar(e),o=$e(s,{...n,follow:!0}),c=await fetch(o,{signal:r});if(!c.ok)throw new Error(`Failed to stream serial logs: ${c.status} ${c.statusText}`);await Er(c,t)}async function Hf(e,t,n={},r){let s=await yt(e,n.container,n.matchContainerIdPrefix??!0),o=n.text??!0,c=n.bare??!0,i=$e(s,{...n,follow:!0,text:o,bare:c}),u=await fetch(i,{signal:r});if(!u.ok)throw new Error(`Failed to stream container logs: ${u.status} ${u.statusText}`);await Rl(u,t)}async function Gf(e,t,n={}){let r=await Dt(e,t),s=$e(r,n),o=await fetch(s);if(!o.ok)throw new Error(`Failed to fetch CVM ${t} logs: ${o.status} ${o.statusText}`);return o.text()}async function Bf(e,t,n,r={},s){let o=await Dt(e,t),c=$e(o,{...r,follow:!0}),i=await fetch(c,{signal:s});if(!i.ok)throw new Error(`Failed to stream CVM ${t} logs: ${i.status} ${i.statusText}`);await Er(i,n)}async function Wf(e){let t=await oe(),n=e.replace(/^app_/,""),r=await gt(t,{app_id:n});if(!r.success)throw new Error(r.error.message);return r.data.status}export{_f as composeFileSchema,Nf as createCvm,kr as cvmAttestationResponseSchema,wl as dockerConfigSchema,wf as encryptedEnvItemSchema,Df as fetchContainerLogs,Vf as fetchContainerLogsEntries,Gf as fetchCvmChannelLogs,Lf as fetchSerialLogs,jf as getCvmAttestation,xf as getCvmByAppId,Uf as getCvmCreateResources,Dt as getCvmLogEndpoint,Tf as getCvmNetwork,Cr as getCvmNetworkResponseSchema,Wf as getCvmStatus,Of as getPubkeyFromCvm,Ff as getTeepods,Cl as imageSchema,wr as postCvmResponseSchema,$f as replicateCvm,Sr as replicateCvmResponseSchema,qf as resizeCvm,Pf as selectCvm,Hf as streamContainerLogs,Mf as streamContainerLogsEntries,Bf as streamCvmChannelLogs,Kf as streamSerialLogs,Cf as teepodSchema,zf as upgradeCvm};
49
44
  //# sourceMappingURL=index.js.map