@dcl/marketplace-site 8.6.1 → 8.6.2-21763626081.commit-e07ffa9
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/assets/{ConstantsUtil-0uePVKyp.js → ConstantsUtil-Cw5uH-i5.js} +1 -1
- package/assets/{ExchangeController-DqQsAVzx.js → ExchangeController-B8g6pRfS.js} +1 -1
- package/assets/{HelpersUtil-DFkbhaRg.js → HelpersUtil-DNBPWmHy.js} +1 -1
- package/assets/{NetworkUtil-DFkzwIPL.js → NetworkUtil-3SIrikOw.js} +1 -1
- package/assets/{SwapController-CNffpgsM.js → SwapController-BGRlDmCA.js} +1 -1
- package/assets/{ccip-CFTnAxWV.js → ccip-Df4LKgZK.js} +1 -1
- package/assets/{data-capture-DPJniIza.js → data-capture-C6QaYSs8.js} +1 -1
- package/assets/{email-CV99yGtH.js → email-BG_i___x.js} +1 -1
- package/assets/{embedded-wallet-BRmiIOUa.js → embedded-wallet-CG7TbOV-.js} +1 -1
- package/assets/{features-DZkQn-RB.js → features-BbA7J1KA.js} +1 -1
- package/assets/{fortmatic-Bo5KzcBD.js → fortmatic-Bz0QEpcS.js} +1 -1
- package/assets/{if-defined-CIrb8Dm-.js → if-defined-Dr097eDH.js} +1 -1
- package/assets/{index-CHuiuTQy.js → index--0UsZF9G.js} +5 -5
- package/assets/{index-ijwspMD9.js → index-3gO2YMOL.js} +1 -1
- package/assets/{index-Dj0QTdt3.js → index-4tzrFolB.js} +1 -1
- package/assets/{index-CJ9JjBbk.js → index-B-U3jRM1.js} +1 -1
- package/assets/{index-CtevShQo.js → index-B3_NJasS.js} +1 -1
- package/assets/{index-BUlRwq2o.js → index-B5TtbbC5.js} +1 -1
- package/assets/{index-BtloeNEV.js → index-BSk3zAXq.js} +1 -1
- package/assets/{index-DT3Iv8i3.js → index-BWv932mQ.js} +1 -1
- package/assets/{index-hJbRNzPd.js → index-BmUGzhOu.js} +1 -1
- package/assets/{index-CoDOM4BJ.js → index-BrS7G6Pb.js} +1 -1
- package/assets/{index-k3NmmIEH.js → index-Bv-MB-53.js} +1 -1
- package/assets/{index-Ba8VNpw-.js → index-C4Iw9Gtu.js} +1 -1
- package/assets/{index-BFABKBJ2.css → index-C7O9dqJ5.css} +4 -4
- package/assets/{index-Dv60edNb.js → index-C8dGzvIM.js} +1 -1
- package/assets/{index-D-L7ozfm.js → index-CBk7djGV.js} +1 -1
- package/assets/{index-DFkNML2i.js → index-CHE56tT6.js} +1 -1
- package/assets/{index-JzUBYnfx.js → index-CP_uj5Ou.js} +1 -1
- package/assets/{index-8ejL2aqn.js → index-CTejii_3.js} +1 -1
- package/assets/{index-CQqxfHPW.js → index-ChZ5AYqd.js} +1 -1
- package/assets/{index-Bk_97mZS.js → index-ClmwewVJ.js} +1 -1
- package/assets/{index-6PFA9My_.js → index-Cwe7emK5.js} +1 -1
- package/assets/{index-C3858rWU.js → index-CyeE4RgJ.js} +1 -1
- package/assets/{index-CruU_JWG.js → index-D3Kjyb0X.js} +1 -1
- package/assets/{index-CMaNpe07.js → index-D7KzIusu.js} +1 -1
- package/assets/{index-DUUFr82u.js → index-DFYCage7.js} +1 -1
- package/assets/{index-DjaTizzB.js → index-DMLVtHMI.js} +1 -1
- package/assets/{index-CM2Bsju7.js → index-DMuYTl5Z.js} +1 -1
- package/assets/{index-BkXJUMdv.js → index-DTzL6GLY.js} +1 -1
- package/assets/{index-DseC2rjG.js → index-DYpsaqOT.js} +1 -1
- package/assets/{index-r-2ydifG.js → index-DeGBgVeI.js} +1 -1
- package/assets/{index-CWln8DL3.js → index-DlVZs1oU.js} +1 -1
- package/assets/{index-Dn_xp_Lo.js → index-DxbiZFrZ.js} +1 -1
- package/assets/{index-Dtmzfbas.js → index-HR0EdyCk.js} +1 -1
- package/assets/{index-BUuapyWi.js → index-HWZ6yYA8.js} +1 -1
- package/assets/{index-B2dkLiRb.js → index-uPtowLYG.js} +1 -1
- package/assets/{index-BVb7vkdp.js → index-xGFXY5RX.js} +12 -12
- package/assets/{index-8wkY0Jb7.js → index-yx1vikfy.js} +1 -1
- package/assets/{index-1O0Ay-sy.js → index-zk_kM3aZ.js} +1 -1
- package/assets/{networks-D_xu1zad.js → networks-DDtnXuR-.js} +1 -1
- package/assets/{onramp-CWeX_eyk.js → onramp-BUHkZqza.js} +1 -1
- package/assets/{pay-with-exchange-Cc8oS6gA.js → pay-with-exchange-sBe4iQtb.js} +1 -1
- package/assets/{receive-CADcxERz.js → receive-CcTr-1Qk.js} +1 -1
- package/assets/{ref-BW5bCcd7.js → ref-CPwoUAPs.js} +1 -1
- package/assets/{secp256k1-DOJZC1KX.js → secp256k1-yAhP4Cup.js} +1 -1
- package/assets/{send-CudJE3ga.js → send-lCTQJ_pv.js} +1 -1
- package/assets/{socials-QLyEk6zh.js → socials-Dc6QGKNd.js} +1 -1
- package/assets/{swaps-DLZEIO9U.js → swaps-11Cmmiib.js} +1 -1
- package/assets/{transactions-of0GeMXR.js → transactions-DFf4sRIF.js} +1 -1
- package/assets/{verifyHash-CKXJQLWy.js → verifyHash-CWmIX1-Z.js} +3 -3
- package/assets/{w3m-modal-DP8Arf0z.js → w3m-modal-DrW1uZDo.js} +1 -1
- package/index.html +6 -5
- package/package.json +3 -3
|
@@ -1,7 +1,7 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/index-
|
|
2
|
-
import{b as En,n as vy,g as Cy,s as Gi,_ as Dt,o as Lo,p as Ca,q as _y,u as Ay,v as Sy,w as Iy,x as Ny,y as iu,I as fi,z as Ty,A as Cs,B as Qt,C as Z,D as An,E as Ry,F as Oy,G as Ue,J as Mi,K as El,L as Py,M as xy,N as ky,O as xr,P as Uy,Q as zs,R as gi,S as Cd,T as $y,U as _d,V as Ad,W as Yi,X as Sd,Y as ou,Z as Dy,$ as Ly,a0 as fr,a1 as Cf,a2 as cn,a3 as Hs,a4 as Nn,a5 as _f}from"./index-BVb7vkdp.js";import{C as U,L as My,a5 as Mo,m as By,s as la,H as Bi,B as Af,ag as jy,ak as da,W as au,X as cu,Y as lu,af as du,_ as uu,ah as hu,ai as pu,ac as fu,Z as gu,a7 as mu,aj as yu,ae as wu,a2 as Eu,a3 as bl,ad as vl,aa as bu,a9 as vu,I as Cu,$ as Cl,a0 as _u,a4 as Au,a1 as Su,a6 as Iu,V as Nu,E as Fy,aA as qy,R as Wy,aC as Sf,aq as If,p as Bo,aD as Nf,at as Hy,av as zy,aw as Vy,ax as Ky,ay as Gy,as as Yy,t as Tu}from"./NetworkUtil-DFkzwIPL.js";const Tf={isLowerCaseMatch(t,e){return(t==null?void 0:t.toLowerCase())===(e==null?void 0:e.toLowerCase())}};var Zy=20,Jy=1,mi=1e6,Xy=1e6,Qy=-7,ew=21,tw=!1,Co="[big.js] ",kr=Co+"Invalid ",tc=kr+"decimal places",sw=kr+"rounding mode",Rf=Co+"Division by zero",qe={},Zs=void 0,nw=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function Of(){function t(e){var s=this;if(!(s instanceof t))return e===Zs?Of():new t(e);if(e instanceof t)s.s=e.s,s.e=e.e,s.c=e.c.slice();else{if(typeof e!="string"){if(t.strict===!0&&typeof e!="bigint")throw TypeError(kr+"value");e=e===0&&1/e<0?"-0":String(e)}rw(s,e)}s.constructor=t}return t.prototype=qe,t.DP=Zy,t.RM=Jy,t.NE=Qy,t.PE=ew,t.strict=tw,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}function rw(t,e){var s,n,r;if(!nw.test(e))throw Error(kr+"number");for(t.s=e.charAt(0)=="-"?(e=e.slice(1),-1):1,(s=e.indexOf("."))>-1&&(e=e.replace(".","")),(n=e.search(/e/i))>0?(s<0&&(s=n),s+=+e.slice(n+1),e=e.substring(0,n)):s<0&&(s=e.length),r=e.length,n=0;n<r&&e.charAt(n)=="0";)++n;if(n==r)t.c=[t.e=0];else{for(;r>0&&e.charAt(--r)=="0";);for(t.e=s-n-1,t.c=[],s=0;n<=r;)t.c[s++]=+e.charAt(n++)}return t}function Ur(t,e,s,n){var r=t.c;if(s===Zs&&(s=t.constructor.RM),s!==0&&s!==1&&s!==2&&s!==3)throw Error(sw);if(e<1)n=s===3&&(n||!!r[0])||e===0&&(s===1&&r[0]>=5||s===2&&(r[0]>5||r[0]===5&&(n||r[1]!==Zs))),r.length=1,n?(t.e=t.e-e+1,r[0]=1):r[0]=t.e=0;else if(e<r.length){if(n=s===1&&r[e]>=5||s===2&&(r[e]>5||r[e]===5&&(n||r[e+1]!==Zs||r[e-1]&1))||s===3&&(n||!!r[0]),r.length=e,n){for(;++r[--e]>9;)if(r[e]=0,e===0){++t.e,r.unshift(1);break}}for(e=r.length;!r[--e];)r.pop()}return t}function $r(t,e,s){var n=t.e,r=t.c.join(""),i=r.length;if(e)r=r.charAt(0)+(i>1?"."+r.slice(1):"")+(n<0?"e":"e+")+n;else if(n<0){for(;++n;)r="0"+r;r="0."+r}else if(n>0)if(++n>i)for(n-=i;n--;)r+="0";else n<i&&(r=r.slice(0,n)+"."+r.slice(n));else i>1&&(r=r.charAt(0)+"."+r.slice(1));return t.s<0&&s?"-"+r:r}qe.abs=function(){var t=new this.constructor(this);return t.s=1,t};qe.cmp=function(t){var e,s=this,n=s.c,r=(t=new s.constructor(t)).c,i=s.s,o=t.s,a=s.e,c=t.e;if(!n[0]||!r[0])return n[0]?i:r[0]?-o:0;if(i!=o)return i;if(e=i<0,a!=c)return a>c^e?1:-1;for(o=(a=n.length)<(c=r.length)?a:c,i=-1;++i<o;)if(n[i]!=r[i])return n[i]>r[i]^e?1:-1;return a==c?0:a>c^e?1:-1};qe.div=function(t){var e=this,s=e.constructor,n=e.c,r=(t=new s(t)).c,i=e.s==t.s?1:-1,o=s.DP;if(o!==~~o||o<0||o>mi)throw Error(tc);if(!r[0])throw Error(Rf);if(!n[0])return t.s=i,t.c=[t.e=0],t;var a,c,l,d,u,h=r.slice(),p=a=r.length,g=n.length,f=n.slice(0,a),y=f.length,_=t,S=_.c=[],v=0,C=o+(_.e=e.e-t.e)+1;for(_.s=i,i=C<0?0:C,h.unshift(0);y++<a;)f.push(0);do{for(l=0;l<10;l++){if(a!=(y=f.length))d=a>y?1:-1;else for(u=-1,d=0;++u<a;)if(r[u]!=f[u]){d=r[u]>f[u]?1:-1;break}if(d<0){for(c=y==a?r:h;y;){if(f[--y]<c[y]){for(u=y;u&&!f[--u];)f[u]=9;--f[u],f[y]+=10}f[y]-=c[y]}for(;!f[0];)f.shift()}else break}S[v++]=d?l:++l,f[0]&&d?f[y]=n[p]||0:f=[n[p]]}while((p++<g||f[0]!==Zs)&&i--);return!S[0]&&v!=1&&(S.shift(),_.e--,C--),v>C&&Ur(_,C,s.RM,f[0]!==Zs),_};qe.eq=function(t){return this.cmp(t)===0};qe.gt=function(t){return this.cmp(t)>0};qe.gte=function(t){return this.cmp(t)>-1};qe.lt=function(t){return this.cmp(t)<0};qe.lte=function(t){return this.cmp(t)<1};qe.minus=qe.sub=function(t){var e,s,n,r,i=this,o=i.constructor,a=i.s,c=(t=new o(t)).s;if(a!=c)return t.s=-c,i.plus(t);var l=i.c.slice(),d=i.e,u=t.c,h=t.e;if(!l[0]||!u[0])return u[0]?t.s=-c:l[0]?t=new o(i):t.s=1,t;if(a=d-h){for((r=a<0)?(a=-a,n=l):(h=d,n=u),n.reverse(),c=a;c--;)n.push(0);n.reverse()}else for(s=((r=l.length<u.length)?l:u).length,a=c=0;c<s;c++)if(l[c]!=u[c]){r=l[c]<u[c];break}if(r&&(n=l,l=u,u=n,t.s=-t.s),(c=(s=u.length)-(e=l.length))>0)for(;c--;)l[e++]=0;for(c=e;s>a;){if(l[--s]<u[s]){for(e=s;e&&!l[--e];)l[e]=9;--l[e],l[s]+=10}l[s]-=u[s]}for(;l[--c]===0;)l.pop();for(;l[0]===0;)l.shift(),--h;return l[0]||(t.s=1,l=[h=0]),t.c=l,t.e=h,t};qe.mod=function(t){var e,s=this,n=s.constructor,r=s.s,i=(t=new n(t)).s;if(!t.c[0])throw Error(Rf);return s.s=t.s=1,e=t.cmp(s)==1,s.s=r,t.s=i,e?new n(s):(r=n.DP,i=n.RM,n.DP=n.RM=0,s=s.div(t),n.DP=r,n.RM=i,this.minus(s.times(t)))};qe.neg=function(){var t=new this.constructor(this);return t.s=-t.s,t};qe.plus=qe.add=function(t){var e,s,n,r=this,i=r.constructor;if(t=new i(t),r.s!=t.s)return t.s=-t.s,r.minus(t);var o=r.e,a=r.c,c=t.e,l=t.c;if(!a[0]||!l[0])return l[0]||(a[0]?t=new i(r):t.s=r.s),t;if(a=a.slice(),e=o-c){for(e>0?(c=o,n=l):(e=-e,n=a),n.reverse();e--;)n.push(0);n.reverse()}for(a.length-l.length<0&&(n=l,l=a,a=n),e=l.length,s=0;e;a[e]%=10)s=(a[--e]=a[e]+l[e]+s)/10|0;for(s&&(a.unshift(s),++c),e=a.length;a[--e]===0;)a.pop();return t.c=a,t.e=c,t};qe.pow=function(t){var e=this,s=new e.constructor("1"),n=s,r=t<0;if(t!==~~t||t<-1e6||t>Xy)throw Error(kr+"exponent");for(r&&(t=-t);t&1&&(n=n.times(e)),t>>=1,!!t;)e=e.times(e);return r?s.div(n):n};qe.prec=function(t,e){if(t!==~~t||t<1||t>mi)throw Error(kr+"precision");return Ur(new this.constructor(this),t,e)};qe.round=function(t,e){if(t===Zs)t=0;else if(t!==~~t||t<-1e6||t>mi)throw Error(tc);return Ur(new this.constructor(this),t+this.e+1,e)};qe.sqrt=function(){var t,e,s,n=this,r=n.constructor,i=n.s,o=n.e,a=new r("0.5");if(!n.c[0])return new r(n);if(i<0)throw Error(Co+"No square root");i=Math.sqrt(+$r(n,!0,!0)),i===0||i===1/0?(e=n.c.join(""),e.length+o&1||(e+="0"),i=Math.sqrt(e),o=((o+1)/2|0)-(o<0||o&1),t=new r((i==1/0?"5e":(i=i.toExponential()).slice(0,i.indexOf("e")+1))+o)):t=new r(i+""),o=t.e+(r.DP+=4);do s=t,t=a.times(s.plus(n.div(s)));while(s.c.slice(0,o).join("")!==t.c.slice(0,o).join(""));return Ur(t,(r.DP-=4)+t.e+1,r.RM)};qe.times=qe.mul=function(t){var e,s=this,n=s.constructor,r=s.c,i=(t=new n(t)).c,o=r.length,a=i.length,c=s.e,l=t.e;if(t.s=s.s==t.s?1:-1,!r[0]||!i[0])return t.c=[t.e=0],t;for(t.e=c+l,o<a&&(e=r,r=i,i=e,l=o,o=a,a=l),e=new Array(l=o+a);l--;)e[l]=0;for(c=a;c--;){for(a=0,l=o+c;l>c;)a=e[l]+i[c]*r[l-c-1]+a,e[l--]=a%10,a=a/10|0;e[l]=a}for(a?++t.e:e.shift(),c=e.length;!e[--c];)e.pop();return t.c=e,t};qe.toExponential=function(t,e){var s=this,n=s.c[0];if(t!==Zs){if(t!==~~t||t<0||t>mi)throw Error(tc);for(s=Ur(new s.constructor(s),++t,e);s.c.length<t;)s.c.push(0)}return $r(s,!0,!!n)};qe.toFixed=function(t,e){var s=this,n=s.c[0];if(t!==Zs){if(t!==~~t||t<0||t>mi)throw Error(tc);for(s=Ur(new s.constructor(s),t+s.e+1,e),t=t+s.e+1;s.c.length<t;)s.c.push(0)}return $r(s,!1,!!n)};qe[Symbol.for("nodejs.util.inspect.custom")]=qe.toJSON=qe.toString=function(){var t=this,e=t.constructor;return $r(t,t.e<=e.NE||t.e>=e.PE,!!t.c[0])};qe.toNumber=function(){var t=+$r(this,!0,!0);if(this.constructor.strict===!0&&!this.eq(t.toString()))throw Error(Co+"Imprecise conversion");return t};qe.toPrecision=function(t,e){var s=this,n=s.constructor,r=s.c[0];if(t!==Zs){if(t!==~~t||t<1||t>mi)throw Error(kr+"precision");for(s=Ur(new n(s),t,e);s.c.length<t;)s.c.push(0)}return $r(s,t<=s.e||s.e<=n.NE||s.e>=n.PE,!!r)};qe.valueOf=function(){var t=this,e=t.constructor;if(e.strict===!0)throw Error(Co+"valueOf disallowed");return $r(t,t.e<=e.NE||t.e>=e.PE,!0)};var Tn=Of();const iw={bigNumber(t){return t?new Tn(t):new Tn(0)},multiply(t,e){if(t===void 0||e===void 0)return new Tn(0);const s=new Tn(t),n=new Tn(e);return s.times(n)},toFixed(t,e=2){return t===void 0||t===""?new Tn(0).toFixed(e):new Tn(t).toFixed(e)},formatNumberToLocalString(t,e=2){return t===void 0||t===""?"0.00":typeof t=="number"?t.toLocaleString("en-US",{maximumFractionDigits:e,minimumFractionDigits:e,roundingMode:"floor"}):parseFloat(t).toLocaleString("en-US",{maximumFractionDigits:e,minimumFractionDigits:e,roundingMode:"floor"})},parseLocalStringToNumber(t){if(t===void 0||t==="")return 0;const e=t.replace(/,/gu,"");return new Tn(e).toNumber()}},ow=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],aw=[{type:"function",name:"approve",stateMutability:"nonpayable",inputs:[{name:"spender",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]}],cw=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"sender",type:"address"},{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],lw={getERC20Abi:t=>U.USDT_CONTRACT_ADDRESSES.includes(t)?cw:ow,getSwapAbi:()=>aw},Mr={ConnectorExplorerIds:{[U.CONNECTOR_ID.COINBASE]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.COINBASE_SDK]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.BASE_ACCOUNT]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.SAFE]:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",[U.CONNECTOR_ID.LEDGER]:"19177a98252e07ddfc9af2083ba8e07ef627cb6103467ffebb3f8f4205fd7927",[U.CONNECTOR_ID.OKX]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[U.METMASK_CONNECTOR_NAME]:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",[U.TRUST_CONNECTOR_NAME]:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",[U.SOLFLARE_CONNECTOR_NAME]:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",[U.PHANTOM_CONNECTOR_NAME]:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",[U.COIN98_CONNECTOR_NAME]:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",[U.MAGIC_EDEN_CONNECTOR_NAME]:"8b830a2b724a9c3fbab63af6f55ed29c9dfa8a55e732dc88c80a196a2ba136c6",[U.BACKPACK_CONNECTOR_NAME]:"2bd8c14e035c2d48f184aaa168559e86b0e3433228d3c4075900a221785019b0",[U.BITGET_CONNECTOR_NAME]:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",[U.FRONTIER_CONNECTOR_NAME]:"85db431492aa2e8672e93f4ea7acf10c88b97b867b0d373107af63dc4880f041",[U.XVERSE_CONNECTOR_NAME]:"2a87d74ae02e10bdd1f51f7ce6c4e1cc53cd5f2c0b6b5ad0d7b3007d2b13de7b",[U.LEATHER_CONNECTOR_NAME]:"483afe1df1df63daf313109971ff3ef8356ddf1cc4e45877d205eee0b7893a13",[U.OKX_CONNECTOR_NAME]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[U.BINANCE_CONNECTOR_NAME]:"2fafea35bb471d22889ccb49c08d99dd0a18a37982602c33f696a5723934ba25"}},dt={validateCaipAddress(t){var e;if(((e=t.split(":"))==null?void 0:e.length)!==3)throw new Error("Invalid CAIP Address");return t},parseCaipAddress(t){const e=t.split(":");if(e.length!==3)throw new Error(`Invalid CAIP-10 address: ${t}`);const[s,n,r]=e;if(!s||!n||!r)throw new Error(`Invalid CAIP-10 address: ${t}`);return{chainNamespace:s,chainId:n,address:r}},parseCaipNetworkId(t){const e=t.split(":");if(e.length!==2)throw new Error(`Invalid CAIP-2 network id: ${t}`);const[s,n]=e;if(!s||!n)throw new Error(`Invalid CAIP-2 network id: ${t}`);return{chainNamespace:s,chainId:n}}},mn={RPC_ERROR_CODE:{USER_REJECTED_REQUEST:4001,USER_REJECTED_METHODS:5002,USER_REJECTED:5e3},PROVIDER_RPC_ERROR_NAME:{PROVIDER_RPC:"ProviderRpcError",USER_REJECTED_REQUEST:"UserRejectedRequestError"},isRpcProviderError(t){try{if(typeof t=="object"&&t!==null){const e=t,s=typeof e.message=="string",n=typeof e.code=="number";return s&&n}return!1}catch{return!1}},isUserRejectedMessage(t){return t.toLowerCase().includes("user rejected")||t.toLowerCase().includes("user cancelled")||t.toLowerCase().includes("user canceled")},isUserRejectedRequestError(t){if(mn.isRpcProviderError(t)){const e=t.code===mn.RPC_ERROR_CODE.USER_REJECTED_REQUEST,s=t.code===mn.RPC_ERROR_CODE.USER_REJECTED_METHODS;return e||s||mn.isUserRejectedMessage(t.message)}return t instanceof Error?mn.isUserRejectedMessage(t.message):!1}};class dw extends Error{constructor(e,s){super(s.message,{cause:e}),this.name=mn.PROVIDER_RPC_ERROR_NAME.PROVIDER_RPC,this.code=s.code}}class Pf extends dw{constructor(e){super(e,{code:mn.RPC_ERROR_CODE.USER_REJECTED_REQUEST,message:"User rejected the request"}),this.name=mn.PROVIDER_RPC_ERROR_NAME.USER_REJECTED_REQUEST}}const le={WALLET_ID:"@appkit/wallet_id",WALLET_NAME:"@appkit/wallet_name",SOLANA_WALLET:"@appkit/solana_wallet",SOLANA_CAIP_CHAIN:"@appkit/solana_caip_chain",ACTIVE_CAIP_NETWORK_ID:"@appkit/active_caip_network_id",CONNECTED_SOCIAL:"@appkit/connected_social",CONNECTED_SOCIAL_USERNAME:"@appkit-wallet/SOCIAL_USERNAME",RECENT_WALLETS:"@appkit/recent_wallets",RECENT_WALLET:"@appkit/recent_wallet",DEEPLINK_CHOICE:"WALLETCONNECT_DEEPLINK_CHOICE",ACTIVE_NAMESPACE:"@appkit/active_namespace",CONNECTED_NAMESPACES:"@appkit/connected_namespaces",CONNECTION_STATUS:"@appkit/connection_status",SIWX_AUTH_TOKEN:"@appkit/siwx-auth-token",SIWX_NONCE_TOKEN:"@appkit/siwx-nonce-token",TELEGRAM_SOCIAL_PROVIDER:"@appkit/social_provider",NATIVE_BALANCE_CACHE:"@appkit/native_balance_cache",PORTFOLIO_CACHE:"@appkit/portfolio_cache",ENS_CACHE:"@appkit/ens_cache",IDENTITY_CACHE:"@appkit/identity_cache",PREFERRED_ACCOUNT_TYPES:"@appkit/preferred_account_types",CONNECTIONS:"@appkit/connections",DISCONNECTED_CONNECTOR_IDS:"@appkit/disconnected_connector_ids",HISTORY_TRANSACTIONS_CACHE:"@appkit/history_transactions_cache",TOKEN_PRICE_CACHE:"@appkit/token_price_cache",RECENT_EMAILS:"@appkit/recent_emails",LATEST_APPKIT_VERSION:"@appkit/latest_version",TON_WALLETS_CACHE:"@appkit/ton_wallets_cache"};function vc(t){if(!t)throw new Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${t}:connected_connector_id`}const ae={setItem(t,e){xi()&&e!==void 0&&localStorage.setItem(t,e)},getItem(t){if(xi())return localStorage.getItem(t)||void 0},removeItem(t){xi()&&localStorage.removeItem(t)},clear(){xi()&&localStorage.clear()}};function xi(){return typeof window<"u"&&typeof localStorage<"u"}function Zi(t,e){const s=(t==null?void 0:t["--apkt-accent"])??(t==null?void 0:t["--w3m-accent"]);return e==="light"?{"--w3m-accent":s||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":s||"hsla(230, 100%, 67%, 1)","--w3m-background":"#202020"}}const uw=Symbol(),Ru=Object.getPrototypeOf,_l=new WeakMap,hw=t=>t&&(_l.has(t)?_l.get(t):Ru(t)===Object.prototype||Ru(t)===Array.prototype),pw=t=>hw(t)&&t[uw]||null,Ou=(t,e=!0)=>{_l.set(t,e)},_a={},Id=t=>typeof t=="object"&&t!==null,fw=t=>Id(t)&&!_o.has(t)&&(Array.isArray(t)||!(Symbol.iterator in t))&&!(t instanceof WeakMap)&&!(t instanceof WeakSet)&&!(t instanceof Error)&&!(t instanceof Number)&&!(t instanceof Date)&&!(t instanceof String)&&!(t instanceof RegExp)&&!(t instanceof ArrayBuffer)&&!(t instanceof Promise),xf=(t,e)=>{const s=Al.get(t);if((s==null?void 0:s[0])===e)return s[1];const n=Array.isArray(t)?[]:Object.create(Object.getPrototypeOf(t));return Ou(n,!0),Al.set(t,[e,n]),Reflect.ownKeys(t).forEach(r=>{if(Object.getOwnPropertyDescriptor(n,r))return;const i=Reflect.get(t,r),{enumerable:o}=Reflect.getOwnPropertyDescriptor(t,r),a={value:i,enumerable:o,configurable:!0};if(_o.has(i))Ou(i,!1);else if(Yn.has(i)){const[c,l]=Yn.get(i);a.value=xf(c,l())}Object.defineProperty(n,r,a)}),Object.preventExtensions(n)},gw=(t,e,s,n)=>({deleteProperty(r,i){const o=Reflect.get(r,i);s(i);const a=Reflect.deleteProperty(r,i);return a&&n(["delete",[i],o]),a},set(r,i,o,a){const c=!t()&&Reflect.has(r,i),l=Reflect.get(r,i,a);if(c&&(Pu(l,o)||Ji.has(o)&&Pu(l,Ji.get(o))))return!0;s(i),Id(o)&&(o=pw(o)||o);const d=!Yn.has(o)&&yw(o)?Ge(o):o;return e(i,d),Reflect.set(r,i,d,a),n(["set",[i],o,l]),!0}}),Yn=new WeakMap,_o=new WeakSet,Al=new WeakMap,ua=[1],Ji=new WeakMap;let Pu=Object.is,mw=(t,e)=>new Proxy(t,e),yw=fw,ww=xf,Ew=gw;function Ge(t={}){if(!Id(t))throw new Error("object required");const e=Ji.get(t);if(e)return e;let s=ua[0];const n=new Set,r=(y,_=++ua[0])=>{s!==_&&(i=s=_,n.forEach(S=>S(y,_)))};let i=s;const o=(y=ua[0])=>(i!==y&&(i=y,c.forEach(([_])=>{const S=_[1](y);S>s&&(s=S)})),s),a=y=>(_,S)=>{const v=[..._];v[1]=[y,...v[1]],r(v,S)},c=new Map,l=(y,_)=>{const S=!_o.has(_)&&Yn.get(_);if(S){if((_a?"production":void 0)!=="production"&&c.has(y))throw new Error("prop listener already exists");if(n.size){const v=S[2](a(y));c.set(y,[S,v])}else c.set(y,[S])}},d=y=>{var _;const S=c.get(y);S&&(c.delete(y),(_=S[1])==null||_.call(S))},u=y=>(n.add(y),n.size===1&&c.forEach(([S,v],C)=>{if((_a?"production":void 0)!=="production"&&v)throw new Error("remove already exists");const R=S[2](a(C));c.set(C,[S,R])}),()=>{n.delete(y),n.size===0&&c.forEach(([S,v],C)=>{v&&(v(),c.set(C,[S]))})});let h=!0;const p=Ew(()=>h,l,d,r),g=mw(t,p);Ji.set(t,g);const f=[t,o,u];return Yn.set(g,f),Reflect.ownKeys(t).forEach(y=>{const _=Object.getOwnPropertyDescriptor(t,y);"value"in _&&_.writable&&(g[y]=t[y])}),h=!1,g}function _t(t,e,s){const n=Yn.get(t);(_a?"production":void 0)!=="production"&&!n&&console.warn("Please use proxy object");let r;const i=[],o=n[2];let a=!1;const l=o(d=>{i.push(d),r||(r=Promise.resolve().then(()=>{r=void 0,a&&e(i.splice(0))}))});return a=!0,()=>{a=!1,l()}}function Xi(t){const e=Yn.get(t);(_a?"production":void 0)!=="production"&&!e&&console.warn("Please use proxy object");const[s,n]=e;return ww(s,n())}function Qi(t){return _o.add(t),t}function bw(){return{proxyStateMap:Yn,refSet:_o,snapCache:Al,versionHolder:ua,proxyCache:Ji}}function At(t,e,s,n){let r=t[e];return _t(t,()=>{const i=t[e];Object.is(r,i)||s(r=i)})}const{proxyStateMap:vw,snapCache:Cw}=bw(),jo=t=>vw.has(t);function _w(t){const e=[];let s=0;const n=new Map,r=new WeakMap,i=()=>{const l=Cw.get(a),d=l==null?void 0:l[1];if(d&&!r.has(d)){const u=new Map(n);r.set(d,u)}},o=l=>r.get(l)||n,a={data:e,index:s,epoch:0,get size(){return jo(this)||i(),o(this).size},get(l){const u=o(this).get(l);if(u===void 0){this.epoch;return}return this.data[u]},has(l){const d=o(this);return this.epoch,d.has(l)},set(l,d){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");const u=n.get(l);return u===void 0?(n.set(l,this.index),this.data[this.index++]=d):this.data[u]=d,this.epoch++,this},delete(l){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");const d=n.get(l);return d===void 0?!1:(delete this.data[d],n.delete(l),this.epoch++,!0)},clear(){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");this.data.length=0,this.index=0,this.epoch++,n.clear()},forEach(l){this.epoch,o(this).forEach((u,h)=>{l(this.data[u],h,this)})},*entries(){this.epoch;const l=o(this);for(const[d,u]of l)yield[d,this.data[u]]},*keys(){this.epoch;const l=o(this);for(const d of l.keys())yield d},*values(){this.epoch;const l=o(this);for(const d of l.values())yield this.data[d]},[Symbol.iterator](){return this.entries()},get[Symbol.toStringTag](){return"Map"},toJSON(){return new Map(this.entries())}},c=Ge(a);return Object.defineProperties(c,{size:{enumerable:!1},index:{enumerable:!1},epoch:{enumerable:!1},data:{enumerable:!1},toJSON:{enumerable:!1}}),Object.seal(c),c}var xu={};const Cc=(typeof En<"u"&&typeof xu<"u"?xu.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",kf=[{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],Aw="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",Ie={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:Cc,SECURE_SITE_DASHBOARD:`${Cc}/dashboard`,SECURE_SITE_FAVICON:`${Cc}/images/favicon.png`,SOLANA_NATIVE_TOKEN_ADDRESS:"So11111111111111111111111111111111111111111",RESTRICTED_TIMEZONES:["ASIA/SHANGHAI","ASIA/URUMQI","ASIA/CHONGQING","ASIA/HARBIN","ASIA/KASHGAR","ASIA/MACAU","ASIA/HONG_KONG","ASIA/MACAO","ASIA/BEIJING","ASIA/HARBIN"],SWAP_SUGGESTED_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP"],SWAP_POPULAR_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP","METAL","DAI","CHAMP","WOLF","SALE","BAL","BUSD","MUST","BTCpx","ROUTE","HEX","WELT","amDAI","VSQ","VISION","AURUM","pSP","SNX","VC","LINK","CHP","amUSDT","SPHERE","FOX","GIDDY","GFC","OMEN","OX_OLD","DE","WNT"],SUGGESTED_TOKENS_BY_CHAIN:{"eip155:42161":["USD₮0"]},BALANCE_SUPPORTED_CHAINS:[U.CHAIN.EVM,U.CHAIN.SOLANA],SEND_PARAMS_SUPPORTED_CHAINS:[U.CHAIN.EVM],SWAP_SUPPORTED_NETWORKS:["eip155:1","eip155:42161","eip155:10","eip155:324","eip155:8453","eip155:56","eip155:137","eip155:100","eip155:43114","eip155:250","eip155:8217","eip155:1313161554"],NAMES_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM],ONRAMP_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],PAY_WITH_EXCHANGE_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],ACTIVITY_ENABLED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.TON],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x",sui:"0x",stacks:"0x",ton:"0x"},CONVERT_SLIPPAGE_TOLERANCE:1,CONNECT_LABELS:{MOBILE:"Open and continue in the wallet app",WEB:"Open and continue in the wallet app"},SEND_SUPPORTED_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],DEFAULT_REMOTE_FEATURES:{swaps:["1inch"],onramp:["meld"],email:!0,socials:["google","x","discord","farcaster","github","apple","facebook"],activity:!0,reownBranding:!0,multiWallet:!1,emailCapture:!1,payWithExchange:!1,payments:!1,reownAuthentication:!1,headless:!1},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1,emailCapture:!1,reownAuthentication:!1,headless:!1},DEFAULT_FEATURES:{receive:!0,send:!0,emailShowWallets:!0,connectorTypeOrder:["walletConnect","recent","injected","featured","custom","external","recommended"],analytics:!0,allWallets:!0,legalCheckbox:!1,smartSessions:!1,collapseWallets:!1,walletFeaturesOrder:["onramp","swaps","receive","send"],connectMethodsOrder:void 0,pay:!1,reownAuthentication:!1,headless:!1},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa",ton:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"},SIWX_DEFAULTS:{signOutOnDisconnect:!0},MANDATORY_WALLET_IDS_ON_MOBILE:[Mr.ConnectorExplorerIds[U.CONNECTOR_ID.COINBASE],Mr.ConnectorExplorerIds[U.CONNECTOR_ID.COINBASE_SDK],Mr.ConnectorExplorerIds[U.CONNECTOR_ID.BASE_ACCOUNT],Mr.ConnectorExplorerIds[U.SOLFLARE_CONNECTOR_NAME],Mr.ConnectorExplorerIds[U.PHANTOM_CONNECTOR_NAME],Mr.ConnectorExplorerIds[U.BINANCE_CONNECTOR_NAME]],DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"]},F={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5,transactionsHistory:15e3,tokenPrice:15e3,latestAppKitVersion:6048e5,tonWallets:864e5},isCacheExpired(t,e){return Date.now()-t>e},getActiveNetworkProps(){const t=F.getActiveNamespace(),e=F.getActiveCaipNetworkId(),s=e?e.split(":")[1]:void 0,n=s?isNaN(Number(s))?s:Number(s):void 0;return{namespace:t,caipNetworkId:e,chainId:n}},setWalletConnectDeepLink({name:t,href:e}){try{ae.setItem(le.DEEPLINK_CHOICE,JSON.stringify({href:e,name:t}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{const t=ae.getItem(le.DEEPLINK_CHOICE);if(t)return JSON.parse(t)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{ae.removeItem(le.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(t){try{ae.setItem(le.ACTIVE_NAMESPACE,t)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(t){try{ae.setItem(le.ACTIVE_CAIP_NETWORK_ID,t),F.setActiveNamespace(t.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return ae.getItem(le.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{ae.removeItem(le.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(t){try{const e=vc(t);ae.removeItem(e)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(t){try{const e=F.getRecentWallets();e.find(n=>n.id===t.id)||(e.unshift(t),e.length>2&&e.pop(),ae.setItem(le.RECENT_WALLETS,JSON.stringify(e)),ae.setItem(le.RECENT_WALLET,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{const t=ae.getItem(le.RECENT_WALLETS);return t?JSON.parse(t):[]}catch{console.info("Unable to get AppKit recent")}return[]},getRecentWallet(){try{const t=ae.getItem(le.RECENT_WALLET);return t?JSON.parse(t):null}catch{console.info("Unable to get AppKit recent")}return null},deleteRecentWallet(){try{ae.removeItem(le.RECENT_WALLET)}catch{console.info("Unable to delete AppKit recent")}},setConnectedConnectorId(t,e){try{const s=vc(t);ae.setItem(s,e)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return ae.getItem(le.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(t){if(t)try{const e=vc(t);return ae.getItem(e)}catch{console.info("Unable to get connected connector id in namespace",t)}},setConnectedSocialProvider(t){try{ae.setItem(le.CONNECTED_SOCIAL,t)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return ae.getItem(le.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{ae.removeItem(le.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return ae.getItem(le.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){var s;const t=ae.getItem(le.ACTIVE_CAIP_NETWORK_ID);return(s=t==null?void 0:t.split(":"))==null?void 0:s[1]},setConnectionStatus(t){try{ae.setItem(le.CONNECTION_STATUS,t)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return ae.getItem(le.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{const t=ae.getItem(le.CONNECTED_NAMESPACES);return t!=null&&t.length?t.split(","):[]}catch{return[]}},setConnectedNamespaces(t){try{const e=Array.from(new Set(t));ae.setItem(le.CONNECTED_NAMESPACES,e.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(t){try{const e=F.getConnectedNamespaces();e.includes(t)||(e.push(t),F.setConnectedNamespaces(e))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(t){try{const e=F.getConnectedNamespaces(),s=e.indexOf(t);s>-1&&(e.splice(s,1),F.setConnectedNamespaces(e))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return ae.getItem(le.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(t){try{ae.setItem(le.TELEGRAM_SOCIAL_PROVIDER,t)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{ae.removeItem(le.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let t={};try{const e=ae.getItem(le.PORTFOLIO_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromBalanceCache(t){try{const e=F.getBalanceCache();ae.setItem(le.PORTFOLIO_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getBalanceCacheForCaipAddress(t){try{const s=F.getBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.portfolio))return s.balance;F.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateBalanceCache(t){try{const e=F.getBalanceCache();e[t.caipAddress]=t,ae.setItem(le.PORTFOLIO_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getNativeBalanceCache(){let t={};try{const e=ae.getItem(le.NATIVE_BALANCE_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromNativeBalanceCache(t){try{const e=F.getBalanceCache();ae.setItem(le.NATIVE_BALANCE_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getNativeBalanceCacheForCaipAddress(t){try{const s=F.getNativeBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.nativeBalance))return s;console.info("Discarding cache for address",t),F.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateNativeBalanceCache(t){try{const e=F.getNativeBalanceCache();e[t.caipAddress]=t,ae.setItem(le.NATIVE_BALANCE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getEnsCache(){let t={};try{const e=ae.getItem(le.ENS_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get ens name cache")}return t},getEnsFromCacheForAddress(t){try{const s=F.getEnsCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.ens))return s.ens;F.removeEnsFromCache(t)}catch{console.info("Unable to get ens name from cache",t)}},updateEnsCache(t){try{const e=F.getEnsCache();e[t.address]=t,ae.setItem(le.ENS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ens name cache",t)}},removeEnsFromCache(t){try{const e=F.getEnsCache();ae.setItem(le.ENS_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove ens name from cache",t)}},getIdentityCache(){let t={};try{const e=ae.getItem(le.IDENTITY_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get identity cache")}return t},getIdentityFromCacheForAddress(t){try{const s=F.getIdentityCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.identity))return s.identity;F.removeIdentityFromCache(t)}catch{console.info("Unable to get identity from cache",t)}},updateIdentityCache(t){try{const e=F.getIdentityCache();e[t.address]={identity:t.identity,timestamp:t.timestamp},ae.setItem(le.IDENTITY_CACHE,JSON.stringify(e))}catch{console.info("Unable to update identity cache",t)}},removeIdentityFromCache(t){try{const e=F.getIdentityCache();ae.setItem(le.IDENTITY_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove identity from cache",t)}},getTonWalletsCache(){try{const t=ae.getItem(le.TON_WALLETS_CACHE),e=t?JSON.parse(t):void 0;if(e&&!this.isCacheExpired(e.timestamp,this.cacheExpiry.tonWallets))return e;F.removeTonWalletsCache()}catch{console.info("Unable to get ton wallets cache")}},updateTonWalletsCache(t){try{const e=F.getTonWalletsCache()||{timestamp:0,wallets:[]};e.timestamp=new Date().getTime(),e.wallets=t,ae.setItem(le.TON_WALLETS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ton wallets cache",t)}},removeTonWalletsCache(){try{ae.removeItem(le.TON_WALLETS_CACHE)}catch{console.info("Unable to remove ton wallets cache")}},clearAddressCache(){try{ae.removeItem(le.PORTFOLIO_CACHE),ae.removeItem(le.NATIVE_BALANCE_CACHE),ae.removeItem(le.ENS_CACHE),ae.removeItem(le.IDENTITY_CACHE),ae.removeItem(le.HISTORY_TRANSACTIONS_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(t){try{ae.setItem(le.PREFERRED_ACCOUNT_TYPES,JSON.stringify(t))}catch{console.info("Unable to set preferred account types",t)}},getPreferredAccountTypes(){try{const t=ae.getItem(le.PREFERRED_ACCOUNT_TYPES);return t?JSON.parse(t):{}}catch{console.info("Unable to get preferred account types")}return{}},setConnections(t,e){try{const s=F.getConnections(),n=s[e]??[],r=new Map;for(const o of n)r.set(o.connectorId,{...o});for(const o of t){const a=r.get(o.connectorId),c=o.connectorId===U.CONNECTOR_ID.AUTH;if(a&&!c){const l=new Set(a.accounts.map(u=>u.address.toLowerCase())),d=o.accounts.filter(u=>!l.has(u.address.toLowerCase()));a.accounts.push(...d)}else r.set(o.connectorId,{...o})}const i={...s,[e]:Array.from(r.values())};ae.setItem(le.CONNECTIONS,JSON.stringify(i))}catch(s){console.error("Unable to sync connections to storage",s)}},getConnections(){try{const t=ae.getItem(le.CONNECTIONS);return t?JSON.parse(t):{}}catch(t){return console.error("Unable to get connections from storage",t),{}}},deleteAddressFromConnection({connectorId:t,address:e,namespace:s}){try{const n=F.getConnections(),r=n[s]??[],i=new Map(r.map(a=>[a.connectorId,a])),o=i.get(t);o&&(o.accounts.filter(c=>c.address.toLowerCase()!==e.toLowerCase()).length===0?i.delete(t):i.set(t,{...o,accounts:o.accounts.filter(c=>c.address.toLowerCase()!==e.toLowerCase())})),ae.setItem(le.CONNECTIONS,JSON.stringify({...n,[s]:Array.from(i.values())}))}catch{console.error(`Unable to remove address "${e}" from connector "${t}" in namespace "${s}"`)}},getDisconnectedConnectorIds(){try{const t=ae.getItem(le.DISCONNECTED_CONNECTOR_IDS);return t?JSON.parse(t):{}}catch{console.info("Unable to get disconnected connector ids")}return{}},addDisconnectedConnectorId(t,e){try{const s=F.getDisconnectedConnectorIds(),n=s[e]??[];n.push(t),ae.setItem(le.DISCONNECTED_CONNECTOR_IDS,JSON.stringify({...s,[e]:Array.from(new Set(n))}))}catch{console.error(`Unable to set disconnected connector id "${t}" for namespace "${e}"`)}},removeDisconnectedConnectorId(t,e){try{const s=F.getDisconnectedConnectorIds();let n=s[e]??[];n=n.filter(r=>r.toLowerCase()!==t.toLowerCase()),ae.setItem(le.DISCONNECTED_CONNECTOR_IDS,JSON.stringify({...s,[e]:Array.from(new Set(n))}))}catch{console.error(`Unable to remove disconnected connector id "${t}" for namespace "${e}"`)}},isConnectorDisconnected(t,e){try{return(F.getDisconnectedConnectorIds()[e]??[]).some(r=>r.toLowerCase()===t.toLowerCase())}catch{console.info(`Unable to get disconnected connector id "${t}" for namespace "${e}"`)}return!1},getTransactionsCache(){try{const t=ae.getItem(le.HISTORY_TRANSACTIONS_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get transactions cache")}return{}},getTransactionsCacheForAddress({address:t,chainId:e=""}){var s;try{const r=(s=F.getTransactionsCache()[t])==null?void 0:s[e];if(r&&!this.isCacheExpired(r.timestamp,this.cacheExpiry.transactionsHistory))return r.transactions;F.removeTransactionsCache({address:t,chainId:e})}catch{console.info("Unable to get transactions cache")}},updateTransactionsCache({address:t,chainId:e="",timestamp:s,transactions:n}){try{const r=F.getTransactionsCache();r[t]={...r[t],[e]:{timestamp:s,transactions:n}},ae.setItem(le.HISTORY_TRANSACTIONS_CACHE,JSON.stringify(r))}catch{console.info("Unable to update transactions cache",{address:t,chainId:e,timestamp:s,transactions:n})}},removeTransactionsCache({address:t,chainId:e}){try{const s=F.getTransactionsCache(),n=(s==null?void 0:s[t])||{},{[e]:r,...i}=n;ae.setItem(le.HISTORY_TRANSACTIONS_CACHE,JSON.stringify({...s,[t]:i}))}catch{console.info("Unable to remove transactions cache",{address:t,chainId:e})}},getTokenPriceCache(){try{const t=ae.getItem(le.TOKEN_PRICE_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get token price cache")}return{}},getTokenPriceCacheForAddresses(t){try{const s=F.getTokenPriceCache()[t.join(",")];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.tokenPrice))return s.tokenPrice;F.removeTokenPriceCache(t)}catch{console.info("Unable to get token price cache for addresses",t)}},updateTokenPriceCache(t){try{const e=F.getTokenPriceCache();e[t.addresses.join(",")]={timestamp:t.timestamp,tokenPrice:t.tokenPrice},ae.setItem(le.TOKEN_PRICE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update token price cache",t)}},removeTokenPriceCache(t){try{const e=F.getTokenPriceCache();ae.setItem(le.TOKEN_PRICE_CACHE,JSON.stringify({...e,[t.join(",")]:void 0}))}catch{console.info("Unable to remove token price cache",t)}},getLatestAppKitVersion(){try{const t=this.getLatestAppKitVersionCache(),e=t==null?void 0:t.version;return e&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.latestAppKitVersion)?e:void 0}catch{console.info("Unable to get latest AppKit version")}},getLatestAppKitVersionCache(){try{const t=ae.getItem(le.LATEST_APPKIT_VERSION);return t?JSON.parse(t):{}}catch{console.info("Unable to get latest AppKit version cache")}return{}},updateLatestAppKitVersion(t){try{const e=F.getLatestAppKitVersionCache();e.timestamp=t.timestamp,e.version=t.version,ae.setItem(le.LATEST_APPKIT_VERSION,JSON.stringify(e))}catch{console.info("Unable to update latest AppKit version on local storage",t)}}},X={getWindow(){if(!(typeof window>"u"))return window},isMobile(){var t;return this.isClient()?!!(window!=null&&window.matchMedia&&typeof window.matchMedia=="function"&&((t=window.matchMedia("(pointer:coarse)"))!=null&&t.matches)||/Android|webOS|iPhone|iPad|iPod|BlackBerry|Opera Mini/u.test(navigator.userAgent)):!1},checkCaipNetwork(t,e=""){return t==null?void 0:t.caipNetworkId.toLocaleLowerCase().includes(e.toLowerCase())},isAndroid(){if(!this.isMobile())return!1;const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return X.isMobile()&&t.includes("android")},isIos(){if(!this.isMobile())return!1;const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return t.includes("iphone")||t.includes("ipad")},isSafari(){return this.isClient()?(window==null?void 0:window.navigator.userAgent.toLowerCase()).includes("safari"):!1},isClient(){return typeof window<"u"},isPairingExpired(t){return t?t-Date.now()<=Ie.TEN_SEC_MS:!0},isAllowedRetry(t,e=Ie.ONE_SEC_MS){return Date.now()-t>=e},copyToClopboard(t){navigator.clipboard.writeText(t)},isIframe(){try{return(window==null?void 0:window.self)!==(window==null?void 0:window.top)}catch{return!1}},isSafeApp(){var t,e;if(X.isClient()&&window.self!==window.top)try{const s=(e=(t=window==null?void 0:window.location)==null?void 0:t.ancestorOrigins)==null?void 0:e[0],n="https://app.safe.global";if(s){const r=new URL(s),i=new URL(n);return r.hostname===i.hostname}}catch{return!1}return!1},getPairingExpiry(){return Date.now()+Ie.FOUR_MINUTES_MS},getNetworkId(t){return t==null?void 0:t.split(":")[1]},getPlainAddress(t){return t==null?void 0:t.split(":")[2]},async wait(t){return new Promise(e=>{setTimeout(e,t)})},debounce(t,e=500){let s;return(...n)=>{function r(){t(...n)}s&&clearTimeout(s),s=setTimeout(r,e)}},isHttpUrl(t){return t.startsWith("http://")||t.startsWith("https://")},formatNativeUrl(t,e,s=null){if(X.isHttpUrl(t))return this.formatUniversalUrl(t,e);let n=t,r=s;n.includes("://")||(n=t.replaceAll("/","").replaceAll(":",""),n=`${n}://`),n.endsWith("/")||(n=`${n}/`),r&&!(r!=null&&r.endsWith("/"))&&(r=`${r}/`),this.isTelegram()&&this.isAndroid()&&(e=encodeURIComponent(e));const i=encodeURIComponent(e);return{redirect:`${n}wc?uri=${i}`,redirectUniversalLink:r?`${r}wc?uri=${i}`:void 0,href:n}},formatUniversalUrl(t,e){if(!X.isHttpUrl(t))return this.formatNativeUrl(t,e);let s=t;s.endsWith("/")||(s=`${s}/`);const n=encodeURIComponent(e);return{redirect:`${s}wc?uri=${n}`,href:s}},getOpenTargetForPlatform(t){return t==="popupWindow"?t:this.isTelegram()?F.getTelegramSocialProvider()?"_top":"_blank":t},openHref(t,e,s){window==null||window.open(t,this.getOpenTargetForPlatform(e),s||"noreferrer noopener")},returnOpenHref(t,e,s){return window==null?void 0:window.open(t,this.getOpenTargetForPlatform(e),s||"noreferrer noopener")},isTelegram(){return typeof window<"u"&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)},isPWA(){var s,n;if(typeof window>"u")return!1;const t=window!=null&&window.matchMedia&&typeof window.matchMedia=="function"?(s=window.matchMedia("(display-mode: standalone)"))==null?void 0:s.matches:!1,e=(n=window==null?void 0:window.navigator)==null?void 0:n.standalone;return!!(t||e)},async preloadImage(t){const e=new Promise((s,n)=>{const r=new Image;r.onload=s,r.onerror=n,r.crossOrigin="anonymous",r.src=t});return Promise.race([e,X.wait(2e3)])},parseBalance(t,e){let s="0.000";if(typeof t=="string"){const c=Number(t);if(!isNaN(c)){const l=(Math.floor(c*1e3)/1e3).toFixed(3);l&&(s=l)}}const[n,r]=s.split("."),i=n||"0",o=r||"000";return{formattedText:`${i}.${o}${e?` ${e}`:""}`,value:i,decimals:o,symbol:e}},getApiUrl(){return U.W3M_API_URL},getBlockchainApiUrl(){return U.BLOCKCHAIN_API_RPC_URL},getAnalyticsUrl(){return U.PULSE_API_URL},getUUID(){return crypto!=null&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,t=>{const e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})},parseError(t){var e,s;return typeof t=="string"?t:typeof((s=(e=t==null?void 0:t.issues)==null?void 0:e[0])==null?void 0:s.message)=="string"?t.issues[0].message:t instanceof Error?t.message:"Unknown error"},sortRequestedNetworks(t,e=[]){const s={};return e&&t&&(t.forEach((n,r)=>{s[n]=r}),e.sort((n,r)=>{const i=s[n.id],o=s[r.id];return i!==void 0&&o!==void 0?i-o:i!==void 0?-1:o!==void 0?1:0})),e},calculateBalance(t){let e=0;for(const s of t)e+=s.value??0;return e},formatTokenBalance(t){const e=t.toFixed(2),[s,n]=e.split(".");return{dollars:s,pennies:n}},isAddress(t,e="eip155"){switch(e){case"eip155":if(/^(?:0x)?[0-9a-f]{40}$/iu.test(t)){if(/^(?:0x)?[0-9a-f]{40}$/iu.test(t)||/^(?:0x)?[0-9A-F]{40}$/iu.test(t))return!0}else return!1;return!1;case"solana":return/[1-9A-HJ-NP-Za-km-z]{32,44}$/iu.test(t);default:return!1}},uniqueBy(t,e){const s=new Set;return t.filter(n=>{const r=n[e];return s.has(r)?!1:(s.add(r),!0)})},generateSdkVersion(t,e,s){const r=t.length===0?Ie.ADAPTER_TYPES.UNIVERSAL:t.map(i=>i.adapterType).join(",");return`${e}-${r}-${s}`},createAccount(t,e,s,n,r){return{namespace:t,address:e,type:s,publicKey:n,path:r}},isCaipAddress(t){if(typeof t!="string")return!1;const e=t.split(":"),s=e[0];return e.filter(Boolean).length===3&&s in U.CHAIN_NAME_MAP},getAccount(t){return t?typeof t=="string"?{address:t,chainId:void 0}:{address:t.address,chainId:t.chainId}:{address:void 0,chainId:void 0}},isMac(){const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return t.includes("macintosh")&&!t.includes("safari")},formatTelegramSocialLoginUrl(t){const e=`--${encodeURIComponent(window==null?void 0:window.location.href)}`,s="state=";if(new URL(t).host==="auth.magic.link"){const r="provider_authorization_url=",i=t.substring(t.indexOf(r)+r.length),o=this.injectIntoUrl(decodeURIComponent(i),s,e);return t.replace(i,encodeURIComponent(o))}return this.injectIntoUrl(t,s,e)},injectIntoUrl(t,e,s){const n=t.indexOf(e);if(n===-1)throw new Error(`${e} parameter not found in the URL: ${t}`);const r=t.indexOf("&",n),i=e.length,o=r!==-1?r:t.length,a=t.substring(0,n+i),c=t.substring(n+i,o),l=t.substring(r),d=c+s;return a+d+l}};var ai={};const Sw="https://secure.walletconnect.org/sdk",Iw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_SECURE_SITE_SDK_URL:void 0)||Sw,Nw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_DEFAULT_LOG_LEVEL:void 0)||"error",Tw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_SECURE_SITE_SDK_VERSION:void 0)||"4",oe={APP_EVENT_KEY:"@w3m-app/",FRAME_EVENT_KEY:"@w3m-frame/",RPC_METHOD_KEY:"RPC_",STORAGE_KEY:"@appkit-wallet/",SESSION_TOKEN_KEY:"SESSION_TOKEN_KEY",EMAIL_LOGIN_USED_KEY:"EMAIL_LOGIN_USED_KEY",LAST_USED_CHAIN_KEY:"LAST_USED_CHAIN_KEY",LAST_EMAIL_LOGIN_TIME:"LAST_EMAIL_LOGIN_TIME",EMAIL:"EMAIL",PREFERRED_ACCOUNT_TYPE:"PREFERRED_ACCOUNT_TYPE",SMART_ACCOUNT_ENABLED:"SMART_ACCOUNT_ENABLED",SMART_ACCOUNT_ENABLED_NETWORKS:"SMART_ACCOUNT_ENABLED_NETWORKS",SOCIAL_USERNAME:"SOCIAL_USERNAME",APP_SWITCH_NETWORK:"@w3m-app/SWITCH_NETWORK",APP_CONNECT_EMAIL:"@w3m-app/CONNECT_EMAIL",APP_CONNECT_DEVICE:"@w3m-app/CONNECT_DEVICE",APP_CONNECT_OTP:"@w3m-app/CONNECT_OTP",APP_CONNECT_SOCIAL:"@w3m-app/CONNECT_SOCIAL",APP_GET_SOCIAL_REDIRECT_URI:"@w3m-app/GET_SOCIAL_REDIRECT_URI",APP_GET_USER:"@w3m-app/GET_USER",APP_SIGN_OUT:"@w3m-app/SIGN_OUT",APP_IS_CONNECTED:"@w3m-app/IS_CONNECTED",APP_GET_CHAIN_ID:"@w3m-app/GET_CHAIN_ID",APP_RPC_REQUEST:"@w3m-app/RPC_REQUEST",APP_UPDATE_EMAIL:"@w3m-app/UPDATE_EMAIL",APP_UPDATE_EMAIL_PRIMARY_OTP:"@w3m-app/UPDATE_EMAIL_PRIMARY_OTP",APP_UPDATE_EMAIL_SECONDARY_OTP:"@w3m-app/UPDATE_EMAIL_SECONDARY_OTP",APP_AWAIT_UPDATE_EMAIL:"@w3m-app/AWAIT_UPDATE_EMAIL",APP_SYNC_THEME:"@w3m-app/SYNC_THEME",APP_SYNC_DAPP_DATA:"@w3m-app/SYNC_DAPP_DATA",APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS:"@w3m-app/GET_SMART_ACCOUNT_ENABLED_NETWORKS",APP_INIT_SMART_ACCOUNT:"@w3m-app/INIT_SMART_ACCOUNT",APP_SET_PREFERRED_ACCOUNT:"@w3m-app/SET_PREFERRED_ACCOUNT",APP_CONNECT_FARCASTER:"@w3m-app/CONNECT_FARCASTER",APP_GET_FARCASTER_URI:"@w3m-app/GET_FARCASTER_URI",APP_RELOAD:"@w3m-app/RELOAD",APP_RPC_ABORT:"@w3m-app/RPC_ABORT",FRAME_SWITCH_NETWORK_ERROR:"@w3m-frame/SWITCH_NETWORK_ERROR",FRAME_SWITCH_NETWORK_SUCCESS:"@w3m-frame/SWITCH_NETWORK_SUCCESS",FRAME_CONNECT_EMAIL_ERROR:"@w3m-frame/CONNECT_EMAIL_ERROR",FRAME_CONNECT_EMAIL_SUCCESS:"@w3m-frame/CONNECT_EMAIL_SUCCESS",FRAME_CONNECT_DEVICE_ERROR:"@w3m-frame/CONNECT_DEVICE_ERROR",FRAME_CONNECT_DEVICE_SUCCESS:"@w3m-frame/CONNECT_DEVICE_SUCCESS",FRAME_CONNECT_OTP_SUCCESS:"@w3m-frame/CONNECT_OTP_SUCCESS",FRAME_CONNECT_OTP_ERROR:"@w3m-frame/CONNECT_OTP_ERROR",FRAME_CONNECT_SOCIAL_SUCCESS:"@w3m-frame/CONNECT_SOCIAL_SUCCESS",FRAME_CONNECT_SOCIAL_ERROR:"@w3m-frame/CONNECT_SOCIAL_ERROR",FRAME_CONNECT_FARCASTER_SUCCESS:"@w3m-frame/CONNECT_FARCASTER_SUCCESS",FRAME_CONNECT_FARCASTER_ERROR:"@w3m-frame/CONNECT_FARCASTER_ERROR",FRAME_GET_FARCASTER_URI_SUCCESS:"@w3m-frame/GET_FARCASTER_URI_SUCCESS",FRAME_GET_FARCASTER_URI_ERROR:"@w3m-frame/GET_FARCASTER_URI_ERROR",FRAME_GET_SOCIAL_REDIRECT_URI_SUCCESS:"@w3m-frame/GET_SOCIAL_REDIRECT_URI_SUCCESS",FRAME_GET_SOCIAL_REDIRECT_URI_ERROR:"@w3m-frame/GET_SOCIAL_REDIRECT_URI_ERROR",FRAME_GET_USER_SUCCESS:"@w3m-frame/GET_USER_SUCCESS",FRAME_GET_USER_ERROR:"@w3m-frame/GET_USER_ERROR",FRAME_SIGN_OUT_SUCCESS:"@w3m-frame/SIGN_OUT_SUCCESS",FRAME_SIGN_OUT_ERROR:"@w3m-frame/SIGN_OUT_ERROR",FRAME_IS_CONNECTED_SUCCESS:"@w3m-frame/IS_CONNECTED_SUCCESS",FRAME_IS_CONNECTED_ERROR:"@w3m-frame/IS_CONNECTED_ERROR",FRAME_GET_CHAIN_ID_SUCCESS:"@w3m-frame/GET_CHAIN_ID_SUCCESS",FRAME_GET_CHAIN_ID_ERROR:"@w3m-frame/GET_CHAIN_ID_ERROR",FRAME_RPC_REQUEST_SUCCESS:"@w3m-frame/RPC_REQUEST_SUCCESS",FRAME_RPC_REQUEST_ERROR:"@w3m-frame/RPC_REQUEST_ERROR",FRAME_SESSION_UPDATE:"@w3m-frame/SESSION_UPDATE",FRAME_UPDATE_EMAIL_SUCCESS:"@w3m-frame/UPDATE_EMAIL_SUCCESS",FRAME_UPDATE_EMAIL_ERROR:"@w3m-frame/UPDATE_EMAIL_ERROR",FRAME_UPDATE_EMAIL_PRIMARY_OTP_SUCCESS:"@w3m-frame/UPDATE_EMAIL_PRIMARY_OTP_SUCCESS",FRAME_UPDATE_EMAIL_PRIMARY_OTP_ERROR:"@w3m-frame/UPDATE_EMAIL_PRIMARY_OTP_ERROR",FRAME_UPDATE_EMAIL_SECONDARY_OTP_SUCCESS:"@w3m-frame/UPDATE_EMAIL_SECONDARY_OTP_SUCCESS",FRAME_UPDATE_EMAIL_SECONDARY_OTP_ERROR:"@w3m-frame/UPDATE_EMAIL_SECONDARY_OTP_ERROR",FRAME_SYNC_THEME_SUCCESS:"@w3m-frame/SYNC_THEME_SUCCESS",FRAME_SYNC_THEME_ERROR:"@w3m-frame/SYNC_THEME_ERROR",FRAME_SYNC_DAPP_DATA_SUCCESS:"@w3m-frame/SYNC_DAPP_DATA_SUCCESS",FRAME_SYNC_DAPP_DATA_ERROR:"@w3m-frame/SYNC_DAPP_DATA_ERROR",FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS:"@w3m-frame/GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS",FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR:"@w3m-frame/GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR",FRAME_INIT_SMART_ACCOUNT_SUCCESS:"@w3m-frame/INIT_SMART_ACCOUNT_SUCCESS",FRAME_INIT_SMART_ACCOUNT_ERROR:"@w3m-frame/INIT_SMART_ACCOUNT_ERROR",FRAME_SET_PREFERRED_ACCOUNT_SUCCESS:"@w3m-frame/SET_PREFERRED_ACCOUNT_SUCCESS",FRAME_SET_PREFERRED_ACCOUNT_ERROR:"@w3m-frame/SET_PREFERRED_ACCOUNT_ERROR",FRAME_READY:"@w3m-frame/READY",FRAME_RELOAD_SUCCESS:"@w3m-frame/RELOAD_SUCCESS",FRAME_RELOAD_ERROR:"@w3m-frame/RELOAD_ERROR",FRAME_RPC_ABORT_SUCCESS:"@w3m-frame/RPC_ABORT_SUCCESS",FRAME_RPC_ABORT_ERROR:"@w3m-frame/RPC_ABORT_ERROR",RPC_RESPONSE_TYPE_ERROR:"RPC_RESPONSE_ERROR",RPC_RESPONSE_TYPE_TX:"RPC_RESPONSE_TRANSACTION_HASH",RPC_RESPONSE_TYPE_OBJECT:"RPC_RESPONSE_OBJECT"},tt={SAFE_RPC_METHODS:["eth_accounts","eth_blockNumber","eth_call","eth_chainId","eth_estimateGas","eth_feeHistory","eth_gasPrice","eth_getAccount","eth_getBalance","eth_getBlockByHash","eth_getBlockByNumber","eth_getBlockReceipts","eth_getBlockTransactionCountByHash","eth_getBlockTransactionCountByNumber","eth_getCode","eth_getFilterChanges","eth_getFilterLogs","eth_getLogs","eth_getProof","eth_getStorageAt","eth_getTransactionByBlockHashAndIndex","eth_getTransactionByBlockNumberAndIndex","eth_getTransactionByHash","eth_getTransactionCount","eth_getTransactionReceipt","eth_getUncleCountByBlockHash","eth_getUncleCountByBlockNumber","eth_maxPriorityFeePerGas","eth_newBlockFilter","eth_newFilter","eth_newPendingTransactionFilter","eth_sendRawTransaction","eth_syncing","eth_uninstallFilter","wallet_getCapabilities","wallet_getCallsStatus","eth_getUserOperationReceipt","eth_estimateUserOperationGas","eth_getUserOperationByHash","eth_supportedEntryPoints","wallet_getAssets"],NOT_SAFE_RPC_METHODS:["personal_sign","eth_signTypedData_v4","eth_sendTransaction","solana_signMessage","solana_signTransaction","solana_signAllTransactions","solana_signAndSendTransaction","wallet_sendCalls","wallet_grantPermissions","wallet_revokePermissions","eth_sendUserOperation"],GET_CHAIN_ID:"eth_chainId",RPC_METHOD_NOT_ALLOWED_MESSAGE:"Requested RPC call is not allowed",RPC_METHOD_NOT_ALLOWED_UI_MESSAGE:"Action not allowed",ACCOUNT_TYPES:{EOA:"eoa",SMART_ACCOUNT:"smartAccount"}},ku={transactionHash:/^0x(?:[A-Fa-f0-9]{64})$/u,signedMessage:/^0x(?:[a-fA-F0-9]{62,})$/u},lt={set(t,e){cs.isClient&&localStorage.setItem(`${oe.STORAGE_KEY}${t}`,e)},get(t){return cs.isClient?localStorage.getItem(`${oe.STORAGE_KEY}${t}`):null},delete(t,e){cs.isClient&&(e?localStorage.removeItem(t):localStorage.removeItem(`${oe.STORAGE_KEY}${t}`))}},Fo=30*1e3,cs={checkIfAllowedToTriggerEmail(){const t=lt.get(oe.LAST_EMAIL_LOGIN_TIME);if(t){const e=Date.now()-Number(t);if(e<Fo){const s=Math.ceil((Fo-e)/1e3);throw new Error(`Please try again after ${s} seconds`)}}},getTimeToNextEmailLogin(){const t=lt.get(oe.LAST_EMAIL_LOGIN_TIME);if(t){const e=Date.now()-Number(t);if(e<Fo)return Math.ceil((Fo-e)/1e3)}return 0},checkIfRequestExists(t){return tt.NOT_SAFE_RPC_METHODS.includes(t.method)||tt.SAFE_RPC_METHODS.includes(t.method)},getResponseType(t){return typeof t=="string"&&((t==null?void 0:t.match(ku.transactionHash))||(t==null?void 0:t.match(ku.signedMessage)))?oe.RPC_RESPONSE_TYPE_TX:oe.RPC_RESPONSE_TYPE_OBJECT},checkIfRequestIsSafe(t){return tt.SAFE_RPC_METHODS.includes(t.method)},isClient:typeof window<"u"};var Le;(function(t){t.assertEqual=r=>r;function e(r){}t.assertIs=e;function s(r){throw new Error}t.assertNever=s,t.arrayToEnum=r=>{const i={};for(const o of r)i[o]=o;return i},t.getValidEnumValues=r=>{const i=t.objectKeys(r).filter(a=>typeof r[r[a]]!="number"),o={};for(const a of i)o[a]=r[a];return t.objectValues(o)},t.objectValues=r=>t.objectKeys(r).map(function(i){return r[i]}),t.objectKeys=typeof Object.keys=="function"?r=>Object.keys(r):r=>{const i=[];for(const o in r)Object.prototype.hasOwnProperty.call(r,o)&&i.push(o);return i},t.find=(r,i)=>{for(const o of r)if(i(o))return o},t.isInteger=typeof Number.isInteger=="function"?r=>Number.isInteger(r):r=>typeof r=="number"&&isFinite(r)&&Math.floor(r)===r;function n(r,i=" | "){return r.map(o=>typeof o=="string"?`'${o}'`:o).join(i)}t.joinValues=n,t.jsonStringifyReplacer=(r,i)=>typeof i=="bigint"?i.toString():i})(Le||(Le={}));var Sl;(function(t){t.mergeShapes=(e,s)=>({...e,...s})})(Sl||(Sl={}));const se=Le.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),Bn=t=>{switch(typeof t){case"undefined":return se.undefined;case"string":return se.string;case"number":return isNaN(t)?se.nan:se.number;case"boolean":return se.boolean;case"function":return se.function;case"bigint":return se.bigint;case"symbol":return se.symbol;case"object":return Array.isArray(t)?se.array:t===null?se.null:t.then&&typeof t.then=="function"&&t.catch&&typeof t.catch=="function"?se.promise:typeof Map<"u"&&t instanceof Map?se.map:typeof Set<"u"&&t instanceof Set?se.set:typeof Date<"u"&&t instanceof Date?se.date:se.object;default:return se.unknown}},K=Le.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),Rw=t=>JSON.stringify(t,null,2).replace(/"([^"]+)":/g,"$1:");class Us extends Error{constructor(e){super(),this.issues=[],this.addIssue=n=>{this.issues=[...this.issues,n]},this.addIssues=(n=[])=>{this.issues=[...this.issues,...n]};const s=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,s):this.__proto__=s,this.name="ZodError",this.issues=e}get errors(){return this.issues}format(e){const s=e||function(i){return i.message},n={_errors:[]},r=i=>{for(const o of i.issues)if(o.code==="invalid_union")o.unionErrors.map(r);else if(o.code==="invalid_return_type")r(o.returnTypeError);else if(o.code==="invalid_arguments")r(o.argumentsError);else if(o.path.length===0)n._errors.push(s(o));else{let a=n,c=0;for(;c<o.path.length;){const l=o.path[c];c===o.path.length-1?(a[l]=a[l]||{_errors:[]},a[l]._errors.push(s(o))):a[l]=a[l]||{_errors:[]},a=a[l],c++}}};return r(this),n}toString(){return this.message}get message(){return JSON.stringify(this.issues,Le.jsonStringifyReplacer,2)}get isEmpty(){return this.issues.length===0}flatten(e=s=>s.message){const s={},n=[];for(const r of this.issues)r.path.length>0?(s[r.path[0]]=s[r.path[0]]||[],s[r.path[0]].push(e(r))):n.push(e(r));return{formErrors:n,fieldErrors:s}}get formErrors(){return this.flatten()}}Us.create=t=>new Us(t);const eo=(t,e)=>{let s;switch(t.code){case K.invalid_type:t.received===se.undefined?s="Required":s=`Expected ${t.expected}, received ${t.received}`;break;case K.invalid_literal:s=`Invalid literal value, expected ${JSON.stringify(t.expected,Le.jsonStringifyReplacer)}`;break;case K.unrecognized_keys:s=`Unrecognized key(s) in object: ${Le.joinValues(t.keys,", ")}`;break;case K.invalid_union:s="Invalid input";break;case K.invalid_union_discriminator:s=`Invalid discriminator value. Expected ${Le.joinValues(t.options)}`;break;case K.invalid_enum_value:s=`Invalid enum value. Expected ${Le.joinValues(t.options)}, received '${t.received}'`;break;case K.invalid_arguments:s="Invalid function arguments";break;case K.invalid_return_type:s="Invalid function return type";break;case K.invalid_date:s="Invalid date";break;case K.invalid_string:typeof t.validation=="object"?"includes"in t.validation?(s=`Invalid input: must include "${t.validation.includes}"`,typeof t.validation.position=="number"&&(s=`${s} at one or more positions greater than or equal to ${t.validation.position}`)):"startsWith"in t.validation?s=`Invalid input: must start with "${t.validation.startsWith}"`:"endsWith"in t.validation?s=`Invalid input: must end with "${t.validation.endsWith}"`:Le.assertNever(t.validation):t.validation!=="regex"?s=`Invalid ${t.validation}`:s="Invalid";break;case K.too_small:t.type==="array"?s=`Array must contain ${t.exact?"exactly":t.inclusive?"at least":"more than"} ${t.minimum} element(s)`:t.type==="string"?s=`String must contain ${t.exact?"exactly":t.inclusive?"at least":"over"} ${t.minimum} character(s)`:t.type==="number"?s=`Number must be ${t.exact?"exactly equal to ":t.inclusive?"greater than or equal to ":"greater than "}${t.minimum}`:t.type==="date"?s=`Date must be ${t.exact?"exactly equal to ":t.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(t.minimum))}`:s="Invalid input";break;case K.too_big:t.type==="array"?s=`Array must contain ${t.exact?"exactly":t.inclusive?"at most":"less than"} ${t.maximum} element(s)`:t.type==="string"?s=`String must contain ${t.exact?"exactly":t.inclusive?"at most":"under"} ${t.maximum} character(s)`:t.type==="number"?s=`Number must be ${t.exact?"exactly":t.inclusive?"less than or equal to":"less than"} ${t.maximum}`:t.type==="bigint"?s=`BigInt must be ${t.exact?"exactly":t.inclusive?"less than or equal to":"less than"} ${t.maximum}`:t.type==="date"?s=`Date must be ${t.exact?"exactly":t.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(t.maximum))}`:s="Invalid input";break;case K.custom:s="Invalid input";break;case K.invalid_intersection_types:s="Intersection results could not be merged";break;case K.not_multiple_of:s=`Number must be a multiple of ${t.multipleOf}`;break;case K.not_finite:s="Number must be finite";break;default:s=e.defaultError,Le.assertNever(t)}return{message:s}};let Uf=eo;function Ow(t){Uf=t}function Aa(){return Uf}const Sa=t=>{const{data:e,path:s,errorMaps:n,issueData:r}=t,i=[...s,...r.path||[]],o={...r,path:i};let a="";const c=n.filter(l=>!!l).slice().reverse();for(const l of c)a=l(o,{data:e,defaultError:a}).message;return{...r,path:i,message:r.message||a}},Pw=[];function ie(t,e){const s=Sa({issueData:e,data:t.data,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,Aa(),eo].filter(n=>!!n)});t.common.issues.push(s)}class kt{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(e,s){const n=[];for(const r of s){if(r.status==="aborted")return be;r.status==="dirty"&&e.dirty(),n.push(r.value)}return{status:e.value,value:n}}static async mergeObjectAsync(e,s){const n=[];for(const r of s)n.push({key:await r.key,value:await r.value});return kt.mergeObjectSync(e,n)}static mergeObjectSync(e,s){const n={};for(const r of s){const{key:i,value:o}=r;if(i.status==="aborted"||o.status==="aborted")return be;i.status==="dirty"&&e.dirty(),o.status==="dirty"&&e.dirty(),i.value!=="__proto__"&&(typeof o.value<"u"||r.alwaysSet)&&(n[i.value]=o.value)}return{status:e.value,value:n}}}const be=Object.freeze({status:"aborted"}),$f=t=>({status:"dirty",value:t}),Ft=t=>({status:"valid",value:t}),Il=t=>t.status==="aborted",Nl=t=>t.status==="dirty",to=t=>t.status==="valid",Ia=t=>typeof Promise<"u"&&t instanceof Promise;var pe;(function(t){t.errToObj=e=>typeof e=="string"?{message:e}:e||{},t.toString=e=>typeof e=="string"?e:e==null?void 0:e.message})(pe||(pe={}));class Qs{constructor(e,s,n,r){this._cachedPath=[],this.parent=e,this.data=s,this._path=n,this._key=r}get path(){return this._cachedPath.length||(this._key instanceof Array?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}}const Uu=(t,e)=>{if(to(e))return{success:!0,data:e.value};if(!t.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;const s=new Us(t.common.issues);return this._error=s,this._error}}};function Ce(t){if(!t)return{};const{errorMap:e,invalid_type_error:s,required_error:n,description:r}=t;if(e&&(s||n))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return e?{errorMap:e,description:r}:{errorMap:(o,a)=>o.code!=="invalid_type"?{message:a.defaultError}:typeof a.data>"u"?{message:n??a.defaultError}:{message:s??a.defaultError},description:r}}class Ae{constructor(e){this.spa=this.safeParseAsync,this._def=e,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this)}get description(){return this._def.description}_getType(e){return Bn(e.data)}_getOrReturnCtx(e,s){return s||{common:e.parent.common,data:e.data,parsedType:Bn(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}_processInputParams(e){return{status:new kt,ctx:{common:e.parent.common,data:e.data,parsedType:Bn(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}}_parseSync(e){const s=this._parse(e);if(Ia(s))throw new Error("Synchronous parse encountered promise.");return s}_parseAsync(e){const s=this._parse(e);return Promise.resolve(s)}parse(e,s){const n=this.safeParse(e,s);if(n.success)return n.data;throw n.error}safeParse(e,s){var n;const r={common:{issues:[],async:(n=s==null?void 0:s.async)!==null&&n!==void 0?n:!1,contextualErrorMap:s==null?void 0:s.errorMap},path:(s==null?void 0:s.path)||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:Bn(e)},i=this._parseSync({data:e,path:r.path,parent:r});return Uu(r,i)}async parseAsync(e,s){const n=await this.safeParseAsync(e,s);if(n.success)return n.data;throw n.error}async safeParseAsync(e,s){const n={common:{issues:[],contextualErrorMap:s==null?void 0:s.errorMap,async:!0},path:(s==null?void 0:s.path)||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:Bn(e)},r=this._parse({data:e,path:n.path,parent:n}),i=await(Ia(r)?r:Promise.resolve(r));return Uu(n,i)}refine(e,s){const n=r=>typeof s=="string"||typeof s>"u"?{message:s}:typeof s=="function"?s(r):s;return this._refinement((r,i)=>{const o=e(r),a=()=>i.addIssue({code:K.custom,...n(r)});return typeof Promise<"u"&&o instanceof Promise?o.then(c=>c?!0:(a(),!1)):o?!0:(a(),!1)})}refinement(e,s){return this._refinement((n,r)=>e(n)?!0:(r.addIssue(typeof s=="function"?s(n,r):s),!1))}_refinement(e){return new Ls({schema:this,typeName:me.ZodEffects,effect:{type:"refinement",refinement:e}})}superRefine(e){return this._refinement(e)}optional(){return bn.create(this,this._def)}nullable(){return Nr.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return $s.create(this,this._def)}promise(){return li.create(this,this._def)}or(e){return io.create([this,e],this._def)}and(e){return oo.create(this,e,this._def)}transform(e){return new Ls({...Ce(this._def),schema:this,typeName:me.ZodEffects,effect:{type:"transform",transform:e}})}default(e){const s=typeof e=="function"?e:()=>e;return new ho({...Ce(this._def),innerType:this,defaultValue:s,typeName:me.ZodDefault})}brand(){return new Lf({typeName:me.ZodBranded,type:this,...Ce(this._def)})}catch(e){const s=typeof e=="function"?e:()=>e;return new Oa({...Ce(this._def),innerType:this,catchValue:s,typeName:me.ZodCatch})}describe(e){const s=this.constructor;return new s({...this._def,description:e})}pipe(e){return Ao.create(this,e)}readonly(){return xa.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}}const xw=/^c[^\s-]{8,}$/i,kw=/^[a-z][a-z0-9]*$/,Uw=/^[0-9A-HJKMNP-TV-Z]{26}$/,$w=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,Dw=/^(?!\.)(?!.*\.\.)([A-Z0-9_+-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,Lw="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$";let _c;const Mw=/^(((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))\.){3}((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))$/,Bw=/^(([a-f0-9]{1,4}:){7}|::([a-f0-9]{1,4}:){0,6}|([a-f0-9]{1,4}:){1}:([a-f0-9]{1,4}:){0,5}|([a-f0-9]{1,4}:){2}:([a-f0-9]{1,4}:){0,4}|([a-f0-9]{1,4}:){3}:([a-f0-9]{1,4}:){0,3}|([a-f0-9]{1,4}:){4}:([a-f0-9]{1,4}:){0,2}|([a-f0-9]{1,4}:){5}:([a-f0-9]{1,4}:){0,1})([a-f0-9]{1,4}|(((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))\.){3}((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2})))$/,jw=t=>t.precision?t.offset?new RegExp(`^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{${t.precision}}(([+-]\\d{2}(:?\\d{2})?)|Z)$`):new RegExp(`^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{${t.precision}}Z$`):t.precision===0?t.offset?new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(([+-]\\d{2}(:?\\d{2})?)|Z)$"):new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}Z$"):t.offset?new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?(([+-]\\d{2}(:?\\d{2})?)|Z)$"):new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?Z$");function Fw(t,e){return!!((e==="v4"||!e)&&Mw.test(t)||(e==="v6"||!e)&&Bw.test(t))}class ks extends Ae{_parse(e){if(this._def.coerce&&(e.data=String(e.data)),this._getType(e)!==se.string){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.string,received:i.parsedType}),be}const n=new kt;let r;for(const i of this._def.checks)if(i.kind==="min")e.data.length<i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="max")e.data.length>i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="length"){const o=e.data.length>i.value,a=e.data.length<i.value;(o||a)&&(r=this._getOrReturnCtx(e,r),o?ie(r,{code:K.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}):a&&ie(r,{code:K.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}),n.dirty())}else if(i.kind==="email")Dw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"email",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="emoji")_c||(_c=new RegExp(Lw,"u")),_c.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"emoji",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="uuid")$w.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"uuid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid")xw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"cuid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid2")kw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"cuid2",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="ulid")Uw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"ulid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="url")try{new URL(e.data)}catch{r=this._getOrReturnCtx(e,r),ie(r,{validation:"url",code:K.invalid_string,message:i.message}),n.dirty()}else i.kind==="regex"?(i.regex.lastIndex=0,i.regex.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"regex",code:K.invalid_string,message:i.message}),n.dirty())):i.kind==="trim"?e.data=e.data.trim():i.kind==="includes"?e.data.includes(i.value,i.position)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{includes:i.value,position:i.position},message:i.message}),n.dirty()):i.kind==="toLowerCase"?e.data=e.data.toLowerCase():i.kind==="toUpperCase"?e.data=e.data.toUpperCase():i.kind==="startsWith"?e.data.startsWith(i.value)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{startsWith:i.value},message:i.message}),n.dirty()):i.kind==="endsWith"?e.data.endsWith(i.value)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{endsWith:i.value},message:i.message}),n.dirty()):i.kind==="datetime"?jw(i).test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:"datetime",message:i.message}),n.dirty()):i.kind==="ip"?Fw(e.data,i.version)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"ip",code:K.invalid_string,message:i.message}),n.dirty()):Le.assertNever(i);return{status:n.value,value:e.data}}_regex(e,s,n){return this.refinement(r=>e.test(r),{validation:s,code:K.invalid_string,...pe.errToObj(n)})}_addCheck(e){return new ks({...this._def,checks:[...this._def.checks,e]})}email(e){return this._addCheck({kind:"email",...pe.errToObj(e)})}url(e){return this._addCheck({kind:"url",...pe.errToObj(e)})}emoji(e){return this._addCheck({kind:"emoji",...pe.errToObj(e)})}uuid(e){return this._addCheck({kind:"uuid",...pe.errToObj(e)})}cuid(e){return this._addCheck({kind:"cuid",...pe.errToObj(e)})}cuid2(e){return this._addCheck({kind:"cuid2",...pe.errToObj(e)})}ulid(e){return this._addCheck({kind:"ulid",...pe.errToObj(e)})}ip(e){return this._addCheck({kind:"ip",...pe.errToObj(e)})}datetime(e){var s;return typeof e=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,message:e}):this._addCheck({kind:"datetime",precision:typeof(e==null?void 0:e.precision)>"u"?null:e==null?void 0:e.precision,offset:(s=e==null?void 0:e.offset)!==null&&s!==void 0?s:!1,...pe.errToObj(e==null?void 0:e.message)})}regex(e,s){return this._addCheck({kind:"regex",regex:e,...pe.errToObj(s)})}includes(e,s){return this._addCheck({kind:"includes",value:e,position:s==null?void 0:s.position,...pe.errToObj(s==null?void 0:s.message)})}startsWith(e,s){return this._addCheck({kind:"startsWith",value:e,...pe.errToObj(s)})}endsWith(e,s){return this._addCheck({kind:"endsWith",value:e,...pe.errToObj(s)})}min(e,s){return this._addCheck({kind:"min",value:e,...pe.errToObj(s)})}max(e,s){return this._addCheck({kind:"max",value:e,...pe.errToObj(s)})}length(e,s){return this._addCheck({kind:"length",value:e,...pe.errToObj(s)})}nonempty(e){return this.min(1,pe.errToObj(e))}trim(){return new ks({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new ks({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new ks({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(e=>e.kind==="datetime")}get isEmail(){return!!this._def.checks.find(e=>e.kind==="email")}get isURL(){return!!this._def.checks.find(e=>e.kind==="url")}get isEmoji(){return!!this._def.checks.find(e=>e.kind==="emoji")}get isUUID(){return!!this._def.checks.find(e=>e.kind==="uuid")}get isCUID(){return!!this._def.checks.find(e=>e.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(e=>e.kind==="cuid2")}get isULID(){return!!this._def.checks.find(e=>e.kind==="ulid")}get isIP(){return!!this._def.checks.find(e=>e.kind==="ip")}get minLength(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxLength(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}}ks.create=t=>{var e;return new ks({checks:[],typeName:me.ZodString,coerce:(e=t==null?void 0:t.coerce)!==null&&e!==void 0?e:!1,...Ce(t)})};function qw(t,e){const s=(t.toString().split(".")[1]||"").length,n=(e.toString().split(".")[1]||"").length,r=s>n?s:n,i=parseInt(t.toFixed(r).replace(".","")),o=parseInt(e.toFixed(r).replace(".",""));return i%o/Math.pow(10,r)}class Zn extends Ae{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(e){if(this._def.coerce&&(e.data=Number(e.data)),this._getType(e)!==se.number){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.number,received:i.parsedType}),be}let n;const r=new kt;for(const i of this._def.checks)i.kind==="int"?Le.isInteger(e.data)||(n=this._getOrReturnCtx(e,n),ie(n,{code:K.invalid_type,expected:"integer",received:"float",message:i.message}),r.dirty()):i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_small,minimum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),r.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_big,maximum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),r.dirty()):i.kind==="multipleOf"?qw(e.data,i.value)!==0&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_multiple_of,multipleOf:i.value,message:i.message}),r.dirty()):i.kind==="finite"?Number.isFinite(e.data)||(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_finite,message:i.message}),r.dirty()):Le.assertNever(i);return{status:r.value,value:e.data}}gte(e,s){return this.setLimit("min",e,!0,pe.toString(s))}gt(e,s){return this.setLimit("min",e,!1,pe.toString(s))}lte(e,s){return this.setLimit("max",e,!0,pe.toString(s))}lt(e,s){return this.setLimit("max",e,!1,pe.toString(s))}setLimit(e,s,n,r){return new Zn({...this._def,checks:[...this._def.checks,{kind:e,value:s,inclusive:n,message:pe.toString(r)}]})}_addCheck(e){return new Zn({...this._def,checks:[...this._def.checks,e]})}int(e){return this._addCheck({kind:"int",message:pe.toString(e)})}positive(e){return this._addCheck({kind:"min",value:0,inclusive:!1,message:pe.toString(e)})}negative(e){return this._addCheck({kind:"max",value:0,inclusive:!1,message:pe.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:0,inclusive:!0,message:pe.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:0,inclusive:!0,message:pe.toString(e)})}multipleOf(e,s){return this._addCheck({kind:"multipleOf",value:e,message:pe.toString(s)})}finite(e){return this._addCheck({kind:"finite",message:pe.toString(e)})}safe(e){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:pe.toString(e)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:pe.toString(e)})}get minValue(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxValue(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}get isInt(){return!!this._def.checks.find(e=>e.kind==="int"||e.kind==="multipleOf"&&Le.isInteger(e.value))}get isFinite(){let e=null,s=null;for(const n of this._def.checks){if(n.kind==="finite"||n.kind==="int"||n.kind==="multipleOf")return!0;n.kind==="min"?(s===null||n.value>s)&&(s=n.value):n.kind==="max"&&(e===null||n.value<e)&&(e=n.value)}return Number.isFinite(s)&&Number.isFinite(e)}}Zn.create=t=>new Zn({checks:[],typeName:me.ZodNumber,coerce:(t==null?void 0:t.coerce)||!1,...Ce(t)});class Jn extends Ae{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(e){if(this._def.coerce&&(e.data=BigInt(e.data)),this._getType(e)!==se.bigint){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.bigint,received:i.parsedType}),be}let n;const r=new kt;for(const i of this._def.checks)i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_small,type:"bigint",minimum:i.value,inclusive:i.inclusive,message:i.message}),r.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_big,type:"bigint",maximum:i.value,inclusive:i.inclusive,message:i.message}),r.dirty()):i.kind==="multipleOf"?e.data%i.value!==BigInt(0)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_multiple_of,multipleOf:i.value,message:i.message}),r.dirty()):Le.assertNever(i);return{status:r.value,value:e.data}}gte(e,s){return this.setLimit("min",e,!0,pe.toString(s))}gt(e,s){return this.setLimit("min",e,!1,pe.toString(s))}lte(e,s){return this.setLimit("max",e,!0,pe.toString(s))}lt(e,s){return this.setLimit("max",e,!1,pe.toString(s))}setLimit(e,s,n,r){return new Jn({...this._def,checks:[...this._def.checks,{kind:e,value:s,inclusive:n,message:pe.toString(r)}]})}_addCheck(e){return new Jn({...this._def,checks:[...this._def.checks,e]})}positive(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:pe.toString(e)})}negative(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:pe.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:pe.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:pe.toString(e)})}multipleOf(e,s){return this._addCheck({kind:"multipleOf",value:e,message:pe.toString(s)})}get minValue(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxValue(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}}Jn.create=t=>{var e;return new Jn({checks:[],typeName:me.ZodBigInt,coerce:(e=t==null?void 0:t.coerce)!==null&&e!==void 0?e:!1,...Ce(t)})};class so extends Ae{_parse(e){if(this._def.coerce&&(e.data=!!e.data),this._getType(e)!==se.boolean){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.boolean,received:n.parsedType}),be}return Ft(e.data)}}so.create=t=>new so({typeName:me.ZodBoolean,coerce:(t==null?void 0:t.coerce)||!1,...Ce(t)});class Sr extends Ae{_parse(e){if(this._def.coerce&&(e.data=new Date(e.data)),this._getType(e)!==se.date){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.date,received:i.parsedType}),be}if(isNaN(e.data.getTime())){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_date}),be}const n=new kt;let r;for(const i of this._def.checks)i.kind==="min"?e.data.getTime()<i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_small,message:i.message,inclusive:!0,exact:!1,minimum:i.value,type:"date"}),n.dirty()):i.kind==="max"?e.data.getTime()>i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_big,message:i.message,inclusive:!0,exact:!1,maximum:i.value,type:"date"}),n.dirty()):Le.assertNever(i);return{status:n.value,value:new Date(e.data.getTime())}}_addCheck(e){return new Sr({...this._def,checks:[...this._def.checks,e]})}min(e,s){return this._addCheck({kind:"min",value:e.getTime(),message:pe.toString(s)})}max(e,s){return this._addCheck({kind:"max",value:e.getTime(),message:pe.toString(s)})}get minDate(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e!=null?new Date(e):null}get maxDate(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e!=null?new Date(e):null}}Sr.create=t=>new Sr({checks:[],coerce:(t==null?void 0:t.coerce)||!1,typeName:me.ZodDate,...Ce(t)});class Na extends Ae{_parse(e){if(this._getType(e)!==se.symbol){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.symbol,received:n.parsedType}),be}return Ft(e.data)}}Na.create=t=>new Na({typeName:me.ZodSymbol,...Ce(t)});class no extends Ae{_parse(e){if(this._getType(e)!==se.undefined){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.undefined,received:n.parsedType}),be}return Ft(e.data)}}no.create=t=>new no({typeName:me.ZodUndefined,...Ce(t)});class ro extends Ae{_parse(e){if(this._getType(e)!==se.null){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.null,received:n.parsedType}),be}return Ft(e.data)}}ro.create=t=>new ro({typeName:me.ZodNull,...Ce(t)});class ci extends Ae{constructor(){super(...arguments),this._any=!0}_parse(e){return Ft(e.data)}}ci.create=t=>new ci({typeName:me.ZodAny,...Ce(t)});class Cr extends Ae{constructor(){super(...arguments),this._unknown=!0}_parse(e){return Ft(e.data)}}Cr.create=t=>new Cr({typeName:me.ZodUnknown,...Ce(t)});class Sn extends Ae{_parse(e){const s=this._getOrReturnCtx(e);return ie(s,{code:K.invalid_type,expected:se.never,received:s.parsedType}),be}}Sn.create=t=>new Sn({typeName:me.ZodNever,...Ce(t)});class Ta extends Ae{_parse(e){if(this._getType(e)!==se.undefined){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.void,received:n.parsedType}),be}return Ft(e.data)}}Ta.create=t=>new Ta({typeName:me.ZodVoid,...Ce(t)});class $s extends Ae{_parse(e){const{ctx:s,status:n}=this._processInputParams(e),r=this._def;if(s.parsedType!==se.array)return ie(s,{code:K.invalid_type,expected:se.array,received:s.parsedType}),be;if(r.exactLength!==null){const o=s.data.length>r.exactLength.value,a=s.data.length<r.exactLength.value;(o||a)&&(ie(s,{code:o?K.too_big:K.too_small,minimum:a?r.exactLength.value:void 0,maximum:o?r.exactLength.value:void 0,type:"array",inclusive:!0,exact:!0,message:r.exactLength.message}),n.dirty())}if(r.minLength!==null&&s.data.length<r.minLength.value&&(ie(s,{code:K.too_small,minimum:r.minLength.value,type:"array",inclusive:!0,exact:!1,message:r.minLength.message}),n.dirty()),r.maxLength!==null&&s.data.length>r.maxLength.value&&(ie(s,{code:K.too_big,maximum:r.maxLength.value,type:"array",inclusive:!0,exact:!1,message:r.maxLength.message}),n.dirty()),s.common.async)return Promise.all([...s.data].map((o,a)=>r.type._parseAsync(new Qs(s,o,s.path,a)))).then(o=>kt.mergeArray(n,o));const i=[...s.data].map((o,a)=>r.type._parseSync(new Qs(s,o,s.path,a)));return kt.mergeArray(n,i)}get element(){return this._def.type}min(e,s){return new $s({...this._def,minLength:{value:e,message:pe.toString(s)}})}max(e,s){return new $s({...this._def,maxLength:{value:e,message:pe.toString(s)}})}length(e,s){return new $s({...this._def,exactLength:{value:e,message:pe.toString(s)}})}nonempty(e){return this.min(1,e)}}$s.create=(t,e)=>new $s({type:t,minLength:null,maxLength:null,exactLength:null,typeName:me.ZodArray,...Ce(e)});function Vr(t){if(t instanceof Xe){const e={};for(const s in t.shape){const n=t.shape[s];e[s]=bn.create(Vr(n))}return new Xe({...t._def,shape:()=>e})}else return t instanceof $s?new $s({...t._def,type:Vr(t.element)}):t instanceof bn?bn.create(Vr(t.unwrap())):t instanceof Nr?Nr.create(Vr(t.unwrap())):t instanceof en?en.create(t.items.map(e=>Vr(e))):t}class Xe extends Ae{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;const e=this._def.shape(),s=Le.objectKeys(e);return this._cached={shape:e,keys:s}}_parse(e){if(this._getType(e)!==se.object){const l=this._getOrReturnCtx(e);return ie(l,{code:K.invalid_type,expected:se.object,received:l.parsedType}),be}const{status:n,ctx:r}=this._processInputParams(e),{shape:i,keys:o}=this._getCached(),a=[];if(!(this._def.catchall instanceof Sn&&this._def.unknownKeys==="strip"))for(const l in r.data)o.includes(l)||a.push(l);const c=[];for(const l of o){const d=i[l],u=r.data[l];c.push({key:{status:"valid",value:l},value:d._parse(new Qs(r,u,r.path,l)),alwaysSet:l in r.data})}if(this._def.catchall instanceof Sn){const l=this._def.unknownKeys;if(l==="passthrough")for(const d of a)c.push({key:{status:"valid",value:d},value:{status:"valid",value:r.data[d]}});else if(l==="strict")a.length>0&&(ie(r,{code:K.unrecognized_keys,keys:a}),n.dirty());else if(l!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{const l=this._def.catchall;for(const d of a){const u=r.data[d];c.push({key:{status:"valid",value:d},value:l._parse(new Qs(r,u,r.path,d)),alwaysSet:d in r.data})}}return r.common.async?Promise.resolve().then(async()=>{const l=[];for(const d of c){const u=await d.key;l.push({key:u,value:await d.value,alwaysSet:d.alwaysSet})}return l}).then(l=>kt.mergeObjectSync(n,l)):kt.mergeObjectSync(n,c)}get shape(){return this._def.shape()}strict(e){return pe.errToObj,new Xe({...this._def,unknownKeys:"strict",...e!==void 0?{errorMap:(s,n)=>{var r,i,o,a;const c=(o=(i=(r=this._def).errorMap)===null||i===void 0?void 0:i.call(r,s,n).message)!==null&&o!==void 0?o:n.defaultError;return s.code==="unrecognized_keys"?{message:(a=pe.errToObj(e).message)!==null&&a!==void 0?a:c}:{message:c}}}:{}})}strip(){return new Xe({...this._def,unknownKeys:"strip"})}passthrough(){return new Xe({...this._def,unknownKeys:"passthrough"})}extend(e){return new Xe({...this._def,shape:()=>({...this._def.shape(),...e})})}merge(e){return new Xe({unknownKeys:e._def.unknownKeys,catchall:e._def.catchall,shape:()=>({...this._def.shape(),...e._def.shape()}),typeName:me.ZodObject})}setKey(e,s){return this.augment({[e]:s})}catchall(e){return new Xe({...this._def,catchall:e})}pick(e){const s={};return Le.objectKeys(e).forEach(n=>{e[n]&&this.shape[n]&&(s[n]=this.shape[n])}),new Xe({...this._def,shape:()=>s})}omit(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{e[n]||(s[n]=this.shape[n])}),new Xe({...this._def,shape:()=>s})}deepPartial(){return Vr(this)}partial(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{const r=this.shape[n];e&&!e[n]?s[n]=r:s[n]=r.optional()}),new Xe({...this._def,shape:()=>s})}required(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{if(e&&!e[n])s[n]=this.shape[n];else{let i=this.shape[n];for(;i instanceof bn;)i=i._def.innerType;s[n]=i}}),new Xe({...this._def,shape:()=>s})}keyof(){return Df(Le.objectKeys(this.shape))}}Xe.create=(t,e)=>new Xe({shape:()=>t,unknownKeys:"strip",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});Xe.strictCreate=(t,e)=>new Xe({shape:()=>t,unknownKeys:"strict",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});Xe.lazycreate=(t,e)=>new Xe({shape:t,unknownKeys:"strip",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});class io extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n=this._def.options;function r(i){for(const a of i)if(a.result.status==="valid")return a.result;for(const a of i)if(a.result.status==="dirty")return s.common.issues.push(...a.ctx.common.issues),a.result;const o=i.map(a=>new Us(a.ctx.common.issues));return ie(s,{code:K.invalid_union,unionErrors:o}),be}if(s.common.async)return Promise.all(n.map(async i=>{const o={...s,common:{...s.common,issues:[]},parent:null};return{result:await i._parseAsync({data:s.data,path:s.path,parent:o}),ctx:o}})).then(r);{let i;const o=[];for(const c of n){const l={...s,common:{...s.common,issues:[]},parent:null},d=c._parseSync({data:s.data,path:s.path,parent:l});if(d.status==="valid")return d;d.status==="dirty"&&!i&&(i={result:d,ctx:l}),l.common.issues.length&&o.push(l.common.issues)}if(i)return s.common.issues.push(...i.ctx.common.issues),i.result;const a=o.map(c=>new Us(c));return ie(s,{code:K.invalid_union,unionErrors:a}),be}}get options(){return this._def.options}}io.create=(t,e)=>new io({options:t,typeName:me.ZodUnion,...Ce(e)});const ha=t=>t instanceof co?ha(t.schema):t instanceof Ls?ha(t.innerType()):t instanceof lo?[t.value]:t instanceof Xn?t.options:t instanceof uo?Object.keys(t.enum):t instanceof ho?ha(t._def.innerType):t instanceof no?[void 0]:t instanceof ro?[null]:null;class sc extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.object)return ie(s,{code:K.invalid_type,expected:se.object,received:s.parsedType}),be;const n=this.discriminator,r=s.data[n],i=this.optionsMap.get(r);return i?s.common.async?i._parseAsync({data:s.data,path:s.path,parent:s}):i._parseSync({data:s.data,path:s.path,parent:s}):(ie(s,{code:K.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[n]}),be)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(e,s,n){const r=new Map;for(const i of s){const o=ha(i.shape[e]);if(!o)throw new Error(`A discriminator value for key \`${e}\` could not be extracted from all schema options`);for(const a of o){if(r.has(a))throw new Error(`Discriminator property ${String(e)} has duplicate value ${String(a)}`);r.set(a,i)}}return new sc({typeName:me.ZodDiscriminatedUnion,discriminator:e,options:s,optionsMap:r,...Ce(n)})}}function Tl(t,e){const s=Bn(t),n=Bn(e);if(t===e)return{valid:!0,data:t};if(s===se.object&&n===se.object){const r=Le.objectKeys(e),i=Le.objectKeys(t).filter(a=>r.indexOf(a)!==-1),o={...t,...e};for(const a of i){const c=Tl(t[a],e[a]);if(!c.valid)return{valid:!1};o[a]=c.data}return{valid:!0,data:o}}else if(s===se.array&&n===se.array){if(t.length!==e.length)return{valid:!1};const r=[];for(let i=0;i<t.length;i++){const o=t[i],a=e[i],c=Tl(o,a);if(!c.valid)return{valid:!1};r.push(c.data)}return{valid:!0,data:r}}else return s===se.date&&n===se.date&&+t==+e?{valid:!0,data:t}:{valid:!1}}class oo extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e),r=(i,o)=>{if(Il(i)||Il(o))return be;const a=Tl(i.value,o.value);return a.valid?((Nl(i)||Nl(o))&&s.dirty(),{status:s.value,value:a.data}):(ie(n,{code:K.invalid_intersection_types}),be)};return n.common.async?Promise.all([this._def.left._parseAsync({data:n.data,path:n.path,parent:n}),this._def.right._parseAsync({data:n.data,path:n.path,parent:n})]).then(([i,o])=>r(i,o)):r(this._def.left._parseSync({data:n.data,path:n.path,parent:n}),this._def.right._parseSync({data:n.data,path:n.path,parent:n}))}}oo.create=(t,e,s)=>new oo({left:t,right:e,typeName:me.ZodIntersection,...Ce(s)});class en extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.array)return ie(n,{code:K.invalid_type,expected:se.array,received:n.parsedType}),be;if(n.data.length<this._def.items.length)return ie(n,{code:K.too_small,minimum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),be;!this._def.rest&&n.data.length>this._def.items.length&&(ie(n,{code:K.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),s.dirty());const i=[...n.data].map((o,a)=>{const c=this._def.items[a]||this._def.rest;return c?c._parse(new Qs(n,o,n.path,a)):null}).filter(o=>!!o);return n.common.async?Promise.all(i).then(o=>kt.mergeArray(s,o)):kt.mergeArray(s,i)}get items(){return this._def.items}rest(e){return new en({...this._def,rest:e})}}en.create=(t,e)=>{if(!Array.isArray(t))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new en({items:t,typeName:me.ZodTuple,rest:null,...Ce(e)})};class ao extends Ae{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.object)return ie(n,{code:K.invalid_type,expected:se.object,received:n.parsedType}),be;const r=[],i=this._def.keyType,o=this._def.valueType;for(const a in n.data)r.push({key:i._parse(new Qs(n,a,n.path,a)),value:o._parse(new Qs(n,n.data[a],n.path,a))});return n.common.async?kt.mergeObjectAsync(s,r):kt.mergeObjectSync(s,r)}get element(){return this._def.valueType}static create(e,s,n){return s instanceof Ae?new ao({keyType:e,valueType:s,typeName:me.ZodRecord,...Ce(n)}):new ao({keyType:ks.create(),valueType:e,typeName:me.ZodRecord,...Ce(s)})}}class Ra extends Ae{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.map)return ie(n,{code:K.invalid_type,expected:se.map,received:n.parsedType}),be;const r=this._def.keyType,i=this._def.valueType,o=[...n.data.entries()].map(([a,c],l)=>({key:r._parse(new Qs(n,a,n.path,[l,"key"])),value:i._parse(new Qs(n,c,n.path,[l,"value"]))}));if(n.common.async){const a=new Map;return Promise.resolve().then(async()=>{for(const c of o){const l=await c.key,d=await c.value;if(l.status==="aborted"||d.status==="aborted")return be;(l.status==="dirty"||d.status==="dirty")&&s.dirty(),a.set(l.value,d.value)}return{status:s.value,value:a}})}else{const a=new Map;for(const c of o){const l=c.key,d=c.value;if(l.status==="aborted"||d.status==="aborted")return be;(l.status==="dirty"||d.status==="dirty")&&s.dirty(),a.set(l.value,d.value)}return{status:s.value,value:a}}}}Ra.create=(t,e,s)=>new Ra({valueType:e,keyType:t,typeName:me.ZodMap,...Ce(s)});class Ir extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.set)return ie(n,{code:K.invalid_type,expected:se.set,received:n.parsedType}),be;const r=this._def;r.minSize!==null&&n.data.size<r.minSize.value&&(ie(n,{code:K.too_small,minimum:r.minSize.value,type:"set",inclusive:!0,exact:!1,message:r.minSize.message}),s.dirty()),r.maxSize!==null&&n.data.size>r.maxSize.value&&(ie(n,{code:K.too_big,maximum:r.maxSize.value,type:"set",inclusive:!0,exact:!1,message:r.maxSize.message}),s.dirty());const i=this._def.valueType;function o(c){const l=new Set;for(const d of c){if(d.status==="aborted")return be;d.status==="dirty"&&s.dirty(),l.add(d.value)}return{status:s.value,value:l}}const a=[...n.data.values()].map((c,l)=>i._parse(new Qs(n,c,n.path,l)));return n.common.async?Promise.all(a).then(c=>o(c)):o(a)}min(e,s){return new Ir({...this._def,minSize:{value:e,message:pe.toString(s)}})}max(e,s){return new Ir({...this._def,maxSize:{value:e,message:pe.toString(s)}})}size(e,s){return this.min(e,s).max(e,s)}nonempty(e){return this.min(1,e)}}Ir.create=(t,e)=>new Ir({valueType:t,minSize:null,maxSize:null,typeName:me.ZodSet,...Ce(e)});class ei extends Ae{constructor(){super(...arguments),this.validate=this.implement}_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.function)return ie(s,{code:K.invalid_type,expected:se.function,received:s.parsedType}),be;function n(a,c){return Sa({data:a,path:s.path,errorMaps:[s.common.contextualErrorMap,s.schemaErrorMap,Aa(),eo].filter(l=>!!l),issueData:{code:K.invalid_arguments,argumentsError:c}})}function r(a,c){return Sa({data:a,path:s.path,errorMaps:[s.common.contextualErrorMap,s.schemaErrorMap,Aa(),eo].filter(l=>!!l),issueData:{code:K.invalid_return_type,returnTypeError:c}})}const i={errorMap:s.common.contextualErrorMap},o=s.data;if(this._def.returns instanceof li){const a=this;return Ft(async function(...c){const l=new Us([]),d=await a._def.args.parseAsync(c,i).catch(p=>{throw l.addIssue(n(c,p)),l}),u=await Reflect.apply(o,this,d);return await a._def.returns._def.type.parseAsync(u,i).catch(p=>{throw l.addIssue(r(u,p)),l})})}else{const a=this;return Ft(function(...c){const l=a._def.args.safeParse(c,i);if(!l.success)throw new Us([n(c,l.error)]);const d=Reflect.apply(o,this,l.data),u=a._def.returns.safeParse(d,i);if(!u.success)throw new Us([r(d,u.error)]);return u.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...e){return new ei({...this._def,args:en.create(e).rest(Cr.create())})}returns(e){return new ei({...this._def,returns:e})}implement(e){return this.parse(e)}strictImplement(e){return this.parse(e)}static create(e,s,n){return new ei({args:e||en.create([]).rest(Cr.create()),returns:s||Cr.create(),typeName:me.ZodFunction,...Ce(n)})}}class co extends Ae{get schema(){return this._def.getter()}_parse(e){const{ctx:s}=this._processInputParams(e);return this._def.getter()._parse({data:s.data,path:s.path,parent:s})}}co.create=(t,e)=>new co({getter:t,typeName:me.ZodLazy,...Ce(e)});class lo extends Ae{_parse(e){if(e.data!==this._def.value){const s=this._getOrReturnCtx(e);return ie(s,{received:s.data,code:K.invalid_literal,expected:this._def.value}),be}return{status:"valid",value:e.data}}get value(){return this._def.value}}lo.create=(t,e)=>new lo({value:t,typeName:me.ZodLiteral,...Ce(e)});function Df(t,e){return new Xn({values:t,typeName:me.ZodEnum,...Ce(e)})}class Xn extends Ae{_parse(e){if(typeof e.data!="string"){const s=this._getOrReturnCtx(e),n=this._def.values;return ie(s,{expected:Le.joinValues(n),received:s.parsedType,code:K.invalid_type}),be}if(this._def.values.indexOf(e.data)===-1){const s=this._getOrReturnCtx(e),n=this._def.values;return ie(s,{received:s.data,code:K.invalid_enum_value,options:n}),be}return Ft(e.data)}get options(){return this._def.values}get enum(){const e={};for(const s of this._def.values)e[s]=s;return e}get Values(){const e={};for(const s of this._def.values)e[s]=s;return e}get Enum(){const e={};for(const s of this._def.values)e[s]=s;return e}extract(e){return Xn.create(e)}exclude(e){return Xn.create(this.options.filter(s=>!e.includes(s)))}}Xn.create=Df;class uo extends Ae{_parse(e){const s=Le.getValidEnumValues(this._def.values),n=this._getOrReturnCtx(e);if(n.parsedType!==se.string&&n.parsedType!==se.number){const r=Le.objectValues(s);return ie(n,{expected:Le.joinValues(r),received:n.parsedType,code:K.invalid_type}),be}if(s.indexOf(e.data)===-1){const r=Le.objectValues(s);return ie(n,{received:n.data,code:K.invalid_enum_value,options:r}),be}return Ft(e.data)}get enum(){return this._def.values}}uo.create=(t,e)=>new uo({values:t,typeName:me.ZodNativeEnum,...Ce(e)});class li extends Ae{unwrap(){return this._def.type}_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.promise&&s.common.async===!1)return ie(s,{code:K.invalid_type,expected:se.promise,received:s.parsedType}),be;const n=s.parsedType===se.promise?s.data:Promise.resolve(s.data);return Ft(n.then(r=>this._def.type.parseAsync(r,{path:s.path,errorMap:s.common.contextualErrorMap})))}}li.create=(t,e)=>new li({type:t,typeName:me.ZodPromise,...Ce(e)});class Ls extends Ae{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===me.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(e){const{status:s,ctx:n}=this._processInputParams(e),r=this._def.effect||null,i={addIssue:o=>{ie(n,o),o.fatal?s.abort():s.dirty()},get path(){return n.path}};if(i.addIssue=i.addIssue.bind(i),r.type==="preprocess"){const o=r.transform(n.data,i);return n.common.issues.length?{status:"dirty",value:n.data}:n.common.async?Promise.resolve(o).then(a=>this._def.schema._parseAsync({data:a,path:n.path,parent:n})):this._def.schema._parseSync({data:o,path:n.path,parent:n})}if(r.type==="refinement"){const o=a=>{const c=r.refinement(a,i);if(n.common.async)return Promise.resolve(c);if(c instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return a};if(n.common.async===!1){const a=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});return a.status==="aborted"?be:(a.status==="dirty"&&s.dirty(),o(a.value),{status:s.value,value:a.value})}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(a=>a.status==="aborted"?be:(a.status==="dirty"&&s.dirty(),o(a.value).then(()=>({status:s.value,value:a.value}))))}if(r.type==="transform")if(n.common.async===!1){const o=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});if(!to(o))return o;const a=r.transform(o.value,i);if(a instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:s.value,value:a}}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(o=>to(o)?Promise.resolve(r.transform(o.value,i)).then(a=>({status:s.value,value:a})):o);Le.assertNever(r)}}Ls.create=(t,e,s)=>new Ls({schema:t,typeName:me.ZodEffects,effect:e,...Ce(s)});Ls.createWithPreprocess=(t,e,s)=>new Ls({schema:e,effect:{type:"preprocess",transform:t},typeName:me.ZodEffects,...Ce(s)});class bn extends Ae{_parse(e){return this._getType(e)===se.undefined?Ft(void 0):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}}bn.create=(t,e)=>new bn({innerType:t,typeName:me.ZodOptional,...Ce(e)});class Nr extends Ae{_parse(e){return this._getType(e)===se.null?Ft(null):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}}Nr.create=(t,e)=>new Nr({innerType:t,typeName:me.ZodNullable,...Ce(e)});class ho extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e);let n=s.data;return s.parsedType===se.undefined&&(n=this._def.defaultValue()),this._def.innerType._parse({data:n,path:s.path,parent:s})}removeDefault(){return this._def.innerType}}ho.create=(t,e)=>new ho({innerType:t,typeName:me.ZodDefault,defaultValue:typeof e.default=="function"?e.default:()=>e.default,...Ce(e)});class Oa extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n={...s,common:{...s.common,issues:[]}},r=this._def.innerType._parse({data:n.data,path:n.path,parent:{...n}});return Ia(r)?r.then(i=>({status:"valid",value:i.status==="valid"?i.value:this._def.catchValue({get error(){return new Us(n.common.issues)},input:n.data})})):{status:"valid",value:r.status==="valid"?r.value:this._def.catchValue({get error(){return new Us(n.common.issues)},input:n.data})}}removeCatch(){return this._def.innerType}}Oa.create=(t,e)=>new Oa({innerType:t,typeName:me.ZodCatch,catchValue:typeof e.catch=="function"?e.catch:()=>e.catch,...Ce(e)});class Pa extends Ae{_parse(e){if(this._getType(e)!==se.nan){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.nan,received:n.parsedType}),be}return{status:"valid",value:e.data}}}Pa.create=t=>new Pa({typeName:me.ZodNaN,...Ce(t)});const Ww=Symbol("zod_brand");class Lf extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n=s.data;return this._def.type._parse({data:n,path:s.path,parent:s})}unwrap(){return this._def.type}}class Ao extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.common.async)return(async()=>{const i=await this._def.in._parseAsync({data:n.data,path:n.path,parent:n});return i.status==="aborted"?be:i.status==="dirty"?(s.dirty(),$f(i.value)):this._def.out._parseAsync({data:i.value,path:n.path,parent:n})})();{const r=this._def.in._parseSync({data:n.data,path:n.path,parent:n});return r.status==="aborted"?be:r.status==="dirty"?(s.dirty(),{status:"dirty",value:r.value}):this._def.out._parseSync({data:r.value,path:n.path,parent:n})}}static create(e,s){return new Ao({in:e,out:s,typeName:me.ZodPipeline})}}class xa extends Ae{_parse(e){const s=this._def.innerType._parse(e);return to(s)&&(s.value=Object.freeze(s.value)),s}}xa.create=(t,e)=>new xa({innerType:t,typeName:me.ZodReadonly,...Ce(e)});const Mf=(t,e={},s)=>t?ci.create().superRefine((n,r)=>{var i,o;if(!t(n)){const a=typeof e=="function"?e(n):typeof e=="string"?{message:e}:e,c=(o=(i=a.fatal)!==null&&i!==void 0?i:s)!==null&&o!==void 0?o:!0,l=typeof a=="string"?{message:a}:a;r.addIssue({code:"custom",...l,fatal:c})}}):ci.create(),Hw={object:Xe.lazycreate};var me;(function(t){t.ZodString="ZodString",t.ZodNumber="ZodNumber",t.ZodNaN="ZodNaN",t.ZodBigInt="ZodBigInt",t.ZodBoolean="ZodBoolean",t.ZodDate="ZodDate",t.ZodSymbol="ZodSymbol",t.ZodUndefined="ZodUndefined",t.ZodNull="ZodNull",t.ZodAny="ZodAny",t.ZodUnknown="ZodUnknown",t.ZodNever="ZodNever",t.ZodVoid="ZodVoid",t.ZodArray="ZodArray",t.ZodObject="ZodObject",t.ZodUnion="ZodUnion",t.ZodDiscriminatedUnion="ZodDiscriminatedUnion",t.ZodIntersection="ZodIntersection",t.ZodTuple="ZodTuple",t.ZodRecord="ZodRecord",t.ZodMap="ZodMap",t.ZodSet="ZodSet",t.ZodFunction="ZodFunction",t.ZodLazy="ZodLazy",t.ZodLiteral="ZodLiteral",t.ZodEnum="ZodEnum",t.ZodEffects="ZodEffects",t.ZodNativeEnum="ZodNativeEnum",t.ZodOptional="ZodOptional",t.ZodNullable="ZodNullable",t.ZodDefault="ZodDefault",t.ZodCatch="ZodCatch",t.ZodPromise="ZodPromise",t.ZodBranded="ZodBranded",t.ZodPipeline="ZodPipeline",t.ZodReadonly="ZodReadonly"})(me||(me={}));const zw=(t,e={message:`Input not instance of ${t.name}`})=>Mf(s=>s instanceof t,e),Bf=ks.create,jf=Zn.create,Vw=Pa.create,Kw=Jn.create,Ff=so.create,Gw=Sr.create,Yw=Na.create,Zw=no.create,Jw=ro.create,Xw=ci.create,Qw=Cr.create,eE=Sn.create,tE=Ta.create,sE=$s.create,nE=Xe.create,rE=Xe.strictCreate,iE=io.create,oE=sc.create,aE=oo.create,cE=en.create,lE=ao.create,dE=Ra.create,uE=Ir.create,hE=ei.create,pE=co.create,fE=lo.create,gE=Xn.create,mE=uo.create,yE=li.create,$u=Ls.create,wE=bn.create,EE=Nr.create,bE=Ls.createWithPreprocess,vE=Ao.create,CE=()=>Bf().optional(),_E=()=>jf().optional(),AE=()=>Ff().optional(),SE={string:t=>ks.create({...t,coerce:!0}),number:t=>Zn.create({...t,coerce:!0}),boolean:t=>so.create({...t,coerce:!0}),bigint:t=>Jn.create({...t,coerce:!0}),date:t=>Sr.create({...t,coerce:!0})},IE=be;var m=Object.freeze({__proto__:null,defaultErrorMap:eo,setErrorMap:Ow,getErrorMap:Aa,makeIssue:Sa,EMPTY_PATH:Pw,addIssueToContext:ie,ParseStatus:kt,INVALID:be,DIRTY:$f,OK:Ft,isAborted:Il,isDirty:Nl,isValid:to,isAsync:Ia,get util(){return Le},get objectUtil(){return Sl},ZodParsedType:se,getParsedType:Bn,ZodType:Ae,ZodString:ks,ZodNumber:Zn,ZodBigInt:Jn,ZodBoolean:so,ZodDate:Sr,ZodSymbol:Na,ZodUndefined:no,ZodNull:ro,ZodAny:ci,ZodUnknown:Cr,ZodNever:Sn,ZodVoid:Ta,ZodArray:$s,ZodObject:Xe,ZodUnion:io,ZodDiscriminatedUnion:sc,ZodIntersection:oo,ZodTuple:en,ZodRecord:ao,ZodMap:Ra,ZodSet:Ir,ZodFunction:ei,ZodLazy:co,ZodLiteral:lo,ZodEnum:Xn,ZodNativeEnum:uo,ZodPromise:li,ZodEffects:Ls,ZodTransformer:Ls,ZodOptional:bn,ZodNullable:Nr,ZodDefault:ho,ZodCatch:Oa,ZodNaN:Pa,BRAND:Ww,ZodBranded:Lf,ZodPipeline:Ao,ZodReadonly:xa,custom:Mf,Schema:Ae,ZodSchema:Ae,late:Hw,get ZodFirstPartyTypeKind(){return me},coerce:SE,any:Xw,array:sE,bigint:Kw,boolean:Ff,date:Gw,discriminatedUnion:oE,effect:$u,enum:gE,function:hE,instanceof:zw,intersection:aE,lazy:pE,literal:fE,map:dE,nan:Vw,nativeEnum:mE,never:eE,null:Jw,nullable:EE,number:jf,object:nE,oboolean:AE,onumber:_E,optional:wE,ostring:CE,pipeline:vE,preprocess:bE,promise:yE,record:lE,set:uE,strictObject:rE,string:Bf,symbol:Yw,transformer:$u,tuple:cE,undefined:Zw,union:iE,unknown:Qw,void:tE,NEVER:IE,ZodIssueCode:K,quotelessJson:Rw,ZodError:Us});const Qe=m.object({message:m.string()});function ne(t){return m.literal(oe[t])}const nc=m.object({serializedMessage:m.string().optional(),accountAddress:m.string(),chainId:m.string(),notBefore:m.string().optional(),domain:m.string(),uri:m.string(),version:m.string(),nonce:m.string(),statement:m.string().optional(),resources:m.array(m.string()).optional(),requestId:m.string().optional(),issuedAt:m.string().optional(),expirationTime:m.string().optional()});m.object({accessList:m.array(m.string()),blockHash:m.string().nullable(),blockNumber:m.string().nullable(),chainId:m.string().or(m.number()),from:m.string(),gas:m.string(),hash:m.string(),input:m.string().nullable(),maxFeePerGas:m.string(),maxPriorityFeePerGas:m.string(),nonce:m.string(),r:m.string(),s:m.string(),to:m.string(),transactionIndex:m.string().nullable(),type:m.string(),v:m.string(),value:m.string()});const NE=m.object({chainId:m.string().or(m.number()),rpcUrl:m.optional(m.string())}),TE=m.object({email:m.string().email()}),RE=m.object({otp:m.string()}),OE=m.object({uri:m.string(),preferredAccountType:m.optional(m.string()),chainId:m.optional(m.string().or(m.number())),siwxMessage:m.optional(nc),rpcUrl:m.optional(m.string())}),PE=m.object({chainId:m.optional(m.string().or(m.number())),preferredAccountType:m.optional(m.string()),socialUri:m.optional(m.string()),siwxMessage:m.optional(nc),rpcUrl:m.optional(m.string())}),xE=m.object({provider:m.enum(["google","github","apple","facebook","x","discord"])}),kE=m.object({email:m.string().email()}),UE=m.object({otp:m.string()}),$E=m.object({otp:m.string()}),DE=m.object({themeMode:m.optional(m.enum(["light","dark"])),themeVariables:m.optional(m.record(m.string(),m.string().or(m.number()))),w3mThemeVariables:m.optional(m.record(m.string(),m.string()))}),LE=m.object({metadata:m.object({name:m.string(),description:m.string(),url:m.string(),icons:m.array(m.string())}).optional(),sdkVersion:m.string().optional(),sdkType:m.string().optional(),projectId:m.string()}),ME=m.object({type:m.string()}),BE=m.object({action:m.enum(["VERIFY_DEVICE","VERIFY_OTP","CONNECT"])}),jE=m.object({url:m.string()}),FE=m.object({userName:m.string()}),qE=m.object({email:m.string().optional().nullable(),address:m.string(),chainId:m.string().or(m.number()),accounts:m.array(m.object({address:m.string(),type:m.enum([tt.ACCOUNT_TYPES.EOA,tt.ACCOUNT_TYPES.SMART_ACCOUNT])})).optional(),userName:m.string().optional().nullable(),preferredAccountType:m.optional(m.string()),signature:m.string().optional(),message:m.string().optional(),siwxMessage:m.optional(nc)}),WE=m.object({action:m.enum(["VERIFY_PRIMARY_OTP","VERIFY_SECONDARY_OTP"])}),HE=m.object({email:m.string().email().optional().nullable(),address:m.string(),chainId:m.string().or(m.number()),smartAccountDeployed:m.optional(m.boolean()),accounts:m.array(m.object({address:m.string(),type:m.enum([tt.ACCOUNT_TYPES.EOA,tt.ACCOUNT_TYPES.SMART_ACCOUNT])})).optional(),preferredAccountType:m.optional(m.string()),signature:m.string().optional(),message:m.string().optional(),siwxMessage:m.optional(nc)}),zE=m.object({uri:m.string()}),VE=m.object({isConnected:m.boolean()}),KE=m.object({chainId:m.string().or(m.number())}),GE=m.object({chainId:m.string().or(m.number())}),YE=m.object({newEmail:m.string().email()}),ZE=m.object({smartAccountEnabledNetworks:m.array(m.number())});m.object({address:m.string(),isDeployed:m.boolean()});const JE=m.object({version:m.string().optional()}),XE=m.object({type:m.string(),address:m.string()}),QE=m.any(),eb=m.object({method:m.literal("eth_accounts")}),tb=m.object({method:m.literal("eth_blockNumber")}),sb=m.object({method:m.literal("eth_call"),params:m.array(m.any())}),nb=m.object({method:m.literal("eth_chainId")}),rb=m.object({method:m.literal("eth_estimateGas"),params:m.array(m.any())}),ib=m.object({method:m.literal("eth_feeHistory"),params:m.array(m.any())}),ob=m.object({method:m.literal("eth_gasPrice")}),ab=m.object({method:m.literal("eth_getAccount"),params:m.array(m.any())}),cb=m.object({method:m.literal("eth_getBalance"),params:m.array(m.any())}),lb=m.object({method:m.literal("eth_getBlockByHash"),params:m.array(m.any())}),db=m.object({method:m.literal("eth_getBlockByNumber"),params:m.array(m.any())}),ub=m.object({method:m.literal("eth_getBlockReceipts"),params:m.array(m.any())}),hb=m.object({method:m.literal("eth_getBlockTransactionCountByHash"),params:m.array(m.any())}),pb=m.object({method:m.literal("eth_getBlockTransactionCountByNumber"),params:m.array(m.any())}),fb=m.object({method:m.literal("eth_getCode"),params:m.array(m.any())}),gb=m.object({method:m.literal("eth_getFilterChanges"),params:m.array(m.any())}),mb=m.object({method:m.literal("eth_getFilterLogs"),params:m.array(m.any())}),yb=m.object({method:m.literal("eth_getLogs"),params:m.array(m.any())}),wb=m.object({method:m.literal("eth_getProof"),params:m.array(m.any())}),Eb=m.object({method:m.literal("eth_getStorageAt"),params:m.array(m.any())}),bb=m.object({method:m.literal("eth_getTransactionByBlockHashAndIndex"),params:m.array(m.any())}),vb=m.object({method:m.literal("eth_getTransactionByBlockNumberAndIndex"),params:m.array(m.any())}),Cb=m.object({method:m.literal("eth_getTransactionByHash"),params:m.array(m.any())}),_b=m.object({method:m.literal("eth_getTransactionCount"),params:m.array(m.any())}),Ab=m.object({method:m.literal("eth_getTransactionReceipt"),params:m.array(m.any())}),Sb=m.object({method:m.literal("eth_getUncleCountByBlockHash"),params:m.array(m.any())}),Ib=m.object({method:m.literal("eth_getUncleCountByBlockNumber"),params:m.array(m.any())}),Nb=m.object({method:m.literal("eth_maxPriorityFeePerGas")}),Tb=m.object({method:m.literal("eth_newBlockFilter")}),Rb=m.object({method:m.literal("eth_newFilter"),params:m.array(m.any())}),Ob=m.object({method:m.literal("eth_newPendingTransactionFilter")}),Pb=m.object({method:m.literal("eth_sendRawTransaction"),params:m.array(m.any())}),xb=m.object({method:m.literal("eth_syncing"),params:m.array(m.any())}),kb=m.object({method:m.literal("eth_uninstallFilter"),params:m.array(m.any())}),Du=m.object({method:m.literal("personal_sign"),params:m.array(m.any())}),Ub=m.object({method:m.literal("eth_signTypedData_v4"),params:m.array(m.any())}),$b=m.object({method:m.literal("eth_sendTransaction"),params:m.array(m.any())}),Db=m.object({method:m.literal("solana_signMessage"),params:m.object({message:m.string(),pubkey:m.string()})}),Lb=m.object({method:m.literal("solana_signTransaction"),params:m.object({transaction:m.string()})}),Mb=m.object({method:m.literal("solana_signAllTransactions"),params:m.object({transactions:m.array(m.string())})}),Bb=m.object({method:m.literal("solana_signAndSendTransaction"),params:m.object({transaction:m.string(),options:m.object({skipPreflight:m.boolean().optional(),preflightCommitment:m.enum(["processed","confirmed","finalized","recent","single","singleGossip","root","max"]).optional(),maxRetries:m.number().optional(),minContextSlot:m.number().optional()}).optional()})}),jb=m.object({method:m.literal("wallet_sendCalls"),params:m.array(m.object({chainId:m.string().or(m.number()).optional(),from:m.string().optional(),version:m.string().optional(),capabilities:m.any().optional(),calls:m.array(m.object({to:m.string().startsWith("0x"),data:m.string().startsWith("0x").optional(),value:m.string().optional()}))}))}),Fb=m.object({method:m.literal("wallet_getCallsStatus"),params:m.array(m.string())}),qb=m.object({method:m.literal("wallet_getCapabilities"),params:m.array(m.string().or(m.number()).optional()).optional()}),Wb=m.object({method:m.literal("wallet_grantPermissions"),params:m.array(m.any())}),Hb=m.object({method:m.literal("wallet_revokePermissions"),params:m.any()}),zb=m.object({method:m.literal("wallet_getAssets"),params:m.any()}),Lu=m.object({token:m.string()}),re=m.object({id:m.string().optional()}),Ac={appEvent:re.extend({type:ne("APP_SWITCH_NETWORK"),payload:NE}).or(re.extend({type:ne("APP_CONNECT_EMAIL"),payload:TE})).or(re.extend({type:ne("APP_CONNECT_DEVICE")})).or(re.extend({type:ne("APP_CONNECT_OTP"),payload:RE})).or(re.extend({type:ne("APP_CONNECT_SOCIAL"),payload:OE})).or(re.extend({type:ne("APP_GET_FARCASTER_URI")})).or(re.extend({type:ne("APP_CONNECT_FARCASTER")})).or(re.extend({type:ne("APP_GET_USER"),payload:m.optional(PE)})).or(re.extend({type:ne("APP_GET_SOCIAL_REDIRECT_URI"),payload:xE})).or(re.extend({type:ne("APP_SIGN_OUT")})).or(re.extend({type:ne("APP_IS_CONNECTED"),payload:m.optional(Lu)})).or(re.extend({type:ne("APP_GET_CHAIN_ID")})).or(re.extend({type:ne("APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS")})).or(re.extend({type:ne("APP_INIT_SMART_ACCOUNT")})).or(re.extend({type:ne("APP_SET_PREFERRED_ACCOUNT"),payload:ME})).or(re.extend({type:ne("APP_RPC_REQUEST"),payload:Du.or(zb).or(eb).or(tb).or(sb).or(nb).or(rb).or(ib).or(ob).or(ab).or(cb).or(lb).or(db).or(ub).or(hb).or(pb).or(fb).or(gb).or(mb).or(yb).or(wb).or(Eb).or(bb).or(vb).or(Cb).or(_b).or(Ab).or(Sb).or(Ib).or(Nb).or(Tb).or(Rb).or(Ob).or(Pb).or(xb).or(kb).or(Du).or(Ub).or($b).or(Db).or(Lb).or(Mb).or(Bb).or(Fb).or(jb).or(qb).or(Wb).or(Hb).and(m.object({chainId:m.string().or(m.number()).optional(),chainNamespace:m.enum(["eip155","solana","polkadot","bip122","cosmos"]).optional(),rpcUrl:m.string().optional()}))})).or(re.extend({type:ne("APP_UPDATE_EMAIL"),payload:kE})).or(re.extend({type:ne("APP_UPDATE_EMAIL_PRIMARY_OTP"),payload:UE})).or(re.extend({type:ne("APP_UPDATE_EMAIL_SECONDARY_OTP"),payload:$E})).or(re.extend({type:ne("APP_SYNC_THEME"),payload:DE})).or(re.extend({type:ne("APP_SYNC_DAPP_DATA"),payload:LE})).or(re.extend({type:ne("APP_RELOAD")})).or(re.extend({type:ne("APP_RPC_ABORT")})),frameEvent:re.extend({type:ne("FRAME_SWITCH_NETWORK_ERROR"),payload:Qe}).or(re.extend({type:ne("FRAME_SWITCH_NETWORK_SUCCESS"),payload:GE})).or(re.extend({type:ne("FRAME_CONNECT_EMAIL_SUCCESS"),payload:BE})).or(re.extend({type:ne("FRAME_CONNECT_EMAIL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_FARCASTER_URI_SUCCESS"),payload:jE})).or(re.extend({type:ne("FRAME_GET_FARCASTER_URI_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_FARCASTER_SUCCESS"),payload:FE})).or(re.extend({type:ne("FRAME_CONNECT_FARCASTER_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_OTP_SUCCESS")})).or(re.extend({type:ne("FRAME_CONNECT_DEVICE_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_DEVICE_SUCCESS")})).or(re.extend({type:ne("FRAME_CONNECT_SOCIAL_SUCCESS"),payload:qE})).or(re.extend({type:ne("FRAME_CONNECT_SOCIAL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_USER_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_USER_SUCCESS"),payload:HE})).or(re.extend({type:ne("FRAME_GET_SOCIAL_REDIRECT_URI_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_SOCIAL_REDIRECT_URI_SUCCESS"),payload:zE})).or(re.extend({type:ne("FRAME_SIGN_OUT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SIGN_OUT_SUCCESS")})).or(re.extend({type:ne("FRAME_IS_CONNECTED_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_IS_CONNECTED_SUCCESS"),payload:VE})).or(re.extend({type:ne("FRAME_GET_CHAIN_ID_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_CHAIN_ID_SUCCESS"),payload:KE})).or(re.extend({type:ne("FRAME_RPC_REQUEST_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_RPC_REQUEST_SUCCESS"),payload:QE})).or(re.extend({type:ne("FRAME_SESSION_UPDATE"),payload:Lu})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SUCCESS"),payload:WE})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_PRIMARY_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_PRIMARY_OTP_SUCCESS")})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SECONDARY_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SECONDARY_OTP_SUCCESS"),payload:YE})).or(re.extend({type:ne("FRAME_SYNC_THEME_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SYNC_THEME_SUCCESS")})).or(re.extend({type:ne("FRAME_SYNC_DAPP_DATA_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SYNC_DAPP_DATA_SUCCESS")})).or(re.extend({type:ne("FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS"),payload:ZE})).or(re.extend({type:ne("FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_INIT_SMART_ACCOUNT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SET_PREFERRED_ACCOUNT_SUCCESS"),payload:XE})).or(re.extend({type:ne("FRAME_SET_PREFERRED_ACCOUNT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_READY"),payload:JE})).or(re.extend({type:ne("FRAME_RELOAD_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_RELOAD_SUCCESS")}))};function Sc(t,e={}){var s;return typeof(e==null?void 0:e.type)=="string"&&((s=e==null?void 0:e.type)==null?void 0:s.includes(t))}function Vb({projectId:t,chainId:e,enableLogger:s,rpcUrl:n=U.BLOCKCHAIN_API_RPC_URL,enableCloudAuthAccount:r=!1}){const i=new URL(Iw);i.searchParams.set("projectId",t),i.searchParams.set("chainId",String(e)),i.searchParams.set("version",Tw),i.searchParams.set("enableLogger",String(s)),i.searchParams.set("rpcUrl",n);const o=lt.get("dapp_smart_account_version");return o&&(o==="v6"||o==="v7")&&(console.warn(">> AppKit - Forcing smart account version",o),i.searchParams.set("smartAccountVersion",o)),r&&i.searchParams.set("enableCloudAuthAccount","true"),i.toString()}class Kb{constructor({projectId:e,isAppClient:s=!1,chainId:n="eip155:1",enableLogger:r=!0,enableCloudAuthAccount:i=!1,rpcUrl:o=U.BLOCKCHAIN_API_RPC_URL}){if(this.iframe=null,this.iframeIsReady=!1,this.initFrame=()=>{const a=document.getElementById("w3m-iframe");this.iframe&&!a&&document.body.appendChild(this.iframe)},this.events={registerFrameEventHandler:(a,c,l)=>{function d({data:u}){var p;if(!Sc(oe.FRAME_EVENT_KEY,u))return;const h=Ac.frameEvent.safeParse(u);if(!h.success){console.warn("W3mFrame: invalid frame event",h.error.message);return}((p=h.data)==null?void 0:p.id)===a&&(c(h.data),window.removeEventListener("message",d))}cs.isClient&&(window.addEventListener("message",d),l.addEventListener("abort",()=>{window.removeEventListener("message",d)}))},onFrameEvent:a=>{cs.isClient&&window.addEventListener("message",({data:c})=>{if(!Sc(oe.FRAME_EVENT_KEY,c))return;const l=Ac.frameEvent.safeParse(c);l.success?a(l.data):console.warn("W3mFrame: invalid frame event",l.error.message)})},onAppEvent:a=>{cs.isClient&&window.addEventListener("message",({data:c})=>{if(!Sc(oe.APP_EVENT_KEY,c))return;const l=Ac.appEvent.safeParse(c);l.success||console.warn("W3mFrame: invalid app event",l.error.message),a(c)})},postAppEvent:a=>{var c;if(cs.isClient){if(!((c=this.iframe)!=null&&c.contentWindow))throw new Error("W3mFrame: iframe is not set");this.iframe.contentWindow.postMessage(a,"*")}},postFrameEvent:a=>{if(cs.isClient){if(!parent)throw new Error("W3mFrame: parent is not set");parent.postMessage(a,"*")}}},this.projectId=e,this.frameLoadPromise=new Promise((a,c)=>{this.frameLoadPromiseResolver={resolve:a,reject:c}}),this.rpcUrl=o,s&&(this.frameLoadPromise=new Promise((a,c)=>{this.frameLoadPromiseResolver={resolve:a,reject:c}}),cs.isClient)){const a=document.createElement("iframe");a.id="w3m-iframe",a.src=Vb({projectId:e,chainId:n,enableLogger:r,rpcUrl:this.rpcUrl,enableCloudAuthAccount:i}),a.name="w3m-secure-iframe",a.style.position="fixed",a.style.zIndex="999999",a.style.display="none",a.style.border="none",a.style.animationDelay="0s, 50ms",a.style.borderBottomLeftRadius="clamp(0px, var(--apkt-borderRadius-8), 44px)",a.style.borderBottomRightRadius="clamp(0px, var(--apkt-borderRadius-8), 44px)",this.iframe=a,this.iframe.onerror=()=>{var c;(c=this.frameLoadPromiseResolver)==null||c.reject("Unable to load email login dependency")},this.events.onFrameEvent(c=>{var l;c.type==="@w3m-frame/READY"&&(this.iframeIsReady=!0,(l=this.frameLoadPromiseResolver)==null||l.resolve(void 0))})}}get networks(){const e=["eip155:1","eip155:5","eip155:11155111","eip155:10","eip155:420","eip155:42161","eip155:421613","eip155:137","eip155:80001","eip155:42220","eip155:1313161554","eip155:1313161555","eip155:56","eip155:97","eip155:43114","eip155:43113","eip155:324","eip155:280","eip155:100","eip155:8453","eip155:84531","eip155:84532","eip155:7777777","eip155:999","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1"].map(s=>({[s]:{rpcUrl:`${this.rpcUrl}/v1/?chainId=${s}&projectId=${this.projectId}`,chainId:s}}));return Object.assign({},...e)}}var bi={exports:{}},Mu;function Gb(){if(Mu)return bi.exports;Mu=1;const t=vy();bi.exports=d;const e=T().console||{},s={mapHttpRequest:L,mapHttpResponse:L,wrapRequestSerializer:W,wrapResponseSerializer:W,wrapErrorSerializer:W,req:L,res:L,err:R,errWithCause:R};function n(w,b){return w==="silent"?1/0:b.levels.values[w]}const r=Symbol("pino.logFuncs"),i=Symbol("pino.hierarchy"),o={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function a(w,b){const I={logger:b,parent:w[i]};b[i]=I}function c(w,b,I){const O={};b.forEach(A=>{O[A]=I[A]?I[A]:e[A]||e[o[A]||"log"]||k}),w[r]=O}function l(w,b){return Array.isArray(w)?w.filter(function(O){return O!=="!stdSerializers.err"}):w===!0?Object.keys(b):!1}function d(w){w=w||{},w.browser=w.browser||{};const b=w.browser.transmit;if(b&&typeof b.send!="function")throw Error("pino: transmit option must have a send function");const I=w.browser.write||e;w.browser.write&&(w.browser.asObject=!0);const O=w.serializers||{},A=l(w.browser.serialize,O);let P=w.browser.serialize;Array.isArray(w.browser.serialize)&&w.browser.serialize.indexOf("!stdSerializers.err")>-1&&(P=!1);const B=Object.keys(w.customLevels||{}),M=["error","fatal","warn","info","debug","trace"].concat(B);typeof I=="function"&&M.forEach(function(ve){I[ve]=I}),(w.enabled===!1||w.browser.disabled)&&(w.level="silent");const ce=w.level||"info",j=Object.create(I);j.log||(j.log=k),c(j,M,I),a({},j),Object.defineProperty(j,"levelVal",{get:he}),Object.defineProperty(j,"level",{get:ge,set:Oe});const J={transmit:b,serialize:A,asObject:w.browser.asObject,asObjectBindingsOnly:w.browser.asObjectBindingsOnly,formatters:w.browser.formatters,levels:M,timestamp:D(w),messageKey:w.messageKey||"msg",onChild:w.onChild||k};j.levels=u(w),j.level=ce,j.isLevelEnabled=function(ve){return this.levels.values[ve]?this.levels.values[ve]>=this.levels.values[this.level]:!1},j.setMaxListeners=j.getMaxListeners=j.emit=j.addListener=j.on=j.prependListener=j.once=j.prependOnceListener=j.removeListener=j.removeAllListeners=j.listeners=j.listenerCount=j.eventNames=j.write=j.flush=k,j.serializers=O,j._serialize=A,j._stdErrSerialize=P,j.child=function(...ve){return ye.call(this,J,...ve)},b&&(j._logEvent=C());function he(){return n(this.level,this)}function ge(){return this._level}function Oe(ve){if(ve!=="silent"&&!this.levels.values[ve])throw Error("unknown level "+ve);this._level=ve,g(this,J,j,"error"),g(this,J,j,"fatal"),g(this,J,j,"warn"),g(this,J,j,"info"),g(this,J,j,"debug"),g(this,J,j,"trace"),B.forEach(Ve=>{g(this,J,j,Ve)})}function ye(ve,Ve,st){if(!Ve)throw new Error("missing bindings for child Pino");st=st||{},A&&Ve.serializers&&(st.serializers=Ve.serializers);const ut=st.serializers;if(A&&ut){var wt=Object.assign({},O,ut),Bs=w.browser.serialize===!0?Object.keys(wt):A;delete Ve.serializers,S([Ve],Bs,wt,this._stdErrSerialize)}function sn(Do){this._childLevel=(Do._childLevel|0)+1,this.bindings=Ve,wt&&(this.serializers=wt,this._serialize=Bs),b&&(this._logEvent=C([].concat(Do._logEvent.bindings,Ve)))}sn.prototype=this;const Ei=new sn(this);return a(this,Ei),Ei.child=function(...Do){return ye.call(this,ve,...Do)},Ei.level=st.level||this.level,ve.onChild(Ei),Ei}return j}function u(w){const b=w.customLevels||{},I=Object.assign({},d.levels.values,b),O=Object.assign({},d.levels.labels,h(b));return{values:I,labels:O}}function h(w){const b={};return Object.keys(w).forEach(function(I){b[w[I]]=I}),b}d.levels={values:{fatal:60,error:50,warn:40,info:30,debug:20,trace:10},labels:{10:"trace",20:"debug",30:"info",40:"warn",50:"error",60:"fatal"}},d.stdSerializers=s,d.stdTimeFunctions=Object.assign({},{nullTime:q,epochTime:V,unixTime:x,isoTime:N});function p(w){const b=[];w.bindings&&b.push(w.bindings);let I=w[i];for(;I.parent;)I=I.parent,I.logger.bindings&&b.push(I.logger.bindings);return b.reverse()}function g(w,b,I,O){if(Object.defineProperty(w,O,{value:n(w.level,I)>n(O,I)?k:I[r][O],writable:!0,enumerable:!0,configurable:!0}),w[O]===k){if(!b.transmit)return;const P=b.transmit.level||w.level,B=n(P,I);if(n(O,I)<B)return}w[O]=y(w,b,I,O);const A=p(w);A.length!==0&&(w[O]=f(A,w[O]))}function f(w,b){return function(){return b.apply(this,[...w,...arguments])}}function y(w,b,I,O){return function(A){return function(){const B=b.timestamp(),M=new Array(arguments.length),ce=Object.getPrototypeOf&&Object.getPrototypeOf(this)===e?e:this;for(var j=0;j<M.length;j++)M[j]=arguments[j];var J=!1;if(b.serialize&&(S(M,this._serialize,this.serializers,this._stdErrSerialize),J=!0),b.asObject||b.formatters?A.call(ce,..._(this,O,M,B,b)):A.apply(ce,M),b.transmit){const he=b.transmit.level||w._level,ge=n(he,I),Oe=n(O,I);if(Oe<ge)return;v(this,{ts:B,methodLevel:O,methodValue:Oe,transmitValue:I.levels.values[b.transmit.level||w._level],send:b.transmit.send,val:n(w._level,I)},M,J)}}}(w[r][O])}function _(w,b,I,O,A){const{level:P,log:B=he=>he}=A.formatters||{},M=I.slice();let ce=M[0];const j={};let J=(w._childLevel|0)+1;if(J<1&&(J=1),O&&(j.time=O),P){const he=P(b,w.levels.values[b]);Object.assign(j,he)}else j.level=w.levels.values[b];if(A.asObjectBindingsOnly){if(ce!==null&&typeof ce=="object")for(;J--&&typeof M[0]=="object";)Object.assign(j,M.shift());return[B(j),...M]}else{if(ce!==null&&typeof ce=="object"){for(;J--&&typeof M[0]=="object";)Object.assign(j,M.shift());ce=M.length?t(M.shift(),M):void 0}else typeof ce=="string"&&(ce=t(M.shift(),M));return ce!==void 0&&(j[A.messageKey]=ce),[B(j)]}}function S(w,b,I,O){for(const A in w)if(O&&w[A]instanceof Error)w[A]=d.stdSerializers.err(w[A]);else if(typeof w[A]=="object"&&!Array.isArray(w[A])&&b)for(const P in w[A])b.indexOf(P)>-1&&P in I&&(w[A][P]=I[P](w[A][P]))}function v(w,b,I,O=!1){const A=b.send,P=b.ts,B=b.methodLevel,M=b.methodValue,ce=b.val,j=w._logEvent.bindings;O||S(I,w._serialize||Object.keys(w.serializers),w.serializers,w._stdErrSerialize===void 0?!0:w._stdErrSerialize),w._logEvent.ts=P,w._logEvent.messages=I.filter(function(J){return j.indexOf(J)===-1}),w._logEvent.level.label=B,w._logEvent.level.value=M,A(B,w._logEvent,ce),w._logEvent=C(j)}function C(w){return{ts:0,messages:[],bindings:w||[],level:{label:"",value:0}}}function R(w){const b={type:w.constructor.name,msg:w.message,stack:w.stack};for(const I in w)b[I]===void 0&&(b[I]=w[I]);return b}function D(w){return typeof w.timestamp=="function"?w.timestamp:w.timestamp===!1?q:V}function L(){return{}}function W(w){return w}function k(){}function q(){return!1}function V(){return Date.now()}function x(){return Math.round(Date.now()/1e3)}function N(){return new Date(Date.now()).toISOString()}function T(){function w(b){return typeof b<"u"&&b}try{return typeof globalThis<"u"||Object.defineProperty(Object.prototype,"globalThis",{get:function(){return delete Object.prototype.globalThis,this.globalThis=this},configurable:!0}),globalThis}catch{return w(self)||w(window)||w(this)||{}}}return bi.exports.default=d,bi.exports.pino=d,bi.exports}var Kr=Gb();const qf=Cy(Kr),Yb={level:"info"},rc="custom_context",Nd=1e3*1024;var Zb=Object.defineProperty,Jb=(t,e,s)=>e in t?Zb(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,jn=(t,e,s)=>Jb(t,typeof e!="symbol"?e+"":e,s);let Xb=class{constructor(e){jn(this,"nodeValue"),jn(this,"sizeInBytes"),jn(this,"next"),this.nodeValue=e,this.sizeInBytes=new TextEncoder().encode(this.nodeValue).length,this.next=null}get value(){return this.nodeValue}get size(){return this.sizeInBytes}},Bu=class{constructor(e){jn(this,"lengthInNodes"),jn(this,"sizeInBytes"),jn(this,"head"),jn(this,"tail"),jn(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new Xb(e);if(s.size>this.maxSizeInBytes)throw new Error(`[LinkedList] Value too big to insert into list: ${e} with size ${s.size}`);for(;this.size+s.size>this.maxSizeInBytes;)this.shift();this.head?(this.tail&&(this.tail.next=s),this.tail=s):(this.head=s,this.tail=s),this.lengthInNodes++,this.sizeInBytes+=s.size}shift(){if(!this.head)return;const e=this.head;this.head=this.head.next,this.head||(this.tail=null),this.lengthInNodes--,this.sizeInBytes-=e.size}toArray(){const e=[];let s=this.head;for(;s!==null;)e.push(s.value),s=s.next;return e}get length(){return this.lengthInNodes}get size(){return this.sizeInBytes}toOrderedArray(){return Array.from(this)}[Symbol.iterator](){let e=this.head;return{next:()=>{if(!e)return{done:!0,value:null};const s=e.value;return e=e.next,{done:!1,value:s}}}}};var Qb=Object.defineProperty,ev=(t,e,s)=>e in t?Qb(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,qo=(t,e,s)=>ev(t,typeof e!="symbol"?e+"":e,s);let Wf=class{constructor(e,s=Nd){qo(this,"logs"),qo(this,"level"),qo(this,"levelValue"),qo(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Kr.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Bu(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Kr.levels.values.error?console.error(e):s===Kr.levels.values.warn?console.warn(e):s===Kr.levels.values.debug?console.debug(e):s===Kr.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Gi({timestamp:new Date().toISOString(),log:e}));const s=typeof e=="string"?JSON.parse(e).level:e.level;s>=this.levelValue&&this.forwardToConsole(e,s)}getLogs(){return this.logs}clearLogs(){this.logs=new Bu(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Gi({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var tv=Object.defineProperty,sv=(t,e,s)=>e in t?tv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,nv=(t,e,s)=>sv(t,e+"",s);let rv=class{constructor(e,s=Nd){nv(this,"baseChunkLogger"),this.baseChunkLogger=new Wf(e,s)}write(e){this.baseChunkLogger.appendToLogs(e)}getLogs(){return this.baseChunkLogger.getLogs()}clearLogs(){this.baseChunkLogger.clearLogs()}getLogArray(){return this.baseChunkLogger.getLogArray()}logsToBlob(e){return this.baseChunkLogger.logsToBlob(e)}downloadLogsBlobInBrowser(e){const s=URL.createObjectURL(this.logsToBlob(e)),n=document.createElement("a");n.href=s,n.download=`walletconnect-logs-${new Date().toISOString()}.txt`,document.body.appendChild(n),n.click(),document.body.removeChild(n),URL.revokeObjectURL(s)}};var iv=Object.defineProperty,ov=(t,e,s)=>e in t?iv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,av=(t,e,s)=>ov(t,e+"",s);let cv=class{constructor(e,s=Nd){av(this,"baseChunkLogger"),this.baseChunkLogger=new Wf(e,s)}write(e){this.baseChunkLogger.appendToLogs(e)}getLogs(){return this.baseChunkLogger.getLogs()}clearLogs(){this.baseChunkLogger.clearLogs()}getLogArray(){return this.baseChunkLogger.getLogArray()}logsToBlob(e){return this.baseChunkLogger.logsToBlob(e)}};var lv=Object.defineProperty,dv=Object.defineProperties,uv=Object.getOwnPropertyDescriptors,ju=Object.getOwnPropertySymbols,hv=Object.prototype.hasOwnProperty,pv=Object.prototype.propertyIsEnumerable,Fu=(t,e,s)=>e in t?lv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ka=(t,e)=>{for(var s in e||(e={}))hv.call(e,s)&&Fu(t,s,e[s]);if(ju)for(var s of ju(e))pv.call(e,s)&&Fu(t,s,e[s]);return t},Ua=(t,e)=>dv(t,uv(e));function Td(t){return Ua(ka({},t),{level:(t==null?void 0:t.level)||Yb.level})}function fv(t,e,s=rc){return t[s]=e,t}function es(t,e=rc){return t[e]||""}function gv(t,e,s=rc){const n=es(t,s);return n.trim()?`${n}/${e}`:e}function ts(t,e,s=rc){const n=gv(t,e,s),r=t.child({context:n});return fv(r,n,s)}function mv(t){var e,s;const n=new rv((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:qf(Ua(ka({},t.opts),{level:"trace",browser:Ua(ka({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function yv(t){var e;const s=new cv((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:qf(Ua(ka({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function ic(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?mv(t):yv(t)}class wv{constructor(e){var i;const s=Td({level:Nw}),{logger:n,chunkLoggerController:r}=ic({opts:s});this.logger=ts(n,this.constructor.name),this.chunkLoggerController=r,typeof window<"u"&&((i=this.chunkLoggerController)!=null&&i.downloadLogsBlobInBrowser)&&(window.downloadAppKitLogsBlob||(window.downloadAppKitLogsBlob={}),window.downloadAppKitLogsBlob.sdk=()=>{var o;(o=this.chunkLoggerController)!=null&&o.downloadLogsBlobInBrowser&&this.chunkLoggerController.downloadLogsBlobInBrowser({projectId:e})})}}class Ev{constructor({projectId:e,chainId:s,enableLogger:n=!0,onTimeout:r,abortController:i,getActiveCaipNetwork:o,getCaipNetworks:a,enableCloudAuthAccount:c,metadata:l,sdkVersion:d,sdkType:u}){this.openRpcRequests=new Map,this.isInitialized=!1,n&&(this.w3mLogger=new wv(e)),this.abortController=i,this.getActiveCaipNetwork=o,this.getCaipNetworks=a;const h=this.getRpcUrl(s);this.projectId=e,this.sdkVersion=d,this.sdkType=u,this.metadata=l,this.w3mFrame=new Kb({projectId:e,isAppClient:!0,chainId:s,enableLogger:n,rpcUrl:h,enableCloudAuthAccount:c}),this.onTimeout=r,this.getLoginEmailUsed()&&this.createFrame()}async createFrame(){this.w3mFrame.initFrame(),this.initPromise=new Promise(e=>{this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_READY&&setTimeout(()=>{e()},500)})}),await this.initPromise,await this.syncDappData({metadata:this.metadata,projectId:this.projectId,sdkVersion:this.sdkVersion,sdkType:this.sdkType}),await this.getSmartAccountEnabledNetworks(),this.isInitialized=!0,this.initPromise=void 0}async init(){if(!this.isInitialized){if(this.initPromise){await this.initPromise;return}await this.createFrame()}}getLoginEmailUsed(){return!!lt.get(oe.EMAIL_LOGIN_USED_KEY)}getEmail(){return lt.get(oe.EMAIL)}getUsername(){return lt.get(oe.SOCIAL_USERNAME)}async reload(){var e;try{await this.appEvent({type:oe.APP_RELOAD})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error reloading iframe"),s}}async connectEmail(e){var s;try{cs.checkIfAllowedToTriggerEmail(),await this.init();const n=await this.appEvent({type:oe.APP_CONNECT_EMAIL,payload:e});return this.setNewLastEmailLoginTime(),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting email"),n}}async connectDevice(){var e;try{return this.appEvent({type:oe.APP_CONNECT_DEVICE})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error connecting device"),s}}async connectOtp(e){var s;try{return this.appEvent({type:oe.APP_CONNECT_OTP,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting otp"),n}}async isConnected(){var e;try{if(!this.getLoginEmailUsed())return{isConnected:!1};const s=await this.appEvent({type:oe.APP_IS_CONNECTED});return s!=null&&s.isConnected||this.deleteAuthLoginCache(),s}catch(s){throw this.deleteAuthLoginCache(),(e=this.w3mLogger)==null||e.logger.error({error:s},"Error checking connection"),s}}async getChainId(){var e;try{const s=await this.appEvent({type:oe.APP_GET_CHAIN_ID});return this.setLastUsedChainId(s.chainId),s}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting chain id"),s}}async getSocialRedirectUri(e){var s;try{return await this.init(),this.appEvent({type:oe.APP_GET_SOCIAL_REDIRECT_URI,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error getting social redirect uri"),n}}async updateEmail(e){var s;try{const n=await this.appEvent({type:oe.APP_UPDATE_EMAIL,payload:e});return this.setNewLastEmailLoginTime(),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email"),n}}async updateEmailPrimaryOtp(e){var s;try{return this.appEvent({type:oe.APP_UPDATE_EMAIL_PRIMARY_OTP,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email primary otp"),n}}async updateEmailSecondaryOtp(e){var s;try{const n=await this.appEvent({type:oe.APP_UPDATE_EMAIL_SECONDARY_OTP,payload:e});return this.setLoginSuccess(n.newEmail),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email secondary otp"),n}}async syncTheme(e){var s;try{return this.appEvent({type:oe.APP_SYNC_THEME,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error syncing theme"),n}}async syncDappData(e){var s;try{return this.appEvent({type:oe.APP_SYNC_DAPP_DATA,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error syncing dapp data"),n}}async getSmartAccountEnabledNetworks(){var e;try{const s=await this.appEvent({type:oe.APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS});return this.persistSmartAccountEnabledNetworks(s.smartAccountEnabledNetworks),s}catch(s){throw this.persistSmartAccountEnabledNetworks([]),(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting smart account enabled networks"),s}}async setPreferredAccount(e){var s;try{return this.appEvent({type:oe.APP_SET_PREFERRED_ACCOUNT,payload:{type:e}})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error setting preferred account"),n}}async connect(e){var s,n;if(e!=null&&e.socialUri)try{await this.init();const r=this.getRpcUrl(e.chainId),i=await this.appEvent({type:oe.APP_CONNECT_SOCIAL,payload:{uri:e.socialUri,preferredAccountType:e.preferredAccountType,chainId:e.chainId,siwxMessage:e.siwxMessage,rpcUrl:r}});return i.userName&&this.setSocialLoginSuccess(i.userName),this.setLoginSuccess(i.email),this.setLastUsedChainId(i.chainId),this.user=i,i}catch(r){throw(s=this.w3mLogger)==null||s.logger.error({error:r},"Error connecting social"),r}else try{const r=(e==null?void 0:e.chainId)||this.getLastUsedChainId()||1,i=await this.getUser({chainId:r,preferredAccountType:e==null?void 0:e.preferredAccountType,siwxMessage:e==null?void 0:e.siwxMessage,rpcUrl:this.getRpcUrl(r)});return this.setLoginSuccess(i.email),this.setLastUsedChainId(i.chainId),this.user=i,i}catch(r){throw(n=this.w3mLogger)==null||n.logger.error({error:r},"Error connecting"),r}}async getUser(e){var s;try{await this.init();const n=(e==null?void 0:e.chainId)||this.getLastUsedChainId()||1,r=await this.appEvent({type:oe.APP_GET_USER,payload:{...e,chainId:n,rpcUrl:this.getRpcUrl(n)}});return this.user=r,r}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting"),n}}async connectSocial({uri:e,chainId:s,preferredAccountType:n}){var r;try{await this.init();const i=this.getRpcUrl(s),o=await this.appEvent({type:oe.APP_CONNECT_SOCIAL,payload:{uri:e,chainId:s,rpcUrl:i,preferredAccountType:n}});return o.userName&&this.setSocialLoginSuccess(o.userName),o}catch(i){throw(r=this.w3mLogger)==null||r.logger.error({error:i},"Error connecting social"),i}}async getFarcasterUri(){var e;try{return await this.init(),await this.appEvent({type:oe.APP_GET_FARCASTER_URI})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting farcaster uri"),s}}async connectFarcaster(){var e;try{const s=await this.appEvent({type:oe.APP_CONNECT_FARCASTER});return s.userName&&this.setSocialLoginSuccess(s.userName),s}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error connecting farcaster"),s}}async switchNetwork({chainId:e}){var s;try{const n=this.getRpcUrl(e),r=await this.appEvent({type:oe.APP_SWITCH_NETWORK,payload:{chainId:e,rpcUrl:n}});return this.setLastUsedChainId(r.chainId),r}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error switching network"),n}}async disconnect(){var e;try{return this.deleteAuthLoginCache(),await new Promise(async n=>{const r=setTimeout(()=>{n()},3e3);await this.appEvent({type:oe.APP_SIGN_OUT}),clearTimeout(r),n()})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error disconnecting"),s}}async request(e){var n,r,i,o,a;const s=e;try{if(tt.GET_CHAIN_ID===e.method)return this.getLastUsedChainId();const c=e.chainNamespace||"eip155",l=(n=this.getActiveCaipNetwork(c))==null?void 0:n.id;s.chainNamespace=c,s.chainId=l,s.rpcUrl=this.getRpcUrl(l),(r=this.rpcRequestHandler)==null||r.call(this,e);const d=await this.appEvent({type:oe.APP_RPC_REQUEST,payload:s});return(i=this.rpcSuccessHandler)==null||i.call(this,d,s),d}catch(c){throw(o=this.rpcErrorHandler)==null||o.call(this,c,s),(a=this.w3mLogger)==null||a.logger.error({error:c},"Error requesting"),c}}onRpcRequest(e){this.rpcRequestHandler=e}onRpcSuccess(e){this.rpcSuccessHandler=e}onRpcError(e){this.rpcErrorHandler=e}onIsConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_IS_CONNECTED_SUCCESS&&s.payload.isConnected&&e()})}onNotConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_IS_CONNECTED_ERROR&&e(),s.type===oe.FRAME_IS_CONNECTED_SUCCESS&&!s.payload.isConnected&&e()})}onConnect(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_GET_USER_SUCCESS&&e(s.payload)})}onSocialConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_CONNECT_SOCIAL_SUCCESS&&e(s.payload)})}async getCapabilities(){try{return await this.request({method:"wallet_getCapabilities"})||{}}catch{return{}}}onSetPreferredAccount(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_SET_PREFERRED_ACCOUNT_SUCCESS?e(s.payload):s.type===oe.FRAME_SET_PREFERRED_ACCOUNT_ERROR&&e({type:tt.ACCOUNT_TYPES.EOA})})}getAvailableChainIds(){return Object.keys(this.w3mFrame.networks)}async rejectRpcRequests(){var e;try{await Promise.all(Array.from(this.openRpcRequests.values()).map(async({abortController:s,method:n})=>{tt.SAFE_RPC_METHODS.includes(n)||s.abort(),await this.appEvent({type:oe.APP_RPC_ABORT})})),this.openRpcRequests.clear()}catch(s){(e=this.w3mLogger)==null||e.logger.error({error:s},"Error aborting RPC request")}}async appEvent(e){let s,n;function r(c){return c.replace("@w3m-app/","")}const i=[oe.APP_SYNC_DAPP_DATA,oe.APP_SYNC_THEME,oe.APP_SET_PREFERRED_ACCOUNT],o=r(e.type);return!this.w3mFrame.iframeIsReady&&!i.includes(e.type)&&(n=setTimeout(()=>{var c;(c=this.onTimeout)==null||c.call(this,"iframe_load_failed"),this.abortController.abort()},2e4)),await this.w3mFrame.frameLoadPromise,clearTimeout(n),[oe.APP_CONNECT_EMAIL,oe.APP_CONNECT_DEVICE,oe.APP_CONNECT_OTP,oe.APP_CONNECT_SOCIAL,oe.APP_GET_SOCIAL_REDIRECT_URI].map(r).includes(o)&&(s=setTimeout(()=>{var c;(c=this.onTimeout)==null||c.call(this,"iframe_request_timeout"),this.abortController.abort()},12e4)),new Promise((c,l)=>{var p,g,f;const d=Math.random().toString(36).substring(7);(f=(p=this.w3mLogger)==null?void 0:(g=p.logger).info)==null||f.call(g,{event:e,id:d},"Sending app event"),this.w3mFrame.events.postAppEvent({...e,id:d});const u=new AbortController;if(o==="RPC_REQUEST"){const y=e;this.openRpcRequests.set(d,{...y.payload,abortController:u})}u.signal.addEventListener("abort",()=>{o==="RPC_REQUEST"?l(new Error("Request was aborted")):o!=="GET_FARCASTER_URI"&&l(new Error("Something went wrong"))});const h=(y,_)=>{var S,v,C;y.id===d&&((v=_==null?void 0:(S=_.logger).info)==null||v.call(S,{framEvent:y,id:d},"Received frame response"),this.openRpcRequests.delete(y.id),y.type===`@w3m-frame/${o}_SUCCESS`?(s&&clearTimeout(s),n&&clearTimeout(n),"payload"in y&&c(y.payload),c(void 0)):y.type===`@w3m-frame/${o}_ERROR`&&(s&&clearTimeout(s),n&&clearTimeout(n),"payload"in y&&l(new Error(((C=y.payload)==null?void 0:C.message)||"An error occurred")),l(new Error("An error occurred"))))};this.w3mFrame.events.registerFrameEventHandler(d,y=>h(y,this.w3mLogger),this.abortController.signal)})}setNewLastEmailLoginTime(){lt.set(oe.LAST_EMAIL_LOGIN_TIME,Date.now().toString())}setSocialLoginSuccess(e){lt.set(oe.SOCIAL_USERNAME,e)}setLoginSuccess(e){e&<.set(oe.EMAIL,e),lt.set(oe.EMAIL_LOGIN_USED_KEY,"true"),lt.delete(oe.LAST_EMAIL_LOGIN_TIME)}deleteAuthLoginCache(){lt.delete(oe.EMAIL_LOGIN_USED_KEY),lt.delete(oe.EMAIL),lt.delete(oe.LAST_USED_CHAIN_KEY),lt.delete(oe.SOCIAL_USERNAME)}setLastUsedChainId(e){e&<.set(oe.LAST_USED_CHAIN_KEY,String(e))}getLastUsedChainId(){const e=lt.get(oe.LAST_USED_CHAIN_KEY)??void 0,s=Number(e);return isNaN(s)?e:s}persistSmartAccountEnabledNetworks(e){lt.set(oe.SMART_ACCOUNT_ENABLED_NETWORKS,e.join(","))}getRpcUrl(e){var i,o;let s=e===void 0?void 0:"eip155";typeof e=="string"&&(e.includes(":")?s=(i=dt.parseCaipNetworkId(e))==null?void 0:i.chainNamespace:Number.isInteger(Number(e))?s="eip155":s="solana");const n=this.getCaipNetworks(s),r=e?n.find(a=>String(a.id)===String(e)||a.caipNetworkId===e):n[0];return(o=r==null?void 0:r.rpcUrls.default.http)==null?void 0:o[0]}}async function Hf(t){return new Promise(e=>setTimeout(e,t))}function bv(t,{delay:e=100,retryCount:s=2,shouldRetry:n=()=>!0}={}){return new Promise((r,i)=>{const o=async({count:a=0}={})=>{const c=async({error:l})=>{const d=typeof e=="function"?e({count:a,error:l}):e;d&&await Hf(d),o({count:a+1})};try{const l=await t();r(l)}catch(l){if(a<s&&await n({count:a,error:l}))return c({error:l});i(l)}};o()})}const Rl=256;let Wo=Rl,Ho;function vv(t=11){if(!Ho||Wo+t>Rl*2){Ho="",Wo=0;for(let e=0;e<Rl;e++)Ho+=(256+Math.random()*256|0).toString(16).substring(1)}return Ho.substring(Wo,Wo+++t)}const zo=new My(8192);function Cv(t,{enabled:e=!0,id:s}){if(!e||!s)return t();if(zo.get(s))return zo.get(s);const n=t().finally(()=>zo.delete(s));return zo.set(s,n),n}function _v(t,e={}){return async(s,n={})=>{var u;const{dedupe:r=!1,methods:i,retryDelay:o=150,retryCount:a=3,uid:c}={...e,...n},{method:l}=s;if((u=i==null?void 0:i.exclude)!=null&&u.includes(l))throw new Mo(new Error("method not supported"),{method:l});if(i!=null&&i.include&&!i.include.includes(l))throw new Mo(new Error("method not supported"),{method:l});const d=r?By(`${c}.${la(s)}`):void 0;return Cv(()=>bv(async()=>{try{return await t(s)}catch(h){const p=h;switch(p.code){case Iu.code:throw new Iu(p);case Su.code:throw new Su(p);case Au.code:throw new Au(p,{method:s.method});case _u.code:throw new _u(p);case Cl.code:throw new Cl(p);case Cu.code:throw new Cu(p);case vu.code:throw new vu(p);case bu.code:throw new bu(p);case vl.code:throw new vl(p);case Mo.code:throw new Mo(p,{method:s.method});case bl.code:throw new bl(p);case Eu.code:throw new Eu(p);case da.code:throw new da(p);case wu.code:throw new wu(p);case yu.code:throw new yu(p);case mu.code:throw new mu(p);case gu.code:throw new gu(p);case fu.code:throw new fu(p);case pu.code:throw new pu(p);case hu.code:throw new hu(p);case uu.code:throw new uu(p);case du.code:throw new du(p);case lu.code:throw new lu(p);case cu.code:throw new cu(p);case au.code:throw new au(p);case 5e3:throw new da(p);default:throw h instanceof Af?h:new jy(p)}}},{delay:({count:h,error:p})=>{var g;if(p&&p instanceof Bi){const f=(g=p==null?void 0:p.headers)==null?void 0:g.get("Retry-After");if(f!=null&&f.match(/\d/))return Number.parseInt(f,10)*1e3}return~~(1<<h)*o},retryCount:a,shouldRetry:({error:h})=>Av(h)}),{enabled:r,id:d})}}function Av(t){return"code"in t&&typeof t.code=="number"?t.code===-1||t.code===bl.code||t.code===Cl.code:t instanceof Bi&&t.status?t.status===403||t.status===408||t.status===413||t.status===429||t.status===500||t.status===502||t.status===503||t.status===504:!0}function Sv(t,{errorInstance:e=new Error("timed out"),timeout:s,signal:n}){return new Promise((r,i)=>{(async()=>{let o;try{const a=new AbortController;s>0&&(o=setTimeout(()=>{n&&a.abort()},s)),r(await t({signal:(a==null?void 0:a.signal)||null}))}catch(a){(a==null?void 0:a.name)==="AbortError"&&i(e),i(a)}finally{clearTimeout(o)}})()})}function Iv(){return{current:0,take(){return this.current++},reset(){this.current=0}}}const qu=Iv();function Nv(t,e={}){return{async request(s){var h;const{body:n,fetchFn:r=e.fetchFn??fetch,onRequest:i=e.onRequest,onResponse:o=e.onResponse,timeout:a=e.timeout??1e4}=s,c={...e.fetchOptions??{},...s.fetchOptions??{}},{headers:l,method:d,signal:u}=c;try{const p=await Sv(async({signal:f})=>{const y={...c,body:Array.isArray(n)?la(n.map(C=>({jsonrpc:"2.0",id:C.id??qu.take(),...C}))):la({jsonrpc:"2.0",id:n.id??qu.take(),...n}),headers:{"Content-Type":"application/json",...l},method:d||"POST",signal:u||(a>0?f:null)},_=new Request(t,y),S=await(i==null?void 0:i(_,y))??{...y,url:t};return await r(S.url??t,S)},{errorInstance:new Nu({body:n,url:t}),timeout:a,signal:!0});o&&await o(p);let g;if((h=p.headers.get("Content-Type"))!=null&&h.startsWith("application/json"))g=await p.json();else{g=await p.text();try{g=JSON.parse(g||"{}")}catch(f){if(p.ok)throw f;g={error:g}}}if(!p.ok)throw new Bi({body:n,details:la(g.error)||p.statusText,headers:p.headers,status:p.status,url:t});return g}catch(p){throw p instanceof Bi||p instanceof Nu?p:new Bi({body:n,cause:p,url:t})}}}}function zf({key:t,methods:e,name:s,request:n,retryCount:r=3,retryDelay:i=150,timeout:o,type:a},c){const l=vv();return{config:{key:t,methods:e,name:s,request:n,retryCount:r,retryDelay:i,timeout:o,type:a},request:_v(n,{methods:e,retryCount:r,retryDelay:i,uid:l}),value:c}}function Wu(t,e={}){const{key:s="fallback",name:n="Fallback",rank:r=!1,shouldThrow:i=Tv,retryCount:o,retryDelay:a}=e;return({chain:c,pollingInterval:l=4e3,timeout:d,...u})=>{let h=t,p=()=>{};const g=zf({key:s,name:n,async request({method:f,params:y}){let _;const S=async(v=0)=>{const C=h[v]({...u,chain:c,retryCount:0,timeout:d});try{const R=await C.request({method:f,params:y});return p({method:f,params:y,response:R,transport:C,status:"success"}),R}catch(R){if(p({error:R,method:f,params:y,transport:C,status:"error"}),i(R)||v===h.length-1||(_??(_=h.slice(v+1).some(D=>{const{include:L,exclude:W}=D({chain:c}).config.methods||{};return L?L.includes(f):W?!W.includes(f):!0})),!_))throw R;return S(v+1)}};return S()},retryCount:o,retryDelay:a,type:"fallback"},{onResponse:f=>p=f,transports:h.map(f=>f({chain:c,retryCount:0}))});if(r){const f=typeof r=="object"?r:{};Rv({chain:c,interval:f.interval??l,onTransports:y=>h=y,ping:f.ping,sampleCount:f.sampleCount,timeout:f.timeout,transports:h,weights:f.weights})}return g}}function Tv(t){return!!("code"in t&&typeof t.code=="number"&&(t.code===vl.code||t.code===da.code||Fy.nodeMessage.test(t.message)||t.code===5e3))}function Rv({chain:t,interval:e=4e3,onTransports:s,ping:n,sampleCount:r=10,timeout:i=1e3,transports:o,weights:a={}}){const{stability:c=.7,latency:l=.3}=a,d=[],u=async()=>{const h=await Promise.all(o.map(async f=>{const y=f({chain:t,retryCount:0,timeout:i}),_=Date.now();let S,v;try{await(n?n({transport:y}):y.request({method:"net_listening"})),v=1}catch{v=0}finally{S=Date.now()}return{latency:S-_,success:v}}));d.push(h),d.length>r&&d.shift();const p=Math.max(...d.map(f=>Math.max(...f.map(({latency:y})=>y)))),g=o.map((f,y)=>{const _=d.map(D=>D[y].latency),v=1-_.reduce((D,L)=>D+L,0)/_.length/p,C=d.map(D=>D[y].success),R=C.reduce((D,L)=>D+L,0)/C.length;return R===0?[0,y]:[l*v+c*R,y]}).sort((f,y)=>y[0]-f[0]);s(g.map(([,f])=>o[f])),await Hf(e),u()};u()}class Ov extends Af{constructor(){super("No URL was provided to the Transport. Please provide a valid RPC URL to the Transport.",{docsPath:"/docs/clients/intro",name:"UrlRequiredError"})}}function Vo(t,e={}){const{batch:s,fetchFn:n,fetchOptions:r,key:i="http",methods:o,name:a="HTTP JSON-RPC",onFetchRequest:c,onFetchResponse:l,retryDelay:d,raw:u}=e;return({chain:h,retryCount:p,timeout:g})=>{const{batchSize:f=1e3,wait:y=0}=typeof s=="object"?s:{},_=e.retryCount??p,S=g??e.timeout??1e4,v=t||(h==null?void 0:h.rpcUrls.default.http[0]);if(!v)throw new Ov;const C=Nv(v,{fetchFn:n,fetchOptions:r,onRequest:c,onResponse:l,timeout:S});return zf({key:i,methods:o,name:a,async request({method:R,params:D}){const L={method:R,params:D},{schedule:W}=qy({id:v,wait:y,shouldSplitBatch(x){return x.length>f},fn:x=>C.request({body:x}),sort:(x,N)=>x.id-N.id}),k=async x=>s?W(x):[await C.request({body:x})],[{error:q,result:V}]=await k(L);if(u)return{error:q,result:V};if(q)throw new Wy({body:L,error:q,url:v});return V},retryCount:_,retryDelay:d,timeout:S,type:"http"},{fetchOptions:r,url:v})}}async function vi(...t){const e=await fetch(...t);if(!e.ok)throw new Error(`HTTP status code: ${e.status}`,{cause:e});return e}class So{constructor({baseUrl:e,clientId:s}){this.baseUrl=e,this.clientId=s}async get({headers:e,signal:s,cache:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"GET",headers:e,signal:s,cache:n})).json()}async getBlob({headers:e,signal:s,...n}){const r=this.createUrl(n);return(await vi(r,{method:"GET",headers:e,signal:s})).blob()}async post({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"POST",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}async put({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"PUT",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}async delete({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"DELETE",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}createUrl({path:e,params:s}){const n=new URL(e,this.baseUrl);return s&&Object.entries(s).forEach(([r,i])=>{i&&n.searchParams.append(r,i)}),this.clientId&&n.searchParams.append("clientId",this.clientId),n}sendBeacon({body:e,...s}){const n=this.createUrl(s);return navigator.sendBeacon(n.toString(),e?JSON.stringify(e):void 0)}}const Ol={getFeatureValue(t,e){const s=e==null?void 0:e[t];return s===void 0?Ie.DEFAULT_FEATURES[t]:s},filterSocialsByPlatform(t){if(!t||!t.length)return t;let e=t;return X.isTelegram()&&(X.isIos()&&(e=e.filter(s=>s!=="google")),X.isMac()&&(e=e.filter(s=>s!=="x")),X.isAndroid()&&(e=e.filter(s=>!["facebook","x"].includes(s)))),X.isMobile()&&(e=e.filter(s=>s!=="facebook")),e},isSocialsEnabled(){var t,e,s,n;return Array.isArray((t=$.state.features)==null?void 0:t.socials)&&((e=$.state.features)==null?void 0:e.socials.length)>0||Array.isArray((s=$.state.remoteFeatures)==null?void 0:s.socials)&&((n=$.state.remoteFeatures)==null?void 0:n.socials.length)>0},isEmailEnabled(){var t,e;return!!((t=$.state.features)!=null&&t.email||(e=$.state.remoteFeatures)!=null&&e.email)}},de=Ge({features:Ie.DEFAULT_FEATURES,projectId:"",sdkType:"appkit",sdkVersion:"html-wagmi-undefined",defaultAccountTypes:Ie.DEFAULT_ACCOUNT_TYPES,enableNetworkSwitch:!0,experimental_preferUniversalLinks:!1,remoteFeatures:{},enableMobileFullScreen:!1,coinbasePreference:"all"}),$={state:de,subscribeKey(t,e){return At(de,t,e)},setOptions(t){Object.assign(de,t)},setRemoteFeatures(t){var s,n;if(!t)return;const e={...de.remoteFeatures,...t};de.remoteFeatures=e,(s=de.remoteFeatures)!=null&&s.socials&&(de.remoteFeatures.socials=Ol.filterSocialsByPlatform(de.remoteFeatures.socials)),(n=de.features)!=null&&n.pay&&(de.remoteFeatures.email=!1,de.remoteFeatures.socials=!1)},setFeatures(t){var s;if(!t)return;de.features||(de.features=Ie.DEFAULT_FEATURES);const e={...de.features,...t};de.features=e,(s=de.features)!=null&&s.pay&&de.remoteFeatures&&(de.remoteFeatures.email=!1,de.remoteFeatures.socials=!1)},setProjectId(t){de.projectId=t},setCustomRpcUrls(t){de.customRpcUrls=t},setAllWallets(t){de.allWallets=t},setIncludeWalletIds(t){de.includeWalletIds=t},setExcludeWalletIds(t){de.excludeWalletIds=t},setFeaturedWalletIds(t){de.featuredWalletIds=t},setTokens(t){de.tokens=t},setTermsConditionsUrl(t){de.termsConditionsUrl=t},setPrivacyPolicyUrl(t){de.privacyPolicyUrl=t},setCustomWallets(t){de.customWallets=t},setIsSiweEnabled(t){de.isSiweEnabled=t},setIsUniversalProvider(t){de.isUniversalProvider=t},setSdkVersion(t){de.sdkVersion=t},setMetadata(t){de.metadata=t},setDisableAppend(t){de.disableAppend=t},setEIP6963Enabled(t){de.enableEIP6963=t},setDebug(t){de.debug=t},setEnableWalletGuide(t){de.enableWalletGuide=t},setEnableAuthLogger(t){de.enableAuthLogger=t},setEnableWallets(t){de.enableWallets=t},setPreferUniversalLinks(t){de.experimental_preferUniversalLinks=t},setSIWX(t){if(t)for(const[e,s]of Object.entries(Ie.SIWX_DEFAULTS))t[e]??(t[e]=s);de.siwx=t},setConnectMethodsOrder(t){de.features={...de.features,connectMethodsOrder:t}},setWalletFeaturesOrder(t){de.features={...de.features,walletFeaturesOrder:t}},setSocialsOrder(t){de.remoteFeatures={...de.remoteFeatures,socials:t}},setCollapseWallets(t){de.features={...de.features,collapseWallets:t}},setEnableEmbedded(t){de.enableEmbedded=t},setAllowUnsupportedChain(t){de.allowUnsupportedChain=t},setManualWCControl(t){de.manualWCControl=t},setEnableNetworkSwitch(t){de.enableNetworkSwitch=t},setEnableMobileFullScreen(t){de.enableMobileFullScreen=X.isMobile()&&t},setEnableReconnect(t){de.enableReconnect=t},setCoinbasePreference(t){de.coinbasePreference=t},setDefaultAccountTypes(t={}){Object.entries(t).forEach(([e,s])=>{s&&(de.defaultAccountTypes[e]=s)})},setUniversalProviderConfigOverride(t){de.universalProviderConfigOverride=t},getUniversalProviderConfigOverride(){return de.universalProviderConfigOverride},getSnapshot(){return Xi(de)}},lr=Object.freeze({message:"",variant:"success",svg:void 0,open:!1,autoClose:!0}),at=Ge({...lr}),Pv={state:at,subscribeKey(t,e){return At(at,t,e)},showLoading(t,e={}){this._showMessage({message:t,variant:"loading",...e})},showSuccess(t){this._showMessage({message:t,variant:"success"})},showSvg(t,e){this._showMessage({message:t,svg:e})},showError(t){const e=X.parseError(t);this._showMessage({message:e,variant:"error"})},hide(){at.message=lr.message,at.variant=lr.variant,at.svg=lr.svg,at.open=lr.open,at.autoClose=lr.autoClose},_showMessage({message:t,svg:e,variant:s="success",autoClose:n=lr.autoClose}){at.open?(at.open=!1,setTimeout(()=>{at.message=t,at.variant=s,at.svg=e,at.open=!0,at.autoClose=n},150)):(at.message=t,at.variant=s,at.svg=e,at.open=!0,at.autoClose=n)}},Ks=Pv,xv={purchaseCurrencies:[{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"Ether",symbol:"ETH",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]}],paymentCurrencies:[{id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},{id:"EUR",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]}]},Vf=X.getBlockchainApiUrl(),Ut=Ge({clientId:null,api:new So({baseUrl:Vf,clientId:null}),supportedChains:{http:[],ws:[]}}),fe={state:Ut,async get(t){const{st:e,sv:s}=fe.getSdkProperties(),n=$.state.projectId,r={...t.params||{},st:e,sv:s,projectId:n};return Ut.api.get({...t,params:r})},getSdkProperties(){const{sdkType:t,sdkVersion:e}=$.state;return{st:t||"unknown",sv:e||"unknown"}},async isNetworkSupported(t){if(!t)return!1;try{Ut.supportedChains.http.length||await fe.getSupportedNetworks()}catch{return!1}return Ut.supportedChains.http.includes(t)},async getSupportedNetworks(){try{const t=await fe.get({path:"v1/supported-chains"});return Ut.supportedChains=t,t}catch{return Ut.supportedChains}},async fetchIdentity({address:t}){const e=F.getIdentityFromCacheForAddress(t);if(e)return e;const s=await fe.get({path:`/v1/identity/${t}`,params:{sender:E.state.activeCaipAddress?X.getPlainAddress(E.state.activeCaipAddress):void 0}});return F.updateIdentityCache({address:t,identity:s,timestamp:Date.now()}),s},async fetchTransactions({account:t,cursor:e,signal:s,cache:n,chainId:r}){var c;if(!await fe.isNetworkSupported((c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId))return{data:[],next:void 0};const o=F.getTransactionsCacheForAddress({address:t,chainId:r});if(o)return o;const a=await fe.get({path:`/v1/account/${t}/history`,params:{cursor:e,chainId:r},signal:s,cache:n});return F.updateTransactionsCache({address:t,chainId:r,timestamp:Date.now(),transactions:a}),a},async fetchSwapQuote({amount:t,userAddress:e,from:s,to:n,gasPrice:r}){var o;return await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId)?fe.get({path:"/v1/convert/quotes",headers:{"Content-Type":"application/json"},params:{amount:t,userAddress:e,from:s,to:n,gasPrice:r}}):{quotes:[]}},async fetchSwapTokens({chainId:t}){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:"/v1/convert/tokens",params:{chainId:t}}):{tokens:[]}},async getAddressBalance({caipNetworkId:t,address:e}){return Ut.api.post({path:`/v1?chainId=${t}&projectId=${$.state.projectId}`,body:{id:"1",jsonrpc:"2.0",method:"getAddressBalance",params:{address:e}}}).then(s=>s.result)},async fetchTokenPrice({addresses:t}){var r;if(!await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))return{fungibles:[]};const s=F.getTokenPriceCacheForAddresses(t);if(s)return s;const n=await Ut.api.post({path:"/v1/fungible/price",body:{currency:"usd",addresses:t,projectId:$.state.projectId},headers:{"Content-Type":"application/json"}});return F.updateTokenPriceCache({addresses:t,timestamp:Date.now(),tokenPrice:n}),n},async fetchSwapAllowance({tokenAddress:t,userAddress:e}){var n;return await fe.isNetworkSupported((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)?fe.get({path:"/v1/convert/allowance",params:{tokenAddress:t,userAddress:e},headers:{"Content-Type":"application/json"}}):{allowance:"0"}},async fetchGasPrice({chainId:t}){var r;const{st:e,sv:s}=fe.getSdkProperties();if(!await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))throw new Error("Network not supported for Gas Price");return fe.get({path:"/v1/convert/gas-price",headers:{"Content-Type":"application/json"},params:{chainId:t,st:e,sv:s}})},async generateSwapCalldata({amount:t,from:e,to:s,userAddress:n,disableEstimate:r}){var o;if(!await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId))throw new Error("Network not supported for Swaps");return Ut.api.post({path:"/v1/convert/build-transaction",headers:{"Content-Type":"application/json"},body:{amount:t,eip155:{slippage:Ie.CONVERT_SLIPPAGE_TOLERANCE},projectId:$.state.projectId,from:e,to:s,userAddress:n,disableEstimate:r}})},async generateApproveCalldata({from:t,to:e,userAddress:s}){var o;const{st:n,sv:r}=fe.getSdkProperties();if(!await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId))throw new Error("Network not supported for Swaps");return fe.get({path:"/v1/convert/build-approve",headers:{"Content-Type":"application/json"},params:{userAddress:s,from:t,to:e,st:n,sv:r}})},async getBalance(t,e,s){var l;const{st:n,sv:r}=fe.getSdkProperties();if(!await fe.isNetworkSupported((l=E.state.activeCaipNetwork)==null?void 0:l.caipNetworkId))return Ks.showError("Token Balance Unavailable"),{balances:[]};const o=`${e}:${t}`,a=F.getBalanceCacheForCaipAddress(o);if(a)return a;const c=await fe.get({path:`/v1/account/${t}/balance`,params:{currency:"usd",chainId:e,forceUpdate:s,st:n,sv:r}});return F.updateBalanceCache({caipAddress:o,balance:c,timestamp:Date.now()}),c},async lookupEnsName(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/profile/account/${t}`,params:{apiVersion:"2"}}):{addresses:{},attributes:[]}},async reverseLookupEnsName({address:t}){var n,r;if(!await fe.isNetworkSupported((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId))return[];const s=(r=E.getAccountData())==null?void 0:r.address;return fe.get({path:`/v1/profile/reverse/${t}`,params:{sender:s,apiVersion:"2"}})},async getEnsNameSuggestions(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/profile/suggestions/${t}`,params:{zone:"reown.id"}}):{suggestions:[]}},async registerEnsName({coinType:t,address:e,message:s,signature:n}){var i;return await fe.isNetworkSupported((i=E.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)?Ut.api.post({path:"/v1/profile/account",body:{coin_type:t,address:e,message:s,signature:n},headers:{"Content-Type":"application/json"}}):{success:!1}},async generateOnRampURL({destinationWallets:t,partnerUserId:e,defaultNetwork:s,purchaseAmount:n,paymentAmount:r}){var a;return await fe.isNetworkSupported((a=E.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)?(await Ut.api.post({path:"/v1/generators/onrampurl",params:{projectId:$.state.projectId},body:{destinationWallets:t,defaultNetwork:s,partnerUserId:e,defaultExperience:"buy",presetCryptoAmount:n,presetFiatAmount:r}})).url:""},async getOnrampOptions(){var e;if(!await fe.isNetworkSupported((e=E.state.activeCaipNetwork)==null?void 0:e.caipNetworkId))return{paymentCurrencies:[],purchaseCurrencies:[]};try{return await fe.get({path:"/v1/onramp/options"})}catch{return xv}},async getOnrampQuote({purchaseCurrency:t,paymentCurrency:e,amount:s,network:n}){var r;try{return await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)?await Ut.api.post({path:"/v1/onramp/quote",params:{projectId:$.state.projectId},body:{purchaseCurrency:t,paymentCurrency:e,amount:s,network:n}}):null}catch{return{networkFee:{amount:s,currency:e.id},paymentSubtotal:{amount:s,currency:e.id},paymentTotal:{amount:s,currency:e.id},purchaseAmount:{amount:s,currency:e.id},quoteId:"mocked-quote-id"}}},async getSmartSessions(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/sessions/${t}`}):[]},async revokeSmartSession(t,e,s){var r;return await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)?Ut.api.post({path:`/v1/sessions/${t}/revoke`,params:{projectId:$.state.projectId},body:{pci:e,signature:s}}):{success:!1}},setClientId(t){Ut.clientId=t,Ut.api=new So({baseUrl:Vf,clientId:t})}},ms={PHANTOM:{id:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",url:"https://phantom.app"},SOLFLARE:{id:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",url:"https://solflare.com"},COINBASE:{id:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",url:"https://go.cb-w.com"},BINANCE:{id:"2fafea35bb471d22889ccb49c08d99dd0a18a37982602c33f696a5723934ba25",appId:"yFK5FCqYprrXDiVFbhyRx7",deeplink:"bnc://app.binance.com/mp/app",url:"https://app.binance.com/en/download"}},kv={handleMobileDeeplinkRedirect(t,e){const s=window.location.href,n=encodeURIComponent(s);if(t===ms.PHANTOM.id&&!("phantom"in window)){const r=s.startsWith("https")?"https":"http",i=s.split("/")[2],o=encodeURIComponent(`${r}://${i}`);window.location.href=`${ms.PHANTOM.url}/ul/browse/${n}?ref=${o}`}if(t===ms.SOLFLARE.id&&!("solflare"in window)&&(window.location.href=`${ms.SOLFLARE.url}/ul/v1/browse/${n}?ref=${n}`),e===U.CHAIN.SOLANA&&t===ms.COINBASE.id&&!("coinbaseSolana"in window)&&(window.location.href=`${ms.COINBASE.url}/dapp?cb_url=${n}`),e===U.CHAIN.BITCOIN&&t===ms.BINANCE.id&&!("binancew3w"in window)){const r=E.state.activeCaipNetwork,i=window.btoa("/pages/browser/index"),o=window.btoa(`url=${n}&defaultChainId=${(r==null?void 0:r.id)??1}`),a=new URL(ms.BINANCE.deeplink);a.searchParams.set("appId",ms.BINANCE.appId),a.searchParams.set("startPagePath",i),a.searchParams.set("startPageQuery",o);const c=new URL(ms.BINANCE.url);c.searchParams.set("_dp",window.btoa(a.toString())),window.location.href=c.toString()}}},Uv=Object.freeze({enabled:!0,events:[]}),$v=new So({baseUrl:X.getAnalyticsUrl(),clientId:null}),Dv=5,Lv=60*1e3,Rn=Ge({...Uv}),Mv={state:Rn,subscribeKey(t,e){return At(Rn,t,e)},async sendError(t,e){if(!Rn.enabled)return;const s=Date.now();if(Rn.events.filter(i=>{const o=new Date(i.properties.timestamp||"").getTime();return s-o<Lv}).length>=Dv)return;const r={type:"error",event:e,properties:{errorType:t.name,errorMessage:t.message,stackTrace:t.stack,timestamp:new Date().toISOString()}};Rn.events.push(r);try{if(typeof window>"u")return;const{projectId:i,sdkType:o,sdkVersion:a}=$.state;await $v.post({path:"/e",params:{projectId:i,st:o,sv:a||"html-wagmi-4.2.2"},body:{eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:new Date().toISOString(),props:{type:"error",event:e,errorType:t.name,errorMessage:t.message,stackTrace:t.stack}}})}catch{}},enable(){Rn.enabled=!0},disable(){Rn.enabled=!1},clearEvents(){Rn.events=[]}};class Tr extends Error{constructor(e,s,n){super(e),this.originalName="AppKitError",this.name="AppKitError",this.category=s,this.originalError=n,n&&n instanceof Error&&(this.originalName=n.name),Object.setPrototypeOf(this,Tr.prototype);let r=!1;if(n instanceof Error&&typeof n.stack=="string"&&n.stack){const i=n.stack,o=i.indexOf(`
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/index-DeGBgVeI.js","assets/verifyHash-CWmIX1-Z.js","assets/NetworkUtil-3SIrikOw.js","assets/index-xGFXY5RX.js","assets/index-C7O9dqJ5.css","assets/ccip-Df4LKgZK.js","assets/features-BbA7J1KA.js","assets/embedded-wallet-CG7TbOV-.js","assets/index-uPtowLYG.js","assets/index-BSk3zAXq.js","assets/if-defined-Dr097eDH.js","assets/ref-CPwoUAPs.js","assets/index-DlVZs1oU.js","assets/HelpersUtil-DNBPWmHy.js","assets/ConstantsUtil-Cw5uH-i5.js","assets/index-4tzrFolB.js","assets/index-Cwe7emK5.js","assets/index-BWv932mQ.js","assets/index-Bv-MB-53.js","assets/index-BmUGzhOu.js","assets/NavigationUtil-DmfK5sOV.js","assets/email-BG_i___x.js","assets/index-B5TtbbC5.js","assets/index-ChZ5AYqd.js","assets/socials-Dc6QGKNd.js","assets/index-CP_uj5Ou.js","assets/index-HR0EdyCk.js","assets/index-C4Iw9Gtu.js","assets/index-zk_kM3aZ.js","assets/index-DYpsaqOT.js","assets/swaps-11Cmmiib.js","assets/index-D7KzIusu.js","assets/index-D3Kjyb0X.js","assets/SwapController-BGRlDmCA.js","assets/index-DTzL6GLY.js","assets/send-lCTQJ_pv.js","assets/index-CyeE4RgJ.js","assets/index-B-U3jRM1.js","assets/index-B3_NJasS.js","assets/index-DMLVtHMI.js","assets/receive-CcTr-1Qk.js","assets/onramp-BUHkZqza.js","assets/index-DxbiZFrZ.js","assets/index-CHE56tT6.js","assets/index-HWZ6yYA8.js","assets/pay-with-exchange-sBe4iQtb.js","assets/ExchangeController-B8g6pRfS.js","assets/transactions-DFf4sRIF.js","assets/index-CBk7djGV.js","assets/index-yx1vikfy.js","assets/index-ClmwewVJ.js","assets/index-C8dGzvIM.js","assets/index-DFYCage7.js","assets/data-capture-C6QaYSs8.js","assets/index-3gO2YMOL.js","assets/index-DMuYTl5Z.js","assets/w3m-modal-DrW1uZDo.js"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{b as En,n as vy,g as Cy,s as Gi,_ as Dt,o as Lo,p as Ca,q as _y,u as Ay,v as Sy,w as Iy,x as Ny,y as iu,I as fi,z as Ty,A as Cs,B as Qt,C as Z,D as An,E as Ry,F as Oy,G as Ue,J as Mi,K as El,L as Py,M as xy,N as ky,O as xr,P as Uy,Q as zs,R as gi,S as Cd,T as $y,U as _d,V as Ad,W as Yi,X as Sd,Y as ou,Z as Dy,$ as Ly,a0 as fr,a1 as Cf,a2 as cn,a3 as Hs,a4 as Nn,a5 as _f}from"./index-xGFXY5RX.js";import{C as U,L as My,a5 as Mo,m as By,s as la,H as Bi,B as Af,ag as jy,ak as da,W as au,X as cu,Y as lu,af as du,_ as uu,ah as hu,ai as pu,ac as fu,Z as gu,a7 as mu,aj as yu,ae as wu,a2 as Eu,a3 as bl,ad as vl,aa as bu,a9 as vu,I as Cu,$ as Cl,a0 as _u,a4 as Au,a1 as Su,a6 as Iu,V as Nu,E as Fy,aA as qy,R as Wy,aC as Sf,aq as If,p as Bo,aD as Nf,at as Hy,av as zy,aw as Vy,ax as Ky,ay as Gy,as as Yy,t as Tu}from"./NetworkUtil-3SIrikOw.js";const Tf={isLowerCaseMatch(t,e){return(t==null?void 0:t.toLowerCase())===(e==null?void 0:e.toLowerCase())}};var Zy=20,Jy=1,mi=1e6,Xy=1e6,Qy=-7,ew=21,tw=!1,Co="[big.js] ",kr=Co+"Invalid ",tc=kr+"decimal places",sw=kr+"rounding mode",Rf=Co+"Division by zero",qe={},Zs=void 0,nw=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function Of(){function t(e){var s=this;if(!(s instanceof t))return e===Zs?Of():new t(e);if(e instanceof t)s.s=e.s,s.e=e.e,s.c=e.c.slice();else{if(typeof e!="string"){if(t.strict===!0&&typeof e!="bigint")throw TypeError(kr+"value");e=e===0&&1/e<0?"-0":String(e)}rw(s,e)}s.constructor=t}return t.prototype=qe,t.DP=Zy,t.RM=Jy,t.NE=Qy,t.PE=ew,t.strict=tw,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}function rw(t,e){var s,n,r;if(!nw.test(e))throw Error(kr+"number");for(t.s=e.charAt(0)=="-"?(e=e.slice(1),-1):1,(s=e.indexOf("."))>-1&&(e=e.replace(".","")),(n=e.search(/e/i))>0?(s<0&&(s=n),s+=+e.slice(n+1),e=e.substring(0,n)):s<0&&(s=e.length),r=e.length,n=0;n<r&&e.charAt(n)=="0";)++n;if(n==r)t.c=[t.e=0];else{for(;r>0&&e.charAt(--r)=="0";);for(t.e=s-n-1,t.c=[],s=0;n<=r;)t.c[s++]=+e.charAt(n++)}return t}function Ur(t,e,s,n){var r=t.c;if(s===Zs&&(s=t.constructor.RM),s!==0&&s!==1&&s!==2&&s!==3)throw Error(sw);if(e<1)n=s===3&&(n||!!r[0])||e===0&&(s===1&&r[0]>=5||s===2&&(r[0]>5||r[0]===5&&(n||r[1]!==Zs))),r.length=1,n?(t.e=t.e-e+1,r[0]=1):r[0]=t.e=0;else if(e<r.length){if(n=s===1&&r[e]>=5||s===2&&(r[e]>5||r[e]===5&&(n||r[e+1]!==Zs||r[e-1]&1))||s===3&&(n||!!r[0]),r.length=e,n){for(;++r[--e]>9;)if(r[e]=0,e===0){++t.e,r.unshift(1);break}}for(e=r.length;!r[--e];)r.pop()}return t}function $r(t,e,s){var n=t.e,r=t.c.join(""),i=r.length;if(e)r=r.charAt(0)+(i>1?"."+r.slice(1):"")+(n<0?"e":"e+")+n;else if(n<0){for(;++n;)r="0"+r;r="0."+r}else if(n>0)if(++n>i)for(n-=i;n--;)r+="0";else n<i&&(r=r.slice(0,n)+"."+r.slice(n));else i>1&&(r=r.charAt(0)+"."+r.slice(1));return t.s<0&&s?"-"+r:r}qe.abs=function(){var t=new this.constructor(this);return t.s=1,t};qe.cmp=function(t){var e,s=this,n=s.c,r=(t=new s.constructor(t)).c,i=s.s,o=t.s,a=s.e,c=t.e;if(!n[0]||!r[0])return n[0]?i:r[0]?-o:0;if(i!=o)return i;if(e=i<0,a!=c)return a>c^e?1:-1;for(o=(a=n.length)<(c=r.length)?a:c,i=-1;++i<o;)if(n[i]!=r[i])return n[i]>r[i]^e?1:-1;return a==c?0:a>c^e?1:-1};qe.div=function(t){var e=this,s=e.constructor,n=e.c,r=(t=new s(t)).c,i=e.s==t.s?1:-1,o=s.DP;if(o!==~~o||o<0||o>mi)throw Error(tc);if(!r[0])throw Error(Rf);if(!n[0])return t.s=i,t.c=[t.e=0],t;var a,c,l,d,u,h=r.slice(),p=a=r.length,g=n.length,f=n.slice(0,a),y=f.length,_=t,S=_.c=[],v=0,C=o+(_.e=e.e-t.e)+1;for(_.s=i,i=C<0?0:C,h.unshift(0);y++<a;)f.push(0);do{for(l=0;l<10;l++){if(a!=(y=f.length))d=a>y?1:-1;else for(u=-1,d=0;++u<a;)if(r[u]!=f[u]){d=r[u]>f[u]?1:-1;break}if(d<0){for(c=y==a?r:h;y;){if(f[--y]<c[y]){for(u=y;u&&!f[--u];)f[u]=9;--f[u],f[y]+=10}f[y]-=c[y]}for(;!f[0];)f.shift()}else break}S[v++]=d?l:++l,f[0]&&d?f[y]=n[p]||0:f=[n[p]]}while((p++<g||f[0]!==Zs)&&i--);return!S[0]&&v!=1&&(S.shift(),_.e--,C--),v>C&&Ur(_,C,s.RM,f[0]!==Zs),_};qe.eq=function(t){return this.cmp(t)===0};qe.gt=function(t){return this.cmp(t)>0};qe.gte=function(t){return this.cmp(t)>-1};qe.lt=function(t){return this.cmp(t)<0};qe.lte=function(t){return this.cmp(t)<1};qe.minus=qe.sub=function(t){var e,s,n,r,i=this,o=i.constructor,a=i.s,c=(t=new o(t)).s;if(a!=c)return t.s=-c,i.plus(t);var l=i.c.slice(),d=i.e,u=t.c,h=t.e;if(!l[0]||!u[0])return u[0]?t.s=-c:l[0]?t=new o(i):t.s=1,t;if(a=d-h){for((r=a<0)?(a=-a,n=l):(h=d,n=u),n.reverse(),c=a;c--;)n.push(0);n.reverse()}else for(s=((r=l.length<u.length)?l:u).length,a=c=0;c<s;c++)if(l[c]!=u[c]){r=l[c]<u[c];break}if(r&&(n=l,l=u,u=n,t.s=-t.s),(c=(s=u.length)-(e=l.length))>0)for(;c--;)l[e++]=0;for(c=e;s>a;){if(l[--s]<u[s]){for(e=s;e&&!l[--e];)l[e]=9;--l[e],l[s]+=10}l[s]-=u[s]}for(;l[--c]===0;)l.pop();for(;l[0]===0;)l.shift(),--h;return l[0]||(t.s=1,l=[h=0]),t.c=l,t.e=h,t};qe.mod=function(t){var e,s=this,n=s.constructor,r=s.s,i=(t=new n(t)).s;if(!t.c[0])throw Error(Rf);return s.s=t.s=1,e=t.cmp(s)==1,s.s=r,t.s=i,e?new n(s):(r=n.DP,i=n.RM,n.DP=n.RM=0,s=s.div(t),n.DP=r,n.RM=i,this.minus(s.times(t)))};qe.neg=function(){var t=new this.constructor(this);return t.s=-t.s,t};qe.plus=qe.add=function(t){var e,s,n,r=this,i=r.constructor;if(t=new i(t),r.s!=t.s)return t.s=-t.s,r.minus(t);var o=r.e,a=r.c,c=t.e,l=t.c;if(!a[0]||!l[0])return l[0]||(a[0]?t=new i(r):t.s=r.s),t;if(a=a.slice(),e=o-c){for(e>0?(c=o,n=l):(e=-e,n=a),n.reverse();e--;)n.push(0);n.reverse()}for(a.length-l.length<0&&(n=l,l=a,a=n),e=l.length,s=0;e;a[e]%=10)s=(a[--e]=a[e]+l[e]+s)/10|0;for(s&&(a.unshift(s),++c),e=a.length;a[--e]===0;)a.pop();return t.c=a,t.e=c,t};qe.pow=function(t){var e=this,s=new e.constructor("1"),n=s,r=t<0;if(t!==~~t||t<-1e6||t>Xy)throw Error(kr+"exponent");for(r&&(t=-t);t&1&&(n=n.times(e)),t>>=1,!!t;)e=e.times(e);return r?s.div(n):n};qe.prec=function(t,e){if(t!==~~t||t<1||t>mi)throw Error(kr+"precision");return Ur(new this.constructor(this),t,e)};qe.round=function(t,e){if(t===Zs)t=0;else if(t!==~~t||t<-1e6||t>mi)throw Error(tc);return Ur(new this.constructor(this),t+this.e+1,e)};qe.sqrt=function(){var t,e,s,n=this,r=n.constructor,i=n.s,o=n.e,a=new r("0.5");if(!n.c[0])return new r(n);if(i<0)throw Error(Co+"No square root");i=Math.sqrt(+$r(n,!0,!0)),i===0||i===1/0?(e=n.c.join(""),e.length+o&1||(e+="0"),i=Math.sqrt(e),o=((o+1)/2|0)-(o<0||o&1),t=new r((i==1/0?"5e":(i=i.toExponential()).slice(0,i.indexOf("e")+1))+o)):t=new r(i+""),o=t.e+(r.DP+=4);do s=t,t=a.times(s.plus(n.div(s)));while(s.c.slice(0,o).join("")!==t.c.slice(0,o).join(""));return Ur(t,(r.DP-=4)+t.e+1,r.RM)};qe.times=qe.mul=function(t){var e,s=this,n=s.constructor,r=s.c,i=(t=new n(t)).c,o=r.length,a=i.length,c=s.e,l=t.e;if(t.s=s.s==t.s?1:-1,!r[0]||!i[0])return t.c=[t.e=0],t;for(t.e=c+l,o<a&&(e=r,r=i,i=e,l=o,o=a,a=l),e=new Array(l=o+a);l--;)e[l]=0;for(c=a;c--;){for(a=0,l=o+c;l>c;)a=e[l]+i[c]*r[l-c-1]+a,e[l--]=a%10,a=a/10|0;e[l]=a}for(a?++t.e:e.shift(),c=e.length;!e[--c];)e.pop();return t.c=e,t};qe.toExponential=function(t,e){var s=this,n=s.c[0];if(t!==Zs){if(t!==~~t||t<0||t>mi)throw Error(tc);for(s=Ur(new s.constructor(s),++t,e);s.c.length<t;)s.c.push(0)}return $r(s,!0,!!n)};qe.toFixed=function(t,e){var s=this,n=s.c[0];if(t!==Zs){if(t!==~~t||t<0||t>mi)throw Error(tc);for(s=Ur(new s.constructor(s),t+s.e+1,e),t=t+s.e+1;s.c.length<t;)s.c.push(0)}return $r(s,!1,!!n)};qe[Symbol.for("nodejs.util.inspect.custom")]=qe.toJSON=qe.toString=function(){var t=this,e=t.constructor;return $r(t,t.e<=e.NE||t.e>=e.PE,!!t.c[0])};qe.toNumber=function(){var t=+$r(this,!0,!0);if(this.constructor.strict===!0&&!this.eq(t.toString()))throw Error(Co+"Imprecise conversion");return t};qe.toPrecision=function(t,e){var s=this,n=s.constructor,r=s.c[0];if(t!==Zs){if(t!==~~t||t<1||t>mi)throw Error(kr+"precision");for(s=Ur(new n(s),t,e);s.c.length<t;)s.c.push(0)}return $r(s,t<=s.e||s.e<=n.NE||s.e>=n.PE,!!r)};qe.valueOf=function(){var t=this,e=t.constructor;if(e.strict===!0)throw Error(Co+"valueOf disallowed");return $r(t,t.e<=e.NE||t.e>=e.PE,!0)};var Tn=Of();const iw={bigNumber(t){return t?new Tn(t):new Tn(0)},multiply(t,e){if(t===void 0||e===void 0)return new Tn(0);const s=new Tn(t),n=new Tn(e);return s.times(n)},toFixed(t,e=2){return t===void 0||t===""?new Tn(0).toFixed(e):new Tn(t).toFixed(e)},formatNumberToLocalString(t,e=2){return t===void 0||t===""?"0.00":typeof t=="number"?t.toLocaleString("en-US",{maximumFractionDigits:e,minimumFractionDigits:e,roundingMode:"floor"}):parseFloat(t).toLocaleString("en-US",{maximumFractionDigits:e,minimumFractionDigits:e,roundingMode:"floor"})},parseLocalStringToNumber(t){if(t===void 0||t==="")return 0;const e=t.replace(/,/gu,"");return new Tn(e).toNumber()}},ow=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"_from",type:"address"},{name:"_to",type:"address"},{name:"_value",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],aw=[{type:"function",name:"approve",stateMutability:"nonpayable",inputs:[{name:"spender",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]}],cw=[{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"sender",type:"address"},{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{name:"",type:"bool"}]}],lw={getERC20Abi:t=>U.USDT_CONTRACT_ADDRESSES.includes(t)?cw:ow,getSwapAbi:()=>aw},Mr={ConnectorExplorerIds:{[U.CONNECTOR_ID.COINBASE]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.COINBASE_SDK]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.BASE_ACCOUNT]:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",[U.CONNECTOR_ID.SAFE]:"225affb176778569276e484e1b92637ad061b01e13a048b35a9d280c3b58970f",[U.CONNECTOR_ID.LEDGER]:"19177a98252e07ddfc9af2083ba8e07ef627cb6103467ffebb3f8f4205fd7927",[U.CONNECTOR_ID.OKX]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[U.METMASK_CONNECTOR_NAME]:"c57ca95b47569778a828d19178114f4db188b89b763c899ba0be274e97267d96",[U.TRUST_CONNECTOR_NAME]:"4622a2b2d6af1c9844944291e5e7351a6aa24cd7b23099efac1b2fd875da31a0",[U.SOLFLARE_CONNECTOR_NAME]:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",[U.PHANTOM_CONNECTOR_NAME]:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",[U.COIN98_CONNECTOR_NAME]:"2a3c89040ac3b723a1972a33a125b1db11e258a6975d3a61252cd64e6ea5ea01",[U.MAGIC_EDEN_CONNECTOR_NAME]:"8b830a2b724a9c3fbab63af6f55ed29c9dfa8a55e732dc88c80a196a2ba136c6",[U.BACKPACK_CONNECTOR_NAME]:"2bd8c14e035c2d48f184aaa168559e86b0e3433228d3c4075900a221785019b0",[U.BITGET_CONNECTOR_NAME]:"38f5d18bd8522c244bdd70cb4a68e0e718865155811c043f052fb9f1c51de662",[U.FRONTIER_CONNECTOR_NAME]:"85db431492aa2e8672e93f4ea7acf10c88b97b867b0d373107af63dc4880f041",[U.XVERSE_CONNECTOR_NAME]:"2a87d74ae02e10bdd1f51f7ce6c4e1cc53cd5f2c0b6b5ad0d7b3007d2b13de7b",[U.LEATHER_CONNECTOR_NAME]:"483afe1df1df63daf313109971ff3ef8356ddf1cc4e45877d205eee0b7893a13",[U.OKX_CONNECTOR_NAME]:"971e689d0a5be527bac79629b4ee9b925e82208e5168b733496a09c0faed0709",[U.BINANCE_CONNECTOR_NAME]:"2fafea35bb471d22889ccb49c08d99dd0a18a37982602c33f696a5723934ba25"}},dt={validateCaipAddress(t){var e;if(((e=t.split(":"))==null?void 0:e.length)!==3)throw new Error("Invalid CAIP Address");return t},parseCaipAddress(t){const e=t.split(":");if(e.length!==3)throw new Error(`Invalid CAIP-10 address: ${t}`);const[s,n,r]=e;if(!s||!n||!r)throw new Error(`Invalid CAIP-10 address: ${t}`);return{chainNamespace:s,chainId:n,address:r}},parseCaipNetworkId(t){const e=t.split(":");if(e.length!==2)throw new Error(`Invalid CAIP-2 network id: ${t}`);const[s,n]=e;if(!s||!n)throw new Error(`Invalid CAIP-2 network id: ${t}`);return{chainNamespace:s,chainId:n}}},mn={RPC_ERROR_CODE:{USER_REJECTED_REQUEST:4001,USER_REJECTED_METHODS:5002,USER_REJECTED:5e3},PROVIDER_RPC_ERROR_NAME:{PROVIDER_RPC:"ProviderRpcError",USER_REJECTED_REQUEST:"UserRejectedRequestError"},isRpcProviderError(t){try{if(typeof t=="object"&&t!==null){const e=t,s=typeof e.message=="string",n=typeof e.code=="number";return s&&n}return!1}catch{return!1}},isUserRejectedMessage(t){return t.toLowerCase().includes("user rejected")||t.toLowerCase().includes("user cancelled")||t.toLowerCase().includes("user canceled")},isUserRejectedRequestError(t){if(mn.isRpcProviderError(t)){const e=t.code===mn.RPC_ERROR_CODE.USER_REJECTED_REQUEST,s=t.code===mn.RPC_ERROR_CODE.USER_REJECTED_METHODS;return e||s||mn.isUserRejectedMessage(t.message)}return t instanceof Error?mn.isUserRejectedMessage(t.message):!1}};class dw extends Error{constructor(e,s){super(s.message,{cause:e}),this.name=mn.PROVIDER_RPC_ERROR_NAME.PROVIDER_RPC,this.code=s.code}}class Pf extends dw{constructor(e){super(e,{code:mn.RPC_ERROR_CODE.USER_REJECTED_REQUEST,message:"User rejected the request"}),this.name=mn.PROVIDER_RPC_ERROR_NAME.USER_REJECTED_REQUEST}}const le={WALLET_ID:"@appkit/wallet_id",WALLET_NAME:"@appkit/wallet_name",SOLANA_WALLET:"@appkit/solana_wallet",SOLANA_CAIP_CHAIN:"@appkit/solana_caip_chain",ACTIVE_CAIP_NETWORK_ID:"@appkit/active_caip_network_id",CONNECTED_SOCIAL:"@appkit/connected_social",CONNECTED_SOCIAL_USERNAME:"@appkit-wallet/SOCIAL_USERNAME",RECENT_WALLETS:"@appkit/recent_wallets",RECENT_WALLET:"@appkit/recent_wallet",DEEPLINK_CHOICE:"WALLETCONNECT_DEEPLINK_CHOICE",ACTIVE_NAMESPACE:"@appkit/active_namespace",CONNECTED_NAMESPACES:"@appkit/connected_namespaces",CONNECTION_STATUS:"@appkit/connection_status",SIWX_AUTH_TOKEN:"@appkit/siwx-auth-token",SIWX_NONCE_TOKEN:"@appkit/siwx-nonce-token",TELEGRAM_SOCIAL_PROVIDER:"@appkit/social_provider",NATIVE_BALANCE_CACHE:"@appkit/native_balance_cache",PORTFOLIO_CACHE:"@appkit/portfolio_cache",ENS_CACHE:"@appkit/ens_cache",IDENTITY_CACHE:"@appkit/identity_cache",PREFERRED_ACCOUNT_TYPES:"@appkit/preferred_account_types",CONNECTIONS:"@appkit/connections",DISCONNECTED_CONNECTOR_IDS:"@appkit/disconnected_connector_ids",HISTORY_TRANSACTIONS_CACHE:"@appkit/history_transactions_cache",TOKEN_PRICE_CACHE:"@appkit/token_price_cache",RECENT_EMAILS:"@appkit/recent_emails",LATEST_APPKIT_VERSION:"@appkit/latest_version",TON_WALLETS_CACHE:"@appkit/ton_wallets_cache"};function vc(t){if(!t)throw new Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${t}:connected_connector_id`}const ae={setItem(t,e){xi()&&e!==void 0&&localStorage.setItem(t,e)},getItem(t){if(xi())return localStorage.getItem(t)||void 0},removeItem(t){xi()&&localStorage.removeItem(t)},clear(){xi()&&localStorage.clear()}};function xi(){return typeof window<"u"&&typeof localStorage<"u"}function Zi(t,e){const s=(t==null?void 0:t["--apkt-accent"])??(t==null?void 0:t["--w3m-accent"]);return e==="light"?{"--w3m-accent":s||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":s||"hsla(230, 100%, 67%, 1)","--w3m-background":"#202020"}}const uw=Symbol(),Ru=Object.getPrototypeOf,_l=new WeakMap,hw=t=>t&&(_l.has(t)?_l.get(t):Ru(t)===Object.prototype||Ru(t)===Array.prototype),pw=t=>hw(t)&&t[uw]||null,Ou=(t,e=!0)=>{_l.set(t,e)},_a={},Id=t=>typeof t=="object"&&t!==null,fw=t=>Id(t)&&!_o.has(t)&&(Array.isArray(t)||!(Symbol.iterator in t))&&!(t instanceof WeakMap)&&!(t instanceof WeakSet)&&!(t instanceof Error)&&!(t instanceof Number)&&!(t instanceof Date)&&!(t instanceof String)&&!(t instanceof RegExp)&&!(t instanceof ArrayBuffer)&&!(t instanceof Promise),xf=(t,e)=>{const s=Al.get(t);if((s==null?void 0:s[0])===e)return s[1];const n=Array.isArray(t)?[]:Object.create(Object.getPrototypeOf(t));return Ou(n,!0),Al.set(t,[e,n]),Reflect.ownKeys(t).forEach(r=>{if(Object.getOwnPropertyDescriptor(n,r))return;const i=Reflect.get(t,r),{enumerable:o}=Reflect.getOwnPropertyDescriptor(t,r),a={value:i,enumerable:o,configurable:!0};if(_o.has(i))Ou(i,!1);else if(Yn.has(i)){const[c,l]=Yn.get(i);a.value=xf(c,l())}Object.defineProperty(n,r,a)}),Object.preventExtensions(n)},gw=(t,e,s,n)=>({deleteProperty(r,i){const o=Reflect.get(r,i);s(i);const a=Reflect.deleteProperty(r,i);return a&&n(["delete",[i],o]),a},set(r,i,o,a){const c=!t()&&Reflect.has(r,i),l=Reflect.get(r,i,a);if(c&&(Pu(l,o)||Ji.has(o)&&Pu(l,Ji.get(o))))return!0;s(i),Id(o)&&(o=pw(o)||o);const d=!Yn.has(o)&&yw(o)?Ge(o):o;return e(i,d),Reflect.set(r,i,d,a),n(["set",[i],o,l]),!0}}),Yn=new WeakMap,_o=new WeakSet,Al=new WeakMap,ua=[1],Ji=new WeakMap;let Pu=Object.is,mw=(t,e)=>new Proxy(t,e),yw=fw,ww=xf,Ew=gw;function Ge(t={}){if(!Id(t))throw new Error("object required");const e=Ji.get(t);if(e)return e;let s=ua[0];const n=new Set,r=(y,_=++ua[0])=>{s!==_&&(i=s=_,n.forEach(S=>S(y,_)))};let i=s;const o=(y=ua[0])=>(i!==y&&(i=y,c.forEach(([_])=>{const S=_[1](y);S>s&&(s=S)})),s),a=y=>(_,S)=>{const v=[..._];v[1]=[y,...v[1]],r(v,S)},c=new Map,l=(y,_)=>{const S=!_o.has(_)&&Yn.get(_);if(S){if((_a?"production":void 0)!=="production"&&c.has(y))throw new Error("prop listener already exists");if(n.size){const v=S[2](a(y));c.set(y,[S,v])}else c.set(y,[S])}},d=y=>{var _;const S=c.get(y);S&&(c.delete(y),(_=S[1])==null||_.call(S))},u=y=>(n.add(y),n.size===1&&c.forEach(([S,v],C)=>{if((_a?"production":void 0)!=="production"&&v)throw new Error("remove already exists");const R=S[2](a(C));c.set(C,[S,R])}),()=>{n.delete(y),n.size===0&&c.forEach(([S,v],C)=>{v&&(v(),c.set(C,[S]))})});let h=!0;const p=Ew(()=>h,l,d,r),g=mw(t,p);Ji.set(t,g);const f=[t,o,u];return Yn.set(g,f),Reflect.ownKeys(t).forEach(y=>{const _=Object.getOwnPropertyDescriptor(t,y);"value"in _&&_.writable&&(g[y]=t[y])}),h=!1,g}function _t(t,e,s){const n=Yn.get(t);(_a?"production":void 0)!=="production"&&!n&&console.warn("Please use proxy object");let r;const i=[],o=n[2];let a=!1;const l=o(d=>{i.push(d),r||(r=Promise.resolve().then(()=>{r=void 0,a&&e(i.splice(0))}))});return a=!0,()=>{a=!1,l()}}function Xi(t){const e=Yn.get(t);(_a?"production":void 0)!=="production"&&!e&&console.warn("Please use proxy object");const[s,n]=e;return ww(s,n())}function Qi(t){return _o.add(t),t}function bw(){return{proxyStateMap:Yn,refSet:_o,snapCache:Al,versionHolder:ua,proxyCache:Ji}}function At(t,e,s,n){let r=t[e];return _t(t,()=>{const i=t[e];Object.is(r,i)||s(r=i)})}const{proxyStateMap:vw,snapCache:Cw}=bw(),jo=t=>vw.has(t);function _w(t){const e=[];let s=0;const n=new Map,r=new WeakMap,i=()=>{const l=Cw.get(a),d=l==null?void 0:l[1];if(d&&!r.has(d)){const u=new Map(n);r.set(d,u)}},o=l=>r.get(l)||n,a={data:e,index:s,epoch:0,get size(){return jo(this)||i(),o(this).size},get(l){const u=o(this).get(l);if(u===void 0){this.epoch;return}return this.data[u]},has(l){const d=o(this);return this.epoch,d.has(l)},set(l,d){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");const u=n.get(l);return u===void 0?(n.set(l,this.index),this.data[this.index++]=d):this.data[u]=d,this.epoch++,this},delete(l){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");const d=n.get(l);return d===void 0?!1:(delete this.data[d],n.delete(l),this.epoch++,!0)},clear(){if(!jo(this))throw new Error("Cannot perform mutations on a snapshot");this.data.length=0,this.index=0,this.epoch++,n.clear()},forEach(l){this.epoch,o(this).forEach((u,h)=>{l(this.data[u],h,this)})},*entries(){this.epoch;const l=o(this);for(const[d,u]of l)yield[d,this.data[u]]},*keys(){this.epoch;const l=o(this);for(const d of l.keys())yield d},*values(){this.epoch;const l=o(this);for(const d of l.values())yield this.data[d]},[Symbol.iterator](){return this.entries()},get[Symbol.toStringTag](){return"Map"},toJSON(){return new Map(this.entries())}},c=Ge(a);return Object.defineProperties(c,{size:{enumerable:!1},index:{enumerable:!1},epoch:{enumerable:!1},data:{enumerable:!1},toJSON:{enumerable:!1}}),Object.seal(c),c}var xu={};const Cc=(typeof En<"u"&&typeof xu<"u"?xu.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",kf=[{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],Aw="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",Ie={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:Cc,SECURE_SITE_DASHBOARD:`${Cc}/dashboard`,SECURE_SITE_FAVICON:`${Cc}/images/favicon.png`,SOLANA_NATIVE_TOKEN_ADDRESS:"So11111111111111111111111111111111111111111",RESTRICTED_TIMEZONES:["ASIA/SHANGHAI","ASIA/URUMQI","ASIA/CHONGQING","ASIA/HARBIN","ASIA/KASHGAR","ASIA/MACAU","ASIA/HONG_KONG","ASIA/MACAO","ASIA/BEIJING","ASIA/HARBIN"],SWAP_SUGGESTED_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP"],SWAP_POPULAR_TOKENS:["ETH","UNI","1INCH","AAVE","SOL","ADA","AVAX","DOT","LINK","NITRO","GAIA","MILK","TRX","NEAR","GNO","WBTC","DAI","WETH","USDC","USDT","ARB","BAL","BICO","CRV","ENS","MATIC","OP","METAL","DAI","CHAMP","WOLF","SALE","BAL","BUSD","MUST","BTCpx","ROUTE","HEX","WELT","amDAI","VSQ","VISION","AURUM","pSP","SNX","VC","LINK","CHP","amUSDT","SPHERE","FOX","GIDDY","GFC","OMEN","OX_OLD","DE","WNT"],SUGGESTED_TOKENS_BY_CHAIN:{"eip155:42161":["USD₮0"]},BALANCE_SUPPORTED_CHAINS:[U.CHAIN.EVM,U.CHAIN.SOLANA],SEND_PARAMS_SUPPORTED_CHAINS:[U.CHAIN.EVM],SWAP_SUPPORTED_NETWORKS:["eip155:1","eip155:42161","eip155:10","eip155:324","eip155:8453","eip155:56","eip155:137","eip155:100","eip155:43114","eip155:250","eip155:8217","eip155:1313161554"],NAMES_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM],ONRAMP_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],PAY_WITH_EXCHANGE_SUPPORTED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],ACTIVITY_ENABLED_CHAIN_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.TON],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x",sui:"0x",stacks:"0x",ton:"0x"},CONVERT_SLIPPAGE_TOLERANCE:1,CONNECT_LABELS:{MOBILE:"Open and continue in the wallet app",WEB:"Open and continue in the wallet app"},SEND_SUPPORTED_NAMESPACES:[U.CHAIN.EVM,U.CHAIN.SOLANA],DEFAULT_REMOTE_FEATURES:{swaps:["1inch"],onramp:["meld"],email:!0,socials:["google","x","discord","farcaster","github","apple","facebook"],activity:!0,reownBranding:!0,multiWallet:!1,emailCapture:!1,payWithExchange:!1,payments:!1,reownAuthentication:!1,headless:!1},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1,emailCapture:!1,reownAuthentication:!1,headless:!1},DEFAULT_FEATURES:{receive:!0,send:!0,emailShowWallets:!0,connectorTypeOrder:["walletConnect","recent","injected","featured","custom","external","recommended"],analytics:!0,allWallets:!0,legalCheckbox:!1,smartSessions:!1,collapseWallets:!1,walletFeaturesOrder:["onramp","swaps","receive","send"],connectMethodsOrder:void 0,pay:!1,reownAuthentication:!1,headless:!1},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa",ton:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"},SIWX_DEFAULTS:{signOutOnDisconnect:!0},MANDATORY_WALLET_IDS_ON_MOBILE:[Mr.ConnectorExplorerIds[U.CONNECTOR_ID.COINBASE],Mr.ConnectorExplorerIds[U.CONNECTOR_ID.COINBASE_SDK],Mr.ConnectorExplorerIds[U.CONNECTOR_ID.BASE_ACCOUNT],Mr.ConnectorExplorerIds[U.SOLFLARE_CONNECTOR_NAME],Mr.ConnectorExplorerIds[U.PHANTOM_CONNECTOR_NAME],Mr.ConnectorExplorerIds[U.BINANCE_CONNECTOR_NAME]],DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"]},F={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5,transactionsHistory:15e3,tokenPrice:15e3,latestAppKitVersion:6048e5,tonWallets:864e5},isCacheExpired(t,e){return Date.now()-t>e},getActiveNetworkProps(){const t=F.getActiveNamespace(),e=F.getActiveCaipNetworkId(),s=e?e.split(":")[1]:void 0,n=s?isNaN(Number(s))?s:Number(s):void 0;return{namespace:t,caipNetworkId:e,chainId:n}},setWalletConnectDeepLink({name:t,href:e}){try{ae.setItem(le.DEEPLINK_CHOICE,JSON.stringify({href:e,name:t}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{const t=ae.getItem(le.DEEPLINK_CHOICE);if(t)return JSON.parse(t)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{ae.removeItem(le.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(t){try{ae.setItem(le.ACTIVE_NAMESPACE,t)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(t){try{ae.setItem(le.ACTIVE_CAIP_NETWORK_ID,t),F.setActiveNamespace(t.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return ae.getItem(le.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{ae.removeItem(le.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(t){try{const e=vc(t);ae.removeItem(e)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(t){try{const e=F.getRecentWallets();e.find(n=>n.id===t.id)||(e.unshift(t),e.length>2&&e.pop(),ae.setItem(le.RECENT_WALLETS,JSON.stringify(e)),ae.setItem(le.RECENT_WALLET,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{const t=ae.getItem(le.RECENT_WALLETS);return t?JSON.parse(t):[]}catch{console.info("Unable to get AppKit recent")}return[]},getRecentWallet(){try{const t=ae.getItem(le.RECENT_WALLET);return t?JSON.parse(t):null}catch{console.info("Unable to get AppKit recent")}return null},deleteRecentWallet(){try{ae.removeItem(le.RECENT_WALLET)}catch{console.info("Unable to delete AppKit recent")}},setConnectedConnectorId(t,e){try{const s=vc(t);ae.setItem(s,e)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return ae.getItem(le.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(t){if(t)try{const e=vc(t);return ae.getItem(e)}catch{console.info("Unable to get connected connector id in namespace",t)}},setConnectedSocialProvider(t){try{ae.setItem(le.CONNECTED_SOCIAL,t)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return ae.getItem(le.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{ae.removeItem(le.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return ae.getItem(le.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){var s;const t=ae.getItem(le.ACTIVE_CAIP_NETWORK_ID);return(s=t==null?void 0:t.split(":"))==null?void 0:s[1]},setConnectionStatus(t){try{ae.setItem(le.CONNECTION_STATUS,t)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return ae.getItem(le.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{const t=ae.getItem(le.CONNECTED_NAMESPACES);return t!=null&&t.length?t.split(","):[]}catch{return[]}},setConnectedNamespaces(t){try{const e=Array.from(new Set(t));ae.setItem(le.CONNECTED_NAMESPACES,e.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(t){try{const e=F.getConnectedNamespaces();e.includes(t)||(e.push(t),F.setConnectedNamespaces(e))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(t){try{const e=F.getConnectedNamespaces(),s=e.indexOf(t);s>-1&&(e.splice(s,1),F.setConnectedNamespaces(e))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return ae.getItem(le.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(t){try{ae.setItem(le.TELEGRAM_SOCIAL_PROVIDER,t)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{ae.removeItem(le.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let t={};try{const e=ae.getItem(le.PORTFOLIO_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromBalanceCache(t){try{const e=F.getBalanceCache();ae.setItem(le.PORTFOLIO_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getBalanceCacheForCaipAddress(t){try{const s=F.getBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.portfolio))return s.balance;F.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateBalanceCache(t){try{const e=F.getBalanceCache();e[t.caipAddress]=t,ae.setItem(le.PORTFOLIO_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getNativeBalanceCache(){let t={};try{const e=ae.getItem(le.NATIVE_BALANCE_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromNativeBalanceCache(t){try{const e=F.getBalanceCache();ae.setItem(le.NATIVE_BALANCE_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getNativeBalanceCacheForCaipAddress(t){try{const s=F.getNativeBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.nativeBalance))return s;console.info("Discarding cache for address",t),F.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateNativeBalanceCache(t){try{const e=F.getNativeBalanceCache();e[t.caipAddress]=t,ae.setItem(le.NATIVE_BALANCE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getEnsCache(){let t={};try{const e=ae.getItem(le.ENS_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get ens name cache")}return t},getEnsFromCacheForAddress(t){try{const s=F.getEnsCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.ens))return s.ens;F.removeEnsFromCache(t)}catch{console.info("Unable to get ens name from cache",t)}},updateEnsCache(t){try{const e=F.getEnsCache();e[t.address]=t,ae.setItem(le.ENS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ens name cache",t)}},removeEnsFromCache(t){try{const e=F.getEnsCache();ae.setItem(le.ENS_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove ens name from cache",t)}},getIdentityCache(){let t={};try{const e=ae.getItem(le.IDENTITY_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get identity cache")}return t},getIdentityFromCacheForAddress(t){try{const s=F.getIdentityCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.identity))return s.identity;F.removeIdentityFromCache(t)}catch{console.info("Unable to get identity from cache",t)}},updateIdentityCache(t){try{const e=F.getIdentityCache();e[t.address]={identity:t.identity,timestamp:t.timestamp},ae.setItem(le.IDENTITY_CACHE,JSON.stringify(e))}catch{console.info("Unable to update identity cache",t)}},removeIdentityFromCache(t){try{const e=F.getIdentityCache();ae.setItem(le.IDENTITY_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove identity from cache",t)}},getTonWalletsCache(){try{const t=ae.getItem(le.TON_WALLETS_CACHE),e=t?JSON.parse(t):void 0;if(e&&!this.isCacheExpired(e.timestamp,this.cacheExpiry.tonWallets))return e;F.removeTonWalletsCache()}catch{console.info("Unable to get ton wallets cache")}},updateTonWalletsCache(t){try{const e=F.getTonWalletsCache()||{timestamp:0,wallets:[]};e.timestamp=new Date().getTime(),e.wallets=t,ae.setItem(le.TON_WALLETS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ton wallets cache",t)}},removeTonWalletsCache(){try{ae.removeItem(le.TON_WALLETS_CACHE)}catch{console.info("Unable to remove ton wallets cache")}},clearAddressCache(){try{ae.removeItem(le.PORTFOLIO_CACHE),ae.removeItem(le.NATIVE_BALANCE_CACHE),ae.removeItem(le.ENS_CACHE),ae.removeItem(le.IDENTITY_CACHE),ae.removeItem(le.HISTORY_TRANSACTIONS_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(t){try{ae.setItem(le.PREFERRED_ACCOUNT_TYPES,JSON.stringify(t))}catch{console.info("Unable to set preferred account types",t)}},getPreferredAccountTypes(){try{const t=ae.getItem(le.PREFERRED_ACCOUNT_TYPES);return t?JSON.parse(t):{}}catch{console.info("Unable to get preferred account types")}return{}},setConnections(t,e){try{const s=F.getConnections(),n=s[e]??[],r=new Map;for(const o of n)r.set(o.connectorId,{...o});for(const o of t){const a=r.get(o.connectorId),c=o.connectorId===U.CONNECTOR_ID.AUTH;if(a&&!c){const l=new Set(a.accounts.map(u=>u.address.toLowerCase())),d=o.accounts.filter(u=>!l.has(u.address.toLowerCase()));a.accounts.push(...d)}else r.set(o.connectorId,{...o})}const i={...s,[e]:Array.from(r.values())};ae.setItem(le.CONNECTIONS,JSON.stringify(i))}catch(s){console.error("Unable to sync connections to storage",s)}},getConnections(){try{const t=ae.getItem(le.CONNECTIONS);return t?JSON.parse(t):{}}catch(t){return console.error("Unable to get connections from storage",t),{}}},deleteAddressFromConnection({connectorId:t,address:e,namespace:s}){try{const n=F.getConnections(),r=n[s]??[],i=new Map(r.map(a=>[a.connectorId,a])),o=i.get(t);o&&(o.accounts.filter(c=>c.address.toLowerCase()!==e.toLowerCase()).length===0?i.delete(t):i.set(t,{...o,accounts:o.accounts.filter(c=>c.address.toLowerCase()!==e.toLowerCase())})),ae.setItem(le.CONNECTIONS,JSON.stringify({...n,[s]:Array.from(i.values())}))}catch{console.error(`Unable to remove address "${e}" from connector "${t}" in namespace "${s}"`)}},getDisconnectedConnectorIds(){try{const t=ae.getItem(le.DISCONNECTED_CONNECTOR_IDS);return t?JSON.parse(t):{}}catch{console.info("Unable to get disconnected connector ids")}return{}},addDisconnectedConnectorId(t,e){try{const s=F.getDisconnectedConnectorIds(),n=s[e]??[];n.push(t),ae.setItem(le.DISCONNECTED_CONNECTOR_IDS,JSON.stringify({...s,[e]:Array.from(new Set(n))}))}catch{console.error(`Unable to set disconnected connector id "${t}" for namespace "${e}"`)}},removeDisconnectedConnectorId(t,e){try{const s=F.getDisconnectedConnectorIds();let n=s[e]??[];n=n.filter(r=>r.toLowerCase()!==t.toLowerCase()),ae.setItem(le.DISCONNECTED_CONNECTOR_IDS,JSON.stringify({...s,[e]:Array.from(new Set(n))}))}catch{console.error(`Unable to remove disconnected connector id "${t}" for namespace "${e}"`)}},isConnectorDisconnected(t,e){try{return(F.getDisconnectedConnectorIds()[e]??[]).some(r=>r.toLowerCase()===t.toLowerCase())}catch{console.info(`Unable to get disconnected connector id "${t}" for namespace "${e}"`)}return!1},getTransactionsCache(){try{const t=ae.getItem(le.HISTORY_TRANSACTIONS_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get transactions cache")}return{}},getTransactionsCacheForAddress({address:t,chainId:e=""}){var s;try{const r=(s=F.getTransactionsCache()[t])==null?void 0:s[e];if(r&&!this.isCacheExpired(r.timestamp,this.cacheExpiry.transactionsHistory))return r.transactions;F.removeTransactionsCache({address:t,chainId:e})}catch{console.info("Unable to get transactions cache")}},updateTransactionsCache({address:t,chainId:e="",timestamp:s,transactions:n}){try{const r=F.getTransactionsCache();r[t]={...r[t],[e]:{timestamp:s,transactions:n}},ae.setItem(le.HISTORY_TRANSACTIONS_CACHE,JSON.stringify(r))}catch{console.info("Unable to update transactions cache",{address:t,chainId:e,timestamp:s,transactions:n})}},removeTransactionsCache({address:t,chainId:e}){try{const s=F.getTransactionsCache(),n=(s==null?void 0:s[t])||{},{[e]:r,...i}=n;ae.setItem(le.HISTORY_TRANSACTIONS_CACHE,JSON.stringify({...s,[t]:i}))}catch{console.info("Unable to remove transactions cache",{address:t,chainId:e})}},getTokenPriceCache(){try{const t=ae.getItem(le.TOKEN_PRICE_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get token price cache")}return{}},getTokenPriceCacheForAddresses(t){try{const s=F.getTokenPriceCache()[t.join(",")];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.tokenPrice))return s.tokenPrice;F.removeTokenPriceCache(t)}catch{console.info("Unable to get token price cache for addresses",t)}},updateTokenPriceCache(t){try{const e=F.getTokenPriceCache();e[t.addresses.join(",")]={timestamp:t.timestamp,tokenPrice:t.tokenPrice},ae.setItem(le.TOKEN_PRICE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update token price cache",t)}},removeTokenPriceCache(t){try{const e=F.getTokenPriceCache();ae.setItem(le.TOKEN_PRICE_CACHE,JSON.stringify({...e,[t.join(",")]:void 0}))}catch{console.info("Unable to remove token price cache",t)}},getLatestAppKitVersion(){try{const t=this.getLatestAppKitVersionCache(),e=t==null?void 0:t.version;return e&&!this.isCacheExpired(t.timestamp,this.cacheExpiry.latestAppKitVersion)?e:void 0}catch{console.info("Unable to get latest AppKit version")}},getLatestAppKitVersionCache(){try{const t=ae.getItem(le.LATEST_APPKIT_VERSION);return t?JSON.parse(t):{}}catch{console.info("Unable to get latest AppKit version cache")}return{}},updateLatestAppKitVersion(t){try{const e=F.getLatestAppKitVersionCache();e.timestamp=t.timestamp,e.version=t.version,ae.setItem(le.LATEST_APPKIT_VERSION,JSON.stringify(e))}catch{console.info("Unable to update latest AppKit version on local storage",t)}}},X={getWindow(){if(!(typeof window>"u"))return window},isMobile(){var t;return this.isClient()?!!(window!=null&&window.matchMedia&&typeof window.matchMedia=="function"&&((t=window.matchMedia("(pointer:coarse)"))!=null&&t.matches)||/Android|webOS|iPhone|iPad|iPod|BlackBerry|Opera Mini/u.test(navigator.userAgent)):!1},checkCaipNetwork(t,e=""){return t==null?void 0:t.caipNetworkId.toLocaleLowerCase().includes(e.toLowerCase())},isAndroid(){if(!this.isMobile())return!1;const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return X.isMobile()&&t.includes("android")},isIos(){if(!this.isMobile())return!1;const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return t.includes("iphone")||t.includes("ipad")},isSafari(){return this.isClient()?(window==null?void 0:window.navigator.userAgent.toLowerCase()).includes("safari"):!1},isClient(){return typeof window<"u"},isPairingExpired(t){return t?t-Date.now()<=Ie.TEN_SEC_MS:!0},isAllowedRetry(t,e=Ie.ONE_SEC_MS){return Date.now()-t>=e},copyToClopboard(t){navigator.clipboard.writeText(t)},isIframe(){try{return(window==null?void 0:window.self)!==(window==null?void 0:window.top)}catch{return!1}},isSafeApp(){var t,e;if(X.isClient()&&window.self!==window.top)try{const s=(e=(t=window==null?void 0:window.location)==null?void 0:t.ancestorOrigins)==null?void 0:e[0],n="https://app.safe.global";if(s){const r=new URL(s),i=new URL(n);return r.hostname===i.hostname}}catch{return!1}return!1},getPairingExpiry(){return Date.now()+Ie.FOUR_MINUTES_MS},getNetworkId(t){return t==null?void 0:t.split(":")[1]},getPlainAddress(t){return t==null?void 0:t.split(":")[2]},async wait(t){return new Promise(e=>{setTimeout(e,t)})},debounce(t,e=500){let s;return(...n)=>{function r(){t(...n)}s&&clearTimeout(s),s=setTimeout(r,e)}},isHttpUrl(t){return t.startsWith("http://")||t.startsWith("https://")},formatNativeUrl(t,e,s=null){if(X.isHttpUrl(t))return this.formatUniversalUrl(t,e);let n=t,r=s;n.includes("://")||(n=t.replaceAll("/","").replaceAll(":",""),n=`${n}://`),n.endsWith("/")||(n=`${n}/`),r&&!(r!=null&&r.endsWith("/"))&&(r=`${r}/`),this.isTelegram()&&this.isAndroid()&&(e=encodeURIComponent(e));const i=encodeURIComponent(e);return{redirect:`${n}wc?uri=${i}`,redirectUniversalLink:r?`${r}wc?uri=${i}`:void 0,href:n}},formatUniversalUrl(t,e){if(!X.isHttpUrl(t))return this.formatNativeUrl(t,e);let s=t;s.endsWith("/")||(s=`${s}/`);const n=encodeURIComponent(e);return{redirect:`${s}wc?uri=${n}`,href:s}},getOpenTargetForPlatform(t){return t==="popupWindow"?t:this.isTelegram()?F.getTelegramSocialProvider()?"_top":"_blank":t},openHref(t,e,s){window==null||window.open(t,this.getOpenTargetForPlatform(e),s||"noreferrer noopener")},returnOpenHref(t,e,s){return window==null?void 0:window.open(t,this.getOpenTargetForPlatform(e),s||"noreferrer noopener")},isTelegram(){return typeof window<"u"&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)},isPWA(){var s,n;if(typeof window>"u")return!1;const t=window!=null&&window.matchMedia&&typeof window.matchMedia=="function"?(s=window.matchMedia("(display-mode: standalone)"))==null?void 0:s.matches:!1,e=(n=window==null?void 0:window.navigator)==null?void 0:n.standalone;return!!(t||e)},async preloadImage(t){const e=new Promise((s,n)=>{const r=new Image;r.onload=s,r.onerror=n,r.crossOrigin="anonymous",r.src=t});return Promise.race([e,X.wait(2e3)])},parseBalance(t,e){let s="0.000";if(typeof t=="string"){const c=Number(t);if(!isNaN(c)){const l=(Math.floor(c*1e3)/1e3).toFixed(3);l&&(s=l)}}const[n,r]=s.split("."),i=n||"0",o=r||"000";return{formattedText:`${i}.${o}${e?` ${e}`:""}`,value:i,decimals:o,symbol:e}},getApiUrl(){return U.W3M_API_URL},getBlockchainApiUrl(){return U.BLOCKCHAIN_API_RPC_URL},getAnalyticsUrl(){return U.PULSE_API_URL},getUUID(){return crypto!=null&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,t=>{const e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})},parseError(t){var e,s;return typeof t=="string"?t:typeof((s=(e=t==null?void 0:t.issues)==null?void 0:e[0])==null?void 0:s.message)=="string"?t.issues[0].message:t instanceof Error?t.message:"Unknown error"},sortRequestedNetworks(t,e=[]){const s={};return e&&t&&(t.forEach((n,r)=>{s[n]=r}),e.sort((n,r)=>{const i=s[n.id],o=s[r.id];return i!==void 0&&o!==void 0?i-o:i!==void 0?-1:o!==void 0?1:0})),e},calculateBalance(t){let e=0;for(const s of t)e+=s.value??0;return e},formatTokenBalance(t){const e=t.toFixed(2),[s,n]=e.split(".");return{dollars:s,pennies:n}},isAddress(t,e="eip155"){switch(e){case"eip155":if(/^(?:0x)?[0-9a-f]{40}$/iu.test(t)){if(/^(?:0x)?[0-9a-f]{40}$/iu.test(t)||/^(?:0x)?[0-9A-F]{40}$/iu.test(t))return!0}else return!1;return!1;case"solana":return/[1-9A-HJ-NP-Za-km-z]{32,44}$/iu.test(t);default:return!1}},uniqueBy(t,e){const s=new Set;return t.filter(n=>{const r=n[e];return s.has(r)?!1:(s.add(r),!0)})},generateSdkVersion(t,e,s){const r=t.length===0?Ie.ADAPTER_TYPES.UNIVERSAL:t.map(i=>i.adapterType).join(",");return`${e}-${r}-${s}`},createAccount(t,e,s,n,r){return{namespace:t,address:e,type:s,publicKey:n,path:r}},isCaipAddress(t){if(typeof t!="string")return!1;const e=t.split(":"),s=e[0];return e.filter(Boolean).length===3&&s in U.CHAIN_NAME_MAP},getAccount(t){return t?typeof t=="string"?{address:t,chainId:void 0}:{address:t.address,chainId:t.chainId}:{address:void 0,chainId:void 0}},isMac(){const t=window==null?void 0:window.navigator.userAgent.toLowerCase();return t.includes("macintosh")&&!t.includes("safari")},formatTelegramSocialLoginUrl(t){const e=`--${encodeURIComponent(window==null?void 0:window.location.href)}`,s="state=";if(new URL(t).host==="auth.magic.link"){const r="provider_authorization_url=",i=t.substring(t.indexOf(r)+r.length),o=this.injectIntoUrl(decodeURIComponent(i),s,e);return t.replace(i,encodeURIComponent(o))}return this.injectIntoUrl(t,s,e)},injectIntoUrl(t,e,s){const n=t.indexOf(e);if(n===-1)throw new Error(`${e} parameter not found in the URL: ${t}`);const r=t.indexOf("&",n),i=e.length,o=r!==-1?r:t.length,a=t.substring(0,n+i),c=t.substring(n+i,o),l=t.substring(r),d=c+s;return a+d+l}};var ai={};const Sw="https://secure.walletconnect.org/sdk",Iw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_SECURE_SITE_SDK_URL:void 0)||Sw,Nw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_DEFAULT_LOG_LEVEL:void 0)||"error",Tw=(typeof En<"u"&&typeof ai<"u"?ai.NEXT_PUBLIC_SECURE_SITE_SDK_VERSION:void 0)||"4",oe={APP_EVENT_KEY:"@w3m-app/",FRAME_EVENT_KEY:"@w3m-frame/",RPC_METHOD_KEY:"RPC_",STORAGE_KEY:"@appkit-wallet/",SESSION_TOKEN_KEY:"SESSION_TOKEN_KEY",EMAIL_LOGIN_USED_KEY:"EMAIL_LOGIN_USED_KEY",LAST_USED_CHAIN_KEY:"LAST_USED_CHAIN_KEY",LAST_EMAIL_LOGIN_TIME:"LAST_EMAIL_LOGIN_TIME",EMAIL:"EMAIL",PREFERRED_ACCOUNT_TYPE:"PREFERRED_ACCOUNT_TYPE",SMART_ACCOUNT_ENABLED:"SMART_ACCOUNT_ENABLED",SMART_ACCOUNT_ENABLED_NETWORKS:"SMART_ACCOUNT_ENABLED_NETWORKS",SOCIAL_USERNAME:"SOCIAL_USERNAME",APP_SWITCH_NETWORK:"@w3m-app/SWITCH_NETWORK",APP_CONNECT_EMAIL:"@w3m-app/CONNECT_EMAIL",APP_CONNECT_DEVICE:"@w3m-app/CONNECT_DEVICE",APP_CONNECT_OTP:"@w3m-app/CONNECT_OTP",APP_CONNECT_SOCIAL:"@w3m-app/CONNECT_SOCIAL",APP_GET_SOCIAL_REDIRECT_URI:"@w3m-app/GET_SOCIAL_REDIRECT_URI",APP_GET_USER:"@w3m-app/GET_USER",APP_SIGN_OUT:"@w3m-app/SIGN_OUT",APP_IS_CONNECTED:"@w3m-app/IS_CONNECTED",APP_GET_CHAIN_ID:"@w3m-app/GET_CHAIN_ID",APP_RPC_REQUEST:"@w3m-app/RPC_REQUEST",APP_UPDATE_EMAIL:"@w3m-app/UPDATE_EMAIL",APP_UPDATE_EMAIL_PRIMARY_OTP:"@w3m-app/UPDATE_EMAIL_PRIMARY_OTP",APP_UPDATE_EMAIL_SECONDARY_OTP:"@w3m-app/UPDATE_EMAIL_SECONDARY_OTP",APP_AWAIT_UPDATE_EMAIL:"@w3m-app/AWAIT_UPDATE_EMAIL",APP_SYNC_THEME:"@w3m-app/SYNC_THEME",APP_SYNC_DAPP_DATA:"@w3m-app/SYNC_DAPP_DATA",APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS:"@w3m-app/GET_SMART_ACCOUNT_ENABLED_NETWORKS",APP_INIT_SMART_ACCOUNT:"@w3m-app/INIT_SMART_ACCOUNT",APP_SET_PREFERRED_ACCOUNT:"@w3m-app/SET_PREFERRED_ACCOUNT",APP_CONNECT_FARCASTER:"@w3m-app/CONNECT_FARCASTER",APP_GET_FARCASTER_URI:"@w3m-app/GET_FARCASTER_URI",APP_RELOAD:"@w3m-app/RELOAD",APP_RPC_ABORT:"@w3m-app/RPC_ABORT",FRAME_SWITCH_NETWORK_ERROR:"@w3m-frame/SWITCH_NETWORK_ERROR",FRAME_SWITCH_NETWORK_SUCCESS:"@w3m-frame/SWITCH_NETWORK_SUCCESS",FRAME_CONNECT_EMAIL_ERROR:"@w3m-frame/CONNECT_EMAIL_ERROR",FRAME_CONNECT_EMAIL_SUCCESS:"@w3m-frame/CONNECT_EMAIL_SUCCESS",FRAME_CONNECT_DEVICE_ERROR:"@w3m-frame/CONNECT_DEVICE_ERROR",FRAME_CONNECT_DEVICE_SUCCESS:"@w3m-frame/CONNECT_DEVICE_SUCCESS",FRAME_CONNECT_OTP_SUCCESS:"@w3m-frame/CONNECT_OTP_SUCCESS",FRAME_CONNECT_OTP_ERROR:"@w3m-frame/CONNECT_OTP_ERROR",FRAME_CONNECT_SOCIAL_SUCCESS:"@w3m-frame/CONNECT_SOCIAL_SUCCESS",FRAME_CONNECT_SOCIAL_ERROR:"@w3m-frame/CONNECT_SOCIAL_ERROR",FRAME_CONNECT_FARCASTER_SUCCESS:"@w3m-frame/CONNECT_FARCASTER_SUCCESS",FRAME_CONNECT_FARCASTER_ERROR:"@w3m-frame/CONNECT_FARCASTER_ERROR",FRAME_GET_FARCASTER_URI_SUCCESS:"@w3m-frame/GET_FARCASTER_URI_SUCCESS",FRAME_GET_FARCASTER_URI_ERROR:"@w3m-frame/GET_FARCASTER_URI_ERROR",FRAME_GET_SOCIAL_REDIRECT_URI_SUCCESS:"@w3m-frame/GET_SOCIAL_REDIRECT_URI_SUCCESS",FRAME_GET_SOCIAL_REDIRECT_URI_ERROR:"@w3m-frame/GET_SOCIAL_REDIRECT_URI_ERROR",FRAME_GET_USER_SUCCESS:"@w3m-frame/GET_USER_SUCCESS",FRAME_GET_USER_ERROR:"@w3m-frame/GET_USER_ERROR",FRAME_SIGN_OUT_SUCCESS:"@w3m-frame/SIGN_OUT_SUCCESS",FRAME_SIGN_OUT_ERROR:"@w3m-frame/SIGN_OUT_ERROR",FRAME_IS_CONNECTED_SUCCESS:"@w3m-frame/IS_CONNECTED_SUCCESS",FRAME_IS_CONNECTED_ERROR:"@w3m-frame/IS_CONNECTED_ERROR",FRAME_GET_CHAIN_ID_SUCCESS:"@w3m-frame/GET_CHAIN_ID_SUCCESS",FRAME_GET_CHAIN_ID_ERROR:"@w3m-frame/GET_CHAIN_ID_ERROR",FRAME_RPC_REQUEST_SUCCESS:"@w3m-frame/RPC_REQUEST_SUCCESS",FRAME_RPC_REQUEST_ERROR:"@w3m-frame/RPC_REQUEST_ERROR",FRAME_SESSION_UPDATE:"@w3m-frame/SESSION_UPDATE",FRAME_UPDATE_EMAIL_SUCCESS:"@w3m-frame/UPDATE_EMAIL_SUCCESS",FRAME_UPDATE_EMAIL_ERROR:"@w3m-frame/UPDATE_EMAIL_ERROR",FRAME_UPDATE_EMAIL_PRIMARY_OTP_SUCCESS:"@w3m-frame/UPDATE_EMAIL_PRIMARY_OTP_SUCCESS",FRAME_UPDATE_EMAIL_PRIMARY_OTP_ERROR:"@w3m-frame/UPDATE_EMAIL_PRIMARY_OTP_ERROR",FRAME_UPDATE_EMAIL_SECONDARY_OTP_SUCCESS:"@w3m-frame/UPDATE_EMAIL_SECONDARY_OTP_SUCCESS",FRAME_UPDATE_EMAIL_SECONDARY_OTP_ERROR:"@w3m-frame/UPDATE_EMAIL_SECONDARY_OTP_ERROR",FRAME_SYNC_THEME_SUCCESS:"@w3m-frame/SYNC_THEME_SUCCESS",FRAME_SYNC_THEME_ERROR:"@w3m-frame/SYNC_THEME_ERROR",FRAME_SYNC_DAPP_DATA_SUCCESS:"@w3m-frame/SYNC_DAPP_DATA_SUCCESS",FRAME_SYNC_DAPP_DATA_ERROR:"@w3m-frame/SYNC_DAPP_DATA_ERROR",FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS:"@w3m-frame/GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS",FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR:"@w3m-frame/GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR",FRAME_INIT_SMART_ACCOUNT_SUCCESS:"@w3m-frame/INIT_SMART_ACCOUNT_SUCCESS",FRAME_INIT_SMART_ACCOUNT_ERROR:"@w3m-frame/INIT_SMART_ACCOUNT_ERROR",FRAME_SET_PREFERRED_ACCOUNT_SUCCESS:"@w3m-frame/SET_PREFERRED_ACCOUNT_SUCCESS",FRAME_SET_PREFERRED_ACCOUNT_ERROR:"@w3m-frame/SET_PREFERRED_ACCOUNT_ERROR",FRAME_READY:"@w3m-frame/READY",FRAME_RELOAD_SUCCESS:"@w3m-frame/RELOAD_SUCCESS",FRAME_RELOAD_ERROR:"@w3m-frame/RELOAD_ERROR",FRAME_RPC_ABORT_SUCCESS:"@w3m-frame/RPC_ABORT_SUCCESS",FRAME_RPC_ABORT_ERROR:"@w3m-frame/RPC_ABORT_ERROR",RPC_RESPONSE_TYPE_ERROR:"RPC_RESPONSE_ERROR",RPC_RESPONSE_TYPE_TX:"RPC_RESPONSE_TRANSACTION_HASH",RPC_RESPONSE_TYPE_OBJECT:"RPC_RESPONSE_OBJECT"},tt={SAFE_RPC_METHODS:["eth_accounts","eth_blockNumber","eth_call","eth_chainId","eth_estimateGas","eth_feeHistory","eth_gasPrice","eth_getAccount","eth_getBalance","eth_getBlockByHash","eth_getBlockByNumber","eth_getBlockReceipts","eth_getBlockTransactionCountByHash","eth_getBlockTransactionCountByNumber","eth_getCode","eth_getFilterChanges","eth_getFilterLogs","eth_getLogs","eth_getProof","eth_getStorageAt","eth_getTransactionByBlockHashAndIndex","eth_getTransactionByBlockNumberAndIndex","eth_getTransactionByHash","eth_getTransactionCount","eth_getTransactionReceipt","eth_getUncleCountByBlockHash","eth_getUncleCountByBlockNumber","eth_maxPriorityFeePerGas","eth_newBlockFilter","eth_newFilter","eth_newPendingTransactionFilter","eth_sendRawTransaction","eth_syncing","eth_uninstallFilter","wallet_getCapabilities","wallet_getCallsStatus","eth_getUserOperationReceipt","eth_estimateUserOperationGas","eth_getUserOperationByHash","eth_supportedEntryPoints","wallet_getAssets"],NOT_SAFE_RPC_METHODS:["personal_sign","eth_signTypedData_v4","eth_sendTransaction","solana_signMessage","solana_signTransaction","solana_signAllTransactions","solana_signAndSendTransaction","wallet_sendCalls","wallet_grantPermissions","wallet_revokePermissions","eth_sendUserOperation"],GET_CHAIN_ID:"eth_chainId",RPC_METHOD_NOT_ALLOWED_MESSAGE:"Requested RPC call is not allowed",RPC_METHOD_NOT_ALLOWED_UI_MESSAGE:"Action not allowed",ACCOUNT_TYPES:{EOA:"eoa",SMART_ACCOUNT:"smartAccount"}},ku={transactionHash:/^0x(?:[A-Fa-f0-9]{64})$/u,signedMessage:/^0x(?:[a-fA-F0-9]{62,})$/u},lt={set(t,e){cs.isClient&&localStorage.setItem(`${oe.STORAGE_KEY}${t}`,e)},get(t){return cs.isClient?localStorage.getItem(`${oe.STORAGE_KEY}${t}`):null},delete(t,e){cs.isClient&&(e?localStorage.removeItem(t):localStorage.removeItem(`${oe.STORAGE_KEY}${t}`))}},Fo=30*1e3,cs={checkIfAllowedToTriggerEmail(){const t=lt.get(oe.LAST_EMAIL_LOGIN_TIME);if(t){const e=Date.now()-Number(t);if(e<Fo){const s=Math.ceil((Fo-e)/1e3);throw new Error(`Please try again after ${s} seconds`)}}},getTimeToNextEmailLogin(){const t=lt.get(oe.LAST_EMAIL_LOGIN_TIME);if(t){const e=Date.now()-Number(t);if(e<Fo)return Math.ceil((Fo-e)/1e3)}return 0},checkIfRequestExists(t){return tt.NOT_SAFE_RPC_METHODS.includes(t.method)||tt.SAFE_RPC_METHODS.includes(t.method)},getResponseType(t){return typeof t=="string"&&((t==null?void 0:t.match(ku.transactionHash))||(t==null?void 0:t.match(ku.signedMessage)))?oe.RPC_RESPONSE_TYPE_TX:oe.RPC_RESPONSE_TYPE_OBJECT},checkIfRequestIsSafe(t){return tt.SAFE_RPC_METHODS.includes(t.method)},isClient:typeof window<"u"};var Le;(function(t){t.assertEqual=r=>r;function e(r){}t.assertIs=e;function s(r){throw new Error}t.assertNever=s,t.arrayToEnum=r=>{const i={};for(const o of r)i[o]=o;return i},t.getValidEnumValues=r=>{const i=t.objectKeys(r).filter(a=>typeof r[r[a]]!="number"),o={};for(const a of i)o[a]=r[a];return t.objectValues(o)},t.objectValues=r=>t.objectKeys(r).map(function(i){return r[i]}),t.objectKeys=typeof Object.keys=="function"?r=>Object.keys(r):r=>{const i=[];for(const o in r)Object.prototype.hasOwnProperty.call(r,o)&&i.push(o);return i},t.find=(r,i)=>{for(const o of r)if(i(o))return o},t.isInteger=typeof Number.isInteger=="function"?r=>Number.isInteger(r):r=>typeof r=="number"&&isFinite(r)&&Math.floor(r)===r;function n(r,i=" | "){return r.map(o=>typeof o=="string"?`'${o}'`:o).join(i)}t.joinValues=n,t.jsonStringifyReplacer=(r,i)=>typeof i=="bigint"?i.toString():i})(Le||(Le={}));var Sl;(function(t){t.mergeShapes=(e,s)=>({...e,...s})})(Sl||(Sl={}));const se=Le.arrayToEnum(["string","nan","number","integer","float","boolean","date","bigint","symbol","function","undefined","null","array","object","unknown","promise","void","never","map","set"]),Bn=t=>{switch(typeof t){case"undefined":return se.undefined;case"string":return se.string;case"number":return isNaN(t)?se.nan:se.number;case"boolean":return se.boolean;case"function":return se.function;case"bigint":return se.bigint;case"symbol":return se.symbol;case"object":return Array.isArray(t)?se.array:t===null?se.null:t.then&&typeof t.then=="function"&&t.catch&&typeof t.catch=="function"?se.promise:typeof Map<"u"&&t instanceof Map?se.map:typeof Set<"u"&&t instanceof Set?se.set:typeof Date<"u"&&t instanceof Date?se.date:se.object;default:return se.unknown}},K=Le.arrayToEnum(["invalid_type","invalid_literal","custom","invalid_union","invalid_union_discriminator","invalid_enum_value","unrecognized_keys","invalid_arguments","invalid_return_type","invalid_date","invalid_string","too_small","too_big","invalid_intersection_types","not_multiple_of","not_finite"]),Rw=t=>JSON.stringify(t,null,2).replace(/"([^"]+)":/g,"$1:");class Us extends Error{constructor(e){super(),this.issues=[],this.addIssue=n=>{this.issues=[...this.issues,n]},this.addIssues=(n=[])=>{this.issues=[...this.issues,...n]};const s=new.target.prototype;Object.setPrototypeOf?Object.setPrototypeOf(this,s):this.__proto__=s,this.name="ZodError",this.issues=e}get errors(){return this.issues}format(e){const s=e||function(i){return i.message},n={_errors:[]},r=i=>{for(const o of i.issues)if(o.code==="invalid_union")o.unionErrors.map(r);else if(o.code==="invalid_return_type")r(o.returnTypeError);else if(o.code==="invalid_arguments")r(o.argumentsError);else if(o.path.length===0)n._errors.push(s(o));else{let a=n,c=0;for(;c<o.path.length;){const l=o.path[c];c===o.path.length-1?(a[l]=a[l]||{_errors:[]},a[l]._errors.push(s(o))):a[l]=a[l]||{_errors:[]},a=a[l],c++}}};return r(this),n}toString(){return this.message}get message(){return JSON.stringify(this.issues,Le.jsonStringifyReplacer,2)}get isEmpty(){return this.issues.length===0}flatten(e=s=>s.message){const s={},n=[];for(const r of this.issues)r.path.length>0?(s[r.path[0]]=s[r.path[0]]||[],s[r.path[0]].push(e(r))):n.push(e(r));return{formErrors:n,fieldErrors:s}}get formErrors(){return this.flatten()}}Us.create=t=>new Us(t);const eo=(t,e)=>{let s;switch(t.code){case K.invalid_type:t.received===se.undefined?s="Required":s=`Expected ${t.expected}, received ${t.received}`;break;case K.invalid_literal:s=`Invalid literal value, expected ${JSON.stringify(t.expected,Le.jsonStringifyReplacer)}`;break;case K.unrecognized_keys:s=`Unrecognized key(s) in object: ${Le.joinValues(t.keys,", ")}`;break;case K.invalid_union:s="Invalid input";break;case K.invalid_union_discriminator:s=`Invalid discriminator value. Expected ${Le.joinValues(t.options)}`;break;case K.invalid_enum_value:s=`Invalid enum value. Expected ${Le.joinValues(t.options)}, received '${t.received}'`;break;case K.invalid_arguments:s="Invalid function arguments";break;case K.invalid_return_type:s="Invalid function return type";break;case K.invalid_date:s="Invalid date";break;case K.invalid_string:typeof t.validation=="object"?"includes"in t.validation?(s=`Invalid input: must include "${t.validation.includes}"`,typeof t.validation.position=="number"&&(s=`${s} at one or more positions greater than or equal to ${t.validation.position}`)):"startsWith"in t.validation?s=`Invalid input: must start with "${t.validation.startsWith}"`:"endsWith"in t.validation?s=`Invalid input: must end with "${t.validation.endsWith}"`:Le.assertNever(t.validation):t.validation!=="regex"?s=`Invalid ${t.validation}`:s="Invalid";break;case K.too_small:t.type==="array"?s=`Array must contain ${t.exact?"exactly":t.inclusive?"at least":"more than"} ${t.minimum} element(s)`:t.type==="string"?s=`String must contain ${t.exact?"exactly":t.inclusive?"at least":"over"} ${t.minimum} character(s)`:t.type==="number"?s=`Number must be ${t.exact?"exactly equal to ":t.inclusive?"greater than or equal to ":"greater than "}${t.minimum}`:t.type==="date"?s=`Date must be ${t.exact?"exactly equal to ":t.inclusive?"greater than or equal to ":"greater than "}${new Date(Number(t.minimum))}`:s="Invalid input";break;case K.too_big:t.type==="array"?s=`Array must contain ${t.exact?"exactly":t.inclusive?"at most":"less than"} ${t.maximum} element(s)`:t.type==="string"?s=`String must contain ${t.exact?"exactly":t.inclusive?"at most":"under"} ${t.maximum} character(s)`:t.type==="number"?s=`Number must be ${t.exact?"exactly":t.inclusive?"less than or equal to":"less than"} ${t.maximum}`:t.type==="bigint"?s=`BigInt must be ${t.exact?"exactly":t.inclusive?"less than or equal to":"less than"} ${t.maximum}`:t.type==="date"?s=`Date must be ${t.exact?"exactly":t.inclusive?"smaller than or equal to":"smaller than"} ${new Date(Number(t.maximum))}`:s="Invalid input";break;case K.custom:s="Invalid input";break;case K.invalid_intersection_types:s="Intersection results could not be merged";break;case K.not_multiple_of:s=`Number must be a multiple of ${t.multipleOf}`;break;case K.not_finite:s="Number must be finite";break;default:s=e.defaultError,Le.assertNever(t)}return{message:s}};let Uf=eo;function Ow(t){Uf=t}function Aa(){return Uf}const Sa=t=>{const{data:e,path:s,errorMaps:n,issueData:r}=t,i=[...s,...r.path||[]],o={...r,path:i};let a="";const c=n.filter(l=>!!l).slice().reverse();for(const l of c)a=l(o,{data:e,defaultError:a}).message;return{...r,path:i,message:r.message||a}},Pw=[];function ie(t,e){const s=Sa({issueData:e,data:t.data,path:t.path,errorMaps:[t.common.contextualErrorMap,t.schemaErrorMap,Aa(),eo].filter(n=>!!n)});t.common.issues.push(s)}class kt{constructor(){this.value="valid"}dirty(){this.value==="valid"&&(this.value="dirty")}abort(){this.value!=="aborted"&&(this.value="aborted")}static mergeArray(e,s){const n=[];for(const r of s){if(r.status==="aborted")return be;r.status==="dirty"&&e.dirty(),n.push(r.value)}return{status:e.value,value:n}}static async mergeObjectAsync(e,s){const n=[];for(const r of s)n.push({key:await r.key,value:await r.value});return kt.mergeObjectSync(e,n)}static mergeObjectSync(e,s){const n={};for(const r of s){const{key:i,value:o}=r;if(i.status==="aborted"||o.status==="aborted")return be;i.status==="dirty"&&e.dirty(),o.status==="dirty"&&e.dirty(),i.value!=="__proto__"&&(typeof o.value<"u"||r.alwaysSet)&&(n[i.value]=o.value)}return{status:e.value,value:n}}}const be=Object.freeze({status:"aborted"}),$f=t=>({status:"dirty",value:t}),Ft=t=>({status:"valid",value:t}),Il=t=>t.status==="aborted",Nl=t=>t.status==="dirty",to=t=>t.status==="valid",Ia=t=>typeof Promise<"u"&&t instanceof Promise;var pe;(function(t){t.errToObj=e=>typeof e=="string"?{message:e}:e||{},t.toString=e=>typeof e=="string"?e:e==null?void 0:e.message})(pe||(pe={}));class Qs{constructor(e,s,n,r){this._cachedPath=[],this.parent=e,this.data=s,this._path=n,this._key=r}get path(){return this._cachedPath.length||(this._key instanceof Array?this._cachedPath.push(...this._path,...this._key):this._cachedPath.push(...this._path,this._key)),this._cachedPath}}const Uu=(t,e)=>{if(to(e))return{success:!0,data:e.value};if(!t.common.issues.length)throw new Error("Validation failed but no issues detected.");return{success:!1,get error(){if(this._error)return this._error;const s=new Us(t.common.issues);return this._error=s,this._error}}};function Ce(t){if(!t)return{};const{errorMap:e,invalid_type_error:s,required_error:n,description:r}=t;if(e&&(s||n))throw new Error(`Can't use "invalid_type_error" or "required_error" in conjunction with custom error map.`);return e?{errorMap:e,description:r}:{errorMap:(o,a)=>o.code!=="invalid_type"?{message:a.defaultError}:typeof a.data>"u"?{message:n??a.defaultError}:{message:s??a.defaultError},description:r}}class Ae{constructor(e){this.spa=this.safeParseAsync,this._def=e,this.parse=this.parse.bind(this),this.safeParse=this.safeParse.bind(this),this.parseAsync=this.parseAsync.bind(this),this.safeParseAsync=this.safeParseAsync.bind(this),this.spa=this.spa.bind(this),this.refine=this.refine.bind(this),this.refinement=this.refinement.bind(this),this.superRefine=this.superRefine.bind(this),this.optional=this.optional.bind(this),this.nullable=this.nullable.bind(this),this.nullish=this.nullish.bind(this),this.array=this.array.bind(this),this.promise=this.promise.bind(this),this.or=this.or.bind(this),this.and=this.and.bind(this),this.transform=this.transform.bind(this),this.brand=this.brand.bind(this),this.default=this.default.bind(this),this.catch=this.catch.bind(this),this.describe=this.describe.bind(this),this.pipe=this.pipe.bind(this),this.readonly=this.readonly.bind(this),this.isNullable=this.isNullable.bind(this),this.isOptional=this.isOptional.bind(this)}get description(){return this._def.description}_getType(e){return Bn(e.data)}_getOrReturnCtx(e,s){return s||{common:e.parent.common,data:e.data,parsedType:Bn(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}_processInputParams(e){return{status:new kt,ctx:{common:e.parent.common,data:e.data,parsedType:Bn(e.data),schemaErrorMap:this._def.errorMap,path:e.path,parent:e.parent}}}_parseSync(e){const s=this._parse(e);if(Ia(s))throw new Error("Synchronous parse encountered promise.");return s}_parseAsync(e){const s=this._parse(e);return Promise.resolve(s)}parse(e,s){const n=this.safeParse(e,s);if(n.success)return n.data;throw n.error}safeParse(e,s){var n;const r={common:{issues:[],async:(n=s==null?void 0:s.async)!==null&&n!==void 0?n:!1,contextualErrorMap:s==null?void 0:s.errorMap},path:(s==null?void 0:s.path)||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:Bn(e)},i=this._parseSync({data:e,path:r.path,parent:r});return Uu(r,i)}async parseAsync(e,s){const n=await this.safeParseAsync(e,s);if(n.success)return n.data;throw n.error}async safeParseAsync(e,s){const n={common:{issues:[],contextualErrorMap:s==null?void 0:s.errorMap,async:!0},path:(s==null?void 0:s.path)||[],schemaErrorMap:this._def.errorMap,parent:null,data:e,parsedType:Bn(e)},r=this._parse({data:e,path:n.path,parent:n}),i=await(Ia(r)?r:Promise.resolve(r));return Uu(n,i)}refine(e,s){const n=r=>typeof s=="string"||typeof s>"u"?{message:s}:typeof s=="function"?s(r):s;return this._refinement((r,i)=>{const o=e(r),a=()=>i.addIssue({code:K.custom,...n(r)});return typeof Promise<"u"&&o instanceof Promise?o.then(c=>c?!0:(a(),!1)):o?!0:(a(),!1)})}refinement(e,s){return this._refinement((n,r)=>e(n)?!0:(r.addIssue(typeof s=="function"?s(n,r):s),!1))}_refinement(e){return new Ls({schema:this,typeName:me.ZodEffects,effect:{type:"refinement",refinement:e}})}superRefine(e){return this._refinement(e)}optional(){return bn.create(this,this._def)}nullable(){return Nr.create(this,this._def)}nullish(){return this.nullable().optional()}array(){return $s.create(this,this._def)}promise(){return li.create(this,this._def)}or(e){return io.create([this,e],this._def)}and(e){return oo.create(this,e,this._def)}transform(e){return new Ls({...Ce(this._def),schema:this,typeName:me.ZodEffects,effect:{type:"transform",transform:e}})}default(e){const s=typeof e=="function"?e:()=>e;return new ho({...Ce(this._def),innerType:this,defaultValue:s,typeName:me.ZodDefault})}brand(){return new Lf({typeName:me.ZodBranded,type:this,...Ce(this._def)})}catch(e){const s=typeof e=="function"?e:()=>e;return new Oa({...Ce(this._def),innerType:this,catchValue:s,typeName:me.ZodCatch})}describe(e){const s=this.constructor;return new s({...this._def,description:e})}pipe(e){return Ao.create(this,e)}readonly(){return xa.create(this)}isOptional(){return this.safeParse(void 0).success}isNullable(){return this.safeParse(null).success}}const xw=/^c[^\s-]{8,}$/i,kw=/^[a-z][a-z0-9]*$/,Uw=/^[0-9A-HJKMNP-TV-Z]{26}$/,$w=/^[0-9a-fA-F]{8}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{4}\b-[0-9a-fA-F]{12}$/i,Dw=/^(?!\.)(?!.*\.\.)([A-Z0-9_+-\.]*)[A-Z0-9_+-]@([A-Z0-9][A-Z0-9\-]*\.)+[A-Z]{2,}$/i,Lw="^(\\p{Extended_Pictographic}|\\p{Emoji_Component})+$";let _c;const Mw=/^(((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))\.){3}((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))$/,Bw=/^(([a-f0-9]{1,4}:){7}|::([a-f0-9]{1,4}:){0,6}|([a-f0-9]{1,4}:){1}:([a-f0-9]{1,4}:){0,5}|([a-f0-9]{1,4}:){2}:([a-f0-9]{1,4}:){0,4}|([a-f0-9]{1,4}:){3}:([a-f0-9]{1,4}:){0,3}|([a-f0-9]{1,4}:){4}:([a-f0-9]{1,4}:){0,2}|([a-f0-9]{1,4}:){5}:([a-f0-9]{1,4}:){0,1})([a-f0-9]{1,4}|(((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2}))\.){3}((25[0-5])|(2[0-4][0-9])|(1[0-9]{2})|([0-9]{1,2})))$/,jw=t=>t.precision?t.offset?new RegExp(`^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{${t.precision}}(([+-]\\d{2}(:?\\d{2})?)|Z)$`):new RegExp(`^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}\\.\\d{${t.precision}}Z$`):t.precision===0?t.offset?new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(([+-]\\d{2}(:?\\d{2})?)|Z)$"):new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}Z$"):t.offset?new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?(([+-]\\d{2}(:?\\d{2})?)|Z)$"):new RegExp("^\\d{4}-\\d{2}-\\d{2}T\\d{2}:\\d{2}:\\d{2}(\\.\\d+)?Z$");function Fw(t,e){return!!((e==="v4"||!e)&&Mw.test(t)||(e==="v6"||!e)&&Bw.test(t))}class ks extends Ae{_parse(e){if(this._def.coerce&&(e.data=String(e.data)),this._getType(e)!==se.string){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.string,received:i.parsedType}),be}const n=new kt;let r;for(const i of this._def.checks)if(i.kind==="min")e.data.length<i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="max")e.data.length>i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!1,message:i.message}),n.dirty());else if(i.kind==="length"){const o=e.data.length>i.value,a=e.data.length<i.value;(o||a)&&(r=this._getOrReturnCtx(e,r),o?ie(r,{code:K.too_big,maximum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}):a&&ie(r,{code:K.too_small,minimum:i.value,type:"string",inclusive:!0,exact:!0,message:i.message}),n.dirty())}else if(i.kind==="email")Dw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"email",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="emoji")_c||(_c=new RegExp(Lw,"u")),_c.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"emoji",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="uuid")$w.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"uuid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid")xw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"cuid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="cuid2")kw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"cuid2",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="ulid")Uw.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"ulid",code:K.invalid_string,message:i.message}),n.dirty());else if(i.kind==="url")try{new URL(e.data)}catch{r=this._getOrReturnCtx(e,r),ie(r,{validation:"url",code:K.invalid_string,message:i.message}),n.dirty()}else i.kind==="regex"?(i.regex.lastIndex=0,i.regex.test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"regex",code:K.invalid_string,message:i.message}),n.dirty())):i.kind==="trim"?e.data=e.data.trim():i.kind==="includes"?e.data.includes(i.value,i.position)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{includes:i.value,position:i.position},message:i.message}),n.dirty()):i.kind==="toLowerCase"?e.data=e.data.toLowerCase():i.kind==="toUpperCase"?e.data=e.data.toUpperCase():i.kind==="startsWith"?e.data.startsWith(i.value)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{startsWith:i.value},message:i.message}),n.dirty()):i.kind==="endsWith"?e.data.endsWith(i.value)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:{endsWith:i.value},message:i.message}),n.dirty()):i.kind==="datetime"?jw(i).test(e.data)||(r=this._getOrReturnCtx(e,r),ie(r,{code:K.invalid_string,validation:"datetime",message:i.message}),n.dirty()):i.kind==="ip"?Fw(e.data,i.version)||(r=this._getOrReturnCtx(e,r),ie(r,{validation:"ip",code:K.invalid_string,message:i.message}),n.dirty()):Le.assertNever(i);return{status:n.value,value:e.data}}_regex(e,s,n){return this.refinement(r=>e.test(r),{validation:s,code:K.invalid_string,...pe.errToObj(n)})}_addCheck(e){return new ks({...this._def,checks:[...this._def.checks,e]})}email(e){return this._addCheck({kind:"email",...pe.errToObj(e)})}url(e){return this._addCheck({kind:"url",...pe.errToObj(e)})}emoji(e){return this._addCheck({kind:"emoji",...pe.errToObj(e)})}uuid(e){return this._addCheck({kind:"uuid",...pe.errToObj(e)})}cuid(e){return this._addCheck({kind:"cuid",...pe.errToObj(e)})}cuid2(e){return this._addCheck({kind:"cuid2",...pe.errToObj(e)})}ulid(e){return this._addCheck({kind:"ulid",...pe.errToObj(e)})}ip(e){return this._addCheck({kind:"ip",...pe.errToObj(e)})}datetime(e){var s;return typeof e=="string"?this._addCheck({kind:"datetime",precision:null,offset:!1,message:e}):this._addCheck({kind:"datetime",precision:typeof(e==null?void 0:e.precision)>"u"?null:e==null?void 0:e.precision,offset:(s=e==null?void 0:e.offset)!==null&&s!==void 0?s:!1,...pe.errToObj(e==null?void 0:e.message)})}regex(e,s){return this._addCheck({kind:"regex",regex:e,...pe.errToObj(s)})}includes(e,s){return this._addCheck({kind:"includes",value:e,position:s==null?void 0:s.position,...pe.errToObj(s==null?void 0:s.message)})}startsWith(e,s){return this._addCheck({kind:"startsWith",value:e,...pe.errToObj(s)})}endsWith(e,s){return this._addCheck({kind:"endsWith",value:e,...pe.errToObj(s)})}min(e,s){return this._addCheck({kind:"min",value:e,...pe.errToObj(s)})}max(e,s){return this._addCheck({kind:"max",value:e,...pe.errToObj(s)})}length(e,s){return this._addCheck({kind:"length",value:e,...pe.errToObj(s)})}nonempty(e){return this.min(1,pe.errToObj(e))}trim(){return new ks({...this._def,checks:[...this._def.checks,{kind:"trim"}]})}toLowerCase(){return new ks({...this._def,checks:[...this._def.checks,{kind:"toLowerCase"}]})}toUpperCase(){return new ks({...this._def,checks:[...this._def.checks,{kind:"toUpperCase"}]})}get isDatetime(){return!!this._def.checks.find(e=>e.kind==="datetime")}get isEmail(){return!!this._def.checks.find(e=>e.kind==="email")}get isURL(){return!!this._def.checks.find(e=>e.kind==="url")}get isEmoji(){return!!this._def.checks.find(e=>e.kind==="emoji")}get isUUID(){return!!this._def.checks.find(e=>e.kind==="uuid")}get isCUID(){return!!this._def.checks.find(e=>e.kind==="cuid")}get isCUID2(){return!!this._def.checks.find(e=>e.kind==="cuid2")}get isULID(){return!!this._def.checks.find(e=>e.kind==="ulid")}get isIP(){return!!this._def.checks.find(e=>e.kind==="ip")}get minLength(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxLength(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}}ks.create=t=>{var e;return new ks({checks:[],typeName:me.ZodString,coerce:(e=t==null?void 0:t.coerce)!==null&&e!==void 0?e:!1,...Ce(t)})};function qw(t,e){const s=(t.toString().split(".")[1]||"").length,n=(e.toString().split(".")[1]||"").length,r=s>n?s:n,i=parseInt(t.toFixed(r).replace(".","")),o=parseInt(e.toFixed(r).replace(".",""));return i%o/Math.pow(10,r)}class Zn extends Ae{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte,this.step=this.multipleOf}_parse(e){if(this._def.coerce&&(e.data=Number(e.data)),this._getType(e)!==se.number){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.number,received:i.parsedType}),be}let n;const r=new kt;for(const i of this._def.checks)i.kind==="int"?Le.isInteger(e.data)||(n=this._getOrReturnCtx(e,n),ie(n,{code:K.invalid_type,expected:"integer",received:"float",message:i.message}),r.dirty()):i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_small,minimum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),r.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_big,maximum:i.value,type:"number",inclusive:i.inclusive,exact:!1,message:i.message}),r.dirty()):i.kind==="multipleOf"?qw(e.data,i.value)!==0&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_multiple_of,multipleOf:i.value,message:i.message}),r.dirty()):i.kind==="finite"?Number.isFinite(e.data)||(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_finite,message:i.message}),r.dirty()):Le.assertNever(i);return{status:r.value,value:e.data}}gte(e,s){return this.setLimit("min",e,!0,pe.toString(s))}gt(e,s){return this.setLimit("min",e,!1,pe.toString(s))}lte(e,s){return this.setLimit("max",e,!0,pe.toString(s))}lt(e,s){return this.setLimit("max",e,!1,pe.toString(s))}setLimit(e,s,n,r){return new Zn({...this._def,checks:[...this._def.checks,{kind:e,value:s,inclusive:n,message:pe.toString(r)}]})}_addCheck(e){return new Zn({...this._def,checks:[...this._def.checks,e]})}int(e){return this._addCheck({kind:"int",message:pe.toString(e)})}positive(e){return this._addCheck({kind:"min",value:0,inclusive:!1,message:pe.toString(e)})}negative(e){return this._addCheck({kind:"max",value:0,inclusive:!1,message:pe.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:0,inclusive:!0,message:pe.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:0,inclusive:!0,message:pe.toString(e)})}multipleOf(e,s){return this._addCheck({kind:"multipleOf",value:e,message:pe.toString(s)})}finite(e){return this._addCheck({kind:"finite",message:pe.toString(e)})}safe(e){return this._addCheck({kind:"min",inclusive:!0,value:Number.MIN_SAFE_INTEGER,message:pe.toString(e)})._addCheck({kind:"max",inclusive:!0,value:Number.MAX_SAFE_INTEGER,message:pe.toString(e)})}get minValue(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxValue(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}get isInt(){return!!this._def.checks.find(e=>e.kind==="int"||e.kind==="multipleOf"&&Le.isInteger(e.value))}get isFinite(){let e=null,s=null;for(const n of this._def.checks){if(n.kind==="finite"||n.kind==="int"||n.kind==="multipleOf")return!0;n.kind==="min"?(s===null||n.value>s)&&(s=n.value):n.kind==="max"&&(e===null||n.value<e)&&(e=n.value)}return Number.isFinite(s)&&Number.isFinite(e)}}Zn.create=t=>new Zn({checks:[],typeName:me.ZodNumber,coerce:(t==null?void 0:t.coerce)||!1,...Ce(t)});class Jn extends Ae{constructor(){super(...arguments),this.min=this.gte,this.max=this.lte}_parse(e){if(this._def.coerce&&(e.data=BigInt(e.data)),this._getType(e)!==se.bigint){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.bigint,received:i.parsedType}),be}let n;const r=new kt;for(const i of this._def.checks)i.kind==="min"?(i.inclusive?e.data<i.value:e.data<=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_small,type:"bigint",minimum:i.value,inclusive:i.inclusive,message:i.message}),r.dirty()):i.kind==="max"?(i.inclusive?e.data>i.value:e.data>=i.value)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.too_big,type:"bigint",maximum:i.value,inclusive:i.inclusive,message:i.message}),r.dirty()):i.kind==="multipleOf"?e.data%i.value!==BigInt(0)&&(n=this._getOrReturnCtx(e,n),ie(n,{code:K.not_multiple_of,multipleOf:i.value,message:i.message}),r.dirty()):Le.assertNever(i);return{status:r.value,value:e.data}}gte(e,s){return this.setLimit("min",e,!0,pe.toString(s))}gt(e,s){return this.setLimit("min",e,!1,pe.toString(s))}lte(e,s){return this.setLimit("max",e,!0,pe.toString(s))}lt(e,s){return this.setLimit("max",e,!1,pe.toString(s))}setLimit(e,s,n,r){return new Jn({...this._def,checks:[...this._def.checks,{kind:e,value:s,inclusive:n,message:pe.toString(r)}]})}_addCheck(e){return new Jn({...this._def,checks:[...this._def.checks,e]})}positive(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!1,message:pe.toString(e)})}negative(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!1,message:pe.toString(e)})}nonpositive(e){return this._addCheck({kind:"max",value:BigInt(0),inclusive:!0,message:pe.toString(e)})}nonnegative(e){return this._addCheck({kind:"min",value:BigInt(0),inclusive:!0,message:pe.toString(e)})}multipleOf(e,s){return this._addCheck({kind:"multipleOf",value:e,message:pe.toString(s)})}get minValue(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e}get maxValue(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e}}Jn.create=t=>{var e;return new Jn({checks:[],typeName:me.ZodBigInt,coerce:(e=t==null?void 0:t.coerce)!==null&&e!==void 0?e:!1,...Ce(t)})};class so extends Ae{_parse(e){if(this._def.coerce&&(e.data=!!e.data),this._getType(e)!==se.boolean){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.boolean,received:n.parsedType}),be}return Ft(e.data)}}so.create=t=>new so({typeName:me.ZodBoolean,coerce:(t==null?void 0:t.coerce)||!1,...Ce(t)});class Sr extends Ae{_parse(e){if(this._def.coerce&&(e.data=new Date(e.data)),this._getType(e)!==se.date){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_type,expected:se.date,received:i.parsedType}),be}if(isNaN(e.data.getTime())){const i=this._getOrReturnCtx(e);return ie(i,{code:K.invalid_date}),be}const n=new kt;let r;for(const i of this._def.checks)i.kind==="min"?e.data.getTime()<i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_small,message:i.message,inclusive:!0,exact:!1,minimum:i.value,type:"date"}),n.dirty()):i.kind==="max"?e.data.getTime()>i.value&&(r=this._getOrReturnCtx(e,r),ie(r,{code:K.too_big,message:i.message,inclusive:!0,exact:!1,maximum:i.value,type:"date"}),n.dirty()):Le.assertNever(i);return{status:n.value,value:new Date(e.data.getTime())}}_addCheck(e){return new Sr({...this._def,checks:[...this._def.checks,e]})}min(e,s){return this._addCheck({kind:"min",value:e.getTime(),message:pe.toString(s)})}max(e,s){return this._addCheck({kind:"max",value:e.getTime(),message:pe.toString(s)})}get minDate(){let e=null;for(const s of this._def.checks)s.kind==="min"&&(e===null||s.value>e)&&(e=s.value);return e!=null?new Date(e):null}get maxDate(){let e=null;for(const s of this._def.checks)s.kind==="max"&&(e===null||s.value<e)&&(e=s.value);return e!=null?new Date(e):null}}Sr.create=t=>new Sr({checks:[],coerce:(t==null?void 0:t.coerce)||!1,typeName:me.ZodDate,...Ce(t)});class Na extends Ae{_parse(e){if(this._getType(e)!==se.symbol){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.symbol,received:n.parsedType}),be}return Ft(e.data)}}Na.create=t=>new Na({typeName:me.ZodSymbol,...Ce(t)});class no extends Ae{_parse(e){if(this._getType(e)!==se.undefined){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.undefined,received:n.parsedType}),be}return Ft(e.data)}}no.create=t=>new no({typeName:me.ZodUndefined,...Ce(t)});class ro extends Ae{_parse(e){if(this._getType(e)!==se.null){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.null,received:n.parsedType}),be}return Ft(e.data)}}ro.create=t=>new ro({typeName:me.ZodNull,...Ce(t)});class ci extends Ae{constructor(){super(...arguments),this._any=!0}_parse(e){return Ft(e.data)}}ci.create=t=>new ci({typeName:me.ZodAny,...Ce(t)});class Cr extends Ae{constructor(){super(...arguments),this._unknown=!0}_parse(e){return Ft(e.data)}}Cr.create=t=>new Cr({typeName:me.ZodUnknown,...Ce(t)});class Sn extends Ae{_parse(e){const s=this._getOrReturnCtx(e);return ie(s,{code:K.invalid_type,expected:se.never,received:s.parsedType}),be}}Sn.create=t=>new Sn({typeName:me.ZodNever,...Ce(t)});class Ta extends Ae{_parse(e){if(this._getType(e)!==se.undefined){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.void,received:n.parsedType}),be}return Ft(e.data)}}Ta.create=t=>new Ta({typeName:me.ZodVoid,...Ce(t)});class $s extends Ae{_parse(e){const{ctx:s,status:n}=this._processInputParams(e),r=this._def;if(s.parsedType!==se.array)return ie(s,{code:K.invalid_type,expected:se.array,received:s.parsedType}),be;if(r.exactLength!==null){const o=s.data.length>r.exactLength.value,a=s.data.length<r.exactLength.value;(o||a)&&(ie(s,{code:o?K.too_big:K.too_small,minimum:a?r.exactLength.value:void 0,maximum:o?r.exactLength.value:void 0,type:"array",inclusive:!0,exact:!0,message:r.exactLength.message}),n.dirty())}if(r.minLength!==null&&s.data.length<r.minLength.value&&(ie(s,{code:K.too_small,minimum:r.minLength.value,type:"array",inclusive:!0,exact:!1,message:r.minLength.message}),n.dirty()),r.maxLength!==null&&s.data.length>r.maxLength.value&&(ie(s,{code:K.too_big,maximum:r.maxLength.value,type:"array",inclusive:!0,exact:!1,message:r.maxLength.message}),n.dirty()),s.common.async)return Promise.all([...s.data].map((o,a)=>r.type._parseAsync(new Qs(s,o,s.path,a)))).then(o=>kt.mergeArray(n,o));const i=[...s.data].map((o,a)=>r.type._parseSync(new Qs(s,o,s.path,a)));return kt.mergeArray(n,i)}get element(){return this._def.type}min(e,s){return new $s({...this._def,minLength:{value:e,message:pe.toString(s)}})}max(e,s){return new $s({...this._def,maxLength:{value:e,message:pe.toString(s)}})}length(e,s){return new $s({...this._def,exactLength:{value:e,message:pe.toString(s)}})}nonempty(e){return this.min(1,e)}}$s.create=(t,e)=>new $s({type:t,minLength:null,maxLength:null,exactLength:null,typeName:me.ZodArray,...Ce(e)});function Vr(t){if(t instanceof Xe){const e={};for(const s in t.shape){const n=t.shape[s];e[s]=bn.create(Vr(n))}return new Xe({...t._def,shape:()=>e})}else return t instanceof $s?new $s({...t._def,type:Vr(t.element)}):t instanceof bn?bn.create(Vr(t.unwrap())):t instanceof Nr?Nr.create(Vr(t.unwrap())):t instanceof en?en.create(t.items.map(e=>Vr(e))):t}class Xe extends Ae{constructor(){super(...arguments),this._cached=null,this.nonstrict=this.passthrough,this.augment=this.extend}_getCached(){if(this._cached!==null)return this._cached;const e=this._def.shape(),s=Le.objectKeys(e);return this._cached={shape:e,keys:s}}_parse(e){if(this._getType(e)!==se.object){const l=this._getOrReturnCtx(e);return ie(l,{code:K.invalid_type,expected:se.object,received:l.parsedType}),be}const{status:n,ctx:r}=this._processInputParams(e),{shape:i,keys:o}=this._getCached(),a=[];if(!(this._def.catchall instanceof Sn&&this._def.unknownKeys==="strip"))for(const l in r.data)o.includes(l)||a.push(l);const c=[];for(const l of o){const d=i[l],u=r.data[l];c.push({key:{status:"valid",value:l},value:d._parse(new Qs(r,u,r.path,l)),alwaysSet:l in r.data})}if(this._def.catchall instanceof Sn){const l=this._def.unknownKeys;if(l==="passthrough")for(const d of a)c.push({key:{status:"valid",value:d},value:{status:"valid",value:r.data[d]}});else if(l==="strict")a.length>0&&(ie(r,{code:K.unrecognized_keys,keys:a}),n.dirty());else if(l!=="strip")throw new Error("Internal ZodObject error: invalid unknownKeys value.")}else{const l=this._def.catchall;for(const d of a){const u=r.data[d];c.push({key:{status:"valid",value:d},value:l._parse(new Qs(r,u,r.path,d)),alwaysSet:d in r.data})}}return r.common.async?Promise.resolve().then(async()=>{const l=[];for(const d of c){const u=await d.key;l.push({key:u,value:await d.value,alwaysSet:d.alwaysSet})}return l}).then(l=>kt.mergeObjectSync(n,l)):kt.mergeObjectSync(n,c)}get shape(){return this._def.shape()}strict(e){return pe.errToObj,new Xe({...this._def,unknownKeys:"strict",...e!==void 0?{errorMap:(s,n)=>{var r,i,o,a;const c=(o=(i=(r=this._def).errorMap)===null||i===void 0?void 0:i.call(r,s,n).message)!==null&&o!==void 0?o:n.defaultError;return s.code==="unrecognized_keys"?{message:(a=pe.errToObj(e).message)!==null&&a!==void 0?a:c}:{message:c}}}:{}})}strip(){return new Xe({...this._def,unknownKeys:"strip"})}passthrough(){return new Xe({...this._def,unknownKeys:"passthrough"})}extend(e){return new Xe({...this._def,shape:()=>({...this._def.shape(),...e})})}merge(e){return new Xe({unknownKeys:e._def.unknownKeys,catchall:e._def.catchall,shape:()=>({...this._def.shape(),...e._def.shape()}),typeName:me.ZodObject})}setKey(e,s){return this.augment({[e]:s})}catchall(e){return new Xe({...this._def,catchall:e})}pick(e){const s={};return Le.objectKeys(e).forEach(n=>{e[n]&&this.shape[n]&&(s[n]=this.shape[n])}),new Xe({...this._def,shape:()=>s})}omit(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{e[n]||(s[n]=this.shape[n])}),new Xe({...this._def,shape:()=>s})}deepPartial(){return Vr(this)}partial(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{const r=this.shape[n];e&&!e[n]?s[n]=r:s[n]=r.optional()}),new Xe({...this._def,shape:()=>s})}required(e){const s={};return Le.objectKeys(this.shape).forEach(n=>{if(e&&!e[n])s[n]=this.shape[n];else{let i=this.shape[n];for(;i instanceof bn;)i=i._def.innerType;s[n]=i}}),new Xe({...this._def,shape:()=>s})}keyof(){return Df(Le.objectKeys(this.shape))}}Xe.create=(t,e)=>new Xe({shape:()=>t,unknownKeys:"strip",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});Xe.strictCreate=(t,e)=>new Xe({shape:()=>t,unknownKeys:"strict",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});Xe.lazycreate=(t,e)=>new Xe({shape:t,unknownKeys:"strip",catchall:Sn.create(),typeName:me.ZodObject,...Ce(e)});class io extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n=this._def.options;function r(i){for(const a of i)if(a.result.status==="valid")return a.result;for(const a of i)if(a.result.status==="dirty")return s.common.issues.push(...a.ctx.common.issues),a.result;const o=i.map(a=>new Us(a.ctx.common.issues));return ie(s,{code:K.invalid_union,unionErrors:o}),be}if(s.common.async)return Promise.all(n.map(async i=>{const o={...s,common:{...s.common,issues:[]},parent:null};return{result:await i._parseAsync({data:s.data,path:s.path,parent:o}),ctx:o}})).then(r);{let i;const o=[];for(const c of n){const l={...s,common:{...s.common,issues:[]},parent:null},d=c._parseSync({data:s.data,path:s.path,parent:l});if(d.status==="valid")return d;d.status==="dirty"&&!i&&(i={result:d,ctx:l}),l.common.issues.length&&o.push(l.common.issues)}if(i)return s.common.issues.push(...i.ctx.common.issues),i.result;const a=o.map(c=>new Us(c));return ie(s,{code:K.invalid_union,unionErrors:a}),be}}get options(){return this._def.options}}io.create=(t,e)=>new io({options:t,typeName:me.ZodUnion,...Ce(e)});const ha=t=>t instanceof co?ha(t.schema):t instanceof Ls?ha(t.innerType()):t instanceof lo?[t.value]:t instanceof Xn?t.options:t instanceof uo?Object.keys(t.enum):t instanceof ho?ha(t._def.innerType):t instanceof no?[void 0]:t instanceof ro?[null]:null;class sc extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.object)return ie(s,{code:K.invalid_type,expected:se.object,received:s.parsedType}),be;const n=this.discriminator,r=s.data[n],i=this.optionsMap.get(r);return i?s.common.async?i._parseAsync({data:s.data,path:s.path,parent:s}):i._parseSync({data:s.data,path:s.path,parent:s}):(ie(s,{code:K.invalid_union_discriminator,options:Array.from(this.optionsMap.keys()),path:[n]}),be)}get discriminator(){return this._def.discriminator}get options(){return this._def.options}get optionsMap(){return this._def.optionsMap}static create(e,s,n){const r=new Map;for(const i of s){const o=ha(i.shape[e]);if(!o)throw new Error(`A discriminator value for key \`${e}\` could not be extracted from all schema options`);for(const a of o){if(r.has(a))throw new Error(`Discriminator property ${String(e)} has duplicate value ${String(a)}`);r.set(a,i)}}return new sc({typeName:me.ZodDiscriminatedUnion,discriminator:e,options:s,optionsMap:r,...Ce(n)})}}function Tl(t,e){const s=Bn(t),n=Bn(e);if(t===e)return{valid:!0,data:t};if(s===se.object&&n===se.object){const r=Le.objectKeys(e),i=Le.objectKeys(t).filter(a=>r.indexOf(a)!==-1),o={...t,...e};for(const a of i){const c=Tl(t[a],e[a]);if(!c.valid)return{valid:!1};o[a]=c.data}return{valid:!0,data:o}}else if(s===se.array&&n===se.array){if(t.length!==e.length)return{valid:!1};const r=[];for(let i=0;i<t.length;i++){const o=t[i],a=e[i],c=Tl(o,a);if(!c.valid)return{valid:!1};r.push(c.data)}return{valid:!0,data:r}}else return s===se.date&&n===se.date&&+t==+e?{valid:!0,data:t}:{valid:!1}}class oo extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e),r=(i,o)=>{if(Il(i)||Il(o))return be;const a=Tl(i.value,o.value);return a.valid?((Nl(i)||Nl(o))&&s.dirty(),{status:s.value,value:a.data}):(ie(n,{code:K.invalid_intersection_types}),be)};return n.common.async?Promise.all([this._def.left._parseAsync({data:n.data,path:n.path,parent:n}),this._def.right._parseAsync({data:n.data,path:n.path,parent:n})]).then(([i,o])=>r(i,o)):r(this._def.left._parseSync({data:n.data,path:n.path,parent:n}),this._def.right._parseSync({data:n.data,path:n.path,parent:n}))}}oo.create=(t,e,s)=>new oo({left:t,right:e,typeName:me.ZodIntersection,...Ce(s)});class en extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.array)return ie(n,{code:K.invalid_type,expected:se.array,received:n.parsedType}),be;if(n.data.length<this._def.items.length)return ie(n,{code:K.too_small,minimum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),be;!this._def.rest&&n.data.length>this._def.items.length&&(ie(n,{code:K.too_big,maximum:this._def.items.length,inclusive:!0,exact:!1,type:"array"}),s.dirty());const i=[...n.data].map((o,a)=>{const c=this._def.items[a]||this._def.rest;return c?c._parse(new Qs(n,o,n.path,a)):null}).filter(o=>!!o);return n.common.async?Promise.all(i).then(o=>kt.mergeArray(s,o)):kt.mergeArray(s,i)}get items(){return this._def.items}rest(e){return new en({...this._def,rest:e})}}en.create=(t,e)=>{if(!Array.isArray(t))throw new Error("You must pass an array of schemas to z.tuple([ ... ])");return new en({items:t,typeName:me.ZodTuple,rest:null,...Ce(e)})};class ao extends Ae{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.object)return ie(n,{code:K.invalid_type,expected:se.object,received:n.parsedType}),be;const r=[],i=this._def.keyType,o=this._def.valueType;for(const a in n.data)r.push({key:i._parse(new Qs(n,a,n.path,a)),value:o._parse(new Qs(n,n.data[a],n.path,a))});return n.common.async?kt.mergeObjectAsync(s,r):kt.mergeObjectSync(s,r)}get element(){return this._def.valueType}static create(e,s,n){return s instanceof Ae?new ao({keyType:e,valueType:s,typeName:me.ZodRecord,...Ce(n)}):new ao({keyType:ks.create(),valueType:e,typeName:me.ZodRecord,...Ce(s)})}}class Ra extends Ae{get keySchema(){return this._def.keyType}get valueSchema(){return this._def.valueType}_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.map)return ie(n,{code:K.invalid_type,expected:se.map,received:n.parsedType}),be;const r=this._def.keyType,i=this._def.valueType,o=[...n.data.entries()].map(([a,c],l)=>({key:r._parse(new Qs(n,a,n.path,[l,"key"])),value:i._parse(new Qs(n,c,n.path,[l,"value"]))}));if(n.common.async){const a=new Map;return Promise.resolve().then(async()=>{for(const c of o){const l=await c.key,d=await c.value;if(l.status==="aborted"||d.status==="aborted")return be;(l.status==="dirty"||d.status==="dirty")&&s.dirty(),a.set(l.value,d.value)}return{status:s.value,value:a}})}else{const a=new Map;for(const c of o){const l=c.key,d=c.value;if(l.status==="aborted"||d.status==="aborted")return be;(l.status==="dirty"||d.status==="dirty")&&s.dirty(),a.set(l.value,d.value)}return{status:s.value,value:a}}}}Ra.create=(t,e,s)=>new Ra({valueType:e,keyType:t,typeName:me.ZodMap,...Ce(s)});class Ir extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.parsedType!==se.set)return ie(n,{code:K.invalid_type,expected:se.set,received:n.parsedType}),be;const r=this._def;r.minSize!==null&&n.data.size<r.minSize.value&&(ie(n,{code:K.too_small,minimum:r.minSize.value,type:"set",inclusive:!0,exact:!1,message:r.minSize.message}),s.dirty()),r.maxSize!==null&&n.data.size>r.maxSize.value&&(ie(n,{code:K.too_big,maximum:r.maxSize.value,type:"set",inclusive:!0,exact:!1,message:r.maxSize.message}),s.dirty());const i=this._def.valueType;function o(c){const l=new Set;for(const d of c){if(d.status==="aborted")return be;d.status==="dirty"&&s.dirty(),l.add(d.value)}return{status:s.value,value:l}}const a=[...n.data.values()].map((c,l)=>i._parse(new Qs(n,c,n.path,l)));return n.common.async?Promise.all(a).then(c=>o(c)):o(a)}min(e,s){return new Ir({...this._def,minSize:{value:e,message:pe.toString(s)}})}max(e,s){return new Ir({...this._def,maxSize:{value:e,message:pe.toString(s)}})}size(e,s){return this.min(e,s).max(e,s)}nonempty(e){return this.min(1,e)}}Ir.create=(t,e)=>new Ir({valueType:t,minSize:null,maxSize:null,typeName:me.ZodSet,...Ce(e)});class ei extends Ae{constructor(){super(...arguments),this.validate=this.implement}_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.function)return ie(s,{code:K.invalid_type,expected:se.function,received:s.parsedType}),be;function n(a,c){return Sa({data:a,path:s.path,errorMaps:[s.common.contextualErrorMap,s.schemaErrorMap,Aa(),eo].filter(l=>!!l),issueData:{code:K.invalid_arguments,argumentsError:c}})}function r(a,c){return Sa({data:a,path:s.path,errorMaps:[s.common.contextualErrorMap,s.schemaErrorMap,Aa(),eo].filter(l=>!!l),issueData:{code:K.invalid_return_type,returnTypeError:c}})}const i={errorMap:s.common.contextualErrorMap},o=s.data;if(this._def.returns instanceof li){const a=this;return Ft(async function(...c){const l=new Us([]),d=await a._def.args.parseAsync(c,i).catch(p=>{throw l.addIssue(n(c,p)),l}),u=await Reflect.apply(o,this,d);return await a._def.returns._def.type.parseAsync(u,i).catch(p=>{throw l.addIssue(r(u,p)),l})})}else{const a=this;return Ft(function(...c){const l=a._def.args.safeParse(c,i);if(!l.success)throw new Us([n(c,l.error)]);const d=Reflect.apply(o,this,l.data),u=a._def.returns.safeParse(d,i);if(!u.success)throw new Us([r(d,u.error)]);return u.data})}}parameters(){return this._def.args}returnType(){return this._def.returns}args(...e){return new ei({...this._def,args:en.create(e).rest(Cr.create())})}returns(e){return new ei({...this._def,returns:e})}implement(e){return this.parse(e)}strictImplement(e){return this.parse(e)}static create(e,s,n){return new ei({args:e||en.create([]).rest(Cr.create()),returns:s||Cr.create(),typeName:me.ZodFunction,...Ce(n)})}}class co extends Ae{get schema(){return this._def.getter()}_parse(e){const{ctx:s}=this._processInputParams(e);return this._def.getter()._parse({data:s.data,path:s.path,parent:s})}}co.create=(t,e)=>new co({getter:t,typeName:me.ZodLazy,...Ce(e)});class lo extends Ae{_parse(e){if(e.data!==this._def.value){const s=this._getOrReturnCtx(e);return ie(s,{received:s.data,code:K.invalid_literal,expected:this._def.value}),be}return{status:"valid",value:e.data}}get value(){return this._def.value}}lo.create=(t,e)=>new lo({value:t,typeName:me.ZodLiteral,...Ce(e)});function Df(t,e){return new Xn({values:t,typeName:me.ZodEnum,...Ce(e)})}class Xn extends Ae{_parse(e){if(typeof e.data!="string"){const s=this._getOrReturnCtx(e),n=this._def.values;return ie(s,{expected:Le.joinValues(n),received:s.parsedType,code:K.invalid_type}),be}if(this._def.values.indexOf(e.data)===-1){const s=this._getOrReturnCtx(e),n=this._def.values;return ie(s,{received:s.data,code:K.invalid_enum_value,options:n}),be}return Ft(e.data)}get options(){return this._def.values}get enum(){const e={};for(const s of this._def.values)e[s]=s;return e}get Values(){const e={};for(const s of this._def.values)e[s]=s;return e}get Enum(){const e={};for(const s of this._def.values)e[s]=s;return e}extract(e){return Xn.create(e)}exclude(e){return Xn.create(this.options.filter(s=>!e.includes(s)))}}Xn.create=Df;class uo extends Ae{_parse(e){const s=Le.getValidEnumValues(this._def.values),n=this._getOrReturnCtx(e);if(n.parsedType!==se.string&&n.parsedType!==se.number){const r=Le.objectValues(s);return ie(n,{expected:Le.joinValues(r),received:n.parsedType,code:K.invalid_type}),be}if(s.indexOf(e.data)===-1){const r=Le.objectValues(s);return ie(n,{received:n.data,code:K.invalid_enum_value,options:r}),be}return Ft(e.data)}get enum(){return this._def.values}}uo.create=(t,e)=>new uo({values:t,typeName:me.ZodNativeEnum,...Ce(e)});class li extends Ae{unwrap(){return this._def.type}_parse(e){const{ctx:s}=this._processInputParams(e);if(s.parsedType!==se.promise&&s.common.async===!1)return ie(s,{code:K.invalid_type,expected:se.promise,received:s.parsedType}),be;const n=s.parsedType===se.promise?s.data:Promise.resolve(s.data);return Ft(n.then(r=>this._def.type.parseAsync(r,{path:s.path,errorMap:s.common.contextualErrorMap})))}}li.create=(t,e)=>new li({type:t,typeName:me.ZodPromise,...Ce(e)});class Ls extends Ae{innerType(){return this._def.schema}sourceType(){return this._def.schema._def.typeName===me.ZodEffects?this._def.schema.sourceType():this._def.schema}_parse(e){const{status:s,ctx:n}=this._processInputParams(e),r=this._def.effect||null,i={addIssue:o=>{ie(n,o),o.fatal?s.abort():s.dirty()},get path(){return n.path}};if(i.addIssue=i.addIssue.bind(i),r.type==="preprocess"){const o=r.transform(n.data,i);return n.common.issues.length?{status:"dirty",value:n.data}:n.common.async?Promise.resolve(o).then(a=>this._def.schema._parseAsync({data:a,path:n.path,parent:n})):this._def.schema._parseSync({data:o,path:n.path,parent:n})}if(r.type==="refinement"){const o=a=>{const c=r.refinement(a,i);if(n.common.async)return Promise.resolve(c);if(c instanceof Promise)throw new Error("Async refinement encountered during synchronous parse operation. Use .parseAsync instead.");return a};if(n.common.async===!1){const a=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});return a.status==="aborted"?be:(a.status==="dirty"&&s.dirty(),o(a.value),{status:s.value,value:a.value})}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(a=>a.status==="aborted"?be:(a.status==="dirty"&&s.dirty(),o(a.value).then(()=>({status:s.value,value:a.value}))))}if(r.type==="transform")if(n.common.async===!1){const o=this._def.schema._parseSync({data:n.data,path:n.path,parent:n});if(!to(o))return o;const a=r.transform(o.value,i);if(a instanceof Promise)throw new Error("Asynchronous transform encountered during synchronous parse operation. Use .parseAsync instead.");return{status:s.value,value:a}}else return this._def.schema._parseAsync({data:n.data,path:n.path,parent:n}).then(o=>to(o)?Promise.resolve(r.transform(o.value,i)).then(a=>({status:s.value,value:a})):o);Le.assertNever(r)}}Ls.create=(t,e,s)=>new Ls({schema:t,typeName:me.ZodEffects,effect:e,...Ce(s)});Ls.createWithPreprocess=(t,e,s)=>new Ls({schema:e,effect:{type:"preprocess",transform:t},typeName:me.ZodEffects,...Ce(s)});class bn extends Ae{_parse(e){return this._getType(e)===se.undefined?Ft(void 0):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}}bn.create=(t,e)=>new bn({innerType:t,typeName:me.ZodOptional,...Ce(e)});class Nr extends Ae{_parse(e){return this._getType(e)===se.null?Ft(null):this._def.innerType._parse(e)}unwrap(){return this._def.innerType}}Nr.create=(t,e)=>new Nr({innerType:t,typeName:me.ZodNullable,...Ce(e)});class ho extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e);let n=s.data;return s.parsedType===se.undefined&&(n=this._def.defaultValue()),this._def.innerType._parse({data:n,path:s.path,parent:s})}removeDefault(){return this._def.innerType}}ho.create=(t,e)=>new ho({innerType:t,typeName:me.ZodDefault,defaultValue:typeof e.default=="function"?e.default:()=>e.default,...Ce(e)});class Oa extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n={...s,common:{...s.common,issues:[]}},r=this._def.innerType._parse({data:n.data,path:n.path,parent:{...n}});return Ia(r)?r.then(i=>({status:"valid",value:i.status==="valid"?i.value:this._def.catchValue({get error(){return new Us(n.common.issues)},input:n.data})})):{status:"valid",value:r.status==="valid"?r.value:this._def.catchValue({get error(){return new Us(n.common.issues)},input:n.data})}}removeCatch(){return this._def.innerType}}Oa.create=(t,e)=>new Oa({innerType:t,typeName:me.ZodCatch,catchValue:typeof e.catch=="function"?e.catch:()=>e.catch,...Ce(e)});class Pa extends Ae{_parse(e){if(this._getType(e)!==se.nan){const n=this._getOrReturnCtx(e);return ie(n,{code:K.invalid_type,expected:se.nan,received:n.parsedType}),be}return{status:"valid",value:e.data}}}Pa.create=t=>new Pa({typeName:me.ZodNaN,...Ce(t)});const Ww=Symbol("zod_brand");class Lf extends Ae{_parse(e){const{ctx:s}=this._processInputParams(e),n=s.data;return this._def.type._parse({data:n,path:s.path,parent:s})}unwrap(){return this._def.type}}class Ao extends Ae{_parse(e){const{status:s,ctx:n}=this._processInputParams(e);if(n.common.async)return(async()=>{const i=await this._def.in._parseAsync({data:n.data,path:n.path,parent:n});return i.status==="aborted"?be:i.status==="dirty"?(s.dirty(),$f(i.value)):this._def.out._parseAsync({data:i.value,path:n.path,parent:n})})();{const r=this._def.in._parseSync({data:n.data,path:n.path,parent:n});return r.status==="aborted"?be:r.status==="dirty"?(s.dirty(),{status:"dirty",value:r.value}):this._def.out._parseSync({data:r.value,path:n.path,parent:n})}}static create(e,s){return new Ao({in:e,out:s,typeName:me.ZodPipeline})}}class xa extends Ae{_parse(e){const s=this._def.innerType._parse(e);return to(s)&&(s.value=Object.freeze(s.value)),s}}xa.create=(t,e)=>new xa({innerType:t,typeName:me.ZodReadonly,...Ce(e)});const Mf=(t,e={},s)=>t?ci.create().superRefine((n,r)=>{var i,o;if(!t(n)){const a=typeof e=="function"?e(n):typeof e=="string"?{message:e}:e,c=(o=(i=a.fatal)!==null&&i!==void 0?i:s)!==null&&o!==void 0?o:!0,l=typeof a=="string"?{message:a}:a;r.addIssue({code:"custom",...l,fatal:c})}}):ci.create(),Hw={object:Xe.lazycreate};var me;(function(t){t.ZodString="ZodString",t.ZodNumber="ZodNumber",t.ZodNaN="ZodNaN",t.ZodBigInt="ZodBigInt",t.ZodBoolean="ZodBoolean",t.ZodDate="ZodDate",t.ZodSymbol="ZodSymbol",t.ZodUndefined="ZodUndefined",t.ZodNull="ZodNull",t.ZodAny="ZodAny",t.ZodUnknown="ZodUnknown",t.ZodNever="ZodNever",t.ZodVoid="ZodVoid",t.ZodArray="ZodArray",t.ZodObject="ZodObject",t.ZodUnion="ZodUnion",t.ZodDiscriminatedUnion="ZodDiscriminatedUnion",t.ZodIntersection="ZodIntersection",t.ZodTuple="ZodTuple",t.ZodRecord="ZodRecord",t.ZodMap="ZodMap",t.ZodSet="ZodSet",t.ZodFunction="ZodFunction",t.ZodLazy="ZodLazy",t.ZodLiteral="ZodLiteral",t.ZodEnum="ZodEnum",t.ZodEffects="ZodEffects",t.ZodNativeEnum="ZodNativeEnum",t.ZodOptional="ZodOptional",t.ZodNullable="ZodNullable",t.ZodDefault="ZodDefault",t.ZodCatch="ZodCatch",t.ZodPromise="ZodPromise",t.ZodBranded="ZodBranded",t.ZodPipeline="ZodPipeline",t.ZodReadonly="ZodReadonly"})(me||(me={}));const zw=(t,e={message:`Input not instance of ${t.name}`})=>Mf(s=>s instanceof t,e),Bf=ks.create,jf=Zn.create,Vw=Pa.create,Kw=Jn.create,Ff=so.create,Gw=Sr.create,Yw=Na.create,Zw=no.create,Jw=ro.create,Xw=ci.create,Qw=Cr.create,eE=Sn.create,tE=Ta.create,sE=$s.create,nE=Xe.create,rE=Xe.strictCreate,iE=io.create,oE=sc.create,aE=oo.create,cE=en.create,lE=ao.create,dE=Ra.create,uE=Ir.create,hE=ei.create,pE=co.create,fE=lo.create,gE=Xn.create,mE=uo.create,yE=li.create,$u=Ls.create,wE=bn.create,EE=Nr.create,bE=Ls.createWithPreprocess,vE=Ao.create,CE=()=>Bf().optional(),_E=()=>jf().optional(),AE=()=>Ff().optional(),SE={string:t=>ks.create({...t,coerce:!0}),number:t=>Zn.create({...t,coerce:!0}),boolean:t=>so.create({...t,coerce:!0}),bigint:t=>Jn.create({...t,coerce:!0}),date:t=>Sr.create({...t,coerce:!0})},IE=be;var m=Object.freeze({__proto__:null,defaultErrorMap:eo,setErrorMap:Ow,getErrorMap:Aa,makeIssue:Sa,EMPTY_PATH:Pw,addIssueToContext:ie,ParseStatus:kt,INVALID:be,DIRTY:$f,OK:Ft,isAborted:Il,isDirty:Nl,isValid:to,isAsync:Ia,get util(){return Le},get objectUtil(){return Sl},ZodParsedType:se,getParsedType:Bn,ZodType:Ae,ZodString:ks,ZodNumber:Zn,ZodBigInt:Jn,ZodBoolean:so,ZodDate:Sr,ZodSymbol:Na,ZodUndefined:no,ZodNull:ro,ZodAny:ci,ZodUnknown:Cr,ZodNever:Sn,ZodVoid:Ta,ZodArray:$s,ZodObject:Xe,ZodUnion:io,ZodDiscriminatedUnion:sc,ZodIntersection:oo,ZodTuple:en,ZodRecord:ao,ZodMap:Ra,ZodSet:Ir,ZodFunction:ei,ZodLazy:co,ZodLiteral:lo,ZodEnum:Xn,ZodNativeEnum:uo,ZodPromise:li,ZodEffects:Ls,ZodTransformer:Ls,ZodOptional:bn,ZodNullable:Nr,ZodDefault:ho,ZodCatch:Oa,ZodNaN:Pa,BRAND:Ww,ZodBranded:Lf,ZodPipeline:Ao,ZodReadonly:xa,custom:Mf,Schema:Ae,ZodSchema:Ae,late:Hw,get ZodFirstPartyTypeKind(){return me},coerce:SE,any:Xw,array:sE,bigint:Kw,boolean:Ff,date:Gw,discriminatedUnion:oE,effect:$u,enum:gE,function:hE,instanceof:zw,intersection:aE,lazy:pE,literal:fE,map:dE,nan:Vw,nativeEnum:mE,never:eE,null:Jw,nullable:EE,number:jf,object:nE,oboolean:AE,onumber:_E,optional:wE,ostring:CE,pipeline:vE,preprocess:bE,promise:yE,record:lE,set:uE,strictObject:rE,string:Bf,symbol:Yw,transformer:$u,tuple:cE,undefined:Zw,union:iE,unknown:Qw,void:tE,NEVER:IE,ZodIssueCode:K,quotelessJson:Rw,ZodError:Us});const Qe=m.object({message:m.string()});function ne(t){return m.literal(oe[t])}const nc=m.object({serializedMessage:m.string().optional(),accountAddress:m.string(),chainId:m.string(),notBefore:m.string().optional(),domain:m.string(),uri:m.string(),version:m.string(),nonce:m.string(),statement:m.string().optional(),resources:m.array(m.string()).optional(),requestId:m.string().optional(),issuedAt:m.string().optional(),expirationTime:m.string().optional()});m.object({accessList:m.array(m.string()),blockHash:m.string().nullable(),blockNumber:m.string().nullable(),chainId:m.string().or(m.number()),from:m.string(),gas:m.string(),hash:m.string(),input:m.string().nullable(),maxFeePerGas:m.string(),maxPriorityFeePerGas:m.string(),nonce:m.string(),r:m.string(),s:m.string(),to:m.string(),transactionIndex:m.string().nullable(),type:m.string(),v:m.string(),value:m.string()});const NE=m.object({chainId:m.string().or(m.number()),rpcUrl:m.optional(m.string())}),TE=m.object({email:m.string().email()}),RE=m.object({otp:m.string()}),OE=m.object({uri:m.string(),preferredAccountType:m.optional(m.string()),chainId:m.optional(m.string().or(m.number())),siwxMessage:m.optional(nc),rpcUrl:m.optional(m.string())}),PE=m.object({chainId:m.optional(m.string().or(m.number())),preferredAccountType:m.optional(m.string()),socialUri:m.optional(m.string()),siwxMessage:m.optional(nc),rpcUrl:m.optional(m.string())}),xE=m.object({provider:m.enum(["google","github","apple","facebook","x","discord"])}),kE=m.object({email:m.string().email()}),UE=m.object({otp:m.string()}),$E=m.object({otp:m.string()}),DE=m.object({themeMode:m.optional(m.enum(["light","dark"])),themeVariables:m.optional(m.record(m.string(),m.string().or(m.number()))),w3mThemeVariables:m.optional(m.record(m.string(),m.string()))}),LE=m.object({metadata:m.object({name:m.string(),description:m.string(),url:m.string(),icons:m.array(m.string())}).optional(),sdkVersion:m.string().optional(),sdkType:m.string().optional(),projectId:m.string()}),ME=m.object({type:m.string()}),BE=m.object({action:m.enum(["VERIFY_DEVICE","VERIFY_OTP","CONNECT"])}),jE=m.object({url:m.string()}),FE=m.object({userName:m.string()}),qE=m.object({email:m.string().optional().nullable(),address:m.string(),chainId:m.string().or(m.number()),accounts:m.array(m.object({address:m.string(),type:m.enum([tt.ACCOUNT_TYPES.EOA,tt.ACCOUNT_TYPES.SMART_ACCOUNT])})).optional(),userName:m.string().optional().nullable(),preferredAccountType:m.optional(m.string()),signature:m.string().optional(),message:m.string().optional(),siwxMessage:m.optional(nc)}),WE=m.object({action:m.enum(["VERIFY_PRIMARY_OTP","VERIFY_SECONDARY_OTP"])}),HE=m.object({email:m.string().email().optional().nullable(),address:m.string(),chainId:m.string().or(m.number()),smartAccountDeployed:m.optional(m.boolean()),accounts:m.array(m.object({address:m.string(),type:m.enum([tt.ACCOUNT_TYPES.EOA,tt.ACCOUNT_TYPES.SMART_ACCOUNT])})).optional(),preferredAccountType:m.optional(m.string()),signature:m.string().optional(),message:m.string().optional(),siwxMessage:m.optional(nc)}),zE=m.object({uri:m.string()}),VE=m.object({isConnected:m.boolean()}),KE=m.object({chainId:m.string().or(m.number())}),GE=m.object({chainId:m.string().or(m.number())}),YE=m.object({newEmail:m.string().email()}),ZE=m.object({smartAccountEnabledNetworks:m.array(m.number())});m.object({address:m.string(),isDeployed:m.boolean()});const JE=m.object({version:m.string().optional()}),XE=m.object({type:m.string(),address:m.string()}),QE=m.any(),eb=m.object({method:m.literal("eth_accounts")}),tb=m.object({method:m.literal("eth_blockNumber")}),sb=m.object({method:m.literal("eth_call"),params:m.array(m.any())}),nb=m.object({method:m.literal("eth_chainId")}),rb=m.object({method:m.literal("eth_estimateGas"),params:m.array(m.any())}),ib=m.object({method:m.literal("eth_feeHistory"),params:m.array(m.any())}),ob=m.object({method:m.literal("eth_gasPrice")}),ab=m.object({method:m.literal("eth_getAccount"),params:m.array(m.any())}),cb=m.object({method:m.literal("eth_getBalance"),params:m.array(m.any())}),lb=m.object({method:m.literal("eth_getBlockByHash"),params:m.array(m.any())}),db=m.object({method:m.literal("eth_getBlockByNumber"),params:m.array(m.any())}),ub=m.object({method:m.literal("eth_getBlockReceipts"),params:m.array(m.any())}),hb=m.object({method:m.literal("eth_getBlockTransactionCountByHash"),params:m.array(m.any())}),pb=m.object({method:m.literal("eth_getBlockTransactionCountByNumber"),params:m.array(m.any())}),fb=m.object({method:m.literal("eth_getCode"),params:m.array(m.any())}),gb=m.object({method:m.literal("eth_getFilterChanges"),params:m.array(m.any())}),mb=m.object({method:m.literal("eth_getFilterLogs"),params:m.array(m.any())}),yb=m.object({method:m.literal("eth_getLogs"),params:m.array(m.any())}),wb=m.object({method:m.literal("eth_getProof"),params:m.array(m.any())}),Eb=m.object({method:m.literal("eth_getStorageAt"),params:m.array(m.any())}),bb=m.object({method:m.literal("eth_getTransactionByBlockHashAndIndex"),params:m.array(m.any())}),vb=m.object({method:m.literal("eth_getTransactionByBlockNumberAndIndex"),params:m.array(m.any())}),Cb=m.object({method:m.literal("eth_getTransactionByHash"),params:m.array(m.any())}),_b=m.object({method:m.literal("eth_getTransactionCount"),params:m.array(m.any())}),Ab=m.object({method:m.literal("eth_getTransactionReceipt"),params:m.array(m.any())}),Sb=m.object({method:m.literal("eth_getUncleCountByBlockHash"),params:m.array(m.any())}),Ib=m.object({method:m.literal("eth_getUncleCountByBlockNumber"),params:m.array(m.any())}),Nb=m.object({method:m.literal("eth_maxPriorityFeePerGas")}),Tb=m.object({method:m.literal("eth_newBlockFilter")}),Rb=m.object({method:m.literal("eth_newFilter"),params:m.array(m.any())}),Ob=m.object({method:m.literal("eth_newPendingTransactionFilter")}),Pb=m.object({method:m.literal("eth_sendRawTransaction"),params:m.array(m.any())}),xb=m.object({method:m.literal("eth_syncing"),params:m.array(m.any())}),kb=m.object({method:m.literal("eth_uninstallFilter"),params:m.array(m.any())}),Du=m.object({method:m.literal("personal_sign"),params:m.array(m.any())}),Ub=m.object({method:m.literal("eth_signTypedData_v4"),params:m.array(m.any())}),$b=m.object({method:m.literal("eth_sendTransaction"),params:m.array(m.any())}),Db=m.object({method:m.literal("solana_signMessage"),params:m.object({message:m.string(),pubkey:m.string()})}),Lb=m.object({method:m.literal("solana_signTransaction"),params:m.object({transaction:m.string()})}),Mb=m.object({method:m.literal("solana_signAllTransactions"),params:m.object({transactions:m.array(m.string())})}),Bb=m.object({method:m.literal("solana_signAndSendTransaction"),params:m.object({transaction:m.string(),options:m.object({skipPreflight:m.boolean().optional(),preflightCommitment:m.enum(["processed","confirmed","finalized","recent","single","singleGossip","root","max"]).optional(),maxRetries:m.number().optional(),minContextSlot:m.number().optional()}).optional()})}),jb=m.object({method:m.literal("wallet_sendCalls"),params:m.array(m.object({chainId:m.string().or(m.number()).optional(),from:m.string().optional(),version:m.string().optional(),capabilities:m.any().optional(),calls:m.array(m.object({to:m.string().startsWith("0x"),data:m.string().startsWith("0x").optional(),value:m.string().optional()}))}))}),Fb=m.object({method:m.literal("wallet_getCallsStatus"),params:m.array(m.string())}),qb=m.object({method:m.literal("wallet_getCapabilities"),params:m.array(m.string().or(m.number()).optional()).optional()}),Wb=m.object({method:m.literal("wallet_grantPermissions"),params:m.array(m.any())}),Hb=m.object({method:m.literal("wallet_revokePermissions"),params:m.any()}),zb=m.object({method:m.literal("wallet_getAssets"),params:m.any()}),Lu=m.object({token:m.string()}),re=m.object({id:m.string().optional()}),Ac={appEvent:re.extend({type:ne("APP_SWITCH_NETWORK"),payload:NE}).or(re.extend({type:ne("APP_CONNECT_EMAIL"),payload:TE})).or(re.extend({type:ne("APP_CONNECT_DEVICE")})).or(re.extend({type:ne("APP_CONNECT_OTP"),payload:RE})).or(re.extend({type:ne("APP_CONNECT_SOCIAL"),payload:OE})).or(re.extend({type:ne("APP_GET_FARCASTER_URI")})).or(re.extend({type:ne("APP_CONNECT_FARCASTER")})).or(re.extend({type:ne("APP_GET_USER"),payload:m.optional(PE)})).or(re.extend({type:ne("APP_GET_SOCIAL_REDIRECT_URI"),payload:xE})).or(re.extend({type:ne("APP_SIGN_OUT")})).or(re.extend({type:ne("APP_IS_CONNECTED"),payload:m.optional(Lu)})).or(re.extend({type:ne("APP_GET_CHAIN_ID")})).or(re.extend({type:ne("APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS")})).or(re.extend({type:ne("APP_INIT_SMART_ACCOUNT")})).or(re.extend({type:ne("APP_SET_PREFERRED_ACCOUNT"),payload:ME})).or(re.extend({type:ne("APP_RPC_REQUEST"),payload:Du.or(zb).or(eb).or(tb).or(sb).or(nb).or(rb).or(ib).or(ob).or(ab).or(cb).or(lb).or(db).or(ub).or(hb).or(pb).or(fb).or(gb).or(mb).or(yb).or(wb).or(Eb).or(bb).or(vb).or(Cb).or(_b).or(Ab).or(Sb).or(Ib).or(Nb).or(Tb).or(Rb).or(Ob).or(Pb).or(xb).or(kb).or(Du).or(Ub).or($b).or(Db).or(Lb).or(Mb).or(Bb).or(Fb).or(jb).or(qb).or(Wb).or(Hb).and(m.object({chainId:m.string().or(m.number()).optional(),chainNamespace:m.enum(["eip155","solana","polkadot","bip122","cosmos"]).optional(),rpcUrl:m.string().optional()}))})).or(re.extend({type:ne("APP_UPDATE_EMAIL"),payload:kE})).or(re.extend({type:ne("APP_UPDATE_EMAIL_PRIMARY_OTP"),payload:UE})).or(re.extend({type:ne("APP_UPDATE_EMAIL_SECONDARY_OTP"),payload:$E})).or(re.extend({type:ne("APP_SYNC_THEME"),payload:DE})).or(re.extend({type:ne("APP_SYNC_DAPP_DATA"),payload:LE})).or(re.extend({type:ne("APP_RELOAD")})).or(re.extend({type:ne("APP_RPC_ABORT")})),frameEvent:re.extend({type:ne("FRAME_SWITCH_NETWORK_ERROR"),payload:Qe}).or(re.extend({type:ne("FRAME_SWITCH_NETWORK_SUCCESS"),payload:GE})).or(re.extend({type:ne("FRAME_CONNECT_EMAIL_SUCCESS"),payload:BE})).or(re.extend({type:ne("FRAME_CONNECT_EMAIL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_FARCASTER_URI_SUCCESS"),payload:jE})).or(re.extend({type:ne("FRAME_GET_FARCASTER_URI_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_FARCASTER_SUCCESS"),payload:FE})).or(re.extend({type:ne("FRAME_CONNECT_FARCASTER_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_OTP_SUCCESS")})).or(re.extend({type:ne("FRAME_CONNECT_DEVICE_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_CONNECT_DEVICE_SUCCESS")})).or(re.extend({type:ne("FRAME_CONNECT_SOCIAL_SUCCESS"),payload:qE})).or(re.extend({type:ne("FRAME_CONNECT_SOCIAL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_USER_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_USER_SUCCESS"),payload:HE})).or(re.extend({type:ne("FRAME_GET_SOCIAL_REDIRECT_URI_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_SOCIAL_REDIRECT_URI_SUCCESS"),payload:zE})).or(re.extend({type:ne("FRAME_SIGN_OUT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SIGN_OUT_SUCCESS")})).or(re.extend({type:ne("FRAME_IS_CONNECTED_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_IS_CONNECTED_SUCCESS"),payload:VE})).or(re.extend({type:ne("FRAME_GET_CHAIN_ID_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_GET_CHAIN_ID_SUCCESS"),payload:KE})).or(re.extend({type:ne("FRAME_RPC_REQUEST_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_RPC_REQUEST_SUCCESS"),payload:QE})).or(re.extend({type:ne("FRAME_SESSION_UPDATE"),payload:Lu})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SUCCESS"),payload:WE})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_PRIMARY_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_PRIMARY_OTP_SUCCESS")})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SECONDARY_OTP_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_UPDATE_EMAIL_SECONDARY_OTP_SUCCESS"),payload:YE})).or(re.extend({type:ne("FRAME_SYNC_THEME_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SYNC_THEME_SUCCESS")})).or(re.extend({type:ne("FRAME_SYNC_DAPP_DATA_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SYNC_DAPP_DATA_SUCCESS")})).or(re.extend({type:ne("FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_SUCCESS"),payload:ZE})).or(re.extend({type:ne("FRAME_GET_SMART_ACCOUNT_ENABLED_NETWORKS_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_INIT_SMART_ACCOUNT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_SET_PREFERRED_ACCOUNT_SUCCESS"),payload:XE})).or(re.extend({type:ne("FRAME_SET_PREFERRED_ACCOUNT_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_READY"),payload:JE})).or(re.extend({type:ne("FRAME_RELOAD_ERROR"),payload:Qe})).or(re.extend({type:ne("FRAME_RELOAD_SUCCESS")}))};function Sc(t,e={}){var s;return typeof(e==null?void 0:e.type)=="string"&&((s=e==null?void 0:e.type)==null?void 0:s.includes(t))}function Vb({projectId:t,chainId:e,enableLogger:s,rpcUrl:n=U.BLOCKCHAIN_API_RPC_URL,enableCloudAuthAccount:r=!1}){const i=new URL(Iw);i.searchParams.set("projectId",t),i.searchParams.set("chainId",String(e)),i.searchParams.set("version",Tw),i.searchParams.set("enableLogger",String(s)),i.searchParams.set("rpcUrl",n);const o=lt.get("dapp_smart_account_version");return o&&(o==="v6"||o==="v7")&&(console.warn(">> AppKit - Forcing smart account version",o),i.searchParams.set("smartAccountVersion",o)),r&&i.searchParams.set("enableCloudAuthAccount","true"),i.toString()}class Kb{constructor({projectId:e,isAppClient:s=!1,chainId:n="eip155:1",enableLogger:r=!0,enableCloudAuthAccount:i=!1,rpcUrl:o=U.BLOCKCHAIN_API_RPC_URL}){if(this.iframe=null,this.iframeIsReady=!1,this.initFrame=()=>{const a=document.getElementById("w3m-iframe");this.iframe&&!a&&document.body.appendChild(this.iframe)},this.events={registerFrameEventHandler:(a,c,l)=>{function d({data:u}){var p;if(!Sc(oe.FRAME_EVENT_KEY,u))return;const h=Ac.frameEvent.safeParse(u);if(!h.success){console.warn("W3mFrame: invalid frame event",h.error.message);return}((p=h.data)==null?void 0:p.id)===a&&(c(h.data),window.removeEventListener("message",d))}cs.isClient&&(window.addEventListener("message",d),l.addEventListener("abort",()=>{window.removeEventListener("message",d)}))},onFrameEvent:a=>{cs.isClient&&window.addEventListener("message",({data:c})=>{if(!Sc(oe.FRAME_EVENT_KEY,c))return;const l=Ac.frameEvent.safeParse(c);l.success?a(l.data):console.warn("W3mFrame: invalid frame event",l.error.message)})},onAppEvent:a=>{cs.isClient&&window.addEventListener("message",({data:c})=>{if(!Sc(oe.APP_EVENT_KEY,c))return;const l=Ac.appEvent.safeParse(c);l.success||console.warn("W3mFrame: invalid app event",l.error.message),a(c)})},postAppEvent:a=>{var c;if(cs.isClient){if(!((c=this.iframe)!=null&&c.contentWindow))throw new Error("W3mFrame: iframe is not set");this.iframe.contentWindow.postMessage(a,"*")}},postFrameEvent:a=>{if(cs.isClient){if(!parent)throw new Error("W3mFrame: parent is not set");parent.postMessage(a,"*")}}},this.projectId=e,this.frameLoadPromise=new Promise((a,c)=>{this.frameLoadPromiseResolver={resolve:a,reject:c}}),this.rpcUrl=o,s&&(this.frameLoadPromise=new Promise((a,c)=>{this.frameLoadPromiseResolver={resolve:a,reject:c}}),cs.isClient)){const a=document.createElement("iframe");a.id="w3m-iframe",a.src=Vb({projectId:e,chainId:n,enableLogger:r,rpcUrl:this.rpcUrl,enableCloudAuthAccount:i}),a.name="w3m-secure-iframe",a.style.position="fixed",a.style.zIndex="999999",a.style.display="none",a.style.border="none",a.style.animationDelay="0s, 50ms",a.style.borderBottomLeftRadius="clamp(0px, var(--apkt-borderRadius-8), 44px)",a.style.borderBottomRightRadius="clamp(0px, var(--apkt-borderRadius-8), 44px)",this.iframe=a,this.iframe.onerror=()=>{var c;(c=this.frameLoadPromiseResolver)==null||c.reject("Unable to load email login dependency")},this.events.onFrameEvent(c=>{var l;c.type==="@w3m-frame/READY"&&(this.iframeIsReady=!0,(l=this.frameLoadPromiseResolver)==null||l.resolve(void 0))})}}get networks(){const e=["eip155:1","eip155:5","eip155:11155111","eip155:10","eip155:420","eip155:42161","eip155:421613","eip155:137","eip155:80001","eip155:42220","eip155:1313161554","eip155:1313161555","eip155:56","eip155:97","eip155:43114","eip155:43113","eip155:324","eip155:280","eip155:100","eip155:8453","eip155:84531","eip155:84532","eip155:7777777","eip155:999","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1"].map(s=>({[s]:{rpcUrl:`${this.rpcUrl}/v1/?chainId=${s}&projectId=${this.projectId}`,chainId:s}}));return Object.assign({},...e)}}var bi={exports:{}},Mu;function Gb(){if(Mu)return bi.exports;Mu=1;const t=vy();bi.exports=d;const e=T().console||{},s={mapHttpRequest:L,mapHttpResponse:L,wrapRequestSerializer:W,wrapResponseSerializer:W,wrapErrorSerializer:W,req:L,res:L,err:R,errWithCause:R};function n(w,b){return w==="silent"?1/0:b.levels.values[w]}const r=Symbol("pino.logFuncs"),i=Symbol("pino.hierarchy"),o={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function a(w,b){const I={logger:b,parent:w[i]};b[i]=I}function c(w,b,I){const O={};b.forEach(A=>{O[A]=I[A]?I[A]:e[A]||e[o[A]||"log"]||k}),w[r]=O}function l(w,b){return Array.isArray(w)?w.filter(function(O){return O!=="!stdSerializers.err"}):w===!0?Object.keys(b):!1}function d(w){w=w||{},w.browser=w.browser||{};const b=w.browser.transmit;if(b&&typeof b.send!="function")throw Error("pino: transmit option must have a send function");const I=w.browser.write||e;w.browser.write&&(w.browser.asObject=!0);const O=w.serializers||{},A=l(w.browser.serialize,O);let P=w.browser.serialize;Array.isArray(w.browser.serialize)&&w.browser.serialize.indexOf("!stdSerializers.err")>-1&&(P=!1);const B=Object.keys(w.customLevels||{}),M=["error","fatal","warn","info","debug","trace"].concat(B);typeof I=="function"&&M.forEach(function(ve){I[ve]=I}),(w.enabled===!1||w.browser.disabled)&&(w.level="silent");const ce=w.level||"info",j=Object.create(I);j.log||(j.log=k),c(j,M,I),a({},j),Object.defineProperty(j,"levelVal",{get:he}),Object.defineProperty(j,"level",{get:ge,set:Oe});const J={transmit:b,serialize:A,asObject:w.browser.asObject,asObjectBindingsOnly:w.browser.asObjectBindingsOnly,formatters:w.browser.formatters,levels:M,timestamp:D(w),messageKey:w.messageKey||"msg",onChild:w.onChild||k};j.levels=u(w),j.level=ce,j.isLevelEnabled=function(ve){return this.levels.values[ve]?this.levels.values[ve]>=this.levels.values[this.level]:!1},j.setMaxListeners=j.getMaxListeners=j.emit=j.addListener=j.on=j.prependListener=j.once=j.prependOnceListener=j.removeListener=j.removeAllListeners=j.listeners=j.listenerCount=j.eventNames=j.write=j.flush=k,j.serializers=O,j._serialize=A,j._stdErrSerialize=P,j.child=function(...ve){return ye.call(this,J,...ve)},b&&(j._logEvent=C());function he(){return n(this.level,this)}function ge(){return this._level}function Oe(ve){if(ve!=="silent"&&!this.levels.values[ve])throw Error("unknown level "+ve);this._level=ve,g(this,J,j,"error"),g(this,J,j,"fatal"),g(this,J,j,"warn"),g(this,J,j,"info"),g(this,J,j,"debug"),g(this,J,j,"trace"),B.forEach(Ve=>{g(this,J,j,Ve)})}function ye(ve,Ve,st){if(!Ve)throw new Error("missing bindings for child Pino");st=st||{},A&&Ve.serializers&&(st.serializers=Ve.serializers);const ut=st.serializers;if(A&&ut){var wt=Object.assign({},O,ut),Bs=w.browser.serialize===!0?Object.keys(wt):A;delete Ve.serializers,S([Ve],Bs,wt,this._stdErrSerialize)}function sn(Do){this._childLevel=(Do._childLevel|0)+1,this.bindings=Ve,wt&&(this.serializers=wt,this._serialize=Bs),b&&(this._logEvent=C([].concat(Do._logEvent.bindings,Ve)))}sn.prototype=this;const Ei=new sn(this);return a(this,Ei),Ei.child=function(...Do){return ye.call(this,ve,...Do)},Ei.level=st.level||this.level,ve.onChild(Ei),Ei}return j}function u(w){const b=w.customLevels||{},I=Object.assign({},d.levels.values,b),O=Object.assign({},d.levels.labels,h(b));return{values:I,labels:O}}function h(w){const b={};return Object.keys(w).forEach(function(I){b[w[I]]=I}),b}d.levels={values:{fatal:60,error:50,warn:40,info:30,debug:20,trace:10},labels:{10:"trace",20:"debug",30:"info",40:"warn",50:"error",60:"fatal"}},d.stdSerializers=s,d.stdTimeFunctions=Object.assign({},{nullTime:q,epochTime:V,unixTime:x,isoTime:N});function p(w){const b=[];w.bindings&&b.push(w.bindings);let I=w[i];for(;I.parent;)I=I.parent,I.logger.bindings&&b.push(I.logger.bindings);return b.reverse()}function g(w,b,I,O){if(Object.defineProperty(w,O,{value:n(w.level,I)>n(O,I)?k:I[r][O],writable:!0,enumerable:!0,configurable:!0}),w[O]===k){if(!b.transmit)return;const P=b.transmit.level||w.level,B=n(P,I);if(n(O,I)<B)return}w[O]=y(w,b,I,O);const A=p(w);A.length!==0&&(w[O]=f(A,w[O]))}function f(w,b){return function(){return b.apply(this,[...w,...arguments])}}function y(w,b,I,O){return function(A){return function(){const B=b.timestamp(),M=new Array(arguments.length),ce=Object.getPrototypeOf&&Object.getPrototypeOf(this)===e?e:this;for(var j=0;j<M.length;j++)M[j]=arguments[j];var J=!1;if(b.serialize&&(S(M,this._serialize,this.serializers,this._stdErrSerialize),J=!0),b.asObject||b.formatters?A.call(ce,..._(this,O,M,B,b)):A.apply(ce,M),b.transmit){const he=b.transmit.level||w._level,ge=n(he,I),Oe=n(O,I);if(Oe<ge)return;v(this,{ts:B,methodLevel:O,methodValue:Oe,transmitValue:I.levels.values[b.transmit.level||w._level],send:b.transmit.send,val:n(w._level,I)},M,J)}}}(w[r][O])}function _(w,b,I,O,A){const{level:P,log:B=he=>he}=A.formatters||{},M=I.slice();let ce=M[0];const j={};let J=(w._childLevel|0)+1;if(J<1&&(J=1),O&&(j.time=O),P){const he=P(b,w.levels.values[b]);Object.assign(j,he)}else j.level=w.levels.values[b];if(A.asObjectBindingsOnly){if(ce!==null&&typeof ce=="object")for(;J--&&typeof M[0]=="object";)Object.assign(j,M.shift());return[B(j),...M]}else{if(ce!==null&&typeof ce=="object"){for(;J--&&typeof M[0]=="object";)Object.assign(j,M.shift());ce=M.length?t(M.shift(),M):void 0}else typeof ce=="string"&&(ce=t(M.shift(),M));return ce!==void 0&&(j[A.messageKey]=ce),[B(j)]}}function S(w,b,I,O){for(const A in w)if(O&&w[A]instanceof Error)w[A]=d.stdSerializers.err(w[A]);else if(typeof w[A]=="object"&&!Array.isArray(w[A])&&b)for(const P in w[A])b.indexOf(P)>-1&&P in I&&(w[A][P]=I[P](w[A][P]))}function v(w,b,I,O=!1){const A=b.send,P=b.ts,B=b.methodLevel,M=b.methodValue,ce=b.val,j=w._logEvent.bindings;O||S(I,w._serialize||Object.keys(w.serializers),w.serializers,w._stdErrSerialize===void 0?!0:w._stdErrSerialize),w._logEvent.ts=P,w._logEvent.messages=I.filter(function(J){return j.indexOf(J)===-1}),w._logEvent.level.label=B,w._logEvent.level.value=M,A(B,w._logEvent,ce),w._logEvent=C(j)}function C(w){return{ts:0,messages:[],bindings:w||[],level:{label:"",value:0}}}function R(w){const b={type:w.constructor.name,msg:w.message,stack:w.stack};for(const I in w)b[I]===void 0&&(b[I]=w[I]);return b}function D(w){return typeof w.timestamp=="function"?w.timestamp:w.timestamp===!1?q:V}function L(){return{}}function W(w){return w}function k(){}function q(){return!1}function V(){return Date.now()}function x(){return Math.round(Date.now()/1e3)}function N(){return new Date(Date.now()).toISOString()}function T(){function w(b){return typeof b<"u"&&b}try{return typeof globalThis<"u"||Object.defineProperty(Object.prototype,"globalThis",{get:function(){return delete Object.prototype.globalThis,this.globalThis=this},configurable:!0}),globalThis}catch{return w(self)||w(window)||w(this)||{}}}return bi.exports.default=d,bi.exports.pino=d,bi.exports}var Kr=Gb();const qf=Cy(Kr),Yb={level:"info"},rc="custom_context",Nd=1e3*1024;var Zb=Object.defineProperty,Jb=(t,e,s)=>e in t?Zb(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,jn=(t,e,s)=>Jb(t,typeof e!="symbol"?e+"":e,s);let Xb=class{constructor(e){jn(this,"nodeValue"),jn(this,"sizeInBytes"),jn(this,"next"),this.nodeValue=e,this.sizeInBytes=new TextEncoder().encode(this.nodeValue).length,this.next=null}get value(){return this.nodeValue}get size(){return this.sizeInBytes}},Bu=class{constructor(e){jn(this,"lengthInNodes"),jn(this,"sizeInBytes"),jn(this,"head"),jn(this,"tail"),jn(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new Xb(e);if(s.size>this.maxSizeInBytes)throw new Error(`[LinkedList] Value too big to insert into list: ${e} with size ${s.size}`);for(;this.size+s.size>this.maxSizeInBytes;)this.shift();this.head?(this.tail&&(this.tail.next=s),this.tail=s):(this.head=s,this.tail=s),this.lengthInNodes++,this.sizeInBytes+=s.size}shift(){if(!this.head)return;const e=this.head;this.head=this.head.next,this.head||(this.tail=null),this.lengthInNodes--,this.sizeInBytes-=e.size}toArray(){const e=[];let s=this.head;for(;s!==null;)e.push(s.value),s=s.next;return e}get length(){return this.lengthInNodes}get size(){return this.sizeInBytes}toOrderedArray(){return Array.from(this)}[Symbol.iterator](){let e=this.head;return{next:()=>{if(!e)return{done:!0,value:null};const s=e.value;return e=e.next,{done:!1,value:s}}}}};var Qb=Object.defineProperty,ev=(t,e,s)=>e in t?Qb(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,qo=(t,e,s)=>ev(t,typeof e!="symbol"?e+"":e,s);let Wf=class{constructor(e,s=Nd){qo(this,"logs"),qo(this,"level"),qo(this,"levelValue"),qo(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Kr.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Bu(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Kr.levels.values.error?console.error(e):s===Kr.levels.values.warn?console.warn(e):s===Kr.levels.values.debug?console.debug(e):s===Kr.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Gi({timestamp:new Date().toISOString(),log:e}));const s=typeof e=="string"?JSON.parse(e).level:e.level;s>=this.levelValue&&this.forwardToConsole(e,s)}getLogs(){return this.logs}clearLogs(){this.logs=new Bu(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Gi({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var tv=Object.defineProperty,sv=(t,e,s)=>e in t?tv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,nv=(t,e,s)=>sv(t,e+"",s);let rv=class{constructor(e,s=Nd){nv(this,"baseChunkLogger"),this.baseChunkLogger=new Wf(e,s)}write(e){this.baseChunkLogger.appendToLogs(e)}getLogs(){return this.baseChunkLogger.getLogs()}clearLogs(){this.baseChunkLogger.clearLogs()}getLogArray(){return this.baseChunkLogger.getLogArray()}logsToBlob(e){return this.baseChunkLogger.logsToBlob(e)}downloadLogsBlobInBrowser(e){const s=URL.createObjectURL(this.logsToBlob(e)),n=document.createElement("a");n.href=s,n.download=`walletconnect-logs-${new Date().toISOString()}.txt`,document.body.appendChild(n),n.click(),document.body.removeChild(n),URL.revokeObjectURL(s)}};var iv=Object.defineProperty,ov=(t,e,s)=>e in t?iv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,av=(t,e,s)=>ov(t,e+"",s);let cv=class{constructor(e,s=Nd){av(this,"baseChunkLogger"),this.baseChunkLogger=new Wf(e,s)}write(e){this.baseChunkLogger.appendToLogs(e)}getLogs(){return this.baseChunkLogger.getLogs()}clearLogs(){this.baseChunkLogger.clearLogs()}getLogArray(){return this.baseChunkLogger.getLogArray()}logsToBlob(e){return this.baseChunkLogger.logsToBlob(e)}};var lv=Object.defineProperty,dv=Object.defineProperties,uv=Object.getOwnPropertyDescriptors,ju=Object.getOwnPropertySymbols,hv=Object.prototype.hasOwnProperty,pv=Object.prototype.propertyIsEnumerable,Fu=(t,e,s)=>e in t?lv(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ka=(t,e)=>{for(var s in e||(e={}))hv.call(e,s)&&Fu(t,s,e[s]);if(ju)for(var s of ju(e))pv.call(e,s)&&Fu(t,s,e[s]);return t},Ua=(t,e)=>dv(t,uv(e));function Td(t){return Ua(ka({},t),{level:(t==null?void 0:t.level)||Yb.level})}function fv(t,e,s=rc){return t[s]=e,t}function es(t,e=rc){return t[e]||""}function gv(t,e,s=rc){const n=es(t,s);return n.trim()?`${n}/${e}`:e}function ts(t,e,s=rc){const n=gv(t,e,s),r=t.child({context:n});return fv(r,n,s)}function mv(t){var e,s;const n=new rv((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:qf(Ua(ka({},t.opts),{level:"trace",browser:Ua(ka({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function yv(t){var e;const s=new cv((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:qf(Ua(ka({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function ic(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?mv(t):yv(t)}class wv{constructor(e){var i;const s=Td({level:Nw}),{logger:n,chunkLoggerController:r}=ic({opts:s});this.logger=ts(n,this.constructor.name),this.chunkLoggerController=r,typeof window<"u"&&((i=this.chunkLoggerController)!=null&&i.downloadLogsBlobInBrowser)&&(window.downloadAppKitLogsBlob||(window.downloadAppKitLogsBlob={}),window.downloadAppKitLogsBlob.sdk=()=>{var o;(o=this.chunkLoggerController)!=null&&o.downloadLogsBlobInBrowser&&this.chunkLoggerController.downloadLogsBlobInBrowser({projectId:e})})}}class Ev{constructor({projectId:e,chainId:s,enableLogger:n=!0,onTimeout:r,abortController:i,getActiveCaipNetwork:o,getCaipNetworks:a,enableCloudAuthAccount:c,metadata:l,sdkVersion:d,sdkType:u}){this.openRpcRequests=new Map,this.isInitialized=!1,n&&(this.w3mLogger=new wv(e)),this.abortController=i,this.getActiveCaipNetwork=o,this.getCaipNetworks=a;const h=this.getRpcUrl(s);this.projectId=e,this.sdkVersion=d,this.sdkType=u,this.metadata=l,this.w3mFrame=new Kb({projectId:e,isAppClient:!0,chainId:s,enableLogger:n,rpcUrl:h,enableCloudAuthAccount:c}),this.onTimeout=r,this.getLoginEmailUsed()&&this.createFrame()}async createFrame(){this.w3mFrame.initFrame(),this.initPromise=new Promise(e=>{this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_READY&&setTimeout(()=>{e()},500)})}),await this.initPromise,await this.syncDappData({metadata:this.metadata,projectId:this.projectId,sdkVersion:this.sdkVersion,sdkType:this.sdkType}),await this.getSmartAccountEnabledNetworks(),this.isInitialized=!0,this.initPromise=void 0}async init(){if(!this.isInitialized){if(this.initPromise){await this.initPromise;return}await this.createFrame()}}getLoginEmailUsed(){return!!lt.get(oe.EMAIL_LOGIN_USED_KEY)}getEmail(){return lt.get(oe.EMAIL)}getUsername(){return lt.get(oe.SOCIAL_USERNAME)}async reload(){var e;try{await this.appEvent({type:oe.APP_RELOAD})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error reloading iframe"),s}}async connectEmail(e){var s;try{cs.checkIfAllowedToTriggerEmail(),await this.init();const n=await this.appEvent({type:oe.APP_CONNECT_EMAIL,payload:e});return this.setNewLastEmailLoginTime(),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting email"),n}}async connectDevice(){var e;try{return this.appEvent({type:oe.APP_CONNECT_DEVICE})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error connecting device"),s}}async connectOtp(e){var s;try{return this.appEvent({type:oe.APP_CONNECT_OTP,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting otp"),n}}async isConnected(){var e;try{if(!this.getLoginEmailUsed())return{isConnected:!1};const s=await this.appEvent({type:oe.APP_IS_CONNECTED});return s!=null&&s.isConnected||this.deleteAuthLoginCache(),s}catch(s){throw this.deleteAuthLoginCache(),(e=this.w3mLogger)==null||e.logger.error({error:s},"Error checking connection"),s}}async getChainId(){var e;try{const s=await this.appEvent({type:oe.APP_GET_CHAIN_ID});return this.setLastUsedChainId(s.chainId),s}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting chain id"),s}}async getSocialRedirectUri(e){var s;try{return await this.init(),this.appEvent({type:oe.APP_GET_SOCIAL_REDIRECT_URI,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error getting social redirect uri"),n}}async updateEmail(e){var s;try{const n=await this.appEvent({type:oe.APP_UPDATE_EMAIL,payload:e});return this.setNewLastEmailLoginTime(),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email"),n}}async updateEmailPrimaryOtp(e){var s;try{return this.appEvent({type:oe.APP_UPDATE_EMAIL_PRIMARY_OTP,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email primary otp"),n}}async updateEmailSecondaryOtp(e){var s;try{const n=await this.appEvent({type:oe.APP_UPDATE_EMAIL_SECONDARY_OTP,payload:e});return this.setLoginSuccess(n.newEmail),n}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error updating email secondary otp"),n}}async syncTheme(e){var s;try{return this.appEvent({type:oe.APP_SYNC_THEME,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error syncing theme"),n}}async syncDappData(e){var s;try{return this.appEvent({type:oe.APP_SYNC_DAPP_DATA,payload:e})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error syncing dapp data"),n}}async getSmartAccountEnabledNetworks(){var e;try{const s=await this.appEvent({type:oe.APP_GET_SMART_ACCOUNT_ENABLED_NETWORKS});return this.persistSmartAccountEnabledNetworks(s.smartAccountEnabledNetworks),s}catch(s){throw this.persistSmartAccountEnabledNetworks([]),(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting smart account enabled networks"),s}}async setPreferredAccount(e){var s;try{return this.appEvent({type:oe.APP_SET_PREFERRED_ACCOUNT,payload:{type:e}})}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error setting preferred account"),n}}async connect(e){var s,n;if(e!=null&&e.socialUri)try{await this.init();const r=this.getRpcUrl(e.chainId),i=await this.appEvent({type:oe.APP_CONNECT_SOCIAL,payload:{uri:e.socialUri,preferredAccountType:e.preferredAccountType,chainId:e.chainId,siwxMessage:e.siwxMessage,rpcUrl:r}});return i.userName&&this.setSocialLoginSuccess(i.userName),this.setLoginSuccess(i.email),this.setLastUsedChainId(i.chainId),this.user=i,i}catch(r){throw(s=this.w3mLogger)==null||s.logger.error({error:r},"Error connecting social"),r}else try{const r=(e==null?void 0:e.chainId)||this.getLastUsedChainId()||1,i=await this.getUser({chainId:r,preferredAccountType:e==null?void 0:e.preferredAccountType,siwxMessage:e==null?void 0:e.siwxMessage,rpcUrl:this.getRpcUrl(r)});return this.setLoginSuccess(i.email),this.setLastUsedChainId(i.chainId),this.user=i,i}catch(r){throw(n=this.w3mLogger)==null||n.logger.error({error:r},"Error connecting"),r}}async getUser(e){var s;try{await this.init();const n=(e==null?void 0:e.chainId)||this.getLastUsedChainId()||1,r=await this.appEvent({type:oe.APP_GET_USER,payload:{...e,chainId:n,rpcUrl:this.getRpcUrl(n)}});return this.user=r,r}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error connecting"),n}}async connectSocial({uri:e,chainId:s,preferredAccountType:n}){var r;try{await this.init();const i=this.getRpcUrl(s),o=await this.appEvent({type:oe.APP_CONNECT_SOCIAL,payload:{uri:e,chainId:s,rpcUrl:i,preferredAccountType:n}});return o.userName&&this.setSocialLoginSuccess(o.userName),o}catch(i){throw(r=this.w3mLogger)==null||r.logger.error({error:i},"Error connecting social"),i}}async getFarcasterUri(){var e;try{return await this.init(),await this.appEvent({type:oe.APP_GET_FARCASTER_URI})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error getting farcaster uri"),s}}async connectFarcaster(){var e;try{const s=await this.appEvent({type:oe.APP_CONNECT_FARCASTER});return s.userName&&this.setSocialLoginSuccess(s.userName),s}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error connecting farcaster"),s}}async switchNetwork({chainId:e}){var s;try{const n=this.getRpcUrl(e),r=await this.appEvent({type:oe.APP_SWITCH_NETWORK,payload:{chainId:e,rpcUrl:n}});return this.setLastUsedChainId(r.chainId),r}catch(n){throw(s=this.w3mLogger)==null||s.logger.error({error:n},"Error switching network"),n}}async disconnect(){var e;try{return this.deleteAuthLoginCache(),await new Promise(async n=>{const r=setTimeout(()=>{n()},3e3);await this.appEvent({type:oe.APP_SIGN_OUT}),clearTimeout(r),n()})}catch(s){throw(e=this.w3mLogger)==null||e.logger.error({error:s},"Error disconnecting"),s}}async request(e){var n,r,i,o,a;const s=e;try{if(tt.GET_CHAIN_ID===e.method)return this.getLastUsedChainId();const c=e.chainNamespace||"eip155",l=(n=this.getActiveCaipNetwork(c))==null?void 0:n.id;s.chainNamespace=c,s.chainId=l,s.rpcUrl=this.getRpcUrl(l),(r=this.rpcRequestHandler)==null||r.call(this,e);const d=await this.appEvent({type:oe.APP_RPC_REQUEST,payload:s});return(i=this.rpcSuccessHandler)==null||i.call(this,d,s),d}catch(c){throw(o=this.rpcErrorHandler)==null||o.call(this,c,s),(a=this.w3mLogger)==null||a.logger.error({error:c},"Error requesting"),c}}onRpcRequest(e){this.rpcRequestHandler=e}onRpcSuccess(e){this.rpcSuccessHandler=e}onRpcError(e){this.rpcErrorHandler=e}onIsConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_IS_CONNECTED_SUCCESS&&s.payload.isConnected&&e()})}onNotConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_IS_CONNECTED_ERROR&&e(),s.type===oe.FRAME_IS_CONNECTED_SUCCESS&&!s.payload.isConnected&&e()})}onConnect(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_GET_USER_SUCCESS&&e(s.payload)})}onSocialConnected(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_CONNECT_SOCIAL_SUCCESS&&e(s.payload)})}async getCapabilities(){try{return await this.request({method:"wallet_getCapabilities"})||{}}catch{return{}}}onSetPreferredAccount(e){this.w3mFrame.events.onFrameEvent(s=>{s.type===oe.FRAME_SET_PREFERRED_ACCOUNT_SUCCESS?e(s.payload):s.type===oe.FRAME_SET_PREFERRED_ACCOUNT_ERROR&&e({type:tt.ACCOUNT_TYPES.EOA})})}getAvailableChainIds(){return Object.keys(this.w3mFrame.networks)}async rejectRpcRequests(){var e;try{await Promise.all(Array.from(this.openRpcRequests.values()).map(async({abortController:s,method:n})=>{tt.SAFE_RPC_METHODS.includes(n)||s.abort(),await this.appEvent({type:oe.APP_RPC_ABORT})})),this.openRpcRequests.clear()}catch(s){(e=this.w3mLogger)==null||e.logger.error({error:s},"Error aborting RPC request")}}async appEvent(e){let s,n;function r(c){return c.replace("@w3m-app/","")}const i=[oe.APP_SYNC_DAPP_DATA,oe.APP_SYNC_THEME,oe.APP_SET_PREFERRED_ACCOUNT],o=r(e.type);return!this.w3mFrame.iframeIsReady&&!i.includes(e.type)&&(n=setTimeout(()=>{var c;(c=this.onTimeout)==null||c.call(this,"iframe_load_failed"),this.abortController.abort()},2e4)),await this.w3mFrame.frameLoadPromise,clearTimeout(n),[oe.APP_CONNECT_EMAIL,oe.APP_CONNECT_DEVICE,oe.APP_CONNECT_OTP,oe.APP_CONNECT_SOCIAL,oe.APP_GET_SOCIAL_REDIRECT_URI].map(r).includes(o)&&(s=setTimeout(()=>{var c;(c=this.onTimeout)==null||c.call(this,"iframe_request_timeout"),this.abortController.abort()},12e4)),new Promise((c,l)=>{var p,g,f;const d=Math.random().toString(36).substring(7);(f=(p=this.w3mLogger)==null?void 0:(g=p.logger).info)==null||f.call(g,{event:e,id:d},"Sending app event"),this.w3mFrame.events.postAppEvent({...e,id:d});const u=new AbortController;if(o==="RPC_REQUEST"){const y=e;this.openRpcRequests.set(d,{...y.payload,abortController:u})}u.signal.addEventListener("abort",()=>{o==="RPC_REQUEST"?l(new Error("Request was aborted")):o!=="GET_FARCASTER_URI"&&l(new Error("Something went wrong"))});const h=(y,_)=>{var S,v,C;y.id===d&&((v=_==null?void 0:(S=_.logger).info)==null||v.call(S,{framEvent:y,id:d},"Received frame response"),this.openRpcRequests.delete(y.id),y.type===`@w3m-frame/${o}_SUCCESS`?(s&&clearTimeout(s),n&&clearTimeout(n),"payload"in y&&c(y.payload),c(void 0)):y.type===`@w3m-frame/${o}_ERROR`&&(s&&clearTimeout(s),n&&clearTimeout(n),"payload"in y&&l(new Error(((C=y.payload)==null?void 0:C.message)||"An error occurred")),l(new Error("An error occurred"))))};this.w3mFrame.events.registerFrameEventHandler(d,y=>h(y,this.w3mLogger),this.abortController.signal)})}setNewLastEmailLoginTime(){lt.set(oe.LAST_EMAIL_LOGIN_TIME,Date.now().toString())}setSocialLoginSuccess(e){lt.set(oe.SOCIAL_USERNAME,e)}setLoginSuccess(e){e&<.set(oe.EMAIL,e),lt.set(oe.EMAIL_LOGIN_USED_KEY,"true"),lt.delete(oe.LAST_EMAIL_LOGIN_TIME)}deleteAuthLoginCache(){lt.delete(oe.EMAIL_LOGIN_USED_KEY),lt.delete(oe.EMAIL),lt.delete(oe.LAST_USED_CHAIN_KEY),lt.delete(oe.SOCIAL_USERNAME)}setLastUsedChainId(e){e&<.set(oe.LAST_USED_CHAIN_KEY,String(e))}getLastUsedChainId(){const e=lt.get(oe.LAST_USED_CHAIN_KEY)??void 0,s=Number(e);return isNaN(s)?e:s}persistSmartAccountEnabledNetworks(e){lt.set(oe.SMART_ACCOUNT_ENABLED_NETWORKS,e.join(","))}getRpcUrl(e){var i,o;let s=e===void 0?void 0:"eip155";typeof e=="string"&&(e.includes(":")?s=(i=dt.parseCaipNetworkId(e))==null?void 0:i.chainNamespace:Number.isInteger(Number(e))?s="eip155":s="solana");const n=this.getCaipNetworks(s),r=e?n.find(a=>String(a.id)===String(e)||a.caipNetworkId===e):n[0];return(o=r==null?void 0:r.rpcUrls.default.http)==null?void 0:o[0]}}async function Hf(t){return new Promise(e=>setTimeout(e,t))}function bv(t,{delay:e=100,retryCount:s=2,shouldRetry:n=()=>!0}={}){return new Promise((r,i)=>{const o=async({count:a=0}={})=>{const c=async({error:l})=>{const d=typeof e=="function"?e({count:a,error:l}):e;d&&await Hf(d),o({count:a+1})};try{const l=await t();r(l)}catch(l){if(a<s&&await n({count:a,error:l}))return c({error:l});i(l)}};o()})}const Rl=256;let Wo=Rl,Ho;function vv(t=11){if(!Ho||Wo+t>Rl*2){Ho="",Wo=0;for(let e=0;e<Rl;e++)Ho+=(256+Math.random()*256|0).toString(16).substring(1)}return Ho.substring(Wo,Wo+++t)}const zo=new My(8192);function Cv(t,{enabled:e=!0,id:s}){if(!e||!s)return t();if(zo.get(s))return zo.get(s);const n=t().finally(()=>zo.delete(s));return zo.set(s,n),n}function _v(t,e={}){return async(s,n={})=>{var u;const{dedupe:r=!1,methods:i,retryDelay:o=150,retryCount:a=3,uid:c}={...e,...n},{method:l}=s;if((u=i==null?void 0:i.exclude)!=null&&u.includes(l))throw new Mo(new Error("method not supported"),{method:l});if(i!=null&&i.include&&!i.include.includes(l))throw new Mo(new Error("method not supported"),{method:l});const d=r?By(`${c}.${la(s)}`):void 0;return Cv(()=>bv(async()=>{try{return await t(s)}catch(h){const p=h;switch(p.code){case Iu.code:throw new Iu(p);case Su.code:throw new Su(p);case Au.code:throw new Au(p,{method:s.method});case _u.code:throw new _u(p);case Cl.code:throw new Cl(p);case Cu.code:throw new Cu(p);case vu.code:throw new vu(p);case bu.code:throw new bu(p);case vl.code:throw new vl(p);case Mo.code:throw new Mo(p,{method:s.method});case bl.code:throw new bl(p);case Eu.code:throw new Eu(p);case da.code:throw new da(p);case wu.code:throw new wu(p);case yu.code:throw new yu(p);case mu.code:throw new mu(p);case gu.code:throw new gu(p);case fu.code:throw new fu(p);case pu.code:throw new pu(p);case hu.code:throw new hu(p);case uu.code:throw new uu(p);case du.code:throw new du(p);case lu.code:throw new lu(p);case cu.code:throw new cu(p);case au.code:throw new au(p);case 5e3:throw new da(p);default:throw h instanceof Af?h:new jy(p)}}},{delay:({count:h,error:p})=>{var g;if(p&&p instanceof Bi){const f=(g=p==null?void 0:p.headers)==null?void 0:g.get("Retry-After");if(f!=null&&f.match(/\d/))return Number.parseInt(f,10)*1e3}return~~(1<<h)*o},retryCount:a,shouldRetry:({error:h})=>Av(h)}),{enabled:r,id:d})}}function Av(t){return"code"in t&&typeof t.code=="number"?t.code===-1||t.code===bl.code||t.code===Cl.code:t instanceof Bi&&t.status?t.status===403||t.status===408||t.status===413||t.status===429||t.status===500||t.status===502||t.status===503||t.status===504:!0}function Sv(t,{errorInstance:e=new Error("timed out"),timeout:s,signal:n}){return new Promise((r,i)=>{(async()=>{let o;try{const a=new AbortController;s>0&&(o=setTimeout(()=>{n&&a.abort()},s)),r(await t({signal:(a==null?void 0:a.signal)||null}))}catch(a){(a==null?void 0:a.name)==="AbortError"&&i(e),i(a)}finally{clearTimeout(o)}})()})}function Iv(){return{current:0,take(){return this.current++},reset(){this.current=0}}}const qu=Iv();function Nv(t,e={}){return{async request(s){var h;const{body:n,fetchFn:r=e.fetchFn??fetch,onRequest:i=e.onRequest,onResponse:o=e.onResponse,timeout:a=e.timeout??1e4}=s,c={...e.fetchOptions??{},...s.fetchOptions??{}},{headers:l,method:d,signal:u}=c;try{const p=await Sv(async({signal:f})=>{const y={...c,body:Array.isArray(n)?la(n.map(C=>({jsonrpc:"2.0",id:C.id??qu.take(),...C}))):la({jsonrpc:"2.0",id:n.id??qu.take(),...n}),headers:{"Content-Type":"application/json",...l},method:d||"POST",signal:u||(a>0?f:null)},_=new Request(t,y),S=await(i==null?void 0:i(_,y))??{...y,url:t};return await r(S.url??t,S)},{errorInstance:new Nu({body:n,url:t}),timeout:a,signal:!0});o&&await o(p);let g;if((h=p.headers.get("Content-Type"))!=null&&h.startsWith("application/json"))g=await p.json();else{g=await p.text();try{g=JSON.parse(g||"{}")}catch(f){if(p.ok)throw f;g={error:g}}}if(!p.ok)throw new Bi({body:n,details:la(g.error)||p.statusText,headers:p.headers,status:p.status,url:t});return g}catch(p){throw p instanceof Bi||p instanceof Nu?p:new Bi({body:n,cause:p,url:t})}}}}function zf({key:t,methods:e,name:s,request:n,retryCount:r=3,retryDelay:i=150,timeout:o,type:a},c){const l=vv();return{config:{key:t,methods:e,name:s,request:n,retryCount:r,retryDelay:i,timeout:o,type:a},request:_v(n,{methods:e,retryCount:r,retryDelay:i,uid:l}),value:c}}function Wu(t,e={}){const{key:s="fallback",name:n="Fallback",rank:r=!1,shouldThrow:i=Tv,retryCount:o,retryDelay:a}=e;return({chain:c,pollingInterval:l=4e3,timeout:d,...u})=>{let h=t,p=()=>{};const g=zf({key:s,name:n,async request({method:f,params:y}){let _;const S=async(v=0)=>{const C=h[v]({...u,chain:c,retryCount:0,timeout:d});try{const R=await C.request({method:f,params:y});return p({method:f,params:y,response:R,transport:C,status:"success"}),R}catch(R){if(p({error:R,method:f,params:y,transport:C,status:"error"}),i(R)||v===h.length-1||(_??(_=h.slice(v+1).some(D=>{const{include:L,exclude:W}=D({chain:c}).config.methods||{};return L?L.includes(f):W?!W.includes(f):!0})),!_))throw R;return S(v+1)}};return S()},retryCount:o,retryDelay:a,type:"fallback"},{onResponse:f=>p=f,transports:h.map(f=>f({chain:c,retryCount:0}))});if(r){const f=typeof r=="object"?r:{};Rv({chain:c,interval:f.interval??l,onTransports:y=>h=y,ping:f.ping,sampleCount:f.sampleCount,timeout:f.timeout,transports:h,weights:f.weights})}return g}}function Tv(t){return!!("code"in t&&typeof t.code=="number"&&(t.code===vl.code||t.code===da.code||Fy.nodeMessage.test(t.message)||t.code===5e3))}function Rv({chain:t,interval:e=4e3,onTransports:s,ping:n,sampleCount:r=10,timeout:i=1e3,transports:o,weights:a={}}){const{stability:c=.7,latency:l=.3}=a,d=[],u=async()=>{const h=await Promise.all(o.map(async f=>{const y=f({chain:t,retryCount:0,timeout:i}),_=Date.now();let S,v;try{await(n?n({transport:y}):y.request({method:"net_listening"})),v=1}catch{v=0}finally{S=Date.now()}return{latency:S-_,success:v}}));d.push(h),d.length>r&&d.shift();const p=Math.max(...d.map(f=>Math.max(...f.map(({latency:y})=>y)))),g=o.map((f,y)=>{const _=d.map(D=>D[y].latency),v=1-_.reduce((D,L)=>D+L,0)/_.length/p,C=d.map(D=>D[y].success),R=C.reduce((D,L)=>D+L,0)/C.length;return R===0?[0,y]:[l*v+c*R,y]}).sort((f,y)=>y[0]-f[0]);s(g.map(([,f])=>o[f])),await Hf(e),u()};u()}class Ov extends Af{constructor(){super("No URL was provided to the Transport. Please provide a valid RPC URL to the Transport.",{docsPath:"/docs/clients/intro",name:"UrlRequiredError"})}}function Vo(t,e={}){const{batch:s,fetchFn:n,fetchOptions:r,key:i="http",methods:o,name:a="HTTP JSON-RPC",onFetchRequest:c,onFetchResponse:l,retryDelay:d,raw:u}=e;return({chain:h,retryCount:p,timeout:g})=>{const{batchSize:f=1e3,wait:y=0}=typeof s=="object"?s:{},_=e.retryCount??p,S=g??e.timeout??1e4,v=t||(h==null?void 0:h.rpcUrls.default.http[0]);if(!v)throw new Ov;const C=Nv(v,{fetchFn:n,fetchOptions:r,onRequest:c,onResponse:l,timeout:S});return zf({key:i,methods:o,name:a,async request({method:R,params:D}){const L={method:R,params:D},{schedule:W}=qy({id:v,wait:y,shouldSplitBatch(x){return x.length>f},fn:x=>C.request({body:x}),sort:(x,N)=>x.id-N.id}),k=async x=>s?W(x):[await C.request({body:x})],[{error:q,result:V}]=await k(L);if(u)return{error:q,result:V};if(q)throw new Wy({body:L,error:q,url:v});return V},retryCount:_,retryDelay:d,timeout:S,type:"http"},{fetchOptions:r,url:v})}}async function vi(...t){const e=await fetch(...t);if(!e.ok)throw new Error(`HTTP status code: ${e.status}`,{cause:e});return e}class So{constructor({baseUrl:e,clientId:s}){this.baseUrl=e,this.clientId=s}async get({headers:e,signal:s,cache:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"GET",headers:e,signal:s,cache:n})).json()}async getBlob({headers:e,signal:s,...n}){const r=this.createUrl(n);return(await vi(r,{method:"GET",headers:e,signal:s})).blob()}async post({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"POST",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}async put({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"PUT",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}async delete({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await vi(i,{method:"DELETE",headers:s,body:e?JSON.stringify(e):void 0,signal:n})).json()}createUrl({path:e,params:s}){const n=new URL(e,this.baseUrl);return s&&Object.entries(s).forEach(([r,i])=>{i&&n.searchParams.append(r,i)}),this.clientId&&n.searchParams.append("clientId",this.clientId),n}sendBeacon({body:e,...s}){const n=this.createUrl(s);return navigator.sendBeacon(n.toString(),e?JSON.stringify(e):void 0)}}const Ol={getFeatureValue(t,e){const s=e==null?void 0:e[t];return s===void 0?Ie.DEFAULT_FEATURES[t]:s},filterSocialsByPlatform(t){if(!t||!t.length)return t;let e=t;return X.isTelegram()&&(X.isIos()&&(e=e.filter(s=>s!=="google")),X.isMac()&&(e=e.filter(s=>s!=="x")),X.isAndroid()&&(e=e.filter(s=>!["facebook","x"].includes(s)))),X.isMobile()&&(e=e.filter(s=>s!=="facebook")),e},isSocialsEnabled(){var t,e,s,n;return Array.isArray((t=$.state.features)==null?void 0:t.socials)&&((e=$.state.features)==null?void 0:e.socials.length)>0||Array.isArray((s=$.state.remoteFeatures)==null?void 0:s.socials)&&((n=$.state.remoteFeatures)==null?void 0:n.socials.length)>0},isEmailEnabled(){var t,e;return!!((t=$.state.features)!=null&&t.email||(e=$.state.remoteFeatures)!=null&&e.email)}},de=Ge({features:Ie.DEFAULT_FEATURES,projectId:"",sdkType:"appkit",sdkVersion:"html-wagmi-undefined",defaultAccountTypes:Ie.DEFAULT_ACCOUNT_TYPES,enableNetworkSwitch:!0,experimental_preferUniversalLinks:!1,remoteFeatures:{},enableMobileFullScreen:!1,coinbasePreference:"all"}),$={state:de,subscribeKey(t,e){return At(de,t,e)},setOptions(t){Object.assign(de,t)},setRemoteFeatures(t){var s,n;if(!t)return;const e={...de.remoteFeatures,...t};de.remoteFeatures=e,(s=de.remoteFeatures)!=null&&s.socials&&(de.remoteFeatures.socials=Ol.filterSocialsByPlatform(de.remoteFeatures.socials)),(n=de.features)!=null&&n.pay&&(de.remoteFeatures.email=!1,de.remoteFeatures.socials=!1)},setFeatures(t){var s;if(!t)return;de.features||(de.features=Ie.DEFAULT_FEATURES);const e={...de.features,...t};de.features=e,(s=de.features)!=null&&s.pay&&de.remoteFeatures&&(de.remoteFeatures.email=!1,de.remoteFeatures.socials=!1)},setProjectId(t){de.projectId=t},setCustomRpcUrls(t){de.customRpcUrls=t},setAllWallets(t){de.allWallets=t},setIncludeWalletIds(t){de.includeWalletIds=t},setExcludeWalletIds(t){de.excludeWalletIds=t},setFeaturedWalletIds(t){de.featuredWalletIds=t},setTokens(t){de.tokens=t},setTermsConditionsUrl(t){de.termsConditionsUrl=t},setPrivacyPolicyUrl(t){de.privacyPolicyUrl=t},setCustomWallets(t){de.customWallets=t},setIsSiweEnabled(t){de.isSiweEnabled=t},setIsUniversalProvider(t){de.isUniversalProvider=t},setSdkVersion(t){de.sdkVersion=t},setMetadata(t){de.metadata=t},setDisableAppend(t){de.disableAppend=t},setEIP6963Enabled(t){de.enableEIP6963=t},setDebug(t){de.debug=t},setEnableWalletGuide(t){de.enableWalletGuide=t},setEnableAuthLogger(t){de.enableAuthLogger=t},setEnableWallets(t){de.enableWallets=t},setPreferUniversalLinks(t){de.experimental_preferUniversalLinks=t},setSIWX(t){if(t)for(const[e,s]of Object.entries(Ie.SIWX_DEFAULTS))t[e]??(t[e]=s);de.siwx=t},setConnectMethodsOrder(t){de.features={...de.features,connectMethodsOrder:t}},setWalletFeaturesOrder(t){de.features={...de.features,walletFeaturesOrder:t}},setSocialsOrder(t){de.remoteFeatures={...de.remoteFeatures,socials:t}},setCollapseWallets(t){de.features={...de.features,collapseWallets:t}},setEnableEmbedded(t){de.enableEmbedded=t},setAllowUnsupportedChain(t){de.allowUnsupportedChain=t},setManualWCControl(t){de.manualWCControl=t},setEnableNetworkSwitch(t){de.enableNetworkSwitch=t},setEnableMobileFullScreen(t){de.enableMobileFullScreen=X.isMobile()&&t},setEnableReconnect(t){de.enableReconnect=t},setCoinbasePreference(t){de.coinbasePreference=t},setDefaultAccountTypes(t={}){Object.entries(t).forEach(([e,s])=>{s&&(de.defaultAccountTypes[e]=s)})},setUniversalProviderConfigOverride(t){de.universalProviderConfigOverride=t},getUniversalProviderConfigOverride(){return de.universalProviderConfigOverride},getSnapshot(){return Xi(de)}},lr=Object.freeze({message:"",variant:"success",svg:void 0,open:!1,autoClose:!0}),at=Ge({...lr}),Pv={state:at,subscribeKey(t,e){return At(at,t,e)},showLoading(t,e={}){this._showMessage({message:t,variant:"loading",...e})},showSuccess(t){this._showMessage({message:t,variant:"success"})},showSvg(t,e){this._showMessage({message:t,svg:e})},showError(t){const e=X.parseError(t);this._showMessage({message:e,variant:"error"})},hide(){at.message=lr.message,at.variant=lr.variant,at.svg=lr.svg,at.open=lr.open,at.autoClose=lr.autoClose},_showMessage({message:t,svg:e,variant:s="success",autoClose:n=lr.autoClose}){at.open?(at.open=!1,setTimeout(()=>{at.message=t,at.variant=s,at.svg=e,at.open=!0,at.autoClose=n},150)):(at.message=t,at.variant=s,at.svg=e,at.open=!0,at.autoClose=n)}},Ks=Pv,xv={purchaseCurrencies:[{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},{id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"Ether",symbol:"ETH",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]}],paymentCurrencies:[{id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},{id:"EUR",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]}]},Vf=X.getBlockchainApiUrl(),Ut=Ge({clientId:null,api:new So({baseUrl:Vf,clientId:null}),supportedChains:{http:[],ws:[]}}),fe={state:Ut,async get(t){const{st:e,sv:s}=fe.getSdkProperties(),n=$.state.projectId,r={...t.params||{},st:e,sv:s,projectId:n};return Ut.api.get({...t,params:r})},getSdkProperties(){const{sdkType:t,sdkVersion:e}=$.state;return{st:t||"unknown",sv:e||"unknown"}},async isNetworkSupported(t){if(!t)return!1;try{Ut.supportedChains.http.length||await fe.getSupportedNetworks()}catch{return!1}return Ut.supportedChains.http.includes(t)},async getSupportedNetworks(){try{const t=await fe.get({path:"v1/supported-chains"});return Ut.supportedChains=t,t}catch{return Ut.supportedChains}},async fetchIdentity({address:t}){const e=F.getIdentityFromCacheForAddress(t);if(e)return e;const s=await fe.get({path:`/v1/identity/${t}`,params:{sender:E.state.activeCaipAddress?X.getPlainAddress(E.state.activeCaipAddress):void 0}});return F.updateIdentityCache({address:t,identity:s,timestamp:Date.now()}),s},async fetchTransactions({account:t,cursor:e,signal:s,cache:n,chainId:r}){var c;if(!await fe.isNetworkSupported((c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId))return{data:[],next:void 0};const o=F.getTransactionsCacheForAddress({address:t,chainId:r});if(o)return o;const a=await fe.get({path:`/v1/account/${t}/history`,params:{cursor:e,chainId:r},signal:s,cache:n});return F.updateTransactionsCache({address:t,chainId:r,timestamp:Date.now(),transactions:a}),a},async fetchSwapQuote({amount:t,userAddress:e,from:s,to:n,gasPrice:r}){var o;return await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId)?fe.get({path:"/v1/convert/quotes",headers:{"Content-Type":"application/json"},params:{amount:t,userAddress:e,from:s,to:n,gasPrice:r}}):{quotes:[]}},async fetchSwapTokens({chainId:t}){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:"/v1/convert/tokens",params:{chainId:t}}):{tokens:[]}},async getAddressBalance({caipNetworkId:t,address:e}){return Ut.api.post({path:`/v1?chainId=${t}&projectId=${$.state.projectId}`,body:{id:"1",jsonrpc:"2.0",method:"getAddressBalance",params:{address:e}}}).then(s=>s.result)},async fetchTokenPrice({addresses:t}){var r;if(!await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))return{fungibles:[]};const s=F.getTokenPriceCacheForAddresses(t);if(s)return s;const n=await Ut.api.post({path:"/v1/fungible/price",body:{currency:"usd",addresses:t,projectId:$.state.projectId},headers:{"Content-Type":"application/json"}});return F.updateTokenPriceCache({addresses:t,timestamp:Date.now(),tokenPrice:n}),n},async fetchSwapAllowance({tokenAddress:t,userAddress:e}){var n;return await fe.isNetworkSupported((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)?fe.get({path:"/v1/convert/allowance",params:{tokenAddress:t,userAddress:e},headers:{"Content-Type":"application/json"}}):{allowance:"0"}},async fetchGasPrice({chainId:t}){var r;const{st:e,sv:s}=fe.getSdkProperties();if(!await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))throw new Error("Network not supported for Gas Price");return fe.get({path:"/v1/convert/gas-price",headers:{"Content-Type":"application/json"},params:{chainId:t,st:e,sv:s}})},async generateSwapCalldata({amount:t,from:e,to:s,userAddress:n,disableEstimate:r}){var o;if(!await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId))throw new Error("Network not supported for Swaps");return Ut.api.post({path:"/v1/convert/build-transaction",headers:{"Content-Type":"application/json"},body:{amount:t,eip155:{slippage:Ie.CONVERT_SLIPPAGE_TOLERANCE},projectId:$.state.projectId,from:e,to:s,userAddress:n,disableEstimate:r}})},async generateApproveCalldata({from:t,to:e,userAddress:s}){var o;const{st:n,sv:r}=fe.getSdkProperties();if(!await fe.isNetworkSupported((o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId))throw new Error("Network not supported for Swaps");return fe.get({path:"/v1/convert/build-approve",headers:{"Content-Type":"application/json"},params:{userAddress:s,from:t,to:e,st:n,sv:r}})},async getBalance(t,e,s){var l;const{st:n,sv:r}=fe.getSdkProperties();if(!await fe.isNetworkSupported((l=E.state.activeCaipNetwork)==null?void 0:l.caipNetworkId))return Ks.showError("Token Balance Unavailable"),{balances:[]};const o=`${e}:${t}`,a=F.getBalanceCacheForCaipAddress(o);if(a)return a;const c=await fe.get({path:`/v1/account/${t}/balance`,params:{currency:"usd",chainId:e,forceUpdate:s,st:n,sv:r}});return F.updateBalanceCache({caipAddress:o,balance:c,timestamp:Date.now()}),c},async lookupEnsName(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/profile/account/${t}`,params:{apiVersion:"2"}}):{addresses:{},attributes:[]}},async reverseLookupEnsName({address:t}){var n,r;if(!await fe.isNetworkSupported((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId))return[];const s=(r=E.getAccountData())==null?void 0:r.address;return fe.get({path:`/v1/profile/reverse/${t}`,params:{sender:s,apiVersion:"2"}})},async getEnsNameSuggestions(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/profile/suggestions/${t}`,params:{zone:"reown.id"}}):{suggestions:[]}},async registerEnsName({coinType:t,address:e,message:s,signature:n}){var i;return await fe.isNetworkSupported((i=E.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)?Ut.api.post({path:"/v1/profile/account",body:{coin_type:t,address:e,message:s,signature:n},headers:{"Content-Type":"application/json"}}):{success:!1}},async generateOnRampURL({destinationWallets:t,partnerUserId:e,defaultNetwork:s,purchaseAmount:n,paymentAmount:r}){var a;return await fe.isNetworkSupported((a=E.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)?(await Ut.api.post({path:"/v1/generators/onrampurl",params:{projectId:$.state.projectId},body:{destinationWallets:t,defaultNetwork:s,partnerUserId:e,defaultExperience:"buy",presetCryptoAmount:n,presetFiatAmount:r}})).url:""},async getOnrampOptions(){var e;if(!await fe.isNetworkSupported((e=E.state.activeCaipNetwork)==null?void 0:e.caipNetworkId))return{paymentCurrencies:[],purchaseCurrencies:[]};try{return await fe.get({path:"/v1/onramp/options"})}catch{return xv}},async getOnrampQuote({purchaseCurrency:t,paymentCurrency:e,amount:s,network:n}){var r;try{return await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)?await Ut.api.post({path:"/v1/onramp/quote",params:{projectId:$.state.projectId},body:{purchaseCurrency:t,paymentCurrency:e,amount:s,network:n}}):null}catch{return{networkFee:{amount:s,currency:e.id},paymentSubtotal:{amount:s,currency:e.id},paymentTotal:{amount:s,currency:e.id},purchaseAmount:{amount:s,currency:e.id},quoteId:"mocked-quote-id"}}},async getSmartSessions(t){var s;return await fe.isNetworkSupported((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?fe.get({path:`/v1/sessions/${t}`}):[]},async revokeSmartSession(t,e,s){var r;return await fe.isNetworkSupported((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)?Ut.api.post({path:`/v1/sessions/${t}/revoke`,params:{projectId:$.state.projectId},body:{pci:e,signature:s}}):{success:!1}},setClientId(t){Ut.clientId=t,Ut.api=new So({baseUrl:Vf,clientId:t})}},ms={PHANTOM:{id:"a797aa35c0fadbfc1a53e7f675162ed5226968b44a19ee3d24385c64d1d3c393",url:"https://phantom.app"},SOLFLARE:{id:"1ca0bdd4747578705b1939af023d120677c64fe6ca76add81fda36e350605e79",url:"https://solflare.com"},COINBASE:{id:"fd20dc426fb37566d803205b19bbc1d4096b248ac04548e3cfb6b3a38bd033aa",url:"https://go.cb-w.com"},BINANCE:{id:"2fafea35bb471d22889ccb49c08d99dd0a18a37982602c33f696a5723934ba25",appId:"yFK5FCqYprrXDiVFbhyRx7",deeplink:"bnc://app.binance.com/mp/app",url:"https://app.binance.com/en/download"}},kv={handleMobileDeeplinkRedirect(t,e){const s=window.location.href,n=encodeURIComponent(s);if(t===ms.PHANTOM.id&&!("phantom"in window)){const r=s.startsWith("https")?"https":"http",i=s.split("/")[2],o=encodeURIComponent(`${r}://${i}`);window.location.href=`${ms.PHANTOM.url}/ul/browse/${n}?ref=${o}`}if(t===ms.SOLFLARE.id&&!("solflare"in window)&&(window.location.href=`${ms.SOLFLARE.url}/ul/v1/browse/${n}?ref=${n}`),e===U.CHAIN.SOLANA&&t===ms.COINBASE.id&&!("coinbaseSolana"in window)&&(window.location.href=`${ms.COINBASE.url}/dapp?cb_url=${n}`),e===U.CHAIN.BITCOIN&&t===ms.BINANCE.id&&!("binancew3w"in window)){const r=E.state.activeCaipNetwork,i=window.btoa("/pages/browser/index"),o=window.btoa(`url=${n}&defaultChainId=${(r==null?void 0:r.id)??1}`),a=new URL(ms.BINANCE.deeplink);a.searchParams.set("appId",ms.BINANCE.appId),a.searchParams.set("startPagePath",i),a.searchParams.set("startPageQuery",o);const c=new URL(ms.BINANCE.url);c.searchParams.set("_dp",window.btoa(a.toString())),window.location.href=c.toString()}}},Uv=Object.freeze({enabled:!0,events:[]}),$v=new So({baseUrl:X.getAnalyticsUrl(),clientId:null}),Dv=5,Lv=60*1e3,Rn=Ge({...Uv}),Mv={state:Rn,subscribeKey(t,e){return At(Rn,t,e)},async sendError(t,e){if(!Rn.enabled)return;const s=Date.now();if(Rn.events.filter(i=>{const o=new Date(i.properties.timestamp||"").getTime();return s-o<Lv}).length>=Dv)return;const r={type:"error",event:e,properties:{errorType:t.name,errorMessage:t.message,stackTrace:t.stack,timestamp:new Date().toISOString()}};Rn.events.push(r);try{if(typeof window>"u")return;const{projectId:i,sdkType:o,sdkVersion:a}=$.state;await $v.post({path:"/e",params:{projectId:i,st:o,sv:a||"html-wagmi-4.2.2"},body:{eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:new Date().toISOString(),props:{type:"error",event:e,errorType:t.name,errorMessage:t.message,stackTrace:t.stack}}})}catch{}},enable(){Rn.enabled=!0},disable(){Rn.enabled=!1},clearEvents(){Rn.events=[]}};class Tr extends Error{constructor(e,s,n){super(e),this.originalName="AppKitError",this.name="AppKitError",this.category=s,this.originalError=n,n&&n instanceof Error&&(this.originalName=n.name),Object.setPrototypeOf(this,Tr.prototype);let r=!1;if(n instanceof Error&&typeof n.stack=="string"&&n.stack){const i=n.stack,o=i.indexOf(`
|
|
3
3
|
`);if(o>-1){const a=i.substring(o+1);this.stack=`${this.name}: ${this.message}
|
|
4
|
-
${a}`,r=!0}}r||(Error.captureStackTrace?Error.captureStackTrace(this,Tr):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function Hu(t,e){let s="";try{t instanceof Error?s=t.message:typeof t=="string"?s=t:typeof t=="object"&&t!==null?Object.keys(t).length===0?s="Unknown error":s=(t==null?void 0:t.message)||JSON.stringify(t):s=String(t)}catch(r){s="Unknown error",console.error("Error parsing error message",r)}const n=t instanceof Tr?t:new Tr(s,e,t);throw Mv.sendError(n,n.category),n}function As(t,e="INTERNAL_SDK_ERROR"){const s={};return Object.keys(t).forEach(n=>{const r=t[n];if(typeof r=="function"){let i=r;r.constructor.name==="AsyncFunction"?i=async(...o)=>{try{return await r(...o)}catch(a){return Hu(a,e)}}:i=(...o)=>{try{return r(...o)}catch(a){return Hu(a,e)}},s[n]=i}else s[n]=r}),s}const ss=Ge({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),Bv={state:ss,subscribeNetworkImages(t){return _t(ss.networkImages,()=>t(ss.networkImages))},subscribeKey(t,e){return At(ss,t,e)},subscribe(t){return _t(ss,()=>t(ss))},setWalletImage(t,e){ss.walletImages[t]=e},setNetworkImage(t,e){ss.networkImages[t]=e},setChainImage(t,e){ss.chainImages[t]=e},setConnectorImage(t,e){ss.connectorImages={...ss.connectorImages,[t]:e}},setTokenImage(t,e){ss.tokenImages[t]=e},setCurrencyImage(t,e){ss.currencyImages[t]=e}},bs=As(Bv),zu={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:"",sui:"",stacks:"",ton:"20f673c0-095e-49b2-07cf-eb5049dcf600"},Ic=Ge({networkImagePromises:{}}),Kf={async fetchWalletImage(t){if(t)return await te._fetchWalletImage(t),this.getWalletImageById(t)},async fetchNetworkImage(t){if(!t)return;const e=this.getNetworkImageById(t);return e||(Ic.networkImagePromises[t]||(Ic.networkImagePromises[t]=te._fetchNetworkImage(t)),await Ic.networkImagePromises[t],this.getNetworkImageById(t))},getWalletImageById(t){if(t)return bs.state.walletImages[t]},getWalletImage(t){if(t!=null&&t.image_url)return t==null?void 0:t.image_url;if(t!=null&&t.image_id)return bs.state.walletImages[t.image_id]},getNetworkImage(t){var e,s,n;if((e=t==null?void 0:t.assets)!=null&&e.imageUrl)return(s=t==null?void 0:t.assets)==null?void 0:s.imageUrl;if((n=t==null?void 0:t.assets)!=null&&n.imageId)return bs.state.networkImages[t.assets.imageId]},getNetworkImageById(t){if(t)return bs.state.networkImages[t]},getConnectorImage(t){var e;if(t!=null&&t.imageUrl)return t.imageUrl;if((e=t==null?void 0:t.info)!=null&&e.icon)return t.info.icon;if(t!=null&&t.imageId)return bs.state.connectorImages[t.imageId]},getChainImage(t){return bs.state.networkImages[zu[t]]},getTokenImage(t){if(t)return bs.state.tokenImages[t]},getWalletImageUrl(t){if(!t)return"";const{projectId:e,sdkType:s,sdkVersion:n}=$.state,r=new URL(`${U.W3M_API_URL}/getWalletImage/${t}`);return r.searchParams.set("projectId",e),r.searchParams.set("st",s),r.searchParams.set("sv",n),r.toString()},getAssetImageUrl(t){if(!t)return"";const{projectId:e,sdkType:s,sdkVersion:n}=$.state,r=new URL(`${U.W3M_API_URL}/public/getAssetImage/${t}`);return r.searchParams.set("projectId",e),r.searchParams.set("st",s),r.searchParams.set("sv",n),r.toString()},getChainNamespaceImageUrl(t){return this.getAssetImageUrl(zu[t])}},jv=X.getAnalyticsUrl(),Fv=new So({baseUrl:jv,clientId:null}),qv=["MODAL_CREATED"],Wv=45,Vu=1e3*10,et=Ge({timestamp:Date.now(),lastFlush:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"},pendingEvents:[],subscribedToVisibilityChange:!1,walletImpressions:[]}),Ee={state:et,subscribe(t){return _t(et,()=>t(et))},getSdkProperties(){const{projectId:t,sdkType:e,sdkVersion:s}=$.state;return{projectId:t,st:e,sv:s||"html-wagmi-4.2.2"}},shouldFlushEvents(){const t=JSON.stringify(et.pendingEvents).length/1024>Wv,e=et.lastFlush+Vu<Date.now();return t||e},_setPendingEvent(t){var e,s;try{let n=(e=E.getAccountData())==null?void 0:e.address;if("address"in t.data&&t.data.address&&(n=t.data.address),qv.includes(t.data.event)||typeof window>"u")return;const r=(s=E.getActiveCaipNetwork())==null?void 0:s.caipNetworkId;this.state.pendingEvents.push({eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:t.timestamp,props:{...t.data,address:n,properties:{..."properties"in t.data?t.data.properties:{},caipNetworkId:r}}}),et.reportedErrors.FORBIDDEN=!1,Ee.shouldFlushEvents()&&Ee._submitPendingEvents()}catch(n){console.warn("_setPendingEvent",n)}},sendEvent(t){var s;et.timestamp=Date.now(),et.data=t;const e=["INITIALIZE","CONNECT_SUCCESS","SOCIAL_LOGIN_SUCCESS"];((s=$.state.features)!=null&&s.analytics||e.includes(t.event))&&Ee._setPendingEvent(et),this.subscribeToFlushTriggers()},sendWalletImpressionEvent(t){et.walletImpressions.push(t)},_transformPendingEventsForBatch(t){try{return t.filter(e=>e.props.event!=="WALLET_IMPRESSION_V2")}catch{return t}},_submitPendingEvents(){if(et.lastFlush=Date.now(),!(et.pendingEvents.length===0&&et.walletImpressions.length===0))try{const t=Ee._transformPendingEventsForBatch(et.pendingEvents);et.walletImpressions.length&&t.push({eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:Date.now(),props:{type:"track",event:"WALLET_IMPRESSION_V2",items:[...et.walletImpressions]}}),Fv.sendBeacon({path:"/batch",params:Ee.getSdkProperties(),body:t}),et.reportedErrors.FORBIDDEN=!1,et.pendingEvents=[],et.walletImpressions=[]}catch{et.reportedErrors.FORBIDDEN=!0}},subscribeToFlushTriggers(){var t,e,s;et.subscribedToVisibilityChange||typeof document>"u"||(et.subscribedToVisibilityChange=!0,(t=document==null?void 0:document.addEventListener)==null||t.call(document,"visibilitychange",()=>{document.visibilityState==="hidden"&&Ee._submitPendingEvents()}),(e=document==null?void 0:document.addEventListener)==null||e.call(document,"freeze",()=>{Ee._submitPendingEvents()}),(s=window==null?void 0:window.addEventListener)==null||s.call(window,"pagehide",()=>{Ee._submitPendingEvents()}),setInterval(()=>{Ee._submitPendingEvents()},Vu))}},Hv=X.getApiUrl(),$t=new So({baseUrl:Hv,clientId:null}),zv=40,Ku=4,Vv=20,we=Ge({promises:{},page:1,count:0,featured:[],allFeatured:[],recommended:[],allRecommended:[],wallets:[],filteredWallets:[],search:[],isAnalyticsEnabled:!1,excludedWallets:[],isFetchingRecommendedWallets:!1,explorerWallets:[],explorerFilteredWallets:[],plan:{tier:"none",hasExceededUsageLimit:!1,limits:{isAboveRpcLimit:!1,isAboveMauLimit:!1}}}),te={state:we,subscribeKey(t,e){return At(we,t,e)},_getSdkProperties(){const{projectId:t,sdkType:e,sdkVersion:s}=$.state;return{projectId:t,st:e||"appkit",sv:s||"html-wagmi-4.2.2"}},_filterOutExtensions(t){return $.state.isUniversalProvider?t.filter(e=>!!(e.mobile_link||e.desktop_link||e.webapp_link)):t},async _fetchWalletImage(t){const e=`${$t.baseUrl}/getWalletImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setWalletImage(t,URL.createObjectURL(s))},async _fetchNetworkImage(t){const e=`${$t.baseUrl}/public/getAssetImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setNetworkImage(t,URL.createObjectURL(s))},async _fetchConnectorImage(t){const e=`${$t.baseUrl}/public/getAssetImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setConnectorImage(t,URL.createObjectURL(s))},async _fetchCurrencyImage(t){const e=`${$t.baseUrl}/public/getCurrencyImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setCurrencyImage(t,URL.createObjectURL(s))},async _fetchTokenImage(t){const e=`${$t.baseUrl}/public/getTokenImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setTokenImage(t,URL.createObjectURL(s))},_filterWalletsByPlatform(t){const e=t.length,s=X.isMobile()?t==null?void 0:t.filter(r=>r.mobile_link||r.webapp_link?!0:Object.values(ms).map(o=>o.id).includes(r.id)):t,n=e-s.length;return{filteredWallets:s,mobileFilteredOutWalletsLength:n}},async fetchProjectConfig(){return(await $t.get({path:"/appkit/v1/config",params:te._getSdkProperties()})).features},async fetchUsage(){try{const t=await $t.get({path:"/appkit/v1/project-limits",params:te._getSdkProperties()}),{tier:e,isAboveMauLimit:s,isAboveRpcLimit:n}=t.planLimits,r=e==="starter",i=s||n;te.state.plan={tier:e,hasExceededUsageLimit:r&&i,limits:{isAboveRpcLimit:n,isAboveMauLimit:s}}}catch(t){console.warn("Failed to fetch usage",t)}},async fetchAllowedOrigins(){try{const{allowedOrigins:t}=await $t.get({path:"/projects/v1/origins",params:te._getSdkProperties()});return t}catch(t){if(t instanceof Error&&t.cause instanceof Response){const e=t.cause.status;if(e===U.HTTP_STATUS_CODES.TOO_MANY_REQUESTS)throw new Error("RATE_LIMITED",{cause:t});if(e>=U.HTTP_STATUS_CODES.SERVER_ERROR&&e<600)throw new Error("SERVER_ERROR",{cause:t});return[]}return[]}},async fetchNetworkImages(){const t=E.getAllRequestedCaipNetworks(),e=t==null?void 0:t.map(({assets:s})=>s==null?void 0:s.imageId).filter(Boolean).filter(s=>!Kf.getNetworkImageById(s));e&&await Promise.allSettled(e.map(s=>te._fetchNetworkImage(s)))},async fetchConnectorImages(){const{connectors:t}=z.state,e=t.map(({imageId:s})=>s).filter(Boolean);await Promise.allSettled(e.map(s=>te._fetchConnectorImage(s)))},async fetchCurrencyImages(t=[]){await Promise.allSettled(t.map(e=>te._fetchCurrencyImage(e)))},async fetchTokenImages(t=[]){await Promise.allSettled(t.map(e=>te._fetchTokenImage(e)))},async fetchWallets(t){var o;const e=t.exclude??[];te._getSdkProperties().sv.startsWith("html-core-")&&e.push(...Object.values(ms).map(a=>a.id));const n=await $t.get({path:"/getWallets",params:{...te._getSdkProperties(),...t,page:String(t.page),entries:String(t.entries),include:(o=t.include)==null?void 0:o.join(","),exclude:e.join(",")}}),{filteredWallets:r,mobileFilteredOutWalletsLength:i}=te._filterWalletsByPlatform(n==null?void 0:n.data);return{data:r||[],count:n==null?void 0:n.count,mobileFilteredOutWalletsLength:i}},async prefetchWalletRanks(){const t=z.state.connectors;if(!(t!=null&&t.length))return;const e={page:1,entries:20,badge:"certified"};if(e.names=t.map(r=>r.name).join(","),E.state.activeChain===U.CHAIN.EVM){const r=[...t.flatMap(i=>{var o;return((o=i.connectors)==null?void 0:o.map(a=>{var c;return(c=a.info)==null?void 0:c.rdns}))||[]}),...t.map(i=>{var o;return(o=i.info)==null?void 0:o.rdns})].filter(i=>typeof i=="string"&&i.length>0);r.length&&(e.rdns=r.join(","))}const{data:s}=await te.fetchWallets(e);we.explorerWallets=s,z.extendConnectorsWithExplorerWallets(s);const n=E.getRequestedCaipNetworkIds().join(",");we.explorerFilteredWallets=s.filter(r=>{var i;return(i=r.chains)==null?void 0:i.some(o=>n.includes(o))})},async fetchFeaturedWallets(){const{featuredWalletIds:t}=$.state;if(t!=null&&t.length){const e={...te._getSdkProperties(),page:1,entries:(t==null?void 0:t.length)??Ku,include:t},{data:s}=await te.fetchWallets(e),n=[...s].sort((i,o)=>t.indexOf(i.id)-t.indexOf(o.id)),r=n.map(i=>i.image_id).filter(Boolean);await Promise.allSettled(r.map(i=>te._fetchWalletImage(i))),we.featured=n,we.allFeatured=n}},async fetchRecommendedWallets(){try{we.isFetchingRecommendedWallets=!0;const{includeWalletIds:t,excludeWalletIds:e,featuredWalletIds:s}=$.state,n=[...e??[],...s??[]].filter(Boolean),r=E.getRequestedCaipNetworkIds().join(","),i={page:1,entries:Ku,include:t,exclude:n,chains:r},{data:o,count:a}=await te.fetchWallets(i),c=F.getRecentWallets(),l=o.map(u=>u.image_id).filter(Boolean),d=c.map(u=>u.image_id).filter(Boolean);await Promise.allSettled([...l,...d].map(u=>te._fetchWalletImage(u))),we.recommended=o,we.allRecommended=o,we.count=a??0}catch{}finally{we.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:t}){const{includeWalletIds:e,excludeWalletIds:s,featuredWalletIds:n}=$.state,r=E.getRequestedCaipNetworkIds().join(","),i=[...we.recommended.map(({id:u})=>u),...s??[],...n??[]].filter(Boolean),o={page:t,entries:zv,include:e,exclude:i,chains:r},{data:a,count:c,mobileFilteredOutWalletsLength:l}=await te.fetchWallets(o);we.mobileFilteredOutWalletsLength=l+(we.mobileFilteredOutWalletsLength??0);const d=a.slice(0,Vv).map(u=>u.image_id).filter(Boolean);await Promise.allSettled(d.map(u=>te._fetchWalletImage(u))),we.wallets=X.uniqueBy([...we.wallets,...te._filterOutExtensions(a)],"id").filter(u=>{var h;return(h=u.chains)==null?void 0:h.some(p=>r.includes(p))}),we.count=c>we.count?c:we.count,we.page=t},async initializeExcludedWallets({ids:t}){const e={page:1,entries:t.length,include:t},{data:s}=await te.fetchWallets(e);s&&s.forEach(n=>{we.excludedWallets.push({rdns:n.rdns,name:n.name})})},async searchWallet({search:t,badge:e}){const{includeWalletIds:s,excludeWalletIds:n}=$.state,r=E.getRequestedCaipNetworkIds().join(",");we.search=[];const i={page:1,entries:100,search:t==null?void 0:t.trim(),badge_type:e,include:s,exclude:n,chains:r},{data:o}=await te.fetchWallets(i);Ee.sendEvent({type:"track",event:"SEARCH_WALLET",properties:{badge:e??"",search:t??""}});const a=o.map(c=>c.image_id).filter(Boolean);await Promise.allSettled([...a.map(c=>te._fetchWalletImage(c)),X.wait(300)]),we.search=te._filterOutExtensions(o)},initPromise(t,e){const s=we.promises[t];return s||(we.promises[t]=e())},prefetch({fetchConnectorImages:t=!0,fetchFeaturedWallets:e=!0,fetchRecommendedWallets:s=!0,fetchNetworkImages:n=!0,fetchWalletRanks:r=!0}={}){const i=[t&&te.initPromise("connectorImages",te.fetchConnectorImages),e&&te.initPromise("featuredWallets",te.fetchFeaturedWallets),s&&te.initPromise("recommendedWallets",te.fetchRecommendedWallets),n&&te.initPromise("networkImages",te.fetchNetworkImages),r&&te.initPromise("walletRanks",te.prefetchWalletRanks)].filter(Boolean);return Promise.allSettled(i)},prefetchAnalyticsConfig(){var t;(t=$.state.features)!=null&&t.analytics&&te.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{const{isAnalyticsEnabled:t}=await $t.get({path:"/getAnalyticsConfig",params:te._getSdkProperties()});$.setFeatures({analytics:t})}catch{$.setFeatures({analytics:!1})}},filterByNamespaces(t){if(!(t!=null&&t.length)){we.featured=we.allFeatured,we.recommended=we.allRecommended;return}const e=E.getRequestedCaipNetworkIds().join(",");we.featured=we.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.recommended=we.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.filteredWallets=we.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})},clearFilterByNamespaces(){we.filteredWallets=[]},setFilterByNamespace(t){if(!t){we.featured=we.allFeatured,we.recommended=we.allRecommended;return}const e=E.getRequestedCaipNetworkIds().join(",");we.featured=we.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.recommended=we.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.filteredWallets=we.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})}},Kv=["ConnectingExternal","ConnectingMultiChain","ConnectingSocial","ConnectingFarcaster"],je=Ge({view:"Connect",history:["Connect"],transactionStack:[]}),Gv={state:je,subscribeKey(t,e){return At(je,t,e)},pushTransactionStack(t){je.transactionStack.push(t)},popTransactionStack(t){const e=je.transactionStack.pop();if(!e)return;const{onSuccess:s,onError:n,onCancel:r}=e;switch(t){case"success":s==null||s();break;case"error":n==null||n(),ue.goBack();break;case"cancel":r==null||r(),ue.goBack();break}},push(t,e){let s=t,n=e;te.state.plan.hasExceededUsageLimit&&Kv.includes(t)&&(s="UsageExceeded",n=void 0),s!==je.view&&(je.view=s,je.history.push(s),je.data=n)},reset(t,e){je.view=t,je.history=[t],je.data=e},replace(t,e){je.history.at(-1)===t||(je.view=t,je.history[je.history.length-1]=t,je.data=e)},goBack(){var n,r;const t=E.state.activeCaipAddress,e=ue.state.view==="ConnectingFarcaster",s=!t&&e;if(je.history.length>1){je.history.pop();const[i]=je.history.slice(-1);i&&(t&&i==="Connect"?je.view="Account":je.view=i)}else Ne.close();(n=je.data)!=null&&n.wallet&&(je.data.wallet=void 0),(r=je.data)!=null&&r.redirectView&&(je.data.redirectView=void 0),setTimeout(()=>{var i,o,a;if(s){E.setAccountProp("farcasterUrl",void 0,E.state.activeChain);const c=z.getAuthConnector();(i=c==null?void 0:c.provider)==null||i.reload();const l=Xi($.state);(a=(o=c==null?void 0:c.provider)==null?void 0:o.syncDappData)==null||a.call(o,{metadata:l.metadata,sdkVersion:l.sdkVersion,projectId:l.projectId,sdkType:l.sdkType})}},100)},goBackToIndex(t){if(je.history.length>1){je.history=je.history.slice(0,t+1);const[e]=je.history.slice(-1);e&&(je.view=e)}},goBackOrCloseModal(){ue.state.history.length>1?ue.goBack():Ne.close()}},ue=As(Gv),nn=Ge({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),Pl={state:nn,subscribe(t){return _t(nn,()=>t(nn))},setThemeMode(t){nn.themeMode=t;try{const e=z.getAuthConnector();if(e){const s=Pl.getSnapshot().themeVariables;e.provider.syncTheme({themeMode:t,themeVariables:s,w3mThemeVariables:Zi(s,t)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(t){nn.themeVariables={...nn.themeVariables,...t};try{const e=z.getAuthConnector();if(e){const s=Pl.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:s,w3mThemeVariables:Zi(nn.themeVariables,nn.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot(){return Xi(nn)}},Kt=As(Pl),Gf=Object.fromEntries(Sf.map(t=>[t,void 0])),Yv=Object.fromEntries(Sf.map(t=>[t,!0])),Pe=Ge({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:Gf,filterByNamespaceMap:Yv}),Zv={state:Pe,subscribe(t){return _t(Pe,()=>{t(Pe)})},subscribeKey(t,e){return At(Pe,t,e)},initialize(t){t.forEach(e=>{const s=F.getConnectedConnectorId(e);s&&z.setConnectorId(s,e)})},setActiveConnector(t){t&&(Pe.activeConnector=Qi(t))},setConnectors(t){t.filter(r=>!Pe.allConnectors.some(i=>i.id===r.id&&z.getConnectorName(i.name)===z.getConnectorName(r.name)&&i.chain===r.chain)).forEach(r=>{r.type!=="MULTI_CHAIN"&&Pe.allConnectors.push(Qi(r))});const s=z.getEnabledNamespaces(),n=z.getEnabledConnectors(s);Pe.connectors=z.mergeMultiChainConnectors(n)},filterByNamespaces(t){Object.keys(Pe.filterByNamespaceMap).forEach(e=>{Pe.filterByNamespaceMap[e]=!1}),t.forEach(e=>{Pe.filterByNamespaceMap[e]=!0}),z.updateConnectorsForEnabledNamespaces()},filterByNamespace(t,e){Pe.filterByNamespaceMap[t]=e,z.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){const t=z.getEnabledNamespaces(),e=z.getEnabledConnectors(t),s=z.areAllNamespacesEnabled();Pe.connectors=z.mergeMultiChainConnectors(e),s?te.clearFilterByNamespaces():te.filterByNamespaces(t)},getEnabledNamespaces(){return Object.entries(Pe.filterByNamespaceMap).filter(([t,e])=>e).map(([t])=>t)},getEnabledConnectors(t){return Pe.allConnectors.filter(e=>t.includes(e.chain))},areAllNamespacesEnabled(){return Object.values(Pe.filterByNamespaceMap).every(t=>t)},mergeMultiChainConnectors(t){const e=z.generateConnectorMapByName(t),s=[];return e.forEach(n=>{const r=n[0],i=(r==null?void 0:r.id)===U.CONNECTOR_ID.AUTH;n.length>1&&r?s.push({name:r.name,imageUrl:r.imageUrl,imageId:r.imageId,connectors:[...n],type:i?"AUTH":"MULTI_CHAIN",chain:"eip155",id:(r==null?void 0:r.id)||""}):r&&s.push(r)}),s},generateConnectorMapByName(t){const e=new Map;return t.forEach(s=>{const{name:n}=s,r=z.getConnectorName(n);if(!r)return;const i=e.get(r)||[];i.find(a=>a.chain===s.chain)||i.push(s),e.set(r,i)}),e},getConnectorName(t){return t&&({"Trust Wallet":"Trust"}[t]||t)},getUniqueConnectorsByName(t){const e=[];return t.forEach(s=>{e.find(n=>n.chain===s.chain)||e.push(s)}),e},addConnector(t){var e,s,n;if(t.id===U.CONNECTOR_ID.AUTH){const r=t,i=Xi($.state),o=Kt.getSnapshot().themeMode,a=Kt.getSnapshot().themeVariables;(s=(e=r==null?void 0:r.provider)==null?void 0:e.syncDappData)==null||s.call(e,{metadata:i.metadata,sdkVersion:i.sdkVersion,projectId:i.projectId,sdkType:i.sdkType}),(n=r==null?void 0:r.provider)==null||n.syncTheme({themeMode:o,themeVariables:a,w3mThemeVariables:Zi(a,o)}),z.setConnectors([t])}else z.setConnectors([t])},getAuthConnector(t){var n;const e=t||E.state.activeChain,s=Pe.connectors.find(r=>r.id===U.CONNECTOR_ID.AUTH);if(s)return(n=s==null?void 0:s.connectors)!=null&&n.length?s.connectors.find(i=>i.chain===e):s},getAnnouncedConnectorRdns(){return Pe.connectors.filter(t=>t.type==="ANNOUNCED").map(t=>{var e;return(e=t.info)==null?void 0:e.rdns})},getConnectorById(t){return Pe.allConnectors.find(e=>e.id===t)},getConnector({id:t,namespace:e}){const s=e||E.state.activeChain;return Pe.allConnectors.filter(i=>i.chain===s).find(i=>i.id===t||i.explorerId===t)},syncIfAuthConnector(t){var i,o;if(t.id!=="AUTH")return;const e=t,s=Xi($.state),n=Kt.getSnapshot().themeMode,r=Kt.getSnapshot().themeVariables;(o=(i=e==null?void 0:e.provider)==null?void 0:i.syncDappData)==null||o.call(i,{metadata:s.metadata,sdkVersion:s.sdkVersion,sdkType:s.sdkType,projectId:s.projectId}),e.provider.syncTheme({themeMode:n,themeVariables:r,w3mThemeVariables:Zi(r,n)})},getConnectorsByNamespace(t){const e=Pe.allConnectors.filter(s=>s.chain===t);return z.mergeMultiChainConnectors(e)},canSwitchToSmartAccount(t){return E.checkIfSmartAccountEnabled()&&ls(t)===tt.ACCOUNT_TYPES.EOA},selectWalletConnector(t){var r;const e=(r=ue.state.data)==null?void 0:r.redirectView,s=E.state.activeChain,n=s?z.getConnector({id:t.id,namespace:s}):void 0;kv.handleMobileDeeplinkRedirect((n==null?void 0:n.explorerId)||t.id,E.state.activeChain),n?ue.push("ConnectingExternal",{connector:n,wallet:t,redirectView:e}):ue.push("ConnectingWalletConnect",{wallet:t,redirectView:e})},getConnectors(t){return t?z.getConnectorsByNamespace(t):z.mergeMultiChainConnectors(Pe.allConnectors)},setFilterByNamespace(t){Pe.filterByNamespace=t,Pe.connectors=z.getConnectors(t),te.setFilterByNamespace(t)},setConnectorId(t,e){t&&(Pe.activeConnectorIds={...Pe.activeConnectorIds,[e]:t},F.setConnectedConnectorId(e,t))},removeConnectorId(t){Pe.activeConnectorIds={...Pe.activeConnectorIds,[t]:void 0},F.deleteConnectedConnectorId(t)},getConnectorId(t){if(t)return Pe.activeConnectorIds[t]},isConnected(t){return t?!!Pe.activeConnectorIds[t]:Object.values(Pe.activeConnectorIds).some(e=>!!e)},resetConnectorIds(){Pe.activeConnectorIds={...Gf}},extendConnectorsWithExplorerWallets(t){Pe.allConnectors.forEach(n=>{const r=t.find(i=>{var o;return i.id===n.id||i.rdns&&i.rdns===((o=n.info)==null?void 0:o.rdns)});r&&(n.explorerWallet=r)});const e=z.getEnabledNamespaces(),s=z.getEnabledConnectors(e);Pe.connectors=z.mergeMultiChainConnectors(s)}},z=As(Zv),Jv=1e3,Ci={checkNamespaceConnectorId(t,e){return z.getConnectorId(t)===e},isSocialProvider(t){return Ie.DEFAULT_REMOTE_FEATURES.socials.includes(t)},connectWalletConnect({walletConnect:t,connector:e,closeModalOnConnect:s=!0,redirectViewOnModalClose:n="Connect",onOpen:r,onConnect:i}){return new Promise((o,a)=>{if(t&&z.setActiveConnector(e),r==null||r(X.isMobile()&&t),n){const l=Ne.subscribeKey("open",d=>{d||(ue.state.view!==n&&ue.replace(n),l(),a(new Error("Modal closed")))})}const c=E.subscribeKey("activeCaipAddress",l=>{l&&(i==null||i(),s&&Ne.close(),c(),o(dt.parseCaipAddress(l)))})})},connectExternal(t){return new Promise((e,s)=>{const n=E.subscribeKey("activeCaipAddress",r=>{r&&(Ne.close(),n(),e(dt.parseCaipAddress(r)))});G.connectExternal(t,t.chain).catch(()=>{n(),s(new Error("Connection rejected"))})})},connectSocial({social:t,namespace:e,closeModalOnConnect:s=!0,onOpenFarcaster:n,onConnect:r}){let i,o=!1,a=null;const c=e||E.state.activeChain,l=E.subscribeKey("activeCaipAddress",d=>{d&&(s&&Ne.close(),l())});return new Promise((d,u)=>{async function h(g){var f;if((f=g.data)!=null&&f.resultUri)if(g.origin===U.SECURE_SITE_SDK_ORIGIN){window.removeEventListener("message",h,!1);try{const y=z.getAuthConnector(c);if(y&&!o){i&&i.close(),o=!0;const _=g.data.resultUri;Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_REQUEST_USER_DATA",properties:{provider:t}}),F.setConnectedSocialProvider(t),await G.connectExternal({id:y.id,type:y.type,socialUri:_},y.chain);const S=E.state.activeCaipAddress;if(!S){u(new Error("Failed to connect"));return}d(dt.parseCaipAddress(S)),Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:t}})}}catch(y){Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:X.parseError(y)}}),u(new Error("Failed to connect"))}}else Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:"Untrusted Origin"}})}async function p(){if(Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_STARTED",properties:{provider:t}}),t==="farcaster"){n==null||n();const g=Ne.subscribeKey("open",y=>{!y&&t==="farcaster"&&(u(new Error("Popup closed")),r==null||r(),g())}),f=z.getAuthConnector();if(f){const y=E.getAccountData(c);if(!(y!=null&&y.farcasterUrl))try{const{url:_}=await f.provider.getFarcasterUri();E.setAccountProp("farcasterUrl",_,c)}catch{u(new Error("Failed to connect to farcaster"))}}}else{const g=z.getAuthConnector();a=X.returnOpenHref(`${U.SECURE_SITE_SDK_ORIGIN}/loading`,"popupWindow","width=600,height=800,scrollbars=yes");try{if(g){const{uri:f}=await g.provider.getSocialRedirectUri({provider:t});if(a&&f){a.location.href=f,i=a;const y=setInterval(()=>{i!=null&&i.closed&&!o&&(u(new Error("Popup closed")),clearInterval(y))},1e3);window.addEventListener("message",h,!1)}else a==null||a.close(),u(new Error("Failed to initiate social connection"))}}catch{u(new Error("Failed to initiate social connection")),a==null||a.close()}}}p()})},connectEmail({closeModalOnConnect:t=!0,redirectViewOnModalClose:e="Connect",onOpen:s,onConnect:n}){return new Promise((r,i)=>{if(s==null||s(),e){const a=Ne.subscribeKey("open",c=>{c||(ue.state.view!==e&&ue.replace(e),a(),i(new Error("Modal closed")))})}const o=E.subscribeKey("activeCaipAddress",a=>{a&&(n==null||n(),t&&Ne.close(),o(),r(dt.parseCaipAddress(a)))})})},async updateEmail(){const t=F.getConnectedConnectorId(E.state.activeChain),e=z.getAuthConnector();if(!e)throw new Error("No auth connector found");if(t!==U.CONNECTOR_ID.AUTH)throw new Error("Not connected to email or social");const s=e.provider.getEmail()??"";return await Ne.open({view:"UpdateEmailWallet",data:{email:s,redirectView:void 0}}),new Promise((n,r)=>{const i=setInterval(()=>{const a=e.provider.getEmail()??"";a!==s&&(Ne.close(),clearInterval(i),o(),n({email:a}))},Jv),o=Ne.subscribeKey("open",a=>{a||(ue.state.view!=="Connect"&&ue.push("Connect"),clearInterval(i),o(),r(new Error("Modal closed")))})})},canSwitchToSmartAccount(t){return E.checkIfSmartAccountEnabled()&&ls(t)===tt.ACCOUNT_TYPES.EOA}};function Yf(){var n,r;const t=((n=E.state.activeCaipNetwork)==null?void 0:n.chainNamespace)||"eip155",e=((r=E.state.activeCaipNetwork)==null?void 0:r.id)||1,s=Ie.NATIVE_TOKEN_ADDRESS[t];return`${t}:${e}:${s}`}function ls(t){var s;return(s=E.getAccountData(t))==null?void 0:s.preferredAccountType}function ki(t){var e,s;return t?(s=(e=E.state.chains.get(t))==null?void 0:e.networkState)==null?void 0:s.caipNetwork:E.state.activeCaipNetwork}const $a={getConnectionStatus(t,e){const s=z.state.activeConnectorIds[e],n=G.getConnections(e);return!!s&&t.connectorId===s?"connected":n.some(o=>o.connectorId.toLowerCase()===t.connectorId.toLowerCase())?"active":"disconnected"},excludeConnectorAddressFromConnections({connections:t,connectorId:e,addresses:s}){return t.map(n=>{if((e?n.connectorId.toLowerCase()===e.toLowerCase():!1)&&s){const i=n.accounts.filter(o=>!s.some(c=>c.toLowerCase()===o.address.toLowerCase()));return{...n,accounts:i}}return n})},excludeExistingConnections(t,e){const s=new Set(t);return e.filter(n=>!s.has(n.connectorId))},getConnectionsByConnectorId(t,e){return t.filter(s=>s.connectorId.toLowerCase()===e.toLowerCase())},getConnectionsData(t){var a;const e=!!((a=$.state.remoteFeatures)!=null&&a.multiWallet),s=z.state.activeConnectorIds[t],n=G.getConnections(t),i=(G.state.recentConnections.get(t)??[]).filter(c=>z.getConnectorById(c.connectorId)),o=$a.excludeExistingConnections([...n.map(c=>c.connectorId),...s?[s]:[]],i);return e?{connections:n,recentConnections:o}:{connections:n.filter(c=>c.connectorId.toLowerCase()===(s==null?void 0:s.toLowerCase())),recentConnections:[]}},onConnectMobile(t){const e=G.state.wcUri;if(t!=null&&t.mobile_link&&e)try{G.setWcError(!1);const{mobile_link:s,link_mode:n,name:r}=t,{redirect:i,redirectUniversalLink:o,href:a}=X.formatNativeUrl(s,e,n),c=i,l=o,d=X.isIframe()?"_top":"_self";G.setWcLinking({name:r,href:a}),G.setRecentWallet(t),$.state.experimental_preferUniversalLinks&&l?X.openHref(l,d):X.openHref(c,d)}catch(s){Ee.sendEvent({type:"track",event:"CONNECT_PROXY_ERROR",properties:{message:s instanceof Error?s.message:"Error parsing the deep link",uri:e,mobile_link:t.mobile_link,name:t.name}}),G.setWcError(!0)}}},Br=Ge({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1,connectingWallet:void 0}),ds={state:Br,subscribe(t){return _t(Br,()=>t(Br))},subscribeOpen(t){return At(Br,"open",t)},set(t){Object.assign(Br,{...Br,...t})}},Ye=Ge({transactions:[],transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),Xv={state:Ye,subscribe(t){return _t(Ye,()=>t(Ye))},setLastNetworkInView(t){Ye.lastNetworkInView=t},async fetchTransactions(t){var e;if(!t)throw new Error("Transactions can't be fetched without an accountAddress");Ye.loading=!0;try{const s=await fe.fetchTransactions({account:t,cursor:Ye.next,chainId:(e=E.state.activeCaipNetwork)==null?void 0:e.caipNetworkId}),n=pa.filterSpamTransactions(s.data),r=pa.filterByConnectedChain(n),i=[...Ye.transactions,...r];Ye.loading=!1,Ye.transactions=i,Ye.transactionsByYear=pa.groupTransactionsByYearAndMonth(Ye.transactionsByYear,r),Ye.empty=i.length===0,Ye.next=s.next?s.next:void 0}catch{const n=E.state.activeChain;Ee.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:t,projectId:$.state.projectId,cursor:Ye.next,isSmartAccount:ls(n)===tt.ACCOUNT_TYPES.SMART_ACCOUNT}}),Ks.showError("Failed to fetch transactions"),Ye.loading=!1,Ye.empty=!0,Ye.next=void 0}},groupTransactionsByYearAndMonth(t={},e=[]){const s=t;return e.forEach(n=>{const r=new Date(n.metadata.minedAt).getFullYear(),i=new Date(n.metadata.minedAt).getMonth(),o=s[r]??{},c=(o[i]??[]).filter(l=>l.id!==n.id);s[r]={...o,[i]:[...c,n].sort((l,d)=>new Date(d.metadata.minedAt).getTime()-new Date(l.metadata.minedAt).getTime())}}),s},filterSpamTransactions(t){return t.filter(e=>{var n;return!((n=e.transfers)==null?void 0:n.every(r=>{var i;return((i=r.nft_info)==null?void 0:i.flags.is_spam)===!0}))})},filterByConnectedChain(t){var n;const e=(n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId;return t.filter(r=>r.metadata.chain===e)},clearCursor(){Ye.next=void 0},resetTransactions(){Ye.transactions=[],Ye.transactionsByYear={},Ye.lastNetworkInView=void 0,Ye.loading=!1,Ye.empty=!1,Ye.next=void 0}},pa=As(Xv,"API_ERROR"),Se=Ge({connections:new Map,recentConnections:new Map,isSwitchingConnection:!1,wcError:!1,wcFetchingUri:!1,buffering:!1,status:"disconnected"});let nr;const Qv={state:Se,subscribe(t){return _t(Se,()=>t(Se))},subscribeKey(t,e){return At(Se,t,e)},_getClient(){return Se._client},setClient(t){Se._client=Qi(t)},initialize(t){const e=t.filter(s=>!!s.namespace).map(s=>s.namespace);G.syncStorageConnections(e)},syncStorageConnections(t){const e=F.getConnections(),s=t??Array.from(E.state.chains.keys());for(const n of s){const r=e[n]??[],i=new Map(Se.recentConnections);i.set(n,r),Se.recentConnections=i}},getConnections(t){return t?Se.connections.get(t)??[]:[]},hasAnyConnection(t){const e=G.state.connections;return Array.from(e.values()).flatMap(s=>s).some(({connectorId:s})=>s===t)},async connectWalletConnect({cache:t="auto"}={}){var s,n,r,i;Se.wcFetchingUri=!0;const e=X.isTelegram()||X.isSafari()&&X.isIos();if(t==="always"||t==="auto"&&e){if(nr){await nr,nr=void 0;return}if(!X.isPairingExpired(Se==null?void 0:Se.wcPairingExpiry)){const o=Se.wcUri;Se.wcUri=o;return}nr=(n=(s=G._getClient())==null?void 0:s.connectWalletConnect)==null?void 0:n.call(s).catch(()=>{}),G.state.status="connecting",await nr,nr=void 0,Se.wcPairingExpiry=void 0,G.state.status="connected"}else await((i=(r=G._getClient())==null?void 0:r.connectWalletConnect)==null?void 0:i.call(r))},async connectExternal(t,e,s=!0){var o,a,c;const n=await((a=(o=G._getClient())==null?void 0:o.connectExternal)==null?void 0:a.call(o,t));s&&E.setActiveNamespace(e);const r=z.state.allConnectors.find(l=>l.id===(t==null?void 0:t.id)),i=t.type==="AUTH"?"email":"browser";return Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",properties:{method:i,name:(r==null?void 0:r.name)||"Unknown",view:ue.state.view,walletRank:(c=r==null?void 0:r.explorerWallet)==null?void 0:c.order}}),n},async reconnectExternal(t){var s,n;await((n=(s=G._getClient())==null?void 0:s.reconnectExternal)==null?void 0:n.call(s,t));const e=t.chain||E.state.activeChain;e&&z.setConnectorId(t.id,e)},async setPreferredAccountType(t,e){var n;if(!e)return;Ne.setLoading(!0,E.state.activeChain);const s=z.getAuthConnector();s&&(E.setAccountProp("preferredAccountType",t,e),await s.provider.setPreferredAccount(t),F.setPreferredAccountTypes(Object.entries(E.state.chains).reduce((r,[i,o])=>{const a=i,c=ls(a);return c!==void 0&&(r[a]=c),r},{})),await G.reconnectExternal(s),Ne.setLoading(!1,E.state.activeChain),Ee.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:t,network:((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}}))},async signMessage(t){var e;return(e=G._getClient())==null?void 0:e.signMessage(t)},parseUnits(t,e){var s;return(s=G._getClient())==null?void 0:s.parseUnits(t,e)},formatUnits(t,e){var s;return(s=G._getClient())==null?void 0:s.formatUnits(t,e)},updateBalance(t){var e;return(e=G._getClient())==null?void 0:e.updateBalance(t)},async sendTransaction(t){var e;return(e=G._getClient())==null?void 0:e.sendTransaction(t)},async getCapabilities(t){var e;return(e=G._getClient())==null?void 0:e.getCapabilities(t)},async grantPermissions(t){var e;return(e=G._getClient())==null?void 0:e.grantPermissions(t)},async walletGetAssets(t){var e;return((e=G._getClient())==null?void 0:e.walletGetAssets(t))??{}},async estimateGas(t){var e;return(e=G._getClient())==null?void 0:e.estimateGas(t)},async writeContract(t){var e;return(e=G._getClient())==null?void 0:e.writeContract(t)},async getEnsAddress(t){var e;return(e=G._getClient())==null?void 0:e.getEnsAddress(t)},async getEnsAvatar(t){var e;return(e=G._getClient())==null?void 0:e.getEnsAvatar(t)},checkInstalled(t){var e,s;return((s=(e=G._getClient())==null?void 0:e.checkInstalled)==null?void 0:s.call(e,t))||!1},resetWcConnection(){Se.wcUri=void 0,Se.wcPairingExpiry=void 0,Se.wcLinking=void 0,Se.recentWallet=void 0,Se.wcFetchingUri=!1,Se.status="disconnected",pa.resetTransactions(),F.deleteWalletConnectDeepLink(),F.deleteRecentWallet(),ds.set({connectingWallet:void 0})},resetUri(){Se.wcUri=void 0,Se.wcPairingExpiry=void 0,nr=void 0,Se.wcFetchingUri=!1,ds.set({connectingWallet:void 0})},finalizeWcConnection(t){var n,r;const{wcLinking:e,recentWallet:s}=G.state;e&&F.setWalletConnectDeepLink(e),s&&F.setAppKitRecent(s),t&&Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:t,properties:{method:e?"mobile":"qrcode",name:((r=(n=ue.state.data)==null?void 0:n.wallet)==null?void 0:r.name)||"Unknown",view:ue.state.view,walletRank:s==null?void 0:s.order}})},setWcBasic(t){Se.wcBasic=t},setUri(t){Se.wcUri=t,Se.wcFetchingUri=!1,Se.wcPairingExpiry=X.getPairingExpiry()},setWcLinking(t){Se.wcLinking=t},setWcError(t){Se.wcError=t,Se.wcFetchingUri=!1,Se.buffering=!1},setRecentWallet(t){Se.recentWallet=t},setBuffering(t){Se.buffering=t},setStatus(t){Se.status=t},setIsSwitchingConnection(t){Se.isSwitchingConnection=t},async disconnect({id:t,namespace:e,initialDisconnect:s}={}){var n;try{await((n=G._getClient())==null?void 0:n.disconnect({id:t,chainNamespace:e,initialDisconnect:s}))}catch(r){throw new Tr("Failed to disconnect","INTERNAL_SDK_ERROR",r)}},async disconnectConnector({id:t,namespace:e}){var s;try{await((s=G._getClient())==null?void 0:s.disconnectConnector({id:t,namespace:e}))}catch(n){throw new Tr("Failed to disconnect connector","INTERNAL_SDK_ERROR",n)}},setConnections(t,e){const s=new Map(Se.connections);s.set(e,t),Se.connections=s},async handleAuthAccountSwitch({address:t,namespace:e}){var i,o;const s=E.getAccountData(e),n=(o=(i=s==null?void 0:s.user)==null?void 0:i.accounts)==null?void 0:o.find(a=>a.type==="smartAccount"),r=n&&n.address.toLowerCase()===t.toLowerCase()&&Ci.canSwitchToSmartAccount(e)?"smartAccount":"eoa";await G.setPreferredAccountType(r,e)},async handleActiveConnection({connection:t,namespace:e,address:s}){const n=z.getConnectorById(t.connectorId),r=t.connectorId===U.CONNECTOR_ID.AUTH;if(!n)throw new Error(`No connector found for connection: ${t.connectorId}`);if(r)s&&await G.handleAuthAccountSwitch({address:s,namespace:e});else{const i=await G.connectExternal({id:n.id,type:n.type,provider:n.provider,address:s,chain:e},e);return i==null?void 0:i.address}return s},async handleDisconnectedConnection({connection:t,namespace:e,address:s,closeModalOnConnect:n}){var l,d;const r=z.getConnectorById(t.connectorId),i=(d=(l=t.auth)==null?void 0:l.name)==null?void 0:d.toLowerCase(),o=t.connectorId===U.CONNECTOR_ID.AUTH,a=t.connectorId===U.CONNECTOR_ID.WALLET_CONNECT;if(!r)throw new Error(`No connector found for connection: ${t.connectorId}`);let c;if(o)if(i&&Ci.isSocialProvider(i)){const{address:u}=await Ci.connectSocial({social:i,closeModalOnConnect:n,onOpenFarcaster(){Ne.open({view:"ConnectingFarcaster"})},onConnect(){ue.replace("ProfileWallets")}});c=u}else{const{address:u}=await Ci.connectEmail({closeModalOnConnect:n,onOpen(){Ne.open({view:"EmailLogin"})},onConnect(){ue.replace("ProfileWallets")}});c=u}else if(a){const{address:u}=await Ci.connectWalletConnect({walletConnect:!0,connector:r,closeModalOnConnect:n,onOpen(h){const p=h?"AllWallets":"ConnectingWalletConnect";Ne.state.open?ue.push(p):Ne.open({view:p})},onConnect(){ue.replace("ProfileWallets")}});c=u}else{const u=await G.connectExternal({id:r.id,type:r.type,provider:r.provider,chain:e},e);u&&(c=u.address)}return o&&s&&await G.handleAuthAccountSwitch({address:s,namespace:e}),c},async switchConnection({connection:t,address:e,namespace:s,closeModalOnConnect:n,onChange:r}){var c;let i;const o=(c=E.getAccountData(s))==null?void 0:c.caipAddress;if(o){const{address:l}=dt.parseCaipAddress(o);i=l}const a=$a.getConnectionStatus(t,s);switch(a){case"connected":case"active":{const l=await G.handleActiveConnection({connection:t,namespace:s,address:e});if(i&&l){const d=l.toLowerCase()!==i.toLowerCase();r==null||r({address:l,namespace:s,hasSwitchedAccount:d,hasSwitchedWallet:a==="active"})}break}case"disconnected":{const l=await G.handleDisconnectedConnection({connection:t,namespace:s,address:e,closeModalOnConnect:n});l&&(r==null||r({address:l,namespace:s,hasSwitchedAccount:!0,hasSwitchedWallet:!0}));break}default:throw new Error(`Invalid connection status: ${a}`)}}},G=As(Qv),Nc={createBalance(t,e){const s={name:t.metadata.name||"",symbol:t.metadata.symbol||"",decimals:t.metadata.decimals||0,value:t.metadata.value||0,price:t.metadata.price||0,iconUrl:t.metadata.iconUrl||""};return{name:s.name,symbol:s.symbol,chainId:e,address:t.address==="native"?void 0:this.convertAddressToCAIP10Address(t.address,e),value:s.value,price:s.price,quantity:{decimals:s.decimals.toString(),numeric:this.convertHexToBalance({hex:t.balance,decimals:s.decimals})},iconUrl:s.iconUrl}},convertHexToBalance({hex:t,decimals:e}){return If(BigInt(t),e)},convertAddressToCAIP10Address(t,e){return`${e}:${t}`},createCAIP2ChainId(t,e){return`${e}:${parseInt(t,16)}`},getChainIdHexFromCAIP2ChainId(t){const e=t.split(":");if(e.length<2||!e[1])return"0x0";const s=e[1],n=parseInt(s,10);return isNaN(n)?"0x0":`0x${n.toString(16)}`},isWalletGetAssetsResponse(t){return typeof t!="object"||t===null?!1:Object.values(t).every(e=>Array.isArray(e)&&e.every(s=>this.isValidAsset(s)))},isValidAsset(t){return typeof t=="object"&&t!==null&&typeof t.address=="string"&&typeof t.balance=="string"&&(t.type==="ERC20"||t.type==="NATIVE")&&typeof t.metadata=="object"&&t.metadata!==null&&typeof t.metadata.name=="string"&&typeof t.metadata.symbol=="string"&&typeof t.metadata.decimals=="number"&&typeof t.metadata.price=="number"&&typeof t.metadata.iconUrl=="string"}};let Tc;async function Gu(){if(!Tc){const{createPublicClient:t,http:e,defineChain:s}=await Dt(async()=>{const{createPublicClient:n,http:r,defineChain:i}=await import("./index-r-2ydifG.js");return{createPublicClient:n,http:r,defineChain:i}},__vite__mapDeps([0,1,2,3,4,5]));Tc={createPublicClient:t,http:e,defineChain:s}}return Tc}const xl={getBlockchainApiRpcUrl(t,e){const s=new URL("https://rpc.walletconnect.org/v1/");return s.searchParams.set("chainId",t),s.searchParams.set("projectId",e),s.toString()},async getViemChain(t){const{defineChain:e}=await Gu(),{chainId:s}=dt.parseCaipNetworkId(t.caipNetworkId);return e({...t,id:Number(s)})},async createViemPublicClient(t){const{createPublicClient:e,http:s}=await Gu(),n=$.state.projectId,r=await xl.getViemChain(t);if(!r)throw new Error(`Chain ${t.caipNetworkId} not found in viem/chains`);return e({chain:r,transport:s(xl.getBlockchainApiRpcUrl(t.caipNetworkId,n))})}},Rd={async getMyTokensWithBalance(t){var a;const e=(a=E.getAccountData())==null?void 0:a.address,s=E.state.activeCaipNetwork,n=z.getConnectorId("eip155")===U.CONNECTOR_ID.AUTH;if(!e||!s)return[];const r=`${s.caipNetworkId}:${e}`,i=F.getBalanceCacheForCaipAddress(r);if(i)return i.balances;if(s.chainNamespace===U.CHAIN.EVM&&n){const c=await this.getEIP155Balances(e,s);if(c)return this.filterLowQualityTokens(c)}const o=await fe.getBalance(e,s.caipNetworkId,t);return this.filterLowQualityTokens(o.balances)},async getEIP155Balances(t,e){var s,n;try{const r=Nc.getChainIdHexFromCAIP2ChainId(e.caipNetworkId),i=await G.getCapabilities(t);if(!((n=(s=i==null?void 0:i[r])==null?void 0:s.assetDiscovery)!=null&&n.supported))return null;const o=await G.walletGetAssets({account:t,chainFilter:[r]});if(!Nc.isWalletGetAssetsResponse(o))return null;const c=(o[r]||[]).map(l=>Nc.createBalance(l,e.caipNetworkId));return F.updateBalanceCache({caipAddress:`${e.caipNetworkId}:${t}`,balance:{balances:c},timestamp:Date.now()}),c}catch{return null}},filterLowQualityTokens(t){return t.filter(e=>e.quantity.decimals!=="0")},async fetchERC20Balance({caipAddress:t,assetAddress:e,caipNetwork:s}){const n=await xl.createViemPublicClient(s),{address:r}=dt.parseCaipAddress(t),[{result:i},{result:o},{result:a},{result:c}]=await n.multicall({contracts:[{address:e,functionName:"name",args:[],abi:Bo},{address:e,functionName:"symbol",args:[],abi:Bo},{address:e,functionName:"balanceOf",args:[r],abi:Bo},{address:e,functionName:"decimals",args:[],abi:Bo}]});return{name:i,symbol:o,decimals:c,balance:a&&c?If(a,c):"0"}}},Rc={adapters:{}},Zf={state:Rc,initialize(t){Rc.adapters={...t}},get(t){return Rc.adapters[t]}},Da={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0,sui:void 0,stacks:void 0,ton:void 0},qt=Ge({providers:{...Da},providerIds:{...Da}}),He={state:qt,subscribeKey(t,e){return At(qt,t,e)},subscribe(t){return _t(qt,()=>{t(qt)})},subscribeProviders(t){return _t(qt.providers,()=>t(qt.providers))},setProvider(t,e){t&&e&&(qt.providers[t]=Qi(e))},getProvider(t){if(t)return qt.providers[t]},setProviderId(t,e){e&&(qt.providerIds[t]=e)},getProviderId(t){if(t)return qt.providerIds[t]},reset(){qt.providers={...Da},qt.providerIds={...Da}},resetChain(t){qt.providers[t]=void 0,qt.providerIds[t]=void 0}},eC={async getTokenList(t){var n;const e=await fe.fetchSwapTokens({chainId:t});return((n=e==null?void 0:e.tokens)==null?void 0:n.map(r=>({...r,eip2612:!1,quantity:{decimals:"0",numeric:"0"},price:0,value:0})))||[]},async fetchGasPrice(){var e;const t=E.state.activeCaipNetwork;if(!t)return null;try{switch(t.chainNamespace){case"solana":const s=(e=await(G==null?void 0:G.estimateGas({chainNamespace:"solana"})))==null?void 0:e.toString();return{standard:s,fast:s,instant:s};case"eip155":default:return await fe.fetchGasPrice({chainId:t.caipNetworkId})}}catch{return null}},async fetchSwapAllowance({tokenAddress:t,userAddress:e,sourceTokenAmount:s,sourceTokenDecimals:n}){const r=await fe.fetchSwapAllowance({tokenAddress:t,userAddress:e});if(r!=null&&r.allowance&&s&&n){const i=G.parseUnits(s,n)||0;return BigInt(r.allowance)>=i}return!1},async getMyTokensWithBalance(t){const e=await Rd.getMyTokensWithBalance(t);return E.setAccountProp("tokenBalance",e,E.state.activeChain),this.mapBalancesToSwapTokens(e)},mapBalancesToSwapTokens(t){return(t==null?void 0:t.map(e=>({...e,address:e!=null&&e.address?e.address:Yf(),decimals:parseInt(e.quantity.decimals,10),logoUri:e.iconUrl,eip2612:!1})))||[]},async handleSwapError(t){var e,s;try{const n=t==null?void 0:t.cause;if(!(n!=null&&n.json))return;const r=await n.json(),i=(s=(e=r==null?void 0:r.reasons)==null?void 0:e[0])==null?void 0:s.description;return i!=null&&i.includes("insufficient liquidity")?"Insufficient liquidity":void 0}catch{return}}},xe=Ge({tokenBalances:[],loading:!1}),tC={state:xe,subscribe(t){return _t(xe,()=>t(xe))},subscribeKey(t,e){return At(xe,t,e)},setToken(t){t&&(xe.token=Qi(t))},setTokenAmount(t){xe.sendTokenAmount=t},setReceiverAddress(t){xe.receiverAddress=t},setReceiverProfileImageUrl(t){xe.receiverProfileImageUrl=t},setReceiverProfileName(t){xe.receiverProfileName=t},setNetworkBalanceInUsd(t){xe.networkBalanceInUSD=t},setLoading(t){xe.loading=t},getSdkEventProperties(t){var e,s;return{message:X.parseError(t),isSmartAccount:ls(E.state.activeChain)===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((e=xe.token)==null?void 0:e.symbol)||"",amount:xe.sendTokenAmount??0,network:((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||""}},async sendToken(){var t;try{switch(_e.setLoading(!0),(t=E.state.activeCaipNetwork)==null?void 0:t.chainNamespace){case"eip155":await _e.sendEvmToken();return;case"solana":await _e.sendSolanaToken();return;default:throw new Error("Unsupported chain")}}catch(e){throw mn.isUserRejectedRequestError(e)?new Pf(e):e}finally{_e.setLoading(!1)}},async sendEvmToken(){var s,n,r;const t=E.state.activeChain;if(!t)throw new Error("SendController:sendEvmToken - activeChainNamespace is required");const e=ls(t);if(!_e.state.sendTokenAmount||!_e.state.receiverAddress)throw new Error("An amount and receiver address are required");if(!_e.state.token)throw new Error("A token is required");if((s=_e.state.token)!=null&&s.address){Ee.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:_e.state.token.address,amount:_e.state.sendTokenAmount,network:((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}});const{hash:i}=await _e.sendERC20Token({receiverAddress:_e.state.receiverAddress,tokenAddress:_e.state.token.address,sendTokenAmount:_e.state.sendTokenAmount,decimals:_e.state.token.quantity.decimals});i&&(xe.hash=i)}else{Ee.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:_e.state.token.symbol||"",amount:_e.state.sendTokenAmount,network:((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||""}});const{hash:i}=await _e.sendNativeToken({receiverAddress:_e.state.receiverAddress,sendTokenAmount:_e.state.sendTokenAmount,decimals:_e.state.token.quantity.decimals});i&&(xe.hash=i)}},async fetchTokenBalance(t){var o,a,c;xe.loading=!0;const e=E.state.activeChain,s=(o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=E.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=((c=E.getAccountData(e))==null?void 0:c.caipAddress)??E.state.activeCaipAddress,i=r?X.getPlainAddress(r):void 0;if(xe.lastRetry&&!X.isAllowedRetry(xe.lastRetry,30*Ie.ONE_SEC_MS))return xe.loading=!1,[];try{if(i&&s&&n){const l=await Rd.getMyTokensWithBalance();return xe.tokenBalances=l,xe.lastRetry=void 0,l}}catch(l){xe.lastRetry=Date.now(),t==null||t(l),Ks.showError("Token Balance Unavailable")}finally{xe.loading=!1}return[]},fetchNetworkBalance(){if(xe.tokenBalances.length===0)return;const t=eC.mapBalancesToSwapTokens(xe.tokenBalances);if(!t)return;const e=t.find(s=>s.address===Yf());e&&(xe.networkBalanceInUSD=e?iw.multiply(e.quantity.numeric,e.price).toString():"0")},async sendNativeToken(t){var o,a,c,l;ue.pushTransactionStack({});const e=t.receiverAddress,s=(o=E.getAccountData())==null?void 0:o.address,n=G.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),i=await G.sendTransaction({chainNamespace:U.CHAIN.EVM,to:e,address:s,data:"0x",value:n??BigInt(0)});return Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:ls("eip155")===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((a=_e.state.token)==null?void 0:a.symbol)||"",amount:t.sendTokenAmount,network:((c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId)||"",hash:i||""}}),(l=G._getClient())==null||l.updateBalance("eip155"),_e.resetSend(),{hash:i}},async sendERC20Token(t){var n,r,i;ue.pushTransactionStack({onSuccess(){ue.replace("Account")}});const e=G.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),s=(n=E.getAccountData())==null?void 0:n.address;if(s&&t.sendTokenAmount&&t.receiverAddress&&t.tokenAddress){const o=X.getPlainAddress(t.tokenAddress);if(!o)throw new Error("SendController:sendERC20Token - tokenAddress is required");const a=await G.writeContract({fromAddress:s,tokenAddress:o,args:[t.receiverAddress,e??BigInt(0)],method:"transfer",abi:lw.getERC20Abi(o),chainNamespace:U.CHAIN.EVM});return Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:ls("eip155")===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((r=_e.state.token)==null?void 0:r.symbol)||"",amount:t.sendTokenAmount,network:((i=E.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)||"",hash:a||""}}),_e.resetSend(),{hash:a}}return{hash:void 0}},async sendSolanaToken(){var s,n,r;if(!_e.state.sendTokenAmount||!_e.state.receiverAddress)throw new Error("An amount and receiver address are required");ue.pushTransactionStack({onSuccess(){ue.replace("Account")}});let t;_e.state.token&&_e.state.token.address!==Ie.SOLANA_NATIVE_TOKEN_ADDRESS&&(X.isCaipAddress(_e.state.token.address)?t=X.getPlainAddress(_e.state.token.address):t=_e.state.token.address);const e=await G.sendTransaction({chainNamespace:"solana",tokenMint:t,to:_e.state.receiverAddress,value:_e.state.sendTokenAmount});e&&(xe.hash=e),(s=G._getClient())==null||s.updateBalance("solana"),Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:!1,token:((n=_e.state.token)==null?void 0:n.symbol)||"",amount:_e.state.sendTokenAmount,network:((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||"",hash:e||""}}),_e.resetSend()},resetSend(){xe.token=void 0,xe.sendTokenAmount=void 0,xe.receiverAddress=void 0,xe.receiverProfileImageUrl=void 0,xe.receiverProfileName=void 0,xe.loading=!1,xe.tokenBalances=[]}},_e=As(tC),Oc={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,user:void 0,preferredAccountType:void 0},Ko={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},Q=Ge({chains:_w(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{connectionControllerClient:void 0},isSwitchingNamespace:!1}),Jf={state:Q,subscribe(t){return _t(Q,()=>{t(Q)})},subscribeKey(t,e){return At(Q,t,e)},subscribeAccountStateProp(t,e,s){var r;const n=s||Q.activeChain;return n?At(((r=Q.chains.get(n))==null?void 0:r.accountState)||{},t,e):()=>{}},subscribeChainProp(t,e,s){let n;return _t(Q.chains,()=>{var i;const r=s||Q.activeChain;if(r){const o=(i=Q.chains.get(r))==null?void 0:i[t];n!==o&&(n=o,e(o))}})},initialize(t,e,s){const{chainId:n,namespace:r}=F.getActiveNetworkProps(),i=e==null?void 0:e.find(d=>d.id.toString()===(n==null?void 0:n.toString())),a=t.find(d=>(d==null?void 0:d.namespace)===r)||(t==null?void 0:t[0]),c=t.map(d=>d.namespace).filter(d=>d!==void 0),l=$.state.enableEmbedded?new Set([...c]):new Set([...(e==null?void 0:e.map(d=>d.chainNamespace))??[]]);((t==null?void 0:t.length)===0||!a)&&(Q.noAdapters=!0),Q.noAdapters||(Q.activeChain=a==null?void 0:a.namespace,Q.activeCaipNetwork=i,E.setChainNetworkData(a==null?void 0:a.namespace,{caipNetwork:i}),Q.activeChain&&ds.set({activeChain:a==null?void 0:a.namespace})),l.forEach(d=>{const u=e==null?void 0:e.filter(g=>g.chainNamespace===d),h=F.getPreferredAccountTypes()||{},p={...$.state.defaultAccountTypes,...h};E.state.chains.set(d,{namespace:d,networkState:Ge({...Ko,caipNetwork:u==null?void 0:u[0]}),accountState:Ge({...Oc,preferredAccountType:p[d]}),caipNetworks:u??[],...s}),E.setRequestedCaipNetworks(u??[],d)})},removeAdapter(t){var e,s;if(Q.activeChain===t){const n=Array.from(Q.chains.entries()).find(([r])=>r!==t);if(n){const r=(s=(e=n[1])==null?void 0:e.caipNetworks)==null?void 0:s[0];r&&E.setActiveCaipNetwork(r)}}Q.chains.delete(t)},addAdapter(t,{connectionControllerClient:e},s){if(!t.namespace)throw new Error("ChainController:addAdapter - adapter must have a namespace");Q.chains.set(t.namespace,{namespace:t.namespace,networkState:{...Ko,caipNetwork:s[0]},accountState:{...Oc},caipNetworks:s,connectionControllerClient:e}),E.setRequestedCaipNetworks((s==null?void 0:s.filter(n=>n.chainNamespace===t.namespace))??[],t.namespace)},addNetwork(t){var s;const e=Q.chains.get(t.chainNamespace);if(e){const n=[...e.caipNetworks||[]];(s=e.caipNetworks)!=null&&s.find(r=>r.id===t.id)||n.push(t),Q.chains.set(t.chainNamespace,{...e,caipNetworks:n}),E.setRequestedCaipNetworks(n,t.chainNamespace),z.filterByNamespace(t.chainNamespace,!0)}},removeNetwork(t,e){var n,r,i;const s=Q.chains.get(t);if(s){const o=((n=Q.activeCaipNetwork)==null?void 0:n.id)===e,a=[...((r=s.caipNetworks)==null?void 0:r.filter(c=>c.id!==e))||[]];o&&((i=s==null?void 0:s.caipNetworks)!=null&&i[0])&&E.setActiveCaipNetwork(s.caipNetworks[0]),Q.chains.set(t,{...s,caipNetworks:a}),E.setRequestedCaipNetworks(a||[],t),a.length===0&&z.filterByNamespace(t,!1)}},setAdapterNetworkState(t,e){const s=Q.chains.get(t);s&&(s.networkState={...s.networkState||Ko,...e},Q.chains.set(t,s))},setChainAccountData(t,e,s=!0){if(!t)throw new Error("Chain is required to update chain account data");const n=Q.chains.get(t);if(n){const r={...n.accountState||Oc,...e};Q.chains.set(t,{...n,accountState:r}),(Q.chains.size===1||Q.activeChain===t)&&e.caipAddress&&(Q.activeCaipAddress=e.caipAddress)}},setChainNetworkData(t,e){if(!t)return;const s=Q.chains.get(t);if(s){const n={...s.networkState||Ko,...e};Q.chains.set(t,{...s,networkState:n})}},setAccountProp(t,e,s,n=!0){E.setChainAccountData(s,{[t]:e},n)},setActiveNamespace(t){var n,r;Q.activeChain=t;const e=t?Q.chains.get(t):void 0,s=(n=e==null?void 0:e.networkState)==null?void 0:n.caipNetwork;s!=null&&s.id&&t&&(Q.activeCaipAddress=(r=e==null?void 0:e.accountState)==null?void 0:r.caipAddress,Q.activeCaipNetwork=s,E.setChainNetworkData(t,{caipNetwork:s}),F.setActiveCaipNetworkId(s==null?void 0:s.caipNetworkId),ds.set({activeChain:t,selectedNetworkId:s==null?void 0:s.caipNetworkId}))},setActiveCaipNetwork(t){var i,o;if(!t)return;const e=Q.activeChain===t.chainNamespace;e||E.setIsSwitchingNamespace(!0);const s=Q.chains.get(t.chainNamespace);Q.activeChain=t.chainNamespace,Q.activeCaipNetwork=t,E.setChainNetworkData(t.chainNamespace,{caipNetwork:t});let n=(i=s==null?void 0:s.accountState)==null?void 0:i.address;if(n)Q.activeCaipAddress=`${t.chainNamespace}:${t.id}:${n}`;else if(e&&Q.activeCaipAddress){const{address:a}=dt.parseCaipAddress(Q.activeCaipAddress);n=a,Q.activeCaipAddress=`${t.caipNetworkId}:${n}`}else Q.activeCaipAddress=void 0;E.setChainAccountData(t.chainNamespace,{address:n,caipAddress:Q.activeCaipAddress}),_e.resetSend(),ds.set({activeChain:Q.activeChain,selectedNetworkId:(o=Q.activeCaipNetwork)==null?void 0:o.caipNetworkId}),F.setActiveCaipNetworkId(t.caipNetworkId),!E.checkIfSupportedNetwork(t.chainNamespace)&&$.state.enableNetworkSwitch&&!$.state.allowUnsupportedChain&&!G.state.wcBasic&&E.showUnsupportedChainUI()},addCaipNetwork(t){var s;if(!t)return;const e=Q.chains.get(t.chainNamespace);e&&((s=e==null?void 0:e.caipNetworks)==null||s.push(t))},async switchActiveNamespace(t){var r;if(!t)return;const e=t!==E.state.activeChain,s=(r=E.getNetworkData(t))==null?void 0:r.caipNetwork,n=E.getCaipNetworkByNamespace(t,s==null?void 0:s.id);e&&n&&await E.switchActiveNetwork(n)},async switchActiveNetwork(t,{throwOnFailure:e=!1}={}){var o;const s=E.state.activeChain;if(!s)throw new Error("ChainController:switchActiveNetwork - namespace is required");const n=He.getProviderId(Q.activeChain)==="AUTH",r=(o=E.getAccountData(s))==null?void 0:o.address,i=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(t.chainNamespace);try{if(r&&t.chainNamespace===s||n&&i){const a=Zf.get(t.chainNamespace);if(!a)throw new Error("Adapter not found");await a.switchNetwork({caipNetwork:t})}E.setActiveCaipNetwork(t)}catch(a){if(e)throw a}Ee.sendEvent({type:"track",event:"SWITCH_NETWORK",properties:{network:t.caipNetworkId}})},getConnectionControllerClient(t){const e=t||Q.activeChain;if(!e)throw new Error("Chain is required to get connection controller client");const s=Q.chains.get(e);if(!(s!=null&&s.connectionControllerClient))throw new Error("ConnectionController client not set");return s.connectionControllerClient},getNetworkProp(t,e){var n;const s=(n=Q.chains.get(e))==null?void 0:n.networkState;if(s)return s[t]},getRequestedCaipNetworks(t){const e=Q.chains.get(t),{approvedCaipNetworkIds:s=[],requestedCaipNetworks:n=[]}=(e==null?void 0:e.networkState)||{};return X.sortRequestedNetworks(s,n).filter(o=>o==null?void 0:o.id)},getAllRequestedCaipNetworks(){const t=[];return Q.chains.forEach(e=>{if(!e.namespace)throw new Error("ChainController:getAllRequestedCaipNetworks - chainAdapter must have a namespace");const s=E.getRequestedCaipNetworks(e.namespace);t.push(...s)}),t},setRequestedCaipNetworks(t,e){E.setAdapterNetworkState(e,{requestedCaipNetworks:t});const n=E.getAllRequestedCaipNetworks().map(i=>i.chainNamespace),r=Array.from(new Set(n));z.filterByNamespaces(r)},getAllApprovedCaipNetworkIds(){const t=[];return Q.chains.forEach(e=>{if(!e.namespace)throw new Error("ChainController:getAllApprovedCaipNetworkIds - chainAdapter must have a namespace");const s=E.getApprovedCaipNetworkIds(e.namespace);t.push(...s)}),t},getActiveCaipNetwork(t){var e,s;return t?(s=(e=Q.chains.get(t))==null?void 0:e.networkState)==null?void 0:s.caipNetwork:Q.activeCaipNetwork},getActiveCaipAddress(){return Q.activeCaipAddress},getApprovedCaipNetworkIds(t){var n;const e=Q.chains.get(t);return((n=e==null?void 0:e.networkState)==null?void 0:n.approvedCaipNetworkIds)||[]},setApprovedCaipNetworksData(t,e){E.setAdapterNetworkState(t,e)},checkIfSupportedNetwork(t,e){var r;const s=e||((r=Q.activeCaipNetwork)==null?void 0:r.caipNetworkId),n=E.getRequestedCaipNetworks(t);return n.length?n==null?void 0:n.some(i=>i.caipNetworkId===s):!0},checkIfSupportedChainId(t){if(!Q.activeChain)return!0;const e=E.getRequestedCaipNetworks(Q.activeChain);return e==null?void 0:e.some(s=>s.id===t)},checkIfSmartAccountEnabled(){var n,r;const t=Nf.caipNetworkIdToNumber((n=Q.activeCaipNetwork)==null?void 0:n.caipNetworkId);if(!Q.activeChain||!t)return!1;const s=((r=lt.get(oe.SMART_ACCOUNT_ENABLED_NETWORKS))==null?void 0:r.split(","))||[];return!!(s!=null&&s.includes(t.toString()))},showUnsupportedChainUI(){Ne.open({view:"UnsupportedChain"})},checkIfNamesSupported(){const t=Q.activeCaipNetwork;return!!(t!=null&&t.chainNamespace&&Ie.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(t.chainNamespace))},resetNetwork(t){E.setAdapterNetworkState(t,{approvedCaipNetworkIds:void 0,supportsAllNetworks:!0})},resetAccount(t){var r,i;const e=t;if(!e)throw new Error("Chain is required to set account prop");const s=(i=(r=E.state.chains.get(e))==null?void 0:r.accountState)==null?void 0:i.preferredAccountType,n=$.state.defaultAccountTypes[e];Q.activeCaipAddress=void 0,E.setChainAccountData(e,{smartAccountDeployed:!1,currentTab:0,caipAddress:void 0,address:void 0,balance:void 0,balanceSymbol:void 0,profileName:void 0,profileImage:void 0,addressExplorerUrl:void 0,tokenBalance:[],connectedWalletInfo:void 0,preferredAccountType:n||s,socialProvider:void 0,socialWindow:void 0,farcasterUrl:void 0,user:void 0,status:"disconnected"}),z.removeConnectorId(e)},setIsSwitchingNamespace(t){Q.isSwitchingNamespace=t},getFirstCaipNetworkSupportsAuthConnector(){var s,n;const t=[];let e;if(Q.chains.forEach(r=>{U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(i=>i===r.namespace)&&r.namespace&&t.push(r.namespace)}),t.length>0){const r=t[0];return e=r?(n=(s=Q.chains.get(r))==null?void 0:s.caipNetworks)==null?void 0:n[0]:void 0,e}},getAccountData(t){var s;const e=t||Q.activeChain;if(e)return(s=E.state.chains.get(e))==null?void 0:s.accountState},getNetworkData(t){var s;const e=t||Q.activeChain;if(e)return(s=E.state.chains.get(e))==null?void 0:s.networkState},getCaipNetworkByNamespace(t,e){var r,i,o;if(!t)return;const s=E.state.chains.get(t),n=(r=s==null?void 0:s.caipNetworks)==null?void 0:r.find(a=>a.id.toString()===(e==null?void 0:e.toString()));return n||((i=s==null?void 0:s.networkState)==null?void 0:i.caipNetwork)||((o=s==null?void 0:s.caipNetworks)==null?void 0:o[0])},getRequestedCaipNetworkIds(){const t=z.state.filterByNamespace;return(t?[Q.chains.get(t)]:Array.from(Q.chains.values())).flatMap(s=>(s==null?void 0:s.caipNetworks)||[]).map(s=>s.caipNetworkId)},getCaipNetworks(t){return t?E.getRequestedCaipNetworks(t):E.getAllRequestedCaipNetworks()},getCaipNetworkById(t,e){return Jf.getCaipNetworks(e).find(s=>s.id.toString()===t.toString()||s.caipNetworkId.toString()===t.toString())},setLastConnectedSIWECaipNetwork(t){Q.lastConnectedSIWECaipNetwork=t},getLastConnectedSIWECaipNetwork(){return Q.lastConnectedSIWECaipNetwork},async fetchTokenBalance(t){var o,a;const e=E.getAccountData();if(!e)return[];const s=(o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=E.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=E.state.activeCaipAddress,i=r?X.getPlainAddress(r):void 0;if(E.setAccountProp("balanceLoading",!0,n),e.lastRetry&&!X.isAllowedRetry(e.lastRetry,30*Ie.ONE_SEC_MS))return E.setAccountProp("balanceLoading",!1,n),[];try{if(i&&s&&n){const c=await Rd.getMyTokensWithBalance();return E.setAccountProp("tokenBalance",c,n),E.setAccountProp("lastRetry",void 0,n),E.setAccountProp("balanceLoading",!1,n),c}}catch(c){E.setAccountProp("lastRetry",Date.now(),n),t==null||t(c),Ks.showError("Token Balance Unavailable")}finally{E.setAccountProp("balanceLoading",!1,n)}return[]},isCaipNetworkDisabled(t){var c;const e=t.chainNamespace,s=!!((c=E.getAccountData(e))!=null&&c.caipAddress),n=E.getAllApprovedCaipNetworkIds(),r=E.getNetworkProp("supportsAllNetworks",e)!==!1,i=z.getConnectorId(e),o=z.getAuthConnector(),a=i===U.CONNECTOR_ID.AUTH&&o;return!s||r||a?!1:!(n!=null&&n.includes(t.caipNetworkId))}},E=As(Jf),sC={onSwitchNetwork({network:t,ignoreSwitchConfirmation:e=!1}){var h,p;const s=E.state.activeCaipNetwork,n=E.state.activeChain,r=ue.state.data;if(t.id===(s==null?void 0:s.id))return;const o=!!((h=E.getAccountData(n))!=null&&h.address),a=!!((p=E.getAccountData(t.chainNamespace))!=null&&p.address),c=t.chainNamespace!==n,d=z.getConnectorId(n)===U.CONNECTOR_ID.AUTH,u=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(g=>g===t.chainNamespace);e||d&&u?ue.push("SwitchNetwork",{...r,network:t}):o&&c&&!a?ue.push("SwitchActiveChain",{switchToChain:t.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:t}):ue.push("SwitchNetwork",{...r,network:t})}},Wt=Ge({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),nC={state:Wt,subscribe(t){return _t(Wt,()=>t(Wt))},subscribeKey(t,e){return At(Wt,t,e)},async open(t){var o,a;const e=t==null?void 0:t.namespace,s=E.state.activeChain,n=e&&e!==s,r=(o=E.getAccountData(t==null?void 0:t.namespace))==null?void 0:o.caipAddress,i=E.state.noAdapters;if(G.state.wcBasic?te.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1}):await te.prefetch(),z.setFilterByNamespace(t==null?void 0:t.namespace),Ne.setLoading(!0,e),e&&n){const c=((a=E.getNetworkData(e))==null?void 0:a.caipNetwork)||E.getRequestedCaipNetworks(e)[0];c&&(i?(await E.switchActiveNetwork(c),ue.push("ConnectingWalletConnectBasic")):sC.onSwitchNetwork({network:c,ignoreSwitchConfirmation:!0}))}else $.state.manualWCControl||i&&!r?X.isMobile()?ue.reset("AllWallets"):ue.reset("ConnectingWalletConnectBasic"):t!=null&&t.view?ue.reset(t.view,t.data):r?ue.reset("Account"):ue.reset("Connect");Wt.open=!0,ds.set({open:!0}),Ee.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!r}})},close(){const t=$.state.enableEmbedded,e=!!E.state.activeCaipAddress;Wt.open&&Ee.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:e}}),Wt.open=!1,ue.reset("Connect"),Ne.clearLoading(),t?e?ue.replace("Account"):ue.push("Connect"):ds.set({open:!1}),G.resetUri()},setLoading(t,e){e&&Wt.loadingNamespaceMap.set(e,t),Wt.loading=t,ds.set({loading:t})},clearLoading(){Wt.loadingNamespaceMap.clear(),Wt.loading=!1,ds.set({loading:!1})},shake(){Wt.shake||(Wt.shake=!0,setTimeout(()=>{Wt.shake=!1},500))}},Ne=As(nC),ji={id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},kl={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},rC={providers:kf,selectedProvider:null,error:null,purchaseCurrency:ji,paymentCurrency:kl,purchaseCurrencies:[ji],paymentCurrencies:[],quotesLoading:!1},ke=Ge(rC),iC={state:ke,subscribe(t){return _t(ke,()=>t(ke))},subscribeKey(t,e){return At(ke,t,e)},setSelectedProvider(t){var e,s;if(t&&t.name==="meld"){const n=E.state.activeChain,r=n===U.CHAIN.SOLANA?"SOL":"USDC",i=n?((s=(e=E.state.chains.get(n))==null?void 0:e.accountState)==null?void 0:s.address)??"":"",o=new URL(t.url);o.searchParams.append("publicKey",Aw),o.searchParams.append("destinationCurrencyCode",r),o.searchParams.append("walletAddress",i),o.searchParams.append("externalCustomerId",$.state.projectId),ke.selectedProvider={...t,url:o.toString()}}else ke.selectedProvider=t},setOnrampProviders(t){if(Array.isArray(t)&&t.every(e=>typeof e=="string")){const e=t,s=kf.filter(n=>e.includes(n.name));ke.providers=s}else ke.providers=[]},setPurchaseCurrency(t){ke.purchaseCurrency=t},setPaymentCurrency(t){ke.paymentCurrency=t},setPurchaseAmount(t){Ul.state.purchaseAmount=t},setPaymentAmount(t){Ul.state.paymentAmount=t},async getAvailableCurrencies(){const t=await fe.getOnrampOptions();ke.purchaseCurrencies=t.purchaseCurrencies,ke.paymentCurrencies=t.paymentCurrencies,ke.paymentCurrency=t.paymentCurrencies[0]||kl,ke.purchaseCurrency=t.purchaseCurrencies[0]||ji,await te.fetchCurrencyImages(t.paymentCurrencies.map(e=>e.id)),await te.fetchTokenImages(t.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){var t,e;ke.quotesLoading=!0;try{const s=await fe.getOnrampQuote({purchaseCurrency:ke.purchaseCurrency,paymentCurrency:ke.paymentCurrency,amount:((t=ke.paymentAmount)==null?void 0:t.toString())||"0",network:(e=ke.purchaseCurrency)==null?void 0:e.symbol});return ke.quotesLoading=!1,ke.purchaseAmount=Number(s==null?void 0:s.purchaseAmount.amount),s}catch(s){return ke.error=s.message,ke.quotesLoading=!1,null}finally{ke.quotesLoading=!1}},resetState(){ke.selectedProvider=null,ke.error=null,ke.purchaseCurrency=ji,ke.paymentCurrency=kl,ke.purchaseCurrencies=[ji],ke.paymentCurrencies=[],ke.paymentAmount=void 0,ke.purchaseAmount=void 0,ke.quotesLoading=!1}},Ul=As(iC);function oC(t){return!t||typeof t.then!="function"?Promise.resolve(t):t}function ft(t,...e){try{return oC(t(...e))}catch(s){return Promise.reject(s)}}function aC(t){const e=typeof t;return t===null||e!=="object"&&e!=="function"}function cC(t){const e=Object.getPrototypeOf(t);return!e||e.isPrototypeOf(Object)}function fa(t){if(aC(t))return String(t);if(cC(t)||Array.isArray(t))return JSON.stringify(t);if(typeof t.toJSON=="function")return fa(t.toJSON());throw new Error("[unstorage] Cannot stringify value!")}const $l="base64:";function lC(t){return typeof t=="string"?t:$l+hC(t)}function dC(t){return typeof t!="string"||!t.startsWith($l)?t:uC(t.slice($l.length))}function uC(t){return globalThis.Buffer?Buffer.from(t,"base64"):Uint8Array.from(globalThis.atob(t),e=>e.codePointAt(0))}function hC(t){return globalThis.Buffer?Buffer.from(t).toString("base64"):globalThis.btoa(String.fromCodePoint(...t))}function zt(t){var e;return t&&((e=t.split("?")[0])==null?void 0:e.replace(/[/\\]/g,":").replace(/:+/g,":").replace(/^:|:$/g,""))||""}function pC(...t){return zt(t.join(":"))}function Go(t){return t=zt(t),t?t+":":""}function fC(t,e){if(e===void 0)return!0;let s=0,n=t.indexOf(":");for(;n>-1;)s++,n=t.indexOf(":",n+1);return s<=e}function gC(t,e){return e?t.startsWith(e)&&t[t.length-1]!=="$":t[t.length-1]!=="$"}const mC="memory",yC=()=>{const t=new Map;return{name:mC,getInstance:()=>t,hasItem(e){return t.has(e)},getItem(e){return t.get(e)??null},getItemRaw(e){return t.get(e)??null},setItem(e,s){t.set(e,s)},setItemRaw(e,s){t.set(e,s)},removeItem(e){t.delete(e)},getKeys(){return[...t.keys()]},clear(){t.clear()},dispose(){t.clear()}}};function wC(t={}){const e={mounts:{"":t.driver||yC()},mountpoints:[""],watching:!1,watchListeners:[],unwatch:{}},s=l=>{for(const d of e.mountpoints)if(l.startsWith(d))return{base:d,relativeKey:l.slice(d.length),driver:e.mounts[d]};return{base:"",relativeKey:l,driver:e.mounts[""]}},n=(l,d)=>e.mountpoints.filter(u=>u.startsWith(l)||d&&l.startsWith(u)).map(u=>({relativeBase:l.length>u.length?l.slice(u.length):void 0,mountpoint:u,driver:e.mounts[u]})),r=(l,d)=>{if(e.watching){d=zt(d);for(const u of e.watchListeners)u(l,d)}},i=async()=>{if(!e.watching){e.watching=!0;for(const l in e.mounts)e.unwatch[l]=await Yu(e.mounts[l],r,l)}},o=async()=>{if(e.watching){for(const l in e.unwatch)await e.unwatch[l]();e.unwatch={},e.watching=!1}},a=(l,d,u)=>{const h=new Map,p=g=>{let f=h.get(g.base);return f||(f={driver:g.driver,base:g.base,items:[]},h.set(g.base,f)),f};for(const g of l){const f=typeof g=="string",y=zt(f?g:g.key),_=f?void 0:g.value,S=f||!g.options?d:{...d,...g.options},v=s(y);p(v).items.push({key:y,value:_,relativeKey:v.relativeKey,options:S})}return Promise.all([...h.values()].map(g=>u(g))).then(g=>g.flat())},c={hasItem(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return ft(h.hasItem,u,d)},getItem(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return ft(h.getItem,u,d).then(p=>Lo(p))},getItems(l,d={}){return a(l,d,u=>u.driver.getItems?ft(u.driver.getItems,u.items.map(h=>({key:h.relativeKey,options:h.options})),d).then(h=>h.map(p=>({key:pC(u.base,p.key),value:Lo(p.value)}))):Promise.all(u.items.map(h=>ft(u.driver.getItem,h.relativeKey,h.options).then(p=>({key:h.key,value:Lo(p)})))))},getItemRaw(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return h.getItemRaw?ft(h.getItemRaw,u,d):ft(h.getItem,u,d).then(p=>dC(p))},async setItem(l,d,u={}){if(d===void 0)return c.removeItem(l);l=zt(l);const{relativeKey:h,driver:p}=s(l);p.setItem&&(await ft(p.setItem,h,fa(d),u),p.watch||r("update",l))},async setItems(l,d){await a(l,d,async u=>{if(u.driver.setItems)return ft(u.driver.setItems,u.items.map(h=>({key:h.relativeKey,value:fa(h.value),options:h.options})),d);u.driver.setItem&&await Promise.all(u.items.map(h=>ft(u.driver.setItem,h.relativeKey,fa(h.value),h.options)))})},async setItemRaw(l,d,u={}){if(d===void 0)return c.removeItem(l,u);l=zt(l);const{relativeKey:h,driver:p}=s(l);if(p.setItemRaw)await ft(p.setItemRaw,h,d,u);else if(p.setItem)await ft(p.setItem,h,lC(d),u);else return;p.watch||r("update",l)},async removeItem(l,d={}){typeof d=="boolean"&&(d={removeMeta:d}),l=zt(l);const{relativeKey:u,driver:h}=s(l);h.removeItem&&(await ft(h.removeItem,u,d),(d.removeMeta||d.removeMata)&&await ft(h.removeItem,u+"$",d),h.watch||r("remove",l))},async getMeta(l,d={}){typeof d=="boolean"&&(d={nativeOnly:d}),l=zt(l);const{relativeKey:u,driver:h}=s(l),p=Object.create(null);if(h.getMeta&&Object.assign(p,await ft(h.getMeta,u,d)),!d.nativeOnly){const g=await ft(h.getItem,u+"$",d).then(f=>Lo(f));g&&typeof g=="object"&&(typeof g.atime=="string"&&(g.atime=new Date(g.atime)),typeof g.mtime=="string"&&(g.mtime=new Date(g.mtime)),Object.assign(p,g))}return p},setMeta(l,d,u={}){return this.setItem(l+"$",d,u)},removeMeta(l,d={}){return this.removeItem(l+"$",d)},async getKeys(l,d={}){var y;l=Go(l);const u=n(l,!0);let h=[];const p=[];let g=!0;for(const _ of u){(y=_.driver.flags)!=null&&y.maxDepth||(g=!1);const S=await ft(_.driver.getKeys,_.relativeBase,d);for(const v of S){const C=_.mountpoint+zt(v);h.some(R=>C.startsWith(R))||p.push(C)}h=[_.mountpoint,...h.filter(v=>!v.startsWith(_.mountpoint))]}const f=d.maxDepth!==void 0&&!g;return p.filter(_=>(!f||fC(_,d.maxDepth))&&gC(_,l))},async clear(l,d={}){l=Go(l),await Promise.all(n(l,!1).map(async u=>{if(u.driver.clear)return ft(u.driver.clear,u.relativeBase,d);if(u.driver.removeItem){const h=await u.driver.getKeys(u.relativeBase||"",d);return Promise.all(h.map(p=>u.driver.removeItem(p,d)))}}))},async dispose(){await Promise.all(Object.values(e.mounts).map(l=>Zu(l)))},async watch(l){return await i(),e.watchListeners.push(l),async()=>{e.watchListeners=e.watchListeners.filter(d=>d!==l),e.watchListeners.length===0&&await o()}},async unwatch(){e.watchListeners=[],await o()},mount(l,d){if(l=Go(l),l&&e.mounts[l])throw new Error(`already mounted at ${l}`);return l&&(e.mountpoints.push(l),e.mountpoints.sort((u,h)=>h.length-u.length)),e.mounts[l]=d,e.watching&&Promise.resolve(Yu(d,r,l)).then(u=>{e.unwatch[l]=u}).catch(console.error),c},async unmount(l,d=!0){var u,h;l=Go(l),!(!l||!e.mounts[l])&&(e.watching&&l in e.unwatch&&((h=(u=e.unwatch)[l])==null||h.call(u),delete e.unwatch[l]),d&&await Zu(e.mounts[l]),e.mountpoints=e.mountpoints.filter(p=>p!==l),delete e.mounts[l])},getMount(l=""){l=zt(l)+":";const d=s(l);return{driver:d.driver,base:d.base}},getMounts(l="",d={}){return l=zt(l),n(l,d.parents).map(h=>({driver:h.driver,base:h.mountpoint}))},keys:(l,d={})=>c.getKeys(l,d),get:(l,d={})=>c.getItem(l,d),set:(l,d,u={})=>c.setItem(l,d,u),has:(l,d={})=>c.hasItem(l,d),del:(l,d={})=>c.removeItem(l,d),remove:(l,d={})=>c.removeItem(l,d)};return c}function Yu(t,e,s){return t.watch?t.watch((n,r)=>e(n,s+r)):()=>{}}async function Zu(t){typeof t.dispose=="function"&&await ft(t.dispose)}var Ju={};const EC="idb-keyval";var bC=(t={})=>{const e=t.base&&t.base.length>0?`${t.base}:`:"",s=r=>e+r;let n;return t.dbName&&t.storeName&&(n=_y(t.dbName,t.storeName)),{name:EC,options:t,async hasItem(r){return!(typeof await iu(s(r),n)>"u")},async getItem(r){return await iu(s(r),n)??null},setItem(r,i){return Ny(s(r),i,n)},removeItem(r){return Iy(s(r),n)},getKeys(){return Sy(n)},clear(){return Ay(n)}}};const vC="WALLET_CONNECT_V2_INDEXED_DB",CC="keyvaluestorage";let _C=class{constructor(){this.indexedDb=wC({driver:bC({dbName:vC,storeName:CC})})}async getKeys(){return this.indexedDb.getKeys()}async getEntries(){return(await this.indexedDb.getItems(await this.indexedDb.getKeys())).map(e=>[e.key,e.value])}async getItem(e){const s=await this.indexedDb.getItem(e);if(s!==null)return s}async setItem(e,s){await this.indexedDb.setItem(e,Gi(s))}async removeItem(e){await this.indexedDb.removeItem(e)}};var Pc=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof Ju<"u"?Ju:typeof self<"u"?self:{},ga={exports:{}};(function(){let t;function e(){}t=e,t.prototype.getItem=function(s){return this.hasOwnProperty(s)?String(this[s]):null},t.prototype.setItem=function(s,n){this[s]=String(n)},t.prototype.removeItem=function(s){delete this[s]},t.prototype.clear=function(){const s=this;Object.keys(s).forEach(function(n){s[n]=void 0,delete s[n]})},t.prototype.key=function(s){return s=s||0,Object.keys(this)[s]},t.prototype.__defineGetter__("length",function(){return Object.keys(this).length}),typeof Pc<"u"&&Pc.localStorage?ga.exports=Pc.localStorage:typeof window<"u"&&window.localStorage?ga.exports=window.localStorage:ga.exports=new e})();function AC(t){var e;return[t[0],Ca((e=t[1])!=null?e:"")]}let SC=class{constructor(){this.localStorage=ga.exports}async getKeys(){return Object.keys(this.localStorage)}async getEntries(){return Object.entries(this.localStorage).map(AC)}async getItem(e){const s=this.localStorage.getItem(e);if(s!==null)return Ca(s)}async setItem(e,s){this.localStorage.setItem(e,Gi(s))}async removeItem(e){this.localStorage.removeItem(e)}};const IC="wc_storage_version",Xu=1,NC=async(t,e,s)=>{const n=IC,r=await e.getItem(n);if(r&&r>=Xu){s(e);return}const i=await t.getKeys();if(!i.length){s(e);return}const o=[];for(;i.length;){const a=i.shift();if(!a)continue;const c=a.toLowerCase();if(c.includes("wc@")||c.includes("walletconnect")||c.includes("wc_")||c.includes("wallet_connect")){const l=await t.getItem(a);await e.setItem(a,l),o.push(a)}}await e.setItem(n,Xu),s(e),TC(t,o)},TC=async(t,e)=>{e.length&&e.forEach(async s=>{await t.removeItem(s)})};let RC=class{constructor(){this.initialized=!1,this.setInitialized=s=>{this.storage=s,this.initialized=!0};const e=new SC;this.storage=e;try{const s=new _C;NC(e,s,this.setInitialized)}catch{this.initialized=!0}}async getKeys(){return await this.initialize(),this.storage.getKeys()}async getEntries(){return await this.initialize(),this.storage.getEntries()}async getItem(e){return await this.initialize(),this.storage.getItem(e)}async setItem(e,s){return await this.initialize(),this.storage.setItem(e,s)}async removeItem(e){return await this.initialize(),this.storage.removeItem(e)}async initialize(){this.initialized||await new Promise(e=>{const s=setInterval(()=>{this.initialized&&(clearInterval(s),e())},20)})}};var OC=Object.defineProperty,PC=(t,e,s)=>e in t?OC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Qu=(t,e,s)=>PC(t,typeof e!="symbol"?e+"":e,s);let xC=class extends fi{constructor(e){super(),this.opts=e,Qu(this,"protocol","wc"),Qu(this,"version",2)}};var kC=Object.defineProperty,UC=(t,e,s)=>e in t?kC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,$C=(t,e,s)=>UC(t,e+"",s);let DC=class extends fi{constructor(e,s){super(),this.core=e,this.logger=s,$C(this,"records",new Map)}},LC=class{constructor(e,s){this.logger=e,this.core=s}},MC=class extends fi{constructor(e,s){super(),this.relayer=e,this.logger=s}},BC=class extends fi{constructor(e){super()}},jC=class{constructor(e,s,n,r){this.core=e,this.logger=s,this.name=n}},FC=class extends fi{constructor(e,s){super(),this.relayer=e,this.logger=s}},qC=class extends fi{constructor(e,s){super(),this.core=e,this.logger=s}},WC=class{constructor(e,s,n){this.core=e,this.logger=s,this.store=n}};class HC{constructor(e,s){this.projectId=e,this.logger=s}}let zC=class{constructor(e,s,n){this.core=e,this.logger=s,this.telemetryEnabled=n}};var VC=Object.defineProperty,KC=(t,e,s)=>e in t?VC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,eh=(t,e,s)=>KC(t,typeof e!="symbol"?e+"":e,s);let GC=class{constructor(e){this.opts=e,eh(this,"protocol","wc"),eh(this,"version",2)}},YC=class{constructor(e){this.client=e}};const ZC="0.1.1";function JC(){return ZC}class Je extends Error{constructor(e,s={}){const n=(()=>{var c;if(s.cause instanceof Je){if(s.cause.details)return s.cause.details;if(s.cause.shortMessage)return s.cause.shortMessage}return s.cause&&"details"in s.cause&&typeof s.cause.details=="string"?s.cause.details:(c=s.cause)!=null&&c.message?s.cause.message:s.details})(),r=s.cause instanceof Je&&s.cause.docsPath||s.docsPath,o=`https://oxlib.sh${r??""}`,a=[e||"An error occurred.",...s.metaMessages?["",...s.metaMessages]:[],...n||r?["",n?`Details: ${n}`:void 0,r?`See: ${o}`:void 0]:[]].filter(c=>typeof c=="string").join(`
|
|
4
|
+
${a}`,r=!0}}r||(Error.captureStackTrace?Error.captureStackTrace(this,Tr):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function Hu(t,e){let s="";try{t instanceof Error?s=t.message:typeof t=="string"?s=t:typeof t=="object"&&t!==null?Object.keys(t).length===0?s="Unknown error":s=(t==null?void 0:t.message)||JSON.stringify(t):s=String(t)}catch(r){s="Unknown error",console.error("Error parsing error message",r)}const n=t instanceof Tr?t:new Tr(s,e,t);throw Mv.sendError(n,n.category),n}function As(t,e="INTERNAL_SDK_ERROR"){const s={};return Object.keys(t).forEach(n=>{const r=t[n];if(typeof r=="function"){let i=r;r.constructor.name==="AsyncFunction"?i=async(...o)=>{try{return await r(...o)}catch(a){return Hu(a,e)}}:i=(...o)=>{try{return r(...o)}catch(a){return Hu(a,e)}},s[n]=i}else s[n]=r}),s}const ss=Ge({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),Bv={state:ss,subscribeNetworkImages(t){return _t(ss.networkImages,()=>t(ss.networkImages))},subscribeKey(t,e){return At(ss,t,e)},subscribe(t){return _t(ss,()=>t(ss))},setWalletImage(t,e){ss.walletImages[t]=e},setNetworkImage(t,e){ss.networkImages[t]=e},setChainImage(t,e){ss.chainImages[t]=e},setConnectorImage(t,e){ss.connectorImages={...ss.connectorImages,[t]:e}},setTokenImage(t,e){ss.tokenImages[t]=e},setCurrencyImage(t,e){ss.currencyImages[t]=e}},bs=As(Bv),zu={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:"",sui:"",stacks:"",ton:"20f673c0-095e-49b2-07cf-eb5049dcf600"},Ic=Ge({networkImagePromises:{}}),Kf={async fetchWalletImage(t){if(t)return await te._fetchWalletImage(t),this.getWalletImageById(t)},async fetchNetworkImage(t){if(!t)return;const e=this.getNetworkImageById(t);return e||(Ic.networkImagePromises[t]||(Ic.networkImagePromises[t]=te._fetchNetworkImage(t)),await Ic.networkImagePromises[t],this.getNetworkImageById(t))},getWalletImageById(t){if(t)return bs.state.walletImages[t]},getWalletImage(t){if(t!=null&&t.image_url)return t==null?void 0:t.image_url;if(t!=null&&t.image_id)return bs.state.walletImages[t.image_id]},getNetworkImage(t){var e,s,n;if((e=t==null?void 0:t.assets)!=null&&e.imageUrl)return(s=t==null?void 0:t.assets)==null?void 0:s.imageUrl;if((n=t==null?void 0:t.assets)!=null&&n.imageId)return bs.state.networkImages[t.assets.imageId]},getNetworkImageById(t){if(t)return bs.state.networkImages[t]},getConnectorImage(t){var e;if(t!=null&&t.imageUrl)return t.imageUrl;if((e=t==null?void 0:t.info)!=null&&e.icon)return t.info.icon;if(t!=null&&t.imageId)return bs.state.connectorImages[t.imageId]},getChainImage(t){return bs.state.networkImages[zu[t]]},getTokenImage(t){if(t)return bs.state.tokenImages[t]},getWalletImageUrl(t){if(!t)return"";const{projectId:e,sdkType:s,sdkVersion:n}=$.state,r=new URL(`${U.W3M_API_URL}/getWalletImage/${t}`);return r.searchParams.set("projectId",e),r.searchParams.set("st",s),r.searchParams.set("sv",n),r.toString()},getAssetImageUrl(t){if(!t)return"";const{projectId:e,sdkType:s,sdkVersion:n}=$.state,r=new URL(`${U.W3M_API_URL}/public/getAssetImage/${t}`);return r.searchParams.set("projectId",e),r.searchParams.set("st",s),r.searchParams.set("sv",n),r.toString()},getChainNamespaceImageUrl(t){return this.getAssetImageUrl(zu[t])}},jv=X.getAnalyticsUrl(),Fv=new So({baseUrl:jv,clientId:null}),qv=["MODAL_CREATED"],Wv=45,Vu=1e3*10,et=Ge({timestamp:Date.now(),lastFlush:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"},pendingEvents:[],subscribedToVisibilityChange:!1,walletImpressions:[]}),Ee={state:et,subscribe(t){return _t(et,()=>t(et))},getSdkProperties(){const{projectId:t,sdkType:e,sdkVersion:s}=$.state;return{projectId:t,st:e,sv:s||"html-wagmi-4.2.2"}},shouldFlushEvents(){const t=JSON.stringify(et.pendingEvents).length/1024>Wv,e=et.lastFlush+Vu<Date.now();return t||e},_setPendingEvent(t){var e,s;try{let n=(e=E.getAccountData())==null?void 0:e.address;if("address"in t.data&&t.data.address&&(n=t.data.address),qv.includes(t.data.event)||typeof window>"u")return;const r=(s=E.getActiveCaipNetwork())==null?void 0:s.caipNetworkId;this.state.pendingEvents.push({eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:t.timestamp,props:{...t.data,address:n,properties:{..."properties"in t.data?t.data.properties:{},caipNetworkId:r}}}),et.reportedErrors.FORBIDDEN=!1,Ee.shouldFlushEvents()&&Ee._submitPendingEvents()}catch(n){console.warn("_setPendingEvent",n)}},sendEvent(t){var s;et.timestamp=Date.now(),et.data=t;const e=["INITIALIZE","CONNECT_SUCCESS","SOCIAL_LOGIN_SUCCESS"];((s=$.state.features)!=null&&s.analytics||e.includes(t.event))&&Ee._setPendingEvent(et),this.subscribeToFlushTriggers()},sendWalletImpressionEvent(t){et.walletImpressions.push(t)},_transformPendingEventsForBatch(t){try{return t.filter(e=>e.props.event!=="WALLET_IMPRESSION_V2")}catch{return t}},_submitPendingEvents(){if(et.lastFlush=Date.now(),!(et.pendingEvents.length===0&&et.walletImpressions.length===0))try{const t=Ee._transformPendingEventsForBatch(et.pendingEvents);et.walletImpressions.length&&t.push({eventId:X.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:Date.now(),props:{type:"track",event:"WALLET_IMPRESSION_V2",items:[...et.walletImpressions]}}),Fv.sendBeacon({path:"/batch",params:Ee.getSdkProperties(),body:t}),et.reportedErrors.FORBIDDEN=!1,et.pendingEvents=[],et.walletImpressions=[]}catch{et.reportedErrors.FORBIDDEN=!0}},subscribeToFlushTriggers(){var t,e,s;et.subscribedToVisibilityChange||typeof document>"u"||(et.subscribedToVisibilityChange=!0,(t=document==null?void 0:document.addEventListener)==null||t.call(document,"visibilitychange",()=>{document.visibilityState==="hidden"&&Ee._submitPendingEvents()}),(e=document==null?void 0:document.addEventListener)==null||e.call(document,"freeze",()=>{Ee._submitPendingEvents()}),(s=window==null?void 0:window.addEventListener)==null||s.call(window,"pagehide",()=>{Ee._submitPendingEvents()}),setInterval(()=>{Ee._submitPendingEvents()},Vu))}},Hv=X.getApiUrl(),$t=new So({baseUrl:Hv,clientId:null}),zv=40,Ku=4,Vv=20,we=Ge({promises:{},page:1,count:0,featured:[],allFeatured:[],recommended:[],allRecommended:[],wallets:[],filteredWallets:[],search:[],isAnalyticsEnabled:!1,excludedWallets:[],isFetchingRecommendedWallets:!1,explorerWallets:[],explorerFilteredWallets:[],plan:{tier:"none",hasExceededUsageLimit:!1,limits:{isAboveRpcLimit:!1,isAboveMauLimit:!1}}}),te={state:we,subscribeKey(t,e){return At(we,t,e)},_getSdkProperties(){const{projectId:t,sdkType:e,sdkVersion:s}=$.state;return{projectId:t,st:e||"appkit",sv:s||"html-wagmi-4.2.2"}},_filterOutExtensions(t){return $.state.isUniversalProvider?t.filter(e=>!!(e.mobile_link||e.desktop_link||e.webapp_link)):t},async _fetchWalletImage(t){const e=`${$t.baseUrl}/getWalletImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setWalletImage(t,URL.createObjectURL(s))},async _fetchNetworkImage(t){const e=`${$t.baseUrl}/public/getAssetImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setNetworkImage(t,URL.createObjectURL(s))},async _fetchConnectorImage(t){const e=`${$t.baseUrl}/public/getAssetImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setConnectorImage(t,URL.createObjectURL(s))},async _fetchCurrencyImage(t){const e=`${$t.baseUrl}/public/getCurrencyImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setCurrencyImage(t,URL.createObjectURL(s))},async _fetchTokenImage(t){const e=`${$t.baseUrl}/public/getTokenImage/${t}`,s=await $t.getBlob({path:e,params:te._getSdkProperties()});bs.setTokenImage(t,URL.createObjectURL(s))},_filterWalletsByPlatform(t){const e=t.length,s=X.isMobile()?t==null?void 0:t.filter(r=>r.mobile_link||r.webapp_link?!0:Object.values(ms).map(o=>o.id).includes(r.id)):t,n=e-s.length;return{filteredWallets:s,mobileFilteredOutWalletsLength:n}},async fetchProjectConfig(){return(await $t.get({path:"/appkit/v1/config",params:te._getSdkProperties()})).features},async fetchUsage(){try{const t=await $t.get({path:"/appkit/v1/project-limits",params:te._getSdkProperties()}),{tier:e,isAboveMauLimit:s,isAboveRpcLimit:n}=t.planLimits,r=e==="starter",i=s||n;te.state.plan={tier:e,hasExceededUsageLimit:r&&i,limits:{isAboveRpcLimit:n,isAboveMauLimit:s}}}catch(t){console.warn("Failed to fetch usage",t)}},async fetchAllowedOrigins(){try{const{allowedOrigins:t}=await $t.get({path:"/projects/v1/origins",params:te._getSdkProperties()});return t}catch(t){if(t instanceof Error&&t.cause instanceof Response){const e=t.cause.status;if(e===U.HTTP_STATUS_CODES.TOO_MANY_REQUESTS)throw new Error("RATE_LIMITED",{cause:t});if(e>=U.HTTP_STATUS_CODES.SERVER_ERROR&&e<600)throw new Error("SERVER_ERROR",{cause:t});return[]}return[]}},async fetchNetworkImages(){const t=E.getAllRequestedCaipNetworks(),e=t==null?void 0:t.map(({assets:s})=>s==null?void 0:s.imageId).filter(Boolean).filter(s=>!Kf.getNetworkImageById(s));e&&await Promise.allSettled(e.map(s=>te._fetchNetworkImage(s)))},async fetchConnectorImages(){const{connectors:t}=z.state,e=t.map(({imageId:s})=>s).filter(Boolean);await Promise.allSettled(e.map(s=>te._fetchConnectorImage(s)))},async fetchCurrencyImages(t=[]){await Promise.allSettled(t.map(e=>te._fetchCurrencyImage(e)))},async fetchTokenImages(t=[]){await Promise.allSettled(t.map(e=>te._fetchTokenImage(e)))},async fetchWallets(t){var o;const e=t.exclude??[];te._getSdkProperties().sv.startsWith("html-core-")&&e.push(...Object.values(ms).map(a=>a.id));const n=await $t.get({path:"/getWallets",params:{...te._getSdkProperties(),...t,page:String(t.page),entries:String(t.entries),include:(o=t.include)==null?void 0:o.join(","),exclude:e.join(",")}}),{filteredWallets:r,mobileFilteredOutWalletsLength:i}=te._filterWalletsByPlatform(n==null?void 0:n.data);return{data:r||[],count:n==null?void 0:n.count,mobileFilteredOutWalletsLength:i}},async prefetchWalletRanks(){const t=z.state.connectors;if(!(t!=null&&t.length))return;const e={page:1,entries:20,badge:"certified"};if(e.names=t.map(r=>r.name).join(","),E.state.activeChain===U.CHAIN.EVM){const r=[...t.flatMap(i=>{var o;return((o=i.connectors)==null?void 0:o.map(a=>{var c;return(c=a.info)==null?void 0:c.rdns}))||[]}),...t.map(i=>{var o;return(o=i.info)==null?void 0:o.rdns})].filter(i=>typeof i=="string"&&i.length>0);r.length&&(e.rdns=r.join(","))}const{data:s}=await te.fetchWallets(e);we.explorerWallets=s,z.extendConnectorsWithExplorerWallets(s);const n=E.getRequestedCaipNetworkIds().join(",");we.explorerFilteredWallets=s.filter(r=>{var i;return(i=r.chains)==null?void 0:i.some(o=>n.includes(o))})},async fetchFeaturedWallets(){const{featuredWalletIds:t}=$.state;if(t!=null&&t.length){const e={...te._getSdkProperties(),page:1,entries:(t==null?void 0:t.length)??Ku,include:t},{data:s}=await te.fetchWallets(e),n=[...s].sort((i,o)=>t.indexOf(i.id)-t.indexOf(o.id)),r=n.map(i=>i.image_id).filter(Boolean);await Promise.allSettled(r.map(i=>te._fetchWalletImage(i))),we.featured=n,we.allFeatured=n}},async fetchRecommendedWallets(){try{we.isFetchingRecommendedWallets=!0;const{includeWalletIds:t,excludeWalletIds:e,featuredWalletIds:s}=$.state,n=[...e??[],...s??[]].filter(Boolean),r=E.getRequestedCaipNetworkIds().join(","),i={page:1,entries:Ku,include:t,exclude:n,chains:r},{data:o,count:a}=await te.fetchWallets(i),c=F.getRecentWallets(),l=o.map(u=>u.image_id).filter(Boolean),d=c.map(u=>u.image_id).filter(Boolean);await Promise.allSettled([...l,...d].map(u=>te._fetchWalletImage(u))),we.recommended=o,we.allRecommended=o,we.count=a??0}catch{}finally{we.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:t}){const{includeWalletIds:e,excludeWalletIds:s,featuredWalletIds:n}=$.state,r=E.getRequestedCaipNetworkIds().join(","),i=[...we.recommended.map(({id:u})=>u),...s??[],...n??[]].filter(Boolean),o={page:t,entries:zv,include:e,exclude:i,chains:r},{data:a,count:c,mobileFilteredOutWalletsLength:l}=await te.fetchWallets(o);we.mobileFilteredOutWalletsLength=l+(we.mobileFilteredOutWalletsLength??0);const d=a.slice(0,Vv).map(u=>u.image_id).filter(Boolean);await Promise.allSettled(d.map(u=>te._fetchWalletImage(u))),we.wallets=X.uniqueBy([...we.wallets,...te._filterOutExtensions(a)],"id").filter(u=>{var h;return(h=u.chains)==null?void 0:h.some(p=>r.includes(p))}),we.count=c>we.count?c:we.count,we.page=t},async initializeExcludedWallets({ids:t}){const e={page:1,entries:t.length,include:t},{data:s}=await te.fetchWallets(e);s&&s.forEach(n=>{we.excludedWallets.push({rdns:n.rdns,name:n.name})})},async searchWallet({search:t,badge:e}){const{includeWalletIds:s,excludeWalletIds:n}=$.state,r=E.getRequestedCaipNetworkIds().join(",");we.search=[];const i={page:1,entries:100,search:t==null?void 0:t.trim(),badge_type:e,include:s,exclude:n,chains:r},{data:o}=await te.fetchWallets(i);Ee.sendEvent({type:"track",event:"SEARCH_WALLET",properties:{badge:e??"",search:t??""}});const a=o.map(c=>c.image_id).filter(Boolean);await Promise.allSettled([...a.map(c=>te._fetchWalletImage(c)),X.wait(300)]),we.search=te._filterOutExtensions(o)},initPromise(t,e){const s=we.promises[t];return s||(we.promises[t]=e())},prefetch({fetchConnectorImages:t=!0,fetchFeaturedWallets:e=!0,fetchRecommendedWallets:s=!0,fetchNetworkImages:n=!0,fetchWalletRanks:r=!0}={}){const i=[t&&te.initPromise("connectorImages",te.fetchConnectorImages),e&&te.initPromise("featuredWallets",te.fetchFeaturedWallets),s&&te.initPromise("recommendedWallets",te.fetchRecommendedWallets),n&&te.initPromise("networkImages",te.fetchNetworkImages),r&&te.initPromise("walletRanks",te.prefetchWalletRanks)].filter(Boolean);return Promise.allSettled(i)},prefetchAnalyticsConfig(){var t;(t=$.state.features)!=null&&t.analytics&&te.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{const{isAnalyticsEnabled:t}=await $t.get({path:"/getAnalyticsConfig",params:te._getSdkProperties()});$.setFeatures({analytics:t})}catch{$.setFeatures({analytics:!1})}},filterByNamespaces(t){if(!(t!=null&&t.length)){we.featured=we.allFeatured,we.recommended=we.allRecommended;return}const e=E.getRequestedCaipNetworkIds().join(",");we.featured=we.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.recommended=we.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.filteredWallets=we.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})},clearFilterByNamespaces(){we.filteredWallets=[]},setFilterByNamespace(t){if(!t){we.featured=we.allFeatured,we.recommended=we.allRecommended;return}const e=E.getRequestedCaipNetworkIds().join(",");we.featured=we.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.recommended=we.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),we.filteredWallets=we.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})}},Kv=["ConnectingExternal","ConnectingMultiChain","ConnectingSocial","ConnectingFarcaster"],je=Ge({view:"Connect",history:["Connect"],transactionStack:[]}),Gv={state:je,subscribeKey(t,e){return At(je,t,e)},pushTransactionStack(t){je.transactionStack.push(t)},popTransactionStack(t){const e=je.transactionStack.pop();if(!e)return;const{onSuccess:s,onError:n,onCancel:r}=e;switch(t){case"success":s==null||s();break;case"error":n==null||n(),ue.goBack();break;case"cancel":r==null||r(),ue.goBack();break}},push(t,e){let s=t,n=e;te.state.plan.hasExceededUsageLimit&&Kv.includes(t)&&(s="UsageExceeded",n=void 0),s!==je.view&&(je.view=s,je.history.push(s),je.data=n)},reset(t,e){je.view=t,je.history=[t],je.data=e},replace(t,e){je.history.at(-1)===t||(je.view=t,je.history[je.history.length-1]=t,je.data=e)},goBack(){var n,r;const t=E.state.activeCaipAddress,e=ue.state.view==="ConnectingFarcaster",s=!t&&e;if(je.history.length>1){je.history.pop();const[i]=je.history.slice(-1);i&&(t&&i==="Connect"?je.view="Account":je.view=i)}else Ne.close();(n=je.data)!=null&&n.wallet&&(je.data.wallet=void 0),(r=je.data)!=null&&r.redirectView&&(je.data.redirectView=void 0),setTimeout(()=>{var i,o,a;if(s){E.setAccountProp("farcasterUrl",void 0,E.state.activeChain);const c=z.getAuthConnector();(i=c==null?void 0:c.provider)==null||i.reload();const l=Xi($.state);(a=(o=c==null?void 0:c.provider)==null?void 0:o.syncDappData)==null||a.call(o,{metadata:l.metadata,sdkVersion:l.sdkVersion,projectId:l.projectId,sdkType:l.sdkType})}},100)},goBackToIndex(t){if(je.history.length>1){je.history=je.history.slice(0,t+1);const[e]=je.history.slice(-1);e&&(je.view=e)}},goBackOrCloseModal(){ue.state.history.length>1?ue.goBack():Ne.close()}},ue=As(Gv),nn=Ge({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),Pl={state:nn,subscribe(t){return _t(nn,()=>t(nn))},setThemeMode(t){nn.themeMode=t;try{const e=z.getAuthConnector();if(e){const s=Pl.getSnapshot().themeVariables;e.provider.syncTheme({themeMode:t,themeVariables:s,w3mThemeVariables:Zi(s,t)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(t){nn.themeVariables={...nn.themeVariables,...t};try{const e=z.getAuthConnector();if(e){const s=Pl.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:s,w3mThemeVariables:Zi(nn.themeVariables,nn.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot(){return Xi(nn)}},Kt=As(Pl),Gf=Object.fromEntries(Sf.map(t=>[t,void 0])),Yv=Object.fromEntries(Sf.map(t=>[t,!0])),Pe=Ge({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:Gf,filterByNamespaceMap:Yv}),Zv={state:Pe,subscribe(t){return _t(Pe,()=>{t(Pe)})},subscribeKey(t,e){return At(Pe,t,e)},initialize(t){t.forEach(e=>{const s=F.getConnectedConnectorId(e);s&&z.setConnectorId(s,e)})},setActiveConnector(t){t&&(Pe.activeConnector=Qi(t))},setConnectors(t){t.filter(r=>!Pe.allConnectors.some(i=>i.id===r.id&&z.getConnectorName(i.name)===z.getConnectorName(r.name)&&i.chain===r.chain)).forEach(r=>{r.type!=="MULTI_CHAIN"&&Pe.allConnectors.push(Qi(r))});const s=z.getEnabledNamespaces(),n=z.getEnabledConnectors(s);Pe.connectors=z.mergeMultiChainConnectors(n)},filterByNamespaces(t){Object.keys(Pe.filterByNamespaceMap).forEach(e=>{Pe.filterByNamespaceMap[e]=!1}),t.forEach(e=>{Pe.filterByNamespaceMap[e]=!0}),z.updateConnectorsForEnabledNamespaces()},filterByNamespace(t,e){Pe.filterByNamespaceMap[t]=e,z.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){const t=z.getEnabledNamespaces(),e=z.getEnabledConnectors(t),s=z.areAllNamespacesEnabled();Pe.connectors=z.mergeMultiChainConnectors(e),s?te.clearFilterByNamespaces():te.filterByNamespaces(t)},getEnabledNamespaces(){return Object.entries(Pe.filterByNamespaceMap).filter(([t,e])=>e).map(([t])=>t)},getEnabledConnectors(t){return Pe.allConnectors.filter(e=>t.includes(e.chain))},areAllNamespacesEnabled(){return Object.values(Pe.filterByNamespaceMap).every(t=>t)},mergeMultiChainConnectors(t){const e=z.generateConnectorMapByName(t),s=[];return e.forEach(n=>{const r=n[0],i=(r==null?void 0:r.id)===U.CONNECTOR_ID.AUTH;n.length>1&&r?s.push({name:r.name,imageUrl:r.imageUrl,imageId:r.imageId,connectors:[...n],type:i?"AUTH":"MULTI_CHAIN",chain:"eip155",id:(r==null?void 0:r.id)||""}):r&&s.push(r)}),s},generateConnectorMapByName(t){const e=new Map;return t.forEach(s=>{const{name:n}=s,r=z.getConnectorName(n);if(!r)return;const i=e.get(r)||[];i.find(a=>a.chain===s.chain)||i.push(s),e.set(r,i)}),e},getConnectorName(t){return t&&({"Trust Wallet":"Trust"}[t]||t)},getUniqueConnectorsByName(t){const e=[];return t.forEach(s=>{e.find(n=>n.chain===s.chain)||e.push(s)}),e},addConnector(t){var e,s,n;if(t.id===U.CONNECTOR_ID.AUTH){const r=t,i=Xi($.state),o=Kt.getSnapshot().themeMode,a=Kt.getSnapshot().themeVariables;(s=(e=r==null?void 0:r.provider)==null?void 0:e.syncDappData)==null||s.call(e,{metadata:i.metadata,sdkVersion:i.sdkVersion,projectId:i.projectId,sdkType:i.sdkType}),(n=r==null?void 0:r.provider)==null||n.syncTheme({themeMode:o,themeVariables:a,w3mThemeVariables:Zi(a,o)}),z.setConnectors([t])}else z.setConnectors([t])},getAuthConnector(t){var n;const e=t||E.state.activeChain,s=Pe.connectors.find(r=>r.id===U.CONNECTOR_ID.AUTH);if(s)return(n=s==null?void 0:s.connectors)!=null&&n.length?s.connectors.find(i=>i.chain===e):s},getAnnouncedConnectorRdns(){return Pe.connectors.filter(t=>t.type==="ANNOUNCED").map(t=>{var e;return(e=t.info)==null?void 0:e.rdns})},getConnectorById(t){return Pe.allConnectors.find(e=>e.id===t)},getConnector({id:t,namespace:e}){const s=e||E.state.activeChain;return Pe.allConnectors.filter(i=>i.chain===s).find(i=>i.id===t||i.explorerId===t)},syncIfAuthConnector(t){var i,o;if(t.id!=="AUTH")return;const e=t,s=Xi($.state),n=Kt.getSnapshot().themeMode,r=Kt.getSnapshot().themeVariables;(o=(i=e==null?void 0:e.provider)==null?void 0:i.syncDappData)==null||o.call(i,{metadata:s.metadata,sdkVersion:s.sdkVersion,sdkType:s.sdkType,projectId:s.projectId}),e.provider.syncTheme({themeMode:n,themeVariables:r,w3mThemeVariables:Zi(r,n)})},getConnectorsByNamespace(t){const e=Pe.allConnectors.filter(s=>s.chain===t);return z.mergeMultiChainConnectors(e)},canSwitchToSmartAccount(t){return E.checkIfSmartAccountEnabled()&&ls(t)===tt.ACCOUNT_TYPES.EOA},selectWalletConnector(t){var r;const e=(r=ue.state.data)==null?void 0:r.redirectView,s=E.state.activeChain,n=s?z.getConnector({id:t.id,namespace:s}):void 0;kv.handleMobileDeeplinkRedirect((n==null?void 0:n.explorerId)||t.id,E.state.activeChain),n?ue.push("ConnectingExternal",{connector:n,wallet:t,redirectView:e}):ue.push("ConnectingWalletConnect",{wallet:t,redirectView:e})},getConnectors(t){return t?z.getConnectorsByNamespace(t):z.mergeMultiChainConnectors(Pe.allConnectors)},setFilterByNamespace(t){Pe.filterByNamespace=t,Pe.connectors=z.getConnectors(t),te.setFilterByNamespace(t)},setConnectorId(t,e){t&&(Pe.activeConnectorIds={...Pe.activeConnectorIds,[e]:t},F.setConnectedConnectorId(e,t))},removeConnectorId(t){Pe.activeConnectorIds={...Pe.activeConnectorIds,[t]:void 0},F.deleteConnectedConnectorId(t)},getConnectorId(t){if(t)return Pe.activeConnectorIds[t]},isConnected(t){return t?!!Pe.activeConnectorIds[t]:Object.values(Pe.activeConnectorIds).some(e=>!!e)},resetConnectorIds(){Pe.activeConnectorIds={...Gf}},extendConnectorsWithExplorerWallets(t){Pe.allConnectors.forEach(n=>{const r=t.find(i=>{var o;return i.id===n.id||i.rdns&&i.rdns===((o=n.info)==null?void 0:o.rdns)});r&&(n.explorerWallet=r)});const e=z.getEnabledNamespaces(),s=z.getEnabledConnectors(e);Pe.connectors=z.mergeMultiChainConnectors(s)}},z=As(Zv),Jv=1e3,Ci={checkNamespaceConnectorId(t,e){return z.getConnectorId(t)===e},isSocialProvider(t){return Ie.DEFAULT_REMOTE_FEATURES.socials.includes(t)},connectWalletConnect({walletConnect:t,connector:e,closeModalOnConnect:s=!0,redirectViewOnModalClose:n="Connect",onOpen:r,onConnect:i}){return new Promise((o,a)=>{if(t&&z.setActiveConnector(e),r==null||r(X.isMobile()&&t),n){const l=Ne.subscribeKey("open",d=>{d||(ue.state.view!==n&&ue.replace(n),l(),a(new Error("Modal closed")))})}const c=E.subscribeKey("activeCaipAddress",l=>{l&&(i==null||i(),s&&Ne.close(),c(),o(dt.parseCaipAddress(l)))})})},connectExternal(t){return new Promise((e,s)=>{const n=E.subscribeKey("activeCaipAddress",r=>{r&&(Ne.close(),n(),e(dt.parseCaipAddress(r)))});G.connectExternal(t,t.chain).catch(()=>{n(),s(new Error("Connection rejected"))})})},connectSocial({social:t,namespace:e,closeModalOnConnect:s=!0,onOpenFarcaster:n,onConnect:r}){let i,o=!1,a=null;const c=e||E.state.activeChain,l=E.subscribeKey("activeCaipAddress",d=>{d&&(s&&Ne.close(),l())});return new Promise((d,u)=>{async function h(g){var f;if((f=g.data)!=null&&f.resultUri)if(g.origin===U.SECURE_SITE_SDK_ORIGIN){window.removeEventListener("message",h,!1);try{const y=z.getAuthConnector(c);if(y&&!o){i&&i.close(),o=!0;const _=g.data.resultUri;Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_REQUEST_USER_DATA",properties:{provider:t}}),F.setConnectedSocialProvider(t),await G.connectExternal({id:y.id,type:y.type,socialUri:_},y.chain);const S=E.state.activeCaipAddress;if(!S){u(new Error("Failed to connect"));return}d(dt.parseCaipAddress(S)),Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:t}})}}catch(y){Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:X.parseError(y)}}),u(new Error("Failed to connect"))}}else Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:"Untrusted Origin"}})}async function p(){if(Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_STARTED",properties:{provider:t}}),t==="farcaster"){n==null||n();const g=Ne.subscribeKey("open",y=>{!y&&t==="farcaster"&&(u(new Error("Popup closed")),r==null||r(),g())}),f=z.getAuthConnector();if(f){const y=E.getAccountData(c);if(!(y!=null&&y.farcasterUrl))try{const{url:_}=await f.provider.getFarcasterUri();E.setAccountProp("farcasterUrl",_,c)}catch{u(new Error("Failed to connect to farcaster"))}}}else{const g=z.getAuthConnector();a=X.returnOpenHref(`${U.SECURE_SITE_SDK_ORIGIN}/loading`,"popupWindow","width=600,height=800,scrollbars=yes");try{if(g){const{uri:f}=await g.provider.getSocialRedirectUri({provider:t});if(a&&f){a.location.href=f,i=a;const y=setInterval(()=>{i!=null&&i.closed&&!o&&(u(new Error("Popup closed")),clearInterval(y))},1e3);window.addEventListener("message",h,!1)}else a==null||a.close(),u(new Error("Failed to initiate social connection"))}}catch{u(new Error("Failed to initiate social connection")),a==null||a.close()}}}p()})},connectEmail({closeModalOnConnect:t=!0,redirectViewOnModalClose:e="Connect",onOpen:s,onConnect:n}){return new Promise((r,i)=>{if(s==null||s(),e){const a=Ne.subscribeKey("open",c=>{c||(ue.state.view!==e&&ue.replace(e),a(),i(new Error("Modal closed")))})}const o=E.subscribeKey("activeCaipAddress",a=>{a&&(n==null||n(),t&&Ne.close(),o(),r(dt.parseCaipAddress(a)))})})},async updateEmail(){const t=F.getConnectedConnectorId(E.state.activeChain),e=z.getAuthConnector();if(!e)throw new Error("No auth connector found");if(t!==U.CONNECTOR_ID.AUTH)throw new Error("Not connected to email or social");const s=e.provider.getEmail()??"";return await Ne.open({view:"UpdateEmailWallet",data:{email:s,redirectView:void 0}}),new Promise((n,r)=>{const i=setInterval(()=>{const a=e.provider.getEmail()??"";a!==s&&(Ne.close(),clearInterval(i),o(),n({email:a}))},Jv),o=Ne.subscribeKey("open",a=>{a||(ue.state.view!=="Connect"&&ue.push("Connect"),clearInterval(i),o(),r(new Error("Modal closed")))})})},canSwitchToSmartAccount(t){return E.checkIfSmartAccountEnabled()&&ls(t)===tt.ACCOUNT_TYPES.EOA}};function Yf(){var n,r;const t=((n=E.state.activeCaipNetwork)==null?void 0:n.chainNamespace)||"eip155",e=((r=E.state.activeCaipNetwork)==null?void 0:r.id)||1,s=Ie.NATIVE_TOKEN_ADDRESS[t];return`${t}:${e}:${s}`}function ls(t){var s;return(s=E.getAccountData(t))==null?void 0:s.preferredAccountType}function ki(t){var e,s;return t?(s=(e=E.state.chains.get(t))==null?void 0:e.networkState)==null?void 0:s.caipNetwork:E.state.activeCaipNetwork}const $a={getConnectionStatus(t,e){const s=z.state.activeConnectorIds[e],n=G.getConnections(e);return!!s&&t.connectorId===s?"connected":n.some(o=>o.connectorId.toLowerCase()===t.connectorId.toLowerCase())?"active":"disconnected"},excludeConnectorAddressFromConnections({connections:t,connectorId:e,addresses:s}){return t.map(n=>{if((e?n.connectorId.toLowerCase()===e.toLowerCase():!1)&&s){const i=n.accounts.filter(o=>!s.some(c=>c.toLowerCase()===o.address.toLowerCase()));return{...n,accounts:i}}return n})},excludeExistingConnections(t,e){const s=new Set(t);return e.filter(n=>!s.has(n.connectorId))},getConnectionsByConnectorId(t,e){return t.filter(s=>s.connectorId.toLowerCase()===e.toLowerCase())},getConnectionsData(t){var a;const e=!!((a=$.state.remoteFeatures)!=null&&a.multiWallet),s=z.state.activeConnectorIds[t],n=G.getConnections(t),i=(G.state.recentConnections.get(t)??[]).filter(c=>z.getConnectorById(c.connectorId)),o=$a.excludeExistingConnections([...n.map(c=>c.connectorId),...s?[s]:[]],i);return e?{connections:n,recentConnections:o}:{connections:n.filter(c=>c.connectorId.toLowerCase()===(s==null?void 0:s.toLowerCase())),recentConnections:[]}},onConnectMobile(t){const e=G.state.wcUri;if(t!=null&&t.mobile_link&&e)try{G.setWcError(!1);const{mobile_link:s,link_mode:n,name:r}=t,{redirect:i,redirectUniversalLink:o,href:a}=X.formatNativeUrl(s,e,n),c=i,l=o,d=X.isIframe()?"_top":"_self";G.setWcLinking({name:r,href:a}),G.setRecentWallet(t),$.state.experimental_preferUniversalLinks&&l?X.openHref(l,d):X.openHref(c,d)}catch(s){Ee.sendEvent({type:"track",event:"CONNECT_PROXY_ERROR",properties:{message:s instanceof Error?s.message:"Error parsing the deep link",uri:e,mobile_link:t.mobile_link,name:t.name}}),G.setWcError(!0)}}},Br=Ge({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1,connectingWallet:void 0}),ds={state:Br,subscribe(t){return _t(Br,()=>t(Br))},subscribeOpen(t){return At(Br,"open",t)},set(t){Object.assign(Br,{...Br,...t})}},Ye=Ge({transactions:[],transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),Xv={state:Ye,subscribe(t){return _t(Ye,()=>t(Ye))},setLastNetworkInView(t){Ye.lastNetworkInView=t},async fetchTransactions(t){var e;if(!t)throw new Error("Transactions can't be fetched without an accountAddress");Ye.loading=!0;try{const s=await fe.fetchTransactions({account:t,cursor:Ye.next,chainId:(e=E.state.activeCaipNetwork)==null?void 0:e.caipNetworkId}),n=pa.filterSpamTransactions(s.data),r=pa.filterByConnectedChain(n),i=[...Ye.transactions,...r];Ye.loading=!1,Ye.transactions=i,Ye.transactionsByYear=pa.groupTransactionsByYearAndMonth(Ye.transactionsByYear,r),Ye.empty=i.length===0,Ye.next=s.next?s.next:void 0}catch{const n=E.state.activeChain;Ee.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:t,projectId:$.state.projectId,cursor:Ye.next,isSmartAccount:ls(n)===tt.ACCOUNT_TYPES.SMART_ACCOUNT}}),Ks.showError("Failed to fetch transactions"),Ye.loading=!1,Ye.empty=!0,Ye.next=void 0}},groupTransactionsByYearAndMonth(t={},e=[]){const s=t;return e.forEach(n=>{const r=new Date(n.metadata.minedAt).getFullYear(),i=new Date(n.metadata.minedAt).getMonth(),o=s[r]??{},c=(o[i]??[]).filter(l=>l.id!==n.id);s[r]={...o,[i]:[...c,n].sort((l,d)=>new Date(d.metadata.minedAt).getTime()-new Date(l.metadata.minedAt).getTime())}}),s},filterSpamTransactions(t){return t.filter(e=>{var n;return!((n=e.transfers)==null?void 0:n.every(r=>{var i;return((i=r.nft_info)==null?void 0:i.flags.is_spam)===!0}))})},filterByConnectedChain(t){var n;const e=(n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId;return t.filter(r=>r.metadata.chain===e)},clearCursor(){Ye.next=void 0},resetTransactions(){Ye.transactions=[],Ye.transactionsByYear={},Ye.lastNetworkInView=void 0,Ye.loading=!1,Ye.empty=!1,Ye.next=void 0}},pa=As(Xv,"API_ERROR"),Se=Ge({connections:new Map,recentConnections:new Map,isSwitchingConnection:!1,wcError:!1,wcFetchingUri:!1,buffering:!1,status:"disconnected"});let nr;const Qv={state:Se,subscribe(t){return _t(Se,()=>t(Se))},subscribeKey(t,e){return At(Se,t,e)},_getClient(){return Se._client},setClient(t){Se._client=Qi(t)},initialize(t){const e=t.filter(s=>!!s.namespace).map(s=>s.namespace);G.syncStorageConnections(e)},syncStorageConnections(t){const e=F.getConnections(),s=t??Array.from(E.state.chains.keys());for(const n of s){const r=e[n]??[],i=new Map(Se.recentConnections);i.set(n,r),Se.recentConnections=i}},getConnections(t){return t?Se.connections.get(t)??[]:[]},hasAnyConnection(t){const e=G.state.connections;return Array.from(e.values()).flatMap(s=>s).some(({connectorId:s})=>s===t)},async connectWalletConnect({cache:t="auto"}={}){var s,n,r,i;Se.wcFetchingUri=!0;const e=X.isTelegram()||X.isSafari()&&X.isIos();if(t==="always"||t==="auto"&&e){if(nr){await nr,nr=void 0;return}if(!X.isPairingExpired(Se==null?void 0:Se.wcPairingExpiry)){const o=Se.wcUri;Se.wcUri=o;return}nr=(n=(s=G._getClient())==null?void 0:s.connectWalletConnect)==null?void 0:n.call(s).catch(()=>{}),G.state.status="connecting",await nr,nr=void 0,Se.wcPairingExpiry=void 0,G.state.status="connected"}else await((i=(r=G._getClient())==null?void 0:r.connectWalletConnect)==null?void 0:i.call(r))},async connectExternal(t,e,s=!0){var o,a,c;const n=await((a=(o=G._getClient())==null?void 0:o.connectExternal)==null?void 0:a.call(o,t));s&&E.setActiveNamespace(e);const r=z.state.allConnectors.find(l=>l.id===(t==null?void 0:t.id)),i=t.type==="AUTH"?"email":"browser";return Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",properties:{method:i,name:(r==null?void 0:r.name)||"Unknown",view:ue.state.view,walletRank:(c=r==null?void 0:r.explorerWallet)==null?void 0:c.order}}),n},async reconnectExternal(t){var s,n;await((n=(s=G._getClient())==null?void 0:s.reconnectExternal)==null?void 0:n.call(s,t));const e=t.chain||E.state.activeChain;e&&z.setConnectorId(t.id,e)},async setPreferredAccountType(t,e){var n;if(!e)return;Ne.setLoading(!0,E.state.activeChain);const s=z.getAuthConnector();s&&(E.setAccountProp("preferredAccountType",t,e),await s.provider.setPreferredAccount(t),F.setPreferredAccountTypes(Object.entries(E.state.chains).reduce((r,[i,o])=>{const a=i,c=ls(a);return c!==void 0&&(r[a]=c),r},{})),await G.reconnectExternal(s),Ne.setLoading(!1,E.state.activeChain),Ee.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:t,network:((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}}))},async signMessage(t){var e;return(e=G._getClient())==null?void 0:e.signMessage(t)},parseUnits(t,e){var s;return(s=G._getClient())==null?void 0:s.parseUnits(t,e)},formatUnits(t,e){var s;return(s=G._getClient())==null?void 0:s.formatUnits(t,e)},updateBalance(t){var e;return(e=G._getClient())==null?void 0:e.updateBalance(t)},async sendTransaction(t){var e;return(e=G._getClient())==null?void 0:e.sendTransaction(t)},async getCapabilities(t){var e;return(e=G._getClient())==null?void 0:e.getCapabilities(t)},async grantPermissions(t){var e;return(e=G._getClient())==null?void 0:e.grantPermissions(t)},async walletGetAssets(t){var e;return((e=G._getClient())==null?void 0:e.walletGetAssets(t))??{}},async estimateGas(t){var e;return(e=G._getClient())==null?void 0:e.estimateGas(t)},async writeContract(t){var e;return(e=G._getClient())==null?void 0:e.writeContract(t)},async getEnsAddress(t){var e;return(e=G._getClient())==null?void 0:e.getEnsAddress(t)},async getEnsAvatar(t){var e;return(e=G._getClient())==null?void 0:e.getEnsAvatar(t)},checkInstalled(t){var e,s;return((s=(e=G._getClient())==null?void 0:e.checkInstalled)==null?void 0:s.call(e,t))||!1},resetWcConnection(){Se.wcUri=void 0,Se.wcPairingExpiry=void 0,Se.wcLinking=void 0,Se.recentWallet=void 0,Se.wcFetchingUri=!1,Se.status="disconnected",pa.resetTransactions(),F.deleteWalletConnectDeepLink(),F.deleteRecentWallet(),ds.set({connectingWallet:void 0})},resetUri(){Se.wcUri=void 0,Se.wcPairingExpiry=void 0,nr=void 0,Se.wcFetchingUri=!1,ds.set({connectingWallet:void 0})},finalizeWcConnection(t){var n,r;const{wcLinking:e,recentWallet:s}=G.state;e&&F.setWalletConnectDeepLink(e),s&&F.setAppKitRecent(s),t&&Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:t,properties:{method:e?"mobile":"qrcode",name:((r=(n=ue.state.data)==null?void 0:n.wallet)==null?void 0:r.name)||"Unknown",view:ue.state.view,walletRank:s==null?void 0:s.order}})},setWcBasic(t){Se.wcBasic=t},setUri(t){Se.wcUri=t,Se.wcFetchingUri=!1,Se.wcPairingExpiry=X.getPairingExpiry()},setWcLinking(t){Se.wcLinking=t},setWcError(t){Se.wcError=t,Se.wcFetchingUri=!1,Se.buffering=!1},setRecentWallet(t){Se.recentWallet=t},setBuffering(t){Se.buffering=t},setStatus(t){Se.status=t},setIsSwitchingConnection(t){Se.isSwitchingConnection=t},async disconnect({id:t,namespace:e,initialDisconnect:s}={}){var n;try{await((n=G._getClient())==null?void 0:n.disconnect({id:t,chainNamespace:e,initialDisconnect:s}))}catch(r){throw new Tr("Failed to disconnect","INTERNAL_SDK_ERROR",r)}},async disconnectConnector({id:t,namespace:e}){var s;try{await((s=G._getClient())==null?void 0:s.disconnectConnector({id:t,namespace:e}))}catch(n){throw new Tr("Failed to disconnect connector","INTERNAL_SDK_ERROR",n)}},setConnections(t,e){const s=new Map(Se.connections);s.set(e,t),Se.connections=s},async handleAuthAccountSwitch({address:t,namespace:e}){var i,o;const s=E.getAccountData(e),n=(o=(i=s==null?void 0:s.user)==null?void 0:i.accounts)==null?void 0:o.find(a=>a.type==="smartAccount"),r=n&&n.address.toLowerCase()===t.toLowerCase()&&Ci.canSwitchToSmartAccount(e)?"smartAccount":"eoa";await G.setPreferredAccountType(r,e)},async handleActiveConnection({connection:t,namespace:e,address:s}){const n=z.getConnectorById(t.connectorId),r=t.connectorId===U.CONNECTOR_ID.AUTH;if(!n)throw new Error(`No connector found for connection: ${t.connectorId}`);if(r)s&&await G.handleAuthAccountSwitch({address:s,namespace:e});else{const i=await G.connectExternal({id:n.id,type:n.type,provider:n.provider,address:s,chain:e},e);return i==null?void 0:i.address}return s},async handleDisconnectedConnection({connection:t,namespace:e,address:s,closeModalOnConnect:n}){var l,d;const r=z.getConnectorById(t.connectorId),i=(d=(l=t.auth)==null?void 0:l.name)==null?void 0:d.toLowerCase(),o=t.connectorId===U.CONNECTOR_ID.AUTH,a=t.connectorId===U.CONNECTOR_ID.WALLET_CONNECT;if(!r)throw new Error(`No connector found for connection: ${t.connectorId}`);let c;if(o)if(i&&Ci.isSocialProvider(i)){const{address:u}=await Ci.connectSocial({social:i,closeModalOnConnect:n,onOpenFarcaster(){Ne.open({view:"ConnectingFarcaster"})},onConnect(){ue.replace("ProfileWallets")}});c=u}else{const{address:u}=await Ci.connectEmail({closeModalOnConnect:n,onOpen(){Ne.open({view:"EmailLogin"})},onConnect(){ue.replace("ProfileWallets")}});c=u}else if(a){const{address:u}=await Ci.connectWalletConnect({walletConnect:!0,connector:r,closeModalOnConnect:n,onOpen(h){const p=h?"AllWallets":"ConnectingWalletConnect";Ne.state.open?ue.push(p):Ne.open({view:p})},onConnect(){ue.replace("ProfileWallets")}});c=u}else{const u=await G.connectExternal({id:r.id,type:r.type,provider:r.provider,chain:e},e);u&&(c=u.address)}return o&&s&&await G.handleAuthAccountSwitch({address:s,namespace:e}),c},async switchConnection({connection:t,address:e,namespace:s,closeModalOnConnect:n,onChange:r}){var c;let i;const o=(c=E.getAccountData(s))==null?void 0:c.caipAddress;if(o){const{address:l}=dt.parseCaipAddress(o);i=l}const a=$a.getConnectionStatus(t,s);switch(a){case"connected":case"active":{const l=await G.handleActiveConnection({connection:t,namespace:s,address:e});if(i&&l){const d=l.toLowerCase()!==i.toLowerCase();r==null||r({address:l,namespace:s,hasSwitchedAccount:d,hasSwitchedWallet:a==="active"})}break}case"disconnected":{const l=await G.handleDisconnectedConnection({connection:t,namespace:s,address:e,closeModalOnConnect:n});l&&(r==null||r({address:l,namespace:s,hasSwitchedAccount:!0,hasSwitchedWallet:!0}));break}default:throw new Error(`Invalid connection status: ${a}`)}}},G=As(Qv),Nc={createBalance(t,e){const s={name:t.metadata.name||"",symbol:t.metadata.symbol||"",decimals:t.metadata.decimals||0,value:t.metadata.value||0,price:t.metadata.price||0,iconUrl:t.metadata.iconUrl||""};return{name:s.name,symbol:s.symbol,chainId:e,address:t.address==="native"?void 0:this.convertAddressToCAIP10Address(t.address,e),value:s.value,price:s.price,quantity:{decimals:s.decimals.toString(),numeric:this.convertHexToBalance({hex:t.balance,decimals:s.decimals})},iconUrl:s.iconUrl}},convertHexToBalance({hex:t,decimals:e}){return If(BigInt(t),e)},convertAddressToCAIP10Address(t,e){return`${e}:${t}`},createCAIP2ChainId(t,e){return`${e}:${parseInt(t,16)}`},getChainIdHexFromCAIP2ChainId(t){const e=t.split(":");if(e.length<2||!e[1])return"0x0";const s=e[1],n=parseInt(s,10);return isNaN(n)?"0x0":`0x${n.toString(16)}`},isWalletGetAssetsResponse(t){return typeof t!="object"||t===null?!1:Object.values(t).every(e=>Array.isArray(e)&&e.every(s=>this.isValidAsset(s)))},isValidAsset(t){return typeof t=="object"&&t!==null&&typeof t.address=="string"&&typeof t.balance=="string"&&(t.type==="ERC20"||t.type==="NATIVE")&&typeof t.metadata=="object"&&t.metadata!==null&&typeof t.metadata.name=="string"&&typeof t.metadata.symbol=="string"&&typeof t.metadata.decimals=="number"&&typeof t.metadata.price=="number"&&typeof t.metadata.iconUrl=="string"}};let Tc;async function Gu(){if(!Tc){const{createPublicClient:t,http:e,defineChain:s}=await Dt(async()=>{const{createPublicClient:n,http:r,defineChain:i}=await import("./index-DeGBgVeI.js");return{createPublicClient:n,http:r,defineChain:i}},__vite__mapDeps([0,1,2,3,4,5]));Tc={createPublicClient:t,http:e,defineChain:s}}return Tc}const xl={getBlockchainApiRpcUrl(t,e){const s=new URL("https://rpc.walletconnect.org/v1/");return s.searchParams.set("chainId",t),s.searchParams.set("projectId",e),s.toString()},async getViemChain(t){const{defineChain:e}=await Gu(),{chainId:s}=dt.parseCaipNetworkId(t.caipNetworkId);return e({...t,id:Number(s)})},async createViemPublicClient(t){const{createPublicClient:e,http:s}=await Gu(),n=$.state.projectId,r=await xl.getViemChain(t);if(!r)throw new Error(`Chain ${t.caipNetworkId} not found in viem/chains`);return e({chain:r,transport:s(xl.getBlockchainApiRpcUrl(t.caipNetworkId,n))})}},Rd={async getMyTokensWithBalance(t){var a;const e=(a=E.getAccountData())==null?void 0:a.address,s=E.state.activeCaipNetwork,n=z.getConnectorId("eip155")===U.CONNECTOR_ID.AUTH;if(!e||!s)return[];const r=`${s.caipNetworkId}:${e}`,i=F.getBalanceCacheForCaipAddress(r);if(i)return i.balances;if(s.chainNamespace===U.CHAIN.EVM&&n){const c=await this.getEIP155Balances(e,s);if(c)return this.filterLowQualityTokens(c)}const o=await fe.getBalance(e,s.caipNetworkId,t);return this.filterLowQualityTokens(o.balances)},async getEIP155Balances(t,e){var s,n;try{const r=Nc.getChainIdHexFromCAIP2ChainId(e.caipNetworkId),i=await G.getCapabilities(t);if(!((n=(s=i==null?void 0:i[r])==null?void 0:s.assetDiscovery)!=null&&n.supported))return null;const o=await G.walletGetAssets({account:t,chainFilter:[r]});if(!Nc.isWalletGetAssetsResponse(o))return null;const c=(o[r]||[]).map(l=>Nc.createBalance(l,e.caipNetworkId));return F.updateBalanceCache({caipAddress:`${e.caipNetworkId}:${t}`,balance:{balances:c},timestamp:Date.now()}),c}catch{return null}},filterLowQualityTokens(t){return t.filter(e=>e.quantity.decimals!=="0")},async fetchERC20Balance({caipAddress:t,assetAddress:e,caipNetwork:s}){const n=await xl.createViemPublicClient(s),{address:r}=dt.parseCaipAddress(t),[{result:i},{result:o},{result:a},{result:c}]=await n.multicall({contracts:[{address:e,functionName:"name",args:[],abi:Bo},{address:e,functionName:"symbol",args:[],abi:Bo},{address:e,functionName:"balanceOf",args:[r],abi:Bo},{address:e,functionName:"decimals",args:[],abi:Bo}]});return{name:i,symbol:o,decimals:c,balance:a&&c?If(a,c):"0"}}},Rc={adapters:{}},Zf={state:Rc,initialize(t){Rc.adapters={...t}},get(t){return Rc.adapters[t]}},Da={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0,sui:void 0,stacks:void 0,ton:void 0},qt=Ge({providers:{...Da},providerIds:{...Da}}),He={state:qt,subscribeKey(t,e){return At(qt,t,e)},subscribe(t){return _t(qt,()=>{t(qt)})},subscribeProviders(t){return _t(qt.providers,()=>t(qt.providers))},setProvider(t,e){t&&e&&(qt.providers[t]=Qi(e))},getProvider(t){if(t)return qt.providers[t]},setProviderId(t,e){e&&(qt.providerIds[t]=e)},getProviderId(t){if(t)return qt.providerIds[t]},reset(){qt.providers={...Da},qt.providerIds={...Da}},resetChain(t){qt.providers[t]=void 0,qt.providerIds[t]=void 0}},eC={async getTokenList(t){var n;const e=await fe.fetchSwapTokens({chainId:t});return((n=e==null?void 0:e.tokens)==null?void 0:n.map(r=>({...r,eip2612:!1,quantity:{decimals:"0",numeric:"0"},price:0,value:0})))||[]},async fetchGasPrice(){var e;const t=E.state.activeCaipNetwork;if(!t)return null;try{switch(t.chainNamespace){case"solana":const s=(e=await(G==null?void 0:G.estimateGas({chainNamespace:"solana"})))==null?void 0:e.toString();return{standard:s,fast:s,instant:s};case"eip155":default:return await fe.fetchGasPrice({chainId:t.caipNetworkId})}}catch{return null}},async fetchSwapAllowance({tokenAddress:t,userAddress:e,sourceTokenAmount:s,sourceTokenDecimals:n}){const r=await fe.fetchSwapAllowance({tokenAddress:t,userAddress:e});if(r!=null&&r.allowance&&s&&n){const i=G.parseUnits(s,n)||0;return BigInt(r.allowance)>=i}return!1},async getMyTokensWithBalance(t){const e=await Rd.getMyTokensWithBalance(t);return E.setAccountProp("tokenBalance",e,E.state.activeChain),this.mapBalancesToSwapTokens(e)},mapBalancesToSwapTokens(t){return(t==null?void 0:t.map(e=>({...e,address:e!=null&&e.address?e.address:Yf(),decimals:parseInt(e.quantity.decimals,10),logoUri:e.iconUrl,eip2612:!1})))||[]},async handleSwapError(t){var e,s;try{const n=t==null?void 0:t.cause;if(!(n!=null&&n.json))return;const r=await n.json(),i=(s=(e=r==null?void 0:r.reasons)==null?void 0:e[0])==null?void 0:s.description;return i!=null&&i.includes("insufficient liquidity")?"Insufficient liquidity":void 0}catch{return}}},xe=Ge({tokenBalances:[],loading:!1}),tC={state:xe,subscribe(t){return _t(xe,()=>t(xe))},subscribeKey(t,e){return At(xe,t,e)},setToken(t){t&&(xe.token=Qi(t))},setTokenAmount(t){xe.sendTokenAmount=t},setReceiverAddress(t){xe.receiverAddress=t},setReceiverProfileImageUrl(t){xe.receiverProfileImageUrl=t},setReceiverProfileName(t){xe.receiverProfileName=t},setNetworkBalanceInUsd(t){xe.networkBalanceInUSD=t},setLoading(t){xe.loading=t},getSdkEventProperties(t){var e,s;return{message:X.parseError(t),isSmartAccount:ls(E.state.activeChain)===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((e=xe.token)==null?void 0:e.symbol)||"",amount:xe.sendTokenAmount??0,network:((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||""}},async sendToken(){var t;try{switch(_e.setLoading(!0),(t=E.state.activeCaipNetwork)==null?void 0:t.chainNamespace){case"eip155":await _e.sendEvmToken();return;case"solana":await _e.sendSolanaToken();return;default:throw new Error("Unsupported chain")}}catch(e){throw mn.isUserRejectedRequestError(e)?new Pf(e):e}finally{_e.setLoading(!1)}},async sendEvmToken(){var s,n,r;const t=E.state.activeChain;if(!t)throw new Error("SendController:sendEvmToken - activeChainNamespace is required");const e=ls(t);if(!_e.state.sendTokenAmount||!_e.state.receiverAddress)throw new Error("An amount and receiver address are required");if(!_e.state.token)throw new Error("A token is required");if((s=_e.state.token)!=null&&s.address){Ee.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:_e.state.token.address,amount:_e.state.sendTokenAmount,network:((n=E.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}});const{hash:i}=await _e.sendERC20Token({receiverAddress:_e.state.receiverAddress,tokenAddress:_e.state.token.address,sendTokenAmount:_e.state.sendTokenAmount,decimals:_e.state.token.quantity.decimals});i&&(xe.hash=i)}else{Ee.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:_e.state.token.symbol||"",amount:_e.state.sendTokenAmount,network:((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||""}});const{hash:i}=await _e.sendNativeToken({receiverAddress:_e.state.receiverAddress,sendTokenAmount:_e.state.sendTokenAmount,decimals:_e.state.token.quantity.decimals});i&&(xe.hash=i)}},async fetchTokenBalance(t){var o,a,c;xe.loading=!0;const e=E.state.activeChain,s=(o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=E.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=((c=E.getAccountData(e))==null?void 0:c.caipAddress)??E.state.activeCaipAddress,i=r?X.getPlainAddress(r):void 0;if(xe.lastRetry&&!X.isAllowedRetry(xe.lastRetry,30*Ie.ONE_SEC_MS))return xe.loading=!1,[];try{if(i&&s&&n){const l=await Rd.getMyTokensWithBalance();return xe.tokenBalances=l,xe.lastRetry=void 0,l}}catch(l){xe.lastRetry=Date.now(),t==null||t(l),Ks.showError("Token Balance Unavailable")}finally{xe.loading=!1}return[]},fetchNetworkBalance(){if(xe.tokenBalances.length===0)return;const t=eC.mapBalancesToSwapTokens(xe.tokenBalances);if(!t)return;const e=t.find(s=>s.address===Yf());e&&(xe.networkBalanceInUSD=e?iw.multiply(e.quantity.numeric,e.price).toString():"0")},async sendNativeToken(t){var o,a,c,l;ue.pushTransactionStack({});const e=t.receiverAddress,s=(o=E.getAccountData())==null?void 0:o.address,n=G.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),i=await G.sendTransaction({chainNamespace:U.CHAIN.EVM,to:e,address:s,data:"0x",value:n??BigInt(0)});return Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:ls("eip155")===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((a=_e.state.token)==null?void 0:a.symbol)||"",amount:t.sendTokenAmount,network:((c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId)||"",hash:i||""}}),(l=G._getClient())==null||l.updateBalance("eip155"),_e.resetSend(),{hash:i}},async sendERC20Token(t){var n,r,i;ue.pushTransactionStack({onSuccess(){ue.replace("Account")}});const e=G.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),s=(n=E.getAccountData())==null?void 0:n.address;if(s&&t.sendTokenAmount&&t.receiverAddress&&t.tokenAddress){const o=X.getPlainAddress(t.tokenAddress);if(!o)throw new Error("SendController:sendERC20Token - tokenAddress is required");const a=await G.writeContract({fromAddress:s,tokenAddress:o,args:[t.receiverAddress,e??BigInt(0)],method:"transfer",abi:lw.getERC20Abi(o),chainNamespace:U.CHAIN.EVM});return Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:ls("eip155")===tt.ACCOUNT_TYPES.SMART_ACCOUNT,token:((r=_e.state.token)==null?void 0:r.symbol)||"",amount:t.sendTokenAmount,network:((i=E.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)||"",hash:a||""}}),_e.resetSend(),{hash:a}}return{hash:void 0}},async sendSolanaToken(){var s,n,r;if(!_e.state.sendTokenAmount||!_e.state.receiverAddress)throw new Error("An amount and receiver address are required");ue.pushTransactionStack({onSuccess(){ue.replace("Account")}});let t;_e.state.token&&_e.state.token.address!==Ie.SOLANA_NATIVE_TOKEN_ADDRESS&&(X.isCaipAddress(_e.state.token.address)?t=X.getPlainAddress(_e.state.token.address):t=_e.state.token.address);const e=await G.sendTransaction({chainNamespace:"solana",tokenMint:t,to:_e.state.receiverAddress,value:_e.state.sendTokenAmount});e&&(xe.hash=e),(s=G._getClient())==null||s.updateBalance("solana"),Ee.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:!1,token:((n=_e.state.token)==null?void 0:n.symbol)||"",amount:_e.state.sendTokenAmount,network:((r=E.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||"",hash:e||""}}),_e.resetSend()},resetSend(){xe.token=void 0,xe.sendTokenAmount=void 0,xe.receiverAddress=void 0,xe.receiverProfileImageUrl=void 0,xe.receiverProfileName=void 0,xe.loading=!1,xe.tokenBalances=[]}},_e=As(tC),Oc={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,user:void 0,preferredAccountType:void 0},Ko={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},Q=Ge({chains:_w(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{connectionControllerClient:void 0},isSwitchingNamespace:!1}),Jf={state:Q,subscribe(t){return _t(Q,()=>{t(Q)})},subscribeKey(t,e){return At(Q,t,e)},subscribeAccountStateProp(t,e,s){var r;const n=s||Q.activeChain;return n?At(((r=Q.chains.get(n))==null?void 0:r.accountState)||{},t,e):()=>{}},subscribeChainProp(t,e,s){let n;return _t(Q.chains,()=>{var i;const r=s||Q.activeChain;if(r){const o=(i=Q.chains.get(r))==null?void 0:i[t];n!==o&&(n=o,e(o))}})},initialize(t,e,s){const{chainId:n,namespace:r}=F.getActiveNetworkProps(),i=e==null?void 0:e.find(d=>d.id.toString()===(n==null?void 0:n.toString())),a=t.find(d=>(d==null?void 0:d.namespace)===r)||(t==null?void 0:t[0]),c=t.map(d=>d.namespace).filter(d=>d!==void 0),l=$.state.enableEmbedded?new Set([...c]):new Set([...(e==null?void 0:e.map(d=>d.chainNamespace))??[]]);((t==null?void 0:t.length)===0||!a)&&(Q.noAdapters=!0),Q.noAdapters||(Q.activeChain=a==null?void 0:a.namespace,Q.activeCaipNetwork=i,E.setChainNetworkData(a==null?void 0:a.namespace,{caipNetwork:i}),Q.activeChain&&ds.set({activeChain:a==null?void 0:a.namespace})),l.forEach(d=>{const u=e==null?void 0:e.filter(g=>g.chainNamespace===d),h=F.getPreferredAccountTypes()||{},p={...$.state.defaultAccountTypes,...h};E.state.chains.set(d,{namespace:d,networkState:Ge({...Ko,caipNetwork:u==null?void 0:u[0]}),accountState:Ge({...Oc,preferredAccountType:p[d]}),caipNetworks:u??[],...s}),E.setRequestedCaipNetworks(u??[],d)})},removeAdapter(t){var e,s;if(Q.activeChain===t){const n=Array.from(Q.chains.entries()).find(([r])=>r!==t);if(n){const r=(s=(e=n[1])==null?void 0:e.caipNetworks)==null?void 0:s[0];r&&E.setActiveCaipNetwork(r)}}Q.chains.delete(t)},addAdapter(t,{connectionControllerClient:e},s){if(!t.namespace)throw new Error("ChainController:addAdapter - adapter must have a namespace");Q.chains.set(t.namespace,{namespace:t.namespace,networkState:{...Ko,caipNetwork:s[0]},accountState:{...Oc},caipNetworks:s,connectionControllerClient:e}),E.setRequestedCaipNetworks((s==null?void 0:s.filter(n=>n.chainNamespace===t.namespace))??[],t.namespace)},addNetwork(t){var s;const e=Q.chains.get(t.chainNamespace);if(e){const n=[...e.caipNetworks||[]];(s=e.caipNetworks)!=null&&s.find(r=>r.id===t.id)||n.push(t),Q.chains.set(t.chainNamespace,{...e,caipNetworks:n}),E.setRequestedCaipNetworks(n,t.chainNamespace),z.filterByNamespace(t.chainNamespace,!0)}},removeNetwork(t,e){var n,r,i;const s=Q.chains.get(t);if(s){const o=((n=Q.activeCaipNetwork)==null?void 0:n.id)===e,a=[...((r=s.caipNetworks)==null?void 0:r.filter(c=>c.id!==e))||[]];o&&((i=s==null?void 0:s.caipNetworks)!=null&&i[0])&&E.setActiveCaipNetwork(s.caipNetworks[0]),Q.chains.set(t,{...s,caipNetworks:a}),E.setRequestedCaipNetworks(a||[],t),a.length===0&&z.filterByNamespace(t,!1)}},setAdapterNetworkState(t,e){const s=Q.chains.get(t);s&&(s.networkState={...s.networkState||Ko,...e},Q.chains.set(t,s))},setChainAccountData(t,e,s=!0){if(!t)throw new Error("Chain is required to update chain account data");const n=Q.chains.get(t);if(n){const r={...n.accountState||Oc,...e};Q.chains.set(t,{...n,accountState:r}),(Q.chains.size===1||Q.activeChain===t)&&e.caipAddress&&(Q.activeCaipAddress=e.caipAddress)}},setChainNetworkData(t,e){if(!t)return;const s=Q.chains.get(t);if(s){const n={...s.networkState||Ko,...e};Q.chains.set(t,{...s,networkState:n})}},setAccountProp(t,e,s,n=!0){E.setChainAccountData(s,{[t]:e},n)},setActiveNamespace(t){var n,r;Q.activeChain=t;const e=t?Q.chains.get(t):void 0,s=(n=e==null?void 0:e.networkState)==null?void 0:n.caipNetwork;s!=null&&s.id&&t&&(Q.activeCaipAddress=(r=e==null?void 0:e.accountState)==null?void 0:r.caipAddress,Q.activeCaipNetwork=s,E.setChainNetworkData(t,{caipNetwork:s}),F.setActiveCaipNetworkId(s==null?void 0:s.caipNetworkId),ds.set({activeChain:t,selectedNetworkId:s==null?void 0:s.caipNetworkId}))},setActiveCaipNetwork(t){var i,o;if(!t)return;const e=Q.activeChain===t.chainNamespace;e||E.setIsSwitchingNamespace(!0);const s=Q.chains.get(t.chainNamespace);Q.activeChain=t.chainNamespace,Q.activeCaipNetwork=t,E.setChainNetworkData(t.chainNamespace,{caipNetwork:t});let n=(i=s==null?void 0:s.accountState)==null?void 0:i.address;if(n)Q.activeCaipAddress=`${t.chainNamespace}:${t.id}:${n}`;else if(e&&Q.activeCaipAddress){const{address:a}=dt.parseCaipAddress(Q.activeCaipAddress);n=a,Q.activeCaipAddress=`${t.caipNetworkId}:${n}`}else Q.activeCaipAddress=void 0;E.setChainAccountData(t.chainNamespace,{address:n,caipAddress:Q.activeCaipAddress}),_e.resetSend(),ds.set({activeChain:Q.activeChain,selectedNetworkId:(o=Q.activeCaipNetwork)==null?void 0:o.caipNetworkId}),F.setActiveCaipNetworkId(t.caipNetworkId),!E.checkIfSupportedNetwork(t.chainNamespace)&&$.state.enableNetworkSwitch&&!$.state.allowUnsupportedChain&&!G.state.wcBasic&&E.showUnsupportedChainUI()},addCaipNetwork(t){var s;if(!t)return;const e=Q.chains.get(t.chainNamespace);e&&((s=e==null?void 0:e.caipNetworks)==null||s.push(t))},async switchActiveNamespace(t){var r;if(!t)return;const e=t!==E.state.activeChain,s=(r=E.getNetworkData(t))==null?void 0:r.caipNetwork,n=E.getCaipNetworkByNamespace(t,s==null?void 0:s.id);e&&n&&await E.switchActiveNetwork(n)},async switchActiveNetwork(t,{throwOnFailure:e=!1}={}){var o;const s=E.state.activeChain;if(!s)throw new Error("ChainController:switchActiveNetwork - namespace is required");const n=He.getProviderId(Q.activeChain)==="AUTH",r=(o=E.getAccountData(s))==null?void 0:o.address,i=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(t.chainNamespace);try{if(r&&t.chainNamespace===s||n&&i){const a=Zf.get(t.chainNamespace);if(!a)throw new Error("Adapter not found");await a.switchNetwork({caipNetwork:t})}E.setActiveCaipNetwork(t)}catch(a){if(e)throw a}Ee.sendEvent({type:"track",event:"SWITCH_NETWORK",properties:{network:t.caipNetworkId}})},getConnectionControllerClient(t){const e=t||Q.activeChain;if(!e)throw new Error("Chain is required to get connection controller client");const s=Q.chains.get(e);if(!(s!=null&&s.connectionControllerClient))throw new Error("ConnectionController client not set");return s.connectionControllerClient},getNetworkProp(t,e){var n;const s=(n=Q.chains.get(e))==null?void 0:n.networkState;if(s)return s[t]},getRequestedCaipNetworks(t){const e=Q.chains.get(t),{approvedCaipNetworkIds:s=[],requestedCaipNetworks:n=[]}=(e==null?void 0:e.networkState)||{};return X.sortRequestedNetworks(s,n).filter(o=>o==null?void 0:o.id)},getAllRequestedCaipNetworks(){const t=[];return Q.chains.forEach(e=>{if(!e.namespace)throw new Error("ChainController:getAllRequestedCaipNetworks - chainAdapter must have a namespace");const s=E.getRequestedCaipNetworks(e.namespace);t.push(...s)}),t},setRequestedCaipNetworks(t,e){E.setAdapterNetworkState(e,{requestedCaipNetworks:t});const n=E.getAllRequestedCaipNetworks().map(i=>i.chainNamespace),r=Array.from(new Set(n));z.filterByNamespaces(r)},getAllApprovedCaipNetworkIds(){const t=[];return Q.chains.forEach(e=>{if(!e.namespace)throw new Error("ChainController:getAllApprovedCaipNetworkIds - chainAdapter must have a namespace");const s=E.getApprovedCaipNetworkIds(e.namespace);t.push(...s)}),t},getActiveCaipNetwork(t){var e,s;return t?(s=(e=Q.chains.get(t))==null?void 0:e.networkState)==null?void 0:s.caipNetwork:Q.activeCaipNetwork},getActiveCaipAddress(){return Q.activeCaipAddress},getApprovedCaipNetworkIds(t){var n;const e=Q.chains.get(t);return((n=e==null?void 0:e.networkState)==null?void 0:n.approvedCaipNetworkIds)||[]},setApprovedCaipNetworksData(t,e){E.setAdapterNetworkState(t,e)},checkIfSupportedNetwork(t,e){var r;const s=e||((r=Q.activeCaipNetwork)==null?void 0:r.caipNetworkId),n=E.getRequestedCaipNetworks(t);return n.length?n==null?void 0:n.some(i=>i.caipNetworkId===s):!0},checkIfSupportedChainId(t){if(!Q.activeChain)return!0;const e=E.getRequestedCaipNetworks(Q.activeChain);return e==null?void 0:e.some(s=>s.id===t)},checkIfSmartAccountEnabled(){var n,r;const t=Nf.caipNetworkIdToNumber((n=Q.activeCaipNetwork)==null?void 0:n.caipNetworkId);if(!Q.activeChain||!t)return!1;const s=((r=lt.get(oe.SMART_ACCOUNT_ENABLED_NETWORKS))==null?void 0:r.split(","))||[];return!!(s!=null&&s.includes(t.toString()))},showUnsupportedChainUI(){Ne.open({view:"UnsupportedChain"})},checkIfNamesSupported(){const t=Q.activeCaipNetwork;return!!(t!=null&&t.chainNamespace&&Ie.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(t.chainNamespace))},resetNetwork(t){E.setAdapterNetworkState(t,{approvedCaipNetworkIds:void 0,supportsAllNetworks:!0})},resetAccount(t){var r,i;const e=t;if(!e)throw new Error("Chain is required to set account prop");const s=(i=(r=E.state.chains.get(e))==null?void 0:r.accountState)==null?void 0:i.preferredAccountType,n=$.state.defaultAccountTypes[e];Q.activeCaipAddress=void 0,E.setChainAccountData(e,{smartAccountDeployed:!1,currentTab:0,caipAddress:void 0,address:void 0,balance:void 0,balanceSymbol:void 0,profileName:void 0,profileImage:void 0,addressExplorerUrl:void 0,tokenBalance:[],connectedWalletInfo:void 0,preferredAccountType:n||s,socialProvider:void 0,socialWindow:void 0,farcasterUrl:void 0,user:void 0,status:"disconnected"}),z.removeConnectorId(e)},setIsSwitchingNamespace(t){Q.isSwitchingNamespace=t},getFirstCaipNetworkSupportsAuthConnector(){var s,n;const t=[];let e;if(Q.chains.forEach(r=>{U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(i=>i===r.namespace)&&r.namespace&&t.push(r.namespace)}),t.length>0){const r=t[0];return e=r?(n=(s=Q.chains.get(r))==null?void 0:s.caipNetworks)==null?void 0:n[0]:void 0,e}},getAccountData(t){var s;const e=t||Q.activeChain;if(e)return(s=E.state.chains.get(e))==null?void 0:s.accountState},getNetworkData(t){var s;const e=t||Q.activeChain;if(e)return(s=E.state.chains.get(e))==null?void 0:s.networkState},getCaipNetworkByNamespace(t,e){var r,i,o;if(!t)return;const s=E.state.chains.get(t),n=(r=s==null?void 0:s.caipNetworks)==null?void 0:r.find(a=>a.id.toString()===(e==null?void 0:e.toString()));return n||((i=s==null?void 0:s.networkState)==null?void 0:i.caipNetwork)||((o=s==null?void 0:s.caipNetworks)==null?void 0:o[0])},getRequestedCaipNetworkIds(){const t=z.state.filterByNamespace;return(t?[Q.chains.get(t)]:Array.from(Q.chains.values())).flatMap(s=>(s==null?void 0:s.caipNetworks)||[]).map(s=>s.caipNetworkId)},getCaipNetworks(t){return t?E.getRequestedCaipNetworks(t):E.getAllRequestedCaipNetworks()},getCaipNetworkById(t,e){return Jf.getCaipNetworks(e).find(s=>s.id.toString()===t.toString()||s.caipNetworkId.toString()===t.toString())},setLastConnectedSIWECaipNetwork(t){Q.lastConnectedSIWECaipNetwork=t},getLastConnectedSIWECaipNetwork(){return Q.lastConnectedSIWECaipNetwork},async fetchTokenBalance(t){var o,a;const e=E.getAccountData();if(!e)return[];const s=(o=E.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=E.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=E.state.activeCaipAddress,i=r?X.getPlainAddress(r):void 0;if(E.setAccountProp("balanceLoading",!0,n),e.lastRetry&&!X.isAllowedRetry(e.lastRetry,30*Ie.ONE_SEC_MS))return E.setAccountProp("balanceLoading",!1,n),[];try{if(i&&s&&n){const c=await Rd.getMyTokensWithBalance();return E.setAccountProp("tokenBalance",c,n),E.setAccountProp("lastRetry",void 0,n),E.setAccountProp("balanceLoading",!1,n),c}}catch(c){E.setAccountProp("lastRetry",Date.now(),n),t==null||t(c),Ks.showError("Token Balance Unavailable")}finally{E.setAccountProp("balanceLoading",!1,n)}return[]},isCaipNetworkDisabled(t){var c;const e=t.chainNamespace,s=!!((c=E.getAccountData(e))!=null&&c.caipAddress),n=E.getAllApprovedCaipNetworkIds(),r=E.getNetworkProp("supportsAllNetworks",e)!==!1,i=z.getConnectorId(e),o=z.getAuthConnector(),a=i===U.CONNECTOR_ID.AUTH&&o;return!s||r||a?!1:!(n!=null&&n.includes(t.caipNetworkId))}},E=As(Jf),sC={onSwitchNetwork({network:t,ignoreSwitchConfirmation:e=!1}){var h,p;const s=E.state.activeCaipNetwork,n=E.state.activeChain,r=ue.state.data;if(t.id===(s==null?void 0:s.id))return;const o=!!((h=E.getAccountData(n))!=null&&h.address),a=!!((p=E.getAccountData(t.chainNamespace))!=null&&p.address),c=t.chainNamespace!==n,d=z.getConnectorId(n)===U.CONNECTOR_ID.AUTH,u=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(g=>g===t.chainNamespace);e||d&&u?ue.push("SwitchNetwork",{...r,network:t}):o&&c&&!a?ue.push("SwitchActiveChain",{switchToChain:t.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:t}):ue.push("SwitchNetwork",{...r,network:t})}},Wt=Ge({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),nC={state:Wt,subscribe(t){return _t(Wt,()=>t(Wt))},subscribeKey(t,e){return At(Wt,t,e)},async open(t){var o,a;const e=t==null?void 0:t.namespace,s=E.state.activeChain,n=e&&e!==s,r=(o=E.getAccountData(t==null?void 0:t.namespace))==null?void 0:o.caipAddress,i=E.state.noAdapters;if(G.state.wcBasic?te.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1}):await te.prefetch(),z.setFilterByNamespace(t==null?void 0:t.namespace),Ne.setLoading(!0,e),e&&n){const c=((a=E.getNetworkData(e))==null?void 0:a.caipNetwork)||E.getRequestedCaipNetworks(e)[0];c&&(i?(await E.switchActiveNetwork(c),ue.push("ConnectingWalletConnectBasic")):sC.onSwitchNetwork({network:c,ignoreSwitchConfirmation:!0}))}else $.state.manualWCControl||i&&!r?X.isMobile()?ue.reset("AllWallets"):ue.reset("ConnectingWalletConnectBasic"):t!=null&&t.view?ue.reset(t.view,t.data):r?ue.reset("Account"):ue.reset("Connect");Wt.open=!0,ds.set({open:!0}),Ee.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!r}})},close(){const t=$.state.enableEmbedded,e=!!E.state.activeCaipAddress;Wt.open&&Ee.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:e}}),Wt.open=!1,ue.reset("Connect"),Ne.clearLoading(),t?e?ue.replace("Account"):ue.push("Connect"):ds.set({open:!1}),G.resetUri()},setLoading(t,e){e&&Wt.loadingNamespaceMap.set(e,t),Wt.loading=t,ds.set({loading:t})},clearLoading(){Wt.loadingNamespaceMap.clear(),Wt.loading=!1,ds.set({loading:!1})},shake(){Wt.shake||(Wt.shake=!0,setTimeout(()=>{Wt.shake=!1},500))}},Ne=As(nC),ji={id:"2b92315d-eab7-5bef-84fa-089a131333f5",name:"USD Coin",symbol:"USDC",networks:[{name:"ethereum-mainnet",display_name:"Ethereum",chain_id:"1",contract_address:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48"},{name:"polygon-mainnet",display_name:"Polygon",chain_id:"137",contract_address:"0x2791Bca1f2de4661ED88A30C99A7a9449Aa84174"}]},kl={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},rC={providers:kf,selectedProvider:null,error:null,purchaseCurrency:ji,paymentCurrency:kl,purchaseCurrencies:[ji],paymentCurrencies:[],quotesLoading:!1},ke=Ge(rC),iC={state:ke,subscribe(t){return _t(ke,()=>t(ke))},subscribeKey(t,e){return At(ke,t,e)},setSelectedProvider(t){var e,s;if(t&&t.name==="meld"){const n=E.state.activeChain,r=n===U.CHAIN.SOLANA?"SOL":"USDC",i=n?((s=(e=E.state.chains.get(n))==null?void 0:e.accountState)==null?void 0:s.address)??"":"",o=new URL(t.url);o.searchParams.append("publicKey",Aw),o.searchParams.append("destinationCurrencyCode",r),o.searchParams.append("walletAddress",i),o.searchParams.append("externalCustomerId",$.state.projectId),ke.selectedProvider={...t,url:o.toString()}}else ke.selectedProvider=t},setOnrampProviders(t){if(Array.isArray(t)&&t.every(e=>typeof e=="string")){const e=t,s=kf.filter(n=>e.includes(n.name));ke.providers=s}else ke.providers=[]},setPurchaseCurrency(t){ke.purchaseCurrency=t},setPaymentCurrency(t){ke.paymentCurrency=t},setPurchaseAmount(t){Ul.state.purchaseAmount=t},setPaymentAmount(t){Ul.state.paymentAmount=t},async getAvailableCurrencies(){const t=await fe.getOnrampOptions();ke.purchaseCurrencies=t.purchaseCurrencies,ke.paymentCurrencies=t.paymentCurrencies,ke.paymentCurrency=t.paymentCurrencies[0]||kl,ke.purchaseCurrency=t.purchaseCurrencies[0]||ji,await te.fetchCurrencyImages(t.paymentCurrencies.map(e=>e.id)),await te.fetchTokenImages(t.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){var t,e;ke.quotesLoading=!0;try{const s=await fe.getOnrampQuote({purchaseCurrency:ke.purchaseCurrency,paymentCurrency:ke.paymentCurrency,amount:((t=ke.paymentAmount)==null?void 0:t.toString())||"0",network:(e=ke.purchaseCurrency)==null?void 0:e.symbol});return ke.quotesLoading=!1,ke.purchaseAmount=Number(s==null?void 0:s.purchaseAmount.amount),s}catch(s){return ke.error=s.message,ke.quotesLoading=!1,null}finally{ke.quotesLoading=!1}},resetState(){ke.selectedProvider=null,ke.error=null,ke.purchaseCurrency=ji,ke.paymentCurrency=kl,ke.purchaseCurrencies=[ji],ke.paymentCurrencies=[],ke.paymentAmount=void 0,ke.purchaseAmount=void 0,ke.quotesLoading=!1}},Ul=As(iC);function oC(t){return!t||typeof t.then!="function"?Promise.resolve(t):t}function ft(t,...e){try{return oC(t(...e))}catch(s){return Promise.reject(s)}}function aC(t){const e=typeof t;return t===null||e!=="object"&&e!=="function"}function cC(t){const e=Object.getPrototypeOf(t);return!e||e.isPrototypeOf(Object)}function fa(t){if(aC(t))return String(t);if(cC(t)||Array.isArray(t))return JSON.stringify(t);if(typeof t.toJSON=="function")return fa(t.toJSON());throw new Error("[unstorage] Cannot stringify value!")}const $l="base64:";function lC(t){return typeof t=="string"?t:$l+hC(t)}function dC(t){return typeof t!="string"||!t.startsWith($l)?t:uC(t.slice($l.length))}function uC(t){return globalThis.Buffer?Buffer.from(t,"base64"):Uint8Array.from(globalThis.atob(t),e=>e.codePointAt(0))}function hC(t){return globalThis.Buffer?Buffer.from(t).toString("base64"):globalThis.btoa(String.fromCodePoint(...t))}function zt(t){var e;return t&&((e=t.split("?")[0])==null?void 0:e.replace(/[/\\]/g,":").replace(/:+/g,":").replace(/^:|:$/g,""))||""}function pC(...t){return zt(t.join(":"))}function Go(t){return t=zt(t),t?t+":":""}function fC(t,e){if(e===void 0)return!0;let s=0,n=t.indexOf(":");for(;n>-1;)s++,n=t.indexOf(":",n+1);return s<=e}function gC(t,e){return e?t.startsWith(e)&&t[t.length-1]!=="$":t[t.length-1]!=="$"}const mC="memory",yC=()=>{const t=new Map;return{name:mC,getInstance:()=>t,hasItem(e){return t.has(e)},getItem(e){return t.get(e)??null},getItemRaw(e){return t.get(e)??null},setItem(e,s){t.set(e,s)},setItemRaw(e,s){t.set(e,s)},removeItem(e){t.delete(e)},getKeys(){return[...t.keys()]},clear(){t.clear()},dispose(){t.clear()}}};function wC(t={}){const e={mounts:{"":t.driver||yC()},mountpoints:[""],watching:!1,watchListeners:[],unwatch:{}},s=l=>{for(const d of e.mountpoints)if(l.startsWith(d))return{base:d,relativeKey:l.slice(d.length),driver:e.mounts[d]};return{base:"",relativeKey:l,driver:e.mounts[""]}},n=(l,d)=>e.mountpoints.filter(u=>u.startsWith(l)||d&&l.startsWith(u)).map(u=>({relativeBase:l.length>u.length?l.slice(u.length):void 0,mountpoint:u,driver:e.mounts[u]})),r=(l,d)=>{if(e.watching){d=zt(d);for(const u of e.watchListeners)u(l,d)}},i=async()=>{if(!e.watching){e.watching=!0;for(const l in e.mounts)e.unwatch[l]=await Yu(e.mounts[l],r,l)}},o=async()=>{if(e.watching){for(const l in e.unwatch)await e.unwatch[l]();e.unwatch={},e.watching=!1}},a=(l,d,u)=>{const h=new Map,p=g=>{let f=h.get(g.base);return f||(f={driver:g.driver,base:g.base,items:[]},h.set(g.base,f)),f};for(const g of l){const f=typeof g=="string",y=zt(f?g:g.key),_=f?void 0:g.value,S=f||!g.options?d:{...d,...g.options},v=s(y);p(v).items.push({key:y,value:_,relativeKey:v.relativeKey,options:S})}return Promise.all([...h.values()].map(g=>u(g))).then(g=>g.flat())},c={hasItem(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return ft(h.hasItem,u,d)},getItem(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return ft(h.getItem,u,d).then(p=>Lo(p))},getItems(l,d={}){return a(l,d,u=>u.driver.getItems?ft(u.driver.getItems,u.items.map(h=>({key:h.relativeKey,options:h.options})),d).then(h=>h.map(p=>({key:pC(u.base,p.key),value:Lo(p.value)}))):Promise.all(u.items.map(h=>ft(u.driver.getItem,h.relativeKey,h.options).then(p=>({key:h.key,value:Lo(p)})))))},getItemRaw(l,d={}){l=zt(l);const{relativeKey:u,driver:h}=s(l);return h.getItemRaw?ft(h.getItemRaw,u,d):ft(h.getItem,u,d).then(p=>dC(p))},async setItem(l,d,u={}){if(d===void 0)return c.removeItem(l);l=zt(l);const{relativeKey:h,driver:p}=s(l);p.setItem&&(await ft(p.setItem,h,fa(d),u),p.watch||r("update",l))},async setItems(l,d){await a(l,d,async u=>{if(u.driver.setItems)return ft(u.driver.setItems,u.items.map(h=>({key:h.relativeKey,value:fa(h.value),options:h.options})),d);u.driver.setItem&&await Promise.all(u.items.map(h=>ft(u.driver.setItem,h.relativeKey,fa(h.value),h.options)))})},async setItemRaw(l,d,u={}){if(d===void 0)return c.removeItem(l,u);l=zt(l);const{relativeKey:h,driver:p}=s(l);if(p.setItemRaw)await ft(p.setItemRaw,h,d,u);else if(p.setItem)await ft(p.setItem,h,lC(d),u);else return;p.watch||r("update",l)},async removeItem(l,d={}){typeof d=="boolean"&&(d={removeMeta:d}),l=zt(l);const{relativeKey:u,driver:h}=s(l);h.removeItem&&(await ft(h.removeItem,u,d),(d.removeMeta||d.removeMata)&&await ft(h.removeItem,u+"$",d),h.watch||r("remove",l))},async getMeta(l,d={}){typeof d=="boolean"&&(d={nativeOnly:d}),l=zt(l);const{relativeKey:u,driver:h}=s(l),p=Object.create(null);if(h.getMeta&&Object.assign(p,await ft(h.getMeta,u,d)),!d.nativeOnly){const g=await ft(h.getItem,u+"$",d).then(f=>Lo(f));g&&typeof g=="object"&&(typeof g.atime=="string"&&(g.atime=new Date(g.atime)),typeof g.mtime=="string"&&(g.mtime=new Date(g.mtime)),Object.assign(p,g))}return p},setMeta(l,d,u={}){return this.setItem(l+"$",d,u)},removeMeta(l,d={}){return this.removeItem(l+"$",d)},async getKeys(l,d={}){var y;l=Go(l);const u=n(l,!0);let h=[];const p=[];let g=!0;for(const _ of u){(y=_.driver.flags)!=null&&y.maxDepth||(g=!1);const S=await ft(_.driver.getKeys,_.relativeBase,d);for(const v of S){const C=_.mountpoint+zt(v);h.some(R=>C.startsWith(R))||p.push(C)}h=[_.mountpoint,...h.filter(v=>!v.startsWith(_.mountpoint))]}const f=d.maxDepth!==void 0&&!g;return p.filter(_=>(!f||fC(_,d.maxDepth))&&gC(_,l))},async clear(l,d={}){l=Go(l),await Promise.all(n(l,!1).map(async u=>{if(u.driver.clear)return ft(u.driver.clear,u.relativeBase,d);if(u.driver.removeItem){const h=await u.driver.getKeys(u.relativeBase||"",d);return Promise.all(h.map(p=>u.driver.removeItem(p,d)))}}))},async dispose(){await Promise.all(Object.values(e.mounts).map(l=>Zu(l)))},async watch(l){return await i(),e.watchListeners.push(l),async()=>{e.watchListeners=e.watchListeners.filter(d=>d!==l),e.watchListeners.length===0&&await o()}},async unwatch(){e.watchListeners=[],await o()},mount(l,d){if(l=Go(l),l&&e.mounts[l])throw new Error(`already mounted at ${l}`);return l&&(e.mountpoints.push(l),e.mountpoints.sort((u,h)=>h.length-u.length)),e.mounts[l]=d,e.watching&&Promise.resolve(Yu(d,r,l)).then(u=>{e.unwatch[l]=u}).catch(console.error),c},async unmount(l,d=!0){var u,h;l=Go(l),!(!l||!e.mounts[l])&&(e.watching&&l in e.unwatch&&((h=(u=e.unwatch)[l])==null||h.call(u),delete e.unwatch[l]),d&&await Zu(e.mounts[l]),e.mountpoints=e.mountpoints.filter(p=>p!==l),delete e.mounts[l])},getMount(l=""){l=zt(l)+":";const d=s(l);return{driver:d.driver,base:d.base}},getMounts(l="",d={}){return l=zt(l),n(l,d.parents).map(h=>({driver:h.driver,base:h.mountpoint}))},keys:(l,d={})=>c.getKeys(l,d),get:(l,d={})=>c.getItem(l,d),set:(l,d,u={})=>c.setItem(l,d,u),has:(l,d={})=>c.hasItem(l,d),del:(l,d={})=>c.removeItem(l,d),remove:(l,d={})=>c.removeItem(l,d)};return c}function Yu(t,e,s){return t.watch?t.watch((n,r)=>e(n,s+r)):()=>{}}async function Zu(t){typeof t.dispose=="function"&&await ft(t.dispose)}var Ju={};const EC="idb-keyval";var bC=(t={})=>{const e=t.base&&t.base.length>0?`${t.base}:`:"",s=r=>e+r;let n;return t.dbName&&t.storeName&&(n=_y(t.dbName,t.storeName)),{name:EC,options:t,async hasItem(r){return!(typeof await iu(s(r),n)>"u")},async getItem(r){return await iu(s(r),n)??null},setItem(r,i){return Ny(s(r),i,n)},removeItem(r){return Iy(s(r),n)},getKeys(){return Sy(n)},clear(){return Ay(n)}}};const vC="WALLET_CONNECT_V2_INDEXED_DB",CC="keyvaluestorage";let _C=class{constructor(){this.indexedDb=wC({driver:bC({dbName:vC,storeName:CC})})}async getKeys(){return this.indexedDb.getKeys()}async getEntries(){return(await this.indexedDb.getItems(await this.indexedDb.getKeys())).map(e=>[e.key,e.value])}async getItem(e){const s=await this.indexedDb.getItem(e);if(s!==null)return s}async setItem(e,s){await this.indexedDb.setItem(e,Gi(s))}async removeItem(e){await this.indexedDb.removeItem(e)}};var Pc=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof Ju<"u"?Ju:typeof self<"u"?self:{},ga={exports:{}};(function(){let t;function e(){}t=e,t.prototype.getItem=function(s){return this.hasOwnProperty(s)?String(this[s]):null},t.prototype.setItem=function(s,n){this[s]=String(n)},t.prototype.removeItem=function(s){delete this[s]},t.prototype.clear=function(){const s=this;Object.keys(s).forEach(function(n){s[n]=void 0,delete s[n]})},t.prototype.key=function(s){return s=s||0,Object.keys(this)[s]},t.prototype.__defineGetter__("length",function(){return Object.keys(this).length}),typeof Pc<"u"&&Pc.localStorage?ga.exports=Pc.localStorage:typeof window<"u"&&window.localStorage?ga.exports=window.localStorage:ga.exports=new e})();function AC(t){var e;return[t[0],Ca((e=t[1])!=null?e:"")]}let SC=class{constructor(){this.localStorage=ga.exports}async getKeys(){return Object.keys(this.localStorage)}async getEntries(){return Object.entries(this.localStorage).map(AC)}async getItem(e){const s=this.localStorage.getItem(e);if(s!==null)return Ca(s)}async setItem(e,s){this.localStorage.setItem(e,Gi(s))}async removeItem(e){this.localStorage.removeItem(e)}};const IC="wc_storage_version",Xu=1,NC=async(t,e,s)=>{const n=IC,r=await e.getItem(n);if(r&&r>=Xu){s(e);return}const i=await t.getKeys();if(!i.length){s(e);return}const o=[];for(;i.length;){const a=i.shift();if(!a)continue;const c=a.toLowerCase();if(c.includes("wc@")||c.includes("walletconnect")||c.includes("wc_")||c.includes("wallet_connect")){const l=await t.getItem(a);await e.setItem(a,l),o.push(a)}}await e.setItem(n,Xu),s(e),TC(t,o)},TC=async(t,e)=>{e.length&&e.forEach(async s=>{await t.removeItem(s)})};let RC=class{constructor(){this.initialized=!1,this.setInitialized=s=>{this.storage=s,this.initialized=!0};const e=new SC;this.storage=e;try{const s=new _C;NC(e,s,this.setInitialized)}catch{this.initialized=!0}}async getKeys(){return await this.initialize(),this.storage.getKeys()}async getEntries(){return await this.initialize(),this.storage.getEntries()}async getItem(e){return await this.initialize(),this.storage.getItem(e)}async setItem(e,s){return await this.initialize(),this.storage.setItem(e,s)}async removeItem(e){return await this.initialize(),this.storage.removeItem(e)}async initialize(){this.initialized||await new Promise(e=>{const s=setInterval(()=>{this.initialized&&(clearInterval(s),e())},20)})}};var OC=Object.defineProperty,PC=(t,e,s)=>e in t?OC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Qu=(t,e,s)=>PC(t,typeof e!="symbol"?e+"":e,s);let xC=class extends fi{constructor(e){super(),this.opts=e,Qu(this,"protocol","wc"),Qu(this,"version",2)}};var kC=Object.defineProperty,UC=(t,e,s)=>e in t?kC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,$C=(t,e,s)=>UC(t,e+"",s);let DC=class extends fi{constructor(e,s){super(),this.core=e,this.logger=s,$C(this,"records",new Map)}},LC=class{constructor(e,s){this.logger=e,this.core=s}},MC=class extends fi{constructor(e,s){super(),this.relayer=e,this.logger=s}},BC=class extends fi{constructor(e){super()}},jC=class{constructor(e,s,n,r){this.core=e,this.logger=s,this.name=n}},FC=class extends fi{constructor(e,s){super(),this.relayer=e,this.logger=s}},qC=class extends fi{constructor(e,s){super(),this.core=e,this.logger=s}},WC=class{constructor(e,s,n){this.core=e,this.logger=s,this.store=n}};class HC{constructor(e,s){this.projectId=e,this.logger=s}}let zC=class{constructor(e,s,n){this.core=e,this.logger=s,this.telemetryEnabled=n}};var VC=Object.defineProperty,KC=(t,e,s)=>e in t?VC(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,eh=(t,e,s)=>KC(t,typeof e!="symbol"?e+"":e,s);let GC=class{constructor(e){this.opts=e,eh(this,"protocol","wc"),eh(this,"version",2)}},YC=class{constructor(e){this.client=e}};const ZC="0.1.1";function JC(){return ZC}class Je extends Error{constructor(e,s={}){const n=(()=>{var c;if(s.cause instanceof Je){if(s.cause.details)return s.cause.details;if(s.cause.shortMessage)return s.cause.shortMessage}return s.cause&&"details"in s.cause&&typeof s.cause.details=="string"?s.cause.details:(c=s.cause)!=null&&c.message?s.cause.message:s.details})(),r=s.cause instanceof Je&&s.cause.docsPath||s.docsPath,o=`https://oxlib.sh${r??""}`,a=[e||"An error occurred.",...s.metaMessages?["",...s.metaMessages]:[],...n||r?["",n?`Details: ${n}`:void 0,r?`See: ${o}`:void 0]:[]].filter(c=>typeof c=="string").join(`
|
|
5
5
|
`);super(a,s.cause?{cause:s.cause}:void 0),Object.defineProperty(this,"details",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"docs",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"docsPath",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"shortMessage",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"cause",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"BaseError"}),Object.defineProperty(this,"version",{enumerable:!0,configurable:!0,writable:!0,value:`ox@${JC()}`}),this.cause=s.cause,this.details=n,this.docs=o,this.docsPath=r,this.shortMessage=e}walk(e){return Xf(this,e)}}function Xf(t,e){return e!=null&&e(t)?t:t&&typeof t=="object"&&"cause"in t&&t.cause?Xf(t.cause,e):e?null:t}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Od=BigInt(0),Dl=BigInt(1);function Io(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function Pd(t){if(!Io(t))throw new Error("Uint8Array expected")}function po(t,e){if(typeof e!="boolean")throw new Error(t+" boolean expected, got "+e)}function Yo(t){const e=t.toString(16);return e.length&1?"0"+e:e}function Qf(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return t===""?Od:BigInt("0x"+t)}const eg=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",XC=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function fo(t){if(Pd(t),eg)return t.toHex();let e="";for(let s=0;s<t.length;s++)e+=XC[t[s]];return e}const rn={_0:48,_9:57,A:65,F:70,a:97,f:102};function th(t){if(t>=rn._0&&t<=rn._9)return t-rn._0;if(t>=rn.A&&t<=rn.F)return t-(rn.A-10);if(t>=rn.a&&t<=rn.f)return t-(rn.a-10)}function La(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(eg)return Uint8Array.fromHex(t);const e=t.length,s=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(s);for(let r=0,i=0;r<s;r++,i+=2){const o=th(t.charCodeAt(i)),a=th(t.charCodeAt(i+1));if(o===void 0||a===void 0){const c=t[i]+t[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[r]=o*16+a}return n}function _r(t){return Qf(fo(t))}function tg(t){return Pd(t),Qf(fo(Uint8Array.from(t).reverse()))}function No(t,e){return La(t.toString(16).padStart(e*2,"0"))}function sg(t,e){return No(t,e).reverse()}function ws(t,e,s){let n;if(typeof e=="string")try{n=La(e)}catch(i){throw new Error(t+" must be hex string or Uint8Array, cause: "+i)}else if(Io(e))n=Uint8Array.from(e);else throw new Error(t+" must be hex string or Uint8Array");const r=n.length;if(typeof s=="number"&&r!==s)throw new Error(t+" of length "+s+" expected, got "+r);return n}function Ma(...t){let e=0;for(let n=0;n<t.length;n++){const r=t[n];Pd(r),e+=r.length}const s=new Uint8Array(e);for(let n=0,r=0;n<t.length;n++){const i=t[n];s.set(i,r),r+=i.length}return s}const xc=t=>typeof t=="bigint"&&Od<=t;function xd(t,e,s){return xc(t)&&xc(e)&&xc(s)&&e<=t&&t<s}function ti(t,e,s,n){if(!xd(e,s,n))throw new Error("expected valid "+t+": "+s+" <= n < "+n+", got "+e)}function QC(t){let e;for(e=0;t>Od;t>>=Dl,e+=1);return e}const oc=t=>(Dl<<BigInt(t))-Dl,kc=t=>new Uint8Array(t),sh=t=>Uint8Array.from(t);function e_(t,e,s){if(typeof t!="number"||t<2)throw new Error("hashLen must be a number");if(typeof e!="number"||e<2)throw new Error("qByteLen must be a number");if(typeof s!="function")throw new Error("hmacFn must be a function");let n=kc(t),r=kc(t),i=0;const o=()=>{n.fill(1),r.fill(0),i=0},a=(...u)=>s(r,n,...u),c=(u=kc(0))=>{r=a(sh([0]),u),n=a(),u.length!==0&&(r=a(sh([1]),u),n=a())},l=()=>{if(i++>=1e3)throw new Error("drbg: tried 1000 values");let u=0;const h=[];for(;u<e;){n=a();const p=n.slice();h.push(p),u+=n.length}return Ma(...h)};return(u,h)=>{o(),c(u);let p;for(;!(p=h(l()));)c();return o(),p}}const t_={bigint:t=>typeof t=="bigint",function:t=>typeof t=="function",boolean:t=>typeof t=="boolean",string:t=>typeof t=="string",stringOrUint8Array:t=>typeof t=="string"||Io(t),isSafeInteger:t=>Number.isSafeInteger(t),array:t=>Array.isArray(t),field:(t,e)=>e.Fp.isValid(t),hash:t=>typeof t=="function"&&Number.isSafeInteger(t.outputLen)};function ac(t,e,s={}){const n=(r,i,o)=>{const a=t_[i];if(typeof a!="function")throw new Error("invalid validator function");const c=t[r];if(!(o&&c===void 0)&&!a(c,t))throw new Error("param "+String(r)+" is invalid. Expected "+i+", got "+c)};for(const[r,i]of Object.entries(e))n(r,i,!1);for(const[r,i]of Object.entries(s))n(r,i,!0);return t}function nh(t){const e=new WeakMap;return(s,...n)=>{const r=e.get(s);if(r!==void 0)return r;const i=t(s,...n);return e.set(s,i),i}}function s_(t,e){if(ah(t)>e)throw new __({givenSize:ah(t),maxSize:e})}const on={zero:48,nine:57,A:65,F:70,a:97,f:102};function rh(t){if(t>=on.zero&&t<=on.nine)return t-on.zero;if(t>=on.A&&t<=on.F)return t-(on.A-10);if(t>=on.a&&t<=on.f)return t-(on.a-10)}function n_(t,e={}){const{dir:s,size:n=32}=e;if(n===0)return t;if(t.length>n)throw new A_({size:t.length,targetSize:n,type:"Bytes"});const r=new Uint8Array(n);for(let i=0;i<n;i++){const o=s==="right";r[o?i:n-i-1]=t[o?i:t.length-i-1]}return r}function ng(t,e){if(Qn(t)>e)throw new p_({givenSize:Qn(t),maxSize:e})}function r_(t,e){if(typeof e=="number"&&e>0&&e>Qn(t)-1)throw new og({offset:e,position:"start",size:Qn(t)})}function i_(t,e,s){if(typeof e=="number"&&typeof s=="number"&&Qn(t)!==s-e)throw new og({offset:s,position:"end",size:Qn(t)})}function rg(t,e={}){const{dir:s,size:n=32}=e;if(n===0)return t;const r=t.replace("0x","");if(r.length>n*2)throw new f_({size:Math.ceil(r.length/2),targetSize:n,type:"Hex"});return`0x${r[s==="right"?"padEnd":"padStart"](n*2,"0")}`}const o_="#__bigint";function kd(t,e,s){return JSON.stringify(t,(n,r)=>typeof r=="bigint"?r.toString()+o_:r,s)}const a_=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function c_(t,e={}){const{strict:s=!1}=e;if(!t)throw new ih(t);if(typeof t!="string")throw new ih(t);if(s&&!/^0x[0-9a-fA-F]*$/.test(t))throw new oh(t);if(!t.startsWith("0x"))throw new oh(t)}function l_(...t){return`0x${t.reduce((e,s)=>e+s.replace("0x",""),"")}`}function Ud(t){return t instanceof Uint8Array?Ba(t):Array.isArray(t)?Ba(new Uint8Array(t)):t}function Ba(t,e={}){let s="";for(let r=0;r<t.length;r++)s+=a_[t[r]];const n=`0x${s}`;return typeof e.size=="number"?(ng(n,e.size),ig(n,e.size)):n}function Uc(t,e={}){const{signed:s,size:n}=e,r=BigInt(t);let i;n?s?i=(1n<<BigInt(n)*8n-1n)-1n:i=2n**(BigInt(n)*8n)-1n:typeof t=="number"&&(i=BigInt(Number.MAX_SAFE_INTEGER));const o=typeof i=="bigint"&&s?-i-1n:0;if(i&&r>i||r<o){const l=typeof t=="bigint"?"n":"";throw new h_({max:i?`${i}${l}`:void 0,min:`${o}${l}`,signed:s,size:n,value:`${t}${l}`})}const c=`0x${(s&&r<0?(1n<<BigInt(n*8))+BigInt(r):r).toString(16)}`;return n?d_(c,n):c}function d_(t,e){return rg(t,{dir:"left",size:e})}function ig(t,e){return rg(t,{dir:"right",size:e})}function hn(t,e,s,n={}){const{strict:r}=n;r_(t,e);const i=`0x${t.replace("0x","").slice((e??0)*2,(s??t.length)*2)}`;return r&&i_(i,e,s),i}function Qn(t){return Math.ceil((t.length-2)/2)}function u_(t,e={}){const{strict:s=!1}=e;try{return c_(t,{strict:s}),!0}catch{return!1}}class h_ extends Je{constructor({max:e,min:s,signed:n,size:r,value:i}){super(`Number \`${i}\` is not in safe${r?` ${r*8}-bit`:""}${n?" signed":" unsigned"} integer range ${e?`(\`${s}\` to \`${e}\`)`:`(above \`${s}\`)`}`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.IntegerOutOfRangeError"})}}class ih extends Je{constructor(e){super(`Value \`${typeof e=="object"?kd(e):e}\` of type \`${typeof e}\` is an invalid hex type.`,{metaMessages:['Hex types must be represented as `"0x${string}"`.']}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.InvalidHexTypeError"})}}class oh extends Je{constructor(e){super(`Value \`${e}\` is an invalid hex value.`,{metaMessages:['Hex values must start with `"0x"` and contain only hexadecimal characters (0-9, a-f, A-F).']}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.InvalidHexValueError"})}}let p_=class extends Je{constructor({givenSize:e,maxSize:s}){super(`Size cannot exceed \`${s}\` bytes. Given size: \`${e}\` bytes.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.SizeOverflowError"})}};class og extends Je{constructor({offset:e,position:s,size:n}){super(`Slice ${s==="start"?"starting":"ending"} at offset \`${e}\` is out-of-bounds (size: \`${n}\`).`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.SliceOffsetOutOfBoundsError"})}}let f_=class extends Je{constructor({size:e,targetSize:s,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} size (\`${e}\`) exceeds padding size (\`${s}\`).`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Hex.SizeExceedsPaddingSizeError"})}};const g_=new TextEncoder;function m_(t){if(!(t instanceof Uint8Array)){if(!t)throw new Zo(t);if(typeof t!="object")throw new Zo(t);if(!("BYTES_PER_ELEMENT"in t))throw new Zo(t);if(t.BYTES_PER_ELEMENT!==1||t.constructor.name!=="Uint8Array")throw new Zo(t)}}function y_(t){return t instanceof Uint8Array?t:typeof t=="string"?E_(t):w_(t)}function w_(t){return t instanceof Uint8Array?t:new Uint8Array(t)}function E_(t,e={}){const{size:s}=e;let n=t;s&&(ng(t,s),n=ig(t,s));let r=n.slice(2);r.length%2&&(r=`0${r}`);const i=r.length/2,o=new Uint8Array(i);for(let a=0,c=0;a<i;a++){const l=rh(r.charCodeAt(c++)),d=rh(r.charCodeAt(c++));if(l===void 0||d===void 0)throw new Je(`Invalid byte sequence ("${r[c-2]}${r[c-1]}" in "${r}").`);o[a]=l*16+d}return o}function b_(t,e={}){const{size:s}=e,n=g_.encode(t);return typeof s=="number"?(s_(n,s),v_(n,s)):n}function v_(t,e){return n_(t,{dir:"right",size:e})}function ah(t){return t.length}function C_(t){try{return m_(t),!0}catch{return!1}}class Zo extends Je{constructor(e){super(`Value \`${typeof e=="object"?kd(e):e}\` of type \`${typeof e}\` is an invalid Bytes value.`,{metaMessages:["Bytes values must be of type `Bytes`."]}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.InvalidBytesTypeError"})}}class __ extends Je{constructor({givenSize:e,maxSize:s}){super(`Size cannot exceed \`${s}\` bytes. Given size: \`${e}\` bytes.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeOverflowError"})}}class A_ extends Je{constructor({size:e,targetSize:s,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} size (\`${e}\`) exceeds padding size (\`${s}\`).`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Bytes.SizeExceedsPaddingSizeError"})}}function ag(t,e={}){const{as:s=typeof t=="string"?"Hex":"Bytes"}=e,n=Hy(y_(t));return s==="Bytes"?n:Ba(n)}class S_ extends Map{constructor(e){super(),Object.defineProperty(this,"maxSize",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.maxSize=e}get(e){const s=super.get(e);return super.has(e)&&s!==void 0&&(this.delete(e),super.set(e,s)),s}set(e,s){if(super.set(e,s),this.maxSize&&this.size>this.maxSize){const n=this.keys().next().value;n&&this.delete(n)}return this}}const I_={checksum:new S_(8192)},$c=I_.checksum;function cg(t,e={}){const{compressed:s}=e,{prefix:n,x:r,y:i}=t;if(s===!1||typeof r=="bigint"&&typeof i=="bigint"){if(n!==4)throw new ch({prefix:n,cause:new x_});return}if(s===!0||typeof r=="bigint"&&typeof i>"u"){if(n!==3&&n!==2)throw new ch({prefix:n,cause:new P_});return}throw new O_({publicKey:t})}function N_(t){const e=(()=>{if(u_(t))return lg(t);if(C_(t))return T_(t);const{prefix:s,x:n,y:r}=t;return typeof n=="bigint"&&typeof r=="bigint"?{prefix:s??4,x:n,y:r}:{prefix:s,x:n}})();return cg(e),e}function T_(t){return lg(Ba(t))}function lg(t){if(t.length!==132&&t.length!==130&&t.length!==68)throw new k_({publicKey:t});if(t.length===130){const n=BigInt(hn(t,0,32)),r=BigInt(hn(t,32,64));return{prefix:4,x:n,y:r}}if(t.length===132){const n=Number(hn(t,0,1)),r=BigInt(hn(t,1,33)),i=BigInt(hn(t,33,65));return{prefix:n,x:r,y:i}}const e=Number(hn(t,0,1)),s=BigInt(hn(t,1,33));return{prefix:e,x:s}}function R_(t,e={}){cg(t);const{prefix:s,x:n,y:r}=t,{includePrefix:i=!0}=e;return l_(i?Uc(s,{size:1}):"0x",Uc(n,{size:32}),typeof r=="bigint"?Uc(r,{size:32}):"0x")}class O_ extends Je{constructor({publicKey:e}){super(`Value \`${kd(e)}\` is not a valid public key.`,{metaMessages:["Public key must contain:","- an `x` and `prefix` value (compressed)","- an `x`, `y`, and `prefix` value (uncompressed)"]}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"PublicKey.InvalidError"})}}class ch extends Je{constructor({prefix:e,cause:s}){super(`Prefix "${e}" is invalid.`,{cause:s}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"PublicKey.InvalidPrefixError"})}}class P_ extends Je{constructor(){super("Prefix must be 2 or 3 for compressed public keys."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"PublicKey.InvalidCompressedPrefixError"})}}class x_ extends Je{constructor(){super("Prefix must be 4 for uncompressed public keys."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"PublicKey.InvalidUncompressedPrefixError"})}}let k_=class extends Je{constructor({publicKey:e}){super(`Value \`${e}\` is an invalid public key size.`,{metaMessages:["Expected: 33 bytes (compressed + prefix), 64 bytes (uncompressed) or 65 bytes (uncompressed + prefix).",`Received ${Qn(Ud(e))} bytes.`]}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"PublicKey.InvalidSerializedSizeError"})}};const U_=/^0x[a-fA-F0-9]{40}$/;function dg(t,e={}){const{strict:s=!0}=e;if(!U_.test(t))throw new lh({address:t,cause:new L_});if(s){if(t.toLowerCase()===t)return;if(ug(t)!==t)throw new lh({address:t,cause:new M_})}}function ug(t){if($c.has(t))return $c.get(t);dg(t,{strict:!1});const e=t.substring(2).toLowerCase(),s=ag(b_(e),{as:"Bytes"}),n=e.split("");for(let i=0;i<40;i+=2)s[i>>1]>>4>=8&&n[i]&&(n[i]=n[i].toUpperCase()),(s[i>>1]&15)>=8&&n[i+1]&&(n[i+1]=n[i+1].toUpperCase());const r=`0x${n.join("")}`;return $c.set(t,r),r}function $_(t,e={}){const{checksum:s=!1}=e;return dg(t),s?ug(t):t}function D_(t,e={}){const s=ag(`0x${R_(t).slice(4)}`).substring(26);return $_(`0x${s}`,e)}class lh extends Je{constructor({address:e,cause:s}){super(`Address "${e}" is invalid.`,{cause:s}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidAddressError"})}}class L_ extends Je{constructor(){super("Address is not a 20 byte (40 hexadecimal character) value."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidInputError"})}}class M_ extends Je{constructor(){super("Address does not match its checksum counterpart."),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Address.InvalidChecksumError"})}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const Jt=BigInt(0),Mt=BigInt(1),gr=BigInt(2),B_=BigInt(3),hg=BigInt(4),pg=BigInt(5),fg=BigInt(8);function Gt(t,e){const s=t%e;return s>=Jt?s:e+s}function hs(t,e,s){let n=t;for(;e-- >Jt;)n*=n,n%=s;return n}function Ll(t,e){if(t===Jt)throw new Error("invert: expected non-zero number");if(e<=Jt)throw new Error("invert: expected positive modulus, got "+e);let s=Gt(t,e),n=e,r=Jt,i=Mt;for(;s!==Jt;){const a=n/s,c=n%s,l=r-i*a;n=s,s=c,r=i,i=l}if(n!==Mt)throw new Error("invert: does not exist");return Gt(r,e)}function gg(t,e){const s=(t.ORDER+Mt)/hg,n=t.pow(e,s);if(!t.eql(t.sqr(n),e))throw new Error("Cannot find square root");return n}function j_(t,e){const s=(t.ORDER-pg)/fg,n=t.mul(e,gr),r=t.pow(n,s),i=t.mul(e,r),o=t.mul(t.mul(i,gr),r),a=t.mul(i,t.sub(o,t.ONE));if(!t.eql(t.sqr(a),e))throw new Error("Cannot find square root");return a}function F_(t){if(t<BigInt(3))throw new Error("sqrt is not defined for small field");let e=t-Mt,s=0;for(;e%gr===Jt;)e/=gr,s++;let n=gr;const r=$d(t);for(;dh(r,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return gg;let i=r.pow(n,e);const o=(e+Mt)/gr;return function(c,l){if(c.is0(l))return l;if(dh(c,l)!==1)throw new Error("Cannot find square root");let d=s,u=c.mul(c.ONE,i),h=c.pow(l,e),p=c.pow(l,o);for(;!c.eql(h,c.ONE);){if(c.is0(h))return c.ZERO;let g=1,f=c.sqr(h);for(;!c.eql(f,c.ONE);)if(g++,f=c.sqr(f),g===d)throw new Error("Cannot find square root");const y=Mt<<BigInt(d-g-1),_=c.pow(u,y);d=g,u=c.sqr(_),h=c.mul(h,u),p=c.mul(p,_)}return p}}function q_(t){return t%hg===B_?gg:t%fg===pg?j_:F_(t)}const W_=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function H_(t){const e={ORDER:"bigint",MASK:"bigint",BYTES:"isSafeInteger",BITS:"isSafeInteger"},s=W_.reduce((n,r)=>(n[r]="function",n),e);return ac(t,s)}function z_(t,e,s){if(s<Jt)throw new Error("invalid exponent, negatives unsupported");if(s===Jt)return t.ONE;if(s===Mt)return e;let n=t.ONE,r=e;for(;s>Jt;)s&Mt&&(n=t.mul(n,r)),r=t.sqr(r),s>>=Mt;return n}function mg(t,e,s=!1){const n=new Array(e.length).fill(s?t.ZERO:void 0),r=e.reduce((o,a,c)=>t.is0(a)?o:(n[c]=o,t.mul(o,a)),t.ONE),i=t.inv(r);return e.reduceRight((o,a,c)=>t.is0(a)?o:(n[c]=t.mul(o,n[c]),t.mul(o,a)),i),n}function dh(t,e){const s=(t.ORDER-Mt)/gr,n=t.pow(e,s),r=t.eql(n,t.ONE),i=t.eql(n,t.ZERO),o=t.eql(n,t.neg(t.ONE));if(!r&&!i&&!o)throw new Error("invalid Legendre symbol result");return r?1:i?0:-1}function yg(t,e){e!==void 0&&zy(e);const s=e!==void 0?e:t.toString(2).length,n=Math.ceil(s/8);return{nBitLength:s,nByteLength:n}}function $d(t,e,s=!1,n={}){if(t<=Jt)throw new Error("invalid field: expected ORDER > 0, got "+t);const{nBitLength:r,nByteLength:i}=yg(t,e);if(i>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let o;const a=Object.freeze({ORDER:t,isLE:s,BITS:r,BYTES:i,MASK:oc(r),ZERO:Jt,ONE:Mt,create:c=>Gt(c,t),isValid:c=>{if(typeof c!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof c);return Jt<=c&&c<t},is0:c=>c===Jt,isOdd:c=>(c&Mt)===Mt,neg:c=>Gt(-c,t),eql:(c,l)=>c===l,sqr:c=>Gt(c*c,t),add:(c,l)=>Gt(c+l,t),sub:(c,l)=>Gt(c-l,t),mul:(c,l)=>Gt(c*l,t),pow:(c,l)=>z_(a,c,l),div:(c,l)=>Gt(c*Ll(l,t),t),sqrN:c=>c*c,addN:(c,l)=>c+l,subN:(c,l)=>c-l,mulN:(c,l)=>c*l,inv:c=>Ll(c,t),sqrt:n.sqrt||(c=>(o||(o=q_(t)),o(a,c))),toBytes:c=>s?sg(c,i):No(c,i),fromBytes:c=>{if(c.length!==i)throw new Error("Field.fromBytes: expected "+i+" bytes, got "+c.length);return s?tg(c):_r(c)},invertBatch:c=>mg(a,c),cmov:(c,l,d)=>d?l:c});return Object.freeze(a)}function wg(t){if(typeof t!="bigint")throw new Error("field order must be bigint");const e=t.toString(2).length;return Math.ceil(e/8)}function Eg(t){const e=wg(t);return e+Math.ceil(e/2)}function V_(t,e,s=!1){const n=t.length,r=wg(e),i=Eg(e);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);const o=s?tg(t):_r(t),a=Gt(o,e-Mt)+Mt;return s?sg(a,r):No(a,r)}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const uh=BigInt(0),Ml=BigInt(1);function Dc(t,e){const s=e.negate();return t?s:e}function bg(t,e){if(!Number.isSafeInteger(t)||t<=0||t>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+t)}function Lc(t,e){bg(t,e);const s=Math.ceil(e/t)+1,n=2**(t-1),r=2**t,i=oc(t),o=BigInt(t);return{windows:s,windowSize:n,mask:i,maxNumber:r,shiftBy:o}}function hh(t,e,s){const{windowSize:n,mask:r,maxNumber:i,shiftBy:o}=s;let a=Number(t&r),c=t>>o;a>n&&(a-=i,c+=Ml);const l=e*n,d=l+Math.abs(a)-1,u=a===0,h=a<0,p=e%2!==0;return{nextN:c,offset:d,isZero:u,isNeg:h,isNegF:p,offsetF:l}}function K_(t,e){if(!Array.isArray(t))throw new Error("array expected");t.forEach((s,n)=>{if(!(s instanceof e))throw new Error("invalid point at index "+n)})}function G_(t,e){if(!Array.isArray(t))throw new Error("array of scalars expected");t.forEach((s,n)=>{if(!e.isValid(s))throw new Error("invalid scalar at index "+n)})}const Mc=new WeakMap,vg=new WeakMap;function Bc(t){return vg.get(t)||1}function Y_(t,e){return{constTimeNegate:Dc,hasPrecomputes(s){return Bc(s)!==1},unsafeLadder(s,n,r=t.ZERO){let i=s;for(;n>uh;)n&Ml&&(r=r.add(i)),i=i.double(),n>>=Ml;return r},precomputeWindow(s,n){const{windows:r,windowSize:i}=Lc(n,e),o=[];let a=s,c=a;for(let l=0;l<r;l++){c=a,o.push(c);for(let d=1;d<i;d++)c=c.add(a),o.push(c);a=c.double()}return o},wNAF(s,n,r){let i=t.ZERO,o=t.BASE;const a=Lc(s,e);for(let c=0;c<a.windows;c++){const{nextN:l,offset:d,isZero:u,isNeg:h,isNegF:p,offsetF:g}=hh(r,c,a);r=l,u?o=o.add(Dc(p,n[g])):i=i.add(Dc(h,n[d]))}return{p:i,f:o}},wNAFUnsafe(s,n,r,i=t.ZERO){const o=Lc(s,e);for(let a=0;a<o.windows&&r!==uh;a++){const{nextN:c,offset:l,isZero:d,isNeg:u}=hh(r,a,o);if(r=c,!d){const h=n[l];i=i.add(u?h.negate():h)}}return i},getPrecomputes(s,n,r){let i=Mc.get(n);return i||(i=this.precomputeWindow(n,s),s!==1&&Mc.set(n,r(i))),i},wNAFCached(s,n,r){const i=Bc(s);return this.wNAF(i,this.getPrecomputes(i,s,r),n)},wNAFCachedUnsafe(s,n,r,i){const o=Bc(s);return o===1?this.unsafeLadder(s,n,i):this.wNAFUnsafe(o,this.getPrecomputes(o,s,r),n,i)},setWindowSize(s,n){bg(n,e),vg.set(s,n),Mc.delete(s)}}}function Z_(t,e,s,n){K_(s,t),G_(n,e);const r=s.length,i=n.length;if(r!==i)throw new Error("arrays of points and scalars must have equal length");const o=t.ZERO,a=QC(BigInt(r));let c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);const l=oc(c),d=new Array(Number(l)+1).fill(o),u=Math.floor((e.BITS-1)/c)*c;let h=o;for(let p=u;p>=0;p-=c){d.fill(o);for(let f=0;f<i;f++){const y=n[f],_=Number(y>>BigInt(p)&l);d[_]=d[_].add(s[f])}let g=o;for(let f=d.length-1,y=o;f>0;f--)y=y.add(d[f]),g=g.add(y);if(h=h.add(g),p!==0)for(let f=0;f<c;f++)h=h.double()}return h}function Cg(t){return H_(t.Fp),ac(t,{n:"bigint",h:"bigint",Gx:"field",Gy:"field"},{nBitLength:"isSafeInteger",nByteLength:"isSafeInteger"}),Object.freeze({...yg(t.n,t.nBitLength),...t,p:t.Fp.ORDER})}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function ph(t){t.lowS!==void 0&&po("lowS",t.lowS),t.prehash!==void 0&&po("prehash",t.prehash)}function J_(t){const e=Cg(t);ac(e,{a:"field",b:"field"},{allowInfinityPoint:"boolean",allowedPrivateKeyLengths:"array",clearCofactor:"function",fromBytes:"function",isTorsionFree:"function",toBytes:"function",wrapPrivateKey:"boolean"});const{endo:s,Fp:n,a:r}=e;if(s){if(!n.eql(r,n.ZERO))throw new Error("invalid endo: CURVE.a must be 0");if(typeof s!="object"||typeof s.beta!="bigint"||typeof s.splitScalar!="function")throw new Error('invalid endo: expected "beta": bigint and "splitScalar": function')}return Object.freeze({...e})}class X_ extends Error{constructor(e=""){super(e)}}const fn={Err:X_,_tlv:{encode:(t,e)=>{const{Err:s}=fn;if(t<0||t>256)throw new s("tlv.encode: wrong tag");if(e.length&1)throw new s("tlv.encode: unpadded data");const n=e.length/2,r=Yo(n);if(r.length/2&128)throw new s("tlv.encode: long form length too big");const i=n>127?Yo(r.length/2|128):"";return Yo(t)+i+r+e},decode(t,e){const{Err:s}=fn;let n=0;if(t<0||t>256)throw new s("tlv.encode: wrong tag");if(e.length<2||e[n++]!==t)throw new s("tlv.decode: wrong tlv");const r=e[n++],i=!!(r&128);let o=0;if(!i)o=r;else{const c=r&127;if(!c)throw new s("tlv.decode(long): indefinite length not supported");if(c>4)throw new s("tlv.decode(long): byte length is too big");const l=e.subarray(n,n+c);if(l.length!==c)throw new s("tlv.decode: length bytes not complete");if(l[0]===0)throw new s("tlv.decode(long): zero leftmost byte");for(const d of l)o=o<<8|d;if(n+=c,o<128)throw new s("tlv.decode(long): not minimal encoding")}const a=e.subarray(n,n+o);if(a.length!==o)throw new s("tlv.decode: wrong value length");return{v:a,l:e.subarray(n+o)}}},_int:{encode(t){const{Err:e}=fn;if(t<yn)throw new e("integer: negative integers are not allowed");let s=Yo(t);if(Number.parseInt(s[0],16)&8&&(s="00"+s),s.length&1)throw new e("unexpected DER parsing assertion: unpadded hex");return s},decode(t){const{Err:e}=fn;if(t[0]&128)throw new e("invalid signature integer: negative");if(t[0]===0&&!(t[1]&128))throw new e("invalid signature integer: unnecessary leading zero");return _r(t)}},toSig(t){const{Err:e,_int:s,_tlv:n}=fn,r=ws("signature",t),{v:i,l:o}=n.decode(48,r);if(o.length)throw new e("invalid signature: left bytes after parsing");const{v:a,l:c}=n.decode(2,i),{v:l,l:d}=n.decode(2,c);if(d.length)throw new e("invalid signature: left bytes after parsing");return{r:s.decode(a),s:s.decode(l)}},hexFromSig(t){const{_tlv:e,_int:s}=fn,n=e.encode(2,s.encode(t.r)),r=e.encode(2,s.encode(t.s)),i=n+r;return e.encode(48,i)}};function jc(t,e){return fo(No(t,e))}const yn=BigInt(0),gt=BigInt(1);BigInt(2);const Fc=BigInt(3),Q_=BigInt(4);function e0(t){const e=J_(t),{Fp:s}=e,n=$d(e.n,e.nBitLength),r=e.toBytes||((v,C,R)=>{const D=C.toAffine();return Ma(Uint8Array.from([4]),s.toBytes(D.x),s.toBytes(D.y))}),i=e.fromBytes||(v=>{const C=v.subarray(1),R=s.fromBytes(C.subarray(0,s.BYTES)),D=s.fromBytes(C.subarray(s.BYTES,2*s.BYTES));return{x:R,y:D}});function o(v){const{a:C,b:R}=e,D=s.sqr(v),L=s.mul(D,v);return s.add(s.add(L,s.mul(v,C)),R)}function a(v,C){const R=s.sqr(C),D=o(v);return s.eql(R,D)}if(!a(e.Gx,e.Gy))throw new Error("bad curve params: generator point");const c=s.mul(s.pow(e.a,Fc),Q_),l=s.mul(s.sqr(e.b),BigInt(27));if(s.is0(s.add(c,l)))throw new Error("bad curve params: a or b");function d(v){return xd(v,gt,e.n)}function u(v){const{allowedPrivateKeyLengths:C,nByteLength:R,wrapPrivateKey:D,n:L}=e;if(C&&typeof v!="bigint"){if(Io(v)&&(v=fo(v)),typeof v!="string"||!C.includes(v.length))throw new Error("invalid private key");v=v.padStart(R*2,"0")}let W;try{W=typeof v=="bigint"?v:_r(ws("private key",v,R))}catch{throw new Error("invalid private key, expected hex or "+R+" bytes, got "+typeof v)}return D&&(W=Gt(W,L)),ti("private key",W,gt,L),W}function h(v){if(!(v instanceof f))throw new Error("ProjectivePoint expected")}const p=nh((v,C)=>{const{px:R,py:D,pz:L}=v;if(s.eql(L,s.ONE))return{x:R,y:D};const W=v.is0();C==null&&(C=W?s.ONE:s.inv(L));const k=s.mul(R,C),q=s.mul(D,C),V=s.mul(L,C);if(W)return{x:s.ZERO,y:s.ZERO};if(!s.eql(V,s.ONE))throw new Error("invZ was invalid");return{x:k,y:q}}),g=nh(v=>{if(v.is0()){if(e.allowInfinityPoint&&!s.is0(v.py))return;throw new Error("bad point: ZERO")}const{x:C,y:R}=v.toAffine();if(!s.isValid(C)||!s.isValid(R))throw new Error("bad point: x or y not FE");if(!a(C,R))throw new Error("bad point: equation left != right");if(!v.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});class f{constructor(C,R,D){if(C==null||!s.isValid(C))throw new Error("x required");if(R==null||!s.isValid(R)||s.is0(R))throw new Error("y required");if(D==null||!s.isValid(D))throw new Error("z required");this.px=C,this.py=R,this.pz=D,Object.freeze(this)}static fromAffine(C){const{x:R,y:D}=C||{};if(!C||!s.isValid(R)||!s.isValid(D))throw new Error("invalid affine point");if(C instanceof f)throw new Error("projective point not allowed");const L=W=>s.eql(W,s.ZERO);return L(R)&&L(D)?f.ZERO:new f(R,D,s.ONE)}get x(){return this.toAffine().x}get y(){return this.toAffine().y}static normalizeZ(C){const R=mg(s,C.map(D=>D.pz));return C.map((D,L)=>D.toAffine(R[L])).map(f.fromAffine)}static fromHex(C){const R=f.fromAffine(i(ws("pointHex",C)));return R.assertValidity(),R}static fromPrivateKey(C){return f.BASE.multiply(u(C))}static msm(C,R){return Z_(f,n,C,R)}_setWindowSize(C){S.setWindowSize(this,C)}assertValidity(){g(this)}hasEvenY(){const{y:C}=this.toAffine();if(s.isOdd)return!s.isOdd(C);throw new Error("Field doesn't support isOdd")}equals(C){h(C);const{px:R,py:D,pz:L}=this,{px:W,py:k,pz:q}=C,V=s.eql(s.mul(R,q),s.mul(W,L)),x=s.eql(s.mul(D,q),s.mul(k,L));return V&&x}negate(){return new f(this.px,s.neg(this.py),this.pz)}double(){const{a:C,b:R}=e,D=s.mul(R,Fc),{px:L,py:W,pz:k}=this;let q=s.ZERO,V=s.ZERO,x=s.ZERO,N=s.mul(L,L),T=s.mul(W,W),w=s.mul(k,k),b=s.mul(L,W);return b=s.add(b,b),x=s.mul(L,k),x=s.add(x,x),q=s.mul(C,x),V=s.mul(D,w),V=s.add(q,V),q=s.sub(T,V),V=s.add(T,V),V=s.mul(q,V),q=s.mul(b,q),x=s.mul(D,x),w=s.mul(C,w),b=s.sub(N,w),b=s.mul(C,b),b=s.add(b,x),x=s.add(N,N),N=s.add(x,N),N=s.add(N,w),N=s.mul(N,b),V=s.add(V,N),w=s.mul(W,k),w=s.add(w,w),N=s.mul(w,b),q=s.sub(q,N),x=s.mul(w,T),x=s.add(x,x),x=s.add(x,x),new f(q,V,x)}add(C){h(C);const{px:R,py:D,pz:L}=this,{px:W,py:k,pz:q}=C;let V=s.ZERO,x=s.ZERO,N=s.ZERO;const T=e.a,w=s.mul(e.b,Fc);let b=s.mul(R,W),I=s.mul(D,k),O=s.mul(L,q),A=s.add(R,D),P=s.add(W,k);A=s.mul(A,P),P=s.add(b,I),A=s.sub(A,P),P=s.add(R,L);let B=s.add(W,q);return P=s.mul(P,B),B=s.add(b,O),P=s.sub(P,B),B=s.add(D,L),V=s.add(k,q),B=s.mul(B,V),V=s.add(I,O),B=s.sub(B,V),N=s.mul(T,P),V=s.mul(w,O),N=s.add(V,N),V=s.sub(I,N),N=s.add(I,N),x=s.mul(V,N),I=s.add(b,b),I=s.add(I,b),O=s.mul(T,O),P=s.mul(w,P),I=s.add(I,O),O=s.sub(b,O),O=s.mul(T,O),P=s.add(P,O),b=s.mul(I,P),x=s.add(x,b),b=s.mul(B,P),V=s.mul(A,V),V=s.sub(V,b),b=s.mul(A,I),N=s.mul(B,N),N=s.add(N,b),new f(V,x,N)}subtract(C){return this.add(C.negate())}is0(){return this.equals(f.ZERO)}wNAF(C){return S.wNAFCached(this,C,f.normalizeZ)}multiplyUnsafe(C){const{endo:R,n:D}=e;ti("scalar",C,yn,D);const L=f.ZERO;if(C===yn)return L;if(this.is0()||C===gt)return this;if(!R||S.hasPrecomputes(this))return S.wNAFCachedUnsafe(this,C,f.normalizeZ);let{k1neg:W,k1:k,k2neg:q,k2:V}=R.splitScalar(C),x=L,N=L,T=this;for(;k>yn||V>yn;)k>&&(x=x.add(T)),V>&&(N=N.add(T)),T=T.double(),k>>=gt,V>>=gt;return W&&(x=x.negate()),q&&(N=N.negate()),N=new f(s.mul(N.px,R.beta),N.py,N.pz),x.add(N)}multiply(C){const{endo:R,n:D}=e;ti("scalar",C,gt,D);let L,W;if(R){const{k1neg:k,k1:q,k2neg:V,k2:x}=R.splitScalar(C);let{p:N,f:T}=this.wNAF(q),{p:w,f:b}=this.wNAF(x);N=S.constTimeNegate(k,N),w=S.constTimeNegate(V,w),w=new f(s.mul(w.px,R.beta),w.py,w.pz),L=N.add(w),W=T.add(b)}else{const{p:k,f:q}=this.wNAF(C);L=k,W=q}return f.normalizeZ([L,W])[0]}multiplyAndAddUnsafe(C,R,D){const L=f.BASE,W=(q,V)=>V===yn||V===gt||!q.equals(L)?q.multiplyUnsafe(V):q.multiply(V),k=W(this,R).add(W(C,D));return k.is0()?void 0:k}toAffine(C){return p(this,C)}isTorsionFree(){const{h:C,isTorsionFree:R}=e;if(C===gt)return!0;if(R)return R(f,this);throw new Error("isTorsionFree() has not been declared for the elliptic curve")}clearCofactor(){const{h:C,clearCofactor:R}=e;return C===gt?this:R?R(f,this):this.multiplyUnsafe(e.h)}toRawBytes(C=!0){return po("isCompressed",C),this.assertValidity(),r(f,this,C)}toHex(C=!0){return po("isCompressed",C),fo(this.toRawBytes(C))}}f.BASE=new f(e.Gx,e.Gy,s.ONE),f.ZERO=new f(s.ZERO,s.ONE,s.ZERO);const{endo:y,nBitLength:_}=e,S=Y_(f,y?Math.ceil(_/2):_);return{CURVE:e,ProjectivePoint:f,normPrivateKeyToScalar:u,weierstrassEquation:o,isWithinCurveOrder:d}}function t0(t){const e=Cg(t);return ac(e,{hash:"hash",hmac:"function",randomBytes:"function"},{bits2int:"function",bits2int_modN:"function",lowS:"boolean"}),Object.freeze({lowS:!0,...e})}function s0(t){const e=t0(t),{Fp:s,n,nByteLength:r,nBitLength:i}=e,o=s.BYTES+1,a=2*s.BYTES+1;function c(w){return Gt(w,n)}function l(w){return Ll(w,n)}const{ProjectivePoint:d,normPrivateKeyToScalar:u,weierstrassEquation:h,isWithinCurveOrder:p}=e0({...e,toBytes(w,b,I){const O=b.toAffine(),A=s.toBytes(O.x),P=Ma;return po("isCompressed",I),I?P(Uint8Array.from([b.hasEvenY()?2:3]),A):P(Uint8Array.from([4]),A,s.toBytes(O.y))},fromBytes(w){const b=w.length,I=w[0],O=w.subarray(1);if(b===o&&(I===2||I===3)){const A=_r(O);if(!xd(A,gt,s.ORDER))throw new Error("Point is not on curve");const P=h(A);let B;try{B=s.sqrt(P)}catch(j){const J=j instanceof Error?": "+j.message:"";throw new Error("Point is not on curve"+J)}const M=(B>)===gt;return(I&1)===1!==M&&(B=s.neg(B)),{x:A,y:B}}else if(b===a&&I===4){const A=s.fromBytes(O.subarray(0,s.BYTES)),P=s.fromBytes(O.subarray(s.BYTES,2*s.BYTES));return{x:A,y:P}}else{const A=o,P=a;throw new Error("invalid Point, expected length of "+A+", or uncompressed "+P+", got "+b)}}});function g(w){const b=n>>gt;return w>b}function f(w){return g(w)?c(-w):w}const y=(w,b,I)=>_r(w.slice(b,I));class _{constructor(b,I,O){ti("r",b,gt,n),ti("s",I,gt,n),this.r=b,this.s=I,O!=null&&(this.recovery=O),Object.freeze(this)}static fromCompact(b){const I=r;return b=ws("compactSignature",b,I*2),new _(y(b,0,I),y(b,I,2*I))}static fromDER(b){const{r:I,s:O}=fn.toSig(ws("DER",b));return new _(I,O)}assertValidity(){}addRecoveryBit(b){return new _(this.r,this.s,b)}recoverPublicKey(b){const{r:I,s:O,recovery:A}=this,P=L(ws("msgHash",b));if(A==null||![0,1,2,3].includes(A))throw new Error("recovery id invalid");const B=A===2||A===3?I+e.n:I;if(B>=s.ORDER)throw new Error("recovery id 2 or 3 invalid");const M=(A&1)===0?"02":"03",ce=d.fromHex(M+jc(B,s.BYTES)),j=l(B),J=c(-P*j),he=c(O*j),ge=d.BASE.multiplyAndAddUnsafe(ce,J,he);if(!ge)throw new Error("point at infinify");return ge.assertValidity(),ge}hasHighS(){return g(this.s)}normalizeS(){return this.hasHighS()?new _(this.r,c(-this.s),this.recovery):this}toDERRawBytes(){return La(this.toDERHex())}toDERHex(){return fn.hexFromSig(this)}toCompactRawBytes(){return La(this.toCompactHex())}toCompactHex(){const b=r;return jc(this.r,b)+jc(this.s,b)}}const S={isValidPrivateKey(w){try{return u(w),!0}catch{return!1}},normPrivateKeyToScalar:u,randomPrivateKey:()=>{const w=Eg(e.n);return V_(e.randomBytes(w),e.n)},precompute(w=8,b=d.BASE){return b._setWindowSize(w),b.multiply(BigInt(3)),b}};function v(w,b=!0){return d.fromPrivateKey(w).toRawBytes(b)}function C(w){if(typeof w=="bigint")return!1;if(w instanceof d)return!0;const I=ws("key",w).length,O=s.BYTES,A=O+1,P=2*O+1;if(!(e.allowedPrivateKeyLengths||r===A))return I===A||I===P}function R(w,b,I=!0){if(C(w)===!0)throw new Error("first arg must be private key");if(C(b)===!1)throw new Error("second arg must be public key");return d.fromHex(b).multiply(u(w)).toRawBytes(I)}const D=e.bits2int||function(w){if(w.length>8192)throw new Error("input is too large");const b=_r(w),I=w.length*8-i;return I>0?b>>BigInt(I):b},L=e.bits2int_modN||function(w){return c(D(w))},W=oc(i);function k(w){return ti("num < 2^"+i,w,yn,W),No(w,r)}function q(w,b,I=V){if(["recovered","canonical"].some(ye=>ye in I))throw new Error("sign() legacy options not supported");const{hash:O,randomBytes:A}=e;let{lowS:P,prehash:B,extraEntropy:M}=I;P==null&&(P=!0),w=ws("msgHash",w),ph(I),B&&(w=ws("prehashed msgHash",O(w)));const ce=L(w),j=u(b),J=[k(j),k(ce)];if(M!=null&&M!==!1){const ye=M===!0?A(s.BYTES):M;J.push(ws("extraEntropy",ye))}const he=Ma(...J),ge=ce;function Oe(ye){const ve=D(ye);if(!p(ve))return;const Ve=l(ve),st=d.BASE.multiply(ve).toAffine(),ut=c(st.x);if(ut===yn)return;const wt=c(Ve*c(ge+ut*j));if(wt===yn)return;let Bs=(st.x===ut?0:2)|Number(st.y>),sn=wt;return P&&g(wt)&&(sn=f(wt),Bs^=1),new _(ut,sn,Bs)}return{seed:he,k2sig:Oe}}const V={lowS:e.lowS,prehash:!1},x={lowS:e.lowS,prehash:!1};function N(w,b,I=V){const{seed:O,k2sig:A}=q(w,b,I),P=e;return e_(P.hash.outputLen,P.nByteLength,P.hmac)(O,A)}d.BASE._setWindowSize(8);function T(w,b,I,O=x){var Bs;const A=w;b=ws("msgHash",b),I=ws("publicKey",I);const{lowS:P,prehash:B,format:M}=O;if(ph(O),"strict"in O)throw new Error("options.strict was renamed to lowS");if(M!==void 0&&M!=="compact"&&M!=="der")throw new Error("format must be compact or der");const ce=typeof A=="string"||Io(A),j=!ce&&!M&&typeof A=="object"&&A!==null&&typeof A.r=="bigint"&&typeof A.s=="bigint";if(!ce&&!j)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");let J,he;try{if(j&&(J=new _(A.r,A.s)),ce){try{M!=="compact"&&(J=_.fromDER(A))}catch(sn){if(!(sn instanceof fn.Err))throw sn}!J&&M!=="der"&&(J=_.fromCompact(A))}he=d.fromHex(I)}catch{return!1}if(!J||P&&J.hasHighS())return!1;B&&(b=e.hash(b));const{r:ge,s:Oe}=J,ye=L(b),ve=l(Oe),Ve=c(ye*ve),st=c(ge*ve),ut=(Bs=d.BASE.multiplyAndAddUnsafe(he,Ve,st))==null?void 0:Bs.toAffine();return ut?c(ut.x)===ge:!1}return{CURVE:e,getPublicKey:v,getSharedSecret:R,sign:N,verify:T,ProjectivePoint:d,Signature:_,utils:S}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */function n0(t){return{hash:t,hmac:(e,...s)=>Ky(t,e,Gy(...s)),randomBytes:Vy}}function r0(t,e){const s=n=>s0({...t,...n0(n)});return{...s(e),create:s}}/*! noble-curves - MIT License (c) 2022 Paul Miller (paulmillr.com) */const _g=BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffefffffc2f"),fh=BigInt("0xfffffffffffffffffffffffffffffffebaaedce6af48a03bbfd25e8cd0364141"),i0=BigInt(0),o0=BigInt(1),Bl=BigInt(2),gh=(t,e)=>(t+e/Bl)/e;function a0(t){const e=_g,s=BigInt(3),n=BigInt(6),r=BigInt(11),i=BigInt(22),o=BigInt(23),a=BigInt(44),c=BigInt(88),l=t*t*t%e,d=l*l*t%e,u=hs(d,s,e)*d%e,h=hs(u,s,e)*d%e,p=hs(h,Bl,e)*l%e,g=hs(p,r,e)*p%e,f=hs(g,i,e)*g%e,y=hs(f,a,e)*f%e,_=hs(y,c,e)*y%e,S=hs(_,a,e)*f%e,v=hs(S,s,e)*d%e,C=hs(v,o,e)*g%e,R=hs(C,n,e)*l%e,D=hs(R,Bl,e);if(!jl.eql(jl.sqr(D),t))throw new Error("Cannot find square root");return D}const jl=$d(_g,void 0,void 0,{sqrt:a0}),c0=r0({a:i0,b:BigInt(7),Fp:jl,n:fh,Gx:BigInt("55066263022277343669578718895168534326250603453777594175500187360389116729240"),Gy:BigInt("32670510020758816978083085130507043184471273380659243275938904335757337482424"),h:BigInt(1),lowS:!0,endo:{beta:BigInt("0x7ae96a2b657c07106e64479eac3434e99cf0497512f58995c1396c28719501ee"),splitScalar:t=>{const e=fh,s=BigInt("0x3086d221a7d46bcde86c90e49284eb15"),n=-o0*BigInt("0xe4437ed6010e88286f547fa90abfe4c3"),r=BigInt("0x114ca50f7a8e2f3f657c1108d9d44cfd8"),i=s,o=BigInt("0x100000000000000000000000000000000"),a=gh(i*t,e),c=gh(-n*t,e);let l=Gt(t-a*s-c*r,e),d=Gt(-a*n-c*i,e);const u=l>o,h=d>o;if(u&&(l=e-l),h&&(d=e-d),l>o||d>o)throw new Error("splitScalar: Endomorphism failed, k="+t);return{k1neg:u,k1:l,k2neg:h,k2:d}}}},Yy);function l0(t){if(t.length!==130&&t.length!==132)throw new u0({signature:t});const e=BigInt(hn(t,0,32)),s=BigInt(hn(t,32,64)),n=(()=>{const r=+`0x${t.slice(130)}`;if(!Number.isNaN(r))try{return d0(r)}catch{throw new h0({value:r})}})();return typeof n>"u"?{r:e,s}:{r:e,s,yParity:n}}function d0(t){if(t===0||t===27)return 0;if(t===1||t===28)return 1;if(t>=35)return t%2===0?1:0;throw new p0({value:t})}class u0 extends Je{constructor({signature:e}){super(`Value \`${e}\` is an invalid signature size.`,{metaMessages:["Expected: 64 bytes or 65 bytes.",`Received ${Qn(Ud(e))} bytes.`]}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Signature.InvalidSerializedSizeError"})}}class h0 extends Je{constructor({value:e}){super(`Value \`${e}\` is an invalid y-parity value. Y-parity must be 0 or 1.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Signature.InvalidYParityError"})}}class p0 extends Je{constructor({value:e}){super(`Value \`${e}\` is an invalid v value. v must be 27, 28 or >=35.`),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"Signature.InvalidVError"})}}/*! scure-base - MIT License (c) 2022 Paul Miller (paulmillr.com) */function f0(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function Ag(t,e){return Array.isArray(e)?e.length===0?!0:t?e.every(s=>typeof s=="string"):e.every(s=>Number.isSafeInteger(s)):!1}function ja(t,e){if(typeof e!="string")throw new Error(`${t}: string expected`);return!0}function Dd(t){if(!Number.isSafeInteger(t))throw new Error(`invalid integer: ${t}`)}function Fl(t){if(!Array.isArray(t))throw new Error("array expected")}function Fa(t,e){if(!Ag(!0,e))throw new Error(`${t}: array of strings expected`)}function g0(t,e){if(!Ag(!1,e))throw new Error(`${t}: array of numbers expected`)}function m0(...t){const e=i=>i,s=(i,o)=>a=>i(o(a)),n=t.map(i=>i.encode).reduceRight(s,e),r=t.map(i=>i.decode).reduce(s,e);return{encode:n,decode:r}}function y0(t){const e=typeof t=="string"?t.split(""):t,s=e.length;Fa("alphabet",e);const n=new Map(e.map((r,i)=>[r,i]));return{encode:r=>(Fl(r),r.map(i=>{if(!Number.isSafeInteger(i)||i<0||i>=s)throw new Error(`alphabet.encode: digit index outside alphabet "${i}". Allowed: ${t}`);return e[i]})),decode:r=>(Fl(r),r.map(i=>{ja("alphabet.decode",i);const o=n.get(i);if(o===void 0)throw new Error(`Unknown letter: "${i}". Allowed: ${t}`);return o}))}}function w0(t=""){return ja("join",t),{encode:e=>(Fa("join.decode",e),e.join(t)),decode:e=>(ja("join.decode",e),e.split(t))}}function E0(t,e="="){return Dd(t),ja("padding",e),{encode(s){for(Fa("padding.encode",s);s.length*t%8;)s.push(e);return s},decode(s){Fa("padding.decode",s);let n=s.length;if(n*t%8)throw new Error("padding: invalid, string should have whole number of bytes");for(;n>0&&s[n-1]===e;n--)if((n-1)*t%8===0)throw new Error("padding: invalid, string has too much padding");return s.slice(0,n)}}}const Sg=(t,e)=>e===0?t:Sg(e,t%e),qa=(t,e)=>t+(e-Sg(t,e)),qc=(()=>{let t=[];for(let e=0;e<40;e++)t.push(2**e);return t})();function mh(t,e,s,n){if(Fl(t),e<=0||e>32)throw new Error(`convertRadix2: wrong from=${e}`);if(s<=0||s>32)throw new Error(`convertRadix2: wrong to=${s}`);if(qa(e,s)>32)throw new Error(`convertRadix2: carry overflow from=${e} to=${s} carryBits=${qa(e,s)}`);let r=0,i=0;const o=qc[e],a=qc[s]-1,c=[];for(const l of t){if(Dd(l),l>=o)throw new Error(`convertRadix2: invalid data word=${l} from=${e}`);if(r=r<<e|l,i+e>32)throw new Error(`convertRadix2: carry overflow pos=${i} from=${e}`);for(i+=e;i>=s;i-=s)c.push((r>>i-s&a)>>>0);const d=qc[i];if(d===void 0)throw new Error("invalid carry");r&=d-1}if(r=r<<s-i&a,!n&&i>=e)throw new Error("Excess padding");if(!n&&r>0)throw new Error(`Non-zero padding: ${r}`);return n&&i>0&&c.push(r>>>0),c}function b0(t,e=!1){if(Dd(t),t<=0||t>32)throw new Error("radix2: bits should be in (0..32]");if(qa(8,t)>32||qa(t,8)>32)throw new Error("radix2: carry overflow");return{encode:s=>{if(!f0(s))throw new Error("radix2.encode input should be Uint8Array");return mh(Array.from(s),8,t,!e)},decode:s=>(g0("radix2.decode",s),Uint8Array.from(mh(s,t,8,e)))}}const v0=m0(b0(5),y0("ABCDEFGHIJKLMNOPQRSTUVWXYZ234567"),E0(5),w0(""));function C0(t){return D_(_0(t))}function _0(t){const{payload:e,signature:s}=t,{r:n,s:r,yParity:i}=s,a=new c0.Signature(BigInt(n),BigInt(r)).addRecoveryBit(i).recoverPublicKey(Ud(e).substring(2));return N_(a)}function A0(t){if(t.length>=255)throw new TypeError("Alphabet too long");const e=new Uint8Array(256);for(let l=0;l<e.length;l++)e[l]=255;for(let l=0;l<t.length;l++){const d=t.charAt(l),u=d.charCodeAt(0);if(e[u]!==255)throw new TypeError(d+" is ambiguous");e[u]=l}const s=t.length,n=t.charAt(0),r=Math.log(s)/Math.log(256),i=Math.log(256)/Math.log(s);function o(l){if(l instanceof Uint8Array||(ArrayBuffer.isView(l)?l=new Uint8Array(l.buffer,l.byteOffset,l.byteLength):Array.isArray(l)&&(l=Uint8Array.from(l))),!(l instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(l.length===0)return"";let d=0,u=0,h=0;const p=l.length;for(;h!==p&&l[h]===0;)h++,d++;const g=(p-h)*i+1>>>0,f=new Uint8Array(g);for(;h!==p;){let S=l[h],v=0;for(let C=g-1;(S!==0||v<u)&&C!==-1;C--,v++)S+=256*f[C]>>>0,f[C]=S%s>>>0,S=S/s>>>0;if(S!==0)throw new Error("Non-zero carry");u=v,h++}let y=g-u;for(;y!==g&&f[y]===0;)y++;let _=n.repeat(d);for(;y<g;++y)_+=t.charAt(f[y]);return _}function a(l){if(typeof l!="string")throw new TypeError("Expected String");if(l.length===0)return new Uint8Array;let d=0,u=0,h=0;for(;l[d]===n;)u++,d++;const p=(l.length-d)*r+1>>>0,g=new Uint8Array(p);for(;d<l.length;){const S=l.charCodeAt(d);if(S>255)return;let v=e[S];if(v===255)return;let C=0;for(let R=p-1;(v!==0||C<h)&&R!==-1;R--,C++)v+=s*g[R]>>>0,g[R]=v%256>>>0,v=v/256>>>0;if(v!==0)throw new Error("Non-zero carry");h=C,d++}let f=p-h;for(;f!==p&&g[f]===0;)f++;const y=new Uint8Array(u+(p-f));let _=u;for(;f!==p;)y[_++]=g[f++];return y}function c(l){const d=a(l);if(d)return d;throw new Error("Non-base"+s+" character")}return{encode:o,decodeUnsafe:a,decode:c}}var S0="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";const To=A0(S0);var Me={},I0={};const N0=":";function vn(t){const[e,s]=t.split(N0);return{namespace:e,reference:s}}function Ig(t,e){return t.includes(":")?[t]:e.chains||[]}var T0=Object.defineProperty,R0=Object.defineProperties,O0=Object.getOwnPropertyDescriptors,yh=Object.getOwnPropertySymbols,P0=Object.prototype.hasOwnProperty,x0=Object.prototype.propertyIsEnumerable,ql=(t,e,s)=>e in t?T0(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,wh=(t,e)=>{for(var s in e||(e={}))P0.call(e,s)&&ql(t,s,e[s]);if(yh)for(var s of yh(e))x0.call(e,s)&&ql(t,s,e[s]);return t},k0=(t,e)=>R0(t,O0(e)),Eh=(t,e,s)=>ql(t,typeof e!="symbol"?e+"":e,s);const U0="ReactNative",us={reactNative:"react-native",node:"node",browser:"browser",unknown:"unknown"},$0="js";function Wa(){return typeof En<"u"&&typeof En.versions<"u"&&typeof En.versions.node<"u"}function tr(){return!An.getDocument()&&!!An.getNavigator()&&navigator.product===U0}function D0(){return tr()&&typeof Me<"u"&&typeof(Me==null?void 0:Me.Platform)<"u"&&(Me==null?void 0:Me.Platform.OS)==="android"}function L0(){return tr()&&typeof Me<"u"&&typeof(Me==null?void 0:Me.Platform)<"u"&&(Me==null?void 0:Me.Platform.OS)==="ios"}function yi(){return!Wa()&&!!An.getNavigator()&&!!An.getDocument()}function Ro(){return tr()?us.reactNative:Wa()?us.node:yi()?us.browser:us.unknown}function bh(){var t;try{return tr()&&typeof Me<"u"&&typeof(Me==null?void 0:Me.Application)<"u"?(t=Me.Application)==null?void 0:t.applicationId:void 0}catch{return}}function M0(t,e){const s=new URLSearchParams(t);return Object.entries(e).sort(([n],[r])=>n.localeCompare(r)).forEach(([n,r])=>{r!=null&&s.set(n,String(r))}),s.toString()}function B0(t){var e,s;const n=Ng();try{return t!=null&&t.url&&n.url&&new URL(t.url).host!==new URL(n.url).host&&(console.warn(`The configured WalletConnect 'metadata.url':${t.url} differs from the actual page url:${n.url}. This is probably unintended and can lead to issues.`),t.url=n.url),(e=t==null?void 0:t.icons)!=null&&e.length&&t.icons.length>0&&(t.icons=t.icons.filter(r=>r!=="")),k0(wh(wh({},n),t),{url:(t==null?void 0:t.url)||n.url,name:(t==null?void 0:t.name)||n.name,description:(t==null?void 0:t.description)||n.description,icons:(s=t==null?void 0:t.icons)!=null&&s.length&&t.icons.length>0?t.icons:n.icons})}catch(r){return console.warn("Error populating app metadata",r),t||n}}function Ng(){return Ty.getWindowMetadata()||{name:"",description:"",url:"",icons:[""]}}function j0(){if(Ro()===us.reactNative&&typeof Me<"u"&&typeof(Me==null?void 0:Me.Platform)<"u"){const{OS:s,Version:n}=Me.Platform;return[s,n].join("-")}const t=Oy();if(t===null)return"unknown";const e=t.os?t.os.replace(" ","").toLowerCase():"unknown";return t.type==="browser"?[e,t.name,t.version].join("-"):[e,t.version].join("-")}function F0(){var t;const e=Ro();return e===us.browser?[e,((t=An.getLocation())==null?void 0:t.host)||"unknown"].join(":"):e}function Tg(t,e,s){const n=j0(),r=F0();return[[t,e].join("-"),[$0,s].join("-"),n,r].join("/")}function q0({protocol:t,version:e,relayUrl:s,sdkVersion:n,auth:r,projectId:i,useOnCloseEvent:o,bundleId:a,packageName:c}){const l=s.split("?"),d=Tg(t,e,n),u={auth:r,ua:d,projectId:i,useOnCloseEvent:o,packageName:c||void 0,bundleId:a||void 0},h=M0(l[1]||"",u);return l[0]+"?"+h}function mr(t,e){return t.filter(s=>e.includes(s)).length===t.length}function Wl(t){return Object.fromEntries(t.entries())}function Hl(t){return new Map(Object.entries(t))}function dr(t=Z.FIVE_MINUTES,e){const s=Z.toMiliseconds(t||Z.FIVE_MINUTES);let n,r,i,o;return{resolve:a=>{i&&n&&(clearTimeout(i),n(a),o=Promise.resolve(a))},reject:a=>{i&&r&&(clearTimeout(i),r(a))},done:()=>new Promise((a,c)=>{if(o)return a(o);i=setTimeout(()=>{const l=new Error(e);o=Promise.reject(l),c(l)},s),n=a,r=c})}}function Gs(t,e,s){return new Promise(async(n,r)=>{const i=setTimeout(()=>r(new Error(s)),e);try{const o=await t;n(o)}catch(o){r(o)}clearTimeout(i)})}function Rg(t,e){if(typeof e=="string"&&e.startsWith(`${t}:`))return e;if(t.toLowerCase()==="topic"){if(typeof e!="string")throw new Error('Value must be "string" for expirer target type: topic');return`topic:${e}`}else if(t.toLowerCase()==="id"){if(typeof e!="number")throw new Error('Value must be "number" for expirer target type: id');return`id:${e}`}throw new Error(`Unknown expirer target type: ${t}`)}function W0(t){return Rg("topic",t)}function H0(t){return Rg("id",t)}function Og(t){const[e,s]=t.split(":"),n={id:void 0,topic:void 0};if(e==="topic"&&typeof s=="string")n.topic=s;else if(e==="id"&&Number.isInteger(Number(s)))n.id=Number(s);else throw new Error(`Invalid target, expected id:number or topic:string, got ${e}:${s}`);return n}function rt(t,e){return Z.fromMiliseconds(Date.now()+Z.toMiliseconds(t))}function Vs(t){return Date.now()>=Z.toMiliseconds(t)}function Fe(t,e){return`${t}${e?`:${e}`:""}`}function Js(t=[],e=[]){return[...new Set([...t,...e])]}async function z0({id:t,topic:e,wcDeepLink:s}){var n;try{if(!s)return;const r=typeof s=="string"?JSON.parse(s):s,i=r==null?void 0:r.href;if(typeof i!="string")return;const o=V0(i,t,e),a=Ro();if(a===us.browser){if(!((n=An.getDocument())!=null&&n.hasFocus())){console.warn("Document does not have focus, skipping deeplink.");return}K0(o)}else a===us.reactNative&&typeof(Me==null?void 0:Me.Linking)<"u"&&await Me.Linking.openURL(o)}catch(r){console.error(r)}}function V0(t,e,s){const n=`requestId=${e}&sessionTopic=${s}`;t.endsWith("/")&&(t=t.slice(0,-1));let r=`${t}`;if(t.startsWith("https://t.me")){const i=t.includes("?")?"&startapp=":"?startapp=";r=`${r}${i}${J0(n,!0)}`}else r=`${r}/wc?${n}`;return r}function K0(t){let e="_self";Z0()?e="_top":(Y0()||t.startsWith("https://")||t.startsWith("http://"))&&(e="_blank"),window.open(t,e,"noreferrer noopener")}async function G0(t,e){let s="";try{if(yi()&&(s=localStorage.getItem(e),s))return s;s=await t.getItem(e)}catch(n){console.error(n)}return s}function vh(t,e){if(!t.includes(e))return null;const s=t.split(/([&,?,=])/),n=s.indexOf(e);return s[n+2]}function Ch(){return typeof crypto<"u"&&crypto!=null&&crypto.randomUUID?crypto.randomUUID():"xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx".replace(/[xy]/gu,t=>{const e=Math.random()*16|0;return(t==="x"?e:e&3|8).toString(16)})}function Ld(){return typeof En<"u"&&I0.IS_VITEST==="true"}function Y0(){return typeof window<"u"&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)}function Z0(){try{return window.self!==window.top}catch{return!1}}function J0(t,e=!1){const s=Ue.from(t).toString("base64");return e?s.replace(/[=]/g,""):s}function Pg(t){return Ue.from(t,"base64").toString("utf-8")}function X0(t){return new Promise(e=>setTimeout(e,t))}let Q0=class{constructor({limit:e}){Eh(this,"limit"),Eh(this,"set"),this.limit=e,this.set=new Set}add(e){if(!this.set.has(e)){if(this.set.size>=this.limit){const s=this.set.values().next().value;s&&this.set.delete(s)}this.set.add(e)}}has(e){return this.set.has(e)}};const Jo=BigInt(2**32-1),_h=BigInt(32);function xg(t,e=!1){return e?{h:Number(t&Jo),l:Number(t>>_h&Jo)}:{h:Number(t>>_h&Jo)|0,l:Number(t&Jo)|0}}function kg(t,e=!1){const s=t.length;let n=new Uint32Array(s),r=new Uint32Array(s);for(let i=0;i<s;i++){const{h:o,l:a}=xg(t[i],e);[n[i],r[i]]=[o,a]}return[n,r]}const Ah=(t,e,s)=>t>>>s,Sh=(t,e,s)=>t<<32-s|e>>>s,Dn=(t,e,s)=>t>>>s|e<<32-s,Ln=(t,e,s)=>t<<32-s|e>>>s,Ui=(t,e,s)=>t<<64-s|e>>>s-32,$i=(t,e,s)=>t>>>s-32|e<<64-s,eA=(t,e)=>e,tA=(t,e)=>t,sA=(t,e,s)=>t<<s|e>>>32-s,nA=(t,e,s)=>e<<s|t>>>32-s,rA=(t,e,s)=>e<<s-32|t>>>64-s,iA=(t,e,s)=>t<<s-32|e>>>64-s;function Os(t,e,s,n){const r=(e>>>0)+(n>>>0);return{h:t+s+(r/2**32|0)|0,l:r|0}}const Md=(t,e,s)=>(t>>>0)+(e>>>0)+(s>>>0),Bd=(t,e,s,n)=>e+s+n+(t/2**32|0)|0,oA=(t,e,s,n)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0),aA=(t,e,s,n,r)=>e+s+n+r+(t/2**32|0)|0,cA=(t,e,s,n,r)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0)+(r>>>0),lA=(t,e,s,n,r,i)=>e+s+n+r+i+(t/2**32|0)|0,jr=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function cc(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function In(t){if(!Number.isSafeInteger(t)||t<0)throw new Error("positive integer expected, got "+t)}function Ms(t,...e){if(!cc(t))throw new Error("Uint8Array expected");if(e.length>0&&!e.includes(t.length))throw new Error("Uint8Array expected of length "+e+", got length="+t.length)}function lc(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");In(t.outputLen),In(t.blockLen)}function er(t,e=!0){if(t.destroyed)throw new Error("Hash instance has been destroyed");if(e&&t.finished)throw new Error("Hash#digest() has already been called")}function jd(t,e){Ms(t);const s=e.outputLen;if(t.length<s)throw new Error("digestInto() expects output buffer of length at least "+s)}function go(t){return new Uint32Array(t.buffer,t.byteOffset,Math.floor(t.byteLength/4))}function _s(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function Wc(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function js(t,e){return t<<32-e|t>>>e}const Ug=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function $g(t){return t<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}const ln=Ug?t=>t:t=>$g(t);function dA(t){for(let e=0;e<t.length;e++)t[e]=$g(t[e]);return t}const Mn=Ug?t=>t:dA,Dg=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",uA=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function si(t){if(Ms(t),Dg)return t.toHex();let e="";for(let s=0;s<t.length;s++)e+=uA[t[s]];return e}const an={_0:48,_9:57,A:65,F:70,a:97,f:102};function Ih(t){if(t>=an._0&&t<=an._9)return t-an._0;if(t>=an.A&&t<=an.F)return t-(an.A-10);if(t>=an.a&&t<=an.f)return t-(an.a-10)}function Ha(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(Dg)return Uint8Array.fromHex(t);const e=t.length,s=e/2;if(e%2)throw new Error("hex string expected, got unpadded hex of length "+e);const n=new Uint8Array(s);for(let r=0,i=0;r<s;r++,i+=2){const o=Ih(t.charCodeAt(i)),a=Ih(t.charCodeAt(i+1));if(o===void 0||a===void 0){const c=t[i]+t[i+1];throw new Error('hex string expected, got non-hex character "'+c+'" at index '+i)}n[r]=o*16+a}return n}function Lg(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function Ds(t){return typeof t=="string"&&(t=Lg(t)),Ms(t),t}function Fn(...t){let e=0;for(let n=0;n<t.length;n++){const r=t[n];Ms(r),e+=r.length}const s=new Uint8Array(e);for(let n=0,r=0;n<t.length;n++){const i=t[n];s.set(i,r),r+=i.length}return s}let dc=class{};function Oo(t){const e=n=>t().update(Ds(n)).digest(),s=t();return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=()=>t(),e}function hA(t){const e=(n,r)=>t(r).update(Ds(n)).digest(),s=t({});return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=n=>t(n),e}function Dr(t=32){if(jr&&typeof jr.getRandomValues=="function")return jr.getRandomValues(new Uint8Array(t));if(jr&&typeof jr.randomBytes=="function")return Uint8Array.from(jr.randomBytes(t));throw new Error("crypto.getRandomValues must be defined")}const pA=BigInt(0),_i=BigInt(1),fA=BigInt(2),gA=BigInt(7),mA=BigInt(256),yA=BigInt(113),Mg=[],Bg=[],jg=[];for(let t=0,e=_i,s=1,n=0;t<24;t++){[s,n]=[n,(2*s+3*n)%5],Mg.push(2*(5*n+s)),Bg.push((t+1)*(t+2)/2%64);let r=pA;for(let i=0;i<7;i++)e=(e<<_i^(e>>gA)*yA)%mA,e&fA&&(r^=_i<<(_i<<BigInt(i))-_i);jg.push(r)}const Fg=kg(jg,!0),wA=Fg[0],EA=Fg[1],Nh=(t,e,s)=>s>32?rA(t,e,s):sA(t,e,s),Th=(t,e,s)=>s>32?iA(t,e,s):nA(t,e,s);function bA(t,e=24){const s=new Uint32Array(10);for(let n=24-e;n<24;n++){for(let o=0;o<10;o++)s[o]=t[o]^t[o+10]^t[o+20]^t[o+30]^t[o+40];for(let o=0;o<10;o+=2){const a=(o+8)%10,c=(o+2)%10,l=s[c],d=s[c+1],u=Nh(l,d,1)^s[a],h=Th(l,d,1)^s[a+1];for(let p=0;p<50;p+=10)t[o+p]^=u,t[o+p+1]^=h}let r=t[2],i=t[3];for(let o=0;o<24;o++){const a=Bg[o],c=Nh(r,i,a),l=Th(r,i,a),d=Mg[o];r=t[d],i=t[d+1],t[d]=c,t[d+1]=l}for(let o=0;o<50;o+=10){for(let a=0;a<10;a++)s[a]=t[o+a];for(let a=0;a<10;a++)t[o+a]^=~s[(a+2)%10]&s[(a+4)%10]}t[0]^=wA[n],t[1]^=EA[n]}_s(s)}let vA=class qg extends dc{constructor(e,s,n,r=!1,i=24){if(super(),this.pos=0,this.posOut=0,this.finished=!1,this.destroyed=!1,this.enableXOF=!1,this.blockLen=e,this.suffix=s,this.outputLen=n,this.enableXOF=r,this.rounds=i,In(n),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=go(this.state)}clone(){return this._cloneInto()}keccak(){Mn(this.state32),bA(this.state32,this.rounds),Mn(this.state32),this.posOut=0,this.pos=0}update(e){er(this),e=Ds(e),Ms(e);const{blockLen:s,state:n}=this,r=e.length;for(let i=0;i<r;){const o=Math.min(s-this.pos,r-i);for(let a=0;a<o;a++)n[this.pos++]^=e[i++];this.pos===s&&this.keccak()}return this}finish(){if(this.finished)return;this.finished=!0;const{state:e,suffix:s,pos:n,blockLen:r}=this;e[n]^=s,(s&128)!==0&&n===r-1&&this.keccak(),e[r-1]^=128,this.keccak()}writeInto(e){er(this,!1),Ms(e),this.finish();const s=this.state,{blockLen:n}=this;for(let r=0,i=e.length;r<i;){this.posOut>=n&&this.keccak();const o=Math.min(n-this.posOut,i-r);e.set(s.subarray(this.posOut,this.posOut+o),r),this.posOut+=o,r+=o}return e}xofInto(e){if(!this.enableXOF)throw new Error("XOF is not possible for this instance");return this.writeInto(e)}xof(e){return In(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(jd(e,this),this.finished)throw new Error("digest() was already called");return this.writeInto(e),this.destroy(),e}digest(){return this.digestInto(new Uint8Array(this.outputLen))}destroy(){this.destroyed=!0,_s(this.state)}_cloneInto(e){const{blockLen:s,suffix:n,outputLen:r,rounds:i,enableXOF:o}=this;return e||(e=new qg(s,n,r,o,i)),e.state32.set(this.state32),e.pos=this.pos,e.posOut=this.posOut,e.finished=this.finished,e.rounds=i,e.suffix=n,e.outputLen=r,e.enableXOF=o,e.destroyed=this.destroyed,e}};const CA=(t,e,s)=>Oo(()=>new vA(e,t,s)),_A=CA(1,136,256/8);function AA(t,e,s,n){if(typeof t.setBigUint64=="function")return t.setBigUint64(e,s,n);const r=BigInt(32),i=BigInt(4294967295),o=Number(s>>r&i),a=Number(s&i),c=n?4:0,l=n?0:4;t.setUint32(e+c,o,n),t.setUint32(e+l,a,n)}function SA(t,e,s){return t&e^~t&s}function IA(t,e,s){return t&e^t&s^e&s}let Wg=class extends dc{constructor(e,s,n,r){super(),this.finished=!1,this.length=0,this.pos=0,this.destroyed=!1,this.blockLen=e,this.outputLen=s,this.padOffset=n,this.isLE=r,this.buffer=new Uint8Array(e),this.view=Wc(this.buffer)}update(e){er(this),e=Ds(e),Ms(e);const{view:s,buffer:n,blockLen:r}=this,i=e.length;for(let o=0;o<i;){const a=Math.min(r-this.pos,i-o);if(a===r){const c=Wc(e);for(;r<=i-o;o+=r)this.process(c,o);continue}n.set(e.subarray(o,o+a),this.pos),this.pos+=a,o+=a,this.pos===r&&(this.process(s,0),this.pos=0)}return this.length+=e.length,this.roundClean(),this}digestInto(e){er(this),jd(e,this),this.finished=!0;const{buffer:s,view:n,blockLen:r,isLE:i}=this;let{pos:o}=this;s[o++]=128,_s(this.buffer.subarray(o)),this.padOffset>r-o&&(this.process(n,0),o=0);for(let u=o;u<r;u++)s[u]=0;AA(n,r-8,BigInt(this.length*8),i),this.process(n,0);const a=Wc(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const l=c/4,d=this.get();if(l>d.length)throw new Error("_sha2: outputLen bigger than state");for(let u=0;u<l;u++)a.setUint32(4*u,d[u],i)}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const n=e.slice(0,s);return this.destroy(),n}_cloneInto(e){e||(e=new this.constructor),e.set(...this.get());const{blockLen:s,buffer:n,length:r,finished:i,destroyed:o,pos:a}=this;return e.destroyed=o,e.finished=i,e.length=r,e.pos=a,r%s&&e.buffer.set(n),e}clone(){return this._cloneInto()}};const On=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),It=Uint32Array.from([3418070365,3238371032,1654270250,914150663,2438529370,812702999,355462360,4144912697,1731405415,4290775857,2394180231,1750603025,3675008525,1694076839,1203062813,3204075428]),Nt=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]),NA=Uint32Array.from([1116352408,1899447441,3049323471,3921009573,961987163,1508970993,2453635748,2870763221,3624381080,310598401,607225278,1426881987,1925078388,2162078206,2614888103,3248222580,3835390401,4022224774,264347078,604807628,770255983,1249150122,1555081692,1996064986,2554220882,2821834349,2952996808,3210313671,3336571891,3584528711,113926993,338241895,666307205,773529912,1294757372,1396182291,1695183700,1986661051,2177026350,2456956037,2730485921,2820302411,3259730800,3345764771,3516065817,3600352804,4094571909,275423344,430227734,506948616,659060556,883997877,958139571,1322822218,1537002063,1747873779,1955562222,2024104815,2227730452,2361852424,2428436474,2756734187,3204031479,3329325298]),Pn=new Uint32Array(64);class TA extends Wg{constructor(e=32){super(64,e,8,!1),this.A=On[0]|0,this.B=On[1]|0,this.C=On[2]|0,this.D=On[3]|0,this.E=On[4]|0,this.F=On[5]|0,this.G=On[6]|0,this.H=On[7]|0}get(){const{A:e,B:s,C:n,D:r,E:i,F:o,G:a,H:c}=this;return[e,s,n,r,i,o,a,c]}set(e,s,n,r,i,o,a,c){this.A=e|0,this.B=s|0,this.C=n|0,this.D=r|0,this.E=i|0,this.F=o|0,this.G=a|0,this.H=c|0}process(e,s){for(let u=0;u<16;u++,s+=4)Pn[u]=e.getUint32(s,!1);for(let u=16;u<64;u++){const h=Pn[u-15],p=Pn[u-2],g=js(h,7)^js(h,18)^h>>>3,f=js(p,17)^js(p,19)^p>>>10;Pn[u]=f+Pn[u-7]+g+Pn[u-16]|0}let{A:n,B:r,C:i,D:o,E:a,F:c,G:l,H:d}=this;for(let u=0;u<64;u++){const h=js(a,6)^js(a,11)^js(a,25),p=d+h+SA(a,c,l)+NA[u]+Pn[u]|0,g=(js(n,2)^js(n,13)^js(n,22))+IA(n,r,i)|0;d=l,l=c,c=a,a=o+p|0,o=i,i=r,r=n,n=p+g|0}n=n+this.A|0,r=r+this.B|0,i=i+this.C|0,o=o+this.D|0,a=a+this.E|0,c=c+this.F|0,l=l+this.G|0,d=d+this.H|0,this.set(n,r,i,o,a,c,l,d)}roundClean(){_s(Pn)}destroy(){this.set(0,0,0,0,0,0,0,0),_s(this.buffer)}}const Hg=kg(["0x428a2f98d728ae22","0x7137449123ef65cd","0xb5c0fbcfec4d3b2f","0xe9b5dba58189dbbc","0x3956c25bf348b538","0x59f111f1b605d019","0x923f82a4af194f9b","0xab1c5ed5da6d8118","0xd807aa98a3030242","0x12835b0145706fbe","0x243185be4ee4b28c","0x550c7dc3d5ffb4e2","0x72be5d74f27b896f","0x80deb1fe3b1696b1","0x9bdc06a725c71235","0xc19bf174cf692694","0xe49b69c19ef14ad2","0xefbe4786384f25e3","0x0fc19dc68b8cd5b5","0x240ca1cc77ac9c65","0x2de92c6f592b0275","0x4a7484aa6ea6e483","0x5cb0a9dcbd41fbd4","0x76f988da831153b5","0x983e5152ee66dfab","0xa831c66d2db43210","0xb00327c898fb213f","0xbf597fc7beef0ee4","0xc6e00bf33da88fc2","0xd5a79147930aa725","0x06ca6351e003826f","0x142929670a0e6e70","0x27b70a8546d22ffc","0x2e1b21385c26c926","0x4d2c6dfc5ac42aed","0x53380d139d95b3df","0x650a73548baf63de","0x766a0abb3c77b2a8","0x81c2c92e47edaee6","0x92722c851482353b","0xa2bfe8a14cf10364","0xa81a664bbc423001","0xc24b8b70d0f89791","0xc76c51a30654be30","0xd192e819d6ef5218","0xd69906245565a910","0xf40e35855771202a","0x106aa07032bbd1b8","0x19a4c116b8d2d0c8","0x1e376c085141ab53","0x2748774cdf8eeb99","0x34b0bcb5e19b48a8","0x391c0cb3c5c95a63","0x4ed8aa4ae3418acb","0x5b9cca4f7763e373","0x682e6ff3d6b2b8a3","0x748f82ee5defb2fc","0x78a5636f43172f60","0x84c87814a1f0ab72","0x8cc702081a6439ec","0x90befffa23631e28","0xa4506cebde82bde9","0xbef9a3f7b2c67915","0xc67178f2e372532b","0xca273eceea26619c","0xd186b8c721c0c207","0xeada7dd6cde0eb1e","0xf57d4f7fee6ed178","0x06f067aa72176fba","0x0a637dc5a2c898a6","0x113f9804bef90dae","0x1b710b35131c471b","0x28db77f523047d84","0x32caab7b40c72493","0x3c9ebe0a15c9bebc","0x431d67c49c100d4c","0x4cc5d4becb3e42b6","0x597f299cfc657e2a","0x5fcb6fab3ad6faec","0x6c44198c4a475817"].map(t=>BigInt(t))),RA=Hg[0],OA=Hg[1],xn=new Uint32Array(80),kn=new Uint32Array(80);let Fd=class extends Wg{constructor(e=64){super(128,e,16,!1),this.Ah=Nt[0]|0,this.Al=Nt[1]|0,this.Bh=Nt[2]|0,this.Bl=Nt[3]|0,this.Ch=Nt[4]|0,this.Cl=Nt[5]|0,this.Dh=Nt[6]|0,this.Dl=Nt[7]|0,this.Eh=Nt[8]|0,this.El=Nt[9]|0,this.Fh=Nt[10]|0,this.Fl=Nt[11]|0,this.Gh=Nt[12]|0,this.Gl=Nt[13]|0,this.Hh=Nt[14]|0,this.Hl=Nt[15]|0}get(){const{Ah:e,Al:s,Bh:n,Bl:r,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:d,Fh:u,Fl:h,Gh:p,Gl:g,Hh:f,Hl:y}=this;return[e,s,n,r,i,o,a,c,l,d,u,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,d,u,h,p,g,f,y){this.Ah=e|0,this.Al=s|0,this.Bh=n|0,this.Bl=r|0,this.Ch=i|0,this.Cl=o|0,this.Dh=a|0,this.Dl=c|0,this.Eh=l|0,this.El=d|0,this.Fh=u|0,this.Fl=h|0,this.Gh=p|0,this.Gl=g|0,this.Hh=f|0,this.Hl=y|0}process(e,s){for(let v=0;v<16;v++,s+=4)xn[v]=e.getUint32(s),kn[v]=e.getUint32(s+=4);for(let v=16;v<80;v++){const C=xn[v-15]|0,R=kn[v-15]|0,D=Dn(C,R,1)^Dn(C,R,8)^Ah(C,R,7),L=Ln(C,R,1)^Ln(C,R,8)^Sh(C,R,7),W=xn[v-2]|0,k=kn[v-2]|0,q=Dn(W,k,19)^Ui(W,k,61)^Ah(W,k,6),V=Ln(W,k,19)^$i(W,k,61)^Sh(W,k,6),x=oA(L,V,kn[v-7],kn[v-16]),N=aA(x,D,q,xn[v-7],xn[v-16]);xn[v]=N|0,kn[v]=x|0}let{Ah:n,Al:r,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:d,Eh:u,El:h,Fh:p,Fl:g,Gh:f,Gl:y,Hh:_,Hl:S}=this;for(let v=0;v<80;v++){const C=Dn(u,h,14)^Dn(u,h,18)^Ui(u,h,41),R=Ln(u,h,14)^Ln(u,h,18)^$i(u,h,41),D=u&p^~u&f,L=h&g^~h&y,W=cA(S,R,L,OA[v],kn[v]),k=lA(W,_,C,D,RA[v],xn[v]),q=W|0,V=Dn(n,r,28)^Ui(n,r,34)^Ui(n,r,39),x=Ln(n,r,28)^$i(n,r,34)^$i(n,r,39),N=n&i^n&a^i&a,T=r&o^r&c^o&c;_=f|0,S=y|0,f=p|0,y=g|0,p=u|0,g=h|0,{h:u,l:h}=Os(l|0,d|0,k|0,q|0),l=a|0,d=c|0,a=i|0,c=o|0,i=n|0,o=r|0;const w=Md(q,x,T);n=Bd(w,k,V,N),r=w|0}({h:n,l:r}=Os(this.Ah|0,this.Al|0,n|0,r|0)),{h:i,l:o}=Os(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=Os(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:d}=Os(this.Dh|0,this.Dl|0,l|0,d|0),{h:u,l:h}=Os(this.Eh|0,this.El|0,u|0,h|0),{h:p,l:g}=Os(this.Fh|0,this.Fl|0,p|0,g|0),{h:f,l:y}=Os(this.Gh|0,this.Gl|0,f|0,y|0),{h:_,l:S}=Os(this.Hh|0,this.Hl|0,_|0,S|0),this.set(n,r,i,o,a,c,l,d,u,h,p,g,f,y,_,S)}roundClean(){_s(xn,kn)}destroy(){_s(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};class PA extends Fd{constructor(){super(48),this.Ah=It[0]|0,this.Al=It[1]|0,this.Bh=It[2]|0,this.Bl=It[3]|0,this.Ch=It[4]|0,this.Cl=It[5]|0,this.Dh=It[6]|0,this.Dl=It[7]|0,this.Eh=It[8]|0,this.El=It[9]|0,this.Fh=It[10]|0,this.Fl=It[11]|0,this.Gh=It[12]|0,this.Gl=It[13]|0,this.Hh=It[14]|0,this.Hl=It[15]|0}}const Tt=Uint32Array.from([573645204,4230739756,2673172387,3360449730,596883563,1867755857,2520282905,1497426621,2519219938,2827943907,3193839141,1401305490,721525244,746961066,246885852,2177182882]);class xA extends Fd{constructor(){super(32),this.Ah=Tt[0]|0,this.Al=Tt[1]|0,this.Bh=Tt[2]|0,this.Bl=Tt[3]|0,this.Ch=Tt[4]|0,this.Cl=Tt[5]|0,this.Dh=Tt[6]|0,this.Dl=Tt[7]|0,this.Eh=Tt[8]|0,this.El=Tt[9]|0,this.Fh=Tt[10]|0,this.Fl=Tt[11]|0,this.Gh=Tt[12]|0,this.Gl=Tt[13]|0,this.Hh=Tt[14]|0,this.Hl=Tt[15]|0}}const uc=Oo(()=>new TA),kA=Oo(()=>new Fd),UA=Oo(()=>new PA),$A=Oo(()=>new xA),DA=Uint8Array.from([0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,14,10,4,8,9,15,13,6,1,12,0,2,11,7,5,3,11,8,12,0,5,2,15,13,10,14,3,6,7,1,9,4,7,9,3,1,13,12,11,14,2,6,5,10,4,0,15,8,9,0,5,7,2,4,10,15,14,1,11,12,6,8,3,13,2,12,6,10,0,11,8,3,4,13,7,5,15,14,1,9,12,5,1,15,14,13,4,10,0,7,6,3,9,2,8,11,13,11,7,14,12,1,3,9,5,0,15,4,8,6,2,10,6,15,14,9,11,3,0,8,12,2,13,7,1,4,10,5,10,2,8,4,7,6,1,5,15,11,9,14,3,12,13,0,0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,14,10,4,8,9,15,13,6,1,12,0,2,11,7,5,3,11,8,12,0,5,2,15,13,10,14,3,6,7,1,9,4,7,9,3,1,13,12,11,14,2,6,5,10,4,0,15,8,9,0,5,7,2,4,10,15,14,1,11,12,6,8,3,13,2,12,6,10,0,11,8,3,4,13,7,5,15,14,1,9]),ct=Uint32Array.from([4089235720,1779033703,2227873595,3144134277,4271175723,1013904242,1595750129,2773480762,2917565137,1359893119,725511199,2600822924,4215389547,528734635,327033209,1541459225]),ee=new Uint32Array(32);function Un(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=ee[2*t],l=ee[2*t+1],d=ee[2*e],u=ee[2*e+1],h=ee[2*s],p=ee[2*s+1],g=ee[2*n],f=ee[2*n+1],y=Md(c,d,o);l=Bd(y,l,u,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:eA(f,g),Dl:tA(f)},{h:p,l:h}=Os(p,h,f,g),{Bh:u,Bl:d}={Bh:u^p,Bl:d^h},{Bh:u,Bl:d}={Bh:Dn(u,d,24),Bl:Ln(u,d,24)},ee[2*t]=c,ee[2*t+1]=l,ee[2*e]=d,ee[2*e+1]=u,ee[2*s]=h,ee[2*s+1]=p,ee[2*n]=g,ee[2*n+1]=f}function $n(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=ee[2*t],l=ee[2*t+1],d=ee[2*e],u=ee[2*e+1],h=ee[2*s],p=ee[2*s+1],g=ee[2*n],f=ee[2*n+1],y=Md(c,d,o);l=Bd(y,l,u,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:Dn(f,g,16),Dl:Ln(f,g,16)},{h:p,l:h}=Os(p,h,f,g),{Bh:u,Bl:d}={Bh:u^p,Bl:d^h},{Bh:u,Bl:d}={Bh:Ui(u,d,63),Bl:$i(u,d,63)},ee[2*t]=c,ee[2*t+1]=l,ee[2*e]=d,ee[2*e+1]=u,ee[2*s]=h,ee[2*s+1]=p,ee[2*n]=g,ee[2*n+1]=f}function LA(t,e={},s,n,r){if(In(s),t<0||t>s)throw new Error("outputLen bigger than keyLen");const{key:i,salt:o,personalization:a}=e;if(i!==void 0&&(i.length<1||i.length>s))throw new Error("key length must be undefined or 1.."+s);if(o!==void 0&&o.length!==n)throw new Error("salt must be undefined or "+n);if(a!==void 0&&a.length!==r)throw new Error("personalization must be undefined or "+r)}class MA extends dc{constructor(e,s){super(),this.finished=!1,this.destroyed=!1,this.length=0,this.pos=0,In(e),In(s),this.blockLen=e,this.outputLen=s,this.buffer=new Uint8Array(e),this.buffer32=go(this.buffer)}update(e){er(this),e=Ds(e),Ms(e);const{blockLen:s,buffer:n,buffer32:r}=this,i=e.length,o=e.byteOffset,a=e.buffer;for(let c=0;c<i;){this.pos===s&&(Mn(r),this.compress(r,0,!1),Mn(r),this.pos=0);const l=Math.min(s-this.pos,i-c),d=o+c;if(l===s&&!(d%4)&&c+l<i){const u=new Uint32Array(a,d,Math.floor((i-c)/4));Mn(u);for(let h=0;c+s<i;h+=r.length,c+=s)this.length+=s,this.compress(u,h,!1);Mn(u);continue}n.set(e.subarray(c,c+l),this.pos),this.pos+=l,this.length+=l,c+=l}return this}digestInto(e){er(this),jd(e,this);const{pos:s,buffer32:n}=this;this.finished=!0,_s(this.buffer.subarray(s)),Mn(n),this.compress(n,0,!0),Mn(n);const r=go(e);this.get().forEach((i,o)=>r[o]=ln(i))}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const n=e.slice(0,s);return this.destroy(),n}_cloneInto(e){const{buffer:s,length:n,finished:r,destroyed:i,outputLen:o,pos:a}=this;return e||(e=new this.constructor({dkLen:o})),e.set(...this.get()),e.buffer.set(s),e.destroyed=i,e.finished=r,e.length=n,e.pos=a,e.outputLen=o,e}clone(){return this._cloneInto()}}class BA extends MA{constructor(e={}){const s=e.dkLen===void 0?64:e.dkLen;super(128,s),this.v0l=ct[0]|0,this.v0h=ct[1]|0,this.v1l=ct[2]|0,this.v1h=ct[3]|0,this.v2l=ct[4]|0,this.v2h=ct[5]|0,this.v3l=ct[6]|0,this.v3h=ct[7]|0,this.v4l=ct[8]|0,this.v4h=ct[9]|0,this.v5l=ct[10]|0,this.v5h=ct[11]|0,this.v6l=ct[12]|0,this.v6h=ct[13]|0,this.v7l=ct[14]|0,this.v7h=ct[15]|0,LA(s,e,64,16,16);let{key:n,personalization:r,salt:i}=e,o=0;if(n!==void 0&&(n=Ds(n),o=n.length),this.v0l^=this.outputLen|o<<8|65536|1<<24,i!==void 0){i=Ds(i);const a=go(i);this.v4l^=ln(a[0]),this.v4h^=ln(a[1]),this.v5l^=ln(a[2]),this.v5h^=ln(a[3])}if(r!==void 0){r=Ds(r);const a=go(r);this.v6l^=ln(a[0]),this.v6h^=ln(a[1]),this.v7l^=ln(a[2]),this.v7h^=ln(a[3])}if(n!==void 0){const a=new Uint8Array(this.blockLen);a.set(n),this.update(a)}}get(){let{v0l:e,v0h:s,v1l:n,v1h:r,v2l:i,v2h:o,v3l:a,v3h:c,v4l:l,v4h:d,v5l:u,v5h:h,v6l:p,v6h:g,v7l:f,v7h:y}=this;return[e,s,n,r,i,o,a,c,l,d,u,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,d,u,h,p,g,f,y){this.v0l=e|0,this.v0h=s|0,this.v1l=n|0,this.v1h=r|0,this.v2l=i|0,this.v2h=o|0,this.v3l=a|0,this.v3h=c|0,this.v4l=l|0,this.v4h=d|0,this.v5l=u|0,this.v5h=h|0,this.v6l=p|0,this.v6h=g|0,this.v7l=f|0,this.v7h=y|0}compress(e,s,n){this.get().forEach((c,l)=>ee[l]=c),ee.set(ct,16);let{h:r,l:i}=xg(BigInt(this.length));ee[24]=ct[8]^i,ee[25]=ct[9]^r,n&&(ee[28]=~ee[28],ee[29]=~ee[29]);let o=0;const a=DA;for(let c=0;c<12;c++)Un(0,4,8,12,e,s+2*a[o++]),$n(0,4,8,12,e,s+2*a[o++]),Un(1,5,9,13,e,s+2*a[o++]),$n(1,5,9,13,e,s+2*a[o++]),Un(2,6,10,14,e,s+2*a[o++]),$n(2,6,10,14,e,s+2*a[o++]),Un(3,7,11,15,e,s+2*a[o++]),$n(3,7,11,15,e,s+2*a[o++]),Un(0,5,10,15,e,s+2*a[o++]),$n(0,5,10,15,e,s+2*a[o++]),Un(1,6,11,12,e,s+2*a[o++]),$n(1,6,11,12,e,s+2*a[o++]),Un(2,7,8,13,e,s+2*a[o++]),$n(2,7,8,13,e,s+2*a[o++]),Un(3,4,9,14,e,s+2*a[o++]),$n(3,4,9,14,e,s+2*a[o++]);this.v0l^=ee[0]^ee[16],this.v0h^=ee[1]^ee[17],this.v1l^=ee[2]^ee[18],this.v1h^=ee[3]^ee[19],this.v2l^=ee[4]^ee[20],this.v2h^=ee[5]^ee[21],this.v3l^=ee[6]^ee[22],this.v3h^=ee[7]^ee[23],this.v4l^=ee[8]^ee[24],this.v4h^=ee[9]^ee[25],this.v5l^=ee[10]^ee[26],this.v5h^=ee[11]^ee[27],this.v6l^=ee[12]^ee[28],this.v6h^=ee[13]^ee[29],this.v7l^=ee[14]^ee[30],this.v7h^=ee[15]^ee[31],_s(ee)}destroy(){this.destroyed=!0,_s(this.buffer32),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}}const jA=hA(t=>new BA(t)),FA="https://rpc.walletconnect.org/v1";function zg(t){const e=`Ethereum Signed Message:
|
|
6
6
|
${t.length}`,s=new TextEncoder().encode(e+t);return"0x"+Ue.from(_A(s)).toString("hex")}async function qA(t,e,s,n,r,i){switch(s.t){case"eip191":return await WA(t,e,s.s);case"eip1271":return await HA(t,e,s.s,n,r,i);default:throw new Error(`verifySignature failed: Attempted to verify CacaoSignature with unknown type: ${s.t}`)}}function WA(t,e,s){const n=l0(s);return C0({payload:zg(e),signature:n}).toLowerCase()===t.toLowerCase()}async function HA(t,e,s,n,r,i){const o=vn(n);if(!o.namespace||!o.reference)throw new Error(`isValidEip1271Signature failed: chainId must be in CAIP-2 format, received: ${n}`);try{const a="0x1626ba7e",c="0000000000000000000000000000000000000000000000000000000000000040",l=s.substring(2),d=(l.length/2).toString(16).padStart(64,"0"),u=(e.startsWith("0x")?e:zg(e)).substring(2),h=a+u+c+d+l,p=await fetch(`${i||FA}/?chainId=${n}&projectId=${r}`,{headers:{"Content-Type":"application/json"},method:"POST",body:JSON.stringify({id:zA(),jsonrpc:"2.0",method:"eth_call",params:[{to:t,data:h},"latest"]})}),{result:g}=await p.json();return g?g.slice(0,a.length).toLowerCase()===a.toLowerCase():!1}catch(a){return console.error("isValidEip1271Signature: ",a),!1}}function zA(){return Date.now()+Math.floor(Math.random()*1e3)}function VA(t){const e=atob(t),s=new Uint8Array(e.length);for(let o=0;o<e.length;o++)s[o]=e.charCodeAt(o);const n=s[0];if(n===0)throw new Error("No signatures found");const r=1+n*64;if(s.length<r)throw new Error("Transaction data too short for claimed signature count");if(s.length<100)throw new Error("Transaction too short");const i=Ue.from(t,"base64").slice(1,65);return To.encode(i)}function KA(t){const e=new Uint8Array(Ue.from(t,"base64")),s=Array.from("TransactionData::").map(i=>i.charCodeAt(0)),n=new Uint8Array(s.length+e.length);n.set(s),n.set(e,s.length);const r=jA(n,{dkLen:32});return To.encode(r)}function Rh(t){const e=new Uint8Array(uc(GA(t)));return To.encode(e)}function GA(t){if(t instanceof Uint8Array)return t;if(Array.isArray(t))return new Uint8Array(t);if(typeof t=="object"&&t!=null&&t.data)return new Uint8Array(Object.values(t.data));if(typeof t=="object"&&t)return new Uint8Array(Object.values(t));throw new Error("getNearUint8ArrayFromBytes: Unexpected result type from bytes array")}function Oh(t){const e=Ue.from(t,"base64"),s=Py(e).txn;if(!s)throw new Error("Invalid signed transaction: missing 'txn' field");const n=xy(s),r=Ue.from("TX"),i=Ue.concat([r,Ue.from(n)]),o=$A(i);return v0.encode(o).replace(/=+$/,"")}function Hc(t){const e=[];let s=BigInt(t);for(;s>=BigInt(128);)e.push(Number(s&BigInt(127)|BigInt(128))),s>>=BigInt(7);return e.push(Number(s)),Ue.from(e)}function YA(t){const e=Ue.from(t.signed.bodyBytes,"base64"),s=Ue.from(t.signed.authInfoBytes,"base64"),n=Ue.from(t.signature.signature,"base64"),r=[];r.push(Ue.from([10])),r.push(Hc(e.length)),r.push(e),r.push(Ue.from([18])),r.push(Hc(s.length)),r.push(s),r.push(Ue.from([26])),r.push(Hc(n.length)),r.push(n);const i=Ue.concat(r),o=uc(i);return Ue.from(o).toString("hex").toUpperCase()}function ZA(t){var e,s;const n=[];try{if(typeof t=="string")return n.push(t),n;if(typeof t!="object")return n;t!=null&&t.id&&n.push(t.id);const r=(s=(e=t==null?void 0:t.capabilities)==null?void 0:e.caip345)==null?void 0:s.transactionHashes;r&&n.push(...r)}catch(r){console.warn("getWalletSendCallsHashes failed: ",r)}return n}var JA=Object.defineProperty,XA=Object.defineProperties,QA=Object.getOwnPropertyDescriptors,Ph=Object.getOwnPropertySymbols,eS=Object.prototype.hasOwnProperty,tS=Object.prototype.propertyIsEnumerable,xh=(t,e,s)=>e in t?JA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,sS=(t,e)=>{for(var s in e||(e={}))eS.call(e,s)&&xh(t,s,e[s]);if(Ph)for(var s of Ph(e))tS.call(e,s)&&xh(t,s,e[s]);return t},nS=(t,e)=>XA(t,QA(e));const Vg="did:pkh:",rS={eip155:"Ethereum",solana:"Solana",bip122:"Bitcoin"},iS=t=>t?rS[t]||t:"",hc=t=>t==null?void 0:t.split(":"),oS=t=>{const e=t&&hc(t);if(e)return t.includes(Vg)?e[3]:e[1]},aS=t=>{const e=t&&hc(t);if(e)return t.includes(Vg)?e[2]:e[0]},zl=t=>{const e=t&&hc(t);if(e)return e[2]+":"+e[3]},za=t=>{const e=t&&hc(t);if(e)return e.pop()};async function kh(t){const{cacao:e,projectId:s}=t,{s:n,p:r}=e,i=Kg(r,r.iss),o=za(r.iss);return await qA(o,i,n,zl(r.iss),s)}const Kg=(t,e)=>{const s=aS(e);if(!s)throw new Error("Invalid issuer: "+e);const n=`${t.domain} wants you to sign in with your ${iS(s)} account:`,r=za(e);if(!t.aud&&!t.uri)throw new Error("Either `aud` or `uri` is required to construct the message");let i=t.statement||void 0;const o=`URI: ${t.aud||t.uri}`,a=`Version: ${t.version}`,c=`Chain ID: ${oS(e)}`,l=`Nonce: ${t.nonce}`,d=`Issued At: ${t.iat}`,u=t.exp?`Expiration Time: ${t.exp}`:void 0,h=t.nbf?`Not Before: ${t.nbf}`:void 0,p=t.requestId?`Request ID: ${t.requestId}`:void 0,g=t.resources?`Resources:${t.resources.map(y=>`
|
|
7
7
|
- ${y}`).join("")}`:void 0,f=ma(t.resources);if(f){const y=mo(f);i=mS(i,y)}return[n,r,"",i,"",o,a,c,l,d,u,h,p,g].filter(y=>y!=null).join(`
|
|
@@ -11,7 +11,7 @@ ${t.length}`,s=new TextEncoder().encode(e+t);return"0x"+Ue.from(_A(s)).toString(
|
|
|
11
11
|
Required: ${o.toString()}
|
|
12
12
|
Approved: ${a.toString()}`)),Object.keys(e).forEach(u=>{if(!u.includes(":")||n)return;const h=wi(e[u].accounts);h.includes(u)||(n=Y("NON_CONFORMING_NAMESPACES",`${s} namespaces accounts don't satisfy namespace accounts for ${u}
|
|
13
13
|
Required: ${u}
|
|
14
|
-
Approved: ${h.toString()}`))}),o.forEach(u=>{n||(mr(r[u].methods,i[u].methods)?mr(r[u].events,i[u].events)||(n=Y("NON_CONFORMING_NAMESPACES",`${s} namespaces events don't satisfy namespace events for ${u}`)):n=Y("NON_CONFORMING_NAMESPACES",`${s} namespaces methods don't satisfy namespace methods for ${u}`))}),n}function xN(t){const e={};return Object.keys(t).forEach(s=>{var n;s.includes(":")?e[s]=t[s]:(n=t[s].chains)==null||n.forEach(r=>{e[r]={methods:t[s].methods,events:t[s].events}})}),e}function up(t){return[...new Set(t.map(e=>e.includes(":")?e.split(":")[0]:e))]}function kN(t){const e={};return Object.keys(t).forEach(s=>{if(s.includes(":"))e[s]=t[s];else{const n=wi(t[s].accounts);n==null||n.forEach(r=>{e[r]={accounts:t[s].accounts.filter(i=>i.includes(`${r}:`)),methods:t[s].methods,events:t[s].events}})}}),e}function UN(t,e){return Kd(t)&&t<=e.max&&t>=e.min}function hp(){const t=Ro();return new Promise(e=>{switch(t){case us.browser:e($N());break;case us.reactNative:e(DN());break;case us.node:e(LN());break;default:e(!0)}})}function $N(){return yi()&&(navigator==null?void 0:navigator.onLine)}async function DN(){if(tr()&&typeof Me<"u"&&Me!=null&&Me.NetInfo){const t=await(Me==null?void 0:Me.NetInfo.fetch());return t==null?void 0:t.isConnected}return!0}function LN(){return!0}function MN(t){switch(Ro()){case us.browser:BN(t);break;case us.reactNative:jN(t);break}}function BN(t){!tr()&&yi()&&(window.addEventListener("online",()=>t(!0)),window.addEventListener("offline",()=>t(!1)))}function jN(t){tr()&&typeof Me<"u"&&Me!=null&&Me.NetInfo&&(Me==null||Me.NetInfo.addEventListener(e=>t(e==null?void 0:e.isConnected)))}function FN(){var t;return yi()&&An.getDocument()?((t=An.getDocument())==null?void 0:t.visibilityState)==="visible":!0}const tl={};class Si{static get(e){return tl[e]}static set(e,s){tl[e]=s}static delete(e){delete tl[e]}}function qN(t){const e=To.decode(t);if(e.length<33)throw new Error("Too short to contain a public key");return e.slice(1,33)}function WN({publicKey:t,signature:e,payload:s}){var n;const r=sd(s.method),i=128|parseInt(((n=s.version)==null?void 0:n.toString())||"4"),o=VN(s.address),a=s.era==="00"?new Uint8Array([0]):sd(s.era);if(a.length!==1&&a.length!==2)throw new Error("Invalid era length");const c=parseInt(s.nonce,16),l=new Uint8Array([c&255,c>>8&255]),d=BigInt(`0x${zN(s.tip)}`),u=GN(d),h=new Uint8Array([0,...t,o,...e,...a,...l,...u,...r]),p=KN(h.length+1);return new Uint8Array([...p,i,...h])}function HN(t){const e=sd(t),s=ky.blake2b(e,void 0,32);return"0x"+Ue.from(s).toString("hex")}function sd(t){return new Uint8Array(t.replace(/^0x/,"").match(/.{1,2}/g).map(e=>parseInt(e,16)))}function zN(t){return t.startsWith("0x")?t.slice(2):t}function VN(t){const e=To.decode(t)[0];return e===42?0:e===60?2:1}function KN(t){if(t<64)return new Uint8Array([t<<2]);if(t<16384){const e=t<<2|1;return new Uint8Array([e&255,e>>8&255])}else if(t<1<<30){const e=t<<2|2;return new Uint8Array([e&255,e>>8&255,e>>16&255,e>>24&255])}else throw new Error("Compact encoding > 2^30 not supported")}function GN(t){if(t<BigInt(1)<<BigInt(6))return new Uint8Array([Number(t<<BigInt(2))]);if(t<BigInt(1)<<BigInt(14)){const e=t<<BigInt(2)|BigInt(1);return new Uint8Array([Number(e&BigInt(255)),Number(e>>BigInt(8)&BigInt(255))])}else if(t<BigInt(1)<<BigInt(30)){const e=t<<BigInt(2)|BigInt(2);return new Uint8Array([Number(e&BigInt(255)),Number(e>>BigInt(8)&BigInt(255)),Number(e>>BigInt(16)&BigInt(255)),Number(e>>BigInt(24)&BigInt(255))])}else throw new Error("BigInt compact encoding not supported > 2^30")}function YN(t){const e=Uint8Array.from(Ue.from(t.signature,"hex")),s=qN(t.transaction.address),n=WN({publicKey:s,signature:e,payload:t.transaction}),r=Ue.from(n).toString("hex");return HN(r)}function Gd({logger:t,name:e}){const s=typeof t=="string"?ic({opts:{level:t,name:e}}).logger:t;return s.level=typeof t=="string"?t:t.level,s}var ZN={VITE_BASE_URL:"https://cdn.decentraland.org/@dcl/marketplace-site/8.6.1"};const xm="wc",km=2,nd="core",tn=`${xm}@2:${nd}:`,JN={logger:"error"},XN={database:":memory:"},QN="crypto",pp="client_ed25519_seed",e1=Z.ONE_DAY,t1="keychain",s1="0.3",n1="messages",r1="0.3",i1=Z.SIX_HOURS,o1="publisher",Um="irn",a1="error",$m="wss://relay.walletconnect.org",c1="relayer",it={message:"relayer_message",message_ack:"relayer_message_ack",connect:"relayer_connect",disconnect:"relayer_disconnect",error:"relayer_error",connection_stalled:"relayer_connection_stalled",transport_closed:"relayer_transport_closed",publish:"relayer_publish"},l1="_subscription",ps={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},d1=.1,rd="2.23.0",Ke={link_mode:"link_mode",relay:"relay"},wa={inbound:"inbound",outbound:"outbound"},u1="0.3",h1="WALLETCONNECT_CLIENT_ID",fp="WALLETCONNECT_LINK_MODE_APPS",is={created:"subscription_created",deleted:"subscription_deleted",expired:"subscription_expired",disabled:"subscription_disabled",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},p1="subscription",f1="0.3",g1="pairing",m1="0.3",Ii={wc_pairingDelete:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:Z.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:Z.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:0},res:{ttl:Z.ONE_DAY,prompt:!1,tag:0}}},ur={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},Ss={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},y1="history",w1="0.3",E1="expirer",ys={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},b1="0.3",v1="verify-api",C1="https://verify.walletconnect.com",Dm="https://verify.walletconnect.org",qi=Dm,_1=`${qi}/v3`,A1=[C1,Dm],S1="echo",I1="https://echo.walletconnect.com",Ws={pairing_started:"pairing_started",pairing_uri_validation_success:"pairing_uri_validation_success",pairing_uri_not_expired:"pairing_uri_not_expired",store_new_pairing:"store_new_pairing",subscribing_pairing_topic:"subscribing_pairing_topic",subscribe_pairing_topic_success:"subscribe_pairing_topic_success",existing_pairing:"existing_pairing",pairing_not_expired:"pairing_not_expired",emit_inactive_pairing:"emit_inactive_pairing",emit_session_proposal:"emit_session_proposal",subscribing_to_pairing_topic:"subscribing_to_pairing_topic"},dn={no_wss_connection:"no_wss_connection",no_internet_connection:"no_internet_connection",malformed_pairing_uri:"malformed_pairing_uri",active_pairing_already_exists:"active_pairing_already_exists",subscribe_pairing_topic_failure:"subscribe_pairing_topic_failure",pairing_expired:"pairing_expired",proposal_expired:"proposal_expired",proposal_listener_not_found:"proposal_listener_not_found"},Is={session_approve_started:"session_approve_started",proposal_not_expired:"proposal_not_expired",session_namespaces_validation_success:"session_namespaces_validation_success",create_session_topic:"create_session_topic",subscribing_session_topic:"subscribing_session_topic",subscribe_session_topic_success:"subscribe_session_topic_success",publishing_session_approve:"publishing_session_approve",session_approve_publish_success:"session_approve_publish_success",store_session:"store_session",publishing_session_settle:"publishing_session_settle",session_settle_publish_success:"session_settle_publish_success",session_request_response_started:"session_request_response_started",session_request_response_validation_success:"session_request_response_validation_success",session_request_response_publish_started:"session_request_response_publish_started"},rr={no_internet_connection:"no_internet_connection",no_wss_connection:"no_wss_connection",proposal_expired:"proposal_expired",subscribe_session_topic_failure:"subscribe_session_topic_failure",session_approve_publish_failure:"session_approve_publish_failure",session_settle_publish_failure:"session_settle_publish_failure",session_approve_namespace_validation_failure:"session_approve_namespace_validation_failure",proposal_not_found:"proposal_not_found",session_request_response_validation_failure:"session_request_response_validation_failure",session_request_response_publish_failure:"session_request_response_publish_failure"},ir={authenticated_session_approve_started:"authenticated_session_approve_started",create_authenticated_session_topic:"create_authenticated_session_topic",cacaos_verified:"cacaos_verified",store_authenticated_session:"store_authenticated_session",subscribing_authenticated_session_topic:"subscribing_authenticated_session_topic",subscribe_authenticated_session_topic_success:"subscribe_authenticated_session_topic_success",publishing_authenticated_session_approve:"publishing_authenticated_session_approve"},Ni={no_internet_connection:"no_internet_connection",invalid_cacao:"invalid_cacao",subscribe_authenticated_session_topic_failure:"subscribe_authenticated_session_topic_failure",authenticated_session_approve_publish_failure:"authenticated_session_approve_publish_failure",authenticated_session_pending_request_not_found:"authenticated_session_pending_request_not_found"},N1=.1,T1="event-client",R1=86400,O1="https://pulse.walletconnect.org/batch";function P1(t,e){if(t.length>=255)throw new TypeError("Alphabet too long");for(var s=new Uint8Array(256),n=0;n<s.length;n++)s[n]=255;for(var r=0;r<t.length;r++){var i=t.charAt(r),o=i.charCodeAt(0);if(s[o]!==255)throw new TypeError(i+" is ambiguous");s[o]=r}var a=t.length,c=t.charAt(0),l=Math.log(a)/Math.log(256),d=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var f=0,y=0,_=0,S=g.length;_!==S&&g[_]===0;)_++,f++;for(var v=(S-_)*d+1>>>0,C=new Uint8Array(v);_!==S;){for(var R=g[_],D=0,L=v-1;(R!==0||D<y)&&L!==-1;L--,D++)R+=256*C[L]>>>0,C[L]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");y=D,_++}for(var W=v-y;W!==v&&C[W]===0;)W++;for(var k=c.repeat(f);W<v;++W)k+=t.charAt(C[W]);return k}function h(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var f=0;if(g[f]!==" "){for(var y=0,_=0;g[f]===c;)y++,f++;for(var S=(g.length-f)*l+1>>>0,v=new Uint8Array(S);g[f];){var C=s[g.charCodeAt(f)];if(C===255)return;for(var R=0,D=S-1;(C!==0||R<_)&&D!==-1;D--,R++)C+=a*v[D]>>>0,v[D]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");_=R,f++}if(g[f]!==" "){for(var L=S-_;L!==S&&v[L]===0;)L++;for(var W=new Uint8Array(y+(S-L)),k=y;L!==S;)W[k++]=v[L++];return W}}}function p(g){var f=h(g);if(f)return f;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:h,decode:p}}var x1=P1,k1=x1;const Lm=t=>{if(t instanceof Uint8Array&&t.constructor.name==="Uint8Array")return t;if(t instanceof ArrayBuffer)return new Uint8Array(t);if(ArrayBuffer.isView(t))return new Uint8Array(t.buffer,t.byteOffset,t.byteLength);throw new Error("Unknown type, must be binary type")},U1=t=>new TextEncoder().encode(t),$1=t=>new TextDecoder().decode(t);class D1{constructor(e,s,n){this.name=e,this.prefix=s,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class L1{constructor(e,s,n){if(this.name=e,this.prefix=s,s.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Mm(this,e)}}class M1{constructor(e){this.decoders=e}or(e){return Mm(this,e)}decode(e){const s=e[0],n=this.decoders[s];if(n)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}const Mm=(t,e)=>new M1({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}});class B1{constructor(e,s,n,r){this.name=e,this.prefix=s,this.baseEncode=n,this.baseDecode=r,this.encoder=new D1(e,s,n),this.decoder=new L1(e,s,r)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const wc=({name:t,prefix:e,encode:s,decode:n})=>new B1(t,e,s,n),Uo=({prefix:t,name:e,alphabet:s})=>{const{encode:n,decode:r}=k1(s,e);return wc({prefix:t,name:e,encode:n,decode:i=>Lm(r(i))})},j1=(t,e,s,n)=>{const r={};for(let d=0;d<e.length;++d)r[e[d]]=d;let i=t.length;for(;t[i-1]==="=";)--i;const o=new Uint8Array(i*s/8|0);let a=0,c=0,l=0;for(let d=0;d<i;++d){const u=r[t[d]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<s|u,a+=s,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=s||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o},F1=(t,e,s)=>{const n=e[e.length-1]==="=",r=(1<<s)-1;let i="",o=0,a=0;for(let c=0;c<t.length;++c)for(a=a<<8|t[c],o+=8;o>s;)o-=s,i+=e[r&a>>o];if(o&&(i+=e[r&a<<s-o]),n)for(;i.length*s&7;)i+="=";return i},St=({name:t,prefix:e,bitsPerChar:s,alphabet:n})=>wc({prefix:e,name:t,encode(r){return F1(r,n,s)},decode(r){return j1(r,n,s,t)}}),q1=wc({prefix:"\0",name:"identity",encode:t=>$1(t),decode:t=>U1(t)});var W1=Object.freeze({__proto__:null,identity:q1});const H1=St({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var z1=Object.freeze({__proto__:null,base2:H1});const V1=St({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var K1=Object.freeze({__proto__:null,base8:V1});const G1=Uo({prefix:"9",name:"base10",alphabet:"0123456789"});var Y1=Object.freeze({__proto__:null,base10:G1});const Z1=St({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),J1=St({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var X1=Object.freeze({__proto__:null,base16:Z1,base16upper:J1});const Q1=St({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),eT=St({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),tT=St({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),sT=St({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),nT=St({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),rT=St({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),iT=St({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),oT=St({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),aT=St({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var cT=Object.freeze({__proto__:null,base32:Q1,base32upper:eT,base32pad:tT,base32padupper:sT,base32hex:nT,base32hexupper:rT,base32hexpad:iT,base32hexpadupper:oT,base32z:aT});const lT=Uo({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),dT=Uo({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var uT=Object.freeze({__proto__:null,base36:lT,base36upper:dT});const hT=Uo({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pT=Uo({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var fT=Object.freeze({__proto__:null,base58btc:hT,base58flickr:pT});const gT=St({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),mT=St({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),yT=St({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),wT=St({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ET=Object.freeze({__proto__:null,base64:gT,base64pad:mT,base64url:yT,base64urlpad:wT});const Bm=Array.from("🚀🪐☄🛰🌌🌑🌒🌓🌔🌕🌖🌗🌘🌍🌏🌎🐉☀💻🖥💾💿😂❤😍🤣😊🙏💕😭😘👍😅👏😁🔥🥰💔💖💙😢🤔😆🙄💪😉☺👌🤗💜😔😎😇🌹🤦🎉💞✌✨🤷😱😌🌸🙌😋💗💚😏💛🙂💓🤩😄😀🖤😃💯🙈👇🎶😒🤭❣😜💋👀😪😑💥🙋😞😩😡🤪👊🥳😥🤤👉💃😳✋😚😝😴🌟😬🙃🍀🌷😻😓⭐✅🥺🌈😈🤘💦✔😣🏃💐☹🎊💘😠☝😕🌺🎂🌻😐🖕💝🙊😹🗣💫💀👑🎵🤞😛🔴😤🌼😫⚽🤙☕🏆🤫👈😮🙆🍻🍃🐶💁😲🌿🧡🎁⚡🌞🎈❌✊👋😰🤨😶🤝🚶💰🍓💢🤟🙁🚨💨🤬✈🎀🍺🤓😙💟🌱😖👶🥴▶➡❓💎💸⬇😨🌚🦋😷🕺⚠🙅😟😵👎🤲🤠🤧📌🔵💅🧐🐾🍒😗🤑🌊🤯🐷☎💧😯💆👆🎤🙇🍑❄🌴💣🐸💌📍🥀🤢👅💡💩👐📸👻🤐🤮🎼🥵🚩🍎🍊👼💍📣🥂"),bT=Bm.reduce((t,e,s)=>(t[s]=e,t),[]),vT=Bm.reduce((t,e,s)=>(t[e.codePointAt(0)]=s,t),[]);function CT(t){return t.reduce((e,s)=>(e+=bT[s],e),"")}function _T(t){const e=[];for(const s of t){const n=vT[s.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${s}`);e.push(n)}return new Uint8Array(e)}const AT=wc({prefix:"🚀",name:"base256emoji",encode:CT,decode:_T});var ST=Object.freeze({__proto__:null,base256emoji:AT}),IT=jm,gp=128,NT=-128,TT=Math.pow(2,31);function jm(t,e,s){e=e||[],s=s||0;for(var n=s;t>=TT;)e[s++]=t&255|gp,t/=128;for(;t&NT;)e[s++]=t&255|gp,t>>>=7;return e[s]=t|0,jm.bytes=s-n+1,e}var RT=id,OT=128,mp=127;function id(t,n){var s=0,n=n||0,r=0,i=n,o,a=t.length;do{if(i>=a)throw id.bytes=0,new RangeError("Could not decode varint");o=t[i++],s+=r<28?(o&mp)<<r:(o&mp)*Math.pow(2,r),r+=7}while(o>=OT);return id.bytes=i-n,s}var PT=Math.pow(2,7),xT=Math.pow(2,14),kT=Math.pow(2,21),UT=Math.pow(2,28),$T=Math.pow(2,35),DT=Math.pow(2,42),LT=Math.pow(2,49),MT=Math.pow(2,56),BT=Math.pow(2,63),jT=function(t){return t<PT?1:t<xT?2:t<kT?3:t<UT?4:t<$T?5:t<DT?6:t<LT?7:t<MT?8:t<BT?9:10},FT={encode:IT,decode:RT,encodingLength:jT},Fm=FT;const yp=(t,e,s=0)=>(Fm.encode(t,e,s),e),wp=t=>Fm.encodingLength(t),od=(t,e)=>{const s=e.byteLength,n=wp(t),r=n+wp(s),i=new Uint8Array(r+s);return yp(t,i,0),yp(s,i,n),i.set(e,r),new qT(t,s,e,i)};class qT{constructor(e,s,n,r){this.code=e,this.size=s,this.digest=n,this.bytes=r}}const qm=({name:t,code:e,encode:s})=>new WT(t,e,s);class WT{constructor(e,s,n){this.name=e,this.code=s,this.encode=n}digest(e){if(e instanceof Uint8Array){const s=this.encode(e);return s instanceof Uint8Array?od(this.code,s):s.then(n=>od(this.code,n))}else throw Error("Unknown type, must be binary type")}}const Wm=t=>async e=>new Uint8Array(await crypto.subtle.digest(t,e)),HT=qm({name:"sha2-256",code:18,encode:Wm("SHA-256")}),zT=qm({name:"sha2-512",code:19,encode:Wm("SHA-512")});var VT=Object.freeze({__proto__:null,sha256:HT,sha512:zT});const Hm=0,KT="identity",zm=Lm,GT=t=>od(Hm,zm(t)),YT={code:Hm,name:KT,encode:zm,digest:GT};var ZT=Object.freeze({__proto__:null,identity:YT});new TextEncoder,new TextDecoder;const Ep={...W1,...z1,...K1,...Y1,...X1,...cT,...uT,...fT,...ET,...ST};({...VT,...ZT});function Vm(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function JT(t=0){return globalThis.Buffer!=null&&globalThis.Buffer.allocUnsafe!=null?Vm(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Km(t,e,s,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:s},decoder:{decode:n}}}const bp=Km("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),sl=Km("ascii","a",t=>{let e="a";for(let s=0;s<t.length;s++)e+=String.fromCharCode(t[s]);return e},t=>{t=t.substring(1);const e=JT(t.length);for(let s=0;s<t.length;s++)e[s]=t.charCodeAt(s);return e}),XT={utf8:bp,"utf-8":bp,hex:Ep.base16,latin1:sl,ascii:sl,binary:sl,...Ep};function QT(t,e="utf8"){const s=XT[e];if(!s)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Vm(globalThis.Buffer.from(t,"utf-8")):s.decoder.decode(`${s.prefix}${t}`)}var eR=Object.defineProperty,tR=(t,e,s)=>e in t?eR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fs=(t,e,s)=>tR(t,typeof e!="symbol"?e+"":e,s);class sR{constructor(e,s){this.core=e,this.logger=s,Fs(this,"keychain",new Map),Fs(this,"name",t1),Fs(this,"version",s1),Fs(this,"initialized",!1),Fs(this,"storagePrefix",tn),Fs(this,"init",async()=>{if(!this.initialized){const n=await this.getKeyChain();typeof n<"u"&&(this.keychain=n),this.initialized=!0}}),Fs(this,"has",n=>(this.isInitialized(),this.keychain.has(n))),Fs(this,"set",async(n,r)=>{this.isInitialized(),this.keychain.set(n,r),await this.persist()}),Fs(this,"get",n=>{this.isInitialized();const r=this.keychain.get(n);if(typeof r>"u"){const{message:i}=Y("NO_MATCHING_KEY",`${this.name}: ${n}`);throw new Error(i)}return r}),Fs(this,"del",async n=>{this.isInitialized(),this.keychain.delete(n),await this.persist()}),this.core=e,this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,Wl(e))}async getKeyChain(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?Hl(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var nR=Object.defineProperty,rR=(t,e,s)=>e in t?nR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ht=(t,e,s)=>rR(t,typeof e!="symbol"?e+"":e,s);class iR{constructor(e,s,n){this.core=e,this.logger=s,ht(this,"name",QN),ht(this,"keychain"),ht(this,"randomSessionIdentifier",td()),ht(this,"initialized",!1),ht(this,"clientId"),ht(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),ht(this,"hasKeys",r=>(this.isInitialized(),this.keychain.has(r))),ht(this,"getClientId",async()=>{if(this.isInitialized(),this.clientId)return this.clientId;const r=await this.getClientSeed(),i=ou(r),o=Dy(i.publicKey);return this.clientId=o,o}),ht(this,"generateKeyPair",()=>{this.isInitialized();const r=xI();return this.setPrivateKey(r.publicKey,r.privateKey)}),ht(this,"signJWT",async r=>{this.isInitialized();const i=await this.getClientSeed(),o=ou(i),a=this.randomSessionIdentifier;return await Ly(a,r,e1,o)}),ht(this,"generateSharedKey",(r,i,o)=>{this.isInitialized();const a=this.getPrivateKey(r),c=kI(a,i);return this.setSymKey(c,o)}),ht(this,"setSymKey",async(r,i)=>{this.isInitialized();const o=i||ya(r);return await this.keychain.set(o,r),o}),ht(this,"deleteKeyPair",async r=>{this.isInitialized(),await this.keychain.del(r)}),ht(this,"deleteSymKey",async r=>{this.isInitialized(),await this.keychain.del(r)}),ht(this,"encode",async(r,i,o)=>{this.isInitialized();const a=Tm(o),c=Gi(i);if(Qh(a))return DI(c,o==null?void 0:o.encoding);if(Xh(a)){const h=a.senderPublicKey,p=a.receiverPublicKey;r=await this.generateSharedKey(h,p)}const l=this.getSymKey(r),{type:d,senderPublicKey:u}=a;return UI({type:d,symKey:l,message:c,senderPublicKey:u,encoding:o==null?void 0:o.encoding})}),ht(this,"decode",async(r,i,o)=>{this.isInitialized();const a=MI(i,o);if(Qh(a)){const c=LI(i,o==null?void 0:o.encoding);return Ca(c)}if(Xh(a)){const c=a.receiverPublicKey,l=a.senderPublicKey;r=await this.generateSharedKey(c,l)}try{const c=this.getSymKey(r),l=$I({symKey:c,encoded:i,encoding:o==null?void 0:o.encoding});return Ca(l)}catch(c){this.logger.error(`Failed to decode message from topic: '${r}', clientId: '${await this.getClientId()}'`),this.logger.error(c)}}),ht(this,"getPayloadType",(r,i=Zt)=>{const o=yo({encoded:r,encoding:i});return Or(o.type)}),ht(this,"getPayloadSenderPublicKey",(r,i=Zt)=>{const o=yo({encoded:r,encoding:i});return o.senderPublicKey?Qt(o.senderPublicKey,jt):void 0}),this.core=e,this.logger=ts(s,this.name),this.keychain=n||new sR(this.core,this.logger)}get context(){return es(this.logger)}async setPrivateKey(e,s){return await this.keychain.set(e,s),e}getPrivateKey(e){return this.keychain.get(e)}async getClientSeed(){let e="";try{e=this.keychain.get(pp)}catch{e=td(),await this.keychain.set(pp,e)}return QT(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var oR=Object.defineProperty,aR=Object.defineProperties,cR=Object.getOwnPropertyDescriptors,vp=Object.getOwnPropertySymbols,lR=Object.prototype.hasOwnProperty,dR=Object.prototype.propertyIsEnumerable,ad=(t,e,s)=>e in t?oR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,uR=(t,e)=>{for(var s in e||(e={}))lR.call(e,s)&&ad(t,s,e[s]);if(vp)for(var s of vp(e))dR.call(e,s)&&ad(t,s,e[s]);return t},hR=(t,e)=>aR(t,cR(e)),ns=(t,e,s)=>ad(t,typeof e!="symbol"?e+"":e,s);class pR extends LC{constructor(e,s){super(e,s),this.logger=e,this.core=s,ns(this,"messages",new Map),ns(this,"messagesWithoutClientAck",new Map),ns(this,"name",n1),ns(this,"version",r1),ns(this,"initialized",!1),ns(this,"storagePrefix",tn),ns(this,"init",async()=>{if(!this.initialized){this.logger.trace("Initialized");try{const n=await this.getRelayerMessages();typeof n<"u"&&(this.messages=n);const r=await this.getRelayerMessagesWithoutClientAck();typeof r<"u"&&(this.messagesWithoutClientAck=r),this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",size:this.messages.size})}catch(n){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(n)}finally{this.initialized=!0}}}),ns(this,"set",async(n,r,i)=>{this.isInitialized();const o=Es(r);let a=this.messages.get(n);if(typeof a>"u"&&(a={}),typeof a[o]<"u")return o;if(a[o]=r,this.messages.set(n,a),i===wa.inbound){const c=this.messagesWithoutClientAck.get(n)||{};this.messagesWithoutClientAck.set(n,hR(uR({},c),{[o]:r}))}return await this.persist(),o}),ns(this,"get",n=>{this.isInitialized();let r=this.messages.get(n);return typeof r>"u"&&(r={}),r}),ns(this,"getWithoutAck",n=>{this.isInitialized();const r={};for(const i of n){const o=this.messagesWithoutClientAck.get(i)||{};r[i]=Object.values(o)}return r}),ns(this,"has",(n,r)=>{this.isInitialized();const i=this.get(n),o=Es(r);return typeof i[o]<"u"}),ns(this,"ack",async(n,r)=>{this.isInitialized();const i=this.messagesWithoutClientAck.get(n);if(typeof i>"u")return;const o=Es(r);delete i[o],Object.keys(i).length===0?this.messagesWithoutClientAck.delete(n):this.messagesWithoutClientAck.set(n,i),await this.persist()}),ns(this,"del",async n=>{this.isInitialized(),this.messages.delete(n),this.messagesWithoutClientAck.delete(n),await this.persist()}),this.logger=ts(e,this.name),this.core=s}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get storageKeyWithoutClientAck(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name+"_withoutClientAck"}async setRelayerMessages(e){await this.core.storage.setItem(this.storageKey,Wl(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,Wl(e))}async getRelayerMessages(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?Hl(e):void 0}async getRelayerMessagesWithoutClientAck(){const e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return typeof e<"u"?Hl(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var fR=Object.defineProperty,gR=Object.defineProperties,mR=Object.getOwnPropertyDescriptors,Cp=Object.getOwnPropertySymbols,yR=Object.prototype.hasOwnProperty,wR=Object.prototype.propertyIsEnumerable,cd=(t,e,s)=>e in t?fR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,qr=(t,e)=>{for(var s in e||(e={}))yR.call(e,s)&&cd(t,s,e[s]);if(Cp)for(var s of Cp(e))wR.call(e,s)&&cd(t,s,e[s]);return t},_p=(t,e)=>gR(t,mR(e)),fs=(t,e,s)=>cd(t,typeof e!="symbol"?e+"":e,s);class ER extends MC{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,fs(this,"events",new xr.EventEmitter),fs(this,"name",o1),fs(this,"queue",new Map),fs(this,"publishTimeout",Z.toMiliseconds(Z.ONE_MINUTE)),fs(this,"initialPublishTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),fs(this,"needsTransportRestart",!1),fs(this,"publish",async(n,r,i)=>{var o,a,c,l,d;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:n,message:r,opts:i}});const u=(i==null?void 0:i.ttl)||i1,h=(i==null?void 0:i.prompt)||!1,p=(i==null?void 0:i.tag)||0,g=(i==null?void 0:i.id)||fr().toString(),f=Jr(Ya().protocol),y={id:g,method:(i==null?void 0:i.publishMethod)||f.publish,params:qr({topic:n,message:r,ttl:u,prompt:h,tag:p,attestation:i==null?void 0:i.attestation},i==null?void 0:i.tvf)},_=`Failed to publish payload, please try again. id:${g} tag:${p}`;try{mt((o=y.params)==null?void 0:o.prompt)&&((a=y.params)==null||delete a.prompt),mt((c=y.params)==null?void 0:c.tag)&&((l=y.params)==null||delete l.tag);const S=new Promise(async v=>{const C=({id:D})=>{var L;((L=y.id)==null?void 0:L.toString())===D.toString()&&(this.removeRequestFromQueue(D),this.relayer.events.removeListener(it.publish,C),v())};this.relayer.events.on(it.publish,C);const R=Gs(new Promise((D,L)=>{this.rpcPublish(y,i).then(D).catch(W=>{this.logger.warn(W,W==null?void 0:W.message),L(W)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${g} tag:${p}`);try{await R,this.events.removeListener(it.publish,C)}catch(D){this.queue.set(g,{request:y,opts:i,attempt:1}),this.logger.warn(D,D==null?void 0:D.message)}});this.logger.trace({type:"method",method:"publish",params:{id:g,topic:n,message:r,opts:i}}),await Gs(S,this.publishTimeout,_)}catch(S){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(S),(d=i==null?void 0:i.internal)!=null&&d.throwOnFailedPublish)throw S}finally{this.queue.delete(g)}}),fs(this,"publishCustom",async n=>{var r,i,o,a,c;this.logger.debug("Publishing custom payload"),this.logger.trace({type:"method",method:"publishCustom",params:n});const{payload:l,opts:d={}}=n,{attestation:u,tvf:h,publishMethod:p,prompt:g,tag:f,ttl:y=Z.FIVE_MINUTES}=d,_=d.id||fr().toString(),S=Jr(Ya().protocol),v=p||S.publish,C={id:_,method:v,params:qr(_p(qr({},l),{ttl:y,prompt:g,tag:f,attestation:u}),h)},R=`Failed to publish custom payload, please try again. id:${_} tag:${f}`;try{mt((r=C.params)==null?void 0:r.prompt)&&((i=C.params)==null||delete i.prompt),mt((o=C.params)==null?void 0:o.tag)&&((a=C.params)==null||delete a.tag);const D=new Promise(async L=>{const W=({id:q})=>{var V;((V=C.id)==null?void 0:V.toString())===q.toString()&&(this.removeRequestFromQueue(q),this.relayer.events.removeListener(it.publish,W),L())};this.relayer.events.on(it.publish,W);const k=Gs(new Promise((q,V)=>{this.rpcPublish(C,d).then(q).catch(x=>{this.logger.warn(x,x==null?void 0:x.message),V(x)})}),this.initialPublishTimeout,`Failed initial custom payload publish, retrying.... method:${v} id:${_} tag:${f}`);try{await k,this.events.removeListener(it.publish,W)}catch(q){this.queue.set(_,{request:C,opts:d,attempt:1}),this.logger.warn(q,q==null?void 0:q.message)}});this.logger.trace({type:"method",method:"publish",params:{id:_,payload:l,opts:d}}),await Gs(D,this.publishTimeout,R)}catch(D){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(D),(c=d==null?void 0:d.internal)!=null&&c.throwOnFailedPublish)throw D}finally{this.queue.delete(_)}}),fs(this,"on",(n,r)=>{this.events.on(n,r)}),fs(this,"once",(n,r)=>{this.events.once(n,r)}),fs(this,"off",(n,r)=>{this.events.off(n,r)}),fs(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.relayer=e,this.logger=ts(s,this.name),this.registerEventListeners()}get context(){return es(this.logger)}async rpcPublish(e,s){this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"message",direction:"outgoing",request:e});const n=await this.relayer.request(e);return this.relayer.events.emit(it.publish,qr(qr({},e),s)),this.logger.debug("Successfully Published Payload"),n}removeRequestFromQueue(e){this.queue.delete(e)}checkQueue(){this.queue.forEach(async(e,s)=>{var n;const r=e.attempt+1;this.queue.set(s,_p(qr({},e),{attempt:r})),this.logger.warn({},`Publisher: queue->publishing: ${e.request.id}, tag: ${(n=e.request.params)==null?void 0:n.tag}, attempt: ${r}`),await this.rpcPublish(e.request,e.opts),this.logger.warn({},`Publisher: queue->published: ${e.request.id}`)})}registerEventListeners(){this.relayer.core.heartbeat.on(gi.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(it.connection_stalled);return}this.checkQueue()}),this.relayer.on(it.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var bR=Object.defineProperty,vR=(t,e,s)=>e in t?bR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Wr=(t,e,s)=>vR(t,typeof e!="symbol"?e+"":e,s);class CR{constructor(){Wr(this,"map",new Map),Wr(this,"set",(e,s)=>{const n=this.get(e);this.exists(e,s)||this.map.set(e,[...n,s])}),Wr(this,"get",e=>this.map.get(e)||[]),Wr(this,"exists",(e,s)=>this.get(e).includes(s)),Wr(this,"delete",(e,s)=>{if(typeof s>"u"){this.map.delete(e);return}if(!this.map.has(e))return;const n=this.get(e);if(!this.exists(e,s))return;const r=n.filter(i=>i!==s);if(!r.length){this.map.delete(e);return}this.map.set(e,r)}),Wr(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var _R=Object.defineProperty,AR=Object.defineProperties,SR=Object.getOwnPropertyDescriptors,Ap=Object.getOwnPropertySymbols,IR=Object.prototype.hasOwnProperty,NR=Object.prototype.propertyIsEnumerable,ld=(t,e,s)=>e in t?_R(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ti=(t,e)=>{for(var s in e||(e={}))IR.call(e,s)&&ld(t,s,e[s]);if(Ap)for(var s of Ap(e))NR.call(e,s)&&ld(t,s,e[s]);return t},nl=(t,e)=>AR(t,SR(e)),We=(t,e,s)=>ld(t,typeof e!="symbol"?e+"":e,s);class TR extends FC{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,We(this,"subscriptions",new Map),We(this,"topicMap",new CR),We(this,"events",new xr.EventEmitter),We(this,"name",p1),We(this,"version",f1),We(this,"pending",new Map),We(this,"cached",[]),We(this,"initialized",!1),We(this,"storagePrefix",tn),We(this,"subscribeTimeout",Z.toMiliseconds(Z.ONE_MINUTE)),We(this,"initialSubscribeTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),We(this,"clientId"),We(this,"batchSubscribeTopicsLimit",500),We(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),We(this,"subscribe",async(n,r)=>{var i;this.isInitialized(),this.logger.debug("Subscribing Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:n,opts:r}});try{const o=Ya(r),a={topic:n,relay:o,transportType:r==null?void 0:r.transportType};(i=r==null?void 0:r.internal)!=null&&i.skipSubscribe||this.pending.set(n,a);const c=await this.rpcSubscribe(n,o,r);return typeof c=="string"&&(this.onSubscribe(c,a),this.logger.debug("Successfully Subscribed Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:n,opts:r}})),c}catch(o){throw this.logger.debug("Failed to Subscribe Topic"),this.logger.error(o),o}}),We(this,"unsubscribe",async(n,r)=>{this.isInitialized(),typeof(r==null?void 0:r.id)<"u"?await this.unsubscribeById(n,r.id,r):await this.unsubscribeByTopic(n,r)}),We(this,"isSubscribed",n=>new Promise(r=>{r(this.topicMap.topics.includes(n))})),We(this,"isKnownTopic",n=>new Promise(r=>{r(this.topicMap.topics.includes(n)||this.pending.has(n)||this.cached.some(i=>i.topic===n))})),We(this,"on",(n,r)=>{this.events.on(n,r)}),We(this,"once",(n,r)=>{this.events.once(n,r)}),We(this,"off",(n,r)=>{this.events.off(n,r)}),We(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),We(this,"start",async()=>{await this.onConnect()}),We(this,"stop",async()=>{await this.onDisconnect()}),We(this,"restart",async()=>{await this.restore(),await this.onRestart()}),We(this,"checkPending",async()=>{if(this.pending.size===0&&(!this.initialized||!this.relayer.connected))return;const n=[];this.pending.forEach(r=>{n.push(r)}),await this.batchSubscribe(n)}),We(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(gi.pulse,async()=>{await this.checkPending()}),this.events.on(is.created,async n=>{const r=is.created;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()}),this.events.on(is.deleted,async n=>{const r=is.deleted;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()})}),this.relayer=e,this.logger=ts(s,this.name),this.clientId=""}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.relayer.core.customStoragePrefix+"//"+this.name}get length(){return this.subscriptions.size}get ids(){return Array.from(this.subscriptions.keys())}get values(){return Array.from(this.subscriptions.values())}get topics(){return this.topicMap.topics}get hasAnyTopics(){return this.topicMap.topics.length>0||this.pending.size>0||this.cached.length>0||this.subscriptions.size>0}hasSubscription(e,s){let n=!1;try{n=this.getSubscription(e).topic===s}catch{}return n}reset(){this.cached=[],this.initialized=!0}onDisable(){this.values.length>0&&(this.cached=this.values),this.subscriptions.clear(),this.topicMap.clear()}async unsubscribeByTopic(e,s){const n=this.topicMap.get(e);await Promise.all(n.map(async r=>await this.unsubscribeById(e,r,s)))}async unsubscribeById(e,s,n){this.logger.debug("Unsubscribing Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:s,opts:n}});try{const r=Ya(n);await this.restartToComplete({topic:e,id:s,relay:r}),await this.rpcUnsubscribe(e,s,r);const i=Ze("USER_DISCONNECTED",`${this.name}, ${e}`);await this.onUnsubscribe(e,s,i),this.logger.debug("Successfully Unsubscribed Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:s,opts:n}})}catch(r){throw this.logger.debug("Failed to Unsubscribe Topic"),this.logger.error(r),r}}async rpcSubscribe(e,s,n){var r,i;const o=await this.getSubscriptionId(e);if((r=n==null?void 0:n.internal)!=null&&r.skipSubscribe)return o;(!n||(n==null?void 0:n.transportType)===Ke.relay)&&await this.restartToComplete({topic:e,id:e,relay:s});const a={method:Jr(s.protocol).subscribe,params:{topic:e}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:a});const c=(i=n==null?void 0:n.internal)==null?void 0:i.throwOnFailedPublish;try{if((n==null?void 0:n.transportType)===Ke.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(a).catch(u=>this.logger.warn(u))},Z.toMiliseconds(Z.ONE_SECOND)),o;const l=new Promise(async u=>{const h=p=>{p.topic===e&&(this.events.removeListener(is.created,h),u(p.id))};this.events.on(is.created,h);try{const p=await Gs(new Promise((g,f)=>{this.relayer.request(a).catch(y=>{this.logger.warn(y,y==null?void 0:y.message),f(y)}).then(g)}),this.initialSubscribeTimeout,`Subscribing to ${e} failed, please try again`);this.events.removeListener(is.created,h),u(p)}catch{}}),d=await Gs(l,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!d&&c)throw new Error(`Subscribing to ${e} failed, please try again`);return d?o:null}catch(l){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(it.connection_stalled),c)throw l}return null}async rpcBatchSubscribe(e){if(!e.length)return;const s=e[0].relay,n={method:Jr(s.protocol).batchSubscribe,params:{topics:e.map(r=>r.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:n});try{await await Gs(new Promise(r=>{this.relayer.request(n).catch(i=>this.logger.warn(i)).then(r)}),this.subscribeTimeout,"rpcBatchSubscribe failed, please try again")}catch{this.relayer.events.emit(it.connection_stalled)}}async rpcBatchFetchMessages(e){if(!e.length)return;const s=e[0].relay,n={method:Jr(s.protocol).batchFetchMessages,params:{topics:e.map(i=>i.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:n});let r;try{r=await await Gs(new Promise((i,o)=>{this.relayer.request(n).catch(a=>{this.logger.warn(a),o(a)}).then(i)}),this.subscribeTimeout,"rpcBatchFetchMessages failed, please try again")}catch{this.relayer.events.emit(it.connection_stalled)}return r}rpcUnsubscribe(e,s,n){const r={method:Jr(n.protocol).unsubscribe,params:{topic:e,id:s}};return this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:r}),this.relayer.request(r)}onSubscribe(e,s){this.setSubscription(e,nl(Ti({},s),{id:e})),this.pending.delete(s.topic)}onBatchSubscribe(e){e.length&&e.forEach(s=>{this.setSubscription(s.id,Ti({},s)),this.pending.delete(s.topic)})}async onUnsubscribe(e,s,n){this.events.removeAllListeners(s),this.hasSubscription(s,e)&&this.deleteSubscription(s,n),await this.relayer.messages.del(e)}async setRelayerSubscriptions(e){await this.relayer.core.storage.setItem(this.storageKey,e)}async getRelayerSubscriptions(){return await this.relayer.core.storage.getItem(this.storageKey)}setSubscription(e,s){this.logger.debug("Setting subscription"),this.logger.trace({type:"method",method:"setSubscription",id:e,subscription:s}),this.addSubscription(e,s)}addSubscription(e,s){this.subscriptions.set(e,Ti({},s)),this.topicMap.set(s.topic,e),this.events.emit(is.created,s)}getSubscription(e){this.logger.debug("Getting subscription"),this.logger.trace({type:"method",method:"getSubscription",id:e});const s=this.subscriptions.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}deleteSubscription(e,s){this.logger.debug("Deleting subscription"),this.logger.trace({type:"method",method:"deleteSubscription",id:e,reason:s});const n=this.getSubscription(e);this.subscriptions.delete(e),this.topicMap.delete(n.topic,e),this.events.emit(is.deleted,nl(Ti({},n),{reason:s}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(is.sync)}async onRestart(){if(this.cached.length){const e=[...this.cached],s=Math.ceil(this.cached.length/this.batchSubscribeTopicsLimit);for(let n=0;n<s;n++){const r=e.splice(0,this.batchSubscribeTopicsLimit);await this.batchSubscribe(r)}}this.events.emit(is.resubscribed)}async restore(){try{const e=await this.getRelayerSubscriptions();if(typeof e>"u"||!e.length)return;if(this.subscriptions.size&&!e.every(s=>{var n;return s.topic===((n=this.subscriptions.get(s.id))==null?void 0:n.topic)})){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),this.logger.error(`${this.name}: ${JSON.stringify(this.values)}`),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored subscriptions for ${this.name}`),this.logger.trace({type:"method",method:"restore",subscriptions:this.values})}catch(e){this.logger.debug(`Failed to Restore subscriptions for ${this.name}`),this.logger.error(e)}}async batchSubscribe(e){e.length&&(await this.rpcBatchSubscribe(e),this.onBatchSubscribe(await Promise.all(e.map(async s=>nl(Ti({},s),{id:await this.getSubscriptionId(s.topic)})))))}async batchFetchMessages(e){if(!e.length)return;this.logger.trace(`Fetching batch messages for ${e.length} subscriptions`);const s=await this.rpcBatchFetchMessages(e);s&&s.messages&&(await X0(Z.toMiliseconds(Z.ONE_SECOND)),await this.relayer.handleBatchMessageEvents(s.messages))}async onConnect(){await this.restart(),this.reset()}onDisconnect(){this.onDisable()}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async restartToComplete(e){!this.relayer.connected&&!this.relayer.connecting&&(this.cached.push(e),await this.relayer.transportOpen())}async getClientId(){return this.clientId||(this.clientId=await this.relayer.core.crypto.getClientId()),this.clientId}async getSubscriptionId(e){return Es(e+await this.getClientId())}}var RR=Object.defineProperty,Sp=Object.getOwnPropertySymbols,OR=Object.prototype.hasOwnProperty,PR=Object.prototype.propertyIsEnumerable,dd=(t,e,s)=>e in t?RR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ip=(t,e)=>{for(var s in e||(e={}))OR.call(e,s)&&dd(t,s,e[s]);if(Sp)for(var s of Sp(e))PR.call(e,s)&&dd(t,s,e[s]);return t},De=(t,e,s)=>dd(t,typeof e!="symbol"?e+"":e,s);class xR extends BC{constructor(e){var s;super(e),De(this,"protocol","wc"),De(this,"version",2),De(this,"core"),De(this,"logger"),De(this,"events",new xr.EventEmitter),De(this,"provider"),De(this,"messages"),De(this,"subscriber"),De(this,"publisher"),De(this,"name",c1),De(this,"transportExplicitlyClosed",!1),De(this,"initialized",!1),De(this,"connectionAttemptInProgress",!1),De(this,"relayUrl"),De(this,"projectId"),De(this,"packageName"),De(this,"bundleId"),De(this,"hasExperiencedNetworkDisruption",!1),De(this,"pingTimeout"),De(this,"heartBeatTimeout",Z.toMiliseconds(Z.THIRTY_SECONDS+Z.FIVE_SECONDS)),De(this,"reconnectTimeout"),De(this,"connectPromise"),De(this,"reconnectInProgress",!1),De(this,"requestsInFlight",[]),De(this,"connectTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),De(this,"request",async n=>{var r,i;this.logger.debug("Publishing Request Payload");const o=n.id||fr().toString();await this.toEstablishConnection();try{this.logger.trace({id:o,method:n.method,topic:(r=n.params)==null?void 0:r.topic},"relayer.request - publishing...");const a=`${o}:${((i=n.params)==null?void 0:i.tag)||""}`;this.requestsInFlight.push(a);const c=await this.provider.request(n);return this.requestsInFlight=this.requestsInFlight.filter(l=>l!==a),c}catch(a){throw this.logger.debug(`Failed to Publish Request: ${o}`),a}}),De(this,"resetPingTimeout",()=>{Wa()&&(clearTimeout(this.pingTimeout),this.pingTimeout=setTimeout(()=>{var n,r,i,o;try{this.logger.debug({},"pingTimeout: Connection stalled, terminating..."),(o=(i=(r=(n=this.provider)==null?void 0:n.connection)==null?void 0:r.socket)==null?void 0:i.terminate)==null||o.call(i)}catch(a){this.logger.warn(a,a==null?void 0:a.message)}},this.heartBeatTimeout))}),De(this,"onPayloadHandler",n=>{this.onProviderPayload(n),this.resetPingTimeout()}),De(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected 🛜"),this.startPingTimeout(),this.events.emit(it.connect)}),De(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected 🛑"),this.requestsInFlight=[],this.onProviderDisconnect()}),De(this,"onProviderErrorHandler",n=>{this.logger.fatal(`Fatal socket error: ${n.message}`),this.events.emit(it.error,n),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),De(this,"registerProviderListeners",()=>{this.provider.on(ps.payload,this.onPayloadHandler),this.provider.on(ps.connect,this.onConnectHandler),this.provider.on(ps.disconnect,this.onDisconnectHandler),this.provider.on(ps.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger=Gd({logger:(s=e.logger)!=null?s:a1,name:this.name}),this.messages=new pR(this.logger,e.core),this.subscriber=new TR(this,this.logger),this.publisher=new ER(this,this.logger),this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||$m,D0()?this.packageName=bh():L0()&&(this.bundleId=bh()),this.provider={}}async init(){this.logger.trace("Initialized"),this.registerEventListeners(),await Promise.all([this.messages.init(),this.subscriber.init()]),this.initialized=!0,this.transportOpen().catch(e=>this.logger.warn(e,e==null?void 0:e.message))}get context(){return es(this.logger)}get connected(){var e,s,n;return((n=(s=(e=this.provider)==null?void 0:e.connection)==null?void 0:s.socket)==null?void 0:n.readyState)===1||!1}get connecting(){var e,s,n;return((n=(s=(e=this.provider)==null?void 0:e.connection)==null?void 0:s.socket)==null?void 0:n.readyState)===0||this.connectPromise!==void 0||!1}async publish(e,s,n){this.isInitialized(),await this.publisher.publish(e,s,n),await this.recordMessageEvent({topic:e,message:s,publishedAt:Date.now(),transportType:Ke.relay},wa.outbound)}async publishCustom(e){this.isInitialized(),await this.publisher.publishCustom(e)}async subscribe(e,s){var n,r,i;this.isInitialized(),(!(s!=null&&s.transportType)||(s==null?void 0:s.transportType)==="relay")&&await this.toEstablishConnection();const o=typeof((n=s==null?void 0:s.internal)==null?void 0:n.throwOnFailedPublish)>"u"?!0:(r=s==null?void 0:s.internal)==null?void 0:r.throwOnFailedPublish;let a=((i=this.subscriber.topicMap.get(e))==null?void 0:i[0])||"",c;const l=d=>{d.topic===e&&(this.subscriber.off(is.created,l),c())};return await Promise.all([new Promise(d=>{c=d,this.subscriber.on(is.created,l)}),new Promise(async(d,u)=>{a=await this.subscriber.subscribe(e,Ip({internal:{throwOnFailedPublish:o}},s)).catch(h=>{o&&u(h)})||a,d()})]),a}async unsubscribe(e,s){this.isInitialized(),await this.subscriber.unsubscribe(e,s)}on(e,s){this.events.on(e,s)}once(e,s){this.events.once(e,s)}off(e,s){this.events.off(e,s)}removeListener(e,s){this.events.removeListener(e,s)}async transportDisconnect(){this.provider.disconnect&&(this.hasExperiencedNetworkDisruption||this.connected)?await Gs(this.provider.disconnect(),2e3,"provider.disconnect()").catch(()=>this.onProviderDisconnect()):this.onProviderDisconnect()}async transportClose(){this.transportExplicitlyClosed=!0,await this.transportDisconnect()}async transportOpen(e){if(!this.subscriber.hasAnyTopics){this.logger.info("Starting WS connection skipped because the client has no topics to work with.");return}if(this.connectPromise?(this.logger.debug({},"Waiting for existing connection attempt to resolve..."),await this.connectPromise,this.logger.debug({},"Existing connection attempt resolved")):(this.connectPromise=new Promise(async(s,n)=>{await this.connect(e).then(s).catch(n).finally(()=>{this.connectPromise=void 0})}),await this.connectPromise),!this.connected)throw new Error(`Couldn't establish socket connection to the relay server: ${this.relayUrl}`)}async restartTransport(e){this.logger.debug({},"Restarting transport..."),!this.connectionAttemptInProgress&&(this.relayUrl=e||this.relayUrl,await this.confirmOnlineStateOrThrow(),await this.transportClose(),await this.transportOpen())}async confirmOnlineStateOrThrow(){if(!await hp())throw new Error("No internet connection detected. Please restart your network and try again.")}async handleBatchMessageEvents(e){if((e==null?void 0:e.length)===0){this.logger.trace("Batch message events is empty. Ignoring...");return}const s=e.sort((n,r)=>n.publishedAt-r.publishedAt);this.logger.debug(`Batch of ${s.length} message events sorted`);for(const n of s)try{await this.onMessageEvent(n)}catch(r){this.logger.warn(r,"Error while processing batch message event: "+(r==null?void 0:r.message))}this.logger.trace(`Batch of ${s.length} message events processed`)}async onLinkMessageEvent(e,s){const{topic:n}=e;if(!s.sessionExists){const r=rt(Z.FIVE_MINUTES),i={topic:n,expiry:r,relay:{protocol:"irn"},active:!1};await this.core.pairing.pairings.set(n,i)}this.events.emit(it.message,e),await this.recordMessageEvent(e,wa.inbound)}async connect(e){await this.confirmOnlineStateOrThrow(),e&&e!==this.relayUrl&&(this.relayUrl=e,await this.transportDisconnect()),this.connectionAttemptInProgress=!0,this.transportExplicitlyClosed=!1;let s=1;for(;s<6;){try{if(this.transportExplicitlyClosed)break;this.logger.debug({},`Connecting to ${this.relayUrl}, attempt: ${s}...`),await this.createProvider(),await new Promise(async(n,r)=>{const i=()=>{r(new Error("Connection interrupted while trying to connect"))};this.provider.once(ps.disconnect,i),await Gs(new Promise((o,a)=>{this.provider.connect().then(o).catch(a)}),this.connectTimeout,`Socket stalled when trying to connect to ${this.relayUrl}`).catch(o=>{r(o)}).finally(()=>{this.provider.off(ps.disconnect,i),clearTimeout(this.reconnectTimeout)}),await new Promise(async(o,a)=>{const c=()=>{r(new Error("Connection interrupted while trying to subscribe"))};this.provider.once(ps.disconnect,c),await this.subscriber.start().then(o).catch(a).finally(()=>{this.provider.off(ps.disconnect,c)})}),this.hasExperiencedNetworkDisruption=!1,n()})}catch(n){await this.subscriber.stop();const r=n;this.logger.warn({},r.message),this.hasExperiencedNetworkDisruption=!0}finally{this.connectionAttemptInProgress=!1}if(this.connected){this.logger.debug({},`Connected to ${this.relayUrl} successfully on attempt: ${s}`);break}await new Promise(n=>setTimeout(n,Z.toMiliseconds(s*1))),s++}}startPingTimeout(){var e,s,n,r,i;if(Wa())try{(s=(e=this.provider)==null?void 0:e.connection)!=null&&s.socket&&((i=(r=(n=this.provider)==null?void 0:n.connection)==null?void 0:r.socket)==null||i.on("ping",()=>{this.resetPingTimeout()})),this.resetPingTimeout()}catch(o){this.logger.warn(o,o==null?void 0:o.message)}}async createProvider(){this.provider.connection&&this.unregisterProviderListeners();const e=await this.core.crypto.signJWT(this.relayUrl);this.provider=new Cd(new $y(q0({sdkVersion:rd,protocol:this.protocol,version:this.version,relayUrl:this.relayUrl,projectId:this.projectId,auth:e,useOnCloseEvent:!0,bundleId:this.bundleId,packageName:this.packageName}))),this.registerProviderListeners()}async recordMessageEvent(e,s){const{topic:n,message:r}=e;await this.messages.set(n,r,s)}async shouldIgnoreMessageEvent(e){const{topic:s,message:n}=e;if(!n||n.length===0)return this.logger.warn(`Ignoring invalid/empty message: ${n}`),!0;if(!await this.subscriber.isKnownTopic(s))return this.logger.warn(`Ignoring message for unknown topic ${s}`),!0;const r=this.messages.has(s,n);return r&&this.logger.warn(`Ignoring duplicate message: ${n}`),r}async onProviderPayload(e){if(this.logger.debug("Incoming Relay Payload"),this.logger.trace({type:"payload",direction:"incoming",payload:e}),_d(e)){if(!e.method.endsWith(l1))return;const s=e.params,{topic:n,message:r,publishedAt:i,attestation:o}=s.data,a={topic:n,message:r,publishedAt:i,transportType:Ke.relay,attestation:o};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(Ip({type:"event",event:s.id},a)),this.events.emit(s.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else Ad(e)&&this.events.emit(it.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,wa.inbound),this.events.emit(it.message,e))}async acknowledgePayload(e){const s=Yi(e.id,!0);await this.provider.connection.send(s)}unregisterProviderListeners(){this.provider.off(ps.payload,this.onPayloadHandler),this.provider.off(ps.connect,this.onConnectHandler),this.provider.off(ps.disconnect,this.onDisconnectHandler),this.provider.off(ps.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await hp();MN(async s=>{e!==s&&(e=s,s?await this.transportOpen().catch(n=>this.logger.error(n,n==null?void 0:n.message)):(this.hasExperiencedNetworkDisruption=!0,await this.transportDisconnect(),this.transportExplicitlyClosed=!1))}),this.core.heartbeat.on(gi.pulse,async()=>{if(!this.transportExplicitlyClosed&&!this.connected&&FN())try{await this.confirmOnlineStateOrThrow(),await this.transportOpen()}catch(s){this.logger.warn(s,s==null?void 0:s.message)}})}async onProviderDisconnect(){clearTimeout(this.pingTimeout),this.events.emit(it.disconnect),this.connectionAttemptInProgress=!1,!this.reconnectInProgress&&(this.reconnectInProgress=!0,await this.subscriber.stop(),this.subscriber.hasAnyTopics&&(this.transportExplicitlyClosed||(this.reconnectTimeout=setTimeout(async()=>{await this.transportOpen().catch(e=>this.logger.error(e,e==null?void 0:e.message)),this.reconnectTimeout=void 0,this.reconnectInProgress=!1},Z.toMiliseconds(d1)))))}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async toEstablishConnection(){if(await this.confirmOnlineStateOrThrow(),!this.connected){if(this.connectPromise){await this.connectPromise;return}await this.connect()}}}function kR(t,e){return t===e||Number.isNaN(t)&&Number.isNaN(e)}function Np(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function Tp(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const UR="[object RegExp]",$R="[object String]",DR="[object Number]",LR="[object Boolean]",Rp="[object Arguments]",MR="[object Symbol]",BR="[object Date]",jR="[object Map]",FR="[object Set]",qR="[object Array]",WR="[object Function]",HR="[object ArrayBuffer]",rl="[object Object]",zR="[object Error]",VR="[object DataView]",KR="[object Uint8Array]",GR="[object Uint8ClampedArray]",YR="[object Uint16Array]",ZR="[object Uint32Array]",JR="[object BigUint64Array]",XR="[object Int8Array]",QR="[object Int16Array]",eO="[object Int32Array]",tO="[object BigInt64Array]",sO="[object Float32Array]",nO="[object Float64Array]";function rO(){}function Op(t){if(!t||typeof t!="object")return!1;const e=Object.getPrototypeOf(t);return e===null||e===Object.prototype||Object.getPrototypeOf(e)===null?Object.prototype.toString.call(t)==="[object Object]":!1}function iO(t,e,s){return Di(t,e,void 0,void 0,void 0,void 0,s)}function Di(t,e,s,n,r,i,o){const a=o(t,e,s,n,r,i);if(a!==void 0)return a;if(typeof t==typeof e)switch(typeof t){case"bigint":case"string":case"boolean":case"symbol":case"undefined":return t===e;case"number":return t===e||Object.is(t,e);case"function":return t===e;case"object":return Wi(t,e,i,o)}return Wi(t,e,i,o)}function Wi(t,e,s,n){if(Object.is(t,e))return!0;let r=Tp(t),i=Tp(e);if(r===Rp&&(r=rl),i===Rp&&(i=rl),r!==i)return!1;switch(r){case $R:return t.toString()===e.toString();case DR:{const c=t.valueOf(),l=e.valueOf();return kR(c,l)}case LR:case BR:case MR:return Object.is(t.valueOf(),e.valueOf());case UR:return t.source===e.source&&t.flags===e.flags;case WR:return t===e}s=s??new Map;const o=s.get(t),a=s.get(e);if(o!=null&&a!=null)return o===e;s.set(t,e),s.set(e,t);try{switch(r){case jR:{if(t.size!==e.size)return!1;for(const[c,l]of t.entries())if(!e.has(c)||!Di(l,e.get(c),c,t,e,s,n))return!1;return!0}case FR:{if(t.size!==e.size)return!1;const c=Array.from(t.values()),l=Array.from(e.values());for(let d=0;d<c.length;d++){const u=c[d],h=l.findIndex(p=>Di(u,p,void 0,t,e,s,n));if(h===-1)return!1;l.splice(h,1)}return!0}case qR:case KR:case GR:case YR:case ZR:case JR:case XR:case QR:case eO:case tO:case sO:case nO:{if(typeof Ue<"u"&&Ue.isBuffer(t)!==Ue.isBuffer(e)||t.length!==e.length)return!1;for(let c=0;c<t.length;c++)if(!Di(t[c],e[c],c,t,e,s,n))return!1;return!0}case HR:return t.byteLength!==e.byteLength?!1:Wi(new Uint8Array(t),new Uint8Array(e),s,n);case VR:return t.byteLength!==e.byteLength||t.byteOffset!==e.byteOffset?!1:Wi(new Uint8Array(t),new Uint8Array(e),s,n);case zR:return t.name===e.name&&t.message===e.message;case rl:{if(!(Wi(t.constructor,e.constructor,s,n)||Op(t)&&Op(e)))return!1;const c=[...Object.keys(t),...Np(t)],l=[...Object.keys(e),...Np(e)];if(c.length!==l.length)return!1;for(let d=0;d<c.length;d++){const u=c[d],h=t[u];if(!Object.hasOwn(e,u))return!1;const p=e[u];if(!Di(h,p,u,t,e,s,n))return!1}return!0}default:return!1}}finally{s.delete(t),s.delete(e)}}function oO(t,e){return iO(t,e,rO)}var aO=Object.defineProperty,Pp=Object.getOwnPropertySymbols,cO=Object.prototype.hasOwnProperty,lO=Object.prototype.propertyIsEnumerable,ud=(t,e,s)=>e in t?aO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,xp=(t,e)=>{for(var s in e||(e={}))cO.call(e,s)&&ud(t,s,e[s]);if(Pp)for(var s of Pp(e))lO.call(e,s)&&ud(t,s,e[s]);return t},Ht=(t,e,s)=>ud(t,typeof e!="symbol"?e+"":e,s);class Lr extends jC{constructor(e,s,n,r=tn,i=void 0){super(e,s,n,r),this.core=e,this.logger=s,this.name=n,Ht(this,"map",new Map),Ht(this,"version",u1),Ht(this,"cached",[]),Ht(this,"initialized",!1),Ht(this,"getKey"),Ht(this,"storagePrefix",tn),Ht(this,"recentlyDeleted",[]),Ht(this,"recentlyDeletedLimit",200),Ht(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(o=>{this.getKey&&o!==null&&!mt(o)?this.map.set(this.getKey(o),o):gN(o)?this.map.set(o.id,o):mN(o)&&this.map.set(o.topic,o)}),this.cached=[],this.initialized=!0)}),Ht(this,"set",async(o,a)=>{this.isInitialized(),this.map.has(o)?await this.update(o,a):(this.logger.debug("Setting value"),this.logger.trace({type:"method",method:"set",key:o,value:a}),this.map.set(o,a),await this.persist())}),Ht(this,"get",o=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:o}),this.getData(o))),Ht(this,"getAll",o=>(this.isInitialized(),o?this.values.filter(a=>Object.keys(o).every(c=>oO(a[c],o[c]))):this.values)),Ht(this,"update",async(o,a)=>{this.isInitialized(),this.logger.debug("Updating value"),this.logger.trace({type:"method",method:"update",key:o,update:a});const c=xp(xp({},this.getData(o)),a);this.map.set(o,c),await this.persist()}),Ht(this,"delete",async(o,a)=>{this.isInitialized(),this.map.has(o)&&(this.logger.debug("Deleting value"),this.logger.trace({type:"method",method:"delete",key:o,reason:a}),this.map.delete(o),this.addToRecentlyDeleted(o),await this.persist())}),this.logger=ts(s,this.name),this.storagePrefix=r,this.getKey=i}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.map.size}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}addToRecentlyDeleted(e){this.recentlyDeleted.push(e),this.recentlyDeleted.length>=this.recentlyDeletedLimit&&this.recentlyDeleted.splice(0,this.recentlyDeletedLimit/2)}async setDataStore(e){await this.core.storage.setItem(this.storageKey,e)}async getDataStore(){return await this.core.storage.getItem(this.storageKey)}getData(e){const s=this.map.get(e);if(!s){if(this.recentlyDeleted.includes(e)){const{message:r}=Y("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(r),new Error(r)}const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.error(n),new Error(n)}return s}async persist(){await this.setDataStore(this.values)}async restore(){try{const e=await this.getDataStore();if(typeof e>"u"||!e.length)return;if(this.map.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored value for ${this.name}`),this.logger.trace({type:"method",method:"restore",value:this.values})}catch(e){this.logger.debug(`Failed to Restore value for ${this.name}`),this.logger.error(e)}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var dO=Object.defineProperty,uO=(t,e,s)=>e in t?dO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Te=(t,e,s)=>uO(t,typeof e!="symbol"?e+"":e,s);class hO{constructor(e,s){this.core=e,this.logger=s,Te(this,"name",g1),Te(this,"version",m1),Te(this,"events",new Sd),Te(this,"pairings"),Te(this,"initialized",!1),Te(this,"storagePrefix",tn),Te(this,"ignoredPayloadTypes",[Cn]),Te(this,"registeredMethods",[]),Te(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),Te(this,"register",({methods:n})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...n])]}),Te(this,"create",async n=>{this.isInitialized();const r=td(),i=await this.core.crypto.setSymKey(r),o=rt(Z.FIVE_MINUTES),a={protocol:Um},c={topic:i,expiry:o,relay:a,active:!1,methods:n==null?void 0:n.methods},l=np({protocol:this.core.protocol,version:this.core.version,topic:i,symKey:r,relay:a,expiryTimestamp:o,methods:n==null?void 0:n.methods});return this.events.emit(ur.create,c),this.core.expirer.set(i,o),await this.pairings.set(i,c),await this.core.relayer.subscribe(i,{transportType:n==null?void 0:n.transportType,internal:n==null?void 0:n.internal}),{topic:i,uri:l}}),Te(this,"pair",async n=>{this.isInitialized();const r=this.core.eventClient.createEvent({properties:{topic:n==null?void 0:n.uri,trace:[Ws.pairing_started]}});this.isValidPair(n,r);const{topic:i,symKey:o,relay:a,expiryTimestamp:c,methods:l}=sp(n.uri);r.props.properties.topic=i,r.addTrace(Ws.pairing_uri_validation_success),r.addTrace(Ws.pairing_uri_not_expired);let d;if(this.pairings.keys.includes(i)){if(d=this.pairings.get(i),r.addTrace(Ws.existing_pairing),d.active)throw r.setError(dn.active_pairing_already_exists),new Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(Ws.pairing_not_expired)}const u=c||rt(Z.FIVE_MINUTES),h={topic:i,relay:a,expiry:u,active:!1,methods:l};this.core.expirer.set(i,u),await this.pairings.set(i,h),r.addTrace(Ws.store_new_pairing),n.activatePairing&&await this.activate({topic:i}),this.events.emit(ur.create,h),r.addTrace(Ws.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(o,i),r.addTrace(Ws.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(dn.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:a})}catch(p){throw r.setError(dn.subscribe_pairing_topic_failure),p}return r.addTrace(Ws.subscribe_pairing_topic_success),h}),Te(this,"activate",async({topic:n})=>{this.isInitialized();const r=rt(Z.FIVE_MINUTES);this.core.expirer.set(n,r),await this.pairings.update(n,{active:!0,expiry:r})}),Te(this,"ping",async n=>{this.isInitialized(),await this.isValidPing(n),this.logger.warn("ping() is deprecated and will be removed in the next major release.");const{topic:r}=n;if(this.pairings.keys.includes(r)){const i=await this.sendRequest(r,"wc_pairingPing",{}),{done:o,resolve:a,reject:c}=dr();this.events.once(Fe("pairing_ping",i),({error:l})=>{l?c(l):a()}),await o()}}),Te(this,"updateExpiry",async({topic:n,expiry:r})=>{this.isInitialized(),await this.pairings.update(n,{expiry:r})}),Te(this,"updateMetadata",async({topic:n,metadata:r})=>{this.isInitialized(),await this.pairings.update(n,{peerMetadata:r})}),Te(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),Te(this,"disconnect",async n=>{this.isInitialized(),await this.isValidDisconnect(n);const{topic:r}=n;this.pairings.keys.includes(r)&&(await this.sendRequest(r,"wc_pairingDelete",Ze("USER_DISCONNECTED")),await this.deletePairing(r))}),Te(this,"formatUriFromPairing",n=>{this.isInitialized();const{topic:r,relay:i,expiry:o,methods:a}=n,c=this.core.crypto.keychain.get(r);return np({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:c,relay:i,expiryTimestamp:o,methods:a})}),Te(this,"sendRequest",async(n,r,i)=>{const o=zs(r,i),a=await this.core.crypto.encode(n,o),c=Ii[r].req;return this.core.history.set(n,o),this.core.relayer.publish(n,a,c),o.id}),Te(this,"sendResult",async(n,r,i)=>{const o=Yi(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Ii[c].res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),Te(this,"sendError",async(n,r,i)=>{const o=Cf(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Ii[c]?Ii[c].res:Ii.unregistered_method.res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),Te(this,"deletePairing",async(n,r)=>{await this.core.relayer.unsubscribe(n),await Promise.all([this.pairings.delete(n,Ze("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(n),r?Promise.resolve():this.core.expirer.del(n)])}),Te(this,"cleanup",async()=>{const n=this.pairings.getAll().filter(r=>Vs(r.expiry));await Promise.all(n.map(r=>this.deletePairing(r.topic)))}),Te(this,"onRelayEventRequest",async n=>{const{topic:r,payload:i}=n;switch(i.method){case"wc_pairingPing":return await this.onPairingPingRequest(r,i);case"wc_pairingDelete":return await this.onPairingDeleteRequest(r,i);default:return await this.onUnknownRpcMethodRequest(r,i)}}),Te(this,"onRelayEventResponse",async n=>{const{topic:r,payload:i}=n,o=(await this.core.history.get(r,i.id)).request.method;switch(o){case"wc_pairingPing":return this.onPairingPingResponse(r,i);default:return this.onUnknownRpcMethodResponse(o)}}),Te(this,"onPairingPingRequest",async(n,r)=>{const{id:i}=r;try{this.isValidPing({topic:n}),await this.sendResult(i,n,!0),this.events.emit(ur.ping,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),Te(this,"onPairingPingResponse",(n,r)=>{const{id:i}=r;setTimeout(()=>{cn(r)?this.events.emit(Fe("pairing_ping",i),{}):Hs(r)&&this.events.emit(Fe("pairing_ping",i),{error:r.error})},500)}),Te(this,"onPairingDeleteRequest",async(n,r)=>{const{id:i}=r;try{this.isValidDisconnect({topic:n}),await this.deletePairing(n),this.events.emit(ur.delete,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),Te(this,"onUnknownRpcMethodRequest",async(n,r)=>{const{id:i,method:o}=r;try{if(this.registeredMethods.includes(o))return;const a=Ze("WC_METHOD_UNSUPPORTED",o);await this.sendError(i,n,a),this.logger.error(a)}catch(a){await this.sendError(i,n,a),this.logger.error(a)}}),Te(this,"onUnknownRpcMethodResponse",n=>{this.registeredMethods.includes(n)||this.logger.error(Ze("WC_METHOD_UNSUPPORTED",n))}),Te(this,"isValidPair",(n,r)=>{var i;if(!Vt(n)){const{message:a}=Y("MISSING_OR_INVALID",`pair() params: ${n}`);throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(!fN(n.uri)){const{message:a}=Y("MISSING_OR_INVALID",`pair() uri: ${n.uri}`);throw r.setError(dn.malformed_pairing_uri),new Error(a)}const o=sp(n==null?void 0:n.uri);if(!((i=o==null?void 0:o.relay)!=null&&i.protocol)){const{message:a}=Y("MISSING_OR_INVALID","pair() uri#relay-protocol");throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(!(o!=null&&o.symKey)){const{message:a}=Y("MISSING_OR_INVALID","pair() uri#symKey");throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(o!=null&&o.expiryTimestamp&&Z.toMiliseconds(o==null?void 0:o.expiryTimestamp)<Date.now()){r.setError(dn.pairing_expired);const{message:a}=Y("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw new Error(a)}}),Te(this,"isValidPing",async n=>{if(!Vt(n)){const{message:i}=Y("MISSING_OR_INVALID",`ping() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),Te(this,"isValidDisconnect",async n=>{if(!Vt(n)){const{message:i}=Y("MISSING_OR_INVALID",`disconnect() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),Te(this,"isValidPairingTopic",async n=>{if(!ot(n,!1)){const{message:r}=Y("MISSING_OR_INVALID",`pairing topic should be a string: ${n}`);throw new Error(r)}if(!this.pairings.keys.includes(n)){const{message:r}=Y("NO_MATCHING_KEY",`pairing topic doesn't exist: ${n}`);throw new Error(r)}if(Vs(this.pairings.get(n).expiry)){await this.deletePairing(n);const{message:r}=Y("EXPIRED",`pairing topic: ${n}`);throw new Error(r)}}),this.core=e,this.logger=ts(s,this.name),this.pairings=new Lr(this.core,this.logger,this.name,this.storagePrefix)}get context(){return es(this.logger)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}registerRelayerEvents(){this.core.relayer.on(it.message,async e=>{const{topic:s,message:n,transportType:r}=e;if(this.pairings.keys.includes(s)&&r!==Ke.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(n)))try{const i=await this.core.crypto.decode(s,n);_d(i)?(this.core.history.set(s,i),await this.onRelayEventRequest({topic:s,payload:i})):Ad(i)&&(await this.core.history.resolve(i),await this.onRelayEventResponse({topic:s,payload:i}),this.core.history.delete(s,i.id)),await this.core.relayer.messages.ack(s,n)}catch(i){this.logger.error(i)}})}registerExpirerEvents(){this.core.expirer.on(ys.expired,async e=>{const{topic:s}=Og(e.target);s&&this.pairings.keys.includes(s)&&(await this.deletePairing(s,!0),this.events.emit(ur.expire,{topic:s}))})}}var pO=Object.defineProperty,fO=(t,e,s)=>e in t?pO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,bt=(t,e,s)=>fO(t,typeof e!="symbol"?e+"":e,s);class gO extends DC{constructor(e,s){super(e,s),this.core=e,this.logger=s,bt(this,"records",new Map),bt(this,"events",new xr.EventEmitter),bt(this,"name",y1),bt(this,"version",w1),bt(this,"cached",[]),bt(this,"initialized",!1),bt(this,"storagePrefix",tn),bt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(n=>this.records.set(n.id,n)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),bt(this,"set",(n,r,i)=>{if(this.isInitialized(),this.logger.debug("Setting JSON-RPC request history record"),this.logger.trace({type:"method",method:"set",topic:n,request:r,chainId:i}),this.records.has(r.id))return;const o={id:r.id,topic:n,request:{method:r.method,params:r.params||null},chainId:i,expiry:rt(Z.THIRTY_DAYS)};this.records.set(o.id,o),this.persist(),this.events.emit(Ss.created,o)}),bt(this,"resolve",async n=>{if(this.isInitialized(),this.logger.debug("Updating JSON-RPC response history record"),this.logger.trace({type:"method",method:"update",response:n}),!this.records.has(n.id))return;const r=await this.getRecord(n.id);typeof r.response>"u"&&(r.response=Hs(n)?{error:n.error}:{result:n.result},this.records.set(r.id,r),this.persist(),this.events.emit(Ss.updated,r))}),bt(this,"get",async(n,r)=>(this.isInitialized(),this.logger.debug("Getting record"),this.logger.trace({type:"method",method:"get",topic:n,id:r}),await this.getRecord(r))),bt(this,"delete",(n,r)=>{this.isInitialized(),this.logger.debug("Deleting record"),this.logger.trace({type:"method",method:"delete",id:r}),this.values.forEach(i=>{if(i.topic===n){if(typeof r<"u"&&i.id!==r)return;this.records.delete(i.id),this.events.emit(Ss.deleted,i)}}),this.persist()}),bt(this,"exists",async(n,r)=>(this.isInitialized(),this.records.has(r)?(await this.getRecord(r)).topic===n:!1)),bt(this,"on",(n,r)=>{this.events.on(n,r)}),bt(this,"once",(n,r)=>{this.events.once(n,r)}),bt(this,"off",(n,r)=>{this.events.off(n,r)}),bt(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get size(){return this.records.size}get keys(){return Array.from(this.records.keys())}get values(){return Array.from(this.records.values())}get pending(){const e=[];return this.values.forEach(s=>{if(typeof s.response<"u")return;const n={topic:s.topic,request:zs(s.request.method,s.request.params,s.id),chainId:s.chainId};return e.push(n)}),e}async setJsonRpcRecords(e){await this.core.storage.setItem(this.storageKey,e)}async getJsonRpcRecords(){return await this.core.storage.getItem(this.storageKey)}getRecord(e){this.isInitialized();const s=this.records.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(Ss.sync)}async restore(){try{const e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",records:this.values})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}}registerEventListeners(){this.events.on(Ss.created,e=>{const s=Ss.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Ss.updated,e=>{const s=Ss.updated;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Ss.deleted,e=>{const s=Ss.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.core.heartbeat.on(gi.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(s=>{Z.toMiliseconds(s.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${s.id}`),this.records.delete(s.id),this.events.emit(Ss.deleted,s,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var mO=Object.defineProperty,yO=(t,e,s)=>e in t?mO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Rt=(t,e,s)=>yO(t,typeof e!="symbol"?e+"":e,s);class wO extends qC{constructor(e,s){super(e,s),this.core=e,this.logger=s,Rt(this,"expirations",new Map),Rt(this,"events",new xr.EventEmitter),Rt(this,"name",E1),Rt(this,"version",b1),Rt(this,"cached",[]),Rt(this,"initialized",!1),Rt(this,"storagePrefix",tn),Rt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(n=>this.expirations.set(n.target,n)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),Rt(this,"has",n=>{try{const r=this.formatTarget(n);return typeof this.getExpiration(r)<"u"}catch{return!1}}),Rt(this,"set",(n,r)=>{this.isInitialized();const i=this.formatTarget(n),o={target:i,expiry:r};this.expirations.set(i,o),this.checkExpiry(i,o),this.events.emit(ys.created,{target:i,expiration:o})}),Rt(this,"get",n=>{this.isInitialized();const r=this.formatTarget(n);return this.getExpiration(r)}),Rt(this,"del",n=>{if(this.isInitialized(),this.has(n)){const r=this.formatTarget(n),i=this.getExpiration(r);this.expirations.delete(r),this.events.emit(ys.deleted,{target:r,expiration:i})}}),Rt(this,"on",(n,r)=>{this.events.on(n,r)}),Rt(this,"once",(n,r)=>{this.events.once(n,r)}),Rt(this,"off",(n,r)=>{this.events.off(n,r)}),Rt(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.expirations.size}get keys(){return Array.from(this.expirations.keys())}get values(){return Array.from(this.expirations.values())}formatTarget(e){if(typeof e=="string")return W0(e);if(typeof e=="number")return H0(e);const{message:s}=Y("UNKNOWN_TYPE",`Target type: ${typeof e}`);throw new Error(s)}async setExpirations(e){await this.core.storage.setItem(this.storageKey,e)}async getExpirations(){return await this.core.storage.getItem(this.storageKey)}async persist(){await this.setExpirations(this.values),this.events.emit(ys.sync)}async restore(){try{const e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored expirations for ${this.name}`),this.logger.trace({type:"method",method:"restore",expirations:this.values})}catch(e){this.logger.debug(`Failed to Restore expirations for ${this.name}`),this.logger.error(e)}}getExpiration(e){const s=this.expirations.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(n),new Error(n)}return s}checkExpiry(e,s){const{expiry:n}=s;Z.toMiliseconds(n)-Date.now()<=0&&this.expire(e,s)}expire(e,s){this.expirations.delete(e),this.events.emit(ys.expired,{target:e,expiration:s})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,s)=>this.checkExpiry(s,e))}registerEventListeners(){this.core.heartbeat.on(gi.pulse,()=>this.checkExpirations()),this.events.on(ys.created,e=>{const s=ys.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(ys.expired,e=>{const s=ys.expired;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(ys.deleted,e=>{const s=ys.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()})}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var EO=Object.defineProperty,bO=(t,e,s)=>e in t?EO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,nt=(t,e,s)=>bO(t,typeof e!="symbol"?e+"":e,s);class vO extends WC{constructor(e,s,n){super(e,s,n),this.core=e,this.logger=s,this.store=n,nt(this,"name",v1),nt(this,"abortController"),nt(this,"isDevEnv"),nt(this,"verifyUrlV3",_1),nt(this,"storagePrefix",tn),nt(this,"version",km),nt(this,"publicKey"),nt(this,"fetchPromise"),nt(this,"init",async()=>{var r;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&Z.toMiliseconds((r=this.publicKey)==null?void 0:r.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),nt(this,"register",async r=>{if(!yi()||this.isDevEnv)return;const i=window.location.origin,{id:o,decryptedId:a}=r,c=`${this.verifyUrlV3}/attestation?projectId=${this.core.projectId}&origin=${i}&id=${o}&decryptedId=${a}`;try{const l=An.getDocument(),d=this.startAbortTimer(Z.ONE_SECOND*5),u=await new Promise((h,p)=>{const g=()=>{window.removeEventListener("message",y),l.body.removeChild(f),p("attestation aborted")};this.abortController.signal.addEventListener("abort",g);const f=l.createElement("iframe");f.src=c,f.style.display="none",f.addEventListener("error",g,{signal:this.abortController.signal});const y=_=>{if(_.data&&typeof _.data=="string")try{const S=JSON.parse(_.data);if(S.type==="verify_attestation"){if(El(S.attestation).payload.id!==o)return;clearInterval(d),l.body.removeChild(f),this.abortController.signal.removeEventListener("abort",g),window.removeEventListener("message",y),h(S.attestation===null?"":S.attestation)}}catch(S){this.logger.warn(S)}};l.body.appendChild(f),window.addEventListener("message",y,{signal:this.abortController.signal})});return this.logger.debug(u,"jwt attestation"),u}catch(l){this.logger.warn(l)}return""}),nt(this,"resolve",async r=>{if(this.isDevEnv)return"";const{attestationId:i,hash:o,encryptedId:a}=r;if(i===""){this.logger.debug("resolve: attestationId is empty, skipping");return}if(i){if(El(i).payload.id!==a)return;const l=await this.isValidJwtAttestation(i);if(l){if(!l.isVerified){this.logger.warn("resolve: jwt attestation: origin url not verified");return}return l}}if(!o)return;const c=this.getVerifyUrl(r==null?void 0:r.verifyUrl);return this.fetchAttestation(o,c)}),nt(this,"fetchAttestation",async(r,i)=>{this.logger.debug(`resolving attestation: ${r} from url: ${i}`);const o=this.startAbortTimer(Z.ONE_SECOND*5),a=await fetch(`${i}/attestation/${r}?v2Supported=true`,{signal:this.abortController.signal});return clearTimeout(o),a.status===200?await a.json():void 0}),nt(this,"getVerifyUrl",r=>{let i=r||qi;return A1.includes(i)||(this.logger.info(`verify url: ${i}, not included in trusted list, assigning default: ${qi}`),i=qi),i}),nt(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);const r=this.startAbortTimer(Z.FIVE_SECONDS),i=await fetch(`${this.verifyUrlV3}/public-key`,{signal:this.abortController.signal});return clearTimeout(r),await i.json()}catch(r){this.logger.warn(r)}}),nt(this,"persistPublicKey",async r=>{this.logger.debug(r,"persisting public key to local storage"),await this.store.setItem(this.storeKey,r),this.publicKey=r}),nt(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),nt(this,"isValidJwtAttestation",async r=>{const i=await this.getPublicKey();try{if(i)return this.validateAttestation(r,i)}catch(a){this.logger.error(a),this.logger.warn("error validating attestation")}const o=await this.fetchAndPersistPublicKey();try{if(o)return this.validateAttestation(r,o)}catch(a){this.logger.error(a),this.logger.warn("error validating attestation")}}),nt(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),nt(this,"fetchAndPersistPublicKey",async()=>{if(this.fetchPromise)return await this.fetchPromise,this.publicKey;this.fetchPromise=new Promise(async i=>{const o=await this.fetchPublicKey();o&&(await this.persistPublicKey(o),i(o))});const r=await this.fetchPromise;return this.fetchPromise=void 0,r}),nt(this,"validateAttestation",(r,i)=>{const o=jI(r,i.publicKey),a={hasExpired:Z.toMiliseconds(o.exp)<Date.now(),payload:o};if(a.hasExpired)throw this.logger.warn("resolve: jwt attestation expired"),new Error("JWT attestation expired");return{origin:a.payload.origin,isScam:a.payload.isScam,isVerified:a.payload.isVerified}}),this.logger=ts(s,this.name),this.abortController=new AbortController,this.isDevEnv=Ld(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return es(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),Z.toMiliseconds(e))}}var CO=Object.defineProperty,_O=(t,e,s)=>e in t?CO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kp=(t,e,s)=>_O(t,typeof e!="symbol"?e+"":e,s);class AO extends HC{constructor(e,s){super(e,s),this.projectId=e,this.logger=s,kp(this,"context",S1),kp(this,"registerDeviceToken",async n=>{const{clientId:r,token:i,notificationType:o,enableEncrypted:a=!1}=n,c=`${I1}/${this.projectId}/clients`;await fetch(c,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_id:r,type:o,token:i,always_raw:a})})}),this.logger=ts(s,this.context)}}var SO=Object.defineProperty,Up=Object.getOwnPropertySymbols,IO=Object.prototype.hasOwnProperty,NO=Object.prototype.propertyIsEnumerable,hd=(t,e,s)=>e in t?SO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ri=(t,e)=>{for(var s in e||(e={}))IO.call(e,s)&&hd(t,s,e[s]);if(Up)for(var s of Up(e))NO.call(e,s)&&hd(t,s,e[s]);return t},pt=(t,e,s)=>hd(t,typeof e!="symbol"?e+"":e,s);class TO extends zC{constructor(e,s,n=!0){super(e,s,n),this.core=e,this.logger=s,pt(this,"context",T1),pt(this,"storagePrefix",tn),pt(this,"storageVersion",N1),pt(this,"events",new Map),pt(this,"shouldPersist",!1),pt(this,"init",async()=>{if(!Ld())try{const r={eventId:Ch(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:Tg(this.core.relayer.protocol,this.core.relayer.version,rd)}}};await this.sendEvent([r])}catch(r){this.logger.warn(r)}}),pt(this,"createEvent",r=>{const{event:i="ERROR",type:o="",properties:{topic:a,trace:c}}=r,l=Ch(),d=this.core.projectId||"",u=Date.now(),h=Ri({eventId:l,timestamp:u,props:{event:i,type:o,properties:{topic:a,trace:c}},bundleId:d,domain:this.getAppDomain()},this.setMethods(l));return this.telemetryEnabled&&(this.events.set(l,h),this.shouldPersist=!0),h}),pt(this,"getEvent",r=>{const{eventId:i,topic:o}=r;if(i)return this.events.get(i);const a=Array.from(this.events.values()).find(c=>c.props.properties.topic===o);if(a)return Ri(Ri({},a),this.setMethods(a.eventId))}),pt(this,"deleteEvent",r=>{const{eventId:i}=r;this.events.delete(i),this.shouldPersist=!0}),pt(this,"setEventListeners",()=>{this.core.heartbeat.on(gi.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(r=>{Z.fromMiliseconds(Date.now())-Z.fromMiliseconds(r.timestamp)>R1&&(this.events.delete(r.eventId),this.shouldPersist=!0)})})}),pt(this,"setMethods",r=>({addTrace:i=>this.addTrace(r,i),setError:i=>this.setError(r,i)})),pt(this,"addTrace",(r,i)=>{const o=this.events.get(r);o&&(o.props.properties.trace.push(i),this.events.set(r,o),this.shouldPersist=!0)}),pt(this,"setError",(r,i)=>{const o=this.events.get(r);o&&(o.props.type=i,o.timestamp=Date.now(),this.events.set(r,o),this.shouldPersist=!0)}),pt(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),pt(this,"restore",async()=>{try{const r=await this.core.storage.getItem(this.storageKey)||[];if(!r.length)return;r.forEach(i=>{this.events.set(i.eventId,Ri(Ri({},i),this.setMethods(i.eventId)))})}catch(r){this.logger.warn(r)}}),pt(this,"submit",async()=>{if(!this.telemetryEnabled||this.events.size===0)return;const r=[];for(const[i,o]of this.events)o.props.type&&r.push(o);if(r.length!==0)try{if((await this.sendEvent(r)).ok)for(const i of r)this.events.delete(i.eventId),this.shouldPersist=!0}catch(i){this.logger.warn(i)}}),pt(this,"sendEvent",async r=>{const i=this.getAppDomain()?"":"&sp=desktop";return await fetch(`${O1}?projectId=${this.core.projectId}&st=events_sdk&sv=js-${rd}${i}`,{method:"POST",body:JSON.stringify(r)})}),pt(this,"getAppDomain",()=>Ng().url),this.logger=ts(s,this.context),this.telemetryEnabled=n,n?this.restore().then(async()=>{await this.submit(),this.setEventListeners()}):this.persist()}get storageKey(){return this.storagePrefix+this.storageVersion+this.core.customStoragePrefix+"//"+this.context}}var RO=Object.defineProperty,$p=Object.getOwnPropertySymbols,OO=Object.prototype.hasOwnProperty,PO=Object.prototype.propertyIsEnumerable,pd=(t,e,s)=>e in t?RO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Dp=(t,e)=>{for(var s in e||(e={}))OO.call(e,s)&&pd(t,s,e[s]);if($p)for(var s of $p(e))PO.call(e,s)&&pd(t,s,e[s]);return t},ze=(t,e,s)=>pd(t,typeof e!="symbol"?e+"":e,s);let xO=class Gm extends xC{constructor(e){var s;super(e),ze(this,"protocol",xm),ze(this,"version",km),ze(this,"name",nd),ze(this,"relayUrl"),ze(this,"projectId"),ze(this,"customStoragePrefix"),ze(this,"events",new xr.EventEmitter),ze(this,"logger"),ze(this,"heartbeat"),ze(this,"relayer"),ze(this,"crypto"),ze(this,"storage"),ze(this,"history"),ze(this,"expirer"),ze(this,"pairing"),ze(this,"verify"),ze(this,"echoClient"),ze(this,"linkModeSupportedApps"),ze(this,"eventClient"),ze(this,"initialized",!1),ze(this,"logChunkController"),ze(this,"on",(a,c)=>this.events.on(a,c)),ze(this,"once",(a,c)=>this.events.once(a,c)),ze(this,"off",(a,c)=>this.events.off(a,c)),ze(this,"removeListener",(a,c)=>this.events.removeListener(a,c)),ze(this,"dispatchEnvelope",({topic:a,message:c,sessionExists:l})=>{if(!a||!c)return;const d={topic:a,message:c,publishedAt:Date.now(),transportType:Ke.link_mode};this.relayer.onLinkMessageEvent(d,{sessionExists:l})});const n=this.getGlobalCore(e==null?void 0:e.customStoragePrefix);if(n)try{return this.customStoragePrefix=n.customStoragePrefix,this.logger=n.logger,this.heartbeat=n.heartbeat,this.crypto=n.crypto,this.history=n.history,this.expirer=n.expirer,this.storage=n.storage,this.relayer=n.relayer,this.pairing=n.pairing,this.verify=n.verify,this.echoClient=n.echoClient,this.linkModeSupportedApps=n.linkModeSupportedApps,this.eventClient=n.eventClient,this.initialized=n.initialized,this.logChunkController=n.logChunkController,n}catch(a){console.warn("Failed to copy global core",a)}this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||$m,this.customStoragePrefix=e!=null&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";const r=Td({level:typeof(e==null?void 0:e.logger)=="string"&&e.logger?e.logger:JN.logger,name:nd}),{logger:i,chunkLoggerController:o}=ic({opts:r,maxSizeInBytes:e==null?void 0:e.maxLogBlobSizeInBytes,loggerOverride:e==null?void 0:e.logger});this.logChunkController=o,(s=this.logChunkController)!=null&&s.downloadLogsBlobInBrowser&&(window.downloadLogsBlobInBrowser=async()=>{var a,c;(a=this.logChunkController)!=null&&a.downloadLogsBlobInBrowser&&((c=this.logChunkController)==null||c.downloadLogsBlobInBrowser({clientId:await this.crypto.getClientId()}))}),this.logger=ts(i,this.name),this.heartbeat=new Uy,this.crypto=new iR(this,this.logger,e==null?void 0:e.keychain),this.history=new gO(this,this.logger),this.expirer=new wO(this,this.logger),this.storage=e!=null&&e.storage?e.storage:new RC(Dp(Dp({},XN),e==null?void 0:e.storageOptions)),this.relayer=new xR({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new hO(this,this.logger),this.verify=new vO(this,this.logger,this.storage),this.echoClient=new AO(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new TO(this,this.logger,e==null?void 0:e.telemetryEnabled),this.setGlobalCore(this)}static async init(e){const s=new Gm(e);await s.initialize();const n=await s.crypto.getClientId();return await s.storage.setItem(h1,n),s}get context(){return es(this.logger)}async start(){this.initialized||await this.initialize()}async getLogsBlob(){var e;return(e=this.logChunkController)==null?void 0:e.logsToBlob({clientId:await this.crypto.getClientId()})}async addLinkModeSupportedApp(e){this.linkModeSupportedApps.includes(e)||(this.linkModeSupportedApps.push(e),await this.storage.setItem(fp,this.linkModeSupportedApps))}async initialize(){this.logger.trace("Initialized");try{await this.crypto.init(),await this.history.init(),await this.expirer.init(),await this.relayer.init(),await this.heartbeat.init(),await this.pairing.init(),this.linkModeSupportedApps=await this.storage.getItem(fp)||[],this.initialized=!0,this.logger.info("Core Initialization Success")}catch(e){throw this.logger.warn(e,`Core Initialization Failure at epoch ${Date.now()}`),this.logger.error(e.message),e}}getGlobalCore(e=""){try{if(this.isGlobalCoreDisabled())return;const s=`_walletConnectCore_${e}`,n=`${s}_count`;return globalThis[n]=(globalThis[n]||0)+1,globalThis[n]>1&&console.warn(`WalletConnect Core is already initialized. This is probably a mistake and can lead to unexpected behavior. Init() was called ${globalThis[n]} times.`),globalThis[s]}catch(s){console.warn("Failed to get global WalletConnect core",s);return}}setGlobalCore(e){var s;try{if(this.isGlobalCoreDisabled())return;const n=`_walletConnectCore_${((s=e.opts)==null?void 0:s.customStoragePrefix)||""}`;globalThis[n]=e}catch(n){console.warn("Failed to set global WalletConnect core",n)}}isGlobalCoreDisabled(){try{return typeof En<"u"&&ZN.DISABLE_GLOBAL_CORE==="true"}catch{return!0}}};const kO=xO;var Ns={};const Ym="wc",Zm=2,Jm="client",Yd=`${Ym}@${Zm}:${Jm}:`,il={name:Jm,logger:"error"},Lp="WALLETCONNECT_DEEPLINK_CHOICE",UO="proposal",Mp="Proposal expired",$O="session",Hr=Z.SEVEN_DAYS,DO="engine",vt={wc_sessionPropose:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1104},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1106},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1112},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1114},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:Z.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:Z.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1119}}},ol={min:Z.FIVE_MINUTES,max:Z.SEVEN_DAYS},qs={idle:"IDLE",active:"ACTIVE"},LO={eth_sendTransaction:{key:""},eth_sendRawTransaction:{key:""},wallet_sendCalls:{key:""},solana_signTransaction:{key:"signature"},solana_signAllTransactions:{key:"transactions"},solana_signAndSendTransaction:{key:"signature"},sui_signAndExecuteTransaction:{key:"digest"},sui_signTransaction:{key:""},hedera_signAndExecuteTransaction:{key:"transactionId"},hedera_executeTransaction:{key:"transactionId"},near_signTransaction:{key:""},near_signTransactions:{key:""},tron_signTransaction:{key:"txID"},xrpl_signTransaction:{key:""},xrpl_signTransactionFor:{key:""},algo_signTxn:{key:""},sendTransfer:{key:"txid"},stacks_stxTransfer:{key:"txId"},polkadot_signTransaction:{key:""},cosmos_signDirect:{key:""}},MO="request",BO=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],jO="wc",FO="auth",qO="authKeys",WO="pairingTopics",HO="requests",Ec=`${jO}@${1.5}:${FO}:`,Ea=`${Ec}:PUB_KEY`;var zO=Object.defineProperty,VO=Object.defineProperties,KO=Object.getOwnPropertyDescriptors,Bp=Object.getOwnPropertySymbols,GO=Object.prototype.hasOwnProperty,YO=Object.prototype.propertyIsEnumerable,fd=(t,e,s)=>e in t?zO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Be=(t,e)=>{for(var s in e||(e={}))GO.call(e,s)&&fd(t,s,e[s]);if(Bp)for(var s of Bp(e))YO.call(e,s)&&fd(t,s,e[s]);return t},Ct=(t,e)=>VO(t,KO(e)),H=(t,e,s)=>fd(t,typeof e!="symbol"?e+"":e,s);class ZO extends YC{constructor(e){super(e),H(this,"name",DO),H(this,"events",new Sd),H(this,"initialized",!1),H(this,"requestQueue",{state:qs.idle,queue:[]}),H(this,"sessionRequestQueue",{state:qs.idle,queue:[]}),H(this,"emittedSessionRequests",new Q0({limit:500})),H(this,"requestQueueDelay",Z.ONE_SECOND),H(this,"expectedPairingMethodMap",new Map),H(this,"recentlyDeletedMap",new Map),H(this,"recentlyDeletedLimit",200),H(this,"relayMessageCache",[]),H(this,"pendingSessions",new Map),H(this,"init",async()=>{this.initialized||(await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.registerPairingEvents(),await this.registerLinkModeListeners(),this.client.core.pairing.register({methods:Object.keys(vt)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},Z.toMiliseconds(this.requestQueueDelay)))}),H(this,"connect",async s=>{var n;this.isInitialized(),await this.confirmOnlineStateOrThrow();const r=Ct(Be({},s),{requiredNamespaces:s.requiredNamespaces||{},optionalNamespaces:s.optionalNamespaces||{}});await this.isValidConnect(r),r.optionalNamespaces=lN(r.requiredNamespaces,r.optionalNamespaces),r.requiredNamespaces={};const{pairingTopic:i,requiredNamespaces:o,optionalNamespaces:a,sessionProperties:c,scopedProperties:l,relays:d,authentication:u,walletPay:h}=r,p=((n=u==null?void 0:u[0])==null?void 0:n.ttl)||vt.wc_sessionPropose.req.ttl||Z.FIVE_MINUTES;this.validateRequestExpiry(p);let g=i,f,y=!1;try{if(g){const k=this.client.core.pairing.pairings.get(g);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),y=k.active}}catch(k){throw this.client.logger.error(`connect() -> pairing.get(${g}) failed`),k}if(!g||!y){const{topic:k,uri:q}=await this.client.core.pairing.create({internal:{skipSubscribe:!0}});g=k,f=q}if(!g){const{message:k}=Y("NO_MATCHING_KEY",`connect() pairing topic: ${g}`);throw new Error(k)}const _=await this.client.core.crypto.generateKeyPair(),S=rt(p),v=Be(Ct(Be(Be({requiredNamespaces:o,optionalNamespaces:a,relays:d??[{protocol:Um}],proposer:{publicKey:_,metadata:this.client.metadata},expiryTimestamp:S,pairingTopic:g},c&&{sessionProperties:c}),l&&{scopedProperties:l}),{id:Nn()}),(u||h)&&{requests:{authentication:u==null?void 0:u.map(k=>{const{domain:q,chains:V,nonce:x,uri:N,exp:T,nbf:w,type:b,statement:I,requestId:O,resources:A,signatureTypes:P}=k;return{domain:q,chains:V,nonce:x,type:b??"caip122",aud:N,version:"1",iat:new Date().toISOString(),exp:T,nbf:w,statement:I,requestId:O,resources:A,signatureTypes:P}}),walletPay:h}}),C=Fe("session_connect",v.id),{reject:R,resolve:D,done:L}=dr(p,Mp),W=({id:k})=>{k===v.id&&(this.client.events.off("proposal_expire",W),this.pendingSessions.delete(v.id),this.events.emit(C,{error:{message:Mp,code:0}}))};return this.client.events.on("proposal_expire",W),this.events.once(C,({error:k,session:q})=>{this.client.events.off("proposal_expire",W),k?R(k):q&&D(q)}),await this.setProposal(v.id,v),await this.sendProposeSession({proposal:v,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:v.id}}}).catch(k=>{throw this.deleteProposal(v.id),k}),{uri:f,approval:L}}),H(this,"pair",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{return await this.client.core.pairing.pair(s)}catch(n){throw this.client.logger.error("pair() failed"),n}}),H(this,"approve",async s=>{var n,r,i;const o=this.client.core.eventClient.createEvent({properties:{topic:(n=s==null?void 0:s.id)==null?void 0:n.toString(),trace:[Is.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(q){throw o.setError(rr.no_internet_connection),q}try{await this.isValidProposalId(s==null?void 0:s.id)}catch(q){throw this.client.logger.error(`approve() -> proposal.get(${s==null?void 0:s.id}) failed`),o.setError(rr.proposal_not_found),q}try{await this.isValidApprove(s)}catch(q){throw this.client.logger.error("approve() -> isValidApprove() failed"),o.setError(rr.session_approve_namespace_validation_failure),q}const{id:a,relayProtocol:c,namespaces:l,sessionProperties:d,scopedProperties:u,sessionConfig:h,proposalRequestsResponses:p}=s,g=this.client.proposal.get(a);this.client.core.eventClient.deleteEvent({eventId:o.eventId});const{pairingTopic:f,proposer:y,requiredNamespaces:_,optionalNamespaces:S}=g;let v=(r=this.client.core.eventClient)==null?void 0:r.getEvent({topic:f});v||(v=(i=this.client.core.eventClient)==null?void 0:i.createEvent({type:Is.session_approve_started,properties:{topic:f,trace:[Is.session_approve_started,Is.session_namespaces_validation_success]}}));const C=await this.client.core.crypto.generateKeyPair(),R=y.publicKey,D=await this.client.core.crypto.generateSharedKey(C,R),L=Ct(Be(Be(Be({relay:{protocol:c??"irn"},namespaces:l,controller:{publicKey:C,metadata:this.client.metadata},expiry:rt(Hr)},d&&{sessionProperties:d}),u&&{scopedProperties:u}),h&&{sessionConfig:h}),{proposalRequestsResponses:p}),W=Ke.relay;v.addTrace(Is.subscribing_session_topic);try{await this.client.core.relayer.subscribe(D,{transportType:W,internal:{skipSubscribe:!0}})}catch(q){throw v.setError(rr.subscribe_session_topic_failure),q}v.addTrace(Is.subscribe_session_topic_success);const k=Ct(Be({},L),{topic:D,requiredNamespaces:_,optionalNamespaces:S,pairingTopic:f,acknowledged:!1,self:L.controller,peer:{publicKey:y.publicKey,metadata:y.metadata},controller:C,transportType:Ke.relay,authentication:p==null?void 0:p.authentication,walletPayResult:p==null?void 0:p.walletPay});await this.client.session.set(D,k),v.addTrace(Is.store_session);try{await this.sendApproveSession({sessionTopic:D,proposal:g,pairingProposalResponse:{relay:{protocol:c??"irn"},responderPublicKey:C},sessionSettleRequest:L,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:Be({correlationId:a},this.getTVFApproveParams(k))}}),v.addTrace(Is.session_approve_publish_success)}catch(q){throw this.client.logger.error(q),this.client.session.delete(D,Ze("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(D),q}return this.client.core.eventClient.deleteEvent({eventId:v.eventId}),await this.client.core.pairing.updateMetadata({topic:f,metadata:y.metadata}),await this.deleteProposal(a),await this.client.core.pairing.activate({topic:f}),await this.setExpiry(D,rt(Hr)),{topic:D,acknowledged:()=>Promise.resolve(this.client.session.get(D))}}),H(this,"reject",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidReject(s)}catch(o){throw this.client.logger.error("reject() -> isValidReject() failed"),o}const{id:n,reason:r}=s;let i;try{i=this.client.proposal.get(n).pairingTopic}catch(o){throw this.client.logger.error(`reject() -> proposal.get(${n}) failed`),o}i&&await this.sendError({id:n,topic:i,error:r,rpcOpts:vt.wc_sessionPropose.reject}),await this.deleteProposal(n)}),H(this,"update",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(s)}catch(u){throw this.client.logger.error("update() -> isValidUpdate() failed"),u}const{topic:n,namespaces:r}=s,{done:i,resolve:o,reject:a}=dr(Z.FIVE_MINUTES,"Session update request expired without receiving any acknowledgement"),c=Nn(),l=fr().toString(),d=this.client.session.get(n).namespaces;return this.events.once(Fe("session_update",c),({error:u})=>{u?a(u):o()}),await this.client.session.update(n,{namespaces:r}),await this.sendRequest({topic:n,method:"wc_sessionUpdate",params:{namespaces:r},throwOnFailedPublish:!0,clientRpcId:c,relayRpcId:l}).catch(u=>{this.client.logger.error(u),this.client.session.update(n,{namespaces:d}),a(u)}),{acknowledged:i}}),H(this,"extend",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidExtend(s)}catch(c){throw this.client.logger.error("extend() -> isValidExtend() failed"),c}const{topic:n}=s,r=Nn(),{done:i,resolve:o,reject:a}=dr(Z.FIVE_MINUTES,"Session extend request expired without receiving any acknowledgement");return this.events.once(Fe("session_extend",r),({error:c})=>{c?a(c):o()}),await this.setExpiry(n,rt(Hr)),this.sendRequest({topic:n,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(c=>{a(c)}),{acknowledged:i}}),H(this,"request",async s=>{this.isInitialized();try{await this.isValidRequest(s)}catch(y){throw this.client.logger.error("request() -> isValidRequest() failed"),y}const{chainId:n,request:r,topic:i,expiry:o=vt.wc_sessionRequest.req.ttl}=s,a=this.client.session.get(i);(a==null?void 0:a.transportType)===Ke.relay&&await this.confirmOnlineStateOrThrow();const c=Nn(),l=fr().toString(),{done:d,resolve:u,reject:h}=dr(o,"Request expired. Please try again.");this.events.once(Fe("session_request",c),({error:y,result:_})=>{y?h(y):u(_)});const p="wc_sessionRequest",g=this.getAppLinkIfEnabled(a.peer.metadata,a.transportType);if(g)return await this.sendRequest({clientRpcId:c,relayRpcId:l,topic:i,method:p,params:{request:Ct(Be({},r),{expiryTimestamp:rt(o)}),chainId:n},expiry:o,throwOnFailedPublish:!0,appLink:g}).catch(y=>h(y)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),await d();const f={request:Ct(Be({},r),{expiryTimestamp:rt(o)}),chainId:n};return await Promise.all([new Promise(async y=>{await this.sendRequest({clientRpcId:c,relayRpcId:l,topic:i,method:p,params:f,expiry:o,throwOnFailedPublish:!0,tvf:this.getTVFParams(c,f)}).catch(_=>h(_)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),y()}),new Promise(async y=>{var _;if(!((_=a.sessionConfig)!=null&&_.disableDeepLink)){const S=await G0(this.client.core.storage,Lp);await z0({id:c,topic:i,wcDeepLink:S})}y()}),d()]).then(y=>y[2])}),H(this,"respond",async s=>{var n,r;this.isInitialized();const i=this.client.core.eventClient.createEvent({properties:{topic:(s==null?void 0:s.topic)||((r=(n=s==null?void 0:s.response)==null?void 0:n.id)==null?void 0:r.toString()),trace:[Is.session_request_response_started]}});try{await this.isValidRespond(s)}catch(u){throw i.addTrace(u==null?void 0:u.message),i.setError(rr.session_request_response_validation_failure),u}i.addTrace(Is.session_request_response_validation_success);const{topic:o,response:a}=s,{id:c}=a,l=this.client.session.get(o);l.transportType===Ke.relay&&await this.confirmOnlineStateOrThrow();const d=this.getAppLinkIfEnabled(l.peer.metadata,l.transportType);try{i.addTrace(Is.session_request_response_publish_started),cn(a)?await this.sendResult({id:c,topic:o,result:a.result,throwOnFailedPublish:!0,appLink:d}):Hs(a)&&await this.sendError({id:c,topic:o,error:a.error,appLink:d}),this.cleanupAfterResponse(s)}catch(u){throw i.addTrace(u==null?void 0:u.message),i.setError(rr.session_request_response_publish_failure),u}}),H(this,"ping",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidPing(s)}catch(r){throw this.client.logger.error("ping() -> isValidPing() failed"),r}const{topic:n}=s;if(this.client.session.keys.includes(n)){const r=Nn(),i=fr().toString(),{done:o,resolve:a,reject:c}=dr(Z.FIVE_MINUTES,"Ping request expired without receiving any acknowledgement");this.events.once(Fe("session_ping",r),({error:l})=>{l?c(l):a()}),await Promise.all([this.sendRequest({topic:n,method:"wc_sessionPing",params:{},throwOnFailedPublish:!0,clientRpcId:r,relayRpcId:i}),o()])}else this.client.core.pairing.pairings.keys.includes(n)&&(this.client.logger.warn("ping() on pairing topic is deprecated and will be removed in the next major release."),await this.client.core.pairing.ping({topic:n}))}),H(this,"emit",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(s);const{topic:n,event:r,chainId:i}=s,o=fr().toString(),a=Nn();await this.sendRequest({topic:n,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:o,clientRpcId:a})}),H(this,"disconnect",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidDisconnect(s);const{topic:n}=s;if(this.client.session.keys.includes(n))await this.sendRequest({topic:n,method:"wc_sessionDelete",params:Ze("USER_DISCONNECTED"),throwOnFailedPublish:!0}),await this.deleteSession({topic:n,emitEvent:!1});else if(this.client.core.pairing.pairings.keys.includes(n))await this.client.core.pairing.disconnect({topic:n});else{const{message:r}=Y("MISMATCHED_TOPIC",`Session or pairing topic not found: ${n}`);throw new Error(r)}}),H(this,"find",s=>(this.isInitialized(),this.client.session.getAll().filter(n=>hN(n,s)))),H(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),H(this,"authenticate",async(s,n)=>{var r;this.isInitialized(),this.isValidAuthenticate(s);const i=n&&this.client.core.linkModeSupportedApps.includes(n)&&((r=this.client.metadata.redirect)==null?void 0:r.linkMode),o=i?Ke.link_mode:Ke.relay;o===Ke.relay&&await this.confirmOnlineStateOrThrow();const{chains:a,statement:c="",uri:l,domain:d,nonce:u,type:h,exp:p,nbf:g,methods:f=[],expiry:y}=s,_=[...s.resources||[]],{topic:S,uri:v}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:S,uri:v}});const C=await this.client.core.crypto.generateKeyPair(),R=ya(C);if(await Promise.all([this.client.auth.authKeys.set(Ea,{responseTopic:R,publicKey:C}),this.client.auth.pairingTopics.set(R,{topic:R,pairingTopic:S})]),await this.client.core.relayer.subscribe(R,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${S}`),f.length>0){const{namespace:A}=vn(a[0]);let P=hS(A,"request",f);ma(_)&&(P=fS(P,_.pop())),_.push(P)}const D=y&&y>vt.wc_sessionAuthenticate.req.ttl?y:vt.wc_sessionAuthenticate.req.ttl,L={authPayload:{type:h??"caip122",chains:a,statement:c,aud:l,domain:d,version:"1",nonce:u,iat:new Date().toISOString(),exp:p,nbf:g,resources:_},requester:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:rt(D)},W={eip155:{chains:a,methods:[...new Set(["personal_sign",...f])],events:["chainChanged","accountsChanged"]}},k={requiredNamespaces:{},optionalNamespaces:W,relays:[{protocol:"irn"}],pairingTopic:S,proposer:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:rt(vt.wc_sessionPropose.req.ttl),id:Nn()},{done:q,resolve:V,reject:x}=dr(D,"Request expired"),N=Nn(),T=Fe("session_connect",k.id),w=Fe("session_request",N),b=async({error:A,session:P})=>{this.events.off(w,I),A?x(A):P&&V({session:P})},I=async A=>{var P,B,M;if(await this.deletePendingAuthRequest(N,{message:"fulfilled",code:0}),A.error){const ye=Ze("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return A.error.code===ye.code?void 0:(this.events.off(T,b),x(A.error.message))}await this.deleteProposal(k.id),this.events.off(T,b);const{cacaos:ce,responder:j}=A.result,J=[],he=[];for(const ye of ce){await kh({cacao:ye,projectId:this.client.core.projectId})||(this.client.logger.error(ye,"Signature verification failed"),x(Ze("SESSION_SETTLEMENT_FAILED","Signature verification failed")));const{p:ve}=ye,Ve=ma(ve.resources),st=[zl(ve.iss)],ut=za(ve.iss);if(Ve){const wt=Uh(Ve),Bs=$h(Ve);J.push(...wt),st.push(...Bs)}for(const wt of st)he.push(`${wt}:${ut}`)}const ge=await this.client.core.crypto.generateSharedKey(C,j.publicKey);let Oe;J.length>0&&(Oe={topic:ge,acknowledged:!0,self:{publicKey:C,metadata:this.client.metadata},peer:j,controller:j.publicKey,expiry:rt(Hr),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:S,namespaces:ap([...new Set(J)],[...new Set(he)]),transportType:o},await this.client.core.relayer.subscribe(ge,{transportType:o}),await this.client.session.set(ge,Oe),S&&await this.client.core.pairing.updateMetadata({topic:S,metadata:j.metadata}),Oe=this.client.session.get(ge)),(P=this.client.metadata.redirect)!=null&&P.linkMode&&(B=j.metadata.redirect)!=null&&B.linkMode&&(M=j.metadata.redirect)!=null&&M.universal&&n&&(this.client.core.addLinkModeSupportedApp(j.metadata.redirect.universal),this.client.session.update(ge,{transportType:Ke.link_mode})),V({auths:ce,session:Oe})};this.events.once(T,b),this.events.once(w,I);let O;try{if(i){const A=zs("wc_sessionAuthenticate",L,N);this.client.core.history.set(S,A);const P=await this.client.core.crypto.encode("",A,{type:ko,encoding:qn});O=sa(n,S,P)}else await Promise.all([this.sendRequest({topic:S,method:"wc_sessionAuthenticate",params:L,expiry:s.expiry,throwOnFailedPublish:!0,clientRpcId:N}),this.sendRequest({topic:S,method:"wc_sessionPropose",params:k,expiry:vt.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:k.id})])}catch(A){throw this.events.off(T,b),this.events.off(w,I),A}return await this.setProposal(k.id,k),await this.setAuthRequest(N,{request:Ct(Be({},L),{verifyContext:{}}),pairingTopic:S,transportType:o}),{uri:O??v,response:q}}),H(this,"approveSessionAuthenticate",async s=>{const{id:n,auths:r}=s,i=this.client.core.eventClient.createEvent({properties:{topic:n.toString(),trace:[ir.authenticated_session_approve_started]}});try{this.isInitialized()}catch(y){throw i.setError(Ni.no_internet_connection),y}const o=this.getPendingAuthRequest(n);if(!o)throw i.setError(Ni.authenticated_session_pending_request_not_found),new Error(`Could not find pending auth request with id ${n}`);const a=o.transportType||Ke.relay;a===Ke.relay&&await this.confirmOnlineStateOrThrow();const c=o.requester.publicKey,l=await this.client.core.crypto.generateKeyPair(),d=ya(c),u={type:Cn,receiverPublicKey:c,senderPublicKey:l},h=[],p=[];for(const y of r){if(!await kh({cacao:y,projectId:this.client.core.projectId})){i.setError(Ni.invalid_cacao);const R=Ze("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:n,topic:d,error:R,encodeOpts:u}),new Error(R.message)}i.addTrace(ir.cacaos_verified);const{p:_}=y,S=ma(_.resources),v=[zl(_.iss)],C=za(_.iss);if(S){const R=Uh(S),D=$h(S);h.push(...R),v.push(...D)}for(const R of v)p.push(`${R}:${C}`)}const g=await this.client.core.crypto.generateSharedKey(l,c);i.addTrace(ir.create_authenticated_session_topic);let f;if((h==null?void 0:h.length)>0){f={topic:g,acknowledged:!0,self:{publicKey:l,metadata:this.client.metadata},peer:{publicKey:c,metadata:o.requester.metadata},controller:c,expiry:rt(Hr),authentication:r,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:o.pairingTopic,namespaces:ap([...new Set(h)],[...new Set(p)]),transportType:a},i.addTrace(ir.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(g,{transportType:a})}catch(y){throw i.setError(Ni.subscribe_authenticated_session_topic_failure),y}i.addTrace(ir.subscribe_authenticated_session_topic_success),await this.client.session.set(g,f),i.addTrace(ir.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:o.pairingTopic,metadata:o.requester.metadata})}i.addTrace(ir.publishing_authenticated_session_approve);try{await this.sendResult({topic:d,id:n,result:{cacaos:r,responder:{publicKey:l,metadata:this.client.metadata}},encodeOpts:u,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(o.requester.metadata,a)})}catch(y){throw i.setError(Ni.authenticated_session_approve_publish_failure),y}return await this.client.auth.requests.delete(n,{message:"fulfilled",code:0}),await this.client.core.pairing.activate({topic:o.pairingTopic}),this.client.core.eventClient.deleteEvent({eventId:i.eventId}),{session:f}}),H(this,"rejectSessionAuthenticate",async s=>{this.isInitialized();const{id:n,reason:r}=s,i=this.getPendingAuthRequest(n);if(!i)throw new Error(`Could not find pending auth request with id ${n}`);i.transportType===Ke.relay&&await this.confirmOnlineStateOrThrow();const o=i.requester.publicKey,a=await this.client.core.crypto.generateKeyPair(),c=ya(o),l={type:Cn,receiverPublicKey:o,senderPublicKey:a};await this.sendError({id:n,topic:c,error:r,encodeOpts:l,rpcOpts:vt.wc_sessionAuthenticate.reject,appLink:this.getAppLinkIfEnabled(i.requester.metadata,i.transportType)}),await this.client.auth.requests.delete(n,{message:"rejected",code:0}),await this.deleteProposal(n)}),H(this,"formatAuthMessage",s=>{this.isInitialized();const{request:n,iss:r}=s;return Kg(n,r)}),H(this,"processRelayMessageCache",()=>{setTimeout(async()=>{if(this.relayMessageCache.length!==0)for(;this.relayMessageCache.length>0;)try{const s=this.relayMessageCache.shift();s&&await this.onRelayMessage(s)}catch(s){this.client.logger.error(s)}},50)}),H(this,"cleanupDuplicatePairings",async s=>{if(s.pairingTopic)try{const n=this.client.core.pairing.pairings.get(s.pairingTopic),r=this.client.core.pairing.pairings.getAll().filter(i=>{var o,a;return((o=i.peerMetadata)==null?void 0:o.url)&&((a=i.peerMetadata)==null?void 0:a.url)===s.peer.metadata.url&&i.topic&&i.topic!==n.topic});if(r.length===0)return;this.client.logger.info(`Cleaning up ${r.length} duplicate pairing(s)`),await Promise.all(r.map(i=>this.client.core.pairing.disconnect({topic:i.topic}))),this.client.logger.info("Duplicate pairings clean up finished")}catch(n){this.client.logger.error(n)}}),H(this,"deleteSession",async s=>{var n;const{topic:r,expirerHasDeleted:i=!1,emitEvent:o=!0,id:a=0}=s,{self:c}=this.client.session.get(r);await this.client.core.relayer.unsubscribe(r),await this.client.session.delete(r,Ze("USER_DISCONNECTED")),this.addToRecentlyDeleted(r,"session"),this.client.core.crypto.keychain.has(c.publicKey)&&await this.client.core.crypto.deleteKeyPair(c.publicKey),this.client.core.crypto.keychain.has(r)&&await this.client.core.crypto.deleteSymKey(r),i||this.client.core.expirer.del(r),this.client.core.storage.removeItem(Lp).catch(l=>this.client.logger.warn(l)),r===((n=this.sessionRequestQueue.queue[0])==null?void 0:n.topic)&&(this.sessionRequestQueue.state=qs.idle),await Promise.all(this.getPendingSessionRequests().filter(l=>l.topic===r).map(l=>this.deletePendingSessionRequest(l.id,Ze("USER_DISCONNECTED")))),o&&this.client.events.emit("session_delete",{id:a,topic:r})}),H(this,"deleteProposal",async(s,n)=>{if(n)try{const r=this.client.proposal.get(s),i=this.client.core.eventClient.getEvent({topic:r.pairingTopic});i==null||i.setError(rr.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(s,Ze("USER_DISCONNECTED")),n?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"proposal")}),H(this,"deletePendingSessionRequest",async(s,n,r=!1)=>{await Promise.all([this.client.pendingRequest.delete(s,n),r?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"request"),this.sessionRequestQueue.queue=this.sessionRequestQueue.queue.filter(i=>i.id!==s),r&&(this.sessionRequestQueue.state=qs.idle,this.client.events.emit("session_request_expire",{id:s}))}),H(this,"deletePendingAuthRequest",async(s,n,r=!1)=>{await Promise.all([this.client.auth.requests.delete(s,n),r?Promise.resolve():this.client.core.expirer.del(s)])}),H(this,"setExpiry",async(s,n)=>{this.client.session.keys.includes(s)&&(this.client.core.expirer.set(s,n),await this.client.session.update(s,{expiry:n}))}),H(this,"setProposal",async(s,n)=>{this.client.core.expirer.set(s,rt(vt.wc_sessionPropose.req.ttl)),await this.client.proposal.set(s,n)}),H(this,"setAuthRequest",async(s,n)=>{const{request:r,pairingTopic:i,transportType:o=Ke.relay}=n;this.client.core.expirer.set(s,r.expiryTimestamp),await this.client.auth.requests.set(s,{authPayload:r.authPayload,requester:r.requester,expiryTimestamp:r.expiryTimestamp,id:s,pairingTopic:i,verifyContext:r.verifyContext,transportType:o})}),H(this,"setPendingSessionRequest",async s=>{const{id:n,topic:r,params:i,verifyContext:o}=s,a=i.request.expiryTimestamp||rt(vt.wc_sessionRequest.req.ttl);this.client.core.expirer.set(n,a),await this.client.pendingRequest.set(n,{id:n,topic:r,params:i,verifyContext:o})}),H(this,"sendRequest",async s=>{const{topic:n,method:r,params:i,expiry:o,relayRpcId:a,clientRpcId:c,throwOnFailedPublish:l,appLink:d,tvf:u,publishOpts:h={}}=s,p=zs(r,i,c);let g;const f=!!d;try{const S=f?qn:Zt;g=await this.client.core.crypto.encode(n,p,{encoding:S})}catch(S){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${n} failed`),S}let y;if(BO.includes(r)){const S=Es(JSON.stringify(p)),v=Es(g);y=await this.client.core.verify.register({id:v,decryptedId:S})}const _=Be(Be({},vt[r].req),h);if(_.attestation=y,o&&(_.ttl=o),a&&(_.id=a),this.client.core.history.set(n,p),f){const S=sa(d,n,g);await Ns.Linking.openURL(S,this.client.name)}else _.tvf=Ct(Be({},u),{correlationId:p.id}),l?(_.internal=Ct(Be({},_.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,g,_)):this.client.core.relayer.publish(n,g,_).catch(S=>this.client.logger.error(S));return p.id}),H(this,"sendProposeSession",async s=>{const{proposal:n,publishOpts:r}=s,i=zs("wc_sessionPropose",n,n.id);this.client.core.history.set(n.pairingTopic,i);const o=await this.client.core.crypto.encode(n.pairingTopic,i,{encoding:Zt}),a=Es(JSON.stringify(i)),c=Es(o),l=await this.client.core.verify.register({id:c,decryptedId:a});await this.client.core.relayer.publishCustom({payload:{pairingTopic:n.pairingTopic,sessionProposal:o},opts:Ct(Be({},r),{publishMethod:"wc_proposeSession",attestation:l})})}),H(this,"sendApproveSession",async s=>{const{sessionTopic:n,pairingProposalResponse:r,proposal:i,sessionSettleRequest:o,publishOpts:a}=s,c=Yi(i.id,r),l=await this.client.core.crypto.encode(i.pairingTopic,c,{encoding:Zt}),d=zs("wc_sessionSettle",o,a==null?void 0:a.id),u=await this.client.core.crypto.encode(n,d,{encoding:Zt});this.client.core.history.set(n,d),await this.client.core.relayer.publishCustom({payload:{sessionTopic:n,pairingTopic:i.pairingTopic,sessionProposalResponse:l,sessionSettlementRequest:u},opts:Ct(Be({},a),{publishMethod:"wc_approveSession"})})}),H(this,"sendResult",async s=>{const{id:n,topic:r,result:i,throwOnFailedPublish:o,encodeOpts:a,appLink:c}=s,l=Yi(n,i);let d;const u=c&&typeof(Ns==null?void 0:Ns.Linking)<"u";try{const g=u?qn:Zt;d=await this.client.core.crypto.encode(r,l,Ct(Be({},a||{}),{encoding:g}))}catch(g){throw await this.cleanup(),this.client.logger.error(`sendResult() -> core.crypto.encode() for topic ${r} failed`),g}let h,p;try{h=await this.client.core.history.get(r,n);const g=h.request;try{p=this.getTVFParams(n,g.params,i)}catch(f){this.client.logger.warn(`sendResult() -> getTVFParams() failed: ${f==null?void 0:f.message}`)}}catch(g){throw this.client.logger.error(`sendResult() -> history.get(${r}, ${n}) failed`),g}if(u){const g=sa(c,r,d);await Ns.Linking.openURL(g,this.client.name)}else{const g=h.request.method,f=vt[g].res;f.tvf=Ct(Be({},p),{correlationId:n}),o?(f.internal=Ct(Be({},f.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(r,d,f)):this.client.core.relayer.publish(r,d,f).catch(y=>this.client.logger.error(y))}await this.client.core.history.resolve(l)}),H(this,"sendError",async s=>{const{id:n,topic:r,error:i,encodeOpts:o,rpcOpts:a,appLink:c}=s,l=Cf(n,i);let d;const u=c&&typeof(Ns==null?void 0:Ns.Linking)<"u";try{const p=u?qn:Zt;d=await this.client.core.crypto.encode(r,l,Ct(Be({},o||{}),{encoding:p}))}catch(p){throw await this.cleanup(),this.client.logger.error(`sendError() -> core.crypto.encode() for topic ${r} failed`),p}let h;try{h=await this.client.core.history.get(r,n)}catch(p){throw this.client.logger.error(`sendError() -> history.get(${r}, ${n}) failed`),p}if(u){const p=sa(c,r,d);await Ns.Linking.openURL(p,this.client.name)}else{const p=h.request.method,g=a||vt[p].res;this.client.core.relayer.publish(r,d,g)}await this.client.core.history.resolve(l)}),H(this,"cleanup",async()=>{const s=[],n=[];this.client.session.getAll().forEach(r=>{let i=!1;Vs(r.expiry)&&(i=!0),this.client.core.crypto.keychain.has(r.topic)||(i=!0),i&&s.push(r.topic)}),this.client.proposal.getAll().forEach(r=>{Vs(r.expiryTimestamp)&&n.push(r.id)}),await Promise.all([...s.map(r=>this.deleteSession({topic:r})),...n.map(r=>this.deleteProposal(r))])}),H(this,"onProviderMessageEvent",async s=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(s):await this.onRelayMessage(s)}),H(this,"onRelayEventRequest",async s=>{this.requestQueue.queue.push(s),await this.processRequestsQueue()}),H(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===qs.active){this.client.logger.info("Request queue already active, skipping...");return}for(this.client.logger.info(`Request queue starting with ${this.requestQueue.queue.length} requests`);this.requestQueue.queue.length>0;){this.requestQueue.state=qs.active;const s=this.requestQueue.queue.shift();if(s)try{await this.processRequest(s)}catch(n){this.client.logger.warn(n)}}this.requestQueue.state=qs.idle}),H(this,"processRequest",async s=>{const{topic:n,payload:r,attestation:i,transportType:o,encryptedId:a}=s,c=r.method;if(!this.shouldIgnorePairingRequest({topic:n,requestMethod:c}))switch(c){case"wc_sessionPropose":return await this.onSessionProposeRequest({topic:n,payload:r,attestation:i,encryptedId:a});case"wc_sessionSettle":return await this.onSessionSettleRequest(n,r);case"wc_sessionUpdate":return await this.onSessionUpdateRequest(n,r);case"wc_sessionExtend":return await this.onSessionExtendRequest(n,r);case"wc_sessionPing":return await this.onSessionPingRequest(n,r);case"wc_sessionDelete":return await this.onSessionDeleteRequest(n,r);case"wc_sessionRequest":return await this.onSessionRequest({topic:n,payload:r,attestation:i,encryptedId:a,transportType:o});case"wc_sessionEvent":return await this.onSessionEventRequest(n,r);case"wc_sessionAuthenticate":return await this.onSessionAuthenticateRequest({topic:n,payload:r,attestation:i,encryptedId:a,transportType:o});default:return this.client.logger.info(`Unsupported request method ${c}`)}}),H(this,"onRelayEventResponse",async s=>{const{topic:n,payload:r,transportType:i}=s,o=(await this.client.core.history.get(n,r.id)).request.method;switch(o){case"wc_sessionPropose":return this.onSessionProposeResponse(n,r,i);case"wc_sessionSettle":return this.onSessionSettleResponse(n,r);case"wc_sessionUpdate":return this.onSessionUpdateResponse(n,r);case"wc_sessionExtend":return this.onSessionExtendResponse(n,r);case"wc_sessionPing":return this.onSessionPingResponse(n,r);case"wc_sessionRequest":return this.onSessionRequestResponse(n,r);case"wc_sessionAuthenticate":return this.onSessionAuthenticateResponse(n,r);default:return this.client.logger.info(`Unsupported response method ${o}`)}}),H(this,"onRelayEventUnknownPayload",s=>{const{topic:n}=s,{message:r}=Y("MISSING_OR_INVALID",`Decoded payload on topic ${n} is not identifiable as a JSON-RPC request or a response.`);throw new Error(r)}),H(this,"shouldIgnorePairingRequest",s=>{const{topic:n,requestMethod:r}=s,i=this.expectedPairingMethodMap.get(n);return!i||i.includes(r)?!1:!!(i.includes("wc_sessionAuthenticate")&&this.client.events.listenerCount("session_authenticate")>0)}),H(this,"onSessionProposeRequest",async s=>{const{topic:n,payload:r,attestation:i,encryptedId:o}=s,{params:a,id:c}=r;try{const l=this.client.core.eventClient.getEvent({topic:n});this.client.events.listenerCount("session_proposal")===0&&(console.warn("No listener for session_proposal event"),l==null||l.setError(dn.proposal_listener_not_found)),this.isValidConnect(Be({},r.params));const d=a.expiryTimestamp||rt(vt.wc_sessionPropose.req.ttl),u=Be({id:c,pairingTopic:n,expiryTimestamp:d,attestation:i,encryptedId:o},a);await this.setProposal(c,u);const h=await this.getVerifyContext({attestationId:i,hash:Es(JSON.stringify(r)),encryptedId:o,metadata:u.proposer.metadata});l==null||l.addTrace(Ws.emit_session_proposal),this.client.events.emit("session_proposal",{id:c,params:u,verifyContext:h})}catch(l){await this.sendError({id:c,topic:n,error:l,rpcOpts:vt.wc_sessionPropose.autoReject}),this.client.logger.error(l)}}),H(this,"onSessionProposeResponse",async(s,n,r)=>{const{id:i}=n;if(cn(n)){const{result:o}=n;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",result:o});const a=this.client.proposal.get(i);this.client.logger.trace({type:"method",method:"onSessionProposeResponse",proposal:a});const c=a.proposer.publicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",selfPublicKey:c});const l=o.responderPublicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",peerPublicKey:l});const d=await this.client.core.crypto.generateSharedKey(c,l);this.pendingSessions.set(i,{sessionTopic:d,pairingTopic:s,proposalId:i,publicKey:c});const u=await this.client.core.relayer.subscribe(d,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:u}),await this.client.core.pairing.activate({topic:s})}else if(Hs(n)){await this.deleteProposal(i);const o=Fe("session_connect",i);if(this.events.listenerCount(o)===0)throw new Error(`emitting ${o} without any listeners, 954`);this.events.emit(o,{error:n.error})}}),H(this,"onSessionSettleRequest",async(s,n)=>{const{id:r,params:i}=n;try{this.isValidSessionSettleRequest(i);const{relay:o,controller:a,expiry:c,namespaces:l,sessionProperties:d,scopedProperties:u,sessionConfig:h,proposalRequestsResponses:p}=n.params,g=[...this.pendingSessions.values()].find(_=>_.sessionTopic===s);if(!g)return this.client.logger.error(`Pending session not found for topic ${s}`);const f=this.client.proposal.get(g.proposalId),y=Ct(Be(Be(Be({topic:s,relay:o,expiry:c,namespaces:l,acknowledged:!0,pairingTopic:g.pairingTopic,requiredNamespaces:f.requiredNamespaces,optionalNamespaces:f.optionalNamespaces,controller:a.publicKey,self:{publicKey:g.publicKey,metadata:this.client.metadata},peer:{publicKey:a.publicKey,metadata:a.metadata}},d&&{sessionProperties:d}),u&&{scopedProperties:u}),h&&{sessionConfig:h}),{transportType:Ke.relay,authentication:p==null?void 0:p.authentication,walletPayResult:p==null?void 0:p.walletPay});await this.client.session.set(y.topic,y),await this.setExpiry(y.topic,y.expiry),await this.client.core.pairing.updateMetadata({topic:g.pairingTopic,metadata:y.peer.metadata}),this.pendingSessions.delete(g.proposalId),this.deleteProposal(g.proposalId,!1),this.cleanupDuplicatePairings(y),await this.sendResult({id:n.id,topic:s,throwOnFailedPublish:!0,result:!0}),this.client.events.emit("session_connect",{session:y}),this.events.emit(Fe("session_connect",g.proposalId),{session:y})}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"onSessionSettleResponse",async(s,n)=>{const{id:r}=n;cn(n)?(await this.client.session.update(s,{acknowledged:!0}),this.events.emit(Fe("session_approve",r),{})):Hs(n)&&(await this.client.session.delete(s,Ze("USER_DISCONNECTED")),this.events.emit(Fe("session_approve",r),{error:n.error}))}),H(this,"onSessionUpdateRequest",async(s,n)=>{const{params:r,id:i}=n;try{const o=`${s}_session_update`,a=Si.get(o);if(a&&this.isRequestOutOfSync(a,i)){this.client.logger.warn(`Discarding out of sync request - ${i}`),this.sendError({id:i,topic:s,error:Ze("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(Be({topic:s},r));try{Si.set(o,i),await this.client.session.update(s,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:s,result:!0})}catch(c){throw Si.delete(o),c}this.client.events.emit("session_update",{id:i,topic:s,params:r})}catch(o){await this.sendError({id:i,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"isRequestOutOfSync",(s,n)=>n.toString().slice(0,-3)<s.toString().slice(0,-3)),H(this,"onSessionUpdateResponse",(s,n)=>{const{id:r}=n,i=Fe("session_update",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_update",r),{}):Hs(n)&&this.events.emit(Fe("session_update",r),{error:n.error})}),H(this,"onSessionExtendRequest",async(s,n)=>{const{id:r}=n;try{this.isValidExtend({topic:s}),await this.setExpiry(s,rt(Hr)),await this.sendResult({id:r,topic:s,result:!0}),this.client.events.emit("session_extend",{id:r,topic:s})}catch(i){await this.sendError({id:r,topic:s,error:i}),this.client.logger.error(i)}}),H(this,"onSessionExtendResponse",(s,n)=>{const{id:r}=n,i=Fe("session_extend",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_extend",r),{}):Hs(n)&&this.events.emit(Fe("session_extend",r),{error:n.error})}),H(this,"onSessionPingRequest",async(s,n)=>{const{id:r}=n;try{this.isValidPing({topic:s}),await this.sendResult({id:r,topic:s,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_ping",{id:r,topic:s})}catch(i){await this.sendError({id:r,topic:s,error:i}),this.client.logger.error(i)}}),H(this,"onSessionPingResponse",(s,n)=>{const{id:r}=n,i=Fe("session_ping",r);setTimeout(()=>{if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners 2176`);cn(n)?this.events.emit(Fe("session_ping",r),{}):Hs(n)&&this.events.emit(Fe("session_ping",r),{error:n.error})},500)}),H(this,"onSessionDeleteRequest",async(s,n)=>{const{id:r}=n;try{await this.isValidDisconnect({topic:s,reason:n.params}),this.cleanupPendingSentRequestsForTopic({topic:s,error:Ze("USER_DISCONNECTED")}),await this.deleteSession({topic:s,id:r})}catch(i){this.client.logger.error(i)}}),H(this,"onSessionRequest",async s=>{var n,r,i;const{topic:o,payload:a,attestation:c,encryptedId:l,transportType:d}=s,{id:u,params:h}=a;try{await this.isValidRequest(Be({topic:o},h));const p=this.client.session.get(o),g=await this.getVerifyContext({attestationId:c,hash:Es(JSON.stringify(zs("wc_sessionRequest",h,u))),encryptedId:l,metadata:p.peer.metadata,transportType:d}),f={id:u,topic:o,params:h,verifyContext:g};await this.setPendingSessionRequest(f),d===Ke.link_mode&&(n=p.peer.metadata.redirect)!=null&&n.universal&&this.client.core.addLinkModeSupportedApp((r=p.peer.metadata.redirect)==null?void 0:r.universal),(i=this.client.signConfig)!=null&&i.disableRequestQueue?this.emitSessionRequest(f):(this.addSessionRequestToSessionRequestQueue(f),this.processSessionRequestQueue())}catch(p){await this.sendError({id:u,topic:o,error:p}),this.client.logger.error(p)}}),H(this,"onSessionRequestResponse",(s,n)=>{const{id:r}=n,i=Fe("session_request",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_request",r),{result:n.result}):Hs(n)&&this.events.emit(Fe("session_request",r),{error:n.error})}),H(this,"onSessionEventRequest",async(s,n)=>{const{id:r,params:i}=n;try{const o=`${s}_session_event_${i.event.name}`,a=Si.get(o);if(a&&this.isRequestOutOfSync(a,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(Be({topic:s},i)),this.client.events.emit("session_event",{id:r,topic:s,params:i}),Si.set(o,r)}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"onSessionAuthenticateResponse",(s,n)=>{const{id:r}=n;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:s,payload:n}),cn(n)?this.events.emit(Fe("session_request",r),{result:n.result}):Hs(n)&&this.events.emit(Fe("session_request",r),{error:n.error})}),H(this,"onSessionAuthenticateRequest",async s=>{var n;const{topic:r,payload:i,attestation:o,encryptedId:a,transportType:c}=s;try{const{requester:l,authPayload:d,expiryTimestamp:u}=i.params,h=await this.getVerifyContext({attestationId:o,hash:Es(JSON.stringify(i)),encryptedId:a,metadata:l.metadata,transportType:c}),p={requester:l,pairingTopic:r,id:i.id,authPayload:d,verifyContext:h,expiryTimestamp:u};await this.setAuthRequest(i.id,{request:p,pairingTopic:r,transportType:c}),c===Ke.link_mode&&(n=l.metadata.redirect)!=null&&n.universal&&this.client.core.addLinkModeSupportedApp(l.metadata.redirect.universal),this.client.events.emit("session_authenticate",{topic:r,params:i.params,id:i.id,verifyContext:h})}catch(l){this.client.logger.error(l);const d=i.params.requester.publicKey,u=await this.client.core.crypto.generateKeyPair(),h=this.getAppLinkIfEnabled(i.params.requester.metadata,c),p={type:Cn,receiverPublicKey:d,senderPublicKey:u};await this.sendError({id:i.id,topic:r,error:l,encodeOpts:p,rpcOpts:vt.wc_sessionAuthenticate.autoReject,appLink:h})}}),H(this,"addSessionRequestToSessionRequestQueue",s=>{this.sessionRequestQueue.queue.push(s)}),H(this,"cleanupAfterResponse",s=>{this.deletePendingSessionRequest(s.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=qs.idle,this.processSessionRequestQueue()},Z.toMiliseconds(this.requestQueueDelay))}),H(this,"cleanupPendingSentRequestsForTopic",({topic:s,error:n})=>{const r=this.client.core.history.pending;r.length>0&&r.filter(i=>i.topic===s&&i.request.method==="wc_sessionRequest").forEach(i=>{this.events.emit(Fe("session_request",i.request.id),{error:n})})}),H(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===qs.active){this.client.logger.info("session request queue is already active.");return}const s=this.sessionRequestQueue.queue[0];if(!s){this.client.logger.info("session request queue is empty.");return}try{this.emitSessionRequest(s)}catch(n){this.client.logger.error(n)}}),H(this,"emitSessionRequest",s=>{if(this.emittedSessionRequests.has(s.id)){this.client.logger.warn({id:s.id},`Skipping emitting \`session_request\` event for duplicate request. id: ${s.id}`);return}this.sessionRequestQueue.state=qs.active,this.emittedSessionRequests.add(s.id),this.client.events.emit("session_request",s)}),H(this,"onPairingCreated",s=>{if(s.methods&&this.expectedPairingMethodMap.set(s.topic,s.methods),s.active)return;const n=this.client.proposal.getAll().find(r=>r.pairingTopic===s.topic);n&&this.onSessionProposeRequest({topic:s.topic,payload:zs("wc_sessionPropose",Ct(Be({},n),{requiredNamespaces:n.requiredNamespaces,optionalNamespaces:n.optionalNamespaces,relays:n.relays,proposer:n.proposer,sessionProperties:n.sessionProperties,scopedProperties:n.scopedProperties}),n.id),attestation:n.attestation,encryptedId:n.encryptedId})}),H(this,"isValidConnect",async s=>{if(!Vt(s)){const{message:l}=Y("MISSING_OR_INVALID",`connect() params: ${JSON.stringify(s)}`);throw new Error(l)}const{pairingTopic:n,requiredNamespaces:r,optionalNamespaces:i,sessionProperties:o,scopedProperties:a,relays:c}=s;if(mt(n)||await this.isValidPairingTopic(n),!AN(c)){const{message:l}=Y("MISSING_OR_INVALID",`connect() relays: ${c}`);throw new Error(l)}if(r&&!mt(r)&&Xs(r)!==0){const l="requiredNamespaces are deprecated and are automatically assigned to optionalNamespaces";["fatal","error","silent"].includes(this.client.logger.level)?console.warn(l):this.client.logger.warn(l),this.validateNamespaces(r,"requiredNamespaces")}if(i&&!mt(i)&&Xs(i)!==0&&this.validateNamespaces(i,"optionalNamespaces"),o&&!mt(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!mt(a)){this.validateSessionProps(a,"scopedProperties");const l=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(a).every(d=>l.includes(d.split(":")[0])))throw new Error(`Scoped properties must be a subset of required/optional namespaces, received: ${JSON.stringify(a)}, required/optional namespaces: ${JSON.stringify(l)}`)}}),H(this,"validateNamespaces",(s,n)=>{const r=_N(s,"connect()",n);if(r)throw new Error(r.message)}),H(this,"isValidApprove",async s=>{if(!Vt(s))throw new Error(Y("MISSING_OR_INVALID",`approve() params: ${s}`).message);const{id:n,namespaces:r,relayProtocol:i,sessionProperties:o,scopedProperties:a}=s;this.checkRecentlyDeleted(n),await this.isValidProposalId(n);const c=this.client.proposal.get(n),l=el(r,"approve()");if(l)throw new Error(l.message);const d=dp(c.requiredNamespaces,r,"approve()");if(d)throw new Error(d.message);if(!ot(i,!0)){const{message:u}=Y("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw new Error(u)}if(o&&!mt(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!mt(a)){this.validateSessionProps(a,"scopedProperties");const u=new Set(Object.keys(r));if(!Object.keys(a).every(h=>u.has(h.split(":")[0])))throw new Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(a)}, approved namespaces: ${Array.from(u).join(", ")}`)}}),H(this,"isValidReject",async s=>{if(!Vt(s)){const{message:i}=Y("MISSING_OR_INVALID",`reject() params: ${s}`);throw new Error(i)}const{id:n,reason:r}=s;if(this.checkRecentlyDeleted(n),await this.isValidProposalId(n),!IN(r)){const{message:i}=Y("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw new Error(i)}}),H(this,"isValidSessionSettleRequest",s=>{if(!Vt(s)){const{message:l}=Y("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${s}`);throw new Error(l)}const{relay:n,controller:r,namespaces:i,expiry:o}=s;if(!Pm(n)){const{message:l}=Y("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw new Error(l)}const a=yN(r,"onSessionSettleRequest()");if(a)throw new Error(a.message);const c=el(i,"onSessionSettleRequest()");if(c)throw new Error(c.message);if(Vs(o)){const{message:l}=Y("EXPIRED","onSessionSettleRequest()");throw new Error(l)}}),H(this,"isValidUpdate",async s=>{if(!Vt(s)){const{message:c}=Y("MISSING_OR_INVALID",`update() params: ${s}`);throw new Error(c)}const{topic:n,namespaces:r}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n);const i=this.client.session.get(n),o=el(r,"update()");if(o)throw new Error(o.message);const a=dp(i.requiredNamespaces,r,"update()");if(a)throw new Error(a.message)}),H(this,"isValidExtend",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`extend() params: ${s}`);throw new Error(r)}const{topic:n}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n)}),H(this,"isValidRequest",async s=>{if(!Vt(s)){const{message:c}=Y("MISSING_OR_INVALID",`request() params: ${s}`);throw new Error(c)}const{topic:n,request:r,chainId:i,expiry:o}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n);const{namespaces:a}=this.client.session.get(n);if(!lp(a,i)){const{message:c}=Y("MISSING_OR_INVALID",`request() chainId: ${i}`);throw new Error(c)}if(!NN(r)){const{message:c}=Y("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw new Error(c)}if(!ON(a,i,r.method)){const{message:c}=Y("MISSING_OR_INVALID",`request() method: ${r.method}`);throw new Error(c)}this.validateRequestExpiry(o)}),H(this,"isValidRespond",async s=>{var n;if(!Vt(s)){const{message:a}=Y("MISSING_OR_INVALID",`respond() params: ${s}`);throw new Error(a)}const{topic:r,response:i}=s;try{await this.isValidSessionTopic(r)}catch(a){throw(n=s==null?void 0:s.response)!=null&&n.id&&this.cleanupAfterResponse(s),a}if(!TN(i)){const{message:a}=Y("MISSING_OR_INVALID",`respond() response: ${JSON.stringify(i)}`);throw new Error(a)}const o=this.client.pendingRequest.get(i.id);if(o.topic!==r){const{message:a}=Y("MISMATCHED_TOPIC",`Request response topic mismatch. reqId: ${i.id}, expected topic: ${o.topic}, received topic: ${r}`);throw new Error(a)}}),H(this,"isValidPing",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`ping() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),H(this,"isValidEmit",async s=>{if(!Vt(s)){const{message:a}=Y("MISSING_OR_INVALID",`emit() params: ${s}`);throw new Error(a)}const{topic:n,event:r,chainId:i}=s;await this.isValidSessionTopic(n);const{namespaces:o}=this.client.session.get(n);if(!lp(o,i)){const{message:a}=Y("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw new Error(a)}if(!RN(r)){const{message:a}=Y("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}if(!PN(o,i,r.name)){const{message:a}=Y("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}}),H(this,"isValidDisconnect",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`disconnect() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),H(this,"isValidAuthenticate",s=>{const{chains:n,uri:r,domain:i,nonce:o}=s;if(!Array.isArray(n)||n.length===0)throw new Error("chains is required and must be a non-empty array");if(!ot(r,!1))throw new Error("uri is required parameter");if(!ot(i,!1))throw new Error("domain is required parameter");if(!ot(o,!1))throw new Error("nonce is required parameter");if([...new Set(n.map(c=>vn(c).namespace))].length>1)throw new Error("Multi-namespace requests are not supported. Please request single namespace only.");const{namespace:a}=vn(n[0]);if(a!=="eip155")throw new Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),H(this,"getVerifyContext",async s=>{const{attestationId:n,hash:r,encryptedId:i,metadata:o,transportType:a}=s,c={verified:{verifyUrl:o.verifyUrl||qi,validation:"UNKNOWN",origin:o.url||""}};try{if(a===Ke.link_mode){const d=this.getAppLinkIfEnabled(o,a);return c.verified.validation=d&&new URL(d).origin===new URL(o.url).origin?"VALID":"INVALID",c}const l=await this.client.core.verify.resolve({attestationId:n,hash:r,encryptedId:i,verifyUrl:o.verifyUrl});l&&(c.verified.origin=l.origin,c.verified.isScam=l.isScam,c.verified.validation=l.origin===new URL(o.url).origin?"VALID":"INVALID")}catch(l){this.client.logger.warn(l)}return this.client.logger.debug(`Verify context: ${JSON.stringify(c)}`),c}),H(this,"validateSessionProps",(s,n)=>{Object.values(s).forEach((r,i)=>{if(r==null){const{message:o}=Y("MISSING_OR_INVALID",`${n} must contain an existing value for each key. Received: ${r} for key ${Object.keys(s)[i]}`);throw new Error(o)}})}),H(this,"getPendingAuthRequest",s=>{const n=this.client.auth.requests.get(s);return typeof n=="object"?n:void 0}),H(this,"addToRecentlyDeleted",(s,n)=>{if(this.recentlyDeletedMap.set(s,n),this.recentlyDeletedMap.size>=this.recentlyDeletedLimit){let r=0;const i=this.recentlyDeletedLimit/2;for(const o of this.recentlyDeletedMap.keys()){if(r++>=i)break;this.recentlyDeletedMap.delete(o)}}}),H(this,"checkRecentlyDeleted",s=>{const n=this.recentlyDeletedMap.get(s);if(n){const{message:r}=Y("MISSING_OR_INVALID",`Record was recently deleted - ${n}: ${s}`);throw new Error(r)}}),H(this,"isLinkModeEnabled",(s,n)=>{var r,i,o,a,c,l,d,u,h;return!s||n!==Ke.link_mode?!1:((i=(r=this.client.metadata)==null?void 0:r.redirect)==null?void 0:i.linkMode)===!0&&((a=(o=this.client.metadata)==null?void 0:o.redirect)==null?void 0:a.universal)!==void 0&&((l=(c=this.client.metadata)==null?void 0:c.redirect)==null?void 0:l.universal)!==""&&((d=s==null?void 0:s.redirect)==null?void 0:d.universal)!==void 0&&((u=s==null?void 0:s.redirect)==null?void 0:u.universal)!==""&&((h=s==null?void 0:s.redirect)==null?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(s.redirect.universal)&&typeof(Ns==null?void 0:Ns.Linking)<"u"}),H(this,"getAppLinkIfEnabled",(s,n)=>{var r;return this.isLinkModeEnabled(s,n)?(r=s==null?void 0:s.redirect)==null?void 0:r.universal:void 0}),H(this,"handleLinkModeMessage",({url:s})=>{if(!s||!s.includes("wc_ev")||!s.includes("topic"))return;const n=vh(s,"topic")||"",r=decodeURIComponent(vh(s,"wc_ev")||""),i=this.client.session.keys.includes(n);i&&this.client.session.update(n,{transportType:Ke.link_mode}),this.client.core.dispatchEnvelope({topic:n,message:r,sessionExists:i})}),H(this,"registerLinkModeListeners",async()=>{var s;if(Ld()||tr()&&(s=this.client.metadata.redirect)!=null&&s.linkMode){const n=Ns==null?void 0:Ns.Linking;if(typeof n<"u"){n.addEventListener("url",this.handleLinkModeMessage,this.client.name);const r=await n.getInitialURL();r&&setTimeout(()=>{this.handleLinkModeMessage({url:r})},50)}}}),H(this,"getTVFApproveParams",s=>{try{const n=Rm(s.namespaces),r=rN(s.namespaces),i=iN(s.namespaces),o=s.sessionProperties,a=s.scopedProperties;return{approvedChains:n,approvedMethods:r,approvedEvents:i,sessionProperties:o,scopedProperties:a}}catch(n){return this.client.logger.warn(n,"Error getting TVF approve params"),{}}}),H(this,"getTVFParams",(s,n,r)=>{var i,o,a;if(!((i=n.request)!=null&&i.method))return{};const c={correlationId:s,rpcMethods:[n.request.method],chainId:n.chainId};try{const l=this.extractTxHashesFromResult(n.request,r);c.txHashes=l,c.contractAddresses=this.isValidContractData(n.request.params)?[(a=(o=n.request.params)==null?void 0:o[0])==null?void 0:a.to]:[]}catch(l){this.client.logger.warn(l,"Error getting TVF params")}return c}),H(this,"isValidContractData",s=>{var n;if(!s)return!1;try{const r=(s==null?void 0:s.data)||((n=s==null?void 0:s[0])==null?void 0:n.data);if(!r.startsWith("0x"))return!1;const i=r.slice(2);return/^[0-9a-fA-F]*$/.test(i)?i.length%2===0:!1}catch{}return!1}),H(this,"extractTxHashesFromResult",(s,n)=>{var r;try{if(!n)return[];const i=s.method,o=LO[i];if(i==="sui_signTransaction")return[KA(n.transactionBytes)];if(i==="near_signTransaction")return[Rh(n)];if(i==="near_signTransactions")return n.map(c=>Rh(c));if(i==="xrpl_signTransactionFor"||i==="xrpl_signTransaction")return[(r=n.tx_json)==null?void 0:r.hash];if(i==="polkadot_signTransaction")return[YN({transaction:s.params.transactionPayload,signature:n.signature})];if(i==="algo_signTxn")return _n(n)?n.map(c=>Oh(c)):[Oh(n)];if(i==="cosmos_signDirect")return[YA(n)];if(i==="wallet_sendCalls")return ZA(n);if(typeof n=="string")return[n];const a=n[o.key];if(_n(a))return i==="solana_signAllTransactions"?a.map(c=>VA(c)):a;if(typeof a=="string")return[a]}catch(i){this.client.logger.warn(i,"Error extracting tx hashes from result")}return[]})}async processPendingMessageEvents(){try{const e=this.client.session.keys,s=this.client.core.relayer.messages.getWithoutAck(e);for(const[n,r]of Object.entries(s))for(const i of r)try{await this.onProviderMessageEvent({topic:n,message:i,publishedAt:Date.now()})}catch{this.client.logger.warn(`Error processing pending message event for topic: ${n}, message: ${i}`)}}catch(e){this.client.logger.warn(e,"processPendingMessageEvents failed")}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(it.message,e=>{this.onProviderMessageEvent(e)})}async onRelayMessage(e){const{topic:s,message:n,attestation:r,transportType:i}=e,{publicKey:o}=this.client.auth.authKeys.keys.includes(Ea)?this.client.auth.authKeys.get(Ea):{publicKey:void 0};try{const a=await this.client.core.crypto.decode(s,n,{receiverPublicKey:o,encoding:i===Ke.link_mode?qn:Zt});_d(a)?(this.client.core.history.set(s,a),await this.onRelayEventRequest({topic:s,payload:a,attestation:r,transportType:i,encryptedId:Es(n)})):Ad(a)?(await this.client.core.history.resolve(a),await this.onRelayEventResponse({topic:s,payload:a,transportType:i}),this.client.core.history.delete(s,a.id)):(this.client.logger.error(`onRelayMessage() -> unknown payload: ${JSON.stringify(a)}`),await this.onRelayEventUnknownPayload({topic:s,payload:a,transportType:i})),await this.client.core.relayer.messages.ack(s,n)}catch(a){this.client.logger.error(`onRelayMessage() -> failed to process an inbound message: ${n}`),this.client.logger.error(a)}}registerExpirerEvents(){this.client.core.expirer.on(ys.expired,async e=>{const{topic:s,id:n}=Og(e.target);if(n&&this.client.pendingRequest.keys.includes(n))return await this.deletePendingSessionRequest(n,Y("EXPIRED"),!0);if(n&&this.client.auth.requests.keys.includes(n))return await this.deletePendingAuthRequest(n,Y("EXPIRED"),!0);s?this.client.session.keys.includes(s)&&(await this.deleteSession({topic:s,expirerHasDeleted:!0}),this.client.events.emit("session_expire",{topic:s})):n&&(await this.deleteProposal(n,!0),this.client.events.emit("proposal_expire",{id:n}))})}registerPairingEvents(){this.client.core.pairing.events.on(ur.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(ur.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!ot(e,!1)){const{message:s}=Y("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw new Error(s)}if(!this.client.core.pairing.pairings.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.core.pairing.pairings.get(e).expiry)){const{message:s}=Y("EXPIRED",`pairing topic: ${e}`);throw new Error(s)}}async isValidSessionTopic(e){if(!ot(e,!1)){const{message:s}=Y("MISSING_OR_INVALID",`session topic should be a string: ${e}`);throw new Error(s)}if(this.checkRecentlyDeleted(e),!this.client.session.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});const{message:s}=Y("EXPIRED",`session topic: ${e}`);throw new Error(s)}if(!this.client.core.crypto.keychain.has(e)){const{message:s}=Y("MISSING_OR_INVALID",`session topic does not exist in keychain: ${e}`);throw await this.deleteSession({topic:e}),new Error(s)}}async isValidSessionOrPairingTopic(e){if(this.checkRecentlyDeleted(e),this.client.session.keys.includes(e))await this.isValidSessionTopic(e);else if(this.client.core.pairing.pairings.keys.includes(e))this.isValidPairingTopic(e);else if(ot(e,!1)){const{message:s}=Y("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw new Error(s)}else{const{message:s}=Y("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw new Error(s)}}async isValidProposalId(e){if(!SN(e)){const{message:s}=Y("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw new Error(s)}if(!this.client.proposal.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);const{message:s}=Y("EXPIRED",`proposal id: ${e}`);throw new Error(s)}}validateRequestExpiry(e){if(e&&!UN(e,ol)){const{message:s}=Y("MISSING_OR_INVALID",`request() expiry: ${e}. Expiry must be a number (in seconds) between ${ol.min} and ${ol.max}`);throw new Error(s)}}}class JO extends Lr{constructor(e,s){super(e,s,UO,Yd),this.core=e,this.logger=s}}let XO=class extends Lr{constructor(e,s){super(e,s,$O,Yd),this.core=e,this.logger=s}};class QO extends Lr{constructor(e,s){super(e,s,MO,Yd,n=>n.id),this.core=e,this.logger=s}}class eP extends Lr{constructor(e,s){super(e,s,qO,Ec,()=>Ea),this.core=e,this.logger=s}}class tP extends Lr{constructor(e,s){super(e,s,WO,Ec),this.core=e,this.logger=s}}class sP extends Lr{constructor(e,s){super(e,s,HO,Ec,n=>n.id),this.core=e,this.logger=s}}var nP=Object.defineProperty,rP=(t,e,s)=>e in t?nP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,al=(t,e,s)=>rP(t,typeof e!="symbol"?e+"":e,s);class iP{constructor(e,s){this.core=e,this.logger=s,al(this,"authKeys"),al(this,"pairingTopics"),al(this,"requests"),this.authKeys=new eP(this.core,this.logger),this.pairingTopics=new tP(this.core,this.logger),this.requests=new sP(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var oP=Object.defineProperty,aP=(t,e,s)=>e in t?oP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Re=(t,e,s)=>aP(t,typeof e!="symbol"?e+"":e,s);class Zd extends GC{constructor(e){super(e),Re(this,"protocol",Ym),Re(this,"version",Zm),Re(this,"name",il.name),Re(this,"metadata"),Re(this,"core"),Re(this,"logger"),Re(this,"events",new xr.EventEmitter),Re(this,"engine"),Re(this,"session"),Re(this,"proposal"),Re(this,"pendingRequest"),Re(this,"auth"),Re(this,"signConfig"),Re(this,"on",(n,r)=>this.events.on(n,r)),Re(this,"once",(n,r)=>this.events.once(n,r)),Re(this,"off",(n,r)=>this.events.off(n,r)),Re(this,"removeListener",(n,r)=>this.events.removeListener(n,r)),Re(this,"removeAllListeners",n=>this.events.removeAllListeners(n)),Re(this,"connect",async n=>{try{return await this.engine.connect(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"pair",async n=>{try{return await this.engine.pair(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"approve",async n=>{try{return await this.engine.approve(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"reject",async n=>{try{return await this.engine.reject(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"update",async n=>{try{return await this.engine.update(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"extend",async n=>{try{return await this.engine.extend(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"request",async n=>{try{return await this.engine.request(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"respond",async n=>{try{return await this.engine.respond(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"ping",async n=>{try{return await this.engine.ping(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"emit",async n=>{try{return await this.engine.emit(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"disconnect",async n=>{try{return await this.engine.disconnect(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"find",n=>{try{return this.engine.find(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(n){throw this.logger.error(n.message),n}}),Re(this,"authenticate",async(n,r)=>{try{return await this.engine.authenticate(n,r)}catch(i){throw this.logger.error(i.message),i}}),Re(this,"formatAuthMessage",n=>{try{return this.engine.formatAuthMessage(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"approveSessionAuthenticate",async n=>{try{return await this.engine.approveSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"rejectSessionAuthenticate",async n=>{try{return await this.engine.rejectSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),this.name=(e==null?void 0:e.name)||il.name,this.metadata=B0(e==null?void 0:e.metadata),this.signConfig=e==null?void 0:e.signConfig;const s=Gd({logger:(e==null?void 0:e.logger)||il.logger,name:this.name});this.logger=s,this.core=(e==null?void 0:e.core)||new kO(e),this.session=new XO(this.core,this.logger),this.proposal=new JO(this.core,this.logger),this.pendingRequest=new QO(this.core,this.logger),this.engine=new ZO(this),this.auth=new iP(this.core,this.logger)}static async init(e){const s=new Zd(e);return await s.initialize(),s}get context(){return es(this.logger)}get pairing(){return this.core.pairing.pairings}async initialize(){this.logger.trace("Initialized");try{await this.core.start(),await this.session.init(),await this.proposal.init(),await this.pendingRequest.init(),await this.auth.init(),await this.engine.init(),this.logger.info("SignClient Initialization Success")}catch(e){throw this.logger.info("SignClient Initialization Failure"),this.logger.error(e.message),e}}}const cP=Zd;function Jd(t){return t==null||typeof t!="object"&&typeof t!="function"}function Xm(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function Qm(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const lP="[object RegExp]",ey="[object String]",ty="[object Number]",sy="[object Boolean]",ny="[object Arguments]",dP="[object Symbol]",uP="[object Date]",hP="[object Map]",pP="[object Set]",fP="[object Array]",gP="[object ArrayBuffer]",mP="[object Object]",yP="[object DataView]",wP="[object Uint8Array]",EP="[object Uint8ClampedArray]",bP="[object Uint16Array]",vP="[object Uint32Array]",CP="[object Int8Array]",_P="[object Int16Array]",AP="[object Int32Array]",SP="[object Float32Array]",IP="[object Float64Array]";function Xd(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)}function NP(t,e){return Qr(t,void 0,t,new Map,e)}function Qr(t,e,s,n=new Map,r=void 0){const i=r==null?void 0:r(t,e,s,n);if(i!=null)return i;if(Jd(t))return t;if(n.has(t))return n.get(t);if(Array.isArray(t)){const o=new Array(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=Qr(t[a],a,s,n,r);return Object.hasOwn(t,"index")&&(o.index=t.index),Object.hasOwn(t,"input")&&(o.input=t.input),o}if(t instanceof Date)return new Date(t.getTime());if(t instanceof RegExp){const o=new RegExp(t.source,t.flags);return o.lastIndex=t.lastIndex,o}if(t instanceof Map){const o=new Map;n.set(t,o);for(const[a,c]of t)o.set(a,Qr(c,a,s,n,r));return o}if(t instanceof Set){const o=new Set;n.set(t,o);for(const a of t)o.add(Qr(a,void 0,s,n,r));return o}if(typeof Ue<"u"&&Ue.isBuffer(t))return t.subarray();if(Xd(t)){const o=new(Object.getPrototypeOf(t)).constructor(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=Qr(t[a],a,s,n,r);return o}if(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer)return t.slice(0);if(t instanceof DataView){const o=new DataView(t.buffer.slice(0),t.byteOffset,t.byteLength);return n.set(t,o),hr(o,t,s,n,r),o}if(typeof File<"u"&&t instanceof File){const o=new File([t],t.name,{type:t.type});return n.set(t,o),hr(o,t,s,n,r),o}if(t instanceof Blob){const o=new Blob([t],{type:t.type});return n.set(t,o),hr(o,t,s,n,r),o}if(t instanceof Error){const o=new t.constructor;return n.set(t,o),o.message=t.message,o.name=t.name,o.stack=t.stack,o.cause=t.cause,hr(o,t,s,n,r),o}if(typeof t=="object"&&TP(t)){const o=Object.create(Object.getPrototypeOf(t));return n.set(t,o),hr(o,t,s,n,r),o}return t}function hr(t,e,s=t,n,r){const i=[...Object.keys(e),...Xm(e)];for(let o=0;o<i.length;o++){const a=i[o],c=Object.getOwnPropertyDescriptor(t,a);(c==null||c.writable)&&(t[a]=Qr(e[a],a,s,n,r))}}function TP(t){switch(Qm(t)){case ny:case fP:case gP:case yP:case sy:case uP:case SP:case IP:case CP:case _P:case AP:case hP:case ty:case mP:case lP:case pP:case ey:case dP:case wP:case EP:case bP:case vP:return!0;default:return!1}}function RP(t,e){return NP(t,(s,n,r,i)=>{if(typeof t=="object")switch(Object.prototype.toString.call(t)){case ty:case ey:case sy:{const o=new t.constructor(t==null?void 0:t.valueOf());return hr(o,t),o}case ny:{const o={};return hr(o,t),o.length=t.length,o[Symbol.iterator]=t[Symbol.iterator],o}default:return}})}function jp(t){return RP(t)}function Fp(t){return t!==null&&typeof t=="object"&&Qm(t)==="[object Arguments]"}function qp(t){return typeof t=="object"&&t!==null}function OP(){}function PP(t){return Xd(t)}function xP(t){var s;if(typeof t!="object"||t==null)return!1;if(Object.getPrototypeOf(t)===null)return!0;if(Object.prototype.toString.call(t)!=="[object Object]"){const n=t[Symbol.toStringTag];return n==null||!((s=Object.getOwnPropertyDescriptor(t,Symbol.toStringTag))!=null&&s.writable)?!1:t.toString()===`[object ${n}]`}let e=t;for(;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(t)===e}function kP(t){if(Jd(t))return t;if(Array.isArray(t)||Xd(t)||t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer)return t.slice(0);const e=Object.getPrototypeOf(t),s=e.constructor;if(t instanceof Date||t instanceof Map||t instanceof Set)return new s(t);if(t instanceof RegExp){const n=new s(t);return n.lastIndex=t.lastIndex,n}if(t instanceof DataView)return new s(t.buffer.slice(0));if(t instanceof Error){const n=new s(t.message);return n.stack=t.stack,n.name=t.name,n.cause=t.cause,n}if(typeof File<"u"&&t instanceof File)return new s([t],t.name,{type:t.type,lastModified:t.lastModified});if(typeof t=="object"){const n=Object.create(e);return Object.assign(n,t)}return t}function UP(t,...e){const s=e.slice(0,-1),n=e[e.length-1];let r=t;for(let i=0;i<s.length;i++){const o=s[i];r=gd(r,o,n,new Map)}return r}function gd(t,e,s,n){if(Jd(t)&&(t=Object(t)),e==null||typeof e!="object")return t;if(n.has(e))return kP(n.get(e));if(n.set(e,t),Array.isArray(e)){e=e.slice();for(let i=0;i<e.length;i++)e[i]=e[i]??void 0}const r=[...Object.keys(e),...Xm(e)];for(let i=0;i<r.length;i++){const o=r[i];let a=e[o],c=t[o];if(Fp(a)&&(a={...a}),Fp(c)&&(c={...c}),typeof Ue<"u"&&Ue.isBuffer(a)&&(a=jp(a)),Array.isArray(a))if(typeof c=="object"&&c!=null){const d=[],u=Reflect.ownKeys(c);for(let h=0;h<u.length;h++){const p=u[h];d[p]=c[p]}c=d}else c=[];const l=s(c,a,o,t,e,n);l!=null?t[o]=l:Array.isArray(a)||qp(c)&&qp(a)?t[o]=gd(c,a,s,n):c==null&&xP(a)?t[o]=gd({},a,s,n):c==null&&PP(a)?t[o]=jp(a):(c===void 0||a!==void 0)&&(t[o]=a)}return t}function $P(t,...e){return UP(t,...e,OP)}const Wp="error",DP="wss://relay.walletconnect.org",LP="wc",ry="universal_provider",na=`${LP}@2:${ry}:`,iy="https://rpc.walletconnect.org/v1/",oy="generic",MP=`${iy}bundler`,ri="call_status",BP=86400,Qd={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};var jP=Object.defineProperty,FP=Object.defineProperties,qP=Object.getOwnPropertyDescriptors,Hp=Object.getOwnPropertySymbols,WP=Object.prototype.hasOwnProperty,HP=Object.prototype.propertyIsEnumerable,zp=(t,e,s)=>e in t?jP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ra=(t,e)=>{for(var s in e||(e={}))WP.call(e,s)&&zp(t,s,e[s]);if(Hp)for(var s of Hp(e))HP.call(e,s)&&zp(t,s,e[s]);return t},zP=(t,e)=>FP(t,qP(e));function ay(t,e,s){var n;const r=vn(t);return((n=e.rpcMap)==null?void 0:n[r.reference])||`${iy}?chainId=${r.namespace}:${r.reference}&projectId=${s}`}function VP(t){return t.includes(":")?t.split(":")[1]:t}function cy(t){return t.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function KP(t,e){const s=Object.keys(e.namespaces).filter(r=>r.includes(t));if(!s.length)return[];const n=[];return s.forEach(r=>{const i=e.namespaces[r].accounts;n.push(...i)}),n}function Vp(t){return Object.fromEntries(Object.entries(t).filter(([e,s])=>{var n,r;return((n=s==null?void 0:s.chains)==null?void 0:n.length)&&((r=s==null?void 0:s.chains)==null?void 0:r.length)>0}))}function ia(t={},e={}){const s=Vp(Kp(t)),n=Vp(Kp(e));return $P(s,n)}function Kp(t){var e,s,n,r,i;const o={};if(!Xs(t))return o;for(const[a,c]of Object.entries(t)){const l=yc(a)?[a]:c.chains,d=c.methods||[],u=c.events||[],h=c.rpcMap||{},p=Xr(a);o[p]=zP(ra(ra({},o[p]),c),{chains:Js(l,(e=o[p])==null?void 0:e.chains),methods:Js(d,(s=o[p])==null?void 0:s.methods),events:Js(u,(n=o[p])==null?void 0:n.events)}),(Xs(h)||Xs(((r=o[p])==null?void 0:r.rpcMap)||{}))&&(o[p].rpcMap=ra(ra({},h),(i=o[p])==null?void 0:i.rpcMap))}return o}function Gp(t){return t.includes(":")?t.split(":")[2]:t}function Yp(t){const e={};for(const[s,n]of Object.entries(t)){const r=n.methods||[],i=n.events||[],o=n.accounts||[],a=yc(s)?[s]:n.chains?n.chains:cy(n.accounts);e[s]={chains:a,methods:r,events:i,accounts:o}}return e}function cl(t){return typeof t=="number"?t:t.includes("0x")?parseInt(t,16):(t=t.includes(":")?t.split(":")[1]:t,isNaN(Number(t))?t:Number(t))}function GP(t){try{const e=JSON.parse(t);return typeof e=="object"&&e!==null&&!Array.isArray(e)}catch{return!1}}const ly={},ii=t=>ly[t],ll=(t,e)=>{ly[t]=e};var YP=Object.defineProperty,Zp=Object.getOwnPropertySymbols,ZP=Object.prototype.hasOwnProperty,JP=Object.prototype.propertyIsEnumerable,Jp=(t,e,s)=>e in t?YP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xp=(t,e)=>{for(var s in e||(e={}))ZP.call(e,s)&&Jp(t,s,e[s]);if(Zp)for(var s of Zp(e))JP.call(e,s)&&Jp(t,s,e[s]);return t};const Qp="eip155",XP=["atomic","flow-control","paymasterService","sessionKeys","auxiliaryFunds"],QP=t=>t&&t.startsWith("0x")?BigInt(t).toString(10):t,dl=t=>t&&t.startsWith("0x")?t:`0x${BigInt(t).toString(16)}`,ef=t=>Object.keys(t).filter(e=>XP.includes(e)).reduce((e,s)=>(e[s]=ex(t[s]),e),{}),ex=t=>typeof t=="string"&&GP(t)?JSON.parse(t):t,tx=(t,e,s)=>{const{sessionProperties:n={},scopedProperties:r={}}=t,i={};if(!Xs(r)&&!Xs(n))return;const o=ef(n);for(const a of s){const c=QP(a);if(!c)continue;i[dl(c)]=o;const l=r==null?void 0:r[`${Qp}:${c}`];if(l){const d=l==null?void 0:l[`${Qp}:${c}:${e}`];i[dl(c)]=Xp(Xp({},i[dl(c)]),ef(d||l))}}for(const[a,c]of Object.entries(i))Object.keys(c).length===0&&delete i[a];return Object.keys(i).length>0?i:void 0};var sx=Object.defineProperty,nx=(t,e,s)=>e in t?sx(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,rx=(t,e,s)=>nx(t,e+"",s);let ul;class eu{constructor(e){rx(this,"storage"),this.storage=e}async getItem(e){return await this.storage.getItem(e)}async setItem(e,s){return await this.storage.setItem(e,s)}async removeItem(e){return await this.storage.removeItem(e)}static getStorage(e){return ul||(ul=new eu(e)),ul}}var ix=Object.defineProperty,ox=Object.defineProperties,ax=Object.getOwnPropertyDescriptors,tf=Object.getOwnPropertySymbols,cx=Object.prototype.hasOwnProperty,lx=Object.prototype.propertyIsEnumerable,sf=(t,e,s)=>e in t?ix(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,dx=(t,e)=>{for(var s in e||(e={}))cx.call(e,s)&&sf(t,s,e[s]);if(tf)for(var s of tf(e))lx.call(e,s)&&sf(t,s,e[s]);return t},ux=(t,e)=>ox(t,ax(e));async function hx(t,e){const s=vn(t.result.capabilities.caip345.caip2),n=t.result.capabilities.caip345.transactionHashes,r=await Promise.allSettled(n.map(u=>px(s.reference,u,e))),i=r.filter(u=>u.status==="fulfilled").map(u=>u.value).filter(u=>u);r.filter(u=>u.status==="rejected").forEach(u=>console.warn("Failed to fetch transaction receipt:",u.reason));const o=!i.length||i.some(u=>!u),a=i.every(u=>(u==null?void 0:u.status)==="0x1"),c=i.every(u=>(u==null?void 0:u.status)==="0x0"),l=i.some(u=>(u==null?void 0:u.status)==="0x0");let d;return o?d=100:a?d=200:c?d=500:l&&(d=600),{id:t.result.id,version:t.request.version,atomic:t.request.atomicRequired,chainId:t.request.chainId,capabilities:t.result.capabilities,receipts:i,status:d}}async function px(t,e,s){return await s(parseInt(t)).request(zs("eth_getTransactionReceipt",[e]))}async function fx({sendCalls:t,storage:e}){const s=await e.getItem(ri);await e.setItem(ri,ux(dx({},s),{[t.result.id]:{request:t.request,result:t.result,expiry:rt(BP)}}))}async function gx({resultId:t,storage:e}){const s=await e.getItem(ri);if(s){delete s[t],await e.setItem(ri,s);for(const n in s)Vs(s[n].expiry)&&delete s[n];await e.setItem(ri,s)}}async function mx({resultId:t,storage:e}){const s=await e.getItem(ri),n=s==null?void 0:s[t];if(n&&!Vs(n.expiry))return n;await gx({resultId:t,storage:e})}var yx=Object.defineProperty,wx=Object.defineProperties,Ex=Object.getOwnPropertyDescriptors,nf=Object.getOwnPropertySymbols,bx=Object.prototype.hasOwnProperty,vx=Object.prototype.propertyIsEnumerable,md=(t,e,s)=>e in t?yx(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,hl=(t,e)=>{for(var s in e||(e={}))bx.call(e,s)&&md(t,s,e[s]);if(nf)for(var s of nf(e))vx.call(e,s)&&md(t,s,e[s]);return t},pl=(t,e)=>wx(t,Ex(e)),or=(t,e,s)=>md(t,typeof e!="symbol"?e+"":e,s);class Cx{constructor(e){or(this,"name","eip155"),or(this,"client"),or(this,"chainId"),or(this,"namespace"),or(this,"httpProviders"),or(this,"events"),or(this,"storage"),this.namespace=e.namespace,this.events=ii("events"),this.client=ii("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain()),this.storage=eu.getStorage(this.client.core.storage)}async request(e){switch(e.request.method){case"eth_requestAccounts":return this.getAccounts();case"eth_accounts":return this.getAccounts();case"wallet_switchEthereumChain":return await this.handleSwitchChain(e);case"eth_chainId":return parseInt(this.getDefaultChain());case"wallet_getCapabilities":return await this.getCapabilities(e);case"wallet_getCallsStatus":return await this.getCallStatus(e);case"wallet_sendCalls":return await this.sendCalls(e)}return this.namespace.methods.includes(e.request.method)?await this.client.request(e):this.getHttpProvider().request(e.request)}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}setDefaultChain(e,s){this.httpProviders[e]||this.setHttpProvider(parseInt(e),s);const n=this.chainId;this.chainId=parseInt(e),this.events.emit(Qd.DEFAULT_CHAIN_CHANGED,{currentCaipChainId:`${this.name}:${e}`,previousCaipChainId:`${this.name}:${n}`})}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId.toString();if(this.namespace.defaultChain)return this.namespace.defaultChain;const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return e.split(":")[1]}createHttpProvider(e,s){const n=s||ay(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Cd(new _f(n,ii("disableProviderPing")))}setHttpProvider(e,s){const n=this.createHttpProvider(e,s);n&&(this.httpProviders[e]=n)}createHttpProviders(){const e={};return this.namespace.chains.forEach(s=>{var n;const r=parseInt(VP(s));e[r]=this.createHttpProvider(r,(n=this.namespace.rpcMap)==null?void 0:n[s])}),e}getAccounts(){const e=this.namespace.accounts;return e?[...new Set(e.filter(s=>s.split(":")[1]===this.chainId.toString()).map(s=>s.split(":")[2]))]:[]}getHttpProvider(e){const s=e||this.chainId;return this.httpProviders[s]||(this.httpProviders=pl(hl({},this.httpProviders),{[s]:this.createHttpProvider(s)}),this.httpProviders[s])}async handleSwitchChain(e){var s,n;let r=e.request.params?(s=e.request.params[0])==null?void 0:s.chainId:"0x0";r=r.startsWith("0x")?r:`0x${r}`;const i=parseInt(r,16);if(this.isChainApproved(i))this.setDefaultChain(`${i}`);else if(this.namespace.methods.includes("wallet_switchEthereumChain"))await this.client.request({topic:e.topic,request:{method:e.request.method,params:[{chainId:r}]},chainId:(n=this.namespace.chains)==null?void 0:n[0]}),this.setDefaultChain(`${i}`);else throw new Error(`Failed to switch to chain 'eip155:${i}'. The chain is not approved or the wallet does not support 'wallet_switchEthereumChain' method.`);return null}isChainApproved(e){return this.namespace.chains.includes(`${this.name}:${e}`)}async getCapabilities(e){var s,n,r,i,o;const a=(n=(s=e.request)==null?void 0:s.params)==null?void 0:n[0],c=((i=(r=e.request)==null?void 0:r.params)==null?void 0:i[1])||[];if(!a)throw new Error("Missing address parameter in `wallet_getCapabilities` request");const l=this.client.session.get(e.topic),d=((o=l==null?void 0:l.sessionProperties)==null?void 0:o.capabilities)||{},u=`${a}${c.join(",")}`,h=d==null?void 0:d[u];if(h)return h;let p;try{p=tx(l,a,c)}catch(f){console.warn("Failed to extract capabilities from session",f)}if(p)return p;const g=await this.client.request(e);try{await this.client.session.update(e.topic,{sessionProperties:pl(hl({},l.sessionProperties||{}),{capabilities:pl(hl({},d||{}),{[u]:g})})})}catch(f){console.warn("Failed to update session with capabilities",f)}return g}async getCallStatus(e){var s,n,r;const i=this.client.session.get(e.topic),o=(s=i.sessionProperties)==null?void 0:s.bundler_name;if(o){const l=this.getBundlerUrl(e.chainId,o);try{return await this.getUserOperationReceipt(l,e)}catch(d){console.warn("Failed to fetch call status from bundler",d,l)}}const a=(n=i.sessionProperties)==null?void 0:n.bundler_url;if(a)try{return await this.getUserOperationReceipt(a,e)}catch(l){console.warn("Failed to fetch call status from custom bundler",l,a)}const c=await mx({resultId:(r=e.request.params)==null?void 0:r[0],storage:this.storage});if(c)try{return await hx(c,this.getHttpProvider.bind(this))}catch(l){console.warn("Failed to fetch call status from stored send calls",l,c)}if(this.namespace.methods.includes(e.request.method))return await this.client.request(e);throw new Error("Fetching call status not approved by the wallet.")}async getUserOperationReceipt(e,s){var n;const r=new URL(e),i=await fetch(r,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(zs("eth_getUserOperationReceipt",[(n=s.request.params)==null?void 0:n[0]]))});if(!i.ok)throw new Error(`Failed to fetch user operation receipt - ${i.status}`);return await i.json()}getBundlerUrl(e,s){return`${MP}?projectId=${this.client.core.projectId}&chainId=${e}&bundler=${s}`}async sendCalls(e){var s,n,r;const i=await this.client.request(e),o=(s=e.request.params)==null?void 0:s[0],a=i==null?void 0:i.id,c=(i==null?void 0:i.capabilities)||{},l=(n=c==null?void 0:c.caip345)==null?void 0:n.caip2,d=(r=c==null?void 0:c.caip345)==null?void 0:r.transactionHashes;return!a||!l||!(d!=null&&d.length)||await fx({sendCalls:{request:o,result:i},storage:this.storage}),i}}var _x=Object.defineProperty,Ax=(t,e,s)=>e in t?_x(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,zr=(t,e,s)=>Ax(t,typeof e!="symbol"?e+"":e,s);class Sx{constructor(e){zr(this,"name",oy),zr(this,"client"),zr(this,"httpProviders"),zr(this,"events"),zr(this,"namespace"),zr(this,"chainId"),this.namespace=e.namespace,this.events=ii("events"),this.client=ii("client"),this.chainId=this.getDefaultChain(),this.name=this.getNamespaceName(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace.chains=[...new Set((this.namespace.chains||[]).concat(e.chains||[]))],this.namespace.accounts=[...new Set((this.namespace.accounts||[]).concat(e.accounts||[]))],this.namespace.methods=[...new Set((this.namespace.methods||[]).concat(e.methods||[]))],this.namespace.events=[...new Set((this.namespace.events||[]).concat(e.events||[]))],this.httpProviders=this.createHttpProviders()}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider(e.chainId).request(e.request)}setDefaultChain(e,s){this.httpProviders[e]||this.setHttpProvider(e,s);const n=this.chainId;this.chainId=e,this.events.emit(Qd.DEFAULT_CHAIN_CHANGED,{currentCaipChainId:`${this.name}:${e}`,previousCaipChainId:`${this.name}:${n}`})}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return e.split(":")[1]}getNamespaceName(){const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return vn(e).namespace}getAccounts(){const e=this.namespace.accounts;return e?[...new Set(e.filter(s=>s.split(":")[1]===this.chainId.toString()).map(s=>s.split(":")[2]))]:[]}createHttpProviders(){var e,s;const n={};return(s=(e=this.namespace)==null?void 0:e.accounts)==null||s.forEach(r=>{var i,o;const a=vn(r),c=(o=(i=this.namespace)==null?void 0:i.rpcMap)==null?void 0:o[`${a.namespace}:${a.reference}`];n[a.reference]=this.createHttpProvider(r,c)}),n}getHttpProvider(e){const s=vn(e).reference,n=this.httpProviders[s];if(typeof n>"u")throw new Error(`JSON-RPC provider for ${e} not found`);return n}setHttpProvider(e,s){const n=this.createHttpProvider(e,s);n&&(this.httpProviders[e]=n)}createHttpProvider(e,s){const n=s||ay(e,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Cd(new _f(n,ii("disableProviderPing")))}}var Ix=Object.defineProperty,Nx=Object.defineProperties,Tx=Object.getOwnPropertyDescriptors,rf=Object.getOwnPropertySymbols,Rx=Object.prototype.hasOwnProperty,Ox=Object.prototype.propertyIsEnumerable,yd=(t,e,s)=>e in t?Ix(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Oi=(t,e)=>{for(var s in e||(e={}))Rx.call(e,s)&&yd(t,s,e[s]);if(rf)for(var s of rf(e))Ox.call(e,s)&&yd(t,s,e[s]);return t},oa=(t,e)=>Nx(t,Tx(e)),rs=(t,e,s)=>yd(t,typeof e!="symbol"?e+"":e,s);let Px=class dy{constructor(e){rs(this,"client"),rs(this,"namespaces"),rs(this,"optionalNamespaces"),rs(this,"sessionProperties"),rs(this,"scopedProperties"),rs(this,"events",new Sd),rs(this,"rpcProviders",{}),rs(this,"session"),rs(this,"providerOpts"),rs(this,"logger"),rs(this,"uri"),rs(this,"disableProviderPing",!1),rs(this,"connectParams");var s,n;this.providerOpts=e,this.logger=Gd({logger:(s=e.logger)!=null?s:Wp,name:(n=this.providerOpts.name)!=null?n:ry}),this.disableProviderPing=(e==null?void 0:e.disableProviderPing)||!1}static async init(e){const s=new dy(e);return await s.initialize(),s}async request(e,s,n){const[r,i]=this.validateChain(s);if(!this.session)throw new Error("Please call connect() before request()");return await this.getProvider(r).request({request:Oi({},e),chainId:`${r}:${i}`,topic:this.session.topic,expiry:n})}sendAsync(e,s,n,r){const i=new Date().getTime();this.request(e,n,r).then(o=>s(null,Yi(i,o))).catch(o=>s(o,void 0))}async enable(){if(!this.client)throw new Error("Sign Client not initialized");return this.session||await this.connect({namespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties}),await this.requestAccounts()}async disconnect(){var e;if(!this.session)throw new Error("Please call connect() before enable()");await this.client.disconnect({topic:(e=this.session)==null?void 0:e.topic,reason:Ze("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw new Error("Sign Client not initialized");if(this.connectParams=e,this.setNamespaces(e),this.cleanupPendingPairings(),!e.skipPairing)return await this.pair(e.pairingTopic)}async authenticate(e,s){if(!this.client)throw new Error("Sign Client not initialized");this.setNamespaces(e),await this.cleanupPendingPairings();const{uri:n,response:r}=await this.client.authenticate(e,s);n&&(this.uri=n,this.events.emit("display_uri",n));const i=await r();if(this.session=i.session,this.session){const o=Yp(this.session.namespaces);this.namespaces=ia(this.namespaces,o),await this.persist("namespaces",this.namespaces),this.onConnect()}return i}on(e,s){this.events.on(e,s)}once(e,s){this.events.once(e,s)}removeListener(e,s){this.events.removeListener(e,s)}off(e,s){this.events.off(e,s)}get isWalletConnect(){return!0}async pair(e){var s,n;const{uri:r,approval:i}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties,authentication:(s=this.connectParams)==null?void 0:s.authentication,walletPay:(n=this.connectParams)==null?void 0:n.walletPay});r&&(this.uri=r,this.events.emit("display_uri",r));const o=await i();this.session=o;const a=Yp(o.namespaces);return this.namespaces=ia(this.namespaces,a),await this.persist("namespaces",this.namespaces),await this.persist("optionalNamespaces",this.optionalNamespaces),this.onConnect(),this.session}setDefaultChain(e,s){try{if(!this.session)return;const[n,r]=this.validateChain(e);this.getProvider(n).setDefaultChain(r,s)}catch(n){if(!/Please call connect/.test(n.message))throw n}}async cleanupPendingPairings(e={}){try{this.logger.info("Cleaning up inactive pairings...");const s=this.client.pairing.getAll();if(!_n(s))return;for(const n of s)e.deletePairings?this.client.core.expirer.set(n.topic,0):await this.client.core.relayer.subscriber.unsubscribe(n.topic);this.logger.info(`Inactive pairings cleared: ${s.length}`)}catch(s){this.logger.warn(s,"Failed to cleanup pending pairings")}}abortPairingAttempt(){this.logger.warn("abortPairingAttempt is deprecated. This is now a no-op.")}async checkStorage(){this.namespaces=await this.getFromStore("namespaces")||{},this.optionalNamespaces=await this.getFromStore("optionalNamespaces")||{},this.session&&this.createProviders()}async initialize(){this.logger.trace("Initialized"),await this.createClient(),await this.checkStorage(),this.registerEventListeners()}async createClient(){var e,s;if(this.client=this.providerOpts.client||await cP.init({core:this.providerOpts.core,logger:this.providerOpts.logger||Wp,relayUrl:this.providerOpts.relayUrl||DP,projectId:this.providerOpts.projectId,metadata:this.providerOpts.metadata,storageOptions:this.providerOpts.storageOptions,storage:this.providerOpts.storage,name:this.providerOpts.name,customStoragePrefix:this.providerOpts.customStoragePrefix,telemetryEnabled:this.providerOpts.telemetryEnabled}),this.providerOpts.session)try{this.session=this.client.session.get(this.providerOpts.session.topic)}catch(n){throw this.logger.error(n,"Failed to get session"),new Error(`The provided session: ${(s=(e=this.providerOpts)==null?void 0:e.session)==null?void 0:s.topic} doesn't exist in the Sign client`)}else{const n=this.client.session.getAll();this.session=n[0]}this.logger.trace("SignClient Initialized")}createProviders(){if(!this.client)throw new Error("Sign Client not initialized");if(!this.session)throw new Error("Session not initialized. Please call connect() before enable()");const e=[...new Set(Object.keys(this.session.namespaces).map(s=>Xr(s)))];ll("client",this.client),ll("events",this.events),ll("disableProviderPing",this.disableProviderPing),e.forEach(s=>{if(!this.session)return;const n=KP(s,this.session);if((n==null?void 0:n.length)===0)return;const r=cy(n),i=ia(this.namespaces,this.optionalNamespaces),o=oa(Oi({},i[s]),{accounts:n,chains:r});switch(s){case"eip155":this.rpcProviders[s]=new Cx({namespace:o});break;default:this.rpcProviders[s]=new Sx({namespace:o})}})}registerEventListeners(){if(typeof this.client>"u")throw new Error("Sign Client is not initialized");this.client.on("session_ping",e=>{var s;const{topic:n}=e;n===((s=this.session)==null?void 0:s.topic)&&this.events.emit("session_ping",e)}),this.client.on("session_event",e=>{var s;const{params:n,topic:r}=e;if(r!==((s=this.session)==null?void 0:s.topic))return;const{event:i}=n;if(i.name==="accountsChanged"){const o=i.data;o&&_n(o)&&this.events.emit("accountsChanged",o.map(Gp))}else if(i.name==="chainChanged"){const o=n.chainId,a=n.event.data,c=Xr(o),l=cl(o)!==cl(a)?`${c}:${cl(a)}`:o;this.onChainChanged({currentCaipChainId:l})}else this.events.emit(i.name,i.data);this.events.emit("session_event",e)}),this.client.on("session_update",({topic:e,params:s})=>{var n,r;if(e!==((n=this.session)==null?void 0:n.topic))return;const{namespaces:i}=s,o=(r=this.client)==null?void 0:r.session.get(e);this.session=oa(Oi({},o),{namespaces:i}),this.onSessionUpdate(),this.events.emit("session_update",{topic:e,params:s})}),this.client.on("session_delete",async e=>{var s;e.topic===((s=this.session)==null?void 0:s.topic)&&(await this.cleanup(),this.events.emit("session_delete",e),this.events.emit("disconnect",oa(Oi({},Ze("USER_DISCONNECTED")),{data:e.topic})))}),this.on(Qd.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(oa(Oi({},e),{internal:!0}))})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[oy]}onSessionUpdate(){Object.keys(this.rpcProviders).forEach(e=>{var s;this.getProvider(e).updateNamespace((s=this.session)==null?void 0:s.namespaces[e])})}setNamespaces(e){const{namespaces:s={},optionalNamespaces:n={},sessionProperties:r,scopedProperties:i}=e;this.optionalNamespaces=ia(s,n),this.sessionProperties=r,this.scopedProperties=i}validateChain(e){const[s,n]=(e==null?void 0:e.split(":"))||["",""];if(!this.namespaces||!Object.keys(this.namespaces).length)return[s,n];if(s&&!Object.keys(this.namespaces||{}).map(o=>Xr(o)).includes(s))throw new Error(`Namespace '${s}' is not configured. Please call connect() first with namespace config.`);if(s&&n)return[s,n];const r=Xr(Object.keys(this.namespaces)[0]),i=this.rpcProviders[r].getDefaultChain();return[r,i]}async requestAccounts(){const[e]=this.validateChain();return await this.getProvider(e).requestAccounts()}async onChainChanged({currentCaipChainId:e,previousCaipChainId:s,internal:n=!1}){if(!this.namespaces)return;const[r,i]=this.validateChain(e);i&&(this.updateNamespaceChain(r,i),n?(this.events.emit("chainChanged",i),this.emitAccountsChangedOnChainChange({namespace:r,currentCaipChainId:e,previousCaipChainId:s})):this.getProvider(r).setDefaultChain(i),await this.persist("namespaces",this.namespaces))}emitAccountsChangedOnChainChange({namespace:e,currentCaipChainId:s,previousCaipChainId:n}){var r,i;try{if(n===s)return;const o=(i=(r=this.session)==null?void 0:r.namespaces[e])==null?void 0:i.accounts;if(!o)return;const a=o.filter(c=>c.includes(`${s}:`)).map(Gp);if(!_n(a))return;this.events.emit("accountsChanged",a)}catch(o){this.logger.warn(o,"Failed to emit accountsChanged on chain change")}}updateNamespaceChain(e,s){if(!this.namespaces)return;const n=this.namespaces[e]?e:`${e}:${s}`,r={chains:[],methods:[],events:[],defaultChain:s};this.namespaces[n]?this.namespaces[n]&&(this.namespaces[n].defaultChain=s):this.namespaces[n]=r}onConnect(){this.createProviders(),this.events.emit("connect",{session:this.session})}async cleanup(){this.connectParams=void 0,this.namespaces=void 0,this.optionalNamespaces=void 0,this.sessionProperties=void 0,await this.deleteFromStore("namespaces"),await this.deleteFromStore("optionalNamespaces"),await this.deleteFromStore("sessionProperties"),this.session=void 0,this.cleanupPendingPairings({deletePairings:!0}),await this.cleanupStorage()}async persist(e,s){var n;const r=((n=this.session)==null?void 0:n.topic)||"";await this.client.core.storage.setItem(`${na}/${e}${r}`,s)}async getFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";return await this.client.core.storage.getItem(`${na}/${e}${n}`)}async deleteFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";await this.client.core.storage.removeItem(`${na}/${e}${n}`)}async cleanupStorage(){var e;try{if(((e=this.client)==null?void 0:e.session.length)>0)return;const s=await this.client.core.storage.getKeys();for(const n of s)n.startsWith(na)&&await this.client.core.storage.removeItem(n)}catch(s){this.logger.warn(s,"Failed to cleanup storage")}}};const of=2147483648,xx={convertEVMChainIdToCoinType(t){if(t>=of)throw new Error("Invalid chainId");return(of|t)>>>0}},gs=Ge({suggestions:[],loading:!1}),kx={state:gs,subscribe(t){return _t(gs,()=>t(gs))},subscribeKey(t,e){return At(gs,t,e)},async resolveName(t){var e,s;try{return await fe.lookupEnsName(t)}catch(n){const r=n;throw new Error(((s=(e=r==null?void 0:r.reasons)==null?void 0:e[0])==null?void 0:s.description)||"Error resolving name")}},async isNameRegistered(t){try{return await fe.lookupEnsName(t),!0}catch{return!1}},async getSuggestions(t){try{gs.loading=!0,gs.suggestions=[];const e=await fe.getEnsNameSuggestions(t);return gs.suggestions=e.suggestions||[],gs.suggestions}catch(e){const s=Hi.parseEnsApiError(e,"Error fetching name suggestions");throw new Error(s)}finally{gs.loading=!1}},async getNamesForAddress(t){try{if(!E.state.activeCaipNetwork)return[];const s=F.getEnsFromCacheForAddress(t);if(s)return s;const n=await fe.reverseLookupEnsName({address:t});return F.updateEnsCache({address:t,ens:n,timestamp:Date.now()}),n}catch(e){const s=Hi.parseEnsApiError(e,"Error fetching names for address");throw new Error(s)}},async registerName(t){var r;const e=E.state.activeCaipNetwork,s=(r=E.getAccountData(e==null?void 0:e.chainNamespace))==null?void 0:r.address,n=z.getAuthConnector();if(!e)throw new Error("Network not found");if(!s||!n)throw new Error("Address or auth connector not found");gs.loading=!0;try{const i=JSON.stringify({name:t,attributes:{},timestamp:Math.floor(Date.now()/1e3)});ue.pushTransactionStack({onCancel(){ue.replace("RegisterAccountName")}});const o=await G.signMessage(i);gs.loading=!1;const a=e.id;if(!a)throw new Error("Network not found");const c=xx.convertEVMChainIdToCoinType(Number(a));await fe.registerEnsName({coinType:c,address:s,signature:o,message:i}),E.setAccountProp("profileName",t,e.chainNamespace),F.updateEnsCache({address:s,ens:[{name:t,registered_at:new Date().toISOString(),updated_at:void 0,addresses:{},attributes:[]}],timestamp:Date.now()}),ue.replace("RegisterAccountNameSuccess")}catch(i){const o=Hi.parseEnsApiError(i,`Error registering name ${t}`);throw ue.replace("RegisterAccountName"),new Error(o)}finally{gs.loading=!1}},validateName(t){return/^[a-zA-Z0-9-]{4,}$/u.test(t)},parseEnsApiError(t,e){var n,r;const s=t;return((r=(n=s==null?void 0:s.reasons)==null?void 0:n[0])==null?void 0:r.description)||e}},Hi=As(kx);function wd(t){try{return new URL(t)}catch{return null}}function Ux(t){const e=t.split("/"),s=e.length>0&&e[0]!==void 0?e[0]:"",n=s.lastIndexOf(":");return n===-1?{host:s}:{host:s.slice(0,n),port:s.slice(n+1)}}function $x(t){const e=t.indexOf("://");if(e===-1)return null;const s=t.slice(0,e),n=e+3;let r=t.indexOf("/",n);r===-1&&(r=t.length);const i=t.slice(n,r),o=i.lastIndexOf(":");return o===-1?{scheme:s,host:i}:{scheme:s,host:i.slice(0,o),port:i.slice(o+1)}}function Dx(t,e){if(e.includes("://")){const o=wd(e);return o?o.origin===t:!1}const{host:s,port:n}=Ux(e),r=t.indexOf("://");if(r!==-1){const o=r+3;let a=t.indexOf("/",o);a===-1&&(a=t.length);const c=t.slice(o,a);if(n!==void 0)return`${s}:${n}`===c;const l=c.split(":")[0];return s===l}const i=wd(t);return i?n!==void 0?s===i.hostname&&n===(i.port||void 0):s===i.hostname:!1}function Lx(t,e,s){let n=s,r;const i=n.indexOf("://");i!==-1&&(r=n.slice(0,i),n=n.slice(i+3));const o=n.indexOf("/");o!==-1&&(n=n.slice(0,o));let a=n,c;const l=a.lastIndexOf(":");l!==-1&&(c=a.slice(l+1),a=a.slice(0,l));const d=a.split(".");for(const f of d)if(f.includes("*")&&f!=="*")return!1;const u=t.protocol.replace(/:$/u,"");if(r&&r!==u||c!==void 0&&c!=="*"&&c!==t.port)return!1;const h=$x(e),g=(h?h.host:t.hostname).split(".");if(d.length!==g.length)return!1;for(let f=d.length-1;f>=0;f-=1){const y=d[f],_=g[f];if(y!=="*"&&y!==_)return!1}return!0}const Mx={ton:["ton_sendMessage","ton_signData"],solana:["solana_signMessage","solana_signTransaction","solana_requestAccounts","solana_getAccounts","solana_signAllTransactions","solana_signAndSendTransaction"],eip155:["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_showCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],bip122:["sendTransfer","signMessage","signPsbt","getAccountAddresses"]},Kn={RPC_ERROR_CODE:{USER_REJECTED:5e3,USER_REJECTED_METHODS:5002},getMethodsByChainNamespace(t){return Mx[t]||[]},createDefaultNamespace(t){return{methods:this.getMethodsByChainNamespace(t),events:["accountsChanged","chainChanged"],chains:[],rpcMap:{}}},applyNamespaceOverrides(t,e){if(!e)return{...t};const s={...t},n=new Set;if(e.methods&&Object.keys(e.methods).forEach(r=>n.add(r)),e.chains&&Object.keys(e.chains).forEach(r=>n.add(r)),e.events&&Object.keys(e.events).forEach(r=>n.add(r)),e.rpcMap&&Object.keys(e.rpcMap).forEach(r=>{const[i]=r.split(":");i&&n.add(i)}),n.forEach(r=>{s[r]||(s[r]=this.createDefaultNamespace(r))}),e.methods&&Object.entries(e.methods).forEach(([r,i])=>{s[r]&&(s[r].methods=i)}),e.chains&&Object.entries(e.chains).forEach(([r,i])=>{s[r]&&(s[r].chains=i)}),e.events&&Object.entries(e.events).forEach(([r,i])=>{s[r]&&(s[r].events=i)}),e.rpcMap){const r=new Set;Object.entries(e.rpcMap).forEach(([i,o])=>{const[a,c]=i.split(":");!a||!c||!s[a]||(s[a].rpcMap||(s[a].rpcMap={}),r.has(a)||(s[a].rpcMap={},r.add(a)),s[a].rpcMap[c]=o)})}return s},createNamespaces(t,e){const s=t.reduce((n,r)=>{const{id:i,chainNamespace:o,rpcUrls:a}=r,c=a.default.http[0];n[o]||(n[o]=this.createDefaultNamespace(o));const l=`${o}:${i}`,d=n[o];switch(d.chains.push(l),l){case"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":d.chains.push("solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ");break;case"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1":d.chains.push("solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K");break}return d!=null&&d.rpcMap&&c&&(d.rpcMap[i]=c),n},{});return this.applyNamespaceOverrides(s,e)},resolveReownName:async t=>{var n;const e=await Hi.resolveName(t);return((n=(e!=null&&e.addresses?Object.values(e.addresses):[])[0])==null?void 0:n.address)||!1},getChainsFromNamespaces(t={}){return Object.values(t).flatMap(e=>{const s=e.chains||[],n=e.accounts.map(r=>{const[i,o]=r.split(":");return`${i}:${o}`});return Array.from(new Set([...s,...n]))})},isSessionEventData(t){return typeof t=="object"&&t!==null&&"id"in t&&"topic"in t&&"params"in t&&typeof t.params=="object"&&t.params!==null&&"chainId"in t.params&&"event"in t.params&&typeof t.params.event=="object"&&t.params.event!==null},isUserRejectedRequestError(t){try{if(typeof t=="object"&&t!==null){const e=t,s=typeof e.code=="number",n=s&&e.code===Kn.RPC_ERROR_CODE.USER_REJECTED_METHODS,r=s&&e.code===Kn.RPC_ERROR_CODE.USER_REJECTED;return n||r}return!1}catch{return!1}},isOriginAllowed(t,e,s){const n=[...e,...s];if(e.length===0)return!0;const r=wd(t);if(!r)return n.some(i=>!i.includes("*")&&i===t);if(r.hostname==="localhost"||r.hostname==="127.0.0.1")return!0;for(const i of n)if(i.includes("*")){if(Lx(r,t,i))return!0}else if(Dx(t,i))return!0;return!1},listenWcProvider({universalProvider:t,namespace:e,onConnect:s,onDisconnect:n,onAccountsChanged:r,onChainChanged:i,onDisplayUri:o}){s&&t.on("connect",()=>{const a=Kn.getWalletConnectAccounts(t,e);s(a)}),n&&t.on("disconnect",()=>{n()}),r&&t.on("accountsChanged",a=>{var c,l,d,u,h;try{const p=((d=(l=(c=t.session)==null?void 0:c.namespaces)==null?void 0:l[e])==null?void 0:d.accounts)||[],g=(h=(u=t.rpcProviders)==null?void 0:u[e])==null?void 0:h.getDefaultChain(),f=a.map(y=>{const _=p.find(C=>C.includes(`${e}:${g}:${y}`));if(!_)return;const{chainId:S,chainNamespace:v}=dt.parseCaipAddress(_);return{address:y,chainId:S,chainNamespace:v}}).filter(y=>y!==void 0);f.length>0&&r(f)}catch(p){console.warn("Failed to parse accounts for namespace on accountsChanged event",e,a,p)}}),i&&t.on("chainChanged",a=>{i(a)}),o&&t.on("display_uri",a=>{o(a)})},getWalletConnectAccounts(t,e){var r,i,o,a;const s=new Set,n=(a=(o=(i=(r=t==null?void 0:t.session)==null?void 0:r.namespaces)==null?void 0:i[e])==null?void 0:o.accounts)==null?void 0:a.map(c=>dt.parseCaipAddress(c)).filter(({address:c})=>s.has(c.toLowerCase())?!1:(s.add(c.toLowerCase()),!0));return n&&n.length>0?n:[]}},Bx=[U.CONNECTOR_ID.AUTH,U.CONNECTOR_ID.WALLET_CONNECT];class jx{constructor(e){this.availableConnectors=[],this.availableConnections=[],this.providerHandlers={},this.eventListeners=new Map,this.getCaipNetworks=s=>E.getCaipNetworks(s),this.getConnectorId=s=>z.getConnectorId(s),e&&this.construct(e)}construct(e){this.projectId=e.projectId,this.namespace=e.namespace,this.adapterType=e.adapterType}get connectors(){return this.availableConnectors}get connections(){return this.availableConnections}get networks(){return this.getCaipNetworks(this.namespace)}onAuthConnected({accounts:e,chainId:s}){const n=this.getCaipNetworks().filter(r=>r.chainNamespace===this.namespace).find(r=>r.id.toString()===(s==null?void 0:s.toString()));e&&n&&this.addConnection({connectorId:U.CONNECTOR_ID.AUTH,accounts:e,caipNetwork:n})}setAuthProvider(e){e.onConnect(this.onAuthConnected.bind(this)),e.onSocialConnected(this.onAuthConnected.bind(this)),this.addConnector({id:U.CONNECTOR_ID.AUTH,type:"AUTH",name:U.CONNECTOR_NAMES.AUTH,provider:e,imageId:void 0,chain:this.namespace,chains:[]})}addConnector(...e){const s=new Set;this.availableConnectors=[...e,...this.availableConnectors].filter(n=>s.has(n.id)?!1:(s.add(n.id),!0)),this.emit("connectors",this.availableConnectors)}addConnection(...e){const s=new Set;this.availableConnections=[...e,...this.availableConnections].filter(n=>s.has(n.connectorId.toLowerCase())?!1:(s.add(n.connectorId.toLowerCase()),!0)),this.emit("connections",this.availableConnections)}deleteConnection(e){this.availableConnections=this.availableConnections.filter(s=>s.connectorId.toLowerCase()!==e.toLowerCase()),this.emit("connections",this.availableConnections)}clearConnections(e=!1){this.availableConnections=[],e&&this.emit("connections",this.availableConnections)}setStatus(e,s){E.setAccountProp("status",e,s)}on(e,s){var n;this.eventListeners.has(e)||this.eventListeners.set(e,new Set),(n=this.eventListeners.get(e))==null||n.add(s)}off(e,s){const n=this.eventListeners.get(e);n&&n.delete(s)}removeAllEventListeners(){this.eventListeners.forEach(e=>{e.clear()})}emit(e,s){const n=this.eventListeners.get(e);n&&n.forEach(r=>r(s))}async connectWalletConnect(e){try{return{clientId:(await this.getWalletConnectConnector().connectWalletConnect()).clientId}}catch(s){throw Kn.isUserRejectedRequestError(s)?new Pf(s):s}}async switchNetwork(e){var i;const{caipNetwork:s}=e,n=He.getProviderId(s.chainNamespace),r=He.getProvider(s.chainNamespace);if(!r)throw new Error("Provider not found");if(n==="WALLET_CONNECT"){r.setDefaultChain(s.caipNetworkId);return}if(n==="AUTH"){const o=(i=z.getAuthConnector())==null?void 0:i.provider;if(!o)throw new Error("Auth provider not found");const a=ls(s.chainNamespace);await o.switchNetwork({chainId:s.caipNetworkId});const c=await o.getUser({chainId:s.caipNetworkId,preferredAccountType:a});this.emit("switchNetwork",c)}}getWalletConnectConnector(){const e=this.connectors.find(s=>s.id==="walletConnect");if(!e)throw new Error("WalletConnectConnector not found");return e}onConnect(e,s){if(e.length>0){const{address:n,chainId:r}=X.getAccount(e[0]),i=this.getCaipNetworks().filter(a=>a.chainNamespace===this.namespace).find(a=>a.id.toString()===(r==null?void 0:r.toString())),o=this.connectors.find(a=>a.id===s);n&&(this.emit("accountChanged",{address:n,chainId:r,connector:o}),this.addConnection({connectorId:s,accounts:e.map(a=>{const{address:c}=X.getAccount(a);return{address:c}}),caipNetwork:i}))}}onAccountsChanged(e,s,n=!0){var r,i;if(e.length>0){const{address:o}=X.getAccount(e[0]),a=this.getConnection({connectorId:s,connections:this.connections,connectors:this.connectors});o&&((r=this.getConnectorId(U.CHAIN.EVM))==null?void 0:r.toLowerCase())===s.toLowerCase()&&this.emit("accountChanged",{address:o,chainId:(i=a==null?void 0:a.caipNetwork)==null?void 0:i.id,connector:a==null?void 0:a.connector}),this.addConnection({connectorId:s,accounts:e.map(c=>{const{address:l}=X.getAccount(c);return{address:l}}),caipNetwork:a==null?void 0:a.caipNetwork})}else n&&this.onDisconnect(s)}onDisconnect(e){var s;this.removeProviderListeners(e),this.deleteConnection(e),((s=this.getConnectorId(U.CHAIN.EVM))==null?void 0:s.toLowerCase())===e.toLowerCase()&&this.emitFirstAvailableConnection(),this.connections.length===0&&this.emit("disconnect")}onChainChanged(e,s){var o;const n=typeof e=="string"&&e.startsWith("0x")?parseInt(e,16).toString():e.toString(),r=this.getConnection({connectorId:s,connections:this.connections,connectors:this.connectors}),i=this.getCaipNetworks().filter(a=>a.chainNamespace===this.namespace).find(a=>a.id.toString()===n);r&&this.addConnection({connectorId:s,accounts:r.accounts,caipNetwork:i}),((o=this.getConnectorId(U.CHAIN.EVM))==null?void 0:o.toLowerCase())===s.toLowerCase()&&this.emit("switchNetwork",{chainId:n})}listenProviderEvents(e,s){if(Bx.includes(e))return;const n=o=>this.onAccountsChanged(o,e),r=o=>this.onChainChanged(o,e),i=()=>this.onDisconnect(e);this.providerHandlers[e]||(s.on("disconnect",i),s.on("accountsChanged",n),s.on("chainChanged",r),this.providerHandlers[e]={provider:s,disconnect:i,accountsChanged:n,chainChanged:r})}removeProviderListeners(e){if(this.providerHandlers[e]){const{provider:s,disconnect:n,accountsChanged:r,chainChanged:i}=this.providerHandlers[e];s.removeListener("disconnect",n),s.removeListener("accountsChanged",r),s.removeListener("chainChanged",i),this.providerHandlers[e]=null}}emitFirstAvailableConnection(){var s;const e=this.getConnection({connections:this.connections,connectors:this.connectors});if(e){const[n]=e.accounts;this.emit("accountChanged",{address:n==null?void 0:n.address,chainId:(s=e.caipNetwork)==null?void 0:s.id,connector:e.connector})}}getConnection({address:e,connectorId:s,connections:n,connectors:r}){if(s){const o=n.find(l=>l.connectorId.toLowerCase()===s.toLowerCase());if(!o)return null;const a=r.find(l=>l.id.toLowerCase()===o.connectorId.toLowerCase()),c=e?o.accounts.find(l=>l.address.toLowerCase()===e.toLowerCase()):o.accounts[0];return{...o,account:c,connector:a}}const i=n.find(o=>o.accounts.length>0&&r.some(a=>a.id.toLowerCase()===o.connectorId.toLowerCase()));if(i){const[o]=i.accounts,a=r.find(c=>c.id.toLowerCase()===i.connectorId.toLowerCase());return{...i,account:o,connector:a}}return null}}let ar=null;const vs={getSIWX(){return $.state.siwx},async initializeIfEnabled(t=E.getActiveCaipAddress()){var i,o,a;const e=$.state.siwx;if(!(e&&t))return;const[s,n,r]=t.split(":");if(E.checkIfSupportedNetwork(s,`${s}:${n}`))try{if((i=$.state.remoteFeatures)!=null&&i.emailCapture){const l=(o=E.getAccountData(s))==null?void 0:o.user;await Ne.open({view:"DataCapture",data:{email:(l==null?void 0:l.email)??void 0}});return}if(ar&&await ar,(await e.getSessions(`${s}:${n}`,r)).length)return;await Ne.open({view:"SIWXSignMessage"})}catch(c){console.error("SIWXUtil:initializeIfEnabled",c),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(c)}),await((a=G._getClient())==null?void 0:a.disconnect().catch(console.error)),ue.reset("Connect"),Ks.showError("A problem occurred while trying initialize authentication")}},async isAuthenticated(t=E.getActiveCaipAddress()){if(!$.state.siwx||!t)return!0;const{chainNamespace:s,chainId:n,address:r}=dt.parseCaipAddress(t),i=`${s}:${n}`;return(await vs.getSessions({address:r,caipNetworkId:i})).length>0},async requestSignMessage(){const t=$.state.siwx,e=X.getPlainAddress(E.getActiveCaipAddress()),s=ki();if(!t)throw new Error("SIWX is not enabled");if(!e)throw new Error("No ActiveCaipAddress found");if(!s)throw new Error("No ActiveCaipNetwork or client found");try{const n=await t.createMessage({chainId:s.caipNetworkId,accountAddress:e}),r=n.toString();let i="";t.signMessage?i=await t.signMessage({message:r,chainId:s.caipNetworkId,accountAddress:e}):(z.getConnectorId(s.chainNamespace)===U.CONNECTOR_ID.AUTH&&ue.pushTransactionStack({}),i=await G.signMessage(r)||""),await t.addSession({data:n,message:r,signature:i}),E.setLastConnectedSIWECaipNetwork(s),Ne.close(),Ee.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(n){(!Ne.state.open||ue.state.view==="ApproveTransaction")&&await Ne.open({view:"SIWXSignMessage"}),Ks.showError("Error signing message"),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(n)}),console.error("SWIXUtil:requestSignMessage",n)}},async cancelSignMessage(){var t;try{const e=this.getSIWX();if((t=e==null?void 0:e.getRequired)==null?void 0:t.call(e)){const n=E.getLastConnectedSIWECaipNetwork();if(n){const r=await(e==null?void 0:e.getSessions(n==null?void 0:n.caipNetworkId,X.getPlainAddress(E.getActiveCaipAddress())||""));r&&r.length>0?await E.switchActiveNetwork(n):await G.disconnect()}else await G.disconnect()}else Ne.close();Ne.close(),Ee.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getAllSessions(){const t=this.getSIWX(),e=E.getAllRequestedCaipNetworks(),s=[];return await Promise.all(e.map(async n=>{const r=await(t==null?void 0:t.getSessions(n.caipNetworkId,X.getPlainAddress(E.getActiveCaipAddress())||""));r&&s.push(...r)})),s},async getSessions(t){const e=$.state.siwx;let s=t==null?void 0:t.address;if(!s){const r=E.getActiveCaipAddress();s=X.getPlainAddress(r)}let n=t==null?void 0:t.caipNetworkId;if(!n){const r=E.getActiveCaipNetwork();n=r==null?void 0:r.caipNetworkId}return e&&s&&n?e.getSessions(n,s):[]},async isSIWXCloseDisabled(){var e;const t=this.getSIWX();if(t){const s=ue.state.view==="ApproveTransaction",n=ue.state.view==="SIWXSignMessage";if(s||n)return((e=t.getRequired)==null?void 0:e.call(t))&&(await this.getSessions()).length===0}return!1},async authConnectorAuthenticate({authConnector:t,chainId:e,socialUri:s,preferredAccountType:n,chainNamespace:r}){var u;const i=vs.getSIWX(),o=ki();if(!i||!r.includes(U.CHAIN.EVM)||(u=$.state.remoteFeatures)!=null&&u.emailCapture){const h=await t.connect({chainId:e,socialUri:s,preferredAccountType:n});return{address:h.address,chainId:h.chainId,accounts:h.accounts}}const a=`${r}:${e}`,c=await i.createMessage({chainId:a,accountAddress:"<<AccountAddress>>"}),l={accountAddress:c.accountAddress,chainId:c.chainId,domain:c.domain,uri:c.uri,version:c.version,nonce:c.nonce,notBefore:c.notBefore,statement:c.statement,resources:c.resources,requestId:c.requestId,issuedAt:c.issuedAt,expirationTime:c.expirationTime,serializedMessage:c.toString()},d=await t.connect({chainId:e,socialUri:s,siwxMessage:l,preferredAccountType:n});return l.accountAddress=d.address,l.serializedMessage=d.message||"",d.signature&&d.message&&await vs.addEmbeddedWalletSession(l,d.message,d.signature),E.setLastConnectedSIWECaipNetwork(o),{address:d.address,chainId:d.chainId,accounts:d.accounts}},async addEmbeddedWalletSession(t,e,s){if(ar)return ar;const n=vs.getSIWX();return n?(ar=n.addSession({data:t,message:e,signature:s}).finally(()=>{ar=null}),ar):Promise.resolve()},async universalProviderAuthenticate({universalProvider:t,chains:e,methods:s}){var l,d,u;const n=vs.getSIWX(),r=ki(),i=new Set(e.map(h=>h.split(":")[0]));if(!n||i.size!==1||!i.has("eip155"))return!1;const o=await n.createMessage({chainId:((l=ki())==null?void 0:l.caipNetworkId)||"",accountAddress:""}),a=await t.authenticate({nonce:o.nonce,domain:o.domain,uri:o.uri,exp:o.expirationTime,iat:o.issuedAt,nbf:o.notBefore,requestId:o.requestId,version:o.version,resources:o.resources,statement:o.statement,chainId:o.chainId,methods:s,chains:[o.chainId,...e.filter(h=>h!==o.chainId)]});Ks.showLoading("Authenticating...",{autoClose:!1});const c={...a.session.peer.metadata,name:a.session.peer.metadata.name,icon:(d=a.session.peer.metadata.icons)==null?void 0:d[0],type:"WALLET_CONNECT"};if(E.setAccountProp("connectedWalletInfo",c,Array.from(i)[0]),(u=a==null?void 0:a.auths)!=null&&u.length){const h=a.auths.map(p=>{const g=t.client.formatAuthMessage({request:p.p,iss:p.p.iss});return{data:{...p.p,accountAddress:p.p.iss.split(":").slice(-1).join(""),chainId:p.p.iss.split(":").slice(2,4).join(":"),uri:p.p.aud??"",version:p.p.version||o.version,expirationTime:p.p.exp,issuedAt:p.p.iat,notBefore:p.p.nbf},message:g,signature:p.s.s,cacao:p}});try{await n.setSessions(h),r&&E.setLastConnectedSIWECaipNetwork(r),Ee.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:vs.getSIWXEventProperties()})}catch(p){throw console.error("SIWX:universalProviderAuth - failed to set sessions",p),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:vs.getSIWXEventProperties(p)}),await t.disconnect().catch(console.error),p}finally{Ks.hide()}}return!0},getSIWXEventProperties(t){var s;const e=E.state.activeChain;if(!e)throw new Error("SIWXUtil:getSIWXEventProperties - namespace is required");return{network:((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||"",isSmartAccount:ls(e)===tt.ACCOUNT_TYPES.SMART_ACCOUNT,message:t?X.parseError(t):void 0}},async clearSessions(){const t=this.getSIWX();t&&await t.setSessions([])}};class Fx{constructor({provider:e,namespace:s}){this.id=U.CONNECTOR_ID.WALLET_CONNECT,this.name="WalletConnect",this.type="WALLET_CONNECT",this.imageId="ef1a1fcf-7fe8-4d69-bd6d-fda1345b4400",this.getCaipNetworks=E.getCaipNetworks.bind(E),this.caipNetworks=this.getCaipNetworks(),this.provider=e,this.chain=s}get chains(){return this.getCaipNetworks()}async connectWalletConnect(){if(!await this.authenticate()){const s=this.getCaipNetworks(),n=$.state.universalProviderConfigOverride,r=Kn.createNamespaces(s,n);await this.provider.connect({optionalNamespaces:r})}return{clientId:await this.provider.client.core.crypto.getClientId(),session:this.provider.session}}async disconnect(){await this.provider.disconnect()}async authenticate(){const e=this.chains.map(s=>s.caipNetworkId);return vs.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:qx})}}const qx=["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],Ts=Ge({message:"",variant:"info",open:!1}),Wx={state:Ts,subscribeKey(t,e){return At(Ts,t,e)},open(t,e){const{debug:s}=$.state,{code:n,displayMessage:r,debugMessage:i}=t;r&&s&&(Ts.message=r,Ts.variant=e,Ts.open=!0),i&&console.error(typeof i=="function"?i():i,n?{code:n}:void 0)},warn(t,e,s){Ts.open=!0,Ts.message=t,Ts.variant="warning",e&&console.warn(e,s)},close(){Ts.open=!1,Ts.message="",Ts.variant="info"}},Ot=As(Wx),Hx={eip155:{native:{assetNamespace:"slip44",assetReference:"60"},defaultTokenNamespace:"erc20"},solana:{native:{assetNamespace:"slip44",assetReference:"501"},defaultTokenNamespace:"token"}};class zx extends Error{}function Vx(){const{sdkType:t,sdkVersion:e,projectId:s}=$.getSnapshot(),n=new URL("https://rpc.walletconnect.org/v1/json-rpc");return n.searchParams.set("projectId",s),n.searchParams.set("st",t),n.searchParams.set("sv",e),n.searchParams.set("source","fund-wallet"),n.toString()}async function tu(t,e){const s=Vx(),{projectId:n}=$.getSnapshot(),r={jsonrpc:"2.0",id:1,method:t,params:{...e||{},projectId:n}},o=await(await fetch(s,{method:"POST",body:JSON.stringify(r),headers:{"Content-Type":"application/json"}})).json();if(o.error)throw new zx(o.error.message);return o}async function I2(t){return(await tu("reown_getExchanges",t)).result}async function N2(t){return(await tu("reown_getExchangePayUrl",t)).result}async function T2(t){return(await tu("reown_getExchangeBuyStatus",t)).result}function R2(t,e){const{chainNamespace:s,chainId:n}=dt.parseCaipNetworkId(t),r=Hx[s];if(!r)throw new Error(`Unsupported chain namespace for CAIP-19 formatting: ${s}`);let i=r.native.assetNamespace,o=r.native.assetReference;return e!=="native"&&(i=r.defaultTokenNamespace,o=e),`${`${s}:${n}`}/${i}:${o}`}const Kx={network:"eip155:1",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},Gx={network:"eip155:8453",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},uy={network:"eip155:8453",asset:"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Yx={asset:"0x036CbD53842c5426634e7929541eC2318f3dCF7e"},Zx={network:"eip155:84532",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},Jx={network:"eip155:1",asset:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Xx={network:"eip155:42161",asset:"0xaf88d065e77c8cC2239327C5EDb3A432268e5831",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Qx={network:"eip155:137",asset:"0x2791bca1f2de4661ed88a30c99a7a9449aa84174",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},ek={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},tk={network:"eip155:1",asset:"0xdAC17F958D2ee523a2206206994597C13D831ec7",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},sk={network:"eip155:10",asset:"0x94b008aA00579c1307B0EF2c499aD98a8ce58e58",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},nk={network:"eip155:42161",asset:"0xFd086bC7CD5C481DCC9C85ebE478A1C0b69FCbb9",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},rk={network:"eip155:137",asset:"0xc2132d05d31c914a87c6611c10748aeb04b58e8f",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},ik={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},ok={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"native",metadata:{name:"Solana",symbol:"SOL",decimals:9}},ak={ethereumETH:Kx,baseETH:Gx,baseUSDC:uy,baseSepoliaETH:Zx,ethereumUSDC:Jx,arbitrumUSDC:Xx,polygonUSDC:Qx,solanaUSDC:ek,ethereumUSDT:tk,optimismUSDT:sk,arbitrumUSDT:nk,polygonUSDT:rk,solanaUSDT:ik,solanaSOL:ok};function O2(t){return Object.values(ak).filter(e=>e.network===t)}const xs={getConnectorsByType(t,e,s){const{customWallets:n}=$.state,r=F.getRecentWallets(),i=zn.filterOutDuplicateWallets(e),o=zn.filterOutDuplicateWallets(s),a=t.filter(u=>u.type==="MULTI_CHAIN"),c=t.filter(u=>u.type==="ANNOUNCED"),l=t.filter(u=>u.type==="INJECTED"),d=t.filter(u=>u.type==="EXTERNAL");return{custom:n,recent:r,external:d,multiChain:a,announced:c,injected:l,recommended:i,featured:o}},showConnector(t){var r;const e=(r=t.info)==null?void 0:r.rdns,s=!!e&&te.state.excludedWallets.some(i=>!!i.rdns&&i.rdns===e),n=!!t.name&&te.state.excludedWallets.some(i=>Tf.isLowerCaseMatch(i.name,t.name));return!(t.type==="INJECTED"&&(t.name==="Browser Wallet"&&(!X.isMobile()||X.isMobile()&&!e&&!G.checkInstalled())||s||n)||(t.type==="ANNOUNCED"||t.type==="EXTERNAL")&&(s||n))},getIsConnectedWithWC(){return Array.from(E.state.chains.values()).some(s=>z.getConnectorId(s.namespace)===U.CONNECTOR_ID.WALLET_CONNECT)},getConnectorTypeOrder({recommended:t,featured:e,custom:s,recent:n,announced:r,injected:i,multiChain:o,external:a,overriddenConnectors:c=(l=>(l=$.state.features)==null?void 0:l.connectorTypeOrder)()??[]}){const u=[{type:"walletConnect",isEnabled:!0},{type:"recent",isEnabled:n.length>0},{type:"injected",isEnabled:[...i,...r,...o].length>0},{type:"featured",isEnabled:e.length>0},{type:"custom",isEnabled:s&&s.length>0},{type:"external",isEnabled:a.length>0},{type:"recommended",isEnabled:t.length>0}].filter(f=>f.isEnabled),h=new Set(u.map(f=>f.type)),p=c.filter(f=>h.has(f)).map(f=>({type:f,isEnabled:!0})),g=u.filter(({type:f})=>!p.some(({type:_})=>_===f));return Array.from(new Set([...p,...g].map(({type:f})=>f)))},sortConnectorsByExplorerWallet(t){return[...t].sort((e,s)=>e.explorerWallet&&s.explorerWallet?(e.explorerWallet.order??0)-(s.explorerWallet.order??0):e.explorerWallet?-1:s.explorerWallet?1:0)},getAuthName({email:t,socialUsername:e,socialProvider:s}){return e?s&&s==="discord"&&e.endsWith("0")?e.slice(0,-1):e:t.length>30?`${t.slice(0,-3)}...`:t},async fetchProviderData(t){var e,s;try{if(t.name==="Browser Wallet"&&!X.isMobile())return{accounts:[],chainId:void 0};if(t.id===U.CONNECTOR_ID.AUTH)return{accounts:[],chainId:void 0};const[n,r]=await Promise.all([(e=t.provider)==null?void 0:e.request({method:"eth_accounts"}),(s=t.provider)==null?void 0:s.request({method:"eth_chainId"}).then(i=>Number(i))]);return{accounts:n,chainId:r}}catch(n){return console.warn(`Failed to fetch provider data for ${t.name}`,n),{accounts:[],chainId:void 0}}},getFilteredCustomWallets(t){const e=F.getRecentWallets(),s=z.state.connectors.map(o=>{var a;return(a=o.info)==null?void 0:a.rdns}).filter(Boolean),n=e.map(o=>o.rdns).filter(Boolean),r=s.concat(n);if(r.includes("io.metamask.mobile")&&X.isMobile()){const o=r.indexOf("io.metamask.mobile");r[o]="io.metamask"}return t.filter(o=>!r.includes(String(o==null?void 0:o.rdns)))},hasWalletConnector(t){return z.state.connectors.some(e=>e.id===t.id||e.name===t.name)},isWalletCompatibleWithCurrentChain(t){const e=E.state.activeChain;return e&&t.chains?t.chains.some(s=>{const n=s.split(":")[0];return e===n}):!0},getFilteredRecentWallets(){return F.getRecentWallets().filter(s=>!zn.isExcluded(s)).filter(s=>!this.hasWalletConnector(s)).filter(s=>this.isWalletCompatibleWithCurrentChain(s))},getCappedRecommendedWallets(t){const{connectors:e}=z.state,{customWallets:s,featuredWalletIds:n}=$.state,r=e.find(S=>S.id==="walletConnect"),i=e.filter(S=>S.type==="INJECTED"||S.type==="ANNOUNCED"||S.type==="MULTI_CHAIN");if(!r&&!i.length&&!(s!=null&&s.length))return[];const o=Ol.isEmailEnabled(),a=Ol.isSocialsEnabled(),c=i.filter(S=>S.name!=="Browser Wallet"&&S.name!=="WalletConnect"),l=(n==null?void 0:n.length)||0,d=(s==null?void 0:s.length)||0,u=c.length||0,h=o?1:0,p=a?1:0,g=l+d+u+h+p,y=Math.max(0,4-g);return y<=0?[]:zn.filterOutDuplicateWallets(t).slice(0,y)},processConnectorsByType(t,e=!0){const s=xs.sortConnectorsByExplorerWallet([...t]);return e?s.filter(xs.showConnector):s},connectorList(){const t=xs.getConnectorsByType(z.state.connectors,te.state.recommended,te.state.featured),e=this.processConnectorsByType(t.announced.filter(p=>p.id!=="walletConnect")),s=this.processConnectorsByType(t.injected),n=this.processConnectorsByType(t.multiChain.filter(p=>p.name!=="WalletConnect"),!1),r=t.custom,i=t.recent,o=this.processConnectorsByType(t.external.filter(p=>p.id!==U.CONNECTOR_ID.COINBASE_SDK&&p.id!==U.CONNECTOR_ID.BASE_ACCOUNT)),a=t.recommended,c=t.featured,l=xs.getConnectorTypeOrder({custom:r,recent:i,announced:e,injected:s,multiChain:n,recommended:a,featured:c,external:o}),d=z.state.connectors.find(p=>p.id==="walletConnect"),u=X.isMobile(),h=[];for(const p of l)switch(p){case"walletConnect":{!u&&d&&h.push({kind:"connector",subtype:"walletConnect",connector:d});break}case"recent":{xs.getFilteredRecentWallets().forEach(f=>h.push({kind:"wallet",subtype:"recent",wallet:f}));break}case"injected":{n.forEach(g=>h.push({kind:"connector",subtype:"multiChain",connector:g})),e.forEach(g=>h.push({kind:"connector",subtype:"announced",connector:g})),s.forEach(g=>h.push({kind:"connector",subtype:"injected",connector:g}));break}case"featured":{c.forEach(g=>h.push({kind:"wallet",subtype:"featured",wallet:g}));break}case"custom":{xs.getFilteredCustomWallets(r??[]).forEach(f=>h.push({kind:"wallet",subtype:"custom",wallet:f}));break}case"external":{o.forEach(g=>h.push({kind:"connector",subtype:"external",connector:g}));break}case"recommended":{xs.getCappedRecommendedWallets(a).forEach(f=>h.push({kind:"wallet",subtype:"recommended",wallet:f}));break}default:console.warn(`Unknown connector type: ${p}`)}return h},hasInjectedConnectors(){return z.state.connectors.filter(t=>(t.type==="INJECTED"||t.type==="ANNOUNCED"||t.type==="MULTI_CHAIN")&&t.name!=="Browser Wallet"&&t.name!=="WalletConnect").length}},zn={filterOutDuplicatesByRDNS(t){const e=$.state.enableEIP6963?z.state.connectors:[],s=F.getRecentWallets(),n=e.map(a=>{var c;return(c=a.info)==null?void 0:c.rdns}).filter(Boolean),r=s.map(a=>a.rdns).filter(Boolean),i=n.concat(r);if(i.includes("io.metamask.mobile")&&X.isMobile()){const a=i.indexOf("io.metamask.mobile");i[a]="io.metamask"}return t.filter(a=>!(a!=null&&a.rdns&&i.includes(String(a.rdns))||!(a!=null&&a.rdns)&&e.some(l=>l.name===a.name)))},filterOutDuplicatesByIds(t){const e=z.state.connectors.filter(a=>a.type==="ANNOUNCED"||a.type==="INJECTED"||a.type==="MULTI_CHAIN"),s=F.getRecentWallets(),n=e.map(a=>{var c;return a.explorerId||((c=a.explorerWallet)==null?void 0:c.id)||a.id}),r=s.map(a=>a.id),i=n.concat(r);return t.filter(a=>!i.includes(a==null?void 0:a.id))},filterOutDuplicateWallets(t){const e=this.filterOutDuplicatesByRDNS(t);return this.filterOutDuplicatesByIds(e)},markWalletsAsInstalled(t){const{connectors:e}=z.state,{featuredWalletIds:s}=$.state,n=e.filter(o=>o.type==="ANNOUNCED").reduce((o,a)=>{var c;return(c=a.info)!=null&&c.rdns&&(o[a.info.rdns]=!0),o},{});return t.map(o=>({...o,installed:!!o.rdns&&!!n[o.rdns??""]})).sort((o,a)=>{const c=Number(a.installed)-Number(o.installed);if(c!==0)return c;if(s!=null&&s.length){const l=s.indexOf(o.id),d=s.indexOf(a.id);if(l!==-1&&d!==-1)return l-d;if(l!==-1)return-1;if(d!==-1)return 1}return 0})},getConnectOrderMethod(t,e){var c;const s=(t==null?void 0:t.connectMethodsOrder)||((c=$.state.features)==null?void 0:c.connectMethodsOrder),n=e||z.state.connectors;if(s)return s;const{injected:r,announced:i}=xs.getConnectorsByType(n,te.state.recommended,te.state.featured),o=r.filter(xs.showConnector),a=i.filter(xs.showConnector);return o.length||a.length?["wallet","email","social"]:Ie.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(t){const e=!!t.rdns&&te.state.excludedWallets.some(n=>n.rdns===t.rdns),s=!!t.name&&te.state.excludedWallets.some(n=>Tf.isLowerCaseMatch(n.name,t.name));return e||s},markWalletsWithDisplayIndex(t){return t.map((e,s)=>({...e,display_index:s}))},filterWalletsByWcSupport(t){return G.state.wcBasic?t.filter(e=>e.supports_wc):X.isMobile()?t.filter(e=>e.supports_wc||Ie.MANDATORY_WALLET_IDS_ON_MOBILE.includes(e.id)):t},getWalletConnectWallets(t){var i;const e=[...te.state.featured,...te.state.recommended];((i=te.state.filteredWallets)==null?void 0:i.length)>0?e.push(...te.state.filteredWallets):e.push(...t);const s=X.uniqueBy(e,"id"),n=zn.markWalletsAsInstalled(s),r=zn.filterWalletsByWcSupport(n);return zn.markWalletsWithDisplayIndex(r)}},Lt={METMASK_CONNECTOR_NAME:"MetaMask",TRUST_CONNECTOR_NAME:"Trust Wallet",SOLFLARE_CONNECTOR_NAME:"Solflare",PHANTOM_CONNECTOR_NAME:"Phantom",COIN98_CONNECTOR_NAME:"Coin98",MAGIC_EDEN_CONNECTOR_NAME:"Magic Eden",BACKPACK_CONNECTOR_NAME:"Backpack",BITGET_CONNECTOR_NAME:"Bitget Wallet",FRONTIER_CONNECTOR_NAME:"Frontier",XVERSE_CONNECTOR_NAME:"Xverse Wallet",LEATHER_CONNECTOR_NAME:"Leather",OKX_CONNECTOR_NAME:"OKX Wallet",BINANCE_CONNECTOR_NAME:"Binance Wallet",EIP155:U.CHAIN.EVM,ADD_CHAIN_METHOD:"wallet_addEthereumChain",EIP6963_ANNOUNCE_EVENT:"eip6963:announceProvider",EIP6963_REQUEST_EVENT:"eip6963:requestProvider",CONNECTOR_RDNS_MAP:{coinbaseWallet:"com.coinbase.wallet",coinbaseWalletSDK:"com.coinbase.wallet"},CONNECTOR_TYPE_EXTERNAL:"EXTERNAL",CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH",CONNECTOR_TYPE_MULTI_CHAIN:"MULTI_CHAIN",CONNECTOR_TYPE_W3M_AUTH:"AUTH",getSDKVersionWarningMessage(t,e){return`
|
|
14
|
+
Approved: ${h.toString()}`))}),o.forEach(u=>{n||(mr(r[u].methods,i[u].methods)?mr(r[u].events,i[u].events)||(n=Y("NON_CONFORMING_NAMESPACES",`${s} namespaces events don't satisfy namespace events for ${u}`)):n=Y("NON_CONFORMING_NAMESPACES",`${s} namespaces methods don't satisfy namespace methods for ${u}`))}),n}function xN(t){const e={};return Object.keys(t).forEach(s=>{var n;s.includes(":")?e[s]=t[s]:(n=t[s].chains)==null||n.forEach(r=>{e[r]={methods:t[s].methods,events:t[s].events}})}),e}function up(t){return[...new Set(t.map(e=>e.includes(":")?e.split(":")[0]:e))]}function kN(t){const e={};return Object.keys(t).forEach(s=>{if(s.includes(":"))e[s]=t[s];else{const n=wi(t[s].accounts);n==null||n.forEach(r=>{e[r]={accounts:t[s].accounts.filter(i=>i.includes(`${r}:`)),methods:t[s].methods,events:t[s].events}})}}),e}function UN(t,e){return Kd(t)&&t<=e.max&&t>=e.min}function hp(){const t=Ro();return new Promise(e=>{switch(t){case us.browser:e($N());break;case us.reactNative:e(DN());break;case us.node:e(LN());break;default:e(!0)}})}function $N(){return yi()&&(navigator==null?void 0:navigator.onLine)}async function DN(){if(tr()&&typeof Me<"u"&&Me!=null&&Me.NetInfo){const t=await(Me==null?void 0:Me.NetInfo.fetch());return t==null?void 0:t.isConnected}return!0}function LN(){return!0}function MN(t){switch(Ro()){case us.browser:BN(t);break;case us.reactNative:jN(t);break}}function BN(t){!tr()&&yi()&&(window.addEventListener("online",()=>t(!0)),window.addEventListener("offline",()=>t(!1)))}function jN(t){tr()&&typeof Me<"u"&&Me!=null&&Me.NetInfo&&(Me==null||Me.NetInfo.addEventListener(e=>t(e==null?void 0:e.isConnected)))}function FN(){var t;return yi()&&An.getDocument()?((t=An.getDocument())==null?void 0:t.visibilityState)==="visible":!0}const tl={};class Si{static get(e){return tl[e]}static set(e,s){tl[e]=s}static delete(e){delete tl[e]}}function qN(t){const e=To.decode(t);if(e.length<33)throw new Error("Too short to contain a public key");return e.slice(1,33)}function WN({publicKey:t,signature:e,payload:s}){var n;const r=sd(s.method),i=128|parseInt(((n=s.version)==null?void 0:n.toString())||"4"),o=VN(s.address),a=s.era==="00"?new Uint8Array([0]):sd(s.era);if(a.length!==1&&a.length!==2)throw new Error("Invalid era length");const c=parseInt(s.nonce,16),l=new Uint8Array([c&255,c>>8&255]),d=BigInt(`0x${zN(s.tip)}`),u=GN(d),h=new Uint8Array([0,...t,o,...e,...a,...l,...u,...r]),p=KN(h.length+1);return new Uint8Array([...p,i,...h])}function HN(t){const e=sd(t),s=ky.blake2b(e,void 0,32);return"0x"+Ue.from(s).toString("hex")}function sd(t){return new Uint8Array(t.replace(/^0x/,"").match(/.{1,2}/g).map(e=>parseInt(e,16)))}function zN(t){return t.startsWith("0x")?t.slice(2):t}function VN(t){const e=To.decode(t)[0];return e===42?0:e===60?2:1}function KN(t){if(t<64)return new Uint8Array([t<<2]);if(t<16384){const e=t<<2|1;return new Uint8Array([e&255,e>>8&255])}else if(t<1<<30){const e=t<<2|2;return new Uint8Array([e&255,e>>8&255,e>>16&255,e>>24&255])}else throw new Error("Compact encoding > 2^30 not supported")}function GN(t){if(t<BigInt(1)<<BigInt(6))return new Uint8Array([Number(t<<BigInt(2))]);if(t<BigInt(1)<<BigInt(14)){const e=t<<BigInt(2)|BigInt(1);return new Uint8Array([Number(e&BigInt(255)),Number(e>>BigInt(8)&BigInt(255))])}else if(t<BigInt(1)<<BigInt(30)){const e=t<<BigInt(2)|BigInt(2);return new Uint8Array([Number(e&BigInt(255)),Number(e>>BigInt(8)&BigInt(255)),Number(e>>BigInt(16)&BigInt(255)),Number(e>>BigInt(24)&BigInt(255))])}else throw new Error("BigInt compact encoding not supported > 2^30")}function YN(t){const e=Uint8Array.from(Ue.from(t.signature,"hex")),s=qN(t.transaction.address),n=WN({publicKey:s,signature:e,payload:t.transaction}),r=Ue.from(n).toString("hex");return HN(r)}function Gd({logger:t,name:e}){const s=typeof t=="string"?ic({opts:{level:t,name:e}}).logger:t;return s.level=typeof t=="string"?t:t.level,s}var ZN={VITE_BASE_URL:"https://cdn.decentraland.org/@dcl/marketplace-site/8.6.2-21763626081.commit-e07ffa9"};const xm="wc",km=2,nd="core",tn=`${xm}@2:${nd}:`,JN={logger:"error"},XN={database:":memory:"},QN="crypto",pp="client_ed25519_seed",e1=Z.ONE_DAY,t1="keychain",s1="0.3",n1="messages",r1="0.3",i1=Z.SIX_HOURS,o1="publisher",Um="irn",a1="error",$m="wss://relay.walletconnect.org",c1="relayer",it={message:"relayer_message",message_ack:"relayer_message_ack",connect:"relayer_connect",disconnect:"relayer_disconnect",error:"relayer_error",connection_stalled:"relayer_connection_stalled",transport_closed:"relayer_transport_closed",publish:"relayer_publish"},l1="_subscription",ps={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},d1=.1,rd="2.23.0",Ke={link_mode:"link_mode",relay:"relay"},wa={inbound:"inbound",outbound:"outbound"},u1="0.3",h1="WALLETCONNECT_CLIENT_ID",fp="WALLETCONNECT_LINK_MODE_APPS",is={created:"subscription_created",deleted:"subscription_deleted",expired:"subscription_expired",disabled:"subscription_disabled",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},p1="subscription",f1="0.3",g1="pairing",m1="0.3",Ii={wc_pairingDelete:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:Z.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:Z.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:0},res:{ttl:Z.ONE_DAY,prompt:!1,tag:0}}},ur={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},Ss={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},y1="history",w1="0.3",E1="expirer",ys={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},b1="0.3",v1="verify-api",C1="https://verify.walletconnect.com",Dm="https://verify.walletconnect.org",qi=Dm,_1=`${qi}/v3`,A1=[C1,Dm],S1="echo",I1="https://echo.walletconnect.com",Ws={pairing_started:"pairing_started",pairing_uri_validation_success:"pairing_uri_validation_success",pairing_uri_not_expired:"pairing_uri_not_expired",store_new_pairing:"store_new_pairing",subscribing_pairing_topic:"subscribing_pairing_topic",subscribe_pairing_topic_success:"subscribe_pairing_topic_success",existing_pairing:"existing_pairing",pairing_not_expired:"pairing_not_expired",emit_inactive_pairing:"emit_inactive_pairing",emit_session_proposal:"emit_session_proposal",subscribing_to_pairing_topic:"subscribing_to_pairing_topic"},dn={no_wss_connection:"no_wss_connection",no_internet_connection:"no_internet_connection",malformed_pairing_uri:"malformed_pairing_uri",active_pairing_already_exists:"active_pairing_already_exists",subscribe_pairing_topic_failure:"subscribe_pairing_topic_failure",pairing_expired:"pairing_expired",proposal_expired:"proposal_expired",proposal_listener_not_found:"proposal_listener_not_found"},Is={session_approve_started:"session_approve_started",proposal_not_expired:"proposal_not_expired",session_namespaces_validation_success:"session_namespaces_validation_success",create_session_topic:"create_session_topic",subscribing_session_topic:"subscribing_session_topic",subscribe_session_topic_success:"subscribe_session_topic_success",publishing_session_approve:"publishing_session_approve",session_approve_publish_success:"session_approve_publish_success",store_session:"store_session",publishing_session_settle:"publishing_session_settle",session_settle_publish_success:"session_settle_publish_success",session_request_response_started:"session_request_response_started",session_request_response_validation_success:"session_request_response_validation_success",session_request_response_publish_started:"session_request_response_publish_started"},rr={no_internet_connection:"no_internet_connection",no_wss_connection:"no_wss_connection",proposal_expired:"proposal_expired",subscribe_session_topic_failure:"subscribe_session_topic_failure",session_approve_publish_failure:"session_approve_publish_failure",session_settle_publish_failure:"session_settle_publish_failure",session_approve_namespace_validation_failure:"session_approve_namespace_validation_failure",proposal_not_found:"proposal_not_found",session_request_response_validation_failure:"session_request_response_validation_failure",session_request_response_publish_failure:"session_request_response_publish_failure"},ir={authenticated_session_approve_started:"authenticated_session_approve_started",create_authenticated_session_topic:"create_authenticated_session_topic",cacaos_verified:"cacaos_verified",store_authenticated_session:"store_authenticated_session",subscribing_authenticated_session_topic:"subscribing_authenticated_session_topic",subscribe_authenticated_session_topic_success:"subscribe_authenticated_session_topic_success",publishing_authenticated_session_approve:"publishing_authenticated_session_approve"},Ni={no_internet_connection:"no_internet_connection",invalid_cacao:"invalid_cacao",subscribe_authenticated_session_topic_failure:"subscribe_authenticated_session_topic_failure",authenticated_session_approve_publish_failure:"authenticated_session_approve_publish_failure",authenticated_session_pending_request_not_found:"authenticated_session_pending_request_not_found"},N1=.1,T1="event-client",R1=86400,O1="https://pulse.walletconnect.org/batch";function P1(t,e){if(t.length>=255)throw new TypeError("Alphabet too long");for(var s=new Uint8Array(256),n=0;n<s.length;n++)s[n]=255;for(var r=0;r<t.length;r++){var i=t.charAt(r),o=i.charCodeAt(0);if(s[o]!==255)throw new TypeError(i+" is ambiguous");s[o]=r}var a=t.length,c=t.charAt(0),l=Math.log(a)/Math.log(256),d=Math.log(256)/Math.log(a);function u(g){if(g instanceof Uint8Array||(ArrayBuffer.isView(g)?g=new Uint8Array(g.buffer,g.byteOffset,g.byteLength):Array.isArray(g)&&(g=Uint8Array.from(g))),!(g instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(g.length===0)return"";for(var f=0,y=0,_=0,S=g.length;_!==S&&g[_]===0;)_++,f++;for(var v=(S-_)*d+1>>>0,C=new Uint8Array(v);_!==S;){for(var R=g[_],D=0,L=v-1;(R!==0||D<y)&&L!==-1;L--,D++)R+=256*C[L]>>>0,C[L]=R%a>>>0,R=R/a>>>0;if(R!==0)throw new Error("Non-zero carry");y=D,_++}for(var W=v-y;W!==v&&C[W]===0;)W++;for(var k=c.repeat(f);W<v;++W)k+=t.charAt(C[W]);return k}function h(g){if(typeof g!="string")throw new TypeError("Expected String");if(g.length===0)return new Uint8Array;var f=0;if(g[f]!==" "){for(var y=0,_=0;g[f]===c;)y++,f++;for(var S=(g.length-f)*l+1>>>0,v=new Uint8Array(S);g[f];){var C=s[g.charCodeAt(f)];if(C===255)return;for(var R=0,D=S-1;(C!==0||R<_)&&D!==-1;D--,R++)C+=a*v[D]>>>0,v[D]=C%256>>>0,C=C/256>>>0;if(C!==0)throw new Error("Non-zero carry");_=R,f++}if(g[f]!==" "){for(var L=S-_;L!==S&&v[L]===0;)L++;for(var W=new Uint8Array(y+(S-L)),k=y;L!==S;)W[k++]=v[L++];return W}}}function p(g){var f=h(g);if(f)return f;throw new Error(`Non-${e} character`)}return{encode:u,decodeUnsafe:h,decode:p}}var x1=P1,k1=x1;const Lm=t=>{if(t instanceof Uint8Array&&t.constructor.name==="Uint8Array")return t;if(t instanceof ArrayBuffer)return new Uint8Array(t);if(ArrayBuffer.isView(t))return new Uint8Array(t.buffer,t.byteOffset,t.byteLength);throw new Error("Unknown type, must be binary type")},U1=t=>new TextEncoder().encode(t),$1=t=>new TextDecoder().decode(t);class D1{constructor(e,s,n){this.name=e,this.prefix=s,this.baseEncode=n}encode(e){if(e instanceof Uint8Array)return`${this.prefix}${this.baseEncode(e)}`;throw Error("Unknown type, must be binary type")}}class L1{constructor(e,s,n){if(this.name=e,this.prefix=s,s.codePointAt(0)===void 0)throw new Error("Invalid prefix character");this.prefixCodePoint=s.codePointAt(0),this.baseDecode=n}decode(e){if(typeof e=="string"){if(e.codePointAt(0)!==this.prefixCodePoint)throw Error(`Unable to decode multibase string ${JSON.stringify(e)}, ${this.name} decoder only supports inputs prefixed with ${this.prefix}`);return this.baseDecode(e.slice(this.prefix.length))}else throw Error("Can only multibase decode strings")}or(e){return Mm(this,e)}}class M1{constructor(e){this.decoders=e}or(e){return Mm(this,e)}decode(e){const s=e[0],n=this.decoders[s];if(n)return n.decode(e);throw RangeError(`Unable to decode multibase string ${JSON.stringify(e)}, only inputs prefixed with ${Object.keys(this.decoders)} are supported`)}}const Mm=(t,e)=>new M1({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}});class B1{constructor(e,s,n,r){this.name=e,this.prefix=s,this.baseEncode=n,this.baseDecode=r,this.encoder=new D1(e,s,n),this.decoder=new L1(e,s,r)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const wc=({name:t,prefix:e,encode:s,decode:n})=>new B1(t,e,s,n),Uo=({prefix:t,name:e,alphabet:s})=>{const{encode:n,decode:r}=k1(s,e);return wc({prefix:t,name:e,encode:n,decode:i=>Lm(r(i))})},j1=(t,e,s,n)=>{const r={};for(let d=0;d<e.length;++d)r[e[d]]=d;let i=t.length;for(;t[i-1]==="=";)--i;const o=new Uint8Array(i*s/8|0);let a=0,c=0,l=0;for(let d=0;d<i;++d){const u=r[t[d]];if(u===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<s|u,a+=s,a>=8&&(a-=8,o[l++]=255&c>>a)}if(a>=s||255&c<<8-a)throw new SyntaxError("Unexpected end of data");return o},F1=(t,e,s)=>{const n=e[e.length-1]==="=",r=(1<<s)-1;let i="",o=0,a=0;for(let c=0;c<t.length;++c)for(a=a<<8|t[c],o+=8;o>s;)o-=s,i+=e[r&a>>o];if(o&&(i+=e[r&a<<s-o]),n)for(;i.length*s&7;)i+="=";return i},St=({name:t,prefix:e,bitsPerChar:s,alphabet:n})=>wc({prefix:e,name:t,encode(r){return F1(r,n,s)},decode(r){return j1(r,n,s,t)}}),q1=wc({prefix:"\0",name:"identity",encode:t=>$1(t),decode:t=>U1(t)});var W1=Object.freeze({__proto__:null,identity:q1});const H1=St({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var z1=Object.freeze({__proto__:null,base2:H1});const V1=St({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var K1=Object.freeze({__proto__:null,base8:V1});const G1=Uo({prefix:"9",name:"base10",alphabet:"0123456789"});var Y1=Object.freeze({__proto__:null,base10:G1});const Z1=St({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),J1=St({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var X1=Object.freeze({__proto__:null,base16:Z1,base16upper:J1});const Q1=St({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),eT=St({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),tT=St({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),sT=St({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),nT=St({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),rT=St({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),iT=St({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),oT=St({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),aT=St({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var cT=Object.freeze({__proto__:null,base32:Q1,base32upper:eT,base32pad:tT,base32padupper:sT,base32hex:nT,base32hexupper:rT,base32hexpad:iT,base32hexpadupper:oT,base32z:aT});const lT=Uo({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),dT=Uo({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var uT=Object.freeze({__proto__:null,base36:lT,base36upper:dT});const hT=Uo({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),pT=Uo({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var fT=Object.freeze({__proto__:null,base58btc:hT,base58flickr:pT});const gT=St({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),mT=St({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),yT=St({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),wT=St({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var ET=Object.freeze({__proto__:null,base64:gT,base64pad:mT,base64url:yT,base64urlpad:wT});const Bm=Array.from("🚀🪐☄🛰🌌🌑🌒🌓🌔🌕🌖🌗🌘🌍🌏🌎🐉☀💻🖥💾💿😂❤😍🤣😊🙏💕😭😘👍😅👏😁🔥🥰💔💖💙😢🤔😆🙄💪😉☺👌🤗💜😔😎😇🌹🤦🎉💞✌✨🤷😱😌🌸🙌😋💗💚😏💛🙂💓🤩😄😀🖤😃💯🙈👇🎶😒🤭❣😜💋👀😪😑💥🙋😞😩😡🤪👊🥳😥🤤👉💃😳✋😚😝😴🌟😬🙃🍀🌷😻😓⭐✅🥺🌈😈🤘💦✔😣🏃💐☹🎊💘😠☝😕🌺🎂🌻😐🖕💝🙊😹🗣💫💀👑🎵🤞😛🔴😤🌼😫⚽🤙☕🏆🤫👈😮🙆🍻🍃🐶💁😲🌿🧡🎁⚡🌞🎈❌✊👋😰🤨😶🤝🚶💰🍓💢🤟🙁🚨💨🤬✈🎀🍺🤓😙💟🌱😖👶🥴▶➡❓💎💸⬇😨🌚🦋😷🕺⚠🙅😟😵👎🤲🤠🤧📌🔵💅🧐🐾🍒😗🤑🌊🤯🐷☎💧😯💆👆🎤🙇🍑❄🌴💣🐸💌📍🥀🤢👅💡💩👐📸👻🤐🤮🎼🥵🚩🍎🍊👼💍📣🥂"),bT=Bm.reduce((t,e,s)=>(t[s]=e,t),[]),vT=Bm.reduce((t,e,s)=>(t[e.codePointAt(0)]=s,t),[]);function CT(t){return t.reduce((e,s)=>(e+=bT[s],e),"")}function _T(t){const e=[];for(const s of t){const n=vT[s.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${s}`);e.push(n)}return new Uint8Array(e)}const AT=wc({prefix:"🚀",name:"base256emoji",encode:CT,decode:_T});var ST=Object.freeze({__proto__:null,base256emoji:AT}),IT=jm,gp=128,NT=-128,TT=Math.pow(2,31);function jm(t,e,s){e=e||[],s=s||0;for(var n=s;t>=TT;)e[s++]=t&255|gp,t/=128;for(;t&NT;)e[s++]=t&255|gp,t>>>=7;return e[s]=t|0,jm.bytes=s-n+1,e}var RT=id,OT=128,mp=127;function id(t,n){var s=0,n=n||0,r=0,i=n,o,a=t.length;do{if(i>=a)throw id.bytes=0,new RangeError("Could not decode varint");o=t[i++],s+=r<28?(o&mp)<<r:(o&mp)*Math.pow(2,r),r+=7}while(o>=OT);return id.bytes=i-n,s}var PT=Math.pow(2,7),xT=Math.pow(2,14),kT=Math.pow(2,21),UT=Math.pow(2,28),$T=Math.pow(2,35),DT=Math.pow(2,42),LT=Math.pow(2,49),MT=Math.pow(2,56),BT=Math.pow(2,63),jT=function(t){return t<PT?1:t<xT?2:t<kT?3:t<UT?4:t<$T?5:t<DT?6:t<LT?7:t<MT?8:t<BT?9:10},FT={encode:IT,decode:RT,encodingLength:jT},Fm=FT;const yp=(t,e,s=0)=>(Fm.encode(t,e,s),e),wp=t=>Fm.encodingLength(t),od=(t,e)=>{const s=e.byteLength,n=wp(t),r=n+wp(s),i=new Uint8Array(r+s);return yp(t,i,0),yp(s,i,n),i.set(e,r),new qT(t,s,e,i)};class qT{constructor(e,s,n,r){this.code=e,this.size=s,this.digest=n,this.bytes=r}}const qm=({name:t,code:e,encode:s})=>new WT(t,e,s);class WT{constructor(e,s,n){this.name=e,this.code=s,this.encode=n}digest(e){if(e instanceof Uint8Array){const s=this.encode(e);return s instanceof Uint8Array?od(this.code,s):s.then(n=>od(this.code,n))}else throw Error("Unknown type, must be binary type")}}const Wm=t=>async e=>new Uint8Array(await crypto.subtle.digest(t,e)),HT=qm({name:"sha2-256",code:18,encode:Wm("SHA-256")}),zT=qm({name:"sha2-512",code:19,encode:Wm("SHA-512")});var VT=Object.freeze({__proto__:null,sha256:HT,sha512:zT});const Hm=0,KT="identity",zm=Lm,GT=t=>od(Hm,zm(t)),YT={code:Hm,name:KT,encode:zm,digest:GT};var ZT=Object.freeze({__proto__:null,identity:YT});new TextEncoder,new TextDecoder;const Ep={...W1,...z1,...K1,...Y1,...X1,...cT,...uT,...fT,...ET,...ST};({...VT,...ZT});function Vm(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function JT(t=0){return globalThis.Buffer!=null&&globalThis.Buffer.allocUnsafe!=null?Vm(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Km(t,e,s,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:s},decoder:{decode:n}}}const bp=Km("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),sl=Km("ascii","a",t=>{let e="a";for(let s=0;s<t.length;s++)e+=String.fromCharCode(t[s]);return e},t=>{t=t.substring(1);const e=JT(t.length);for(let s=0;s<t.length;s++)e[s]=t.charCodeAt(s);return e}),XT={utf8:bp,"utf-8":bp,hex:Ep.base16,latin1:sl,ascii:sl,binary:sl,...Ep};function QT(t,e="utf8"){const s=XT[e];if(!s)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Vm(globalThis.Buffer.from(t,"utf-8")):s.decoder.decode(`${s.prefix}${t}`)}var eR=Object.defineProperty,tR=(t,e,s)=>e in t?eR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fs=(t,e,s)=>tR(t,typeof e!="symbol"?e+"":e,s);class sR{constructor(e,s){this.core=e,this.logger=s,Fs(this,"keychain",new Map),Fs(this,"name",t1),Fs(this,"version",s1),Fs(this,"initialized",!1),Fs(this,"storagePrefix",tn),Fs(this,"init",async()=>{if(!this.initialized){const n=await this.getKeyChain();typeof n<"u"&&(this.keychain=n),this.initialized=!0}}),Fs(this,"has",n=>(this.isInitialized(),this.keychain.has(n))),Fs(this,"set",async(n,r)=>{this.isInitialized(),this.keychain.set(n,r),await this.persist()}),Fs(this,"get",n=>{this.isInitialized();const r=this.keychain.get(n);if(typeof r>"u"){const{message:i}=Y("NO_MATCHING_KEY",`${this.name}: ${n}`);throw new Error(i)}return r}),Fs(this,"del",async n=>{this.isInitialized(),this.keychain.delete(n),await this.persist()}),this.core=e,this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,Wl(e))}async getKeyChain(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?Hl(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var nR=Object.defineProperty,rR=(t,e,s)=>e in t?nR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ht=(t,e,s)=>rR(t,typeof e!="symbol"?e+"":e,s);class iR{constructor(e,s,n){this.core=e,this.logger=s,ht(this,"name",QN),ht(this,"keychain"),ht(this,"randomSessionIdentifier",td()),ht(this,"initialized",!1),ht(this,"clientId"),ht(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),ht(this,"hasKeys",r=>(this.isInitialized(),this.keychain.has(r))),ht(this,"getClientId",async()=>{if(this.isInitialized(),this.clientId)return this.clientId;const r=await this.getClientSeed(),i=ou(r),o=Dy(i.publicKey);return this.clientId=o,o}),ht(this,"generateKeyPair",()=>{this.isInitialized();const r=xI();return this.setPrivateKey(r.publicKey,r.privateKey)}),ht(this,"signJWT",async r=>{this.isInitialized();const i=await this.getClientSeed(),o=ou(i),a=this.randomSessionIdentifier;return await Ly(a,r,e1,o)}),ht(this,"generateSharedKey",(r,i,o)=>{this.isInitialized();const a=this.getPrivateKey(r),c=kI(a,i);return this.setSymKey(c,o)}),ht(this,"setSymKey",async(r,i)=>{this.isInitialized();const o=i||ya(r);return await this.keychain.set(o,r),o}),ht(this,"deleteKeyPair",async r=>{this.isInitialized(),await this.keychain.del(r)}),ht(this,"deleteSymKey",async r=>{this.isInitialized(),await this.keychain.del(r)}),ht(this,"encode",async(r,i,o)=>{this.isInitialized();const a=Tm(o),c=Gi(i);if(Qh(a))return DI(c,o==null?void 0:o.encoding);if(Xh(a)){const h=a.senderPublicKey,p=a.receiverPublicKey;r=await this.generateSharedKey(h,p)}const l=this.getSymKey(r),{type:d,senderPublicKey:u}=a;return UI({type:d,symKey:l,message:c,senderPublicKey:u,encoding:o==null?void 0:o.encoding})}),ht(this,"decode",async(r,i,o)=>{this.isInitialized();const a=MI(i,o);if(Qh(a)){const c=LI(i,o==null?void 0:o.encoding);return Ca(c)}if(Xh(a)){const c=a.receiverPublicKey,l=a.senderPublicKey;r=await this.generateSharedKey(c,l)}try{const c=this.getSymKey(r),l=$I({symKey:c,encoded:i,encoding:o==null?void 0:o.encoding});return Ca(l)}catch(c){this.logger.error(`Failed to decode message from topic: '${r}', clientId: '${await this.getClientId()}'`),this.logger.error(c)}}),ht(this,"getPayloadType",(r,i=Zt)=>{const o=yo({encoded:r,encoding:i});return Or(o.type)}),ht(this,"getPayloadSenderPublicKey",(r,i=Zt)=>{const o=yo({encoded:r,encoding:i});return o.senderPublicKey?Qt(o.senderPublicKey,jt):void 0}),this.core=e,this.logger=ts(s,this.name),this.keychain=n||new sR(this.core,this.logger)}get context(){return es(this.logger)}async setPrivateKey(e,s){return await this.keychain.set(e,s),e}getPrivateKey(e){return this.keychain.get(e)}async getClientSeed(){let e="";try{e=this.keychain.get(pp)}catch{e=td(),await this.keychain.set(pp,e)}return QT(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var oR=Object.defineProperty,aR=Object.defineProperties,cR=Object.getOwnPropertyDescriptors,vp=Object.getOwnPropertySymbols,lR=Object.prototype.hasOwnProperty,dR=Object.prototype.propertyIsEnumerable,ad=(t,e,s)=>e in t?oR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,uR=(t,e)=>{for(var s in e||(e={}))lR.call(e,s)&&ad(t,s,e[s]);if(vp)for(var s of vp(e))dR.call(e,s)&&ad(t,s,e[s]);return t},hR=(t,e)=>aR(t,cR(e)),ns=(t,e,s)=>ad(t,typeof e!="symbol"?e+"":e,s);class pR extends LC{constructor(e,s){super(e,s),this.logger=e,this.core=s,ns(this,"messages",new Map),ns(this,"messagesWithoutClientAck",new Map),ns(this,"name",n1),ns(this,"version",r1),ns(this,"initialized",!1),ns(this,"storagePrefix",tn),ns(this,"init",async()=>{if(!this.initialized){this.logger.trace("Initialized");try{const n=await this.getRelayerMessages();typeof n<"u"&&(this.messages=n);const r=await this.getRelayerMessagesWithoutClientAck();typeof r<"u"&&(this.messagesWithoutClientAck=r),this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",size:this.messages.size})}catch(n){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(n)}finally{this.initialized=!0}}}),ns(this,"set",async(n,r,i)=>{this.isInitialized();const o=Es(r);let a=this.messages.get(n);if(typeof a>"u"&&(a={}),typeof a[o]<"u")return o;if(a[o]=r,this.messages.set(n,a),i===wa.inbound){const c=this.messagesWithoutClientAck.get(n)||{};this.messagesWithoutClientAck.set(n,hR(uR({},c),{[o]:r}))}return await this.persist(),o}),ns(this,"get",n=>{this.isInitialized();let r=this.messages.get(n);return typeof r>"u"&&(r={}),r}),ns(this,"getWithoutAck",n=>{this.isInitialized();const r={};for(const i of n){const o=this.messagesWithoutClientAck.get(i)||{};r[i]=Object.values(o)}return r}),ns(this,"has",(n,r)=>{this.isInitialized();const i=this.get(n),o=Es(r);return typeof i[o]<"u"}),ns(this,"ack",async(n,r)=>{this.isInitialized();const i=this.messagesWithoutClientAck.get(n);if(typeof i>"u")return;const o=Es(r);delete i[o],Object.keys(i).length===0?this.messagesWithoutClientAck.delete(n):this.messagesWithoutClientAck.set(n,i),await this.persist()}),ns(this,"del",async n=>{this.isInitialized(),this.messages.delete(n),this.messagesWithoutClientAck.delete(n),await this.persist()}),this.logger=ts(e,this.name),this.core=s}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get storageKeyWithoutClientAck(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name+"_withoutClientAck"}async setRelayerMessages(e){await this.core.storage.setItem(this.storageKey,Wl(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,Wl(e))}async getRelayerMessages(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?Hl(e):void 0}async getRelayerMessagesWithoutClientAck(){const e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return typeof e<"u"?Hl(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var fR=Object.defineProperty,gR=Object.defineProperties,mR=Object.getOwnPropertyDescriptors,Cp=Object.getOwnPropertySymbols,yR=Object.prototype.hasOwnProperty,wR=Object.prototype.propertyIsEnumerable,cd=(t,e,s)=>e in t?fR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,qr=(t,e)=>{for(var s in e||(e={}))yR.call(e,s)&&cd(t,s,e[s]);if(Cp)for(var s of Cp(e))wR.call(e,s)&&cd(t,s,e[s]);return t},_p=(t,e)=>gR(t,mR(e)),fs=(t,e,s)=>cd(t,typeof e!="symbol"?e+"":e,s);class ER extends MC{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,fs(this,"events",new xr.EventEmitter),fs(this,"name",o1),fs(this,"queue",new Map),fs(this,"publishTimeout",Z.toMiliseconds(Z.ONE_MINUTE)),fs(this,"initialPublishTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),fs(this,"needsTransportRestart",!1),fs(this,"publish",async(n,r,i)=>{var o,a,c,l,d;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:n,message:r,opts:i}});const u=(i==null?void 0:i.ttl)||i1,h=(i==null?void 0:i.prompt)||!1,p=(i==null?void 0:i.tag)||0,g=(i==null?void 0:i.id)||fr().toString(),f=Jr(Ya().protocol),y={id:g,method:(i==null?void 0:i.publishMethod)||f.publish,params:qr({topic:n,message:r,ttl:u,prompt:h,tag:p,attestation:i==null?void 0:i.attestation},i==null?void 0:i.tvf)},_=`Failed to publish payload, please try again. id:${g} tag:${p}`;try{mt((o=y.params)==null?void 0:o.prompt)&&((a=y.params)==null||delete a.prompt),mt((c=y.params)==null?void 0:c.tag)&&((l=y.params)==null||delete l.tag);const S=new Promise(async v=>{const C=({id:D})=>{var L;((L=y.id)==null?void 0:L.toString())===D.toString()&&(this.removeRequestFromQueue(D),this.relayer.events.removeListener(it.publish,C),v())};this.relayer.events.on(it.publish,C);const R=Gs(new Promise((D,L)=>{this.rpcPublish(y,i).then(D).catch(W=>{this.logger.warn(W,W==null?void 0:W.message),L(W)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${g} tag:${p}`);try{await R,this.events.removeListener(it.publish,C)}catch(D){this.queue.set(g,{request:y,opts:i,attempt:1}),this.logger.warn(D,D==null?void 0:D.message)}});this.logger.trace({type:"method",method:"publish",params:{id:g,topic:n,message:r,opts:i}}),await Gs(S,this.publishTimeout,_)}catch(S){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(S),(d=i==null?void 0:i.internal)!=null&&d.throwOnFailedPublish)throw S}finally{this.queue.delete(g)}}),fs(this,"publishCustom",async n=>{var r,i,o,a,c;this.logger.debug("Publishing custom payload"),this.logger.trace({type:"method",method:"publishCustom",params:n});const{payload:l,opts:d={}}=n,{attestation:u,tvf:h,publishMethod:p,prompt:g,tag:f,ttl:y=Z.FIVE_MINUTES}=d,_=d.id||fr().toString(),S=Jr(Ya().protocol),v=p||S.publish,C={id:_,method:v,params:qr(_p(qr({},l),{ttl:y,prompt:g,tag:f,attestation:u}),h)},R=`Failed to publish custom payload, please try again. id:${_} tag:${f}`;try{mt((r=C.params)==null?void 0:r.prompt)&&((i=C.params)==null||delete i.prompt),mt((o=C.params)==null?void 0:o.tag)&&((a=C.params)==null||delete a.tag);const D=new Promise(async L=>{const W=({id:q})=>{var V;((V=C.id)==null?void 0:V.toString())===q.toString()&&(this.removeRequestFromQueue(q),this.relayer.events.removeListener(it.publish,W),L())};this.relayer.events.on(it.publish,W);const k=Gs(new Promise((q,V)=>{this.rpcPublish(C,d).then(q).catch(x=>{this.logger.warn(x,x==null?void 0:x.message),V(x)})}),this.initialPublishTimeout,`Failed initial custom payload publish, retrying.... method:${v} id:${_} tag:${f}`);try{await k,this.events.removeListener(it.publish,W)}catch(q){this.queue.set(_,{request:C,opts:d,attempt:1}),this.logger.warn(q,q==null?void 0:q.message)}});this.logger.trace({type:"method",method:"publish",params:{id:_,payload:l,opts:d}}),await Gs(D,this.publishTimeout,R)}catch(D){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(D),(c=d==null?void 0:d.internal)!=null&&c.throwOnFailedPublish)throw D}finally{this.queue.delete(_)}}),fs(this,"on",(n,r)=>{this.events.on(n,r)}),fs(this,"once",(n,r)=>{this.events.once(n,r)}),fs(this,"off",(n,r)=>{this.events.off(n,r)}),fs(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.relayer=e,this.logger=ts(s,this.name),this.registerEventListeners()}get context(){return es(this.logger)}async rpcPublish(e,s){this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"message",direction:"outgoing",request:e});const n=await this.relayer.request(e);return this.relayer.events.emit(it.publish,qr(qr({},e),s)),this.logger.debug("Successfully Published Payload"),n}removeRequestFromQueue(e){this.queue.delete(e)}checkQueue(){this.queue.forEach(async(e,s)=>{var n;const r=e.attempt+1;this.queue.set(s,_p(qr({},e),{attempt:r})),this.logger.warn({},`Publisher: queue->publishing: ${e.request.id}, tag: ${(n=e.request.params)==null?void 0:n.tag}, attempt: ${r}`),await this.rpcPublish(e.request,e.opts),this.logger.warn({},`Publisher: queue->published: ${e.request.id}`)})}registerEventListeners(){this.relayer.core.heartbeat.on(gi.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(it.connection_stalled);return}this.checkQueue()}),this.relayer.on(it.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var bR=Object.defineProperty,vR=(t,e,s)=>e in t?bR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Wr=(t,e,s)=>vR(t,typeof e!="symbol"?e+"":e,s);class CR{constructor(){Wr(this,"map",new Map),Wr(this,"set",(e,s)=>{const n=this.get(e);this.exists(e,s)||this.map.set(e,[...n,s])}),Wr(this,"get",e=>this.map.get(e)||[]),Wr(this,"exists",(e,s)=>this.get(e).includes(s)),Wr(this,"delete",(e,s)=>{if(typeof s>"u"){this.map.delete(e);return}if(!this.map.has(e))return;const n=this.get(e);if(!this.exists(e,s))return;const r=n.filter(i=>i!==s);if(!r.length){this.map.delete(e);return}this.map.set(e,r)}),Wr(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var _R=Object.defineProperty,AR=Object.defineProperties,SR=Object.getOwnPropertyDescriptors,Ap=Object.getOwnPropertySymbols,IR=Object.prototype.hasOwnProperty,NR=Object.prototype.propertyIsEnumerable,ld=(t,e,s)=>e in t?_R(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ti=(t,e)=>{for(var s in e||(e={}))IR.call(e,s)&&ld(t,s,e[s]);if(Ap)for(var s of Ap(e))NR.call(e,s)&&ld(t,s,e[s]);return t},nl=(t,e)=>AR(t,SR(e)),We=(t,e,s)=>ld(t,typeof e!="symbol"?e+"":e,s);class TR extends FC{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,We(this,"subscriptions",new Map),We(this,"topicMap",new CR),We(this,"events",new xr.EventEmitter),We(this,"name",p1),We(this,"version",f1),We(this,"pending",new Map),We(this,"cached",[]),We(this,"initialized",!1),We(this,"storagePrefix",tn),We(this,"subscribeTimeout",Z.toMiliseconds(Z.ONE_MINUTE)),We(this,"initialSubscribeTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),We(this,"clientId"),We(this,"batchSubscribeTopicsLimit",500),We(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),We(this,"subscribe",async(n,r)=>{var i;this.isInitialized(),this.logger.debug("Subscribing Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:n,opts:r}});try{const o=Ya(r),a={topic:n,relay:o,transportType:r==null?void 0:r.transportType};(i=r==null?void 0:r.internal)!=null&&i.skipSubscribe||this.pending.set(n,a);const c=await this.rpcSubscribe(n,o,r);return typeof c=="string"&&(this.onSubscribe(c,a),this.logger.debug("Successfully Subscribed Topic"),this.logger.trace({type:"method",method:"subscribe",params:{topic:n,opts:r}})),c}catch(o){throw this.logger.debug("Failed to Subscribe Topic"),this.logger.error(o),o}}),We(this,"unsubscribe",async(n,r)=>{this.isInitialized(),typeof(r==null?void 0:r.id)<"u"?await this.unsubscribeById(n,r.id,r):await this.unsubscribeByTopic(n,r)}),We(this,"isSubscribed",n=>new Promise(r=>{r(this.topicMap.topics.includes(n))})),We(this,"isKnownTopic",n=>new Promise(r=>{r(this.topicMap.topics.includes(n)||this.pending.has(n)||this.cached.some(i=>i.topic===n))})),We(this,"on",(n,r)=>{this.events.on(n,r)}),We(this,"once",(n,r)=>{this.events.once(n,r)}),We(this,"off",(n,r)=>{this.events.off(n,r)}),We(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),We(this,"start",async()=>{await this.onConnect()}),We(this,"stop",async()=>{await this.onDisconnect()}),We(this,"restart",async()=>{await this.restore(),await this.onRestart()}),We(this,"checkPending",async()=>{if(this.pending.size===0&&(!this.initialized||!this.relayer.connected))return;const n=[];this.pending.forEach(r=>{n.push(r)}),await this.batchSubscribe(n)}),We(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(gi.pulse,async()=>{await this.checkPending()}),this.events.on(is.created,async n=>{const r=is.created;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()}),this.events.on(is.deleted,async n=>{const r=is.deleted;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()})}),this.relayer=e,this.logger=ts(s,this.name),this.clientId=""}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.relayer.core.customStoragePrefix+"//"+this.name}get length(){return this.subscriptions.size}get ids(){return Array.from(this.subscriptions.keys())}get values(){return Array.from(this.subscriptions.values())}get topics(){return this.topicMap.topics}get hasAnyTopics(){return this.topicMap.topics.length>0||this.pending.size>0||this.cached.length>0||this.subscriptions.size>0}hasSubscription(e,s){let n=!1;try{n=this.getSubscription(e).topic===s}catch{}return n}reset(){this.cached=[],this.initialized=!0}onDisable(){this.values.length>0&&(this.cached=this.values),this.subscriptions.clear(),this.topicMap.clear()}async unsubscribeByTopic(e,s){const n=this.topicMap.get(e);await Promise.all(n.map(async r=>await this.unsubscribeById(e,r,s)))}async unsubscribeById(e,s,n){this.logger.debug("Unsubscribing Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:s,opts:n}});try{const r=Ya(n);await this.restartToComplete({topic:e,id:s,relay:r}),await this.rpcUnsubscribe(e,s,r);const i=Ze("USER_DISCONNECTED",`${this.name}, ${e}`);await this.onUnsubscribe(e,s,i),this.logger.debug("Successfully Unsubscribed Topic"),this.logger.trace({type:"method",method:"unsubscribe",params:{topic:e,id:s,opts:n}})}catch(r){throw this.logger.debug("Failed to Unsubscribe Topic"),this.logger.error(r),r}}async rpcSubscribe(e,s,n){var r,i;const o=await this.getSubscriptionId(e);if((r=n==null?void 0:n.internal)!=null&&r.skipSubscribe)return o;(!n||(n==null?void 0:n.transportType)===Ke.relay)&&await this.restartToComplete({topic:e,id:e,relay:s});const a={method:Jr(s.protocol).subscribe,params:{topic:e}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:a});const c=(i=n==null?void 0:n.internal)==null?void 0:i.throwOnFailedPublish;try{if((n==null?void 0:n.transportType)===Ke.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(a).catch(u=>this.logger.warn(u))},Z.toMiliseconds(Z.ONE_SECOND)),o;const l=new Promise(async u=>{const h=p=>{p.topic===e&&(this.events.removeListener(is.created,h),u(p.id))};this.events.on(is.created,h);try{const p=await Gs(new Promise((g,f)=>{this.relayer.request(a).catch(y=>{this.logger.warn(y,y==null?void 0:y.message),f(y)}).then(g)}),this.initialSubscribeTimeout,`Subscribing to ${e} failed, please try again`);this.events.removeListener(is.created,h),u(p)}catch{}}),d=await Gs(l,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!d&&c)throw new Error(`Subscribing to ${e} failed, please try again`);return d?o:null}catch(l){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(it.connection_stalled),c)throw l}return null}async rpcBatchSubscribe(e){if(!e.length)return;const s=e[0].relay,n={method:Jr(s.protocol).batchSubscribe,params:{topics:e.map(r=>r.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:n});try{await await Gs(new Promise(r=>{this.relayer.request(n).catch(i=>this.logger.warn(i)).then(r)}),this.subscribeTimeout,"rpcBatchSubscribe failed, please try again")}catch{this.relayer.events.emit(it.connection_stalled)}}async rpcBatchFetchMessages(e){if(!e.length)return;const s=e[0].relay,n={method:Jr(s.protocol).batchFetchMessages,params:{topics:e.map(i=>i.topic)}};this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:n});let r;try{r=await await Gs(new Promise((i,o)=>{this.relayer.request(n).catch(a=>{this.logger.warn(a),o(a)}).then(i)}),this.subscribeTimeout,"rpcBatchFetchMessages failed, please try again")}catch{this.relayer.events.emit(it.connection_stalled)}return r}rpcUnsubscribe(e,s,n){const r={method:Jr(n.protocol).unsubscribe,params:{topic:e,id:s}};return this.logger.debug("Outgoing Relay Payload"),this.logger.trace({type:"payload",direction:"outgoing",request:r}),this.relayer.request(r)}onSubscribe(e,s){this.setSubscription(e,nl(Ti({},s),{id:e})),this.pending.delete(s.topic)}onBatchSubscribe(e){e.length&&e.forEach(s=>{this.setSubscription(s.id,Ti({},s)),this.pending.delete(s.topic)})}async onUnsubscribe(e,s,n){this.events.removeAllListeners(s),this.hasSubscription(s,e)&&this.deleteSubscription(s,n),await this.relayer.messages.del(e)}async setRelayerSubscriptions(e){await this.relayer.core.storage.setItem(this.storageKey,e)}async getRelayerSubscriptions(){return await this.relayer.core.storage.getItem(this.storageKey)}setSubscription(e,s){this.logger.debug("Setting subscription"),this.logger.trace({type:"method",method:"setSubscription",id:e,subscription:s}),this.addSubscription(e,s)}addSubscription(e,s){this.subscriptions.set(e,Ti({},s)),this.topicMap.set(s.topic,e),this.events.emit(is.created,s)}getSubscription(e){this.logger.debug("Getting subscription"),this.logger.trace({type:"method",method:"getSubscription",id:e});const s=this.subscriptions.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}deleteSubscription(e,s){this.logger.debug("Deleting subscription"),this.logger.trace({type:"method",method:"deleteSubscription",id:e,reason:s});const n=this.getSubscription(e);this.subscriptions.delete(e),this.topicMap.delete(n.topic,e),this.events.emit(is.deleted,nl(Ti({},n),{reason:s}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(is.sync)}async onRestart(){if(this.cached.length){const e=[...this.cached],s=Math.ceil(this.cached.length/this.batchSubscribeTopicsLimit);for(let n=0;n<s;n++){const r=e.splice(0,this.batchSubscribeTopicsLimit);await this.batchSubscribe(r)}}this.events.emit(is.resubscribed)}async restore(){try{const e=await this.getRelayerSubscriptions();if(typeof e>"u"||!e.length)return;if(this.subscriptions.size&&!e.every(s=>{var n;return s.topic===((n=this.subscriptions.get(s.id))==null?void 0:n.topic)})){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),this.logger.error(`${this.name}: ${JSON.stringify(this.values)}`),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored subscriptions for ${this.name}`),this.logger.trace({type:"method",method:"restore",subscriptions:this.values})}catch(e){this.logger.debug(`Failed to Restore subscriptions for ${this.name}`),this.logger.error(e)}}async batchSubscribe(e){e.length&&(await this.rpcBatchSubscribe(e),this.onBatchSubscribe(await Promise.all(e.map(async s=>nl(Ti({},s),{id:await this.getSubscriptionId(s.topic)})))))}async batchFetchMessages(e){if(!e.length)return;this.logger.trace(`Fetching batch messages for ${e.length} subscriptions`);const s=await this.rpcBatchFetchMessages(e);s&&s.messages&&(await X0(Z.toMiliseconds(Z.ONE_SECOND)),await this.relayer.handleBatchMessageEvents(s.messages))}async onConnect(){await this.restart(),this.reset()}onDisconnect(){this.onDisable()}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async restartToComplete(e){!this.relayer.connected&&!this.relayer.connecting&&(this.cached.push(e),await this.relayer.transportOpen())}async getClientId(){return this.clientId||(this.clientId=await this.relayer.core.crypto.getClientId()),this.clientId}async getSubscriptionId(e){return Es(e+await this.getClientId())}}var RR=Object.defineProperty,Sp=Object.getOwnPropertySymbols,OR=Object.prototype.hasOwnProperty,PR=Object.prototype.propertyIsEnumerable,dd=(t,e,s)=>e in t?RR(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ip=(t,e)=>{for(var s in e||(e={}))OR.call(e,s)&&dd(t,s,e[s]);if(Sp)for(var s of Sp(e))PR.call(e,s)&&dd(t,s,e[s]);return t},De=(t,e,s)=>dd(t,typeof e!="symbol"?e+"":e,s);class xR extends BC{constructor(e){var s;super(e),De(this,"protocol","wc"),De(this,"version",2),De(this,"core"),De(this,"logger"),De(this,"events",new xr.EventEmitter),De(this,"provider"),De(this,"messages"),De(this,"subscriber"),De(this,"publisher"),De(this,"name",c1),De(this,"transportExplicitlyClosed",!1),De(this,"initialized",!1),De(this,"connectionAttemptInProgress",!1),De(this,"relayUrl"),De(this,"projectId"),De(this,"packageName"),De(this,"bundleId"),De(this,"hasExperiencedNetworkDisruption",!1),De(this,"pingTimeout"),De(this,"heartBeatTimeout",Z.toMiliseconds(Z.THIRTY_SECONDS+Z.FIVE_SECONDS)),De(this,"reconnectTimeout"),De(this,"connectPromise"),De(this,"reconnectInProgress",!1),De(this,"requestsInFlight",[]),De(this,"connectTimeout",Z.toMiliseconds(Z.ONE_SECOND*15)),De(this,"request",async n=>{var r,i;this.logger.debug("Publishing Request Payload");const o=n.id||fr().toString();await this.toEstablishConnection();try{this.logger.trace({id:o,method:n.method,topic:(r=n.params)==null?void 0:r.topic},"relayer.request - publishing...");const a=`${o}:${((i=n.params)==null?void 0:i.tag)||""}`;this.requestsInFlight.push(a);const c=await this.provider.request(n);return this.requestsInFlight=this.requestsInFlight.filter(l=>l!==a),c}catch(a){throw this.logger.debug(`Failed to Publish Request: ${o}`),a}}),De(this,"resetPingTimeout",()=>{Wa()&&(clearTimeout(this.pingTimeout),this.pingTimeout=setTimeout(()=>{var n,r,i,o;try{this.logger.debug({},"pingTimeout: Connection stalled, terminating..."),(o=(i=(r=(n=this.provider)==null?void 0:n.connection)==null?void 0:r.socket)==null?void 0:i.terminate)==null||o.call(i)}catch(a){this.logger.warn(a,a==null?void 0:a.message)}},this.heartBeatTimeout))}),De(this,"onPayloadHandler",n=>{this.onProviderPayload(n),this.resetPingTimeout()}),De(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected 🛜"),this.startPingTimeout(),this.events.emit(it.connect)}),De(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected 🛑"),this.requestsInFlight=[],this.onProviderDisconnect()}),De(this,"onProviderErrorHandler",n=>{this.logger.fatal(`Fatal socket error: ${n.message}`),this.events.emit(it.error,n),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),De(this,"registerProviderListeners",()=>{this.provider.on(ps.payload,this.onPayloadHandler),this.provider.on(ps.connect,this.onConnectHandler),this.provider.on(ps.disconnect,this.onDisconnectHandler),this.provider.on(ps.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger=Gd({logger:(s=e.logger)!=null?s:a1,name:this.name}),this.messages=new pR(this.logger,e.core),this.subscriber=new TR(this,this.logger),this.publisher=new ER(this,this.logger),this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||$m,D0()?this.packageName=bh():L0()&&(this.bundleId=bh()),this.provider={}}async init(){this.logger.trace("Initialized"),this.registerEventListeners(),await Promise.all([this.messages.init(),this.subscriber.init()]),this.initialized=!0,this.transportOpen().catch(e=>this.logger.warn(e,e==null?void 0:e.message))}get context(){return es(this.logger)}get connected(){var e,s,n;return((n=(s=(e=this.provider)==null?void 0:e.connection)==null?void 0:s.socket)==null?void 0:n.readyState)===1||!1}get connecting(){var e,s,n;return((n=(s=(e=this.provider)==null?void 0:e.connection)==null?void 0:s.socket)==null?void 0:n.readyState)===0||this.connectPromise!==void 0||!1}async publish(e,s,n){this.isInitialized(),await this.publisher.publish(e,s,n),await this.recordMessageEvent({topic:e,message:s,publishedAt:Date.now(),transportType:Ke.relay},wa.outbound)}async publishCustom(e){this.isInitialized(),await this.publisher.publishCustom(e)}async subscribe(e,s){var n,r,i;this.isInitialized(),(!(s!=null&&s.transportType)||(s==null?void 0:s.transportType)==="relay")&&await this.toEstablishConnection();const o=typeof((n=s==null?void 0:s.internal)==null?void 0:n.throwOnFailedPublish)>"u"?!0:(r=s==null?void 0:s.internal)==null?void 0:r.throwOnFailedPublish;let a=((i=this.subscriber.topicMap.get(e))==null?void 0:i[0])||"",c;const l=d=>{d.topic===e&&(this.subscriber.off(is.created,l),c())};return await Promise.all([new Promise(d=>{c=d,this.subscriber.on(is.created,l)}),new Promise(async(d,u)=>{a=await this.subscriber.subscribe(e,Ip({internal:{throwOnFailedPublish:o}},s)).catch(h=>{o&&u(h)})||a,d()})]),a}async unsubscribe(e,s){this.isInitialized(),await this.subscriber.unsubscribe(e,s)}on(e,s){this.events.on(e,s)}once(e,s){this.events.once(e,s)}off(e,s){this.events.off(e,s)}removeListener(e,s){this.events.removeListener(e,s)}async transportDisconnect(){this.provider.disconnect&&(this.hasExperiencedNetworkDisruption||this.connected)?await Gs(this.provider.disconnect(),2e3,"provider.disconnect()").catch(()=>this.onProviderDisconnect()):this.onProviderDisconnect()}async transportClose(){this.transportExplicitlyClosed=!0,await this.transportDisconnect()}async transportOpen(e){if(!this.subscriber.hasAnyTopics){this.logger.info("Starting WS connection skipped because the client has no topics to work with.");return}if(this.connectPromise?(this.logger.debug({},"Waiting for existing connection attempt to resolve..."),await this.connectPromise,this.logger.debug({},"Existing connection attempt resolved")):(this.connectPromise=new Promise(async(s,n)=>{await this.connect(e).then(s).catch(n).finally(()=>{this.connectPromise=void 0})}),await this.connectPromise),!this.connected)throw new Error(`Couldn't establish socket connection to the relay server: ${this.relayUrl}`)}async restartTransport(e){this.logger.debug({},"Restarting transport..."),!this.connectionAttemptInProgress&&(this.relayUrl=e||this.relayUrl,await this.confirmOnlineStateOrThrow(),await this.transportClose(),await this.transportOpen())}async confirmOnlineStateOrThrow(){if(!await hp())throw new Error("No internet connection detected. Please restart your network and try again.")}async handleBatchMessageEvents(e){if((e==null?void 0:e.length)===0){this.logger.trace("Batch message events is empty. Ignoring...");return}const s=e.sort((n,r)=>n.publishedAt-r.publishedAt);this.logger.debug(`Batch of ${s.length} message events sorted`);for(const n of s)try{await this.onMessageEvent(n)}catch(r){this.logger.warn(r,"Error while processing batch message event: "+(r==null?void 0:r.message))}this.logger.trace(`Batch of ${s.length} message events processed`)}async onLinkMessageEvent(e,s){const{topic:n}=e;if(!s.sessionExists){const r=rt(Z.FIVE_MINUTES),i={topic:n,expiry:r,relay:{protocol:"irn"},active:!1};await this.core.pairing.pairings.set(n,i)}this.events.emit(it.message,e),await this.recordMessageEvent(e,wa.inbound)}async connect(e){await this.confirmOnlineStateOrThrow(),e&&e!==this.relayUrl&&(this.relayUrl=e,await this.transportDisconnect()),this.connectionAttemptInProgress=!0,this.transportExplicitlyClosed=!1;let s=1;for(;s<6;){try{if(this.transportExplicitlyClosed)break;this.logger.debug({},`Connecting to ${this.relayUrl}, attempt: ${s}...`),await this.createProvider(),await new Promise(async(n,r)=>{const i=()=>{r(new Error("Connection interrupted while trying to connect"))};this.provider.once(ps.disconnect,i),await Gs(new Promise((o,a)=>{this.provider.connect().then(o).catch(a)}),this.connectTimeout,`Socket stalled when trying to connect to ${this.relayUrl}`).catch(o=>{r(o)}).finally(()=>{this.provider.off(ps.disconnect,i),clearTimeout(this.reconnectTimeout)}),await new Promise(async(o,a)=>{const c=()=>{r(new Error("Connection interrupted while trying to subscribe"))};this.provider.once(ps.disconnect,c),await this.subscriber.start().then(o).catch(a).finally(()=>{this.provider.off(ps.disconnect,c)})}),this.hasExperiencedNetworkDisruption=!1,n()})}catch(n){await this.subscriber.stop();const r=n;this.logger.warn({},r.message),this.hasExperiencedNetworkDisruption=!0}finally{this.connectionAttemptInProgress=!1}if(this.connected){this.logger.debug({},`Connected to ${this.relayUrl} successfully on attempt: ${s}`);break}await new Promise(n=>setTimeout(n,Z.toMiliseconds(s*1))),s++}}startPingTimeout(){var e,s,n,r,i;if(Wa())try{(s=(e=this.provider)==null?void 0:e.connection)!=null&&s.socket&&((i=(r=(n=this.provider)==null?void 0:n.connection)==null?void 0:r.socket)==null||i.on("ping",()=>{this.resetPingTimeout()})),this.resetPingTimeout()}catch(o){this.logger.warn(o,o==null?void 0:o.message)}}async createProvider(){this.provider.connection&&this.unregisterProviderListeners();const e=await this.core.crypto.signJWT(this.relayUrl);this.provider=new Cd(new $y(q0({sdkVersion:rd,protocol:this.protocol,version:this.version,relayUrl:this.relayUrl,projectId:this.projectId,auth:e,useOnCloseEvent:!0,bundleId:this.bundleId,packageName:this.packageName}))),this.registerProviderListeners()}async recordMessageEvent(e,s){const{topic:n,message:r}=e;await this.messages.set(n,r,s)}async shouldIgnoreMessageEvent(e){const{topic:s,message:n}=e;if(!n||n.length===0)return this.logger.warn(`Ignoring invalid/empty message: ${n}`),!0;if(!await this.subscriber.isKnownTopic(s))return this.logger.warn(`Ignoring message for unknown topic ${s}`),!0;const r=this.messages.has(s,n);return r&&this.logger.warn(`Ignoring duplicate message: ${n}`),r}async onProviderPayload(e){if(this.logger.debug("Incoming Relay Payload"),this.logger.trace({type:"payload",direction:"incoming",payload:e}),_d(e)){if(!e.method.endsWith(l1))return;const s=e.params,{topic:n,message:r,publishedAt:i,attestation:o}=s.data,a={topic:n,message:r,publishedAt:i,transportType:Ke.relay,attestation:o};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(Ip({type:"event",event:s.id},a)),this.events.emit(s.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else Ad(e)&&this.events.emit(it.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,wa.inbound),this.events.emit(it.message,e))}async acknowledgePayload(e){const s=Yi(e.id,!0);await this.provider.connection.send(s)}unregisterProviderListeners(){this.provider.off(ps.payload,this.onPayloadHandler),this.provider.off(ps.connect,this.onConnectHandler),this.provider.off(ps.disconnect,this.onDisconnectHandler),this.provider.off(ps.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await hp();MN(async s=>{e!==s&&(e=s,s?await this.transportOpen().catch(n=>this.logger.error(n,n==null?void 0:n.message)):(this.hasExperiencedNetworkDisruption=!0,await this.transportDisconnect(),this.transportExplicitlyClosed=!1))}),this.core.heartbeat.on(gi.pulse,async()=>{if(!this.transportExplicitlyClosed&&!this.connected&&FN())try{await this.confirmOnlineStateOrThrow(),await this.transportOpen()}catch(s){this.logger.warn(s,s==null?void 0:s.message)}})}async onProviderDisconnect(){clearTimeout(this.pingTimeout),this.events.emit(it.disconnect),this.connectionAttemptInProgress=!1,!this.reconnectInProgress&&(this.reconnectInProgress=!0,await this.subscriber.stop(),this.subscriber.hasAnyTopics&&(this.transportExplicitlyClosed||(this.reconnectTimeout=setTimeout(async()=>{await this.transportOpen().catch(e=>this.logger.error(e,e==null?void 0:e.message)),this.reconnectTimeout=void 0,this.reconnectInProgress=!1},Z.toMiliseconds(d1)))))}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async toEstablishConnection(){if(await this.confirmOnlineStateOrThrow(),!this.connected){if(this.connectPromise){await this.connectPromise;return}await this.connect()}}}function kR(t,e){return t===e||Number.isNaN(t)&&Number.isNaN(e)}function Np(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function Tp(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const UR="[object RegExp]",$R="[object String]",DR="[object Number]",LR="[object Boolean]",Rp="[object Arguments]",MR="[object Symbol]",BR="[object Date]",jR="[object Map]",FR="[object Set]",qR="[object Array]",WR="[object Function]",HR="[object ArrayBuffer]",rl="[object Object]",zR="[object Error]",VR="[object DataView]",KR="[object Uint8Array]",GR="[object Uint8ClampedArray]",YR="[object Uint16Array]",ZR="[object Uint32Array]",JR="[object BigUint64Array]",XR="[object Int8Array]",QR="[object Int16Array]",eO="[object Int32Array]",tO="[object BigInt64Array]",sO="[object Float32Array]",nO="[object Float64Array]";function rO(){}function Op(t){if(!t||typeof t!="object")return!1;const e=Object.getPrototypeOf(t);return e===null||e===Object.prototype||Object.getPrototypeOf(e)===null?Object.prototype.toString.call(t)==="[object Object]":!1}function iO(t,e,s){return Di(t,e,void 0,void 0,void 0,void 0,s)}function Di(t,e,s,n,r,i,o){const a=o(t,e,s,n,r,i);if(a!==void 0)return a;if(typeof t==typeof e)switch(typeof t){case"bigint":case"string":case"boolean":case"symbol":case"undefined":return t===e;case"number":return t===e||Object.is(t,e);case"function":return t===e;case"object":return Wi(t,e,i,o)}return Wi(t,e,i,o)}function Wi(t,e,s,n){if(Object.is(t,e))return!0;let r=Tp(t),i=Tp(e);if(r===Rp&&(r=rl),i===Rp&&(i=rl),r!==i)return!1;switch(r){case $R:return t.toString()===e.toString();case DR:{const c=t.valueOf(),l=e.valueOf();return kR(c,l)}case LR:case BR:case MR:return Object.is(t.valueOf(),e.valueOf());case UR:return t.source===e.source&&t.flags===e.flags;case WR:return t===e}s=s??new Map;const o=s.get(t),a=s.get(e);if(o!=null&&a!=null)return o===e;s.set(t,e),s.set(e,t);try{switch(r){case jR:{if(t.size!==e.size)return!1;for(const[c,l]of t.entries())if(!e.has(c)||!Di(l,e.get(c),c,t,e,s,n))return!1;return!0}case FR:{if(t.size!==e.size)return!1;const c=Array.from(t.values()),l=Array.from(e.values());for(let d=0;d<c.length;d++){const u=c[d],h=l.findIndex(p=>Di(u,p,void 0,t,e,s,n));if(h===-1)return!1;l.splice(h,1)}return!0}case qR:case KR:case GR:case YR:case ZR:case JR:case XR:case QR:case eO:case tO:case sO:case nO:{if(typeof Ue<"u"&&Ue.isBuffer(t)!==Ue.isBuffer(e)||t.length!==e.length)return!1;for(let c=0;c<t.length;c++)if(!Di(t[c],e[c],c,t,e,s,n))return!1;return!0}case HR:return t.byteLength!==e.byteLength?!1:Wi(new Uint8Array(t),new Uint8Array(e),s,n);case VR:return t.byteLength!==e.byteLength||t.byteOffset!==e.byteOffset?!1:Wi(new Uint8Array(t),new Uint8Array(e),s,n);case zR:return t.name===e.name&&t.message===e.message;case rl:{if(!(Wi(t.constructor,e.constructor,s,n)||Op(t)&&Op(e)))return!1;const c=[...Object.keys(t),...Np(t)],l=[...Object.keys(e),...Np(e)];if(c.length!==l.length)return!1;for(let d=0;d<c.length;d++){const u=c[d],h=t[u];if(!Object.hasOwn(e,u))return!1;const p=e[u];if(!Di(h,p,u,t,e,s,n))return!1}return!0}default:return!1}}finally{s.delete(t),s.delete(e)}}function oO(t,e){return iO(t,e,rO)}var aO=Object.defineProperty,Pp=Object.getOwnPropertySymbols,cO=Object.prototype.hasOwnProperty,lO=Object.prototype.propertyIsEnumerable,ud=(t,e,s)=>e in t?aO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,xp=(t,e)=>{for(var s in e||(e={}))cO.call(e,s)&&ud(t,s,e[s]);if(Pp)for(var s of Pp(e))lO.call(e,s)&&ud(t,s,e[s]);return t},Ht=(t,e,s)=>ud(t,typeof e!="symbol"?e+"":e,s);class Lr extends jC{constructor(e,s,n,r=tn,i=void 0){super(e,s,n,r),this.core=e,this.logger=s,this.name=n,Ht(this,"map",new Map),Ht(this,"version",u1),Ht(this,"cached",[]),Ht(this,"initialized",!1),Ht(this,"getKey"),Ht(this,"storagePrefix",tn),Ht(this,"recentlyDeleted",[]),Ht(this,"recentlyDeletedLimit",200),Ht(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(o=>{this.getKey&&o!==null&&!mt(o)?this.map.set(this.getKey(o),o):gN(o)?this.map.set(o.id,o):mN(o)&&this.map.set(o.topic,o)}),this.cached=[],this.initialized=!0)}),Ht(this,"set",async(o,a)=>{this.isInitialized(),this.map.has(o)?await this.update(o,a):(this.logger.debug("Setting value"),this.logger.trace({type:"method",method:"set",key:o,value:a}),this.map.set(o,a),await this.persist())}),Ht(this,"get",o=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:o}),this.getData(o))),Ht(this,"getAll",o=>(this.isInitialized(),o?this.values.filter(a=>Object.keys(o).every(c=>oO(a[c],o[c]))):this.values)),Ht(this,"update",async(o,a)=>{this.isInitialized(),this.logger.debug("Updating value"),this.logger.trace({type:"method",method:"update",key:o,update:a});const c=xp(xp({},this.getData(o)),a);this.map.set(o,c),await this.persist()}),Ht(this,"delete",async(o,a)=>{this.isInitialized(),this.map.has(o)&&(this.logger.debug("Deleting value"),this.logger.trace({type:"method",method:"delete",key:o,reason:a}),this.map.delete(o),this.addToRecentlyDeleted(o),await this.persist())}),this.logger=ts(s,this.name),this.storagePrefix=r,this.getKey=i}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.map.size}get keys(){return Array.from(this.map.keys())}get values(){return Array.from(this.map.values())}addToRecentlyDeleted(e){this.recentlyDeleted.push(e),this.recentlyDeleted.length>=this.recentlyDeletedLimit&&this.recentlyDeleted.splice(0,this.recentlyDeletedLimit/2)}async setDataStore(e){await this.core.storage.setItem(this.storageKey,e)}async getDataStore(){return await this.core.storage.getItem(this.storageKey)}getData(e){const s=this.map.get(e);if(!s){if(this.recentlyDeleted.includes(e)){const{message:r}=Y("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(r),new Error(r)}const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.error(n),new Error(n)}return s}async persist(){await this.setDataStore(this.values)}async restore(){try{const e=await this.getDataStore();if(typeof e>"u"||!e.length)return;if(this.map.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored value for ${this.name}`),this.logger.trace({type:"method",method:"restore",value:this.values})}catch(e){this.logger.debug(`Failed to Restore value for ${this.name}`),this.logger.error(e)}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var dO=Object.defineProperty,uO=(t,e,s)=>e in t?dO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Te=(t,e,s)=>uO(t,typeof e!="symbol"?e+"":e,s);class hO{constructor(e,s){this.core=e,this.logger=s,Te(this,"name",g1),Te(this,"version",m1),Te(this,"events",new Sd),Te(this,"pairings"),Te(this,"initialized",!1),Te(this,"storagePrefix",tn),Te(this,"ignoredPayloadTypes",[Cn]),Te(this,"registeredMethods",[]),Te(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),Te(this,"register",({methods:n})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...n])]}),Te(this,"create",async n=>{this.isInitialized();const r=td(),i=await this.core.crypto.setSymKey(r),o=rt(Z.FIVE_MINUTES),a={protocol:Um},c={topic:i,expiry:o,relay:a,active:!1,methods:n==null?void 0:n.methods},l=np({protocol:this.core.protocol,version:this.core.version,topic:i,symKey:r,relay:a,expiryTimestamp:o,methods:n==null?void 0:n.methods});return this.events.emit(ur.create,c),this.core.expirer.set(i,o),await this.pairings.set(i,c),await this.core.relayer.subscribe(i,{transportType:n==null?void 0:n.transportType,internal:n==null?void 0:n.internal}),{topic:i,uri:l}}),Te(this,"pair",async n=>{this.isInitialized();const r=this.core.eventClient.createEvent({properties:{topic:n==null?void 0:n.uri,trace:[Ws.pairing_started]}});this.isValidPair(n,r);const{topic:i,symKey:o,relay:a,expiryTimestamp:c,methods:l}=sp(n.uri);r.props.properties.topic=i,r.addTrace(Ws.pairing_uri_validation_success),r.addTrace(Ws.pairing_uri_not_expired);let d;if(this.pairings.keys.includes(i)){if(d=this.pairings.get(i),r.addTrace(Ws.existing_pairing),d.active)throw r.setError(dn.active_pairing_already_exists),new Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(Ws.pairing_not_expired)}const u=c||rt(Z.FIVE_MINUTES),h={topic:i,relay:a,expiry:u,active:!1,methods:l};this.core.expirer.set(i,u),await this.pairings.set(i,h),r.addTrace(Ws.store_new_pairing),n.activatePairing&&await this.activate({topic:i}),this.events.emit(ur.create,h),r.addTrace(Ws.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(o,i),r.addTrace(Ws.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(dn.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:a})}catch(p){throw r.setError(dn.subscribe_pairing_topic_failure),p}return r.addTrace(Ws.subscribe_pairing_topic_success),h}),Te(this,"activate",async({topic:n})=>{this.isInitialized();const r=rt(Z.FIVE_MINUTES);this.core.expirer.set(n,r),await this.pairings.update(n,{active:!0,expiry:r})}),Te(this,"ping",async n=>{this.isInitialized(),await this.isValidPing(n),this.logger.warn("ping() is deprecated and will be removed in the next major release.");const{topic:r}=n;if(this.pairings.keys.includes(r)){const i=await this.sendRequest(r,"wc_pairingPing",{}),{done:o,resolve:a,reject:c}=dr();this.events.once(Fe("pairing_ping",i),({error:l})=>{l?c(l):a()}),await o()}}),Te(this,"updateExpiry",async({topic:n,expiry:r})=>{this.isInitialized(),await this.pairings.update(n,{expiry:r})}),Te(this,"updateMetadata",async({topic:n,metadata:r})=>{this.isInitialized(),await this.pairings.update(n,{peerMetadata:r})}),Te(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),Te(this,"disconnect",async n=>{this.isInitialized(),await this.isValidDisconnect(n);const{topic:r}=n;this.pairings.keys.includes(r)&&(await this.sendRequest(r,"wc_pairingDelete",Ze("USER_DISCONNECTED")),await this.deletePairing(r))}),Te(this,"formatUriFromPairing",n=>{this.isInitialized();const{topic:r,relay:i,expiry:o,methods:a}=n,c=this.core.crypto.keychain.get(r);return np({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:c,relay:i,expiryTimestamp:o,methods:a})}),Te(this,"sendRequest",async(n,r,i)=>{const o=zs(r,i),a=await this.core.crypto.encode(n,o),c=Ii[r].req;return this.core.history.set(n,o),this.core.relayer.publish(n,a,c),o.id}),Te(this,"sendResult",async(n,r,i)=>{const o=Yi(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Ii[c].res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),Te(this,"sendError",async(n,r,i)=>{const o=Cf(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Ii[c]?Ii[c].res:Ii.unregistered_method.res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),Te(this,"deletePairing",async(n,r)=>{await this.core.relayer.unsubscribe(n),await Promise.all([this.pairings.delete(n,Ze("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(n),r?Promise.resolve():this.core.expirer.del(n)])}),Te(this,"cleanup",async()=>{const n=this.pairings.getAll().filter(r=>Vs(r.expiry));await Promise.all(n.map(r=>this.deletePairing(r.topic)))}),Te(this,"onRelayEventRequest",async n=>{const{topic:r,payload:i}=n;switch(i.method){case"wc_pairingPing":return await this.onPairingPingRequest(r,i);case"wc_pairingDelete":return await this.onPairingDeleteRequest(r,i);default:return await this.onUnknownRpcMethodRequest(r,i)}}),Te(this,"onRelayEventResponse",async n=>{const{topic:r,payload:i}=n,o=(await this.core.history.get(r,i.id)).request.method;switch(o){case"wc_pairingPing":return this.onPairingPingResponse(r,i);default:return this.onUnknownRpcMethodResponse(o)}}),Te(this,"onPairingPingRequest",async(n,r)=>{const{id:i}=r;try{this.isValidPing({topic:n}),await this.sendResult(i,n,!0),this.events.emit(ur.ping,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),Te(this,"onPairingPingResponse",(n,r)=>{const{id:i}=r;setTimeout(()=>{cn(r)?this.events.emit(Fe("pairing_ping",i),{}):Hs(r)&&this.events.emit(Fe("pairing_ping",i),{error:r.error})},500)}),Te(this,"onPairingDeleteRequest",async(n,r)=>{const{id:i}=r;try{this.isValidDisconnect({topic:n}),await this.deletePairing(n),this.events.emit(ur.delete,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),Te(this,"onUnknownRpcMethodRequest",async(n,r)=>{const{id:i,method:o}=r;try{if(this.registeredMethods.includes(o))return;const a=Ze("WC_METHOD_UNSUPPORTED",o);await this.sendError(i,n,a),this.logger.error(a)}catch(a){await this.sendError(i,n,a),this.logger.error(a)}}),Te(this,"onUnknownRpcMethodResponse",n=>{this.registeredMethods.includes(n)||this.logger.error(Ze("WC_METHOD_UNSUPPORTED",n))}),Te(this,"isValidPair",(n,r)=>{var i;if(!Vt(n)){const{message:a}=Y("MISSING_OR_INVALID",`pair() params: ${n}`);throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(!fN(n.uri)){const{message:a}=Y("MISSING_OR_INVALID",`pair() uri: ${n.uri}`);throw r.setError(dn.malformed_pairing_uri),new Error(a)}const o=sp(n==null?void 0:n.uri);if(!((i=o==null?void 0:o.relay)!=null&&i.protocol)){const{message:a}=Y("MISSING_OR_INVALID","pair() uri#relay-protocol");throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(!(o!=null&&o.symKey)){const{message:a}=Y("MISSING_OR_INVALID","pair() uri#symKey");throw r.setError(dn.malformed_pairing_uri),new Error(a)}if(o!=null&&o.expiryTimestamp&&Z.toMiliseconds(o==null?void 0:o.expiryTimestamp)<Date.now()){r.setError(dn.pairing_expired);const{message:a}=Y("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw new Error(a)}}),Te(this,"isValidPing",async n=>{if(!Vt(n)){const{message:i}=Y("MISSING_OR_INVALID",`ping() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),Te(this,"isValidDisconnect",async n=>{if(!Vt(n)){const{message:i}=Y("MISSING_OR_INVALID",`disconnect() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),Te(this,"isValidPairingTopic",async n=>{if(!ot(n,!1)){const{message:r}=Y("MISSING_OR_INVALID",`pairing topic should be a string: ${n}`);throw new Error(r)}if(!this.pairings.keys.includes(n)){const{message:r}=Y("NO_MATCHING_KEY",`pairing topic doesn't exist: ${n}`);throw new Error(r)}if(Vs(this.pairings.get(n).expiry)){await this.deletePairing(n);const{message:r}=Y("EXPIRED",`pairing topic: ${n}`);throw new Error(r)}}),this.core=e,this.logger=ts(s,this.name),this.pairings=new Lr(this.core,this.logger,this.name,this.storagePrefix)}get context(){return es(this.logger)}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}registerRelayerEvents(){this.core.relayer.on(it.message,async e=>{const{topic:s,message:n,transportType:r}=e;if(this.pairings.keys.includes(s)&&r!==Ke.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(n)))try{const i=await this.core.crypto.decode(s,n);_d(i)?(this.core.history.set(s,i),await this.onRelayEventRequest({topic:s,payload:i})):Ad(i)&&(await this.core.history.resolve(i),await this.onRelayEventResponse({topic:s,payload:i}),this.core.history.delete(s,i.id)),await this.core.relayer.messages.ack(s,n)}catch(i){this.logger.error(i)}})}registerExpirerEvents(){this.core.expirer.on(ys.expired,async e=>{const{topic:s}=Og(e.target);s&&this.pairings.keys.includes(s)&&(await this.deletePairing(s,!0),this.events.emit(ur.expire,{topic:s}))})}}var pO=Object.defineProperty,fO=(t,e,s)=>e in t?pO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,bt=(t,e,s)=>fO(t,typeof e!="symbol"?e+"":e,s);class gO extends DC{constructor(e,s){super(e,s),this.core=e,this.logger=s,bt(this,"records",new Map),bt(this,"events",new xr.EventEmitter),bt(this,"name",y1),bt(this,"version",w1),bt(this,"cached",[]),bt(this,"initialized",!1),bt(this,"storagePrefix",tn),bt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(n=>this.records.set(n.id,n)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),bt(this,"set",(n,r,i)=>{if(this.isInitialized(),this.logger.debug("Setting JSON-RPC request history record"),this.logger.trace({type:"method",method:"set",topic:n,request:r,chainId:i}),this.records.has(r.id))return;const o={id:r.id,topic:n,request:{method:r.method,params:r.params||null},chainId:i,expiry:rt(Z.THIRTY_DAYS)};this.records.set(o.id,o),this.persist(),this.events.emit(Ss.created,o)}),bt(this,"resolve",async n=>{if(this.isInitialized(),this.logger.debug("Updating JSON-RPC response history record"),this.logger.trace({type:"method",method:"update",response:n}),!this.records.has(n.id))return;const r=await this.getRecord(n.id);typeof r.response>"u"&&(r.response=Hs(n)?{error:n.error}:{result:n.result},this.records.set(r.id,r),this.persist(),this.events.emit(Ss.updated,r))}),bt(this,"get",async(n,r)=>(this.isInitialized(),this.logger.debug("Getting record"),this.logger.trace({type:"method",method:"get",topic:n,id:r}),await this.getRecord(r))),bt(this,"delete",(n,r)=>{this.isInitialized(),this.logger.debug("Deleting record"),this.logger.trace({type:"method",method:"delete",id:r}),this.values.forEach(i=>{if(i.topic===n){if(typeof r<"u"&&i.id!==r)return;this.records.delete(i.id),this.events.emit(Ss.deleted,i)}}),this.persist()}),bt(this,"exists",async(n,r)=>(this.isInitialized(),this.records.has(r)?(await this.getRecord(r)).topic===n:!1)),bt(this,"on",(n,r)=>{this.events.on(n,r)}),bt(this,"once",(n,r)=>{this.events.once(n,r)}),bt(this,"off",(n,r)=>{this.events.off(n,r)}),bt(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get size(){return this.records.size}get keys(){return Array.from(this.records.keys())}get values(){return Array.from(this.records.values())}get pending(){const e=[];return this.values.forEach(s=>{if(typeof s.response<"u")return;const n={topic:s.topic,request:zs(s.request.method,s.request.params,s.id),chainId:s.chainId};return e.push(n)}),e}async setJsonRpcRecords(e){await this.core.storage.setItem(this.storageKey,e)}async getJsonRpcRecords(){return await this.core.storage.getItem(this.storageKey)}getRecord(e){this.isInitialized();const s=this.records.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(Ss.sync)}async restore(){try{const e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored records for ${this.name}`),this.logger.trace({type:"method",method:"restore",records:this.values})}catch(e){this.logger.debug(`Failed to Restore records for ${this.name}`),this.logger.error(e)}}registerEventListeners(){this.events.on(Ss.created,e=>{const s=Ss.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Ss.updated,e=>{const s=Ss.updated;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Ss.deleted,e=>{const s=Ss.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.core.heartbeat.on(gi.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(s=>{Z.toMiliseconds(s.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${s.id}`),this.records.delete(s.id),this.events.emit(Ss.deleted,s,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var mO=Object.defineProperty,yO=(t,e,s)=>e in t?mO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Rt=(t,e,s)=>yO(t,typeof e!="symbol"?e+"":e,s);class wO extends qC{constructor(e,s){super(e,s),this.core=e,this.logger=s,Rt(this,"expirations",new Map),Rt(this,"events",new xr.EventEmitter),Rt(this,"name",E1),Rt(this,"version",b1),Rt(this,"cached",[]),Rt(this,"initialized",!1),Rt(this,"storagePrefix",tn),Rt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(n=>this.expirations.set(n.target,n)),this.cached=[],this.registerEventListeners(),this.initialized=!0)}),Rt(this,"has",n=>{try{const r=this.formatTarget(n);return typeof this.getExpiration(r)<"u"}catch{return!1}}),Rt(this,"set",(n,r)=>{this.isInitialized();const i=this.formatTarget(n),o={target:i,expiry:r};this.expirations.set(i,o),this.checkExpiry(i,o),this.events.emit(ys.created,{target:i,expiration:o})}),Rt(this,"get",n=>{this.isInitialized();const r=this.formatTarget(n);return this.getExpiration(r)}),Rt(this,"del",n=>{if(this.isInitialized(),this.has(n)){const r=this.formatTarget(n),i=this.getExpiration(r);this.expirations.delete(r),this.events.emit(ys.deleted,{target:r,expiration:i})}}),Rt(this,"on",(n,r)=>{this.events.on(n,r)}),Rt(this,"once",(n,r)=>{this.events.once(n,r)}),Rt(this,"off",(n,r)=>{this.events.off(n,r)}),Rt(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=ts(s,this.name)}get context(){return es(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}get length(){return this.expirations.size}get keys(){return Array.from(this.expirations.keys())}get values(){return Array.from(this.expirations.values())}formatTarget(e){if(typeof e=="string")return W0(e);if(typeof e=="number")return H0(e);const{message:s}=Y("UNKNOWN_TYPE",`Target type: ${typeof e}`);throw new Error(s)}async setExpirations(e){await this.core.storage.setItem(this.storageKey,e)}async getExpirations(){return await this.core.storage.getItem(this.storageKey)}async persist(){await this.setExpirations(this.values),this.events.emit(ys.sync)}async restore(){try{const e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){const{message:s}=Y("RESTORE_WILL_OVERRIDE",this.name);throw this.logger.error(s),new Error(s)}this.cached=e,this.logger.debug(`Successfully Restored expirations for ${this.name}`),this.logger.trace({type:"method",method:"restore",expirations:this.values})}catch(e){this.logger.debug(`Failed to Restore expirations for ${this.name}`),this.logger.error(e)}}getExpiration(e){const s=this.expirations.get(e);if(!s){const{message:n}=Y("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(n),new Error(n)}return s}checkExpiry(e,s){const{expiry:n}=s;Z.toMiliseconds(n)-Date.now()<=0&&this.expire(e,s)}expire(e,s){this.expirations.delete(e),this.events.emit(ys.expired,{target:e,expiration:s})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,s)=>this.checkExpiry(s,e))}registerEventListeners(){this.core.heartbeat.on(gi.pulse,()=>this.checkExpirations()),this.events.on(ys.created,e=>{const s=ys.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(ys.expired,e=>{const s=ys.expired;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(ys.deleted,e=>{const s=ys.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()})}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}}var EO=Object.defineProperty,bO=(t,e,s)=>e in t?EO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,nt=(t,e,s)=>bO(t,typeof e!="symbol"?e+"":e,s);class vO extends WC{constructor(e,s,n){super(e,s,n),this.core=e,this.logger=s,this.store=n,nt(this,"name",v1),nt(this,"abortController"),nt(this,"isDevEnv"),nt(this,"verifyUrlV3",_1),nt(this,"storagePrefix",tn),nt(this,"version",km),nt(this,"publicKey"),nt(this,"fetchPromise"),nt(this,"init",async()=>{var r;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&Z.toMiliseconds((r=this.publicKey)==null?void 0:r.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),nt(this,"register",async r=>{if(!yi()||this.isDevEnv)return;const i=window.location.origin,{id:o,decryptedId:a}=r,c=`${this.verifyUrlV3}/attestation?projectId=${this.core.projectId}&origin=${i}&id=${o}&decryptedId=${a}`;try{const l=An.getDocument(),d=this.startAbortTimer(Z.ONE_SECOND*5),u=await new Promise((h,p)=>{const g=()=>{window.removeEventListener("message",y),l.body.removeChild(f),p("attestation aborted")};this.abortController.signal.addEventListener("abort",g);const f=l.createElement("iframe");f.src=c,f.style.display="none",f.addEventListener("error",g,{signal:this.abortController.signal});const y=_=>{if(_.data&&typeof _.data=="string")try{const S=JSON.parse(_.data);if(S.type==="verify_attestation"){if(El(S.attestation).payload.id!==o)return;clearInterval(d),l.body.removeChild(f),this.abortController.signal.removeEventListener("abort",g),window.removeEventListener("message",y),h(S.attestation===null?"":S.attestation)}}catch(S){this.logger.warn(S)}};l.body.appendChild(f),window.addEventListener("message",y,{signal:this.abortController.signal})});return this.logger.debug(u,"jwt attestation"),u}catch(l){this.logger.warn(l)}return""}),nt(this,"resolve",async r=>{if(this.isDevEnv)return"";const{attestationId:i,hash:o,encryptedId:a}=r;if(i===""){this.logger.debug("resolve: attestationId is empty, skipping");return}if(i){if(El(i).payload.id!==a)return;const l=await this.isValidJwtAttestation(i);if(l){if(!l.isVerified){this.logger.warn("resolve: jwt attestation: origin url not verified");return}return l}}if(!o)return;const c=this.getVerifyUrl(r==null?void 0:r.verifyUrl);return this.fetchAttestation(o,c)}),nt(this,"fetchAttestation",async(r,i)=>{this.logger.debug(`resolving attestation: ${r} from url: ${i}`);const o=this.startAbortTimer(Z.ONE_SECOND*5),a=await fetch(`${i}/attestation/${r}?v2Supported=true`,{signal:this.abortController.signal});return clearTimeout(o),a.status===200?await a.json():void 0}),nt(this,"getVerifyUrl",r=>{let i=r||qi;return A1.includes(i)||(this.logger.info(`verify url: ${i}, not included in trusted list, assigning default: ${qi}`),i=qi),i}),nt(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);const r=this.startAbortTimer(Z.FIVE_SECONDS),i=await fetch(`${this.verifyUrlV3}/public-key`,{signal:this.abortController.signal});return clearTimeout(r),await i.json()}catch(r){this.logger.warn(r)}}),nt(this,"persistPublicKey",async r=>{this.logger.debug(r,"persisting public key to local storage"),await this.store.setItem(this.storeKey,r),this.publicKey=r}),nt(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),nt(this,"isValidJwtAttestation",async r=>{const i=await this.getPublicKey();try{if(i)return this.validateAttestation(r,i)}catch(a){this.logger.error(a),this.logger.warn("error validating attestation")}const o=await this.fetchAndPersistPublicKey();try{if(o)return this.validateAttestation(r,o)}catch(a){this.logger.error(a),this.logger.warn("error validating attestation")}}),nt(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),nt(this,"fetchAndPersistPublicKey",async()=>{if(this.fetchPromise)return await this.fetchPromise,this.publicKey;this.fetchPromise=new Promise(async i=>{const o=await this.fetchPublicKey();o&&(await this.persistPublicKey(o),i(o))});const r=await this.fetchPromise;return this.fetchPromise=void 0,r}),nt(this,"validateAttestation",(r,i)=>{const o=jI(r,i.publicKey),a={hasExpired:Z.toMiliseconds(o.exp)<Date.now(),payload:o};if(a.hasExpired)throw this.logger.warn("resolve: jwt attestation expired"),new Error("JWT attestation expired");return{origin:a.payload.origin,isScam:a.payload.isScam,isVerified:a.payload.isVerified}}),this.logger=ts(s,this.name),this.abortController=new AbortController,this.isDevEnv=Ld(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return es(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),Z.toMiliseconds(e))}}var CO=Object.defineProperty,_O=(t,e,s)=>e in t?CO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kp=(t,e,s)=>_O(t,typeof e!="symbol"?e+"":e,s);class AO extends HC{constructor(e,s){super(e,s),this.projectId=e,this.logger=s,kp(this,"context",S1),kp(this,"registerDeviceToken",async n=>{const{clientId:r,token:i,notificationType:o,enableEncrypted:a=!1}=n,c=`${I1}/${this.projectId}/clients`;await fetch(c,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify({client_id:r,type:o,token:i,always_raw:a})})}),this.logger=ts(s,this.context)}}var SO=Object.defineProperty,Up=Object.getOwnPropertySymbols,IO=Object.prototype.hasOwnProperty,NO=Object.prototype.propertyIsEnumerable,hd=(t,e,s)=>e in t?SO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ri=(t,e)=>{for(var s in e||(e={}))IO.call(e,s)&&hd(t,s,e[s]);if(Up)for(var s of Up(e))NO.call(e,s)&&hd(t,s,e[s]);return t},pt=(t,e,s)=>hd(t,typeof e!="symbol"?e+"":e,s);class TO extends zC{constructor(e,s,n=!0){super(e,s,n),this.core=e,this.logger=s,pt(this,"context",T1),pt(this,"storagePrefix",tn),pt(this,"storageVersion",N1),pt(this,"events",new Map),pt(this,"shouldPersist",!1),pt(this,"init",async()=>{if(!Ld())try{const r={eventId:Ch(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:Tg(this.core.relayer.protocol,this.core.relayer.version,rd)}}};await this.sendEvent([r])}catch(r){this.logger.warn(r)}}),pt(this,"createEvent",r=>{const{event:i="ERROR",type:o="",properties:{topic:a,trace:c}}=r,l=Ch(),d=this.core.projectId||"",u=Date.now(),h=Ri({eventId:l,timestamp:u,props:{event:i,type:o,properties:{topic:a,trace:c}},bundleId:d,domain:this.getAppDomain()},this.setMethods(l));return this.telemetryEnabled&&(this.events.set(l,h),this.shouldPersist=!0),h}),pt(this,"getEvent",r=>{const{eventId:i,topic:o}=r;if(i)return this.events.get(i);const a=Array.from(this.events.values()).find(c=>c.props.properties.topic===o);if(a)return Ri(Ri({},a),this.setMethods(a.eventId))}),pt(this,"deleteEvent",r=>{const{eventId:i}=r;this.events.delete(i),this.shouldPersist=!0}),pt(this,"setEventListeners",()=>{this.core.heartbeat.on(gi.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(r=>{Z.fromMiliseconds(Date.now())-Z.fromMiliseconds(r.timestamp)>R1&&(this.events.delete(r.eventId),this.shouldPersist=!0)})})}),pt(this,"setMethods",r=>({addTrace:i=>this.addTrace(r,i),setError:i=>this.setError(r,i)})),pt(this,"addTrace",(r,i)=>{const o=this.events.get(r);o&&(o.props.properties.trace.push(i),this.events.set(r,o),this.shouldPersist=!0)}),pt(this,"setError",(r,i)=>{const o=this.events.get(r);o&&(o.props.type=i,o.timestamp=Date.now(),this.events.set(r,o),this.shouldPersist=!0)}),pt(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),pt(this,"restore",async()=>{try{const r=await this.core.storage.getItem(this.storageKey)||[];if(!r.length)return;r.forEach(i=>{this.events.set(i.eventId,Ri(Ri({},i),this.setMethods(i.eventId)))})}catch(r){this.logger.warn(r)}}),pt(this,"submit",async()=>{if(!this.telemetryEnabled||this.events.size===0)return;const r=[];for(const[i,o]of this.events)o.props.type&&r.push(o);if(r.length!==0)try{if((await this.sendEvent(r)).ok)for(const i of r)this.events.delete(i.eventId),this.shouldPersist=!0}catch(i){this.logger.warn(i)}}),pt(this,"sendEvent",async r=>{const i=this.getAppDomain()?"":"&sp=desktop";return await fetch(`${O1}?projectId=${this.core.projectId}&st=events_sdk&sv=js-${rd}${i}`,{method:"POST",body:JSON.stringify(r)})}),pt(this,"getAppDomain",()=>Ng().url),this.logger=ts(s,this.context),this.telemetryEnabled=n,n?this.restore().then(async()=>{await this.submit(),this.setEventListeners()}):this.persist()}get storageKey(){return this.storagePrefix+this.storageVersion+this.core.customStoragePrefix+"//"+this.context}}var RO=Object.defineProperty,$p=Object.getOwnPropertySymbols,OO=Object.prototype.hasOwnProperty,PO=Object.prototype.propertyIsEnumerable,pd=(t,e,s)=>e in t?RO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Dp=(t,e)=>{for(var s in e||(e={}))OO.call(e,s)&&pd(t,s,e[s]);if($p)for(var s of $p(e))PO.call(e,s)&&pd(t,s,e[s]);return t},ze=(t,e,s)=>pd(t,typeof e!="symbol"?e+"":e,s);let xO=class Gm extends xC{constructor(e){var s;super(e),ze(this,"protocol",xm),ze(this,"version",km),ze(this,"name",nd),ze(this,"relayUrl"),ze(this,"projectId"),ze(this,"customStoragePrefix"),ze(this,"events",new xr.EventEmitter),ze(this,"logger"),ze(this,"heartbeat"),ze(this,"relayer"),ze(this,"crypto"),ze(this,"storage"),ze(this,"history"),ze(this,"expirer"),ze(this,"pairing"),ze(this,"verify"),ze(this,"echoClient"),ze(this,"linkModeSupportedApps"),ze(this,"eventClient"),ze(this,"initialized",!1),ze(this,"logChunkController"),ze(this,"on",(a,c)=>this.events.on(a,c)),ze(this,"once",(a,c)=>this.events.once(a,c)),ze(this,"off",(a,c)=>this.events.off(a,c)),ze(this,"removeListener",(a,c)=>this.events.removeListener(a,c)),ze(this,"dispatchEnvelope",({topic:a,message:c,sessionExists:l})=>{if(!a||!c)return;const d={topic:a,message:c,publishedAt:Date.now(),transportType:Ke.link_mode};this.relayer.onLinkMessageEvent(d,{sessionExists:l})});const n=this.getGlobalCore(e==null?void 0:e.customStoragePrefix);if(n)try{return this.customStoragePrefix=n.customStoragePrefix,this.logger=n.logger,this.heartbeat=n.heartbeat,this.crypto=n.crypto,this.history=n.history,this.expirer=n.expirer,this.storage=n.storage,this.relayer=n.relayer,this.pairing=n.pairing,this.verify=n.verify,this.echoClient=n.echoClient,this.linkModeSupportedApps=n.linkModeSupportedApps,this.eventClient=n.eventClient,this.initialized=n.initialized,this.logChunkController=n.logChunkController,n}catch(a){console.warn("Failed to copy global core",a)}this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||$m,this.customStoragePrefix=e!=null&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";const r=Td({level:typeof(e==null?void 0:e.logger)=="string"&&e.logger?e.logger:JN.logger,name:nd}),{logger:i,chunkLoggerController:o}=ic({opts:r,maxSizeInBytes:e==null?void 0:e.maxLogBlobSizeInBytes,loggerOverride:e==null?void 0:e.logger});this.logChunkController=o,(s=this.logChunkController)!=null&&s.downloadLogsBlobInBrowser&&(window.downloadLogsBlobInBrowser=async()=>{var a,c;(a=this.logChunkController)!=null&&a.downloadLogsBlobInBrowser&&((c=this.logChunkController)==null||c.downloadLogsBlobInBrowser({clientId:await this.crypto.getClientId()}))}),this.logger=ts(i,this.name),this.heartbeat=new Uy,this.crypto=new iR(this,this.logger,e==null?void 0:e.keychain),this.history=new gO(this,this.logger),this.expirer=new wO(this,this.logger),this.storage=e!=null&&e.storage?e.storage:new RC(Dp(Dp({},XN),e==null?void 0:e.storageOptions)),this.relayer=new xR({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new hO(this,this.logger),this.verify=new vO(this,this.logger,this.storage),this.echoClient=new AO(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new TO(this,this.logger,e==null?void 0:e.telemetryEnabled),this.setGlobalCore(this)}static async init(e){const s=new Gm(e);await s.initialize();const n=await s.crypto.getClientId();return await s.storage.setItem(h1,n),s}get context(){return es(this.logger)}async start(){this.initialized||await this.initialize()}async getLogsBlob(){var e;return(e=this.logChunkController)==null?void 0:e.logsToBlob({clientId:await this.crypto.getClientId()})}async addLinkModeSupportedApp(e){this.linkModeSupportedApps.includes(e)||(this.linkModeSupportedApps.push(e),await this.storage.setItem(fp,this.linkModeSupportedApps))}async initialize(){this.logger.trace("Initialized");try{await this.crypto.init(),await this.history.init(),await this.expirer.init(),await this.relayer.init(),await this.heartbeat.init(),await this.pairing.init(),this.linkModeSupportedApps=await this.storage.getItem(fp)||[],this.initialized=!0,this.logger.info("Core Initialization Success")}catch(e){throw this.logger.warn(e,`Core Initialization Failure at epoch ${Date.now()}`),this.logger.error(e.message),e}}getGlobalCore(e=""){try{if(this.isGlobalCoreDisabled())return;const s=`_walletConnectCore_${e}`,n=`${s}_count`;return globalThis[n]=(globalThis[n]||0)+1,globalThis[n]>1&&console.warn(`WalletConnect Core is already initialized. This is probably a mistake and can lead to unexpected behavior. Init() was called ${globalThis[n]} times.`),globalThis[s]}catch(s){console.warn("Failed to get global WalletConnect core",s);return}}setGlobalCore(e){var s;try{if(this.isGlobalCoreDisabled())return;const n=`_walletConnectCore_${((s=e.opts)==null?void 0:s.customStoragePrefix)||""}`;globalThis[n]=e}catch(n){console.warn("Failed to set global WalletConnect core",n)}}isGlobalCoreDisabled(){try{return typeof En<"u"&&ZN.DISABLE_GLOBAL_CORE==="true"}catch{return!0}}};const kO=xO;var Ns={};const Ym="wc",Zm=2,Jm="client",Yd=`${Ym}@${Zm}:${Jm}:`,il={name:Jm,logger:"error"},Lp="WALLETCONNECT_DEEPLINK_CHOICE",UO="proposal",Mp="Proposal expired",$O="session",Hr=Z.SEVEN_DAYS,DO="engine",vt={wc_sessionPropose:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1104},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1106},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:Z.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1112},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:Z.ONE_DAY,prompt:!1,tag:1114},res:{ttl:Z.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:Z.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:Z.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:Z.FIVE_MINUTES,prompt:!1,tag:1119}}},ol={min:Z.FIVE_MINUTES,max:Z.SEVEN_DAYS},qs={idle:"IDLE",active:"ACTIVE"},LO={eth_sendTransaction:{key:""},eth_sendRawTransaction:{key:""},wallet_sendCalls:{key:""},solana_signTransaction:{key:"signature"},solana_signAllTransactions:{key:"transactions"},solana_signAndSendTransaction:{key:"signature"},sui_signAndExecuteTransaction:{key:"digest"},sui_signTransaction:{key:""},hedera_signAndExecuteTransaction:{key:"transactionId"},hedera_executeTransaction:{key:"transactionId"},near_signTransaction:{key:""},near_signTransactions:{key:""},tron_signTransaction:{key:"txID"},xrpl_signTransaction:{key:""},xrpl_signTransactionFor:{key:""},algo_signTxn:{key:""},sendTransfer:{key:"txid"},stacks_stxTransfer:{key:"txId"},polkadot_signTransaction:{key:""},cosmos_signDirect:{key:""}},MO="request",BO=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],jO="wc",FO="auth",qO="authKeys",WO="pairingTopics",HO="requests",Ec=`${jO}@${1.5}:${FO}:`,Ea=`${Ec}:PUB_KEY`;var zO=Object.defineProperty,VO=Object.defineProperties,KO=Object.getOwnPropertyDescriptors,Bp=Object.getOwnPropertySymbols,GO=Object.prototype.hasOwnProperty,YO=Object.prototype.propertyIsEnumerable,fd=(t,e,s)=>e in t?zO(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Be=(t,e)=>{for(var s in e||(e={}))GO.call(e,s)&&fd(t,s,e[s]);if(Bp)for(var s of Bp(e))YO.call(e,s)&&fd(t,s,e[s]);return t},Ct=(t,e)=>VO(t,KO(e)),H=(t,e,s)=>fd(t,typeof e!="symbol"?e+"":e,s);class ZO extends YC{constructor(e){super(e),H(this,"name",DO),H(this,"events",new Sd),H(this,"initialized",!1),H(this,"requestQueue",{state:qs.idle,queue:[]}),H(this,"sessionRequestQueue",{state:qs.idle,queue:[]}),H(this,"emittedSessionRequests",new Q0({limit:500})),H(this,"requestQueueDelay",Z.ONE_SECOND),H(this,"expectedPairingMethodMap",new Map),H(this,"recentlyDeletedMap",new Map),H(this,"recentlyDeletedLimit",200),H(this,"relayMessageCache",[]),H(this,"pendingSessions",new Map),H(this,"init",async()=>{this.initialized||(await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.registerPairingEvents(),await this.registerLinkModeListeners(),this.client.core.pairing.register({methods:Object.keys(vt)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},Z.toMiliseconds(this.requestQueueDelay)))}),H(this,"connect",async s=>{var n;this.isInitialized(),await this.confirmOnlineStateOrThrow();const r=Ct(Be({},s),{requiredNamespaces:s.requiredNamespaces||{},optionalNamespaces:s.optionalNamespaces||{}});await this.isValidConnect(r),r.optionalNamespaces=lN(r.requiredNamespaces,r.optionalNamespaces),r.requiredNamespaces={};const{pairingTopic:i,requiredNamespaces:o,optionalNamespaces:a,sessionProperties:c,scopedProperties:l,relays:d,authentication:u,walletPay:h}=r,p=((n=u==null?void 0:u[0])==null?void 0:n.ttl)||vt.wc_sessionPropose.req.ttl||Z.FIVE_MINUTES;this.validateRequestExpiry(p);let g=i,f,y=!1;try{if(g){const k=this.client.core.pairing.pairings.get(g);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),y=k.active}}catch(k){throw this.client.logger.error(`connect() -> pairing.get(${g}) failed`),k}if(!g||!y){const{topic:k,uri:q}=await this.client.core.pairing.create({internal:{skipSubscribe:!0}});g=k,f=q}if(!g){const{message:k}=Y("NO_MATCHING_KEY",`connect() pairing topic: ${g}`);throw new Error(k)}const _=await this.client.core.crypto.generateKeyPair(),S=rt(p),v=Be(Ct(Be(Be({requiredNamespaces:o,optionalNamespaces:a,relays:d??[{protocol:Um}],proposer:{publicKey:_,metadata:this.client.metadata},expiryTimestamp:S,pairingTopic:g},c&&{sessionProperties:c}),l&&{scopedProperties:l}),{id:Nn()}),(u||h)&&{requests:{authentication:u==null?void 0:u.map(k=>{const{domain:q,chains:V,nonce:x,uri:N,exp:T,nbf:w,type:b,statement:I,requestId:O,resources:A,signatureTypes:P}=k;return{domain:q,chains:V,nonce:x,type:b??"caip122",aud:N,version:"1",iat:new Date().toISOString(),exp:T,nbf:w,statement:I,requestId:O,resources:A,signatureTypes:P}}),walletPay:h}}),C=Fe("session_connect",v.id),{reject:R,resolve:D,done:L}=dr(p,Mp),W=({id:k})=>{k===v.id&&(this.client.events.off("proposal_expire",W),this.pendingSessions.delete(v.id),this.events.emit(C,{error:{message:Mp,code:0}}))};return this.client.events.on("proposal_expire",W),this.events.once(C,({error:k,session:q})=>{this.client.events.off("proposal_expire",W),k?R(k):q&&D(q)}),await this.setProposal(v.id,v),await this.sendProposeSession({proposal:v,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:v.id}}}).catch(k=>{throw this.deleteProposal(v.id),k}),{uri:f,approval:L}}),H(this,"pair",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{return await this.client.core.pairing.pair(s)}catch(n){throw this.client.logger.error("pair() failed"),n}}),H(this,"approve",async s=>{var n,r,i;const o=this.client.core.eventClient.createEvent({properties:{topic:(n=s==null?void 0:s.id)==null?void 0:n.toString(),trace:[Is.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(q){throw o.setError(rr.no_internet_connection),q}try{await this.isValidProposalId(s==null?void 0:s.id)}catch(q){throw this.client.logger.error(`approve() -> proposal.get(${s==null?void 0:s.id}) failed`),o.setError(rr.proposal_not_found),q}try{await this.isValidApprove(s)}catch(q){throw this.client.logger.error("approve() -> isValidApprove() failed"),o.setError(rr.session_approve_namespace_validation_failure),q}const{id:a,relayProtocol:c,namespaces:l,sessionProperties:d,scopedProperties:u,sessionConfig:h,proposalRequestsResponses:p}=s,g=this.client.proposal.get(a);this.client.core.eventClient.deleteEvent({eventId:o.eventId});const{pairingTopic:f,proposer:y,requiredNamespaces:_,optionalNamespaces:S}=g;let v=(r=this.client.core.eventClient)==null?void 0:r.getEvent({topic:f});v||(v=(i=this.client.core.eventClient)==null?void 0:i.createEvent({type:Is.session_approve_started,properties:{topic:f,trace:[Is.session_approve_started,Is.session_namespaces_validation_success]}}));const C=await this.client.core.crypto.generateKeyPair(),R=y.publicKey,D=await this.client.core.crypto.generateSharedKey(C,R),L=Ct(Be(Be(Be({relay:{protocol:c??"irn"},namespaces:l,controller:{publicKey:C,metadata:this.client.metadata},expiry:rt(Hr)},d&&{sessionProperties:d}),u&&{scopedProperties:u}),h&&{sessionConfig:h}),{proposalRequestsResponses:p}),W=Ke.relay;v.addTrace(Is.subscribing_session_topic);try{await this.client.core.relayer.subscribe(D,{transportType:W,internal:{skipSubscribe:!0}})}catch(q){throw v.setError(rr.subscribe_session_topic_failure),q}v.addTrace(Is.subscribe_session_topic_success);const k=Ct(Be({},L),{topic:D,requiredNamespaces:_,optionalNamespaces:S,pairingTopic:f,acknowledged:!1,self:L.controller,peer:{publicKey:y.publicKey,metadata:y.metadata},controller:C,transportType:Ke.relay,authentication:p==null?void 0:p.authentication,walletPayResult:p==null?void 0:p.walletPay});await this.client.session.set(D,k),v.addTrace(Is.store_session);try{await this.sendApproveSession({sessionTopic:D,proposal:g,pairingProposalResponse:{relay:{protocol:c??"irn"},responderPublicKey:C},sessionSettleRequest:L,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:Be({correlationId:a},this.getTVFApproveParams(k))}}),v.addTrace(Is.session_approve_publish_success)}catch(q){throw this.client.logger.error(q),this.client.session.delete(D,Ze("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(D),q}return this.client.core.eventClient.deleteEvent({eventId:v.eventId}),await this.client.core.pairing.updateMetadata({topic:f,metadata:y.metadata}),await this.deleteProposal(a),await this.client.core.pairing.activate({topic:f}),await this.setExpiry(D,rt(Hr)),{topic:D,acknowledged:()=>Promise.resolve(this.client.session.get(D))}}),H(this,"reject",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidReject(s)}catch(o){throw this.client.logger.error("reject() -> isValidReject() failed"),o}const{id:n,reason:r}=s;let i;try{i=this.client.proposal.get(n).pairingTopic}catch(o){throw this.client.logger.error(`reject() -> proposal.get(${n}) failed`),o}i&&await this.sendError({id:n,topic:i,error:r,rpcOpts:vt.wc_sessionPropose.reject}),await this.deleteProposal(n)}),H(this,"update",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(s)}catch(u){throw this.client.logger.error("update() -> isValidUpdate() failed"),u}const{topic:n,namespaces:r}=s,{done:i,resolve:o,reject:a}=dr(Z.FIVE_MINUTES,"Session update request expired without receiving any acknowledgement"),c=Nn(),l=fr().toString(),d=this.client.session.get(n).namespaces;return this.events.once(Fe("session_update",c),({error:u})=>{u?a(u):o()}),await this.client.session.update(n,{namespaces:r}),await this.sendRequest({topic:n,method:"wc_sessionUpdate",params:{namespaces:r},throwOnFailedPublish:!0,clientRpcId:c,relayRpcId:l}).catch(u=>{this.client.logger.error(u),this.client.session.update(n,{namespaces:d}),a(u)}),{acknowledged:i}}),H(this,"extend",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidExtend(s)}catch(c){throw this.client.logger.error("extend() -> isValidExtend() failed"),c}const{topic:n}=s,r=Nn(),{done:i,resolve:o,reject:a}=dr(Z.FIVE_MINUTES,"Session extend request expired without receiving any acknowledgement");return this.events.once(Fe("session_extend",r),({error:c})=>{c?a(c):o()}),await this.setExpiry(n,rt(Hr)),this.sendRequest({topic:n,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(c=>{a(c)}),{acknowledged:i}}),H(this,"request",async s=>{this.isInitialized();try{await this.isValidRequest(s)}catch(y){throw this.client.logger.error("request() -> isValidRequest() failed"),y}const{chainId:n,request:r,topic:i,expiry:o=vt.wc_sessionRequest.req.ttl}=s,a=this.client.session.get(i);(a==null?void 0:a.transportType)===Ke.relay&&await this.confirmOnlineStateOrThrow();const c=Nn(),l=fr().toString(),{done:d,resolve:u,reject:h}=dr(o,"Request expired. Please try again.");this.events.once(Fe("session_request",c),({error:y,result:_})=>{y?h(y):u(_)});const p="wc_sessionRequest",g=this.getAppLinkIfEnabled(a.peer.metadata,a.transportType);if(g)return await this.sendRequest({clientRpcId:c,relayRpcId:l,topic:i,method:p,params:{request:Ct(Be({},r),{expiryTimestamp:rt(o)}),chainId:n},expiry:o,throwOnFailedPublish:!0,appLink:g}).catch(y=>h(y)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),await d();const f={request:Ct(Be({},r),{expiryTimestamp:rt(o)}),chainId:n};return await Promise.all([new Promise(async y=>{await this.sendRequest({clientRpcId:c,relayRpcId:l,topic:i,method:p,params:f,expiry:o,throwOnFailedPublish:!0,tvf:this.getTVFParams(c,f)}).catch(_=>h(_)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),y()}),new Promise(async y=>{var _;if(!((_=a.sessionConfig)!=null&&_.disableDeepLink)){const S=await G0(this.client.core.storage,Lp);await z0({id:c,topic:i,wcDeepLink:S})}y()}),d()]).then(y=>y[2])}),H(this,"respond",async s=>{var n,r;this.isInitialized();const i=this.client.core.eventClient.createEvent({properties:{topic:(s==null?void 0:s.topic)||((r=(n=s==null?void 0:s.response)==null?void 0:n.id)==null?void 0:r.toString()),trace:[Is.session_request_response_started]}});try{await this.isValidRespond(s)}catch(u){throw i.addTrace(u==null?void 0:u.message),i.setError(rr.session_request_response_validation_failure),u}i.addTrace(Is.session_request_response_validation_success);const{topic:o,response:a}=s,{id:c}=a,l=this.client.session.get(o);l.transportType===Ke.relay&&await this.confirmOnlineStateOrThrow();const d=this.getAppLinkIfEnabled(l.peer.metadata,l.transportType);try{i.addTrace(Is.session_request_response_publish_started),cn(a)?await this.sendResult({id:c,topic:o,result:a.result,throwOnFailedPublish:!0,appLink:d}):Hs(a)&&await this.sendError({id:c,topic:o,error:a.error,appLink:d}),this.cleanupAfterResponse(s)}catch(u){throw i.addTrace(u==null?void 0:u.message),i.setError(rr.session_request_response_publish_failure),u}}),H(this,"ping",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidPing(s)}catch(r){throw this.client.logger.error("ping() -> isValidPing() failed"),r}const{topic:n}=s;if(this.client.session.keys.includes(n)){const r=Nn(),i=fr().toString(),{done:o,resolve:a,reject:c}=dr(Z.FIVE_MINUTES,"Ping request expired without receiving any acknowledgement");this.events.once(Fe("session_ping",r),({error:l})=>{l?c(l):a()}),await Promise.all([this.sendRequest({topic:n,method:"wc_sessionPing",params:{},throwOnFailedPublish:!0,clientRpcId:r,relayRpcId:i}),o()])}else this.client.core.pairing.pairings.keys.includes(n)&&(this.client.logger.warn("ping() on pairing topic is deprecated and will be removed in the next major release."),await this.client.core.pairing.ping({topic:n}))}),H(this,"emit",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(s);const{topic:n,event:r,chainId:i}=s,o=fr().toString(),a=Nn();await this.sendRequest({topic:n,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:o,clientRpcId:a})}),H(this,"disconnect",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidDisconnect(s);const{topic:n}=s;if(this.client.session.keys.includes(n))await this.sendRequest({topic:n,method:"wc_sessionDelete",params:Ze("USER_DISCONNECTED"),throwOnFailedPublish:!0}),await this.deleteSession({topic:n,emitEvent:!1});else if(this.client.core.pairing.pairings.keys.includes(n))await this.client.core.pairing.disconnect({topic:n});else{const{message:r}=Y("MISMATCHED_TOPIC",`Session or pairing topic not found: ${n}`);throw new Error(r)}}),H(this,"find",s=>(this.isInitialized(),this.client.session.getAll().filter(n=>hN(n,s)))),H(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),H(this,"authenticate",async(s,n)=>{var r;this.isInitialized(),this.isValidAuthenticate(s);const i=n&&this.client.core.linkModeSupportedApps.includes(n)&&((r=this.client.metadata.redirect)==null?void 0:r.linkMode),o=i?Ke.link_mode:Ke.relay;o===Ke.relay&&await this.confirmOnlineStateOrThrow();const{chains:a,statement:c="",uri:l,domain:d,nonce:u,type:h,exp:p,nbf:g,methods:f=[],expiry:y}=s,_=[...s.resources||[]],{topic:S,uri:v}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:S,uri:v}});const C=await this.client.core.crypto.generateKeyPair(),R=ya(C);if(await Promise.all([this.client.auth.authKeys.set(Ea,{responseTopic:R,publicKey:C}),this.client.auth.pairingTopics.set(R,{topic:R,pairingTopic:S})]),await this.client.core.relayer.subscribe(R,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${S}`),f.length>0){const{namespace:A}=vn(a[0]);let P=hS(A,"request",f);ma(_)&&(P=fS(P,_.pop())),_.push(P)}const D=y&&y>vt.wc_sessionAuthenticate.req.ttl?y:vt.wc_sessionAuthenticate.req.ttl,L={authPayload:{type:h??"caip122",chains:a,statement:c,aud:l,domain:d,version:"1",nonce:u,iat:new Date().toISOString(),exp:p,nbf:g,resources:_},requester:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:rt(D)},W={eip155:{chains:a,methods:[...new Set(["personal_sign",...f])],events:["chainChanged","accountsChanged"]}},k={requiredNamespaces:{},optionalNamespaces:W,relays:[{protocol:"irn"}],pairingTopic:S,proposer:{publicKey:C,metadata:this.client.metadata},expiryTimestamp:rt(vt.wc_sessionPropose.req.ttl),id:Nn()},{done:q,resolve:V,reject:x}=dr(D,"Request expired"),N=Nn(),T=Fe("session_connect",k.id),w=Fe("session_request",N),b=async({error:A,session:P})=>{this.events.off(w,I),A?x(A):P&&V({session:P})},I=async A=>{var P,B,M;if(await this.deletePendingAuthRequest(N,{message:"fulfilled",code:0}),A.error){const ye=Ze("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return A.error.code===ye.code?void 0:(this.events.off(T,b),x(A.error.message))}await this.deleteProposal(k.id),this.events.off(T,b);const{cacaos:ce,responder:j}=A.result,J=[],he=[];for(const ye of ce){await kh({cacao:ye,projectId:this.client.core.projectId})||(this.client.logger.error(ye,"Signature verification failed"),x(Ze("SESSION_SETTLEMENT_FAILED","Signature verification failed")));const{p:ve}=ye,Ve=ma(ve.resources),st=[zl(ve.iss)],ut=za(ve.iss);if(Ve){const wt=Uh(Ve),Bs=$h(Ve);J.push(...wt),st.push(...Bs)}for(const wt of st)he.push(`${wt}:${ut}`)}const ge=await this.client.core.crypto.generateSharedKey(C,j.publicKey);let Oe;J.length>0&&(Oe={topic:ge,acknowledged:!0,self:{publicKey:C,metadata:this.client.metadata},peer:j,controller:j.publicKey,expiry:rt(Hr),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:S,namespaces:ap([...new Set(J)],[...new Set(he)]),transportType:o},await this.client.core.relayer.subscribe(ge,{transportType:o}),await this.client.session.set(ge,Oe),S&&await this.client.core.pairing.updateMetadata({topic:S,metadata:j.metadata}),Oe=this.client.session.get(ge)),(P=this.client.metadata.redirect)!=null&&P.linkMode&&(B=j.metadata.redirect)!=null&&B.linkMode&&(M=j.metadata.redirect)!=null&&M.universal&&n&&(this.client.core.addLinkModeSupportedApp(j.metadata.redirect.universal),this.client.session.update(ge,{transportType:Ke.link_mode})),V({auths:ce,session:Oe})};this.events.once(T,b),this.events.once(w,I);let O;try{if(i){const A=zs("wc_sessionAuthenticate",L,N);this.client.core.history.set(S,A);const P=await this.client.core.crypto.encode("",A,{type:ko,encoding:qn});O=sa(n,S,P)}else await Promise.all([this.sendRequest({topic:S,method:"wc_sessionAuthenticate",params:L,expiry:s.expiry,throwOnFailedPublish:!0,clientRpcId:N}),this.sendRequest({topic:S,method:"wc_sessionPropose",params:k,expiry:vt.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:k.id})])}catch(A){throw this.events.off(T,b),this.events.off(w,I),A}return await this.setProposal(k.id,k),await this.setAuthRequest(N,{request:Ct(Be({},L),{verifyContext:{}}),pairingTopic:S,transportType:o}),{uri:O??v,response:q}}),H(this,"approveSessionAuthenticate",async s=>{const{id:n,auths:r}=s,i=this.client.core.eventClient.createEvent({properties:{topic:n.toString(),trace:[ir.authenticated_session_approve_started]}});try{this.isInitialized()}catch(y){throw i.setError(Ni.no_internet_connection),y}const o=this.getPendingAuthRequest(n);if(!o)throw i.setError(Ni.authenticated_session_pending_request_not_found),new Error(`Could not find pending auth request with id ${n}`);const a=o.transportType||Ke.relay;a===Ke.relay&&await this.confirmOnlineStateOrThrow();const c=o.requester.publicKey,l=await this.client.core.crypto.generateKeyPair(),d=ya(c),u={type:Cn,receiverPublicKey:c,senderPublicKey:l},h=[],p=[];for(const y of r){if(!await kh({cacao:y,projectId:this.client.core.projectId})){i.setError(Ni.invalid_cacao);const R=Ze("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:n,topic:d,error:R,encodeOpts:u}),new Error(R.message)}i.addTrace(ir.cacaos_verified);const{p:_}=y,S=ma(_.resources),v=[zl(_.iss)],C=za(_.iss);if(S){const R=Uh(S),D=$h(S);h.push(...R),v.push(...D)}for(const R of v)p.push(`${R}:${C}`)}const g=await this.client.core.crypto.generateSharedKey(l,c);i.addTrace(ir.create_authenticated_session_topic);let f;if((h==null?void 0:h.length)>0){f={topic:g,acknowledged:!0,self:{publicKey:l,metadata:this.client.metadata},peer:{publicKey:c,metadata:o.requester.metadata},controller:c,expiry:rt(Hr),authentication:r,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:o.pairingTopic,namespaces:ap([...new Set(h)],[...new Set(p)]),transportType:a},i.addTrace(ir.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(g,{transportType:a})}catch(y){throw i.setError(Ni.subscribe_authenticated_session_topic_failure),y}i.addTrace(ir.subscribe_authenticated_session_topic_success),await this.client.session.set(g,f),i.addTrace(ir.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:o.pairingTopic,metadata:o.requester.metadata})}i.addTrace(ir.publishing_authenticated_session_approve);try{await this.sendResult({topic:d,id:n,result:{cacaos:r,responder:{publicKey:l,metadata:this.client.metadata}},encodeOpts:u,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(o.requester.metadata,a)})}catch(y){throw i.setError(Ni.authenticated_session_approve_publish_failure),y}return await this.client.auth.requests.delete(n,{message:"fulfilled",code:0}),await this.client.core.pairing.activate({topic:o.pairingTopic}),this.client.core.eventClient.deleteEvent({eventId:i.eventId}),{session:f}}),H(this,"rejectSessionAuthenticate",async s=>{this.isInitialized();const{id:n,reason:r}=s,i=this.getPendingAuthRequest(n);if(!i)throw new Error(`Could not find pending auth request with id ${n}`);i.transportType===Ke.relay&&await this.confirmOnlineStateOrThrow();const o=i.requester.publicKey,a=await this.client.core.crypto.generateKeyPair(),c=ya(o),l={type:Cn,receiverPublicKey:o,senderPublicKey:a};await this.sendError({id:n,topic:c,error:r,encodeOpts:l,rpcOpts:vt.wc_sessionAuthenticate.reject,appLink:this.getAppLinkIfEnabled(i.requester.metadata,i.transportType)}),await this.client.auth.requests.delete(n,{message:"rejected",code:0}),await this.deleteProposal(n)}),H(this,"formatAuthMessage",s=>{this.isInitialized();const{request:n,iss:r}=s;return Kg(n,r)}),H(this,"processRelayMessageCache",()=>{setTimeout(async()=>{if(this.relayMessageCache.length!==0)for(;this.relayMessageCache.length>0;)try{const s=this.relayMessageCache.shift();s&&await this.onRelayMessage(s)}catch(s){this.client.logger.error(s)}},50)}),H(this,"cleanupDuplicatePairings",async s=>{if(s.pairingTopic)try{const n=this.client.core.pairing.pairings.get(s.pairingTopic),r=this.client.core.pairing.pairings.getAll().filter(i=>{var o,a;return((o=i.peerMetadata)==null?void 0:o.url)&&((a=i.peerMetadata)==null?void 0:a.url)===s.peer.metadata.url&&i.topic&&i.topic!==n.topic});if(r.length===0)return;this.client.logger.info(`Cleaning up ${r.length} duplicate pairing(s)`),await Promise.all(r.map(i=>this.client.core.pairing.disconnect({topic:i.topic}))),this.client.logger.info("Duplicate pairings clean up finished")}catch(n){this.client.logger.error(n)}}),H(this,"deleteSession",async s=>{var n;const{topic:r,expirerHasDeleted:i=!1,emitEvent:o=!0,id:a=0}=s,{self:c}=this.client.session.get(r);await this.client.core.relayer.unsubscribe(r),await this.client.session.delete(r,Ze("USER_DISCONNECTED")),this.addToRecentlyDeleted(r,"session"),this.client.core.crypto.keychain.has(c.publicKey)&&await this.client.core.crypto.deleteKeyPair(c.publicKey),this.client.core.crypto.keychain.has(r)&&await this.client.core.crypto.deleteSymKey(r),i||this.client.core.expirer.del(r),this.client.core.storage.removeItem(Lp).catch(l=>this.client.logger.warn(l)),r===((n=this.sessionRequestQueue.queue[0])==null?void 0:n.topic)&&(this.sessionRequestQueue.state=qs.idle),await Promise.all(this.getPendingSessionRequests().filter(l=>l.topic===r).map(l=>this.deletePendingSessionRequest(l.id,Ze("USER_DISCONNECTED")))),o&&this.client.events.emit("session_delete",{id:a,topic:r})}),H(this,"deleteProposal",async(s,n)=>{if(n)try{const r=this.client.proposal.get(s),i=this.client.core.eventClient.getEvent({topic:r.pairingTopic});i==null||i.setError(rr.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(s,Ze("USER_DISCONNECTED")),n?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"proposal")}),H(this,"deletePendingSessionRequest",async(s,n,r=!1)=>{await Promise.all([this.client.pendingRequest.delete(s,n),r?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"request"),this.sessionRequestQueue.queue=this.sessionRequestQueue.queue.filter(i=>i.id!==s),r&&(this.sessionRequestQueue.state=qs.idle,this.client.events.emit("session_request_expire",{id:s}))}),H(this,"deletePendingAuthRequest",async(s,n,r=!1)=>{await Promise.all([this.client.auth.requests.delete(s,n),r?Promise.resolve():this.client.core.expirer.del(s)])}),H(this,"setExpiry",async(s,n)=>{this.client.session.keys.includes(s)&&(this.client.core.expirer.set(s,n),await this.client.session.update(s,{expiry:n}))}),H(this,"setProposal",async(s,n)=>{this.client.core.expirer.set(s,rt(vt.wc_sessionPropose.req.ttl)),await this.client.proposal.set(s,n)}),H(this,"setAuthRequest",async(s,n)=>{const{request:r,pairingTopic:i,transportType:o=Ke.relay}=n;this.client.core.expirer.set(s,r.expiryTimestamp),await this.client.auth.requests.set(s,{authPayload:r.authPayload,requester:r.requester,expiryTimestamp:r.expiryTimestamp,id:s,pairingTopic:i,verifyContext:r.verifyContext,transportType:o})}),H(this,"setPendingSessionRequest",async s=>{const{id:n,topic:r,params:i,verifyContext:o}=s,a=i.request.expiryTimestamp||rt(vt.wc_sessionRequest.req.ttl);this.client.core.expirer.set(n,a),await this.client.pendingRequest.set(n,{id:n,topic:r,params:i,verifyContext:o})}),H(this,"sendRequest",async s=>{const{topic:n,method:r,params:i,expiry:o,relayRpcId:a,clientRpcId:c,throwOnFailedPublish:l,appLink:d,tvf:u,publishOpts:h={}}=s,p=zs(r,i,c);let g;const f=!!d;try{const S=f?qn:Zt;g=await this.client.core.crypto.encode(n,p,{encoding:S})}catch(S){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${n} failed`),S}let y;if(BO.includes(r)){const S=Es(JSON.stringify(p)),v=Es(g);y=await this.client.core.verify.register({id:v,decryptedId:S})}const _=Be(Be({},vt[r].req),h);if(_.attestation=y,o&&(_.ttl=o),a&&(_.id=a),this.client.core.history.set(n,p),f){const S=sa(d,n,g);await Ns.Linking.openURL(S,this.client.name)}else _.tvf=Ct(Be({},u),{correlationId:p.id}),l?(_.internal=Ct(Be({},_.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,g,_)):this.client.core.relayer.publish(n,g,_).catch(S=>this.client.logger.error(S));return p.id}),H(this,"sendProposeSession",async s=>{const{proposal:n,publishOpts:r}=s,i=zs("wc_sessionPropose",n,n.id);this.client.core.history.set(n.pairingTopic,i);const o=await this.client.core.crypto.encode(n.pairingTopic,i,{encoding:Zt}),a=Es(JSON.stringify(i)),c=Es(o),l=await this.client.core.verify.register({id:c,decryptedId:a});await this.client.core.relayer.publishCustom({payload:{pairingTopic:n.pairingTopic,sessionProposal:o},opts:Ct(Be({},r),{publishMethod:"wc_proposeSession",attestation:l})})}),H(this,"sendApproveSession",async s=>{const{sessionTopic:n,pairingProposalResponse:r,proposal:i,sessionSettleRequest:o,publishOpts:a}=s,c=Yi(i.id,r),l=await this.client.core.crypto.encode(i.pairingTopic,c,{encoding:Zt}),d=zs("wc_sessionSettle",o,a==null?void 0:a.id),u=await this.client.core.crypto.encode(n,d,{encoding:Zt});this.client.core.history.set(n,d),await this.client.core.relayer.publishCustom({payload:{sessionTopic:n,pairingTopic:i.pairingTopic,sessionProposalResponse:l,sessionSettlementRequest:u},opts:Ct(Be({},a),{publishMethod:"wc_approveSession"})})}),H(this,"sendResult",async s=>{const{id:n,topic:r,result:i,throwOnFailedPublish:o,encodeOpts:a,appLink:c}=s,l=Yi(n,i);let d;const u=c&&typeof(Ns==null?void 0:Ns.Linking)<"u";try{const g=u?qn:Zt;d=await this.client.core.crypto.encode(r,l,Ct(Be({},a||{}),{encoding:g}))}catch(g){throw await this.cleanup(),this.client.logger.error(`sendResult() -> core.crypto.encode() for topic ${r} failed`),g}let h,p;try{h=await this.client.core.history.get(r,n);const g=h.request;try{p=this.getTVFParams(n,g.params,i)}catch(f){this.client.logger.warn(`sendResult() -> getTVFParams() failed: ${f==null?void 0:f.message}`)}}catch(g){throw this.client.logger.error(`sendResult() -> history.get(${r}, ${n}) failed`),g}if(u){const g=sa(c,r,d);await Ns.Linking.openURL(g,this.client.name)}else{const g=h.request.method,f=vt[g].res;f.tvf=Ct(Be({},p),{correlationId:n}),o?(f.internal=Ct(Be({},f.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(r,d,f)):this.client.core.relayer.publish(r,d,f).catch(y=>this.client.logger.error(y))}await this.client.core.history.resolve(l)}),H(this,"sendError",async s=>{const{id:n,topic:r,error:i,encodeOpts:o,rpcOpts:a,appLink:c}=s,l=Cf(n,i);let d;const u=c&&typeof(Ns==null?void 0:Ns.Linking)<"u";try{const p=u?qn:Zt;d=await this.client.core.crypto.encode(r,l,Ct(Be({},o||{}),{encoding:p}))}catch(p){throw await this.cleanup(),this.client.logger.error(`sendError() -> core.crypto.encode() for topic ${r} failed`),p}let h;try{h=await this.client.core.history.get(r,n)}catch(p){throw this.client.logger.error(`sendError() -> history.get(${r}, ${n}) failed`),p}if(u){const p=sa(c,r,d);await Ns.Linking.openURL(p,this.client.name)}else{const p=h.request.method,g=a||vt[p].res;this.client.core.relayer.publish(r,d,g)}await this.client.core.history.resolve(l)}),H(this,"cleanup",async()=>{const s=[],n=[];this.client.session.getAll().forEach(r=>{let i=!1;Vs(r.expiry)&&(i=!0),this.client.core.crypto.keychain.has(r.topic)||(i=!0),i&&s.push(r.topic)}),this.client.proposal.getAll().forEach(r=>{Vs(r.expiryTimestamp)&&n.push(r.id)}),await Promise.all([...s.map(r=>this.deleteSession({topic:r})),...n.map(r=>this.deleteProposal(r))])}),H(this,"onProviderMessageEvent",async s=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(s):await this.onRelayMessage(s)}),H(this,"onRelayEventRequest",async s=>{this.requestQueue.queue.push(s),await this.processRequestsQueue()}),H(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===qs.active){this.client.logger.info("Request queue already active, skipping...");return}for(this.client.logger.info(`Request queue starting with ${this.requestQueue.queue.length} requests`);this.requestQueue.queue.length>0;){this.requestQueue.state=qs.active;const s=this.requestQueue.queue.shift();if(s)try{await this.processRequest(s)}catch(n){this.client.logger.warn(n)}}this.requestQueue.state=qs.idle}),H(this,"processRequest",async s=>{const{topic:n,payload:r,attestation:i,transportType:o,encryptedId:a}=s,c=r.method;if(!this.shouldIgnorePairingRequest({topic:n,requestMethod:c}))switch(c){case"wc_sessionPropose":return await this.onSessionProposeRequest({topic:n,payload:r,attestation:i,encryptedId:a});case"wc_sessionSettle":return await this.onSessionSettleRequest(n,r);case"wc_sessionUpdate":return await this.onSessionUpdateRequest(n,r);case"wc_sessionExtend":return await this.onSessionExtendRequest(n,r);case"wc_sessionPing":return await this.onSessionPingRequest(n,r);case"wc_sessionDelete":return await this.onSessionDeleteRequest(n,r);case"wc_sessionRequest":return await this.onSessionRequest({topic:n,payload:r,attestation:i,encryptedId:a,transportType:o});case"wc_sessionEvent":return await this.onSessionEventRequest(n,r);case"wc_sessionAuthenticate":return await this.onSessionAuthenticateRequest({topic:n,payload:r,attestation:i,encryptedId:a,transportType:o});default:return this.client.logger.info(`Unsupported request method ${c}`)}}),H(this,"onRelayEventResponse",async s=>{const{topic:n,payload:r,transportType:i}=s,o=(await this.client.core.history.get(n,r.id)).request.method;switch(o){case"wc_sessionPropose":return this.onSessionProposeResponse(n,r,i);case"wc_sessionSettle":return this.onSessionSettleResponse(n,r);case"wc_sessionUpdate":return this.onSessionUpdateResponse(n,r);case"wc_sessionExtend":return this.onSessionExtendResponse(n,r);case"wc_sessionPing":return this.onSessionPingResponse(n,r);case"wc_sessionRequest":return this.onSessionRequestResponse(n,r);case"wc_sessionAuthenticate":return this.onSessionAuthenticateResponse(n,r);default:return this.client.logger.info(`Unsupported response method ${o}`)}}),H(this,"onRelayEventUnknownPayload",s=>{const{topic:n}=s,{message:r}=Y("MISSING_OR_INVALID",`Decoded payload on topic ${n} is not identifiable as a JSON-RPC request or a response.`);throw new Error(r)}),H(this,"shouldIgnorePairingRequest",s=>{const{topic:n,requestMethod:r}=s,i=this.expectedPairingMethodMap.get(n);return!i||i.includes(r)?!1:!!(i.includes("wc_sessionAuthenticate")&&this.client.events.listenerCount("session_authenticate")>0)}),H(this,"onSessionProposeRequest",async s=>{const{topic:n,payload:r,attestation:i,encryptedId:o}=s,{params:a,id:c}=r;try{const l=this.client.core.eventClient.getEvent({topic:n});this.client.events.listenerCount("session_proposal")===0&&(console.warn("No listener for session_proposal event"),l==null||l.setError(dn.proposal_listener_not_found)),this.isValidConnect(Be({},r.params));const d=a.expiryTimestamp||rt(vt.wc_sessionPropose.req.ttl),u=Be({id:c,pairingTopic:n,expiryTimestamp:d,attestation:i,encryptedId:o},a);await this.setProposal(c,u);const h=await this.getVerifyContext({attestationId:i,hash:Es(JSON.stringify(r)),encryptedId:o,metadata:u.proposer.metadata});l==null||l.addTrace(Ws.emit_session_proposal),this.client.events.emit("session_proposal",{id:c,params:u,verifyContext:h})}catch(l){await this.sendError({id:c,topic:n,error:l,rpcOpts:vt.wc_sessionPropose.autoReject}),this.client.logger.error(l)}}),H(this,"onSessionProposeResponse",async(s,n,r)=>{const{id:i}=n;if(cn(n)){const{result:o}=n;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",result:o});const a=this.client.proposal.get(i);this.client.logger.trace({type:"method",method:"onSessionProposeResponse",proposal:a});const c=a.proposer.publicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",selfPublicKey:c});const l=o.responderPublicKey;this.client.logger.trace({type:"method",method:"onSessionProposeResponse",peerPublicKey:l});const d=await this.client.core.crypto.generateSharedKey(c,l);this.pendingSessions.set(i,{sessionTopic:d,pairingTopic:s,proposalId:i,publicKey:c});const u=await this.client.core.relayer.subscribe(d,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:u}),await this.client.core.pairing.activate({topic:s})}else if(Hs(n)){await this.deleteProposal(i);const o=Fe("session_connect",i);if(this.events.listenerCount(o)===0)throw new Error(`emitting ${o} without any listeners, 954`);this.events.emit(o,{error:n.error})}}),H(this,"onSessionSettleRequest",async(s,n)=>{const{id:r,params:i}=n;try{this.isValidSessionSettleRequest(i);const{relay:o,controller:a,expiry:c,namespaces:l,sessionProperties:d,scopedProperties:u,sessionConfig:h,proposalRequestsResponses:p}=n.params,g=[...this.pendingSessions.values()].find(_=>_.sessionTopic===s);if(!g)return this.client.logger.error(`Pending session not found for topic ${s}`);const f=this.client.proposal.get(g.proposalId),y=Ct(Be(Be(Be({topic:s,relay:o,expiry:c,namespaces:l,acknowledged:!0,pairingTopic:g.pairingTopic,requiredNamespaces:f.requiredNamespaces,optionalNamespaces:f.optionalNamespaces,controller:a.publicKey,self:{publicKey:g.publicKey,metadata:this.client.metadata},peer:{publicKey:a.publicKey,metadata:a.metadata}},d&&{sessionProperties:d}),u&&{scopedProperties:u}),h&&{sessionConfig:h}),{transportType:Ke.relay,authentication:p==null?void 0:p.authentication,walletPayResult:p==null?void 0:p.walletPay});await this.client.session.set(y.topic,y),await this.setExpiry(y.topic,y.expiry),await this.client.core.pairing.updateMetadata({topic:g.pairingTopic,metadata:y.peer.metadata}),this.pendingSessions.delete(g.proposalId),this.deleteProposal(g.proposalId,!1),this.cleanupDuplicatePairings(y),await this.sendResult({id:n.id,topic:s,throwOnFailedPublish:!0,result:!0}),this.client.events.emit("session_connect",{session:y}),this.events.emit(Fe("session_connect",g.proposalId),{session:y})}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"onSessionSettleResponse",async(s,n)=>{const{id:r}=n;cn(n)?(await this.client.session.update(s,{acknowledged:!0}),this.events.emit(Fe("session_approve",r),{})):Hs(n)&&(await this.client.session.delete(s,Ze("USER_DISCONNECTED")),this.events.emit(Fe("session_approve",r),{error:n.error}))}),H(this,"onSessionUpdateRequest",async(s,n)=>{const{params:r,id:i}=n;try{const o=`${s}_session_update`,a=Si.get(o);if(a&&this.isRequestOutOfSync(a,i)){this.client.logger.warn(`Discarding out of sync request - ${i}`),this.sendError({id:i,topic:s,error:Ze("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(Be({topic:s},r));try{Si.set(o,i),await this.client.session.update(s,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:s,result:!0})}catch(c){throw Si.delete(o),c}this.client.events.emit("session_update",{id:i,topic:s,params:r})}catch(o){await this.sendError({id:i,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"isRequestOutOfSync",(s,n)=>n.toString().slice(0,-3)<s.toString().slice(0,-3)),H(this,"onSessionUpdateResponse",(s,n)=>{const{id:r}=n,i=Fe("session_update",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_update",r),{}):Hs(n)&&this.events.emit(Fe("session_update",r),{error:n.error})}),H(this,"onSessionExtendRequest",async(s,n)=>{const{id:r}=n;try{this.isValidExtend({topic:s}),await this.setExpiry(s,rt(Hr)),await this.sendResult({id:r,topic:s,result:!0}),this.client.events.emit("session_extend",{id:r,topic:s})}catch(i){await this.sendError({id:r,topic:s,error:i}),this.client.logger.error(i)}}),H(this,"onSessionExtendResponse",(s,n)=>{const{id:r}=n,i=Fe("session_extend",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_extend",r),{}):Hs(n)&&this.events.emit(Fe("session_extend",r),{error:n.error})}),H(this,"onSessionPingRequest",async(s,n)=>{const{id:r}=n;try{this.isValidPing({topic:s}),await this.sendResult({id:r,topic:s,result:!0,throwOnFailedPublish:!0}),this.client.events.emit("session_ping",{id:r,topic:s})}catch(i){await this.sendError({id:r,topic:s,error:i}),this.client.logger.error(i)}}),H(this,"onSessionPingResponse",(s,n)=>{const{id:r}=n,i=Fe("session_ping",r);setTimeout(()=>{if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners 2176`);cn(n)?this.events.emit(Fe("session_ping",r),{}):Hs(n)&&this.events.emit(Fe("session_ping",r),{error:n.error})},500)}),H(this,"onSessionDeleteRequest",async(s,n)=>{const{id:r}=n;try{await this.isValidDisconnect({topic:s,reason:n.params}),this.cleanupPendingSentRequestsForTopic({topic:s,error:Ze("USER_DISCONNECTED")}),await this.deleteSession({topic:s,id:r})}catch(i){this.client.logger.error(i)}}),H(this,"onSessionRequest",async s=>{var n,r,i;const{topic:o,payload:a,attestation:c,encryptedId:l,transportType:d}=s,{id:u,params:h}=a;try{await this.isValidRequest(Be({topic:o},h));const p=this.client.session.get(o),g=await this.getVerifyContext({attestationId:c,hash:Es(JSON.stringify(zs("wc_sessionRequest",h,u))),encryptedId:l,metadata:p.peer.metadata,transportType:d}),f={id:u,topic:o,params:h,verifyContext:g};await this.setPendingSessionRequest(f),d===Ke.link_mode&&(n=p.peer.metadata.redirect)!=null&&n.universal&&this.client.core.addLinkModeSupportedApp((r=p.peer.metadata.redirect)==null?void 0:r.universal),(i=this.client.signConfig)!=null&&i.disableRequestQueue?this.emitSessionRequest(f):(this.addSessionRequestToSessionRequestQueue(f),this.processSessionRequestQueue())}catch(p){await this.sendError({id:u,topic:o,error:p}),this.client.logger.error(p)}}),H(this,"onSessionRequestResponse",(s,n)=>{const{id:r}=n,i=Fe("session_request",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);cn(n)?this.events.emit(Fe("session_request",r),{result:n.result}):Hs(n)&&this.events.emit(Fe("session_request",r),{error:n.error})}),H(this,"onSessionEventRequest",async(s,n)=>{const{id:r,params:i}=n;try{const o=`${s}_session_event_${i.event.name}`,a=Si.get(o);if(a&&this.isRequestOutOfSync(a,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(Be({topic:s},i)),this.client.events.emit("session_event",{id:r,topic:s,params:i}),Si.set(o,r)}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),H(this,"onSessionAuthenticateResponse",(s,n)=>{const{id:r}=n;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:s,payload:n}),cn(n)?this.events.emit(Fe("session_request",r),{result:n.result}):Hs(n)&&this.events.emit(Fe("session_request",r),{error:n.error})}),H(this,"onSessionAuthenticateRequest",async s=>{var n;const{topic:r,payload:i,attestation:o,encryptedId:a,transportType:c}=s;try{const{requester:l,authPayload:d,expiryTimestamp:u}=i.params,h=await this.getVerifyContext({attestationId:o,hash:Es(JSON.stringify(i)),encryptedId:a,metadata:l.metadata,transportType:c}),p={requester:l,pairingTopic:r,id:i.id,authPayload:d,verifyContext:h,expiryTimestamp:u};await this.setAuthRequest(i.id,{request:p,pairingTopic:r,transportType:c}),c===Ke.link_mode&&(n=l.metadata.redirect)!=null&&n.universal&&this.client.core.addLinkModeSupportedApp(l.metadata.redirect.universal),this.client.events.emit("session_authenticate",{topic:r,params:i.params,id:i.id,verifyContext:h})}catch(l){this.client.logger.error(l);const d=i.params.requester.publicKey,u=await this.client.core.crypto.generateKeyPair(),h=this.getAppLinkIfEnabled(i.params.requester.metadata,c),p={type:Cn,receiverPublicKey:d,senderPublicKey:u};await this.sendError({id:i.id,topic:r,error:l,encodeOpts:p,rpcOpts:vt.wc_sessionAuthenticate.autoReject,appLink:h})}}),H(this,"addSessionRequestToSessionRequestQueue",s=>{this.sessionRequestQueue.queue.push(s)}),H(this,"cleanupAfterResponse",s=>{this.deletePendingSessionRequest(s.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=qs.idle,this.processSessionRequestQueue()},Z.toMiliseconds(this.requestQueueDelay))}),H(this,"cleanupPendingSentRequestsForTopic",({topic:s,error:n})=>{const r=this.client.core.history.pending;r.length>0&&r.filter(i=>i.topic===s&&i.request.method==="wc_sessionRequest").forEach(i=>{this.events.emit(Fe("session_request",i.request.id),{error:n})})}),H(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===qs.active){this.client.logger.info("session request queue is already active.");return}const s=this.sessionRequestQueue.queue[0];if(!s){this.client.logger.info("session request queue is empty.");return}try{this.emitSessionRequest(s)}catch(n){this.client.logger.error(n)}}),H(this,"emitSessionRequest",s=>{if(this.emittedSessionRequests.has(s.id)){this.client.logger.warn({id:s.id},`Skipping emitting \`session_request\` event for duplicate request. id: ${s.id}`);return}this.sessionRequestQueue.state=qs.active,this.emittedSessionRequests.add(s.id),this.client.events.emit("session_request",s)}),H(this,"onPairingCreated",s=>{if(s.methods&&this.expectedPairingMethodMap.set(s.topic,s.methods),s.active)return;const n=this.client.proposal.getAll().find(r=>r.pairingTopic===s.topic);n&&this.onSessionProposeRequest({topic:s.topic,payload:zs("wc_sessionPropose",Ct(Be({},n),{requiredNamespaces:n.requiredNamespaces,optionalNamespaces:n.optionalNamespaces,relays:n.relays,proposer:n.proposer,sessionProperties:n.sessionProperties,scopedProperties:n.scopedProperties}),n.id),attestation:n.attestation,encryptedId:n.encryptedId})}),H(this,"isValidConnect",async s=>{if(!Vt(s)){const{message:l}=Y("MISSING_OR_INVALID",`connect() params: ${JSON.stringify(s)}`);throw new Error(l)}const{pairingTopic:n,requiredNamespaces:r,optionalNamespaces:i,sessionProperties:o,scopedProperties:a,relays:c}=s;if(mt(n)||await this.isValidPairingTopic(n),!AN(c)){const{message:l}=Y("MISSING_OR_INVALID",`connect() relays: ${c}`);throw new Error(l)}if(r&&!mt(r)&&Xs(r)!==0){const l="requiredNamespaces are deprecated and are automatically assigned to optionalNamespaces";["fatal","error","silent"].includes(this.client.logger.level)?console.warn(l):this.client.logger.warn(l),this.validateNamespaces(r,"requiredNamespaces")}if(i&&!mt(i)&&Xs(i)!==0&&this.validateNamespaces(i,"optionalNamespaces"),o&&!mt(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!mt(a)){this.validateSessionProps(a,"scopedProperties");const l=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(a).every(d=>l.includes(d.split(":")[0])))throw new Error(`Scoped properties must be a subset of required/optional namespaces, received: ${JSON.stringify(a)}, required/optional namespaces: ${JSON.stringify(l)}`)}}),H(this,"validateNamespaces",(s,n)=>{const r=_N(s,"connect()",n);if(r)throw new Error(r.message)}),H(this,"isValidApprove",async s=>{if(!Vt(s))throw new Error(Y("MISSING_OR_INVALID",`approve() params: ${s}`).message);const{id:n,namespaces:r,relayProtocol:i,sessionProperties:o,scopedProperties:a}=s;this.checkRecentlyDeleted(n),await this.isValidProposalId(n);const c=this.client.proposal.get(n),l=el(r,"approve()");if(l)throw new Error(l.message);const d=dp(c.requiredNamespaces,r,"approve()");if(d)throw new Error(d.message);if(!ot(i,!0)){const{message:u}=Y("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw new Error(u)}if(o&&!mt(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!mt(a)){this.validateSessionProps(a,"scopedProperties");const u=new Set(Object.keys(r));if(!Object.keys(a).every(h=>u.has(h.split(":")[0])))throw new Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(a)}, approved namespaces: ${Array.from(u).join(", ")}`)}}),H(this,"isValidReject",async s=>{if(!Vt(s)){const{message:i}=Y("MISSING_OR_INVALID",`reject() params: ${s}`);throw new Error(i)}const{id:n,reason:r}=s;if(this.checkRecentlyDeleted(n),await this.isValidProposalId(n),!IN(r)){const{message:i}=Y("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw new Error(i)}}),H(this,"isValidSessionSettleRequest",s=>{if(!Vt(s)){const{message:l}=Y("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${s}`);throw new Error(l)}const{relay:n,controller:r,namespaces:i,expiry:o}=s;if(!Pm(n)){const{message:l}=Y("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw new Error(l)}const a=yN(r,"onSessionSettleRequest()");if(a)throw new Error(a.message);const c=el(i,"onSessionSettleRequest()");if(c)throw new Error(c.message);if(Vs(o)){const{message:l}=Y("EXPIRED","onSessionSettleRequest()");throw new Error(l)}}),H(this,"isValidUpdate",async s=>{if(!Vt(s)){const{message:c}=Y("MISSING_OR_INVALID",`update() params: ${s}`);throw new Error(c)}const{topic:n,namespaces:r}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n);const i=this.client.session.get(n),o=el(r,"update()");if(o)throw new Error(o.message);const a=dp(i.requiredNamespaces,r,"update()");if(a)throw new Error(a.message)}),H(this,"isValidExtend",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`extend() params: ${s}`);throw new Error(r)}const{topic:n}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n)}),H(this,"isValidRequest",async s=>{if(!Vt(s)){const{message:c}=Y("MISSING_OR_INVALID",`request() params: ${s}`);throw new Error(c)}const{topic:n,request:r,chainId:i,expiry:o}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n);const{namespaces:a}=this.client.session.get(n);if(!lp(a,i)){const{message:c}=Y("MISSING_OR_INVALID",`request() chainId: ${i}`);throw new Error(c)}if(!NN(r)){const{message:c}=Y("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw new Error(c)}if(!ON(a,i,r.method)){const{message:c}=Y("MISSING_OR_INVALID",`request() method: ${r.method}`);throw new Error(c)}this.validateRequestExpiry(o)}),H(this,"isValidRespond",async s=>{var n;if(!Vt(s)){const{message:a}=Y("MISSING_OR_INVALID",`respond() params: ${s}`);throw new Error(a)}const{topic:r,response:i}=s;try{await this.isValidSessionTopic(r)}catch(a){throw(n=s==null?void 0:s.response)!=null&&n.id&&this.cleanupAfterResponse(s),a}if(!TN(i)){const{message:a}=Y("MISSING_OR_INVALID",`respond() response: ${JSON.stringify(i)}`);throw new Error(a)}const o=this.client.pendingRequest.get(i.id);if(o.topic!==r){const{message:a}=Y("MISMATCHED_TOPIC",`Request response topic mismatch. reqId: ${i.id}, expected topic: ${o.topic}, received topic: ${r}`);throw new Error(a)}}),H(this,"isValidPing",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`ping() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),H(this,"isValidEmit",async s=>{if(!Vt(s)){const{message:a}=Y("MISSING_OR_INVALID",`emit() params: ${s}`);throw new Error(a)}const{topic:n,event:r,chainId:i}=s;await this.isValidSessionTopic(n);const{namespaces:o}=this.client.session.get(n);if(!lp(o,i)){const{message:a}=Y("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw new Error(a)}if(!RN(r)){const{message:a}=Y("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}if(!PN(o,i,r.name)){const{message:a}=Y("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}}),H(this,"isValidDisconnect",async s=>{if(!Vt(s)){const{message:r}=Y("MISSING_OR_INVALID",`disconnect() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),H(this,"isValidAuthenticate",s=>{const{chains:n,uri:r,domain:i,nonce:o}=s;if(!Array.isArray(n)||n.length===0)throw new Error("chains is required and must be a non-empty array");if(!ot(r,!1))throw new Error("uri is required parameter");if(!ot(i,!1))throw new Error("domain is required parameter");if(!ot(o,!1))throw new Error("nonce is required parameter");if([...new Set(n.map(c=>vn(c).namespace))].length>1)throw new Error("Multi-namespace requests are not supported. Please request single namespace only.");const{namespace:a}=vn(n[0]);if(a!=="eip155")throw new Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),H(this,"getVerifyContext",async s=>{const{attestationId:n,hash:r,encryptedId:i,metadata:o,transportType:a}=s,c={verified:{verifyUrl:o.verifyUrl||qi,validation:"UNKNOWN",origin:o.url||""}};try{if(a===Ke.link_mode){const d=this.getAppLinkIfEnabled(o,a);return c.verified.validation=d&&new URL(d).origin===new URL(o.url).origin?"VALID":"INVALID",c}const l=await this.client.core.verify.resolve({attestationId:n,hash:r,encryptedId:i,verifyUrl:o.verifyUrl});l&&(c.verified.origin=l.origin,c.verified.isScam=l.isScam,c.verified.validation=l.origin===new URL(o.url).origin?"VALID":"INVALID")}catch(l){this.client.logger.warn(l)}return this.client.logger.debug(`Verify context: ${JSON.stringify(c)}`),c}),H(this,"validateSessionProps",(s,n)=>{Object.values(s).forEach((r,i)=>{if(r==null){const{message:o}=Y("MISSING_OR_INVALID",`${n} must contain an existing value for each key. Received: ${r} for key ${Object.keys(s)[i]}`);throw new Error(o)}})}),H(this,"getPendingAuthRequest",s=>{const n=this.client.auth.requests.get(s);return typeof n=="object"?n:void 0}),H(this,"addToRecentlyDeleted",(s,n)=>{if(this.recentlyDeletedMap.set(s,n),this.recentlyDeletedMap.size>=this.recentlyDeletedLimit){let r=0;const i=this.recentlyDeletedLimit/2;for(const o of this.recentlyDeletedMap.keys()){if(r++>=i)break;this.recentlyDeletedMap.delete(o)}}}),H(this,"checkRecentlyDeleted",s=>{const n=this.recentlyDeletedMap.get(s);if(n){const{message:r}=Y("MISSING_OR_INVALID",`Record was recently deleted - ${n}: ${s}`);throw new Error(r)}}),H(this,"isLinkModeEnabled",(s,n)=>{var r,i,o,a,c,l,d,u,h;return!s||n!==Ke.link_mode?!1:((i=(r=this.client.metadata)==null?void 0:r.redirect)==null?void 0:i.linkMode)===!0&&((a=(o=this.client.metadata)==null?void 0:o.redirect)==null?void 0:a.universal)!==void 0&&((l=(c=this.client.metadata)==null?void 0:c.redirect)==null?void 0:l.universal)!==""&&((d=s==null?void 0:s.redirect)==null?void 0:d.universal)!==void 0&&((u=s==null?void 0:s.redirect)==null?void 0:u.universal)!==""&&((h=s==null?void 0:s.redirect)==null?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(s.redirect.universal)&&typeof(Ns==null?void 0:Ns.Linking)<"u"}),H(this,"getAppLinkIfEnabled",(s,n)=>{var r;return this.isLinkModeEnabled(s,n)?(r=s==null?void 0:s.redirect)==null?void 0:r.universal:void 0}),H(this,"handleLinkModeMessage",({url:s})=>{if(!s||!s.includes("wc_ev")||!s.includes("topic"))return;const n=vh(s,"topic")||"",r=decodeURIComponent(vh(s,"wc_ev")||""),i=this.client.session.keys.includes(n);i&&this.client.session.update(n,{transportType:Ke.link_mode}),this.client.core.dispatchEnvelope({topic:n,message:r,sessionExists:i})}),H(this,"registerLinkModeListeners",async()=>{var s;if(Ld()||tr()&&(s=this.client.metadata.redirect)!=null&&s.linkMode){const n=Ns==null?void 0:Ns.Linking;if(typeof n<"u"){n.addEventListener("url",this.handleLinkModeMessage,this.client.name);const r=await n.getInitialURL();r&&setTimeout(()=>{this.handleLinkModeMessage({url:r})},50)}}}),H(this,"getTVFApproveParams",s=>{try{const n=Rm(s.namespaces),r=rN(s.namespaces),i=iN(s.namespaces),o=s.sessionProperties,a=s.scopedProperties;return{approvedChains:n,approvedMethods:r,approvedEvents:i,sessionProperties:o,scopedProperties:a}}catch(n){return this.client.logger.warn(n,"Error getting TVF approve params"),{}}}),H(this,"getTVFParams",(s,n,r)=>{var i,o,a;if(!((i=n.request)!=null&&i.method))return{};const c={correlationId:s,rpcMethods:[n.request.method],chainId:n.chainId};try{const l=this.extractTxHashesFromResult(n.request,r);c.txHashes=l,c.contractAddresses=this.isValidContractData(n.request.params)?[(a=(o=n.request.params)==null?void 0:o[0])==null?void 0:a.to]:[]}catch(l){this.client.logger.warn(l,"Error getting TVF params")}return c}),H(this,"isValidContractData",s=>{var n;if(!s)return!1;try{const r=(s==null?void 0:s.data)||((n=s==null?void 0:s[0])==null?void 0:n.data);if(!r.startsWith("0x"))return!1;const i=r.slice(2);return/^[0-9a-fA-F]*$/.test(i)?i.length%2===0:!1}catch{}return!1}),H(this,"extractTxHashesFromResult",(s,n)=>{var r;try{if(!n)return[];const i=s.method,o=LO[i];if(i==="sui_signTransaction")return[KA(n.transactionBytes)];if(i==="near_signTransaction")return[Rh(n)];if(i==="near_signTransactions")return n.map(c=>Rh(c));if(i==="xrpl_signTransactionFor"||i==="xrpl_signTransaction")return[(r=n.tx_json)==null?void 0:r.hash];if(i==="polkadot_signTransaction")return[YN({transaction:s.params.transactionPayload,signature:n.signature})];if(i==="algo_signTxn")return _n(n)?n.map(c=>Oh(c)):[Oh(n)];if(i==="cosmos_signDirect")return[YA(n)];if(i==="wallet_sendCalls")return ZA(n);if(typeof n=="string")return[n];const a=n[o.key];if(_n(a))return i==="solana_signAllTransactions"?a.map(c=>VA(c)):a;if(typeof a=="string")return[a]}catch(i){this.client.logger.warn(i,"Error extracting tx hashes from result")}return[]})}async processPendingMessageEvents(){try{const e=this.client.session.keys,s=this.client.core.relayer.messages.getWithoutAck(e);for(const[n,r]of Object.entries(s))for(const i of r)try{await this.onProviderMessageEvent({topic:n,message:i,publishedAt:Date.now()})}catch{this.client.logger.warn(`Error processing pending message event for topic: ${n}, message: ${i}`)}}catch(e){this.client.logger.warn(e,"processPendingMessageEvents failed")}}isInitialized(){if(!this.initialized){const{message:e}=Y("NOT_INITIALIZED",this.name);throw new Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(it.message,e=>{this.onProviderMessageEvent(e)})}async onRelayMessage(e){const{topic:s,message:n,attestation:r,transportType:i}=e,{publicKey:o}=this.client.auth.authKeys.keys.includes(Ea)?this.client.auth.authKeys.get(Ea):{publicKey:void 0};try{const a=await this.client.core.crypto.decode(s,n,{receiverPublicKey:o,encoding:i===Ke.link_mode?qn:Zt});_d(a)?(this.client.core.history.set(s,a),await this.onRelayEventRequest({topic:s,payload:a,attestation:r,transportType:i,encryptedId:Es(n)})):Ad(a)?(await this.client.core.history.resolve(a),await this.onRelayEventResponse({topic:s,payload:a,transportType:i}),this.client.core.history.delete(s,a.id)):(this.client.logger.error(`onRelayMessage() -> unknown payload: ${JSON.stringify(a)}`),await this.onRelayEventUnknownPayload({topic:s,payload:a,transportType:i})),await this.client.core.relayer.messages.ack(s,n)}catch(a){this.client.logger.error(`onRelayMessage() -> failed to process an inbound message: ${n}`),this.client.logger.error(a)}}registerExpirerEvents(){this.client.core.expirer.on(ys.expired,async e=>{const{topic:s,id:n}=Og(e.target);if(n&&this.client.pendingRequest.keys.includes(n))return await this.deletePendingSessionRequest(n,Y("EXPIRED"),!0);if(n&&this.client.auth.requests.keys.includes(n))return await this.deletePendingAuthRequest(n,Y("EXPIRED"),!0);s?this.client.session.keys.includes(s)&&(await this.deleteSession({topic:s,expirerHasDeleted:!0}),this.client.events.emit("session_expire",{topic:s})):n&&(await this.deleteProposal(n,!0),this.client.events.emit("proposal_expire",{id:n}))})}registerPairingEvents(){this.client.core.pairing.events.on(ur.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(ur.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!ot(e,!1)){const{message:s}=Y("MISSING_OR_INVALID",`pairing topic should be a string: ${e}`);throw new Error(s)}if(!this.client.core.pairing.pairings.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.core.pairing.pairings.get(e).expiry)){const{message:s}=Y("EXPIRED",`pairing topic: ${e}`);throw new Error(s)}}async isValidSessionTopic(e){if(!ot(e,!1)){const{message:s}=Y("MISSING_OR_INVALID",`session topic should be a string: ${e}`);throw new Error(s)}if(this.checkRecentlyDeleted(e),!this.client.session.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});const{message:s}=Y("EXPIRED",`session topic: ${e}`);throw new Error(s)}if(!this.client.core.crypto.keychain.has(e)){const{message:s}=Y("MISSING_OR_INVALID",`session topic does not exist in keychain: ${e}`);throw await this.deleteSession({topic:e}),new Error(s)}}async isValidSessionOrPairingTopic(e){if(this.checkRecentlyDeleted(e),this.client.session.keys.includes(e))await this.isValidSessionTopic(e);else if(this.client.core.pairing.pairings.keys.includes(e))this.isValidPairingTopic(e);else if(ot(e,!1)){const{message:s}=Y("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw new Error(s)}else{const{message:s}=Y("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw new Error(s)}}async isValidProposalId(e){if(!SN(e)){const{message:s}=Y("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw new Error(s)}if(!this.client.proposal.keys.includes(e)){const{message:s}=Y("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw new Error(s)}if(Vs(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);const{message:s}=Y("EXPIRED",`proposal id: ${e}`);throw new Error(s)}}validateRequestExpiry(e){if(e&&!UN(e,ol)){const{message:s}=Y("MISSING_OR_INVALID",`request() expiry: ${e}. Expiry must be a number (in seconds) between ${ol.min} and ${ol.max}`);throw new Error(s)}}}class JO extends Lr{constructor(e,s){super(e,s,UO,Yd),this.core=e,this.logger=s}}let XO=class extends Lr{constructor(e,s){super(e,s,$O,Yd),this.core=e,this.logger=s}};class QO extends Lr{constructor(e,s){super(e,s,MO,Yd,n=>n.id),this.core=e,this.logger=s}}class eP extends Lr{constructor(e,s){super(e,s,qO,Ec,()=>Ea),this.core=e,this.logger=s}}class tP extends Lr{constructor(e,s){super(e,s,WO,Ec),this.core=e,this.logger=s}}class sP extends Lr{constructor(e,s){super(e,s,HO,Ec,n=>n.id),this.core=e,this.logger=s}}var nP=Object.defineProperty,rP=(t,e,s)=>e in t?nP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,al=(t,e,s)=>rP(t,typeof e!="symbol"?e+"":e,s);class iP{constructor(e,s){this.core=e,this.logger=s,al(this,"authKeys"),al(this,"pairingTopics"),al(this,"requests"),this.authKeys=new eP(this.core,this.logger),this.pairingTopics=new tP(this.core,this.logger),this.requests=new sP(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var oP=Object.defineProperty,aP=(t,e,s)=>e in t?oP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Re=(t,e,s)=>aP(t,typeof e!="symbol"?e+"":e,s);class Zd extends GC{constructor(e){super(e),Re(this,"protocol",Ym),Re(this,"version",Zm),Re(this,"name",il.name),Re(this,"metadata"),Re(this,"core"),Re(this,"logger"),Re(this,"events",new xr.EventEmitter),Re(this,"engine"),Re(this,"session"),Re(this,"proposal"),Re(this,"pendingRequest"),Re(this,"auth"),Re(this,"signConfig"),Re(this,"on",(n,r)=>this.events.on(n,r)),Re(this,"once",(n,r)=>this.events.once(n,r)),Re(this,"off",(n,r)=>this.events.off(n,r)),Re(this,"removeListener",(n,r)=>this.events.removeListener(n,r)),Re(this,"removeAllListeners",n=>this.events.removeAllListeners(n)),Re(this,"connect",async n=>{try{return await this.engine.connect(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"pair",async n=>{try{return await this.engine.pair(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"approve",async n=>{try{return await this.engine.approve(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"reject",async n=>{try{return await this.engine.reject(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"update",async n=>{try{return await this.engine.update(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"extend",async n=>{try{return await this.engine.extend(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"request",async n=>{try{return await this.engine.request(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"respond",async n=>{try{return await this.engine.respond(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"ping",async n=>{try{return await this.engine.ping(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"emit",async n=>{try{return await this.engine.emit(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"disconnect",async n=>{try{return await this.engine.disconnect(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"find",n=>{try{return this.engine.find(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(n){throw this.logger.error(n.message),n}}),Re(this,"authenticate",async(n,r)=>{try{return await this.engine.authenticate(n,r)}catch(i){throw this.logger.error(i.message),i}}),Re(this,"formatAuthMessage",n=>{try{return this.engine.formatAuthMessage(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"approveSessionAuthenticate",async n=>{try{return await this.engine.approveSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),Re(this,"rejectSessionAuthenticate",async n=>{try{return await this.engine.rejectSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),this.name=(e==null?void 0:e.name)||il.name,this.metadata=B0(e==null?void 0:e.metadata),this.signConfig=e==null?void 0:e.signConfig;const s=Gd({logger:(e==null?void 0:e.logger)||il.logger,name:this.name});this.logger=s,this.core=(e==null?void 0:e.core)||new kO(e),this.session=new XO(this.core,this.logger),this.proposal=new JO(this.core,this.logger),this.pendingRequest=new QO(this.core,this.logger),this.engine=new ZO(this),this.auth=new iP(this.core,this.logger)}static async init(e){const s=new Zd(e);return await s.initialize(),s}get context(){return es(this.logger)}get pairing(){return this.core.pairing.pairings}async initialize(){this.logger.trace("Initialized");try{await this.core.start(),await this.session.init(),await this.proposal.init(),await this.pendingRequest.init(),await this.auth.init(),await this.engine.init(),this.logger.info("SignClient Initialization Success")}catch(e){throw this.logger.info("SignClient Initialization Failure"),this.logger.error(e.message),e}}}const cP=Zd;function Jd(t){return t==null||typeof t!="object"&&typeof t!="function"}function Xm(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function Qm(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const lP="[object RegExp]",ey="[object String]",ty="[object Number]",sy="[object Boolean]",ny="[object Arguments]",dP="[object Symbol]",uP="[object Date]",hP="[object Map]",pP="[object Set]",fP="[object Array]",gP="[object ArrayBuffer]",mP="[object Object]",yP="[object DataView]",wP="[object Uint8Array]",EP="[object Uint8ClampedArray]",bP="[object Uint16Array]",vP="[object Uint32Array]",CP="[object Int8Array]",_P="[object Int16Array]",AP="[object Int32Array]",SP="[object Float32Array]",IP="[object Float64Array]";function Xd(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)}function NP(t,e){return Qr(t,void 0,t,new Map,e)}function Qr(t,e,s,n=new Map,r=void 0){const i=r==null?void 0:r(t,e,s,n);if(i!=null)return i;if(Jd(t))return t;if(n.has(t))return n.get(t);if(Array.isArray(t)){const o=new Array(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=Qr(t[a],a,s,n,r);return Object.hasOwn(t,"index")&&(o.index=t.index),Object.hasOwn(t,"input")&&(o.input=t.input),o}if(t instanceof Date)return new Date(t.getTime());if(t instanceof RegExp){const o=new RegExp(t.source,t.flags);return o.lastIndex=t.lastIndex,o}if(t instanceof Map){const o=new Map;n.set(t,o);for(const[a,c]of t)o.set(a,Qr(c,a,s,n,r));return o}if(t instanceof Set){const o=new Set;n.set(t,o);for(const a of t)o.add(Qr(a,void 0,s,n,r));return o}if(typeof Ue<"u"&&Ue.isBuffer(t))return t.subarray();if(Xd(t)){const o=new(Object.getPrototypeOf(t)).constructor(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=Qr(t[a],a,s,n,r);return o}if(t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer)return t.slice(0);if(t instanceof DataView){const o=new DataView(t.buffer.slice(0),t.byteOffset,t.byteLength);return n.set(t,o),hr(o,t,s,n,r),o}if(typeof File<"u"&&t instanceof File){const o=new File([t],t.name,{type:t.type});return n.set(t,o),hr(o,t,s,n,r),o}if(t instanceof Blob){const o=new Blob([t],{type:t.type});return n.set(t,o),hr(o,t,s,n,r),o}if(t instanceof Error){const o=new t.constructor;return n.set(t,o),o.message=t.message,o.name=t.name,o.stack=t.stack,o.cause=t.cause,hr(o,t,s,n,r),o}if(typeof t=="object"&&TP(t)){const o=Object.create(Object.getPrototypeOf(t));return n.set(t,o),hr(o,t,s,n,r),o}return t}function hr(t,e,s=t,n,r){const i=[...Object.keys(e),...Xm(e)];for(let o=0;o<i.length;o++){const a=i[o],c=Object.getOwnPropertyDescriptor(t,a);(c==null||c.writable)&&(t[a]=Qr(e[a],a,s,n,r))}}function TP(t){switch(Qm(t)){case ny:case fP:case gP:case yP:case sy:case uP:case SP:case IP:case CP:case _P:case AP:case hP:case ty:case mP:case lP:case pP:case ey:case dP:case wP:case EP:case bP:case vP:return!0;default:return!1}}function RP(t,e){return NP(t,(s,n,r,i)=>{if(typeof t=="object")switch(Object.prototype.toString.call(t)){case ty:case ey:case sy:{const o=new t.constructor(t==null?void 0:t.valueOf());return hr(o,t),o}case ny:{const o={};return hr(o,t),o.length=t.length,o[Symbol.iterator]=t[Symbol.iterator],o}default:return}})}function jp(t){return RP(t)}function Fp(t){return t!==null&&typeof t=="object"&&Qm(t)==="[object Arguments]"}function qp(t){return typeof t=="object"&&t!==null}function OP(){}function PP(t){return Xd(t)}function xP(t){var s;if(typeof t!="object"||t==null)return!1;if(Object.getPrototypeOf(t)===null)return!0;if(Object.prototype.toString.call(t)!=="[object Object]"){const n=t[Symbol.toStringTag];return n==null||!((s=Object.getOwnPropertyDescriptor(t,Symbol.toStringTag))!=null&&s.writable)?!1:t.toString()===`[object ${n}]`}let e=t;for(;Object.getPrototypeOf(e)!==null;)e=Object.getPrototypeOf(e);return Object.getPrototypeOf(t)===e}function kP(t){if(Jd(t))return t;if(Array.isArray(t)||Xd(t)||t instanceof ArrayBuffer||typeof SharedArrayBuffer<"u"&&t instanceof SharedArrayBuffer)return t.slice(0);const e=Object.getPrototypeOf(t),s=e.constructor;if(t instanceof Date||t instanceof Map||t instanceof Set)return new s(t);if(t instanceof RegExp){const n=new s(t);return n.lastIndex=t.lastIndex,n}if(t instanceof DataView)return new s(t.buffer.slice(0));if(t instanceof Error){const n=new s(t.message);return n.stack=t.stack,n.name=t.name,n.cause=t.cause,n}if(typeof File<"u"&&t instanceof File)return new s([t],t.name,{type:t.type,lastModified:t.lastModified});if(typeof t=="object"){const n=Object.create(e);return Object.assign(n,t)}return t}function UP(t,...e){const s=e.slice(0,-1),n=e[e.length-1];let r=t;for(let i=0;i<s.length;i++){const o=s[i];r=gd(r,o,n,new Map)}return r}function gd(t,e,s,n){if(Jd(t)&&(t=Object(t)),e==null||typeof e!="object")return t;if(n.has(e))return kP(n.get(e));if(n.set(e,t),Array.isArray(e)){e=e.slice();for(let i=0;i<e.length;i++)e[i]=e[i]??void 0}const r=[...Object.keys(e),...Xm(e)];for(let i=0;i<r.length;i++){const o=r[i];let a=e[o],c=t[o];if(Fp(a)&&(a={...a}),Fp(c)&&(c={...c}),typeof Ue<"u"&&Ue.isBuffer(a)&&(a=jp(a)),Array.isArray(a))if(typeof c=="object"&&c!=null){const d=[],u=Reflect.ownKeys(c);for(let h=0;h<u.length;h++){const p=u[h];d[p]=c[p]}c=d}else c=[];const l=s(c,a,o,t,e,n);l!=null?t[o]=l:Array.isArray(a)||qp(c)&&qp(a)?t[o]=gd(c,a,s,n):c==null&&xP(a)?t[o]=gd({},a,s,n):c==null&&PP(a)?t[o]=jp(a):(c===void 0||a!==void 0)&&(t[o]=a)}return t}function $P(t,...e){return UP(t,...e,OP)}const Wp="error",DP="wss://relay.walletconnect.org",LP="wc",ry="universal_provider",na=`${LP}@2:${ry}:`,iy="https://rpc.walletconnect.org/v1/",oy="generic",MP=`${iy}bundler`,ri="call_status",BP=86400,Qd={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};var jP=Object.defineProperty,FP=Object.defineProperties,qP=Object.getOwnPropertyDescriptors,Hp=Object.getOwnPropertySymbols,WP=Object.prototype.hasOwnProperty,HP=Object.prototype.propertyIsEnumerable,zp=(t,e,s)=>e in t?jP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ra=(t,e)=>{for(var s in e||(e={}))WP.call(e,s)&&zp(t,s,e[s]);if(Hp)for(var s of Hp(e))HP.call(e,s)&&zp(t,s,e[s]);return t},zP=(t,e)=>FP(t,qP(e));function ay(t,e,s){var n;const r=vn(t);return((n=e.rpcMap)==null?void 0:n[r.reference])||`${iy}?chainId=${r.namespace}:${r.reference}&projectId=${s}`}function VP(t){return t.includes(":")?t.split(":")[1]:t}function cy(t){return t.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function KP(t,e){const s=Object.keys(e.namespaces).filter(r=>r.includes(t));if(!s.length)return[];const n=[];return s.forEach(r=>{const i=e.namespaces[r].accounts;n.push(...i)}),n}function Vp(t){return Object.fromEntries(Object.entries(t).filter(([e,s])=>{var n,r;return((n=s==null?void 0:s.chains)==null?void 0:n.length)&&((r=s==null?void 0:s.chains)==null?void 0:r.length)>0}))}function ia(t={},e={}){const s=Vp(Kp(t)),n=Vp(Kp(e));return $P(s,n)}function Kp(t){var e,s,n,r,i;const o={};if(!Xs(t))return o;for(const[a,c]of Object.entries(t)){const l=yc(a)?[a]:c.chains,d=c.methods||[],u=c.events||[],h=c.rpcMap||{},p=Xr(a);o[p]=zP(ra(ra({},o[p]),c),{chains:Js(l,(e=o[p])==null?void 0:e.chains),methods:Js(d,(s=o[p])==null?void 0:s.methods),events:Js(u,(n=o[p])==null?void 0:n.events)}),(Xs(h)||Xs(((r=o[p])==null?void 0:r.rpcMap)||{}))&&(o[p].rpcMap=ra(ra({},h),(i=o[p])==null?void 0:i.rpcMap))}return o}function Gp(t){return t.includes(":")?t.split(":")[2]:t}function Yp(t){const e={};for(const[s,n]of Object.entries(t)){const r=n.methods||[],i=n.events||[],o=n.accounts||[],a=yc(s)?[s]:n.chains?n.chains:cy(n.accounts);e[s]={chains:a,methods:r,events:i,accounts:o}}return e}function cl(t){return typeof t=="number"?t:t.includes("0x")?parseInt(t,16):(t=t.includes(":")?t.split(":")[1]:t,isNaN(Number(t))?t:Number(t))}function GP(t){try{const e=JSON.parse(t);return typeof e=="object"&&e!==null&&!Array.isArray(e)}catch{return!1}}const ly={},ii=t=>ly[t],ll=(t,e)=>{ly[t]=e};var YP=Object.defineProperty,Zp=Object.getOwnPropertySymbols,ZP=Object.prototype.hasOwnProperty,JP=Object.prototype.propertyIsEnumerable,Jp=(t,e,s)=>e in t?YP(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xp=(t,e)=>{for(var s in e||(e={}))ZP.call(e,s)&&Jp(t,s,e[s]);if(Zp)for(var s of Zp(e))JP.call(e,s)&&Jp(t,s,e[s]);return t};const Qp="eip155",XP=["atomic","flow-control","paymasterService","sessionKeys","auxiliaryFunds"],QP=t=>t&&t.startsWith("0x")?BigInt(t).toString(10):t,dl=t=>t&&t.startsWith("0x")?t:`0x${BigInt(t).toString(16)}`,ef=t=>Object.keys(t).filter(e=>XP.includes(e)).reduce((e,s)=>(e[s]=ex(t[s]),e),{}),ex=t=>typeof t=="string"&&GP(t)?JSON.parse(t):t,tx=(t,e,s)=>{const{sessionProperties:n={},scopedProperties:r={}}=t,i={};if(!Xs(r)&&!Xs(n))return;const o=ef(n);for(const a of s){const c=QP(a);if(!c)continue;i[dl(c)]=o;const l=r==null?void 0:r[`${Qp}:${c}`];if(l){const d=l==null?void 0:l[`${Qp}:${c}:${e}`];i[dl(c)]=Xp(Xp({},i[dl(c)]),ef(d||l))}}for(const[a,c]of Object.entries(i))Object.keys(c).length===0&&delete i[a];return Object.keys(i).length>0?i:void 0};var sx=Object.defineProperty,nx=(t,e,s)=>e in t?sx(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,rx=(t,e,s)=>nx(t,e+"",s);let ul;class eu{constructor(e){rx(this,"storage"),this.storage=e}async getItem(e){return await this.storage.getItem(e)}async setItem(e,s){return await this.storage.setItem(e,s)}async removeItem(e){return await this.storage.removeItem(e)}static getStorage(e){return ul||(ul=new eu(e)),ul}}var ix=Object.defineProperty,ox=Object.defineProperties,ax=Object.getOwnPropertyDescriptors,tf=Object.getOwnPropertySymbols,cx=Object.prototype.hasOwnProperty,lx=Object.prototype.propertyIsEnumerable,sf=(t,e,s)=>e in t?ix(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,dx=(t,e)=>{for(var s in e||(e={}))cx.call(e,s)&&sf(t,s,e[s]);if(tf)for(var s of tf(e))lx.call(e,s)&&sf(t,s,e[s]);return t},ux=(t,e)=>ox(t,ax(e));async function hx(t,e){const s=vn(t.result.capabilities.caip345.caip2),n=t.result.capabilities.caip345.transactionHashes,r=await Promise.allSettled(n.map(u=>px(s.reference,u,e))),i=r.filter(u=>u.status==="fulfilled").map(u=>u.value).filter(u=>u);r.filter(u=>u.status==="rejected").forEach(u=>console.warn("Failed to fetch transaction receipt:",u.reason));const o=!i.length||i.some(u=>!u),a=i.every(u=>(u==null?void 0:u.status)==="0x1"),c=i.every(u=>(u==null?void 0:u.status)==="0x0"),l=i.some(u=>(u==null?void 0:u.status)==="0x0");let d;return o?d=100:a?d=200:c?d=500:l&&(d=600),{id:t.result.id,version:t.request.version,atomic:t.request.atomicRequired,chainId:t.request.chainId,capabilities:t.result.capabilities,receipts:i,status:d}}async function px(t,e,s){return await s(parseInt(t)).request(zs("eth_getTransactionReceipt",[e]))}async function fx({sendCalls:t,storage:e}){const s=await e.getItem(ri);await e.setItem(ri,ux(dx({},s),{[t.result.id]:{request:t.request,result:t.result,expiry:rt(BP)}}))}async function gx({resultId:t,storage:e}){const s=await e.getItem(ri);if(s){delete s[t],await e.setItem(ri,s);for(const n in s)Vs(s[n].expiry)&&delete s[n];await e.setItem(ri,s)}}async function mx({resultId:t,storage:e}){const s=await e.getItem(ri),n=s==null?void 0:s[t];if(n&&!Vs(n.expiry))return n;await gx({resultId:t,storage:e})}var yx=Object.defineProperty,wx=Object.defineProperties,Ex=Object.getOwnPropertyDescriptors,nf=Object.getOwnPropertySymbols,bx=Object.prototype.hasOwnProperty,vx=Object.prototype.propertyIsEnumerable,md=(t,e,s)=>e in t?yx(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,hl=(t,e)=>{for(var s in e||(e={}))bx.call(e,s)&&md(t,s,e[s]);if(nf)for(var s of nf(e))vx.call(e,s)&&md(t,s,e[s]);return t},pl=(t,e)=>wx(t,Ex(e)),or=(t,e,s)=>md(t,typeof e!="symbol"?e+"":e,s);class Cx{constructor(e){or(this,"name","eip155"),or(this,"client"),or(this,"chainId"),or(this,"namespace"),or(this,"httpProviders"),or(this,"events"),or(this,"storage"),this.namespace=e.namespace,this.events=ii("events"),this.client=ii("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain()),this.storage=eu.getStorage(this.client.core.storage)}async request(e){switch(e.request.method){case"eth_requestAccounts":return this.getAccounts();case"eth_accounts":return this.getAccounts();case"wallet_switchEthereumChain":return await this.handleSwitchChain(e);case"eth_chainId":return parseInt(this.getDefaultChain());case"wallet_getCapabilities":return await this.getCapabilities(e);case"wallet_getCallsStatus":return await this.getCallStatus(e);case"wallet_sendCalls":return await this.sendCalls(e)}return this.namespace.methods.includes(e.request.method)?await this.client.request(e):this.getHttpProvider().request(e.request)}updateNamespace(e){this.namespace=Object.assign(this.namespace,e)}setDefaultChain(e,s){this.httpProviders[e]||this.setHttpProvider(parseInt(e),s);const n=this.chainId;this.chainId=parseInt(e),this.events.emit(Qd.DEFAULT_CHAIN_CHANGED,{currentCaipChainId:`${this.name}:${e}`,previousCaipChainId:`${this.name}:${n}`})}requestAccounts(){return this.getAccounts()}getDefaultChain(){if(this.chainId)return this.chainId.toString();if(this.namespace.defaultChain)return this.namespace.defaultChain;const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return e.split(":")[1]}createHttpProvider(e,s){const n=s||ay(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Cd(new _f(n,ii("disableProviderPing")))}setHttpProvider(e,s){const n=this.createHttpProvider(e,s);n&&(this.httpProviders[e]=n)}createHttpProviders(){const e={};return this.namespace.chains.forEach(s=>{var n;const r=parseInt(VP(s));e[r]=this.createHttpProvider(r,(n=this.namespace.rpcMap)==null?void 0:n[s])}),e}getAccounts(){const e=this.namespace.accounts;return e?[...new Set(e.filter(s=>s.split(":")[1]===this.chainId.toString()).map(s=>s.split(":")[2]))]:[]}getHttpProvider(e){const s=e||this.chainId;return this.httpProviders[s]||(this.httpProviders=pl(hl({},this.httpProviders),{[s]:this.createHttpProvider(s)}),this.httpProviders[s])}async handleSwitchChain(e){var s,n;let r=e.request.params?(s=e.request.params[0])==null?void 0:s.chainId:"0x0";r=r.startsWith("0x")?r:`0x${r}`;const i=parseInt(r,16);if(this.isChainApproved(i))this.setDefaultChain(`${i}`);else if(this.namespace.methods.includes("wallet_switchEthereumChain"))await this.client.request({topic:e.topic,request:{method:e.request.method,params:[{chainId:r}]},chainId:(n=this.namespace.chains)==null?void 0:n[0]}),this.setDefaultChain(`${i}`);else throw new Error(`Failed to switch to chain 'eip155:${i}'. The chain is not approved or the wallet does not support 'wallet_switchEthereumChain' method.`);return null}isChainApproved(e){return this.namespace.chains.includes(`${this.name}:${e}`)}async getCapabilities(e){var s,n,r,i,o;const a=(n=(s=e.request)==null?void 0:s.params)==null?void 0:n[0],c=((i=(r=e.request)==null?void 0:r.params)==null?void 0:i[1])||[];if(!a)throw new Error("Missing address parameter in `wallet_getCapabilities` request");const l=this.client.session.get(e.topic),d=((o=l==null?void 0:l.sessionProperties)==null?void 0:o.capabilities)||{},u=`${a}${c.join(",")}`,h=d==null?void 0:d[u];if(h)return h;let p;try{p=tx(l,a,c)}catch(f){console.warn("Failed to extract capabilities from session",f)}if(p)return p;const g=await this.client.request(e);try{await this.client.session.update(e.topic,{sessionProperties:pl(hl({},l.sessionProperties||{}),{capabilities:pl(hl({},d||{}),{[u]:g})})})}catch(f){console.warn("Failed to update session with capabilities",f)}return g}async getCallStatus(e){var s,n,r;const i=this.client.session.get(e.topic),o=(s=i.sessionProperties)==null?void 0:s.bundler_name;if(o){const l=this.getBundlerUrl(e.chainId,o);try{return await this.getUserOperationReceipt(l,e)}catch(d){console.warn("Failed to fetch call status from bundler",d,l)}}const a=(n=i.sessionProperties)==null?void 0:n.bundler_url;if(a)try{return await this.getUserOperationReceipt(a,e)}catch(l){console.warn("Failed to fetch call status from custom bundler",l,a)}const c=await mx({resultId:(r=e.request.params)==null?void 0:r[0],storage:this.storage});if(c)try{return await hx(c,this.getHttpProvider.bind(this))}catch(l){console.warn("Failed to fetch call status from stored send calls",l,c)}if(this.namespace.methods.includes(e.request.method))return await this.client.request(e);throw new Error("Fetching call status not approved by the wallet.")}async getUserOperationReceipt(e,s){var n;const r=new URL(e),i=await fetch(r,{method:"POST",headers:{"Content-Type":"application/json"},body:JSON.stringify(zs("eth_getUserOperationReceipt",[(n=s.request.params)==null?void 0:n[0]]))});if(!i.ok)throw new Error(`Failed to fetch user operation receipt - ${i.status}`);return await i.json()}getBundlerUrl(e,s){return`${MP}?projectId=${this.client.core.projectId}&chainId=${e}&bundler=${s}`}async sendCalls(e){var s,n,r;const i=await this.client.request(e),o=(s=e.request.params)==null?void 0:s[0],a=i==null?void 0:i.id,c=(i==null?void 0:i.capabilities)||{},l=(n=c==null?void 0:c.caip345)==null?void 0:n.caip2,d=(r=c==null?void 0:c.caip345)==null?void 0:r.transactionHashes;return!a||!l||!(d!=null&&d.length)||await fx({sendCalls:{request:o,result:i},storage:this.storage}),i}}var _x=Object.defineProperty,Ax=(t,e,s)=>e in t?_x(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,zr=(t,e,s)=>Ax(t,typeof e!="symbol"?e+"":e,s);class Sx{constructor(e){zr(this,"name",oy),zr(this,"client"),zr(this,"httpProviders"),zr(this,"events"),zr(this,"namespace"),zr(this,"chainId"),this.namespace=e.namespace,this.events=ii("events"),this.client=ii("client"),this.chainId=this.getDefaultChain(),this.name=this.getNamespaceName(),this.httpProviders=this.createHttpProviders()}updateNamespace(e){this.namespace.chains=[...new Set((this.namespace.chains||[]).concat(e.chains||[]))],this.namespace.accounts=[...new Set((this.namespace.accounts||[]).concat(e.accounts||[]))],this.namespace.methods=[...new Set((this.namespace.methods||[]).concat(e.methods||[]))],this.namespace.events=[...new Set((this.namespace.events||[]).concat(e.events||[]))],this.httpProviders=this.createHttpProviders()}requestAccounts(){return this.getAccounts()}request(e){return this.namespace.methods.includes(e.request.method)?this.client.request(e):this.getHttpProvider(e.chainId).request(e.request)}setDefaultChain(e,s){this.httpProviders[e]||this.setHttpProvider(e,s);const n=this.chainId;this.chainId=e,this.events.emit(Qd.DEFAULT_CHAIN_CHANGED,{currentCaipChainId:`${this.name}:${e}`,previousCaipChainId:`${this.name}:${n}`})}getDefaultChain(){if(this.chainId)return this.chainId;if(this.namespace.defaultChain)return this.namespace.defaultChain;const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return e.split(":")[1]}getNamespaceName(){const e=this.namespace.chains[0];if(!e)throw new Error("ChainId not found");return vn(e).namespace}getAccounts(){const e=this.namespace.accounts;return e?[...new Set(e.filter(s=>s.split(":")[1]===this.chainId.toString()).map(s=>s.split(":")[2]))]:[]}createHttpProviders(){var e,s;const n={};return(s=(e=this.namespace)==null?void 0:e.accounts)==null||s.forEach(r=>{var i,o;const a=vn(r),c=(o=(i=this.namespace)==null?void 0:i.rpcMap)==null?void 0:o[`${a.namespace}:${a.reference}`];n[a.reference]=this.createHttpProvider(r,c)}),n}getHttpProvider(e){const s=vn(e).reference,n=this.httpProviders[s];if(typeof n>"u")throw new Error(`JSON-RPC provider for ${e} not found`);return n}setHttpProvider(e,s){const n=this.createHttpProvider(e,s);n&&(this.httpProviders[e]=n)}createHttpProvider(e,s){const n=s||ay(e,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Cd(new _f(n,ii("disableProviderPing")))}}var Ix=Object.defineProperty,Nx=Object.defineProperties,Tx=Object.getOwnPropertyDescriptors,rf=Object.getOwnPropertySymbols,Rx=Object.prototype.hasOwnProperty,Ox=Object.prototype.propertyIsEnumerable,yd=(t,e,s)=>e in t?Ix(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Oi=(t,e)=>{for(var s in e||(e={}))Rx.call(e,s)&&yd(t,s,e[s]);if(rf)for(var s of rf(e))Ox.call(e,s)&&yd(t,s,e[s]);return t},oa=(t,e)=>Nx(t,Tx(e)),rs=(t,e,s)=>yd(t,typeof e!="symbol"?e+"":e,s);let Px=class dy{constructor(e){rs(this,"client"),rs(this,"namespaces"),rs(this,"optionalNamespaces"),rs(this,"sessionProperties"),rs(this,"scopedProperties"),rs(this,"events",new Sd),rs(this,"rpcProviders",{}),rs(this,"session"),rs(this,"providerOpts"),rs(this,"logger"),rs(this,"uri"),rs(this,"disableProviderPing",!1),rs(this,"connectParams");var s,n;this.providerOpts=e,this.logger=Gd({logger:(s=e.logger)!=null?s:Wp,name:(n=this.providerOpts.name)!=null?n:ry}),this.disableProviderPing=(e==null?void 0:e.disableProviderPing)||!1}static async init(e){const s=new dy(e);return await s.initialize(),s}async request(e,s,n){const[r,i]=this.validateChain(s);if(!this.session)throw new Error("Please call connect() before request()");return await this.getProvider(r).request({request:Oi({},e),chainId:`${r}:${i}`,topic:this.session.topic,expiry:n})}sendAsync(e,s,n,r){const i=new Date().getTime();this.request(e,n,r).then(o=>s(null,Yi(i,o))).catch(o=>s(o,void 0))}async enable(){if(!this.client)throw new Error("Sign Client not initialized");return this.session||await this.connect({namespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties}),await this.requestAccounts()}async disconnect(){var e;if(!this.session)throw new Error("Please call connect() before enable()");await this.client.disconnect({topic:(e=this.session)==null?void 0:e.topic,reason:Ze("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw new Error("Sign Client not initialized");if(this.connectParams=e,this.setNamespaces(e),this.cleanupPendingPairings(),!e.skipPairing)return await this.pair(e.pairingTopic)}async authenticate(e,s){if(!this.client)throw new Error("Sign Client not initialized");this.setNamespaces(e),await this.cleanupPendingPairings();const{uri:n,response:r}=await this.client.authenticate(e,s);n&&(this.uri=n,this.events.emit("display_uri",n));const i=await r();if(this.session=i.session,this.session){const o=Yp(this.session.namespaces);this.namespaces=ia(this.namespaces,o),await this.persist("namespaces",this.namespaces),this.onConnect()}return i}on(e,s){this.events.on(e,s)}once(e,s){this.events.once(e,s)}removeListener(e,s){this.events.removeListener(e,s)}off(e,s){this.events.off(e,s)}get isWalletConnect(){return!0}async pair(e){var s,n;const{uri:r,approval:i}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties,authentication:(s=this.connectParams)==null?void 0:s.authentication,walletPay:(n=this.connectParams)==null?void 0:n.walletPay});r&&(this.uri=r,this.events.emit("display_uri",r));const o=await i();this.session=o;const a=Yp(o.namespaces);return this.namespaces=ia(this.namespaces,a),await this.persist("namespaces",this.namespaces),await this.persist("optionalNamespaces",this.optionalNamespaces),this.onConnect(),this.session}setDefaultChain(e,s){try{if(!this.session)return;const[n,r]=this.validateChain(e);this.getProvider(n).setDefaultChain(r,s)}catch(n){if(!/Please call connect/.test(n.message))throw n}}async cleanupPendingPairings(e={}){try{this.logger.info("Cleaning up inactive pairings...");const s=this.client.pairing.getAll();if(!_n(s))return;for(const n of s)e.deletePairings?this.client.core.expirer.set(n.topic,0):await this.client.core.relayer.subscriber.unsubscribe(n.topic);this.logger.info(`Inactive pairings cleared: ${s.length}`)}catch(s){this.logger.warn(s,"Failed to cleanup pending pairings")}}abortPairingAttempt(){this.logger.warn("abortPairingAttempt is deprecated. This is now a no-op.")}async checkStorage(){this.namespaces=await this.getFromStore("namespaces")||{},this.optionalNamespaces=await this.getFromStore("optionalNamespaces")||{},this.session&&this.createProviders()}async initialize(){this.logger.trace("Initialized"),await this.createClient(),await this.checkStorage(),this.registerEventListeners()}async createClient(){var e,s;if(this.client=this.providerOpts.client||await cP.init({core:this.providerOpts.core,logger:this.providerOpts.logger||Wp,relayUrl:this.providerOpts.relayUrl||DP,projectId:this.providerOpts.projectId,metadata:this.providerOpts.metadata,storageOptions:this.providerOpts.storageOptions,storage:this.providerOpts.storage,name:this.providerOpts.name,customStoragePrefix:this.providerOpts.customStoragePrefix,telemetryEnabled:this.providerOpts.telemetryEnabled}),this.providerOpts.session)try{this.session=this.client.session.get(this.providerOpts.session.topic)}catch(n){throw this.logger.error(n,"Failed to get session"),new Error(`The provided session: ${(s=(e=this.providerOpts)==null?void 0:e.session)==null?void 0:s.topic} doesn't exist in the Sign client`)}else{const n=this.client.session.getAll();this.session=n[0]}this.logger.trace("SignClient Initialized")}createProviders(){if(!this.client)throw new Error("Sign Client not initialized");if(!this.session)throw new Error("Session not initialized. Please call connect() before enable()");const e=[...new Set(Object.keys(this.session.namespaces).map(s=>Xr(s)))];ll("client",this.client),ll("events",this.events),ll("disableProviderPing",this.disableProviderPing),e.forEach(s=>{if(!this.session)return;const n=KP(s,this.session);if((n==null?void 0:n.length)===0)return;const r=cy(n),i=ia(this.namespaces,this.optionalNamespaces),o=oa(Oi({},i[s]),{accounts:n,chains:r});switch(s){case"eip155":this.rpcProviders[s]=new Cx({namespace:o});break;default:this.rpcProviders[s]=new Sx({namespace:o})}})}registerEventListeners(){if(typeof this.client>"u")throw new Error("Sign Client is not initialized");this.client.on("session_ping",e=>{var s;const{topic:n}=e;n===((s=this.session)==null?void 0:s.topic)&&this.events.emit("session_ping",e)}),this.client.on("session_event",e=>{var s;const{params:n,topic:r}=e;if(r!==((s=this.session)==null?void 0:s.topic))return;const{event:i}=n;if(i.name==="accountsChanged"){const o=i.data;o&&_n(o)&&this.events.emit("accountsChanged",o.map(Gp))}else if(i.name==="chainChanged"){const o=n.chainId,a=n.event.data,c=Xr(o),l=cl(o)!==cl(a)?`${c}:${cl(a)}`:o;this.onChainChanged({currentCaipChainId:l})}else this.events.emit(i.name,i.data);this.events.emit("session_event",e)}),this.client.on("session_update",({topic:e,params:s})=>{var n,r;if(e!==((n=this.session)==null?void 0:n.topic))return;const{namespaces:i}=s,o=(r=this.client)==null?void 0:r.session.get(e);this.session=oa(Oi({},o),{namespaces:i}),this.onSessionUpdate(),this.events.emit("session_update",{topic:e,params:s})}),this.client.on("session_delete",async e=>{var s;e.topic===((s=this.session)==null?void 0:s.topic)&&(await this.cleanup(),this.events.emit("session_delete",e),this.events.emit("disconnect",oa(Oi({},Ze("USER_DISCONNECTED")),{data:e.topic})))}),this.on(Qd.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(oa(Oi({},e),{internal:!0}))})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[oy]}onSessionUpdate(){Object.keys(this.rpcProviders).forEach(e=>{var s;this.getProvider(e).updateNamespace((s=this.session)==null?void 0:s.namespaces[e])})}setNamespaces(e){const{namespaces:s={},optionalNamespaces:n={},sessionProperties:r,scopedProperties:i}=e;this.optionalNamespaces=ia(s,n),this.sessionProperties=r,this.scopedProperties=i}validateChain(e){const[s,n]=(e==null?void 0:e.split(":"))||["",""];if(!this.namespaces||!Object.keys(this.namespaces).length)return[s,n];if(s&&!Object.keys(this.namespaces||{}).map(o=>Xr(o)).includes(s))throw new Error(`Namespace '${s}' is not configured. Please call connect() first with namespace config.`);if(s&&n)return[s,n];const r=Xr(Object.keys(this.namespaces)[0]),i=this.rpcProviders[r].getDefaultChain();return[r,i]}async requestAccounts(){const[e]=this.validateChain();return await this.getProvider(e).requestAccounts()}async onChainChanged({currentCaipChainId:e,previousCaipChainId:s,internal:n=!1}){if(!this.namespaces)return;const[r,i]=this.validateChain(e);i&&(this.updateNamespaceChain(r,i),n?(this.events.emit("chainChanged",i),this.emitAccountsChangedOnChainChange({namespace:r,currentCaipChainId:e,previousCaipChainId:s})):this.getProvider(r).setDefaultChain(i),await this.persist("namespaces",this.namespaces))}emitAccountsChangedOnChainChange({namespace:e,currentCaipChainId:s,previousCaipChainId:n}){var r,i;try{if(n===s)return;const o=(i=(r=this.session)==null?void 0:r.namespaces[e])==null?void 0:i.accounts;if(!o)return;const a=o.filter(c=>c.includes(`${s}:`)).map(Gp);if(!_n(a))return;this.events.emit("accountsChanged",a)}catch(o){this.logger.warn(o,"Failed to emit accountsChanged on chain change")}}updateNamespaceChain(e,s){if(!this.namespaces)return;const n=this.namespaces[e]?e:`${e}:${s}`,r={chains:[],methods:[],events:[],defaultChain:s};this.namespaces[n]?this.namespaces[n]&&(this.namespaces[n].defaultChain=s):this.namespaces[n]=r}onConnect(){this.createProviders(),this.events.emit("connect",{session:this.session})}async cleanup(){this.connectParams=void 0,this.namespaces=void 0,this.optionalNamespaces=void 0,this.sessionProperties=void 0,await this.deleteFromStore("namespaces"),await this.deleteFromStore("optionalNamespaces"),await this.deleteFromStore("sessionProperties"),this.session=void 0,this.cleanupPendingPairings({deletePairings:!0}),await this.cleanupStorage()}async persist(e,s){var n;const r=((n=this.session)==null?void 0:n.topic)||"";await this.client.core.storage.setItem(`${na}/${e}${r}`,s)}async getFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";return await this.client.core.storage.getItem(`${na}/${e}${n}`)}async deleteFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";await this.client.core.storage.removeItem(`${na}/${e}${n}`)}async cleanupStorage(){var e;try{if(((e=this.client)==null?void 0:e.session.length)>0)return;const s=await this.client.core.storage.getKeys();for(const n of s)n.startsWith(na)&&await this.client.core.storage.removeItem(n)}catch(s){this.logger.warn(s,"Failed to cleanup storage")}}};const of=2147483648,xx={convertEVMChainIdToCoinType(t){if(t>=of)throw new Error("Invalid chainId");return(of|t)>>>0}},gs=Ge({suggestions:[],loading:!1}),kx={state:gs,subscribe(t){return _t(gs,()=>t(gs))},subscribeKey(t,e){return At(gs,t,e)},async resolveName(t){var e,s;try{return await fe.lookupEnsName(t)}catch(n){const r=n;throw new Error(((s=(e=r==null?void 0:r.reasons)==null?void 0:e[0])==null?void 0:s.description)||"Error resolving name")}},async isNameRegistered(t){try{return await fe.lookupEnsName(t),!0}catch{return!1}},async getSuggestions(t){try{gs.loading=!0,gs.suggestions=[];const e=await fe.getEnsNameSuggestions(t);return gs.suggestions=e.suggestions||[],gs.suggestions}catch(e){const s=Hi.parseEnsApiError(e,"Error fetching name suggestions");throw new Error(s)}finally{gs.loading=!1}},async getNamesForAddress(t){try{if(!E.state.activeCaipNetwork)return[];const s=F.getEnsFromCacheForAddress(t);if(s)return s;const n=await fe.reverseLookupEnsName({address:t});return F.updateEnsCache({address:t,ens:n,timestamp:Date.now()}),n}catch(e){const s=Hi.parseEnsApiError(e,"Error fetching names for address");throw new Error(s)}},async registerName(t){var r;const e=E.state.activeCaipNetwork,s=(r=E.getAccountData(e==null?void 0:e.chainNamespace))==null?void 0:r.address,n=z.getAuthConnector();if(!e)throw new Error("Network not found");if(!s||!n)throw new Error("Address or auth connector not found");gs.loading=!0;try{const i=JSON.stringify({name:t,attributes:{},timestamp:Math.floor(Date.now()/1e3)});ue.pushTransactionStack({onCancel(){ue.replace("RegisterAccountName")}});const o=await G.signMessage(i);gs.loading=!1;const a=e.id;if(!a)throw new Error("Network not found");const c=xx.convertEVMChainIdToCoinType(Number(a));await fe.registerEnsName({coinType:c,address:s,signature:o,message:i}),E.setAccountProp("profileName",t,e.chainNamespace),F.updateEnsCache({address:s,ens:[{name:t,registered_at:new Date().toISOString(),updated_at:void 0,addresses:{},attributes:[]}],timestamp:Date.now()}),ue.replace("RegisterAccountNameSuccess")}catch(i){const o=Hi.parseEnsApiError(i,`Error registering name ${t}`);throw ue.replace("RegisterAccountName"),new Error(o)}finally{gs.loading=!1}},validateName(t){return/^[a-zA-Z0-9-]{4,}$/u.test(t)},parseEnsApiError(t,e){var n,r;const s=t;return((r=(n=s==null?void 0:s.reasons)==null?void 0:n[0])==null?void 0:r.description)||e}},Hi=As(kx);function wd(t){try{return new URL(t)}catch{return null}}function Ux(t){const e=t.split("/"),s=e.length>0&&e[0]!==void 0?e[0]:"",n=s.lastIndexOf(":");return n===-1?{host:s}:{host:s.slice(0,n),port:s.slice(n+1)}}function $x(t){const e=t.indexOf("://");if(e===-1)return null;const s=t.slice(0,e),n=e+3;let r=t.indexOf("/",n);r===-1&&(r=t.length);const i=t.slice(n,r),o=i.lastIndexOf(":");return o===-1?{scheme:s,host:i}:{scheme:s,host:i.slice(0,o),port:i.slice(o+1)}}function Dx(t,e){if(e.includes("://")){const o=wd(e);return o?o.origin===t:!1}const{host:s,port:n}=Ux(e),r=t.indexOf("://");if(r!==-1){const o=r+3;let a=t.indexOf("/",o);a===-1&&(a=t.length);const c=t.slice(o,a);if(n!==void 0)return`${s}:${n}`===c;const l=c.split(":")[0];return s===l}const i=wd(t);return i?n!==void 0?s===i.hostname&&n===(i.port||void 0):s===i.hostname:!1}function Lx(t,e,s){let n=s,r;const i=n.indexOf("://");i!==-1&&(r=n.slice(0,i),n=n.slice(i+3));const o=n.indexOf("/");o!==-1&&(n=n.slice(0,o));let a=n,c;const l=a.lastIndexOf(":");l!==-1&&(c=a.slice(l+1),a=a.slice(0,l));const d=a.split(".");for(const f of d)if(f.includes("*")&&f!=="*")return!1;const u=t.protocol.replace(/:$/u,"");if(r&&r!==u||c!==void 0&&c!=="*"&&c!==t.port)return!1;const h=$x(e),g=(h?h.host:t.hostname).split(".");if(d.length!==g.length)return!1;for(let f=d.length-1;f>=0;f-=1){const y=d[f],_=g[f];if(y!=="*"&&y!==_)return!1}return!0}const Mx={ton:["ton_sendMessage","ton_signData"],solana:["solana_signMessage","solana_signTransaction","solana_requestAccounts","solana_getAccounts","solana_signAllTransactions","solana_signAndSendTransaction"],eip155:["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_showCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],bip122:["sendTransfer","signMessage","signPsbt","getAccountAddresses"]},Kn={RPC_ERROR_CODE:{USER_REJECTED:5e3,USER_REJECTED_METHODS:5002},getMethodsByChainNamespace(t){return Mx[t]||[]},createDefaultNamespace(t){return{methods:this.getMethodsByChainNamespace(t),events:["accountsChanged","chainChanged"],chains:[],rpcMap:{}}},applyNamespaceOverrides(t,e){if(!e)return{...t};const s={...t},n=new Set;if(e.methods&&Object.keys(e.methods).forEach(r=>n.add(r)),e.chains&&Object.keys(e.chains).forEach(r=>n.add(r)),e.events&&Object.keys(e.events).forEach(r=>n.add(r)),e.rpcMap&&Object.keys(e.rpcMap).forEach(r=>{const[i]=r.split(":");i&&n.add(i)}),n.forEach(r=>{s[r]||(s[r]=this.createDefaultNamespace(r))}),e.methods&&Object.entries(e.methods).forEach(([r,i])=>{s[r]&&(s[r].methods=i)}),e.chains&&Object.entries(e.chains).forEach(([r,i])=>{s[r]&&(s[r].chains=i)}),e.events&&Object.entries(e.events).forEach(([r,i])=>{s[r]&&(s[r].events=i)}),e.rpcMap){const r=new Set;Object.entries(e.rpcMap).forEach(([i,o])=>{const[a,c]=i.split(":");!a||!c||!s[a]||(s[a].rpcMap||(s[a].rpcMap={}),r.has(a)||(s[a].rpcMap={},r.add(a)),s[a].rpcMap[c]=o)})}return s},createNamespaces(t,e){const s=t.reduce((n,r)=>{const{id:i,chainNamespace:o,rpcUrls:a}=r,c=a.default.http[0];n[o]||(n[o]=this.createDefaultNamespace(o));const l=`${o}:${i}`,d=n[o];switch(d.chains.push(l),l){case"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":d.chains.push("solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ");break;case"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1":d.chains.push("solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K");break}return d!=null&&d.rpcMap&&c&&(d.rpcMap[i]=c),n},{});return this.applyNamespaceOverrides(s,e)},resolveReownName:async t=>{var n;const e=await Hi.resolveName(t);return((n=(e!=null&&e.addresses?Object.values(e.addresses):[])[0])==null?void 0:n.address)||!1},getChainsFromNamespaces(t={}){return Object.values(t).flatMap(e=>{const s=e.chains||[],n=e.accounts.map(r=>{const[i,o]=r.split(":");return`${i}:${o}`});return Array.from(new Set([...s,...n]))})},isSessionEventData(t){return typeof t=="object"&&t!==null&&"id"in t&&"topic"in t&&"params"in t&&typeof t.params=="object"&&t.params!==null&&"chainId"in t.params&&"event"in t.params&&typeof t.params.event=="object"&&t.params.event!==null},isUserRejectedRequestError(t){try{if(typeof t=="object"&&t!==null){const e=t,s=typeof e.code=="number",n=s&&e.code===Kn.RPC_ERROR_CODE.USER_REJECTED_METHODS,r=s&&e.code===Kn.RPC_ERROR_CODE.USER_REJECTED;return n||r}return!1}catch{return!1}},isOriginAllowed(t,e,s){const n=[...e,...s];if(e.length===0)return!0;const r=wd(t);if(!r)return n.some(i=>!i.includes("*")&&i===t);if(r.hostname==="localhost"||r.hostname==="127.0.0.1")return!0;for(const i of n)if(i.includes("*")){if(Lx(r,t,i))return!0}else if(Dx(t,i))return!0;return!1},listenWcProvider({universalProvider:t,namespace:e,onConnect:s,onDisconnect:n,onAccountsChanged:r,onChainChanged:i,onDisplayUri:o}){s&&t.on("connect",()=>{const a=Kn.getWalletConnectAccounts(t,e);s(a)}),n&&t.on("disconnect",()=>{n()}),r&&t.on("accountsChanged",a=>{var c,l,d,u,h;try{const p=((d=(l=(c=t.session)==null?void 0:c.namespaces)==null?void 0:l[e])==null?void 0:d.accounts)||[],g=(h=(u=t.rpcProviders)==null?void 0:u[e])==null?void 0:h.getDefaultChain(),f=a.map(y=>{const _=p.find(C=>C.includes(`${e}:${g}:${y}`));if(!_)return;const{chainId:S,chainNamespace:v}=dt.parseCaipAddress(_);return{address:y,chainId:S,chainNamespace:v}}).filter(y=>y!==void 0);f.length>0&&r(f)}catch(p){console.warn("Failed to parse accounts for namespace on accountsChanged event",e,a,p)}}),i&&t.on("chainChanged",a=>{i(a)}),o&&t.on("display_uri",a=>{o(a)})},getWalletConnectAccounts(t,e){var r,i,o,a;const s=new Set,n=(a=(o=(i=(r=t==null?void 0:t.session)==null?void 0:r.namespaces)==null?void 0:i[e])==null?void 0:o.accounts)==null?void 0:a.map(c=>dt.parseCaipAddress(c)).filter(({address:c})=>s.has(c.toLowerCase())?!1:(s.add(c.toLowerCase()),!0));return n&&n.length>0?n:[]}},Bx=[U.CONNECTOR_ID.AUTH,U.CONNECTOR_ID.WALLET_CONNECT];class jx{constructor(e){this.availableConnectors=[],this.availableConnections=[],this.providerHandlers={},this.eventListeners=new Map,this.getCaipNetworks=s=>E.getCaipNetworks(s),this.getConnectorId=s=>z.getConnectorId(s),e&&this.construct(e)}construct(e){this.projectId=e.projectId,this.namespace=e.namespace,this.adapterType=e.adapterType}get connectors(){return this.availableConnectors}get connections(){return this.availableConnections}get networks(){return this.getCaipNetworks(this.namespace)}onAuthConnected({accounts:e,chainId:s}){const n=this.getCaipNetworks().filter(r=>r.chainNamespace===this.namespace).find(r=>r.id.toString()===(s==null?void 0:s.toString()));e&&n&&this.addConnection({connectorId:U.CONNECTOR_ID.AUTH,accounts:e,caipNetwork:n})}setAuthProvider(e){e.onConnect(this.onAuthConnected.bind(this)),e.onSocialConnected(this.onAuthConnected.bind(this)),this.addConnector({id:U.CONNECTOR_ID.AUTH,type:"AUTH",name:U.CONNECTOR_NAMES.AUTH,provider:e,imageId:void 0,chain:this.namespace,chains:[]})}addConnector(...e){const s=new Set;this.availableConnectors=[...e,...this.availableConnectors].filter(n=>s.has(n.id)?!1:(s.add(n.id),!0)),this.emit("connectors",this.availableConnectors)}addConnection(...e){const s=new Set;this.availableConnections=[...e,...this.availableConnections].filter(n=>s.has(n.connectorId.toLowerCase())?!1:(s.add(n.connectorId.toLowerCase()),!0)),this.emit("connections",this.availableConnections)}deleteConnection(e){this.availableConnections=this.availableConnections.filter(s=>s.connectorId.toLowerCase()!==e.toLowerCase()),this.emit("connections",this.availableConnections)}clearConnections(e=!1){this.availableConnections=[],e&&this.emit("connections",this.availableConnections)}setStatus(e,s){E.setAccountProp("status",e,s)}on(e,s){var n;this.eventListeners.has(e)||this.eventListeners.set(e,new Set),(n=this.eventListeners.get(e))==null||n.add(s)}off(e,s){const n=this.eventListeners.get(e);n&&n.delete(s)}removeAllEventListeners(){this.eventListeners.forEach(e=>{e.clear()})}emit(e,s){const n=this.eventListeners.get(e);n&&n.forEach(r=>r(s))}async connectWalletConnect(e){try{return{clientId:(await this.getWalletConnectConnector().connectWalletConnect()).clientId}}catch(s){throw Kn.isUserRejectedRequestError(s)?new Pf(s):s}}async switchNetwork(e){var i;const{caipNetwork:s}=e,n=He.getProviderId(s.chainNamespace),r=He.getProvider(s.chainNamespace);if(!r)throw new Error("Provider not found");if(n==="WALLET_CONNECT"){r.setDefaultChain(s.caipNetworkId);return}if(n==="AUTH"){const o=(i=z.getAuthConnector())==null?void 0:i.provider;if(!o)throw new Error("Auth provider not found");const a=ls(s.chainNamespace);await o.switchNetwork({chainId:s.caipNetworkId});const c=await o.getUser({chainId:s.caipNetworkId,preferredAccountType:a});this.emit("switchNetwork",c)}}getWalletConnectConnector(){const e=this.connectors.find(s=>s.id==="walletConnect");if(!e)throw new Error("WalletConnectConnector not found");return e}onConnect(e,s){if(e.length>0){const{address:n,chainId:r}=X.getAccount(e[0]),i=this.getCaipNetworks().filter(a=>a.chainNamespace===this.namespace).find(a=>a.id.toString()===(r==null?void 0:r.toString())),o=this.connectors.find(a=>a.id===s);n&&(this.emit("accountChanged",{address:n,chainId:r,connector:o}),this.addConnection({connectorId:s,accounts:e.map(a=>{const{address:c}=X.getAccount(a);return{address:c}}),caipNetwork:i}))}}onAccountsChanged(e,s,n=!0){var r,i;if(e.length>0){const{address:o}=X.getAccount(e[0]),a=this.getConnection({connectorId:s,connections:this.connections,connectors:this.connectors});o&&((r=this.getConnectorId(U.CHAIN.EVM))==null?void 0:r.toLowerCase())===s.toLowerCase()&&this.emit("accountChanged",{address:o,chainId:(i=a==null?void 0:a.caipNetwork)==null?void 0:i.id,connector:a==null?void 0:a.connector}),this.addConnection({connectorId:s,accounts:e.map(c=>{const{address:l}=X.getAccount(c);return{address:l}}),caipNetwork:a==null?void 0:a.caipNetwork})}else n&&this.onDisconnect(s)}onDisconnect(e){var s;this.removeProviderListeners(e),this.deleteConnection(e),((s=this.getConnectorId(U.CHAIN.EVM))==null?void 0:s.toLowerCase())===e.toLowerCase()&&this.emitFirstAvailableConnection(),this.connections.length===0&&this.emit("disconnect")}onChainChanged(e,s){var o;const n=typeof e=="string"&&e.startsWith("0x")?parseInt(e,16).toString():e.toString(),r=this.getConnection({connectorId:s,connections:this.connections,connectors:this.connectors}),i=this.getCaipNetworks().filter(a=>a.chainNamespace===this.namespace).find(a=>a.id.toString()===n);r&&this.addConnection({connectorId:s,accounts:r.accounts,caipNetwork:i}),((o=this.getConnectorId(U.CHAIN.EVM))==null?void 0:o.toLowerCase())===s.toLowerCase()&&this.emit("switchNetwork",{chainId:n})}listenProviderEvents(e,s){if(Bx.includes(e))return;const n=o=>this.onAccountsChanged(o,e),r=o=>this.onChainChanged(o,e),i=()=>this.onDisconnect(e);this.providerHandlers[e]||(s.on("disconnect",i),s.on("accountsChanged",n),s.on("chainChanged",r),this.providerHandlers[e]={provider:s,disconnect:i,accountsChanged:n,chainChanged:r})}removeProviderListeners(e){if(this.providerHandlers[e]){const{provider:s,disconnect:n,accountsChanged:r,chainChanged:i}=this.providerHandlers[e];s.removeListener("disconnect",n),s.removeListener("accountsChanged",r),s.removeListener("chainChanged",i),this.providerHandlers[e]=null}}emitFirstAvailableConnection(){var s;const e=this.getConnection({connections:this.connections,connectors:this.connectors});if(e){const[n]=e.accounts;this.emit("accountChanged",{address:n==null?void 0:n.address,chainId:(s=e.caipNetwork)==null?void 0:s.id,connector:e.connector})}}getConnection({address:e,connectorId:s,connections:n,connectors:r}){if(s){const o=n.find(l=>l.connectorId.toLowerCase()===s.toLowerCase());if(!o)return null;const a=r.find(l=>l.id.toLowerCase()===o.connectorId.toLowerCase()),c=e?o.accounts.find(l=>l.address.toLowerCase()===e.toLowerCase()):o.accounts[0];return{...o,account:c,connector:a}}const i=n.find(o=>o.accounts.length>0&&r.some(a=>a.id.toLowerCase()===o.connectorId.toLowerCase()));if(i){const[o]=i.accounts,a=r.find(c=>c.id.toLowerCase()===i.connectorId.toLowerCase());return{...i,account:o,connector:a}}return null}}let ar=null;const vs={getSIWX(){return $.state.siwx},async initializeIfEnabled(t=E.getActiveCaipAddress()){var i,o,a;const e=$.state.siwx;if(!(e&&t))return;const[s,n,r]=t.split(":");if(E.checkIfSupportedNetwork(s,`${s}:${n}`))try{if((i=$.state.remoteFeatures)!=null&&i.emailCapture){const l=(o=E.getAccountData(s))==null?void 0:o.user;await Ne.open({view:"DataCapture",data:{email:(l==null?void 0:l.email)??void 0}});return}if(ar&&await ar,(await e.getSessions(`${s}:${n}`,r)).length)return;await Ne.open({view:"SIWXSignMessage"})}catch(c){console.error("SIWXUtil:initializeIfEnabled",c),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(c)}),await((a=G._getClient())==null?void 0:a.disconnect().catch(console.error)),ue.reset("Connect"),Ks.showError("A problem occurred while trying initialize authentication")}},async isAuthenticated(t=E.getActiveCaipAddress()){if(!$.state.siwx||!t)return!0;const{chainNamespace:s,chainId:n,address:r}=dt.parseCaipAddress(t),i=`${s}:${n}`;return(await vs.getSessions({address:r,caipNetworkId:i})).length>0},async requestSignMessage(){const t=$.state.siwx,e=X.getPlainAddress(E.getActiveCaipAddress()),s=ki();if(!t)throw new Error("SIWX is not enabled");if(!e)throw new Error("No ActiveCaipAddress found");if(!s)throw new Error("No ActiveCaipNetwork or client found");try{const n=await t.createMessage({chainId:s.caipNetworkId,accountAddress:e}),r=n.toString();let i="";t.signMessage?i=await t.signMessage({message:r,chainId:s.caipNetworkId,accountAddress:e}):(z.getConnectorId(s.chainNamespace)===U.CONNECTOR_ID.AUTH&&ue.pushTransactionStack({}),i=await G.signMessage(r)||""),await t.addSession({data:n,message:r,signature:i}),E.setLastConnectedSIWECaipNetwork(s),Ne.close(),Ee.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(n){(!Ne.state.open||ue.state.view==="ApproveTransaction")&&await Ne.open({view:"SIWXSignMessage"}),Ks.showError("Error signing message"),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(n)}),console.error("SWIXUtil:requestSignMessage",n)}},async cancelSignMessage(){var t;try{const e=this.getSIWX();if((t=e==null?void 0:e.getRequired)==null?void 0:t.call(e)){const n=E.getLastConnectedSIWECaipNetwork();if(n){const r=await(e==null?void 0:e.getSessions(n==null?void 0:n.caipNetworkId,X.getPlainAddress(E.getActiveCaipAddress())||""));r&&r.length>0?await E.switchActiveNetwork(n):await G.disconnect()}else await G.disconnect()}else Ne.close();Ne.close(),Ee.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getAllSessions(){const t=this.getSIWX(),e=E.getAllRequestedCaipNetworks(),s=[];return await Promise.all(e.map(async n=>{const r=await(t==null?void 0:t.getSessions(n.caipNetworkId,X.getPlainAddress(E.getActiveCaipAddress())||""));r&&s.push(...r)})),s},async getSessions(t){const e=$.state.siwx;let s=t==null?void 0:t.address;if(!s){const r=E.getActiveCaipAddress();s=X.getPlainAddress(r)}let n=t==null?void 0:t.caipNetworkId;if(!n){const r=E.getActiveCaipNetwork();n=r==null?void 0:r.caipNetworkId}return e&&s&&n?e.getSessions(n,s):[]},async isSIWXCloseDisabled(){var e;const t=this.getSIWX();if(t){const s=ue.state.view==="ApproveTransaction",n=ue.state.view==="SIWXSignMessage";if(s||n)return((e=t.getRequired)==null?void 0:e.call(t))&&(await this.getSessions()).length===0}return!1},async authConnectorAuthenticate({authConnector:t,chainId:e,socialUri:s,preferredAccountType:n,chainNamespace:r}){var u;const i=vs.getSIWX(),o=ki();if(!i||!r.includes(U.CHAIN.EVM)||(u=$.state.remoteFeatures)!=null&&u.emailCapture){const h=await t.connect({chainId:e,socialUri:s,preferredAccountType:n});return{address:h.address,chainId:h.chainId,accounts:h.accounts}}const a=`${r}:${e}`,c=await i.createMessage({chainId:a,accountAddress:"<<AccountAddress>>"}),l={accountAddress:c.accountAddress,chainId:c.chainId,domain:c.domain,uri:c.uri,version:c.version,nonce:c.nonce,notBefore:c.notBefore,statement:c.statement,resources:c.resources,requestId:c.requestId,issuedAt:c.issuedAt,expirationTime:c.expirationTime,serializedMessage:c.toString()},d=await t.connect({chainId:e,socialUri:s,siwxMessage:l,preferredAccountType:n});return l.accountAddress=d.address,l.serializedMessage=d.message||"",d.signature&&d.message&&await vs.addEmbeddedWalletSession(l,d.message,d.signature),E.setLastConnectedSIWECaipNetwork(o),{address:d.address,chainId:d.chainId,accounts:d.accounts}},async addEmbeddedWalletSession(t,e,s){if(ar)return ar;const n=vs.getSIWX();return n?(ar=n.addSession({data:t,message:e,signature:s}).finally(()=>{ar=null}),ar):Promise.resolve()},async universalProviderAuthenticate({universalProvider:t,chains:e,methods:s}){var l,d,u;const n=vs.getSIWX(),r=ki(),i=new Set(e.map(h=>h.split(":")[0]));if(!n||i.size!==1||!i.has("eip155"))return!1;const o=await n.createMessage({chainId:((l=ki())==null?void 0:l.caipNetworkId)||"",accountAddress:""}),a=await t.authenticate({nonce:o.nonce,domain:o.domain,uri:o.uri,exp:o.expirationTime,iat:o.issuedAt,nbf:o.notBefore,requestId:o.requestId,version:o.version,resources:o.resources,statement:o.statement,chainId:o.chainId,methods:s,chains:[o.chainId,...e.filter(h=>h!==o.chainId)]});Ks.showLoading("Authenticating...",{autoClose:!1});const c={...a.session.peer.metadata,name:a.session.peer.metadata.name,icon:(d=a.session.peer.metadata.icons)==null?void 0:d[0],type:"WALLET_CONNECT"};if(E.setAccountProp("connectedWalletInfo",c,Array.from(i)[0]),(u=a==null?void 0:a.auths)!=null&&u.length){const h=a.auths.map(p=>{const g=t.client.formatAuthMessage({request:p.p,iss:p.p.iss});return{data:{...p.p,accountAddress:p.p.iss.split(":").slice(-1).join(""),chainId:p.p.iss.split(":").slice(2,4).join(":"),uri:p.p.aud??"",version:p.p.version||o.version,expirationTime:p.p.exp,issuedAt:p.p.iat,notBefore:p.p.nbf},message:g,signature:p.s.s,cacao:p}});try{await n.setSessions(h),r&&E.setLastConnectedSIWECaipNetwork(r),Ee.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:vs.getSIWXEventProperties()})}catch(p){throw console.error("SIWX:universalProviderAuth - failed to set sessions",p),Ee.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:vs.getSIWXEventProperties(p)}),await t.disconnect().catch(console.error),p}finally{Ks.hide()}}return!0},getSIWXEventProperties(t){var s;const e=E.state.activeChain;if(!e)throw new Error("SIWXUtil:getSIWXEventProperties - namespace is required");return{network:((s=E.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||"",isSmartAccount:ls(e)===tt.ACCOUNT_TYPES.SMART_ACCOUNT,message:t?X.parseError(t):void 0}},async clearSessions(){const t=this.getSIWX();t&&await t.setSessions([])}};class Fx{constructor({provider:e,namespace:s}){this.id=U.CONNECTOR_ID.WALLET_CONNECT,this.name="WalletConnect",this.type="WALLET_CONNECT",this.imageId="ef1a1fcf-7fe8-4d69-bd6d-fda1345b4400",this.getCaipNetworks=E.getCaipNetworks.bind(E),this.caipNetworks=this.getCaipNetworks(),this.provider=e,this.chain=s}get chains(){return this.getCaipNetworks()}async connectWalletConnect(){if(!await this.authenticate()){const s=this.getCaipNetworks(),n=$.state.universalProviderConfigOverride,r=Kn.createNamespaces(s,n);await this.provider.connect({optionalNamespaces:r})}return{clientId:await this.provider.client.core.crypto.getClientId(),session:this.provider.session}}async disconnect(){await this.provider.disconnect()}async authenticate(){const e=this.chains.map(s=>s.caipNetworkId);return vs.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:qx})}}const qx=["eth_accounts","eth_requestAccounts","eth_sendRawTransaction","eth_sign","eth_signTransaction","eth_signTypedData","eth_signTypedData_v3","eth_signTypedData_v4","eth_sendTransaction","personal_sign","wallet_switchEthereumChain","wallet_addEthereumChain","wallet_getPermissions","wallet_requestPermissions","wallet_registerOnboarding","wallet_watchAsset","wallet_scanQRCode","wallet_getCallsStatus","wallet_sendCalls","wallet_getCapabilities","wallet_grantPermissions","wallet_revokePermissions","wallet_getAssets"],Ts=Ge({message:"",variant:"info",open:!1}),Wx={state:Ts,subscribeKey(t,e){return At(Ts,t,e)},open(t,e){const{debug:s}=$.state,{code:n,displayMessage:r,debugMessage:i}=t;r&&s&&(Ts.message=r,Ts.variant=e,Ts.open=!0),i&&console.error(typeof i=="function"?i():i,n?{code:n}:void 0)},warn(t,e,s){Ts.open=!0,Ts.message=t,Ts.variant="warning",e&&console.warn(e,s)},close(){Ts.open=!1,Ts.message="",Ts.variant="info"}},Ot=As(Wx),Hx={eip155:{native:{assetNamespace:"slip44",assetReference:"60"},defaultTokenNamespace:"erc20"},solana:{native:{assetNamespace:"slip44",assetReference:"501"},defaultTokenNamespace:"token"}};class zx extends Error{}function Vx(){const{sdkType:t,sdkVersion:e,projectId:s}=$.getSnapshot(),n=new URL("https://rpc.walletconnect.org/v1/json-rpc");return n.searchParams.set("projectId",s),n.searchParams.set("st",t),n.searchParams.set("sv",e),n.searchParams.set("source","fund-wallet"),n.toString()}async function tu(t,e){const s=Vx(),{projectId:n}=$.getSnapshot(),r={jsonrpc:"2.0",id:1,method:t,params:{...e||{},projectId:n}},o=await(await fetch(s,{method:"POST",body:JSON.stringify(r),headers:{"Content-Type":"application/json"}})).json();if(o.error)throw new zx(o.error.message);return o}async function I2(t){return(await tu("reown_getExchanges",t)).result}async function N2(t){return(await tu("reown_getExchangePayUrl",t)).result}async function T2(t){return(await tu("reown_getExchangeBuyStatus",t)).result}function R2(t,e){const{chainNamespace:s,chainId:n}=dt.parseCaipNetworkId(t),r=Hx[s];if(!r)throw new Error(`Unsupported chain namespace for CAIP-19 formatting: ${s}`);let i=r.native.assetNamespace,o=r.native.assetReference;return e!=="native"&&(i=r.defaultTokenNamespace,o=e),`${`${s}:${n}`}/${i}:${o}`}const Kx={network:"eip155:1",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},Gx={network:"eip155:8453",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},uy={network:"eip155:8453",asset:"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Yx={asset:"0x036CbD53842c5426634e7929541eC2318f3dCF7e"},Zx={network:"eip155:84532",asset:"native",metadata:{name:"Ethereum",symbol:"ETH",decimals:18}},Jx={network:"eip155:1",asset:"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Xx={network:"eip155:42161",asset:"0xaf88d065e77c8cC2239327C5EDb3A432268e5831",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},Qx={network:"eip155:137",asset:"0x2791bca1f2de4661ed88a30c99a7a9449aa84174",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},ek={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",metadata:{name:"USD Coin",symbol:"USDC",decimals:6}},tk={network:"eip155:1",asset:"0xdAC17F958D2ee523a2206206994597C13D831ec7",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},sk={network:"eip155:10",asset:"0x94b008aA00579c1307B0EF2c499aD98a8ce58e58",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},nk={network:"eip155:42161",asset:"0xFd086bC7CD5C481DCC9C85ebE478A1C0b69FCbb9",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},rk={network:"eip155:137",asset:"0xc2132d05d31c914a87c6611c10748aeb04b58e8f",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},ik={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"Es9vMFrzaCERmJfrF4H2FYD4KCoNkY11McCe8BenwNYB",metadata:{name:"Tether USD",symbol:"USDT",decimals:6}},ok={network:"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp",asset:"native",metadata:{name:"Solana",symbol:"SOL",decimals:9}},ak={ethereumETH:Kx,baseETH:Gx,baseUSDC:uy,baseSepoliaETH:Zx,ethereumUSDC:Jx,arbitrumUSDC:Xx,polygonUSDC:Qx,solanaUSDC:ek,ethereumUSDT:tk,optimismUSDT:sk,arbitrumUSDT:nk,polygonUSDT:rk,solanaUSDT:ik,solanaSOL:ok};function O2(t){return Object.values(ak).filter(e=>e.network===t)}const xs={getConnectorsByType(t,e,s){const{customWallets:n}=$.state,r=F.getRecentWallets(),i=zn.filterOutDuplicateWallets(e),o=zn.filterOutDuplicateWallets(s),a=t.filter(u=>u.type==="MULTI_CHAIN"),c=t.filter(u=>u.type==="ANNOUNCED"),l=t.filter(u=>u.type==="INJECTED"),d=t.filter(u=>u.type==="EXTERNAL");return{custom:n,recent:r,external:d,multiChain:a,announced:c,injected:l,recommended:i,featured:o}},showConnector(t){var r;const e=(r=t.info)==null?void 0:r.rdns,s=!!e&&te.state.excludedWallets.some(i=>!!i.rdns&&i.rdns===e),n=!!t.name&&te.state.excludedWallets.some(i=>Tf.isLowerCaseMatch(i.name,t.name));return!(t.type==="INJECTED"&&(t.name==="Browser Wallet"&&(!X.isMobile()||X.isMobile()&&!e&&!G.checkInstalled())||s||n)||(t.type==="ANNOUNCED"||t.type==="EXTERNAL")&&(s||n))},getIsConnectedWithWC(){return Array.from(E.state.chains.values()).some(s=>z.getConnectorId(s.namespace)===U.CONNECTOR_ID.WALLET_CONNECT)},getConnectorTypeOrder({recommended:t,featured:e,custom:s,recent:n,announced:r,injected:i,multiChain:o,external:a,overriddenConnectors:c=(l=>(l=$.state.features)==null?void 0:l.connectorTypeOrder)()??[]}){const u=[{type:"walletConnect",isEnabled:!0},{type:"recent",isEnabled:n.length>0},{type:"injected",isEnabled:[...i,...r,...o].length>0},{type:"featured",isEnabled:e.length>0},{type:"custom",isEnabled:s&&s.length>0},{type:"external",isEnabled:a.length>0},{type:"recommended",isEnabled:t.length>0}].filter(f=>f.isEnabled),h=new Set(u.map(f=>f.type)),p=c.filter(f=>h.has(f)).map(f=>({type:f,isEnabled:!0})),g=u.filter(({type:f})=>!p.some(({type:_})=>_===f));return Array.from(new Set([...p,...g].map(({type:f})=>f)))},sortConnectorsByExplorerWallet(t){return[...t].sort((e,s)=>e.explorerWallet&&s.explorerWallet?(e.explorerWallet.order??0)-(s.explorerWallet.order??0):e.explorerWallet?-1:s.explorerWallet?1:0)},getAuthName({email:t,socialUsername:e,socialProvider:s}){return e?s&&s==="discord"&&e.endsWith("0")?e.slice(0,-1):e:t.length>30?`${t.slice(0,-3)}...`:t},async fetchProviderData(t){var e,s;try{if(t.name==="Browser Wallet"&&!X.isMobile())return{accounts:[],chainId:void 0};if(t.id===U.CONNECTOR_ID.AUTH)return{accounts:[],chainId:void 0};const[n,r]=await Promise.all([(e=t.provider)==null?void 0:e.request({method:"eth_accounts"}),(s=t.provider)==null?void 0:s.request({method:"eth_chainId"}).then(i=>Number(i))]);return{accounts:n,chainId:r}}catch(n){return console.warn(`Failed to fetch provider data for ${t.name}`,n),{accounts:[],chainId:void 0}}},getFilteredCustomWallets(t){const e=F.getRecentWallets(),s=z.state.connectors.map(o=>{var a;return(a=o.info)==null?void 0:a.rdns}).filter(Boolean),n=e.map(o=>o.rdns).filter(Boolean),r=s.concat(n);if(r.includes("io.metamask.mobile")&&X.isMobile()){const o=r.indexOf("io.metamask.mobile");r[o]="io.metamask"}return t.filter(o=>!r.includes(String(o==null?void 0:o.rdns)))},hasWalletConnector(t){return z.state.connectors.some(e=>e.id===t.id||e.name===t.name)},isWalletCompatibleWithCurrentChain(t){const e=E.state.activeChain;return e&&t.chains?t.chains.some(s=>{const n=s.split(":")[0];return e===n}):!0},getFilteredRecentWallets(){return F.getRecentWallets().filter(s=>!zn.isExcluded(s)).filter(s=>!this.hasWalletConnector(s)).filter(s=>this.isWalletCompatibleWithCurrentChain(s))},getCappedRecommendedWallets(t){const{connectors:e}=z.state,{customWallets:s,featuredWalletIds:n}=$.state,r=e.find(S=>S.id==="walletConnect"),i=e.filter(S=>S.type==="INJECTED"||S.type==="ANNOUNCED"||S.type==="MULTI_CHAIN");if(!r&&!i.length&&!(s!=null&&s.length))return[];const o=Ol.isEmailEnabled(),a=Ol.isSocialsEnabled(),c=i.filter(S=>S.name!=="Browser Wallet"&&S.name!=="WalletConnect"),l=(n==null?void 0:n.length)||0,d=(s==null?void 0:s.length)||0,u=c.length||0,h=o?1:0,p=a?1:0,g=l+d+u+h+p,y=Math.max(0,4-g);return y<=0?[]:zn.filterOutDuplicateWallets(t).slice(0,y)},processConnectorsByType(t,e=!0){const s=xs.sortConnectorsByExplorerWallet([...t]);return e?s.filter(xs.showConnector):s},connectorList(){const t=xs.getConnectorsByType(z.state.connectors,te.state.recommended,te.state.featured),e=this.processConnectorsByType(t.announced.filter(p=>p.id!=="walletConnect")),s=this.processConnectorsByType(t.injected),n=this.processConnectorsByType(t.multiChain.filter(p=>p.name!=="WalletConnect"),!1),r=t.custom,i=t.recent,o=this.processConnectorsByType(t.external.filter(p=>p.id!==U.CONNECTOR_ID.COINBASE_SDK&&p.id!==U.CONNECTOR_ID.BASE_ACCOUNT)),a=t.recommended,c=t.featured,l=xs.getConnectorTypeOrder({custom:r,recent:i,announced:e,injected:s,multiChain:n,recommended:a,featured:c,external:o}),d=z.state.connectors.find(p=>p.id==="walletConnect"),u=X.isMobile(),h=[];for(const p of l)switch(p){case"walletConnect":{!u&&d&&h.push({kind:"connector",subtype:"walletConnect",connector:d});break}case"recent":{xs.getFilteredRecentWallets().forEach(f=>h.push({kind:"wallet",subtype:"recent",wallet:f}));break}case"injected":{n.forEach(g=>h.push({kind:"connector",subtype:"multiChain",connector:g})),e.forEach(g=>h.push({kind:"connector",subtype:"announced",connector:g})),s.forEach(g=>h.push({kind:"connector",subtype:"injected",connector:g}));break}case"featured":{c.forEach(g=>h.push({kind:"wallet",subtype:"featured",wallet:g}));break}case"custom":{xs.getFilteredCustomWallets(r??[]).forEach(f=>h.push({kind:"wallet",subtype:"custom",wallet:f}));break}case"external":{o.forEach(g=>h.push({kind:"connector",subtype:"external",connector:g}));break}case"recommended":{xs.getCappedRecommendedWallets(a).forEach(f=>h.push({kind:"wallet",subtype:"recommended",wallet:f}));break}default:console.warn(`Unknown connector type: ${p}`)}return h},hasInjectedConnectors(){return z.state.connectors.filter(t=>(t.type==="INJECTED"||t.type==="ANNOUNCED"||t.type==="MULTI_CHAIN")&&t.name!=="Browser Wallet"&&t.name!=="WalletConnect").length}},zn={filterOutDuplicatesByRDNS(t){const e=$.state.enableEIP6963?z.state.connectors:[],s=F.getRecentWallets(),n=e.map(a=>{var c;return(c=a.info)==null?void 0:c.rdns}).filter(Boolean),r=s.map(a=>a.rdns).filter(Boolean),i=n.concat(r);if(i.includes("io.metamask.mobile")&&X.isMobile()){const a=i.indexOf("io.metamask.mobile");i[a]="io.metamask"}return t.filter(a=>!(a!=null&&a.rdns&&i.includes(String(a.rdns))||!(a!=null&&a.rdns)&&e.some(l=>l.name===a.name)))},filterOutDuplicatesByIds(t){const e=z.state.connectors.filter(a=>a.type==="ANNOUNCED"||a.type==="INJECTED"||a.type==="MULTI_CHAIN"),s=F.getRecentWallets(),n=e.map(a=>{var c;return a.explorerId||((c=a.explorerWallet)==null?void 0:c.id)||a.id}),r=s.map(a=>a.id),i=n.concat(r);return t.filter(a=>!i.includes(a==null?void 0:a.id))},filterOutDuplicateWallets(t){const e=this.filterOutDuplicatesByRDNS(t);return this.filterOutDuplicatesByIds(e)},markWalletsAsInstalled(t){const{connectors:e}=z.state,{featuredWalletIds:s}=$.state,n=e.filter(o=>o.type==="ANNOUNCED").reduce((o,a)=>{var c;return(c=a.info)!=null&&c.rdns&&(o[a.info.rdns]=!0),o},{});return t.map(o=>({...o,installed:!!o.rdns&&!!n[o.rdns??""]})).sort((o,a)=>{const c=Number(a.installed)-Number(o.installed);if(c!==0)return c;if(s!=null&&s.length){const l=s.indexOf(o.id),d=s.indexOf(a.id);if(l!==-1&&d!==-1)return l-d;if(l!==-1)return-1;if(d!==-1)return 1}return 0})},getConnectOrderMethod(t,e){var c;const s=(t==null?void 0:t.connectMethodsOrder)||((c=$.state.features)==null?void 0:c.connectMethodsOrder),n=e||z.state.connectors;if(s)return s;const{injected:r,announced:i}=xs.getConnectorsByType(n,te.state.recommended,te.state.featured),o=r.filter(xs.showConnector),a=i.filter(xs.showConnector);return o.length||a.length?["wallet","email","social"]:Ie.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(t){const e=!!t.rdns&&te.state.excludedWallets.some(n=>n.rdns===t.rdns),s=!!t.name&&te.state.excludedWallets.some(n=>Tf.isLowerCaseMatch(n.name,t.name));return e||s},markWalletsWithDisplayIndex(t){return t.map((e,s)=>({...e,display_index:s}))},filterWalletsByWcSupport(t){return G.state.wcBasic?t.filter(e=>e.supports_wc):X.isMobile()?t.filter(e=>e.supports_wc||Ie.MANDATORY_WALLET_IDS_ON_MOBILE.includes(e.id)):t},getWalletConnectWallets(t){var i;const e=[...te.state.featured,...te.state.recommended];((i=te.state.filteredWallets)==null?void 0:i.length)>0?e.push(...te.state.filteredWallets):e.push(...t);const s=X.uniqueBy(e,"id"),n=zn.markWalletsAsInstalled(s),r=zn.filterWalletsByWcSupport(n);return zn.markWalletsWithDisplayIndex(r)}},Lt={METMASK_CONNECTOR_NAME:"MetaMask",TRUST_CONNECTOR_NAME:"Trust Wallet",SOLFLARE_CONNECTOR_NAME:"Solflare",PHANTOM_CONNECTOR_NAME:"Phantom",COIN98_CONNECTOR_NAME:"Coin98",MAGIC_EDEN_CONNECTOR_NAME:"Magic Eden",BACKPACK_CONNECTOR_NAME:"Backpack",BITGET_CONNECTOR_NAME:"Bitget Wallet",FRONTIER_CONNECTOR_NAME:"Frontier",XVERSE_CONNECTOR_NAME:"Xverse Wallet",LEATHER_CONNECTOR_NAME:"Leather",OKX_CONNECTOR_NAME:"OKX Wallet",BINANCE_CONNECTOR_NAME:"Binance Wallet",EIP155:U.CHAIN.EVM,ADD_CHAIN_METHOD:"wallet_addEthereumChain",EIP6963_ANNOUNCE_EVENT:"eip6963:announceProvider",EIP6963_REQUEST_EVENT:"eip6963:requestProvider",CONNECTOR_RDNS_MAP:{coinbaseWallet:"com.coinbase.wallet",coinbaseWalletSDK:"com.coinbase.wallet"},CONNECTOR_TYPE_EXTERNAL:"EXTERNAL",CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH",CONNECTOR_TYPE_MULTI_CHAIN:"MULTI_CHAIN",CONNECTOR_TYPE_W3M_AUTH:"AUTH",getSDKVersionWarningMessage(t,e){return`
|
|
15
15
|
@@@@@@@ @@@@@@@@@@@@@@@@@@
|
|
16
16
|
@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@
|
|
17
17
|
@@@@@@@@@@@@@ @@@@@@@@@@@@@@@@@@@@@@@@@@
|
|
@@ -245,4 +245,4 @@ NPM Registry: https://www.npmjs.com/package/@reown/appkit`}},ck={NetworkImageIds
|
|
|
245
245
|
outline: none;
|
|
246
246
|
appearance: none;
|
|
247
247
|
}
|
|
248
|
-
`;function jk(t){if(t.length>=255)throw new TypeError("Alphabet too long");const e=new Uint8Array(256);for(let l=0;l<e.length;l++)e[l]=255;for(let l=0;l<t.length;l++){const d=t.charAt(l),u=d.charCodeAt(0);if(e[u]!==255)throw new TypeError(d+" is ambiguous");e[u]=l}const s=t.length,n=t.charAt(0),r=Math.log(s)/Math.log(256),i=Math.log(256)/Math.log(s);function o(l){if(l instanceof Uint8Array||(ArrayBuffer.isView(l)?l=new Uint8Array(l.buffer,l.byteOffset,l.byteLength):Array.isArray(l)&&(l=Uint8Array.from(l))),!(l instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(l.length===0)return"";let d=0,u=0,h=0;const p=l.length;for(;h!==p&&l[h]===0;)h++,d++;const g=(p-h)*i+1>>>0,f=new Uint8Array(g);for(;h!==p;){let S=l[h],v=0;for(let C=g-1;(S!==0||v<u)&&C!==-1;C--,v++)S+=256*f[C]>>>0,f[C]=S%s>>>0,S=S/s>>>0;if(S!==0)throw new Error("Non-zero carry");u=v,h++}let y=g-u;for(;y!==g&&f[y]===0;)y++;let _=n.repeat(d);for(;y<g;++y)_+=t.charAt(f[y]);return _}function a(l){if(typeof l!="string")throw new TypeError("Expected String");if(l.length===0)return new Uint8Array;let d=0,u=0,h=0;for(;l[d]===n;)u++,d++;const p=(l.length-d)*r+1>>>0,g=new Uint8Array(p);for(;d<l.length;){const S=l.charCodeAt(d);if(S>255)return;let v=e[S];if(v===255)return;let C=0;for(let R=p-1;(v!==0||C<h)&&R!==-1;R--,C++)v+=s*g[R]>>>0,g[R]=v%256>>>0,v=v/256>>>0;if(v!==0)throw new Error("Non-zero carry");h=C,d++}let f=p-h;for(;f!==p&&g[f]===0;)f++;const y=new Uint8Array(u+(p-f));let _=u;for(;f!==p;)y[_++]=g[f++];return y}function c(l){const d=a(l);if(d)return d;throw new Error("Non-base"+s+" character")}return{encode:o,decodeUnsafe:a,decode:c}}var Fk="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";const qk=jk(Fk),Li={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603};class Wk extends jx{async setUniversalProvider(e){if(!this.namespace)throw new Error("UniversalAdapter:setUniversalProvider - namespace is required");return this.addConnector(new Fx({provider:e,caipNetworks:this.getCaipNetworks(),namespace:this.namespace})),Promise.resolve()}async connect(e){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:Number(e.chainId),provider:this.provider,address:""})}async disconnect(){try{await this.getWalletConnectConnector().disconnect(),this.emit("disconnect")}catch(e){console.warn("UniversalAdapter:disconnect - error",e)}return{connections:[]}}syncConnections(){return Promise.resolve()}async getAccounts({namespace:e}){var r,i,o,a;const s=this.provider,n=((a=(o=(i=(r=s==null?void 0:s.session)==null?void 0:r.namespaces)==null?void 0:i[e])==null?void 0:o.accounts)==null?void 0:a.map(c=>{const[,,l]=c.split(":");return l}).filter((c,l,d)=>d.indexOf(c)===l))||[];return Promise.resolve({accounts:n.map(c=>X.createAccount(e,c,e==="bip122"?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){var o,a,c,l,d;if(!(e.caipNetwork&&Ie.BALANCE_SUPPORTED_CHAINS.includes((o=e.caipNetwork)==null?void 0:o.chainNamespace))||(a=e.caipNetwork)!=null&&a.testnet)return{balance:"0.00",symbol:((c=e.caipNetwork)==null?void 0:c.nativeCurrency.symbol)||""};const n=E.getAccountData();if(n!=null&&n.balanceLoading&&e.chainId===((l=E.state.activeCaipNetwork)==null?void 0:l.id))return{balance:(n==null?void 0:n.balance)||"0.00",symbol:(n==null?void 0:n.balanceSymbol)||""};const i=(await E.fetchTokenBalance()).find(u=>{var h,p;return u.chainId===`${(h=e.caipNetwork)==null?void 0:h.chainNamespace}:${e.chainId}`&&u.symbol===((p=e.caipNetwork)==null?void 0:p.nativeCurrency.symbol)});return{balance:(i==null?void 0:i.quantity.numeric)||"0.00",symbol:(i==null?void 0:i.symbol)||((d=e.caipNetwork)==null?void 0:d.nativeCurrency.symbol)||""}}async signMessage(e){var o,a,c;const{provider:s,message:n,address:r}=e;if(!s)throw new Error("UniversalAdapter:signMessage - provider is undefined");let i="";return((o=E.state.activeCaipNetwork)==null?void 0:o.chainNamespace)===U.CHAIN.SOLANA?i=(await s.request({method:"solana_signMessage",params:{message:qk.encode(new TextEncoder().encode(n)),pubkey:r}},(a=E.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)).signature:i=await s.request({method:"personal_sign",params:[n,r]},(c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId),{signature:i}}async estimateGas(){return Promise.resolve({gas:BigInt(0)})}async sendTransaction(){return Promise.resolve({hash:""})}walletGetAssets(e){return Promise.resolve({})}async writeContract(){return Promise.resolve({hash:""})}emitFirstAvailableConnection(){}parseUnits(){return 0n}formatUnits(){return"0"}async getCapabilities(){return Promise.resolve({})}async grantPermissions(){return Promise.resolve({})}async revokePermissions(){return Promise.resolve("0x")}async syncConnection(){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:1,provider:this.provider,address:""})}async switchNetwork(e){var r,i,o,a,c,l;const{caipNetwork:s}=e,n=this.getWalletConnectConnector();if(s.chainNamespace===U.CHAIN.EVM)try{await((r=n.provider)==null?void 0:r.request({method:"wallet_switchEthereumChain",params:[{chainId:Tu(s.id)}]}))}catch(d){if(d.code===Li.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||d.code===Li.ERROR_INVALID_CHAIN_ID||d.code===Li.ERROR_CODE_DEFAULT||((o=(i=d==null?void 0:d.data)==null?void 0:i.originalError)==null?void 0:o.code)===Li.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await((l=n.provider)==null?void 0:l.request({method:"wallet_addEthereumChain",params:[{chainId:Tu(s.id),rpcUrls:[(a=s==null?void 0:s.rpcUrls.chainDefault)==null?void 0:a.http],chainName:s.name,nativeCurrency:s.nativeCurrency,blockExplorerUrls:[(c=s.blockExplorers)==null?void 0:c.default.url]}]}))}catch{throw new Error("Chain is not supported")}}n.provider.setDefaultChain(s.caipNetworkId)}getWalletConnectProvider(){const e=this.connectors.find(n=>n.type==="WALLET_CONNECT");return e==null?void 0:e.provider}}const Hk=["email","socials","swaps","onramp","activity","reownBranding","multiWallet","emailCapture","payWithExchange","payments","reownAuthentication","headless"],ca={email:{apiFeatureName:"social_login",localFeatureName:"email",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return!!t.isEnabled&&e.includes("email")},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.email:!!t},socials:{apiFeatureName:"social_login",localFeatureName:"socials",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e.filter(s=>s!=="email"):!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.socials:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.socials:!1:t},swaps:{apiFeatureName:"swap",localFeatureName:"swaps",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e:!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.swaps:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.swaps:!1:t},onramp:{apiFeatureName:"onramp",localFeatureName:"onramp",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e:!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.onramp:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.onramp:!1:t},activity:{apiFeatureName:"activity",localFeatureName:"history",returnType:!1,isLegacy:!0,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.activity:!!t},reownBranding:{apiFeatureName:"reown_branding",localFeatureName:"reownBranding",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.reownBranding:!!t},emailCapture:{apiFeatureName:"email_capture",localFeatureName:"emailCapture",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>t.isEnabled&&(t.config??[]),processFallback:t=>!1},multiWallet:{apiFeatureName:"multi_wallet",localFeatureName:"multiWallet",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.multiWallet},payWithExchange:{apiFeatureName:"fund_from_exchange",localFeatureName:"payWithExchange",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.payWithExchange},payments:{apiFeatureName:"payments",localFeatureName:"payments",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.payments},reownAuthentication:{apiFeatureName:"reown_authentication",localFeatureName:"reownAuthentication",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>typeof t>"u"?Ie.DEFAULT_REMOTE_FEATURES.reownAuthentication:!!t},headless:{apiFeatureName:"headless",localFeatureName:"headless",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.headless}},zk={localSettingsOverridden:new Set,getApiConfig(t,e){return e==null?void 0:e.find(s=>s.id===t)},addWarning(t,e){if(t!==void 0){const s=ca[e],n=s.isLegacy?`"features.${s.localFeatureName}" (now "${e}")`:`"features.${e}"`;this.localSettingsOverridden.add(n)}},processFeature(t,e,s,n,r){const i=ca[t],o=e[i.localFeatureName];if(r&&!i.isAvailableOnBasic)return!1;if(n){const a=this.getApiConfig(i.apiFeatureName,s);return(a==null?void 0:a.config)===null?this.processFallbackFeature(t,o):a!=null&&a.config?(o!==void 0&&this.addWarning(o,t),this.processApiFeature(t,a)):!1}return this.processFallbackFeature(t,o)},processApiFeature(t,e){return ca[t].processApi(e)},processFallbackFeature(t,e){return ca[t].processFallback(e)},async fetchRemoteFeatures(t){const e=t.basic??!1,s=t.features||{};this.localSettingsOverridden.clear();let n=null,r=!1;try{n=await te.fetchProjectConfig(),r=n!=null}catch(o){console.warn("[Reown Config] Failed to fetch remote project configuration. Using local/default values.",o)}const i=r&&!e?Ie.DEFAULT_REMOTE_FEATURES:Ie.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(const o of Hk){const a=this.processFeature(o,s,n,r,e);Object.assign(i,{[o]:a})}}catch(o){return console.warn("[Reown Config] Failed to process the configuration from Cloud. Using default values.",o),Ie.DEFAULT_REMOTE_FEATURES}if(r&&this.localSettingsOverridden.size>0){const o=`Your local configuration for ${Array.from(this.localSettingsOverridden).join(", ")} was ignored because a remote configuration was successfully fetched. Please manage these features via your project dashboard on dashboard.reown.com.`;Ot.open({debugMessage:Pt.ALERT_WARNINGS.LOCAL_CONFIGURATION_IGNORED.debugMessage(o)},"warning")}return i}};class Vk{constructor(e){this.chainNamespaces=[],this.features={},this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(s,n)=>{var r,i,o;if(s){const a=(r=E.getCaipNetworks(s))==null?void 0:r.find(d=>d.id===n);if(a)return a;const c=(i=E.getNetworkData(s))==null?void 0:i.caipNetwork;return c||((o=E.getRequestedCaipNetworks(s).filter(d=>d.chainNamespace===s))==null?void 0:o[0])}return E.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{const s=this.getCaipNetwork();if(s)return s.id},this.getCaipNetworks=s=>E.getCaipNetworks(s),this.getActiveChainNamespace=()=>E.state.activeChain,this.setRequestedCaipNetworks=(s,n)=>{E.setRequestedCaipNetworks(s,n)},this.getApprovedCaipNetworkIds=()=>E.getAllApprovedCaipNetworkIds(),this.getCaipAddress=s=>{var n,r;return E.state.activeChain===s||!s?E.state.activeCaipAddress:(r=(n=E.state.chains.get(s))==null?void 0:n.accountState)==null?void 0:r.caipAddress},this.setClientId=s=>{fe.setClientId(s)},this.getProvider=s=>He.getProvider(s),this.getProviderType=s=>He.getProviderId(s),this.getPreferredAccountType=s=>ls(s),this.setCaipAddress=(s,n,r=!1)=>{E.setAccountProp("caipAddress",s,n,r),E.setAccountProp("address",X.getPlainAddress(s),n,r)},this.setBalance=(s,n,r)=>{E.setAccountProp("balance",s,r),E.setAccountProp("balanceSymbol",n,r)},this.setProfileName=(s,n)=>{E.setAccountProp("profileName",s,n)},this.setProfileImage=(s,n)=>{E.setAccountProp("profileImage",s,n)},this.setUser=(s,n)=>{E.setAccountProp("user",s,n)},this.resetAccount=s=>{E.resetAccount(s)},this.setCaipNetwork=s=>{E.setActiveCaipNetwork(s)},this.setCaipNetworkOfNamespace=(s,n)=>{E.setChainNetworkData(n,{caipNetwork:s})},this.setStatus=(s,n)=>{E.setAccountProp("status",s,n),z.isConnected()?F.setConnectionStatus("connected"):F.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=s=>{var n;return(n=E.getAccountData(s))==null?void 0:n.address},this.setConnectors=s=>{const n=[...z.state.allConnectors,...s];z.setConnectors(n)},this.setConnections=(s,n)=>{F.setConnections(s,n),G.setConnections(s,n)},this.fetchIdentity=s=>fe.fetchIdentity(s),this.getReownName=s=>Hi.getNamesForAddress(s),this.getConnectors=()=>z.getConnectors(),this.getConnectorImage=s=>Kf.getConnectorImage(s),this.getConnections=s=>this.remoteFeatures.multiWallet?$a.getConnectionsData(s).connections:(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.getRecentConnections=s=>this.remoteFeatures.multiWallet?$a.getConnectionsData(s).recentConnections:(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.switchConnection=async s=>{if(!this.remoteFeatures.multiWallet){Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}await G.switchConnection(s)},this.deleteConnection=s=>{if(!this.remoteFeatures.multiWallet){Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}F.deleteAddressFromConnection(s),G.syncStorageConnections()},this.setConnectedWalletInfo=(s,n)=>{const r=He.getProviderId(n),i=s?{...s,type:r}:void 0;E.setAccountProp("connectedWalletInfo",i,n)},this.getIsConnectedState=()=>!!E.state.activeCaipAddress,this.addAddressLabel=(s,n,r)=>{var o;const i=((o=E.getAccountData(r))==null?void 0:o.addressLabels)||{};E.setAccountProp("addressLabels",{...i,[s]:n},r)},this.removeAddressLabel=(s,n)=>{var i;const r=((i=E.getAccountData(n))==null?void 0:i.addressLabels)||{};E.setAccountProp("addressLabels",{...r,[s]:void 0},n)},this.getAddress=s=>{var r;const n=s||E.state.activeChain;return(r=E.getAccountData(n))==null?void 0:r.address},this.resetNetwork=s=>{E.resetNetwork(s)},this.addConnector=s=>{z.addConnector(s)},this.resetWcConnection=()=>{G.resetWcConnection()},this.setAddressExplorerUrl=(s,n)=>{E.setAccountProp("addressExplorerUrl",s,n)},this.setSmartAccountDeployed=(s,n)=>{E.setAccountProp("smartAccountDeployed",s,n)},this.setPreferredAccountType=(s,n)=>{E.setAccountProp("preferredAccountType",s,n)},this.setEIP6963Enabled=s=>{$.setEIP6963Enabled(s)},this.handleUnsafeRPCRequest=()=>{if(this.isOpen()){if(this.isTransactionStackEmpty())return;this.redirect("ApproveTransaction")}else this.open({view:"ApproveTransaction"})},this.options=e,this.version=e.sdkVersion,this.caipNetworks=this.extendCaipNetworks(e),this.chainNamespaces=this.getChainNamespacesSet(e.adapters,this.caipNetworks),this.defaultCaipNetwork=this.extendDefaultCaipNetwork(e),this.chainAdapters=this.createAdapters(e.adapters),this.readyPromise=this.initialize(e)}getChainNamespacesSet(e,s){const n=e==null?void 0:e.map(i=>i.namespace).filter(i=>!!i);if(n!=null&&n.length)return[...new Set(n)];const r=s==null?void 0:s.map(i=>i.chainNamespace);return[...new Set(r)]}async initialize(e){var s,n,r,i,o,a;if(this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),(s=e.features)!=null&&s.headless&&!xs.hasInjectedConnectors()&&te.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1,fetchRecommendedWallets:!0}),$.state.enableReconnect?(await this.syncExistingConnection(),await this.syncAdapterConnections()):await this.unSyncExistingConnection(),!e.basic&&!e.manualWCControl&&(this.remoteFeatures=await zk.fetchRemoteFeatures(e)),await te.fetchUsage(),$.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&Ul.setOnrampProviders(this.remoteFeatures.onramp),((n=$.state.remoteFeatures)!=null&&n.email||Array.isArray((r=$.state.remoteFeatures)==null?void 0:r.socials)&&((i=$.state.remoteFeatures)==null?void 0:i.socials.length)>0)&&await this.checkAllowedOrigins(),(o=$.state.features)!=null&&o.reownAuthentication||(a=$.state.remoteFeatures)!=null&&a.reownAuthentication){const{ReownAuthentication:c}=await Dt(async()=>{const{ReownAuthentication:d}=await import("./features-DZkQn-RB.js");return{ReownAuthentication:d}},__vite__mapDeps([6,2,3,4])),l=$.state.siwx;l instanceof c||(l&&console.warn("ReownAuthentication option is enabled, SIWX configuration will be overridden."),$.setSIWX(new c))}}async openSend(e){var i;const s=e.namespace||E.state.activeChain,n=this.getCaipAddress(s),r=(i=this.getCaipNetwork(s))==null?void 0:i.id;if(!n)throw new Error("openSend: caipAddress not found");if((r==null?void 0:r.toString())!==e.chainId.toString()){const o=E.getCaipNetworkById(e.chainId,s);if(!o)throw new Error(`openSend: caipNetwork with chainId ${e.chainId} not found`);await this.switchNetwork(o,{throwOnFailure:!0})}try{const o=hy.getTokenSymbolByAddress(e.assetAddress);o&&await te.fetchTokenImages([o])}catch{}return await Ne.open({view:"WalletSend",data:{send:e}}),new Promise((o,a)=>{const c=_e.subscribeKey("hash",u=>{u&&(d(),o({hash:u}))}),l=Ne.subscribe(u=>{u.open||(d(),a(new Error("Modal closed")))}),d=this.createCleanupHandler([c,l])})}toModalOptions(){function e(n){return(n==null?void 0:n.view)==="Swap"}function s(n){return(n==null?void 0:n.view)==="WalletSend"}return{isSwap:e,isSend:s}}async checkAllowedOrigins(){try{const e=await te.fetchAllowedOrigins();if(!X.isClient())return;const s=window.location.origin;Kn.isOriginAllowed(s,e,U.DEFAULT_ALLOWED_ANCESTORS)||Ot.open(Pt.ALERT_ERRORS.ORIGIN_NOT_ALLOWED,"error")}catch(e){if(!(e instanceof Error))return;switch(e.message){case"RATE_LIMITED":Ot.open(Pt.ALERT_ERRORS.RATE_LIMITED_APP_CONFIGURATION,"error");break;case"SERVER_ERROR":{const s=e.cause instanceof Error?e.cause:e;Ot.open({displayMessage:Pt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.displayMessage,debugMessage:Pt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.debugMessage(s.message)},"error");break}}}}createCleanupHandler(e){return()=>{e.forEach(s=>{try{s()}catch{}})}}sendInitializeEvent(e){var n;const{...s}=e;delete s.adapters,delete s.universalProvider,Ee.sendEvent({type:"track",event:"INITIALIZE",properties:{...s,networks:e.networks.map(r=>r.id),siweConfig:{options:((n=e.siweConfig)==null?void 0:n.options)||{}}}})}initControllers(e){this.initializeOptionsController(e),this.initializeChainController(e),this.initializeThemeController(e),this.initializeConnectionController(e),this.initializeConnectorController()}initAdapterController(){Zf.initialize(this.chainAdapters)}initializeThemeController(e){e.themeMode&&Kt.setThemeMode(e.themeMode),e.themeVariables&&Kt.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient)throw new Error("ConnectionControllerClient must be set");E.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient});const s=this.getDefaultNetwork();s&&E.setActiveCaipNetwork(s)}initializeConnectionController(e){G.initialize(e.adapters??[]),G.setWcBasic(e.basic??!1)}initializeConnectorController(){z.initialize(this.chainNamespaces)}initializeProjectSettings(e){$.setProjectId(e.projectId),$.setSdkVersion(e.sdkVersion)}initializeOptionsController(e){var r;$.setDebug(e.debug!==!1),$.setEnableWalletGuide(e.enableWalletGuide!==!1),$.setEnableWallets(e.enableWallets!==!1),$.setEIP6963Enabled(e.enableEIP6963!==!1),$.setEnableNetworkSwitch(e.enableNetworkSwitch!==!1),$.setEnableReconnect(e.enableReconnect!==!1),$.setEnableMobileFullScreen(e.enableMobileFullScreen===!0),$.setCoinbasePreference(e.coinbasePreference),$.setEnableAuthLogger(e.enableAuthLogger!==!1),$.setCustomRpcUrls(e.customRpcUrls),$.setEnableEmbedded(e.enableEmbedded),$.setAllWallets(e.allWallets),$.setIncludeWalletIds(e.includeWalletIds),$.setExcludeWalletIds(e.excludeWalletIds),$.setFeaturedWalletIds(e.featuredWalletIds),$.setTokens(e.tokens),$.setTermsConditionsUrl(e.termsConditionsUrl),$.setPrivacyPolicyUrl(e.privacyPolicyUrl),$.setCustomWallets(e.customWallets),$.setFeatures(e.features),$.setAllowUnsupportedChain(e.allowUnsupportedChain),$.setUniversalProviderConfigOverride(e.universalProviderConfigOverride),$.setPreferUniversalLinks(e.experimental_preferUniversalLinks),$.setDefaultAccountTypes(e.defaultAccountTypes);const s=this.getDefaultMetaData();if(!e.metadata&&s&&(e.metadata=s),$.setMetadata(e.metadata),$.setDisableAppend(e.disableAppend),$.setEnableEmbedded(e.enableEmbedded),$.setSIWX(e.siwx),this.features=$.state.features??{},!e.projectId){Ot.open(Pt.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error");return}if(((r=e.adapters)==null?void 0:r.find(i=>i.namespace===U.CHAIN.EVM))&&e.siweConfig){if(e.siwx)throw new Error("Cannot set both `siweConfig` and `siwx` options");$.setSIWX(e.siweConfig.mapToSIWX())}}getDefaultMetaData(){var e,s,n,r;return X.isClient()?{name:((s=(e=document.getElementsByTagName("title"))==null?void 0:e[0])==null?void 0:s.textContent)||"",description:((n=document.querySelector('meta[property="og:description"]'))==null?void 0:n.content)||"",url:window.location.origin,icons:[((r=document.querySelector('link[rel~="icon"]'))==null?void 0:r.href)||""]}:null}setUnsupportedNetwork(e){const s=this.getActiveChainNamespace();if(s){const n=Gr.getUnsupportedNetwork(`${s}:${e}`);E.setActiveCaipNetwork(n)}}getDefaultNetwork(){return Gr.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,s){return Gr.extendCaipNetwork(e,{customNetworkImageUrls:s.chainImages,projectId:s.projectId})}extendCaipNetworks(e){return Gr.extendCaipNetworks(e.networks,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId})}extendDefaultCaipNetwork(e){const s=e.networks.find(r=>{var i;return r.id===((i=e.defaultNetwork)==null?void 0:i.id)});return s?Gr.extendCaipNetwork(s,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId}):void 0}async disconnectConnector(e,s){var n,r;try{this.setLoading(!0,e);let i={connections:[]};const o=this.getAdapter(e);return(((r=(n=E.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.caipAddress)||!$.state.enableReconnect)&&(o!=null&&o.disconnect)&&(i=await o.disconnect({id:s})),this.setLoading(!1,e),i}catch(i){throw this.setLoading(!1,e),new Error(`Failed to disconnect chains: ${i.message}`)}}createClients(){this.connectionControllerClient={connectWalletConnect:async()=>{var l;const e=E.state.activeChain,s=this.getAdapter(e),n=(l=this.getCaipNetwork(e))==null?void 0:l.id,r=G.getConnections(e),i=this.remoteFeatures.multiWallet,o=r.length>0;if(!s)throw new Error("Adapter not found");const a=await s.connectWalletConnect(n);(!o||!i)&&this.close(),this.setClientId((a==null?void 0:a.clientId)||null),F.setConnectedNamespaces([...E.state.chains.keys()]),await this.syncWalletConnectAccount(),await vs.initializeIfEnabled()},connectExternal:async e=>{const s=await this.onConnectExternal(e);return await this.connectInactiveNamespaces(e,s),s?{address:s.address}:void 0},reconnectExternal:async({id:e,info:s,type:n,provider:r})=>{var a;const i=E.state.activeChain,o=this.getAdapter(i);if(!i)throw new Error("reconnectExternal: namespace not found");if(!o)throw new Error("reconnectExternal: adapter not found");o!=null&&o.reconnect&&(await(o==null?void 0:o.reconnect({id:e,info:s,type:n,provider:r,chainId:(a=this.getCaipNetwork())==null?void 0:a.id})),F.addConnectedNamespace(i),this.syncConnectedWalletInfo(i))},disconnectConnector:async e=>{await this.disconnectConnector(e.namespace,e.id)},disconnect:async e=>{var l;const{id:s,chainNamespace:n,initialDisconnect:r}=e||{},i=n||E.state.activeChain,o=z.getConnectorId(i),a=s===U.CONNECTOR_ID.AUTH||o===U.CONNECTOR_ID.AUTH,c=s===U.CONNECTOR_ID.WALLET_CONNECT||o===U.CONNECTOR_ID.WALLET_CONNECT;try{const d=Array.from(E.state.chains.keys());let u=n?[n]:d;(c||a)&&(u=d);const h=u.map(async f=>{const y=z.getConnectorId(f),_=s||y,S=await this.disconnectConnector(f,_);S&&(a&&F.deleteConnectedSocialProvider(),S.connections.forEach(v=>{F.addDisconnectedConnectorId(v.connectorId,f)})),r&&this.onDisconnectNamespace({chainNamespace:f,closeModal:!1})}),p=await Promise.allSettled(h);_e.resetSend(),G.resetWcConnection(),(l=vs.getSIWX())!=null&&l.signOutOnDisconnect&&await vs.clearSessions(),z.setFilterByNamespace(void 0),G.syncStorageConnections();const g=p.filter(f=>f.status==="rejected");if(g.length>0)throw new Error(g.map(f=>f.reason.message).join(", "));Ee.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:n||"all"}})}catch(d){throw new Error(`Failed to disconnect chains: ${d.message}`)}},checkInstalled:e=>e?e.some(s=>{var n;return!!((n=window.ethereum)!=null&&n[String(s)])}):!!window.ethereum,signMessage:async e=>{const s=E.state.activeChain,n=this.getAdapter(E.state.activeChain);if(!s)throw new Error("signMessage: namespace not found");if(!n)throw new Error("signMessage: adapter not found");const r=this.getAddress(s);if(!r)throw new Error("signMessage: address not found");const i=await(n==null?void 0:n.signMessage({message:e,address:r,provider:He.getProvider(s)}));return(i==null?void 0:i.signature)||""},sendTransaction:async e=>{const s=e.chainNamespace;if(!s)throw new Error("sendTransaction: namespace not found");if(Ie.SEND_SUPPORTED_NAMESPACES.includes(s)){const n=this.getAdapter(s);if(!n)throw new Error("sendTransaction: adapter not found");const r=He.getProvider(s),i=await(n==null?void 0:n.sendTransaction({...e,caipNetwork:this.getCaipNetwork(),provider:r}));return(i==null?void 0:i.hash)||""}return""},estimateGas:async e=>{const s=e.chainNamespace;if(s===U.CHAIN.EVM){const n=this.getAdapter(s);if(!n)throw new Error("estimateGas: adapter is required but got undefined");const r=He.getProvider(s),i=this.getCaipNetwork();if(!i)throw new Error("estimateGas: caipNetwork is required but got undefined");const o=await(n==null?void 0:n.estimateGas({...e,provider:r,caipNetwork:i}));return(o==null?void 0:o.gas)||0n}return 0n},getEnsAvatar:async()=>{var r;const e=E.state.activeChain;if(!e)throw new Error("getEnsAvatar: namespace is required but got undefined");const s=this.getAddress(e);if(!s)throw new Error("getEnsAvatar: address not found");await this.syncIdentity({address:s,chainId:Number((r=this.getCaipNetwork())==null?void 0:r.id),chainNamespace:e});const n=E.getAccountData();return(n==null?void 0:n.profileImage)||!1},getEnsAddress:async e=>await Kn.resolveReownName(e),writeContract:async e=>{const s=E.state.activeChain,n=this.getAdapter(s);if(!s)throw new Error("writeContract: namespace is required but got undefined");if(!n)throw new Error("writeContract: adapter is required but got undefined");const r=this.getCaipNetwork(),i=this.getCaipAddress(),o=He.getProvider(s);if(!r||!i)throw new Error("writeContract: caipNetwork or caipAddress is required but got undefined");const a=await(n==null?void 0:n.writeContract({...e,caipNetwork:r,provider:o,caipAddress:i}));return a==null?void 0:a.hash},parseUnits:(e,s)=>{const n=this.getAdapter(E.state.activeChain);if(!n)throw new Error("parseUnits: adapter is required but got undefined");return(n==null?void 0:n.parseUnits({value:e,decimals:s}))??0n},formatUnits:(e,s)=>{const n=this.getAdapter(E.state.activeChain);if(!n)throw new Error("formatUnits: adapter is required but got undefined");return(n==null?void 0:n.formatUnits({value:e,decimals:s}))??"0"},getCapabilities:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("getCapabilities: adapter is required but got undefined");return await(s==null?void 0:s.getCapabilities(e))},grantPermissions:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("grantPermissions: adapter is required but got undefined");return await(s==null?void 0:s.grantPermissions(e))},revokePermissions:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("revokePermissions: adapter is required but got undefined");return s!=null&&s.revokePermissions?await s.revokePermissions(e):"0x"},walletGetAssets:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("walletGetAssets: adapter is required but got undefined");return await(s==null?void 0:s.walletGetAssets(e))??{}},updateBalance:e=>{const s=this.getAddress(e),n=this.getCaipNetwork(e);!n||!s||this.updateNativeBalance(s,n==null?void 0:n.id,e)}},G.setClient(this.connectionControllerClient)}async onConnectExternal(e){var l,d,u,h,p,g,f,y;const s=E.state.activeChain,n=e.chain||s,r=this.getAdapter(n);let i=!0;if(e.type===Lt.CONNECTOR_TYPE_AUTH&&U.AUTH_CONNECTOR_SUPPORTED_CHAINS.some(v=>z.getConnectorId(v)===U.CONNECTOR_ID.AUTH)&&e.chain!==s&&(i=!1),e.chain&&e.chain!==s&&!e.caipNetwork){const _=this.getCaipNetworks().find(S=>S.chainNamespace===e.chain);_&&i&&this.setCaipNetwork(_)}if(!n)throw new Error("connectExternal: namespace not found");if(!r)throw new Error("connectExternal: adapter not found");const o=this.getCaipNetwork(n),a=e.caipNetwork||o,c=await r.connect({id:e.id,address:e.address,info:e.info,type:e.type,provider:e.provider,socialUri:e.socialUri,chainId:((l=e.caipNetwork)==null?void 0:l.id)||(o==null?void 0:o.id),rpcUrl:((p=(h=(u=(d=e.caipNetwork)==null?void 0:d.rpcUrls)==null?void 0:u.default)==null?void 0:h.http)==null?void 0:p[0])||((y=(f=(g=o==null?void 0:o.rpcUrls)==null?void 0:g.default)==null?void 0:f.http)==null?void 0:y[0])});if(c)return F.addConnectedNamespace(n),this.syncProvider({...c,chainNamespace:n}),this.setStatus("connected",n),this.syncConnectedWalletInfo(n),F.removeDisconnectedConnectorId(e.id,n),{address:c.address,connectedCaipNetwork:a}}async connectInactiveNamespaces(e,s){var a;const n=e.type===Lt.CONNECTOR_TYPE_AUTH,r=wo.getOtherAuthNamespaces((a=s==null?void 0:s.connectedCaipNetwork)==null?void 0:a.chainNamespace),i=E.state.activeCaipNetwork,o=this.getAdapter(i==null?void 0:i.chainNamespace);n&&(await Promise.all(r.map(async c=>{var l,d,u;try{const h=He.getProvider(c),p=this.getCaipNetwork(c),g=this.getAdapter(c);await(g==null?void 0:g.connect({...e,provider:h,socialUri:void 0,chainId:p==null?void 0:p.id,rpcUrl:(u=(d=(l=p==null?void 0:p.rpcUrls)==null?void 0:l.default)==null?void 0:d.http)==null?void 0:u[0]}))&&(F.addConnectedNamespace(c),F.removeDisconnectedConnectorId(e.id,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c))}catch(h){Ot.warn(Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.displayMessage,Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.debugMessage(c,h instanceof Error?h.message:void 0),Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.code)}})),i&&await(o==null?void 0:o.switchNetwork({caipNetwork:i})))}getApprovedCaipNetworksData(){var s,n,r,i,o;if(He.getProviderId(E.state.activeChain)===Lt.CONNECTOR_TYPE_WALLET_CONNECT){const a=(n=(s=this.universalProvider)==null?void 0:s.session)==null?void 0:n.namespaces;return{supportsAllNetworks:((o=(i=(r=this.universalProvider)==null?void 0:r.session)==null?void 0:i.peer)==null?void 0:o.metadata.name)==="MetaMask Wallet",approvedCaipNetworkIds:this.getChainsFromNamespaces(a)}}return{supportsAllNetworks:!0,approvedCaipNetworkIds:[]}}async switchCaipNetwork(e){const s=e.chainNamespace;if(this.getAddressByChainNamespace(e.chainNamespace)){const r=He.getProviderId(s);if(e.chainNamespace===E.state.activeChain){const i=this.getAdapter(s);await(i==null?void 0:i.switchNetwork({caipNetwork:e}))}else if(this.setCaipNetwork(e),r===Lt.CONNECTOR_TYPE_WALLET_CONNECT)this.syncWalletConnectAccount();else{const i=this.getAddressByChainNamespace(s);i&&this.syncAccount({address:i,chainId:e.id,chainNamespace:s})}}else this.setCaipNetwork(e)}getChainsFromNamespaces(e={}){return Object.values(e).flatMap(s=>{const n=s.chains||[],r=s.accounts.map(i=>{const{chainId:o,chainNamespace:a}=dt.parseCaipAddress(i);return`${a}:${o}`});return Array.from(new Set([...n,...r]))})}createAdapters(e){return this.createClients(),this.chainNamespaces.reduce((s,n)=>{var i,o;const r=e==null?void 0:e.find(a=>a.namespace===n);return r?(r.construct({namespace:n,projectId:(i=this.options)==null?void 0:i.projectId,networks:(o=this.caipNetworks)==null?void 0:o.filter(({chainNamespace:a})=>a===n)}),s[n]=r):s[n]=new Wk({namespace:n,networks:this.getCaipNetworks()}),s},{})}async initChainAdapter(e){this.onConnectors(e),this.listenAdapter(e);const s=this.getAdapter(e);if(!s)throw new Error("adapter not found");await s.syncConnectors(),await this.createUniversalProviderForAdapter(e)}async initChainAdapters(){await Promise.all(this.chainNamespaces.map(async e=>{await this.initChainAdapter(e)})),this.initAdapterController()}onConnectors(e){const s=this.getAdapter(e);s==null||s.on("connectors",this.setConnectors.bind(this))}listenAdapter(e){const s=this.getAdapter(e);if(!s)return;const n=F.getConnectionStatus();$.state.enableReconnect===!1?this.setStatus("disconnected",e):n==="connected"?this.setStatus("connecting",e):n==="disconnected"?(F.clearAddressCache(),this.setStatus(n,e)):this.setStatus(n,e),s.on("switchNetwork",({address:r,chainId:i})=>{var l,d;const o=this.getCaipNetworks().find(u=>u.id.toString()===i.toString()||u.caipNetworkId.toString()===i.toString()),a=E.state.activeChain===e,c=(d=(l=E.state.chains.get(e))==null?void 0:l.accountState)==null?void 0:d.address;if(o){const u=a&&r?r:c;u&&this.syncAccount({address:u,chainId:o.id,chainNamespace:e})}else this.setUnsupportedNetwork(i)}),s.on("disconnect",()=>{const r=this.remoteFeatures.multiWallet,i=Array.from(G.state.connections.values()).flat();this.onDisconnectNamespace({chainNamespace:e,closeModal:!r||i.length===0})}),s.on("connections",r=>{this.setConnections(r,e)}),s.on("pendingTransactions",()=>{const r=this.getAddress(e),i=E.state.activeCaipNetwork;!r||!(i!=null&&i.id)||this.updateNativeBalance(r,i.id,i.chainNamespace)}),s.on("accountChanged",({address:r,chainId:i,connector:o})=>{var d,u;this.handlePreviousConnectorConnection(o);const a=E.state.activeChain===e;o!=null&&o.provider&&(this.syncProvider({id:o.id,type:o.type,provider:o==null?void 0:o.provider,chainNamespace:e}),this.syncConnectedWalletInfo(e));const c=(u=(d=E.getNetworkData(e))==null?void 0:d.caipNetwork)==null?void 0:u.id,l=i||c;a&&l?this.syncAccount({address:r,chainId:l,chainNamespace:e}):!a&&l?(this.syncAccountInfo(r,l,e),this.syncBalance({address:r,chainId:l,chainNamespace:e})):this.syncAccountInfo(r,i,e),F.addConnectedNamespace(e)})}async handlePreviousConnectorConnection(e){var c;const s=e==null?void 0:e.chain,n=e==null?void 0:e.id,r=z.getConnectorId(s),i=(c=$.state.remoteFeatures)==null?void 0:c.multiWallet,a=s&&n&&r&&r!==n&&!i;try{a&&await G.disconnect({id:r,namespace:s})}catch(l){console.warn("Error disconnecting previous connector",l)}}async createUniversalProviderForAdapter(e){var s,n,r;await this.getUniversalProvider(),this.universalProvider&&await((r=(n=(s=this.chainAdapters)==null?void 0:s[e])==null?void 0:n.setUniversalProvider)==null?void 0:r.call(n,this.universalProvider))}async syncExistingConnection(){await Promise.allSettled(this.chainNamespaces.map(e=>this.syncNamespaceConnection(e)))}async unSyncExistingConnection(){try{await Promise.allSettled(this.chainNamespaces.map(e=>G.disconnect({namespace:e,initialDisconnect:!0})))}catch(e){console.error("Error disconnecting existing connections:",e)}}async reconnectWalletConnect(){await this.syncWalletConnectAccount();const e=this.getAddress();this.getCaipAddress()||F.deleteRecentWallet();const s=F.getRecentWallet();Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:e,properties:{method:X.isMobile()?"mobile":"qrcode",name:(s==null?void 0:s.name)||"Unknown",reconnect:!0,view:ue.state.view,walletRank:s==null?void 0:s.order}})}async syncNamespaceConnection(e){try{e===U.CHAIN.EVM&&X.isSafeApp()&&z.setConnectorId(U.CONNECTOR_ID.SAFE,e);const s=z.getConnectorId(e);switch(this.setStatus("connecting",e),s){case U.CONNECTOR_ID.WALLET_CONNECT:await this.reconnectWalletConnect();break;case U.CONNECTOR_ID.AUTH:break;default:await this.syncAdapterConnection(e)}}catch(s){console.warn("AppKit couldn't sync existing connection",s),this.setStatus("disconnected",e)}}onDisconnectNamespace(e){const{chainNamespace:s,closeModal:n}=e||{};E.resetAccount(s),E.resetNetwork(s),F.removeConnectedNamespace(s);const r=Array.from(E.state.chains.keys());(s?[s]:r).forEach(o=>F.addDisconnectedConnectorId(z.getConnectorId(o)||"",o)),z.removeConnectorId(s),He.resetChain(s),this.setUser(null,s),this.setStatus("disconnected",s),this.setConnectedWalletInfo(null,s),n!==!1&&Ne.close()}async syncAdapterConnections(){await Promise.allSettled(this.chainNamespaces.map(e=>{const s=this.getAdapter(e),n=this.getCaipAddress(e),r=this.getCaipNetwork(e);return s==null?void 0:s.syncConnections({connectToFirstConnector:!n,caipNetwork:r})}))}async syncAdapterConnection(e){var a,c,l,d,u;const s=this.getAdapter(e),n=this.getCaipNetwork(e),r=z.getConnectorId(e),o=z.getConnectors(e).find(h=>h.id===r);try{if(!s||!o)throw new Error(`Adapter or connector not found for namespace ${e}`);if(!(n!=null&&n.id))throw new Error("CaipNetwork not found");const h=await(s==null?void 0:s.syncConnection({namespace:e,id:o.id,chainId:n.id,rpcUrl:(l=(c=(a=n==null?void 0:n.rpcUrls)==null?void 0:a.default)==null?void 0:c.http)==null?void 0:l[0]}));h?(this.syncProvider({...h,chainNamespace:e}),await this.syncAccount({...h,chainNamespace:e}),this.setStatus("connected",e),Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:h.address,properties:{method:"browser",name:((d=o.info)==null?void 0:d.name)||o.name||"Unknown",reconnect:!0,view:ue.state.view,walletRank:(u=o==null?void 0:o.explorerWallet)==null?void 0:u.order}})):this.setStatus("disconnected",e)}catch{this.onDisconnectNamespace({chainNamespace:e,closeModal:!1})}}async syncWalletConnectAccount(){var n,r;const e=Object.keys(((r=(n=this.universalProvider)==null?void 0:n.session)==null?void 0:r.namespaces)||{}),s=this.chainNamespaces.map(async i=>{var u,h,p,g,f;const o=this.getAdapter(i);if(!o)return;const a=((g=(p=(h=(u=this.universalProvider)==null?void 0:u.session)==null?void 0:h.namespaces)==null?void 0:p[i])==null?void 0:g.accounts)||[],c=(f=E.state.activeCaipNetwork)==null?void 0:f.id,l=a.find(y=>{const{chainId:_}=dt.parseCaipAddress(y);return _===(c==null?void 0:c.toString())})||a[0];if(l){const y=dt.validateCaipAddress(l),{chainId:_,address:S}=dt.parseCaipAddress(y);if(He.setProviderId(i,Lt.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&E.state.activeCaipNetwork&&o.namespace!==U.CHAIN.EVM){const v=o.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:E.state.activeCaipNetwork});He.setProvider(i,v)}else He.setProvider(i,this.universalProvider);z.setConnectorId(U.CONNECTOR_ID.WALLET_CONNECT,i),F.addConnectedNamespace(i),await this.syncAccount({address:S,chainId:_,chainNamespace:i})}else e.includes(i)&&this.setStatus("disconnected",i);const d=this.getApprovedCaipNetworksData();this.syncConnectedWalletInfo(i),E.setApprovedCaipNetworksData(i,{approvedCaipNetworkIds:d.approvedCaipNetworkIds,supportsAllNetworks:d.supportsAllNetworks})});await Promise.all(s)}syncProvider({type:e,provider:s,id:n,chainNamespace:r}){He.setProviderId(r,e),He.setProvider(r,s),z.setConnectorId(n,r)}async syncAccount(e){var u,h;const s=e.chainNamespace===E.state.activeChain,n=E.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:r,chainId:i,chainNamespace:o}=e,{chainId:a}=F.getActiveNetworkProps(),c=(n==null?void 0:n.id)||a,l=((u=E.state.activeCaipNetwork)==null?void 0:u.name)===U.UNSUPPORTED_NETWORK_NAME,d=E.getNetworkProp("supportsAllNetworks",o);if(this.setStatus("connected",o),!(l&&!d)&&c){let p=this.getCaipNetworks().find(_=>_.id.toString()===c.toString()),g=this.getCaipNetworks().find(_=>_.chainNamespace===o);if(!d&&!p&&!g){const _=this.getApprovedCaipNetworkIds()||[],S=_.find(C=>{var R;return((R=dt.parseCaipNetworkId(C))==null?void 0:R.chainId)===c.toString()}),v=_.find(C=>{var R;return((R=dt.parseCaipNetworkId(C))==null?void 0:R.chainNamespace)===o});p=this.getCaipNetworks().find(C=>C.caipNetworkId===S),g=this.getCaipNetworks().find(C=>C.caipNetworkId===v||"deprecatedCaipNetworkId"in C&&C.deprecatedCaipNetworkId===v)}const f=p||g;(f==null?void 0:f.chainNamespace)===E.state.activeChain?$.state.enableNetworkSwitch&&!$.state.allowUnsupportedChain&&((h=E.state.activeCaipNetwork)==null?void 0:h.name)===U.UNSUPPORTED_NETWORK_NAME?E.showUnsupportedChainUI():this.setCaipNetwork(f):s||n&&this.setCaipNetworkOfNamespace(n,o),this.syncConnectedWalletInfo(o);const y=this.getAddress(o);wo.isLowerCaseMatch(r,y)||this.syncAccountInfo(r,f==null?void 0:f.id,o),s?await this.syncBalance({address:r,chainId:f==null?void 0:f.id,chainNamespace:o}):await this.syncBalance({address:r,chainId:n==null?void 0:n.id,chainNamespace:o}),this.syncIdentity({address:r,chainId:i,chainNamespace:o})}}async syncAccountInfo(e,s,n){const r=this.getCaipAddress(n),i=s||(r==null?void 0:r.split(":")[1]);if(!i)return;const o=`${n}:${i}:${e}`;this.setCaipAddress(o,n,!0),await this.syncIdentity({address:e,chainId:i,chainNamespace:n})}async syncReownName(e,s){try{const n=await this.getReownName(e);if(n[0]){const r=n[0];this.setProfileName(r.name,s)}else this.setProfileName(null,s)}catch{this.setProfileName(null,s)}}syncConnectedWalletInfo(e){var r;const s=z.getConnectorId(e),n=He.getProviderId(e);if(n===Lt.CONNECTOR_TYPE_ANNOUNCED||n===Lt.CONNECTOR_TYPE_INJECTED){if(s){const o=this.getConnectors().find(a=>{var u,h;const c=a.id===s,l=((u=a.info)==null?void 0:u.rdns)===s,d=(h=a.connectors)==null?void 0:h.some(p=>{var g;return p.id===s||((g=p.info)==null?void 0:g.rdns)===s});return c||l||!!d});if(o){const{info:a,name:c,imageUrl:l}=o,d=l||this.getConnectorImage(o);this.setConnectedWalletInfo({name:c,icon:d,...a},e)}}}else if(n===Lt.CONNECTOR_TYPE_WALLET_CONNECT){const i=He.getProvider(e);i!=null&&i.session&&this.setConnectedWalletInfo({...i.session.peer.metadata,name:i.session.peer.metadata.name,icon:(r=i.session.peer.metadata.icons)==null?void 0:r[0]},e)}else if(s&&(s===U.CONNECTOR_ID.COINBASE_SDK||s===U.CONNECTOR_ID.COINBASE)){const i=this.getConnectors().find(l=>l.id===s),o=(i==null?void 0:i.name)||"Coinbase Wallet",a=(i==null?void 0:i.imageUrl)||this.getConnectorImage(i),c=i==null?void 0:i.info;this.setConnectedWalletInfo({...c,name:o,icon:a},e)}}async syncBalance(e){!Nf.getNetworksByNamespace(this.getCaipNetworks(),e.chainNamespace).find(n=>{var r;return n.id.toString()===((r=e.chainId)==null?void 0:r.toString())})||!e.chainId||await this.updateNativeBalance(e.address,e.chainId,e.chainNamespace)}async ready(){await this.readyPromise}async updateNativeBalance(e,s,n){const r=this.getAdapter(n),i=E.getCaipNetworkByNamespace(n,s);if(r){const o=await r.getBalance({address:e,chainId:s,caipNetwork:i,tokens:this.options.tokens});return this.setBalance(o.balance,o.symbol,n),o}}async initializeUniversalAdapter(){var r,i,o,a,c,l,d,u,h,p;const e=dk.createLogger((g,...f)=>{g&&this.handleAlertError(g),console.error(...f)}),s={projectId:(r=this.options)==null?void 0:r.projectId,metadata:{name:(i=this.options)!=null&&i.metadata?(o=this.options)==null?void 0:o.metadata.name:"",description:(a=this.options)!=null&&a.metadata?(c=this.options)==null?void 0:c.metadata.description:"",url:(l=this.options)!=null&&l.metadata?(d=this.options)==null?void 0:d.metadata.url:"",icons:(u=this.options)!=null&&u.metadata?(h=this.options)==null?void 0:h.metadata.icons:[""]},logger:e};$.setManualWCControl(!!((p=this.options)!=null&&p.manualWCControl)),this.universalProvider=this.options.universalProvider??await Px.init(s);const n=this.universalProvider.disconnect.bind(this.universalProvider);this.universalProvider.disconnect=async()=>{try{return await n()}catch(g){if(g instanceof Error&&g.message.includes("Missing or invalid. Record was recently deleted"))return;throw g}},$.state.enableReconnect===!1&&this.universalProvider.session&&await this.universalProvider.disconnect(),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&this.chainNamespaces.forEach(e=>{Kn.listenWcProvider({universalProvider:this.universalProvider,namespace:e,onDisplayUri:s=>{G.setUri(s)},onConnect:s=>{const{address:n}=X.getAccount(s[0]);G.finalizeWcConnection(n)},onDisconnect:()=>{E.state.noAdapters&&this.resetAccount(e),G.resetWcConnection()},onChainChanged:s=>{const n=E.state.activeChain,r=n&&z.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(E.state.noAdapters||r)){const i=this.getCaipNetworks().find(a=>a.id.toString()===s.toString()||a.caipNetworkId.toString()===s.toString()),o=this.getCaipNetwork();if(!i){this.setUnsupportedNetwork(s);return}(o==null?void 0:o.id.toString())!==(i==null?void 0:i.id.toString())&&(o==null?void 0:o.chainNamespace)===(i==null?void 0:i.chainNamespace)&&this.setCaipNetwork(i)}},onAccountsChanged:s=>{const n=E.state.activeChain,r=n&&z.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(E.state.noAdapters||r)){const i=s==null?void 0:s[0];i&&this.syncAccount({address:i.address,chainId:i.chainId,chainNamespace:i.chainNamespace})}}})})}createUniversalProvider(){var e;return!this.universalProviderInitPromise&&X.isClient()&&((e=this.options)!=null&&e.projectId)&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){Ee.sendEvent({type:"error",event:"INTERNAL_SDK_ERROR",properties:{errorType:"UniversalProviderInitError",errorMessage:e instanceof Error?e.message:"Unknown",uncaught:!1}}),console.error("AppKit:getUniversalProvider - Cannot create provider",e)}return this.universalProvider}getDisabledCaipNetworks(){const e=E.getAllApprovedCaipNetworkIds(),s=E.getAllRequestedCaipNetworks();return X.sortRequestedNetworks(e,s).filter(r=>E.isCaipNetworkDisabled(r))}handleAlertError(e){const s=Object.entries(Pt.UniversalProviderErrors).find(([,{message:a}])=>e.message.includes(a)),[n,r]=s??[],{message:i,alertErrorKey:o}=r??{};if(n&&i&&!this.reportedAlertErrors[n]){const a=Pt.ALERT_ERRORS[o];a&&(Ot.open(a,"error"),this.reportedAlertErrors[n]=!0)}}getAdapter(e){var s;if(e)return(s=this.chainAdapters)==null?void 0:s[e]}createAdapter(e){var r,i;if(!e)return;const s=e.namespace;if(!s)return;this.createClients();const n=e;n.namespace=s,n.construct({namespace:s,projectId:(r=this.options)==null?void 0:r.projectId,networks:(i=this.caipNetworks)==null?void 0:i.filter(({chainNamespace:o})=>o===s)}),this.chainNamespaces.includes(s)||this.chainNamespaces.push(s),this.chainAdapters&&(this.chainAdapters[s]=n)}async open(e){await this.injectModalUi(),e!=null&&e.uri&&G.setUri(e.uri);const{isSwap:s,isSend:n}=this.toModalOptions();return s(e)?Ne.open({...e,data:{swap:e.arguments}}):n(e)&&e.arguments?this.openSend(e.arguments):Ne.open(e)}async close(){await this.injectModalUi(),Ne.close()}setLoading(e,s){Ne.setLoading(e,s)}async disconnect(e){await G.disconnect({namespace:e})}getSIWX(){return $.state.siwx}getError(){return""}getChainId(){var e;return(e=E.state.activeCaipNetwork)==null?void 0:e.id}async switchNetwork(e,{throwOnFailure:s=!1}={}){const n=this.getCaipNetworks().find(r=>r.id===e.id);if(!n){Ot.open(Pt.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await E.switchActiveNetwork(n,{throwOnFailure:s})}getWalletProvider(){return E.state.activeChain?He.state.providers[E.state.activeChain]:null}getWalletProviderType(){return He.getProviderId(E.state.activeChain)}subscribeProviders(e){return He.subscribeProviders(e)}getThemeMode(){return Kt.state.themeMode}getThemeVariables(){return Kt.state.themeVariables}setThemeMode(e){Kt.setThemeMode(e),vd(Kt.state.themeMode)}setTermsConditionsUrl(e){$.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){$.setPrivacyPolicyUrl(e)}setThemeVariables(e){Kt.setThemeVariables(e),Bk(Kt.state.themeVariables)}subscribeTheme(e){return Kt.subscribe(e)}subscribeConnections(e){return this.remoteFeatures.multiWallet?G.subscribe(e):(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),()=>{})}getWalletInfo(e){var n,r;if(e)return(r=(n=E.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.connectedWalletInfo;const s=E.getAccountData();return s==null?void 0:s.connectedWalletInfo}getAccount(e){const s=e||E.state.activeChain,n=z.getAuthConnector(s),r=E.getAccountData(s),i=F.getConnectedConnectorId(E.state.activeChain),o=G.getConnections(s);if(!s)throw new Error("AppKit:getAccount - namespace is required");const a=o.flatMap(c=>c.accounts.map(({address:l,type:d,publicKey:u})=>X.createAccount(s,l,d||"eoa",u)));if(r)return{allAccounts:a,caipAddress:r.caipAddress,address:X.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:n&&i===U.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:F.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:ls(s),isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,s){const n=()=>{const r=this.getAccount(s);r&&e(r)};s?E.subscribeChainProp("accountState",n,s):E.subscribe(n),z.subscribe(n)}subscribeNetwork(e){return E.subscribe(({activeCaipNetwork:s})=>{e({caipNetwork:s,chainId:s==null?void 0:s.id,caipNetworkId:s==null?void 0:s.caipNetworkId})})}subscribeWalletInfo(e,s){return s?E.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo),s):E.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo))}subscribeShouldUpdateToAddress(e){E.subscribeChainProp("accountState",s=>e(s==null?void 0:s.shouldUpdateToAddress))}subscribeCaipNetworkChange(e){E.subscribeKey("activeCaipNetwork",e)}getState(){return ds.state}getRemoteFeatures(){return $.state.remoteFeatures}subscribeState(e){return ds.subscribe(e)}subscribeRemoteFeatures(e){return $.subscribeKey("remoteFeatures",e)}showErrorMessage(e){Ks.showError(e)}showSuccessMessage(e){Ks.showSuccess(e)}getEvent(){return{...Ee.state}}subscribeEvents(e){return Ee.subscribe(e)}replace(e){ue.replace(e)}redirect(e){ue.push(e)}popTransactionStack(e){ue.popTransactionStack(e)}isOpen(){return Ne.state.open}isTransactionStackEmpty(){return ue.state.transactionStack.length===0}static getInstance(){return this.instance}updateFeatures(e){$.setFeatures(e)}updateRemoteFeatures(e){$.setRemoteFeatures(e)}updateOptions(e){const n={...$.state||{},...e};$.setOptions(n)}setConnectMethodsOrder(e){$.setConnectMethodsOrder(e)}setWalletFeaturesOrder(e){$.setWalletFeaturesOrder(e)}setCollapseWallets(e){$.setCollapseWallets(e)}setSocialsOrder(e){$.setSocialsOrder(e)}getConnectMethodsOrder(){return zn.getConnectOrderMethod($.state.features,z.getConnectors())}addNetwork(e,s){if(this.chainAdapters&&!this.chainAdapters[e])throw new Error(`Adapter for namespace ${e} doesn't exist`);const n=this.extendCaipNetwork(s,this.options);this.getCaipNetworks().find(r=>r.id===n.id)||E.addNetwork(n)}removeNetwork(e,s){if(this.chainAdapters&&!this.chainAdapters[e])throw new Error(`Adapter for namespace ${e} doesn't exist`);this.getCaipNetworks().find(r=>r.id===s)&&E.removeNetwork(e,s)}}let bf=!1;class by extends Vk{async onAuthProviderConnected(e){const s=wo.userChainIdToChainNamespace(e==null?void 0:e.chainId);if(e.message&&e.signature&&e.siwxMessage&&await vs.addEmbeddedWalletSession({chainId:e.siwxMessage.chainId,accountAddress:e.address,notBefore:e.siwxMessage.notBefore,statement:e.siwxMessage.statement,resources:e.siwxMessage.resources,requestId:e.siwxMessage.requestId,issuedAt:e.siwxMessage.issuedAt,domain:e.siwxMessage.domain,uri:e.siwxMessage.uri,version:e.siwxMessage.version,nonce:e.siwxMessage.nonce},e.message,e.signature),!s)throw new Error("AppKit:onAuthProviderConnected - namespace is required");const n=s===U.CHAIN.EVM?`eip155:${e.chainId}:${e.address}`:`${e.chainId}:${e.address}`,r=$.state.defaultAccountTypes[s],i=ls(s),o=e.preferredAccountType||i||r;this.setCaipAddress(n,s);const{signature:a,siwxMessage:c,message:l,...d}=e,u=E.getAccountData(s);this.setUser({...(u==null?void 0:u.user)||{},...d},s),this.setSmartAccountDeployed(!!e.smartAccountDeployed,s),this.setPreferredAccountType(o,s),await Promise.all([this.syncAuthConnectorTheme(this.authProvider),this.syncAccount({address:e.address,chainId:e.chainId,chainNamespace:s})]),this.setLoading(!1,s)}setupAuthConnectorListeners(e){e.onRpcRequest(s=>{cs.checkIfRequestExists(s)?cs.checkIfRequestIsSafe(s)||this.handleUnsafeRPCRequest():(this.open(),console.error(tt.RPC_METHOD_NOT_ALLOWED_MESSAGE,{method:s.method}),setTimeout(()=>{this.showErrorMessage(tt.RPC_METHOD_NOT_ALLOWED_UI_MESSAGE)},300),e.rejectRpcRequests())}),e.onRpcError(()=>{this.isOpen()&&(this.isTransactionStackEmpty()?this.close():this.popTransactionStack("error"))}),e.onRpcSuccess((s,n)=>{const r=cs.checkIfRequestIsSafe(n),i=this.getAddress(),o=E.state.activeCaipNetwork;r||(i&&(o!=null&&o.id)&&this.updateNativeBalance(i,o.id,o.chainNamespace),this.isTransactionStackEmpty()?this.close():this.popTransactionStack("success"))}),e.onNotConnected(()=>{const s=E.state.activeChain;if(!s)throw new Error("AppKit:onNotConnected - namespace is required");z.getConnectorId(s)===U.CONNECTOR_ID.AUTH&&(this.setCaipAddress(null,s),this.setLoading(!1,s))}),e.onConnect(this.onAuthProviderConnected.bind(this)),e.onSocialConnected(this.onAuthProviderConnected.bind(this)),e.onSetPreferredAccount(({address:s,type:n})=>{const r=E.state.activeChain;if(!r)throw new Error("AppKit:onSetPreferredAccount - namespace is required");s&&this.setPreferredAccountType(n,r)})}async syncAuthConnectorTheme(e){if(!e)return;const s=Kt.getSnapshot();await e.syncTheme({themeMode:s.themeMode,themeVariables:s.themeVariables,w3mThemeVariables:Zi(s.themeVariables,s.themeMode)})}async syncAuthConnector(e,s){var d,u,h,p,g,f,y,_,S;const n=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(s),r=s===E.state.activeChain;if(!n)return;this.setLoading(!0,s);const i=e.getLoginEmailUsed();this.setLoading(i,s),i&&this.setStatus("connecting",s);const o=e.getEmail(),a=e.getUsername(),c=((d=E.getAccountData(s))==null?void 0:d.user)||{};this.setUser({...c,username:a,email:o},s),this.setupAuthConnectorListeners(e);const{isConnected:l}=await e.isConnected();if(s&&n&&r)if(l&&((u=this.connectionControllerClient)!=null&&u.connectExternal)){await e.init(),await this.syncAuthConnectorTheme(e),await((g=this.connectionControllerClient)==null?void 0:g.connectExternal({id:U.CONNECTOR_ID.AUTH,info:{name:U.CONNECTOR_ID.AUTH},type:Lt.CONNECTOR_TYPE_AUTH,provider:e,chainId:(p=(h=E.getNetworkData(s))==null?void 0:h.caipNetwork)==null?void 0:p.id,chain:s})),this.setStatus("connected",s);const v=F.getConnectedSocialProvider();v?Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",address:this.getAddress(),properties:{provider:v,reconnect:!0}}):Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:this.getAddress(),properties:{method:"email",name:((S=(_=(y=(f=this.universalProvider)==null?void 0:f.session)==null?void 0:y.peer)==null?void 0:_.metadata)==null?void 0:S.name)||"Unknown",reconnect:!0,view:ue.state.view,walletRank:void 0}})}else z.getConnectorId(s)===U.CONNECTOR_ID.AUTH&&(this.setStatus("disconnected",s),F.removeConnectedNamespace(s));this.setLoading(!1,s)}async checkExistingTelegramSocialConnection(e){var s;try{if(!X.isTelegram())return;const n=F.getTelegramSocialProvider();if(!n||!X.isClient())return;const i=new URL(window.location.href).searchParams.get("result_uri");if(!i)return;n&&E.setAccountProp("socialProvider",n,e),await((s=this.authProvider)==null?void 0:s.init());const o=z.getAuthConnector();n&&o&&(this.setLoading(!0,e),await G.connectExternal({id:o.id,type:o.type,socialUri:i},o.chain),F.setConnectedSocialProvider(n),F.removeTelegramSocialProvider(),Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:n}}))}catch(n){this.setLoading(!1,e),console.error("checkExistingSTelegramocialConnection error",n)}try{const n=new URL(window.location.href);n.searchParams.delete("result_uri"),window.history.replaceState({},document.title,n.toString())}catch(n){console.error("tma social login failed",n)}}createAuthProvider(e){var l,d,u,h;if(!U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(e))return;const n=(l=this.remoteFeatures)==null?void 0:l.email,r=Array.isArray((d=this.remoteFeatures)==null?void 0:d.socials)&&this.remoteFeatures.socials.length>0,i=n||r,a=wo.getActiveNamespaceConnectedToAuth()||e;!this.authProvider&&((u=this.options)!=null&&u.projectId)&&i&&(this.authProvider=zi.getInstance({projectId:this.options.projectId,enableLogger:this.options.enableAuthLogger,chainId:(h=this.getCaipNetwork(a))==null?void 0:h.caipNetworkId,abortController:Pt.EmbeddedWalletAbortController,onTimeout:p=>{p==="iframe_load_failed"?Ot.open(Pt.ALERT_ERRORS.IFRAME_LOAD_FAILED,"error"):p==="iframe_request_timeout"?Ot.open(Pt.ALERT_ERRORS.IFRAME_REQUEST_TIMEOUT,"error"):p==="unverified_domain"&&Ot.open(Pt.ALERT_ERRORS.UNVERIFIED_DOMAIN,"error")},getActiveCaipNetwork:p=>ki(p),getCaipNetworks:p=>E.getCaipNetworks(p)}),ds.subscribeOpen(p=>{var g;!p&&this.isTransactionStackEmpty()&&((g=this.authProvider)==null||g.rejectRpcRequests())}));const c=e===E.state.activeChain&&$.state.enableReconnect;$.state.enableReconnect===!1?this.syncAuthConnectorTheme(this.authProvider):this.authProvider&&c&&(this.syncAuthConnector(this.authProvider,e),this.checkExistingTelegramSocialConnection(e))}createAuthProviderForAdapter(e){var s,n,r;this.createAuthProvider(e),this.authProvider&&((r=(n=(s=this.chainAdapters)==null?void 0:s[e])==null?void 0:n.setAuthProvider)==null||r.call(n,this.authProvider))}initControllers(e){super.initControllers(e),this.options.excludeWalletIds&&te.initializeExcludedWallets({ids:this.options.excludeWalletIds})}async switchCaipNetwork(e){var o,a,c;if(!e)return;const s=E.state.activeChain,n=e.chainNamespace,r=this.getAddressByChainNamespace(n);if(n===s&&((o=E.getAccountData(n))!=null&&o.caipAddress)){const l=this.getAdapter(n);await(l==null?void 0:l.switchNetwork({caipNetwork:e})),this.setCaipNetwork(e)}else{const d=He.getProviderId(s)===Lt.CONNECTOR_TYPE_AUTH,u=He.getProviderId(n),h=u===Lt.CONNECTOR_TYPE_AUTH,p=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(n);if(!n)throw new Error("AppKit:switchCaipNetwork - networkNamespace is required");if((d&&u===void 0||h)&&p)try{if(E.state.activeChain=e.chainNamespace,r){const g=this.getAdapter(n);await(g==null?void 0:g.switchNetwork({caipNetwork:e}))}else await((c=(a=this.connectionControllerClient)==null?void 0:a.connectExternal)==null?void 0:c.call(a,{id:U.CONNECTOR_ID.AUTH,provider:this.authProvider,chain:n,chainId:e.id,type:Lt.CONNECTOR_TYPE_AUTH,caipNetwork:e}));this.setCaipNetwork(e)}catch{const f=this.getAdapter(n);await(f==null?void 0:f.switchNetwork({caipNetwork:e}))}else if(u===Lt.CONNECTOR_TYPE_WALLET_CONNECT){if(!E.state.noAdapters){const g=this.getAdapter(n);await(g==null?void 0:g.switchNetwork({caipNetwork:e}))}this.setCaipNetwork(e),this.syncWalletConnectAccount()}else this.setCaipNetwork(e),r&&this.syncAccount({address:r,chainId:e.id,chainNamespace:n})}}async initialize(e){var s;await super.initialize(e),(s=this.chainNamespaces)==null||s.forEach(n=>{this.createAuthProviderForAdapter(n)}),await this.injectModalUi(),ds.set({initialized:!0})}async syncIdentity({address:e,chainId:s,chainNamespace:n}){var a;const r=`${n}:${s}`,i=(a=this.caipNetworks)==null?void 0:a.find(c=>c.caipNetworkId===r);if(i!=null&&i.testnet){this.setProfileName(null,n),this.setProfileImage(null,n);return}const o=z.getConnectorId(n)===U.CONNECTOR_ID.AUTH;try{const{name:c,avatar:l}=await this.fetchIdentity({address:e});!c&&o?await this.syncReownName(e,n):(this.setProfileName(c,n),this.setProfileImage(l,n))}catch{s!==1&&this.setProfileImage(null,n)}}syncConnectedWalletInfo(e){const s=He.getProviderId(e);if(s===Lt.CONNECTOR_TYPE_AUTH){const n=this.authProvider;if(n){const r=F.getConnectedSocialProvider()??"email",i=n.getEmail()??n.getUsername();this.setConnectedWalletInfo({name:s,identifier:i,social:r},e)}}else super.syncConnectedWalletInfo(e)}async injectModalUi(){if(X.isClient()&&!bf)try{const e={...Ie.DEFAULT_FEATURES,...this.options.features},s=this.remoteFeatures;if(await this.loadModalComponents(e,s),X.isClient()&&!document.querySelector("w3m-modal")){const r=document.createElement("w3m-modal");!$.state.disableAppend&&!$.state.enableEmbedded&&document.body.insertAdjacentElement("beforeend",r)}bf=!0}catch(e){console.error("Error injecting modal UI:",e)}}async loadModalComponents(e,s){if(!X.isClient())return;const n=[];(s.email||s.socials&&s.socials.length>0)&&n.push(Dt(()=>import("./embedded-wallet-BRmiIOUa.js"),__vite__mapDeps([7,8,3,4,9,10,2,11,12,13,14,15,16,17,18,19,20]))),s.email&&n.push(Dt(()=>import("./email-CV99yGtH.js"),__vite__mapDeps([21,8,3,4,22,19,12,18,10,11,17,23,15,2]))),s.socials&&n.push(Dt(()=>import("./socials-QLyEk6zh.js"),__vite__mapDeps([24,8,3,4,10,25,11,26,2,18,27,14,17,12,28,9,29]))),s.swaps&&s.swaps.length>0&&n.push(Dt(()=>import("./swaps-DLZEIO9U.js"),__vite__mapDeps([30,8,3,4,17,12,18,10,31,32,33,2,29,34,9,15,11]))),e.send&&n.push(Dt(()=>import("./send-CudJE3ga.js"),__vite__mapDeps([35,8,3,4,17,12,18,10,36,11,37,19,34,9,29,33,2,15,38,39]))),e.receive&&n.push(Dt(()=>import("./receive-CADcxERz.js"),__vite__mapDeps([40,8,3,4,10,9,28,2]))),s.onramp&&s.onramp.length>0&&n.push(Dt(()=>import("./onramp-CWeX_eyk.js"),__vite__mapDeps([41,8,3,4,10,42,12,25,11,9,43,44,19,17,18,27,15,2]))),s.payWithExchange&&n.push(Dt(()=>import("./pay-with-exchange-Cc8oS6gA.js"),__vite__mapDeps([45,8,3,4,10,9,16,42,12,29,17,37,11,19,46,18,15,38,36,2]))),s.activity&&n.push(Dt(()=>import("./transactions-of0GeMXR.js"),__vite__mapDeps([47,8,3,4,48,18,10,19,9,29,2]))),(e.pay||s.payments)&&n.push(Dt(()=>import("./index-8wkY0Jb7.js"),__vite__mapDeps([49,8,3,4,10,17,12,50,16,9,42,51,36,52,18,2,27]))),s.emailCapture&&n.push(Dt(()=>import("./data-capture-DPJniIza.js"),__vite__mapDeps([53,8,3,4,22,19,12,6,2]))),await Promise.all([...n,Dt(()=>import("./index-ijwspMD9.js"),__vite__mapDeps([54,8,3,4,10,9,12,39,18,55,44,19,13,14,2,52,16,42,17,46,48,29,38,31,32,36,11,15,51,23,25,26,27,28,20,43])),Dt(()=>import("./w3m-modal-DP8Arf0z.js"),__vite__mapDeps([56,8,3,4,10,50,9,13,14,2,12,18,32,55,44,19,52,33,17]))])}}const Kk="1.8.15";function Gk(t){return new by({...t,sdkVersion:X.generateSdkVersion(t.adapters??[],"html",Kk)})}const B2=Object.freeze(Object.defineProperty({__proto__:null,AppKit:by,CoreHelperUtil:X,WcConstantsUtil:Li,createAppKit:Gk},Symbol.toStringTag,{value:"Module"}));export{Hi as $,yt as A,fe as B,E as C,U2 as D,Ee as E,Qi as F,F as G,cs as H,ae as I,le as J,Lt as K,te as L,Ne as M,iw as N,$ as O,Ev as P,Pt as Q,ue as R,Ks as S,Kt as T,dt as U,He as V,tt as W,lw as X,Zi as Y,lt as Z,_e as _,X as a,Ul as a0,bs as a1,Tr as a2,mn as a3,vs as a4,D2 as a5,Zf as a6,pa as a7,fy as a8,Ed as a9,hi as aa,Hf as ab,vv as ac,bv as ad,zf as ae,Wu as af,Tv as ag,Vo as ah,Ov as ai,Sv as aj,xs as ak,$a as al,wo as am,zn as an,Gr as ao,sC as ap,ki as aq,B2 as ar,N2 as b,I2 as c,Ie as d,Yf as e,R2 as f,T2 as g,O2 as h,_t as i,$2 as j,M2 as k,va as l,k2 as m,Wn as n,G as o,Ge as p,ls as q,L2 as r,At as s,eC as t,Ot as u,Mk as v,As as w,Rd as x,z as y,Kf as z};
|
|
248
|
+
`;function jk(t){if(t.length>=255)throw new TypeError("Alphabet too long");const e=new Uint8Array(256);for(let l=0;l<e.length;l++)e[l]=255;for(let l=0;l<t.length;l++){const d=t.charAt(l),u=d.charCodeAt(0);if(e[u]!==255)throw new TypeError(d+" is ambiguous");e[u]=l}const s=t.length,n=t.charAt(0),r=Math.log(s)/Math.log(256),i=Math.log(256)/Math.log(s);function o(l){if(l instanceof Uint8Array||(ArrayBuffer.isView(l)?l=new Uint8Array(l.buffer,l.byteOffset,l.byteLength):Array.isArray(l)&&(l=Uint8Array.from(l))),!(l instanceof Uint8Array))throw new TypeError("Expected Uint8Array");if(l.length===0)return"";let d=0,u=0,h=0;const p=l.length;for(;h!==p&&l[h]===0;)h++,d++;const g=(p-h)*i+1>>>0,f=new Uint8Array(g);for(;h!==p;){let S=l[h],v=0;for(let C=g-1;(S!==0||v<u)&&C!==-1;C--,v++)S+=256*f[C]>>>0,f[C]=S%s>>>0,S=S/s>>>0;if(S!==0)throw new Error("Non-zero carry");u=v,h++}let y=g-u;for(;y!==g&&f[y]===0;)y++;let _=n.repeat(d);for(;y<g;++y)_+=t.charAt(f[y]);return _}function a(l){if(typeof l!="string")throw new TypeError("Expected String");if(l.length===0)return new Uint8Array;let d=0,u=0,h=0;for(;l[d]===n;)u++,d++;const p=(l.length-d)*r+1>>>0,g=new Uint8Array(p);for(;d<l.length;){const S=l.charCodeAt(d);if(S>255)return;let v=e[S];if(v===255)return;let C=0;for(let R=p-1;(v!==0||C<h)&&R!==-1;R--,C++)v+=s*g[R]>>>0,g[R]=v%256>>>0,v=v/256>>>0;if(v!==0)throw new Error("Non-zero carry");h=C,d++}let f=p-h;for(;f!==p&&g[f]===0;)f++;const y=new Uint8Array(u+(p-f));let _=u;for(;f!==p;)y[_++]=g[f++];return y}function c(l){const d=a(l);if(d)return d;throw new Error("Non-base"+s+" character")}return{encode:o,decodeUnsafe:a,decode:c}}var Fk="123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";const qk=jk(Fk),Li={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603};class Wk extends jx{async setUniversalProvider(e){if(!this.namespace)throw new Error("UniversalAdapter:setUniversalProvider - namespace is required");return this.addConnector(new Fx({provider:e,caipNetworks:this.getCaipNetworks(),namespace:this.namespace})),Promise.resolve()}async connect(e){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:Number(e.chainId),provider:this.provider,address:""})}async disconnect(){try{await this.getWalletConnectConnector().disconnect(),this.emit("disconnect")}catch(e){console.warn("UniversalAdapter:disconnect - error",e)}return{connections:[]}}syncConnections(){return Promise.resolve()}async getAccounts({namespace:e}){var r,i,o,a;const s=this.provider,n=((a=(o=(i=(r=s==null?void 0:s.session)==null?void 0:r.namespaces)==null?void 0:i[e])==null?void 0:o.accounts)==null?void 0:a.map(c=>{const[,,l]=c.split(":");return l}).filter((c,l,d)=>d.indexOf(c)===l))||[];return Promise.resolve({accounts:n.map(c=>X.createAccount(e,c,e==="bip122"?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){var o,a,c,l,d;if(!(e.caipNetwork&&Ie.BALANCE_SUPPORTED_CHAINS.includes((o=e.caipNetwork)==null?void 0:o.chainNamespace))||(a=e.caipNetwork)!=null&&a.testnet)return{balance:"0.00",symbol:((c=e.caipNetwork)==null?void 0:c.nativeCurrency.symbol)||""};const n=E.getAccountData();if(n!=null&&n.balanceLoading&&e.chainId===((l=E.state.activeCaipNetwork)==null?void 0:l.id))return{balance:(n==null?void 0:n.balance)||"0.00",symbol:(n==null?void 0:n.balanceSymbol)||""};const i=(await E.fetchTokenBalance()).find(u=>{var h,p;return u.chainId===`${(h=e.caipNetwork)==null?void 0:h.chainNamespace}:${e.chainId}`&&u.symbol===((p=e.caipNetwork)==null?void 0:p.nativeCurrency.symbol)});return{balance:(i==null?void 0:i.quantity.numeric)||"0.00",symbol:(i==null?void 0:i.symbol)||((d=e.caipNetwork)==null?void 0:d.nativeCurrency.symbol)||""}}async signMessage(e){var o,a,c;const{provider:s,message:n,address:r}=e;if(!s)throw new Error("UniversalAdapter:signMessage - provider is undefined");let i="";return((o=E.state.activeCaipNetwork)==null?void 0:o.chainNamespace)===U.CHAIN.SOLANA?i=(await s.request({method:"solana_signMessage",params:{message:qk.encode(new TextEncoder().encode(n)),pubkey:r}},(a=E.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)).signature:i=await s.request({method:"personal_sign",params:[n,r]},(c=E.state.activeCaipNetwork)==null?void 0:c.caipNetworkId),{signature:i}}async estimateGas(){return Promise.resolve({gas:BigInt(0)})}async sendTransaction(){return Promise.resolve({hash:""})}walletGetAssets(e){return Promise.resolve({})}async writeContract(){return Promise.resolve({hash:""})}emitFirstAvailableConnection(){}parseUnits(){return 0n}formatUnits(){return"0"}async getCapabilities(){return Promise.resolve({})}async grantPermissions(){return Promise.resolve({})}async revokePermissions(){return Promise.resolve("0x")}async syncConnection(){return Promise.resolve({id:"WALLET_CONNECT",type:"WALLET_CONNECT",chainId:1,provider:this.provider,address:""})}async switchNetwork(e){var r,i,o,a,c,l;const{caipNetwork:s}=e,n=this.getWalletConnectConnector();if(s.chainNamespace===U.CHAIN.EVM)try{await((r=n.provider)==null?void 0:r.request({method:"wallet_switchEthereumChain",params:[{chainId:Tu(s.id)}]}))}catch(d){if(d.code===Li.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||d.code===Li.ERROR_INVALID_CHAIN_ID||d.code===Li.ERROR_CODE_DEFAULT||((o=(i=d==null?void 0:d.data)==null?void 0:i.originalError)==null?void 0:o.code)===Li.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await((l=n.provider)==null?void 0:l.request({method:"wallet_addEthereumChain",params:[{chainId:Tu(s.id),rpcUrls:[(a=s==null?void 0:s.rpcUrls.chainDefault)==null?void 0:a.http],chainName:s.name,nativeCurrency:s.nativeCurrency,blockExplorerUrls:[(c=s.blockExplorers)==null?void 0:c.default.url]}]}))}catch{throw new Error("Chain is not supported")}}n.provider.setDefaultChain(s.caipNetworkId)}getWalletConnectProvider(){const e=this.connectors.find(n=>n.type==="WALLET_CONNECT");return e==null?void 0:e.provider}}const Hk=["email","socials","swaps","onramp","activity","reownBranding","multiWallet","emailCapture","payWithExchange","payments","reownAuthentication","headless"],ca={email:{apiFeatureName:"social_login",localFeatureName:"email",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return!!t.isEnabled&&e.includes("email")},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.email:!!t},socials:{apiFeatureName:"social_login",localFeatureName:"socials",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e.filter(s=>s!=="email"):!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.socials:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.socials:!1:t},swaps:{apiFeatureName:"swap",localFeatureName:"swaps",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e:!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.swaps:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.swaps:!1:t},onramp:{apiFeatureName:"onramp",localFeatureName:"onramp",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>{if(!(t!=null&&t.config))return!1;const e=t.config;return t.isEnabled&&e.length>0?e:!1},processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.onramp:typeof t=="boolean"?t?Ie.DEFAULT_REMOTE_FEATURES.onramp:!1:t},activity:{apiFeatureName:"activity",localFeatureName:"history",returnType:!1,isLegacy:!0,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.activity:!!t},reownBranding:{apiFeatureName:"reown_branding",localFeatureName:"reownBranding",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>t===void 0?Ie.DEFAULT_REMOTE_FEATURES.reownBranding:!!t},emailCapture:{apiFeatureName:"email_capture",localFeatureName:"emailCapture",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>t.isEnabled&&(t.config??[]),processFallback:t=>!1},multiWallet:{apiFeatureName:"multi_wallet",localFeatureName:"multiWallet",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.multiWallet},payWithExchange:{apiFeatureName:"fund_from_exchange",localFeatureName:"payWithExchange",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.payWithExchange},payments:{apiFeatureName:"payments",localFeatureName:"payments",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.payments},reownAuthentication:{apiFeatureName:"reown_authentication",localFeatureName:"reownAuthentication",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:t=>typeof t>"u"?Ie.DEFAULT_REMOTE_FEATURES.reownAuthentication:!!t},headless:{apiFeatureName:"headless",localFeatureName:"headless",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>Ie.DEFAULT_REMOTE_FEATURES.headless}},zk={localSettingsOverridden:new Set,getApiConfig(t,e){return e==null?void 0:e.find(s=>s.id===t)},addWarning(t,e){if(t!==void 0){const s=ca[e],n=s.isLegacy?`"features.${s.localFeatureName}" (now "${e}")`:`"features.${e}"`;this.localSettingsOverridden.add(n)}},processFeature(t,e,s,n,r){const i=ca[t],o=e[i.localFeatureName];if(r&&!i.isAvailableOnBasic)return!1;if(n){const a=this.getApiConfig(i.apiFeatureName,s);return(a==null?void 0:a.config)===null?this.processFallbackFeature(t,o):a!=null&&a.config?(o!==void 0&&this.addWarning(o,t),this.processApiFeature(t,a)):!1}return this.processFallbackFeature(t,o)},processApiFeature(t,e){return ca[t].processApi(e)},processFallbackFeature(t,e){return ca[t].processFallback(e)},async fetchRemoteFeatures(t){const e=t.basic??!1,s=t.features||{};this.localSettingsOverridden.clear();let n=null,r=!1;try{n=await te.fetchProjectConfig(),r=n!=null}catch(o){console.warn("[Reown Config] Failed to fetch remote project configuration. Using local/default values.",o)}const i=r&&!e?Ie.DEFAULT_REMOTE_FEATURES:Ie.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(const o of Hk){const a=this.processFeature(o,s,n,r,e);Object.assign(i,{[o]:a})}}catch(o){return console.warn("[Reown Config] Failed to process the configuration from Cloud. Using default values.",o),Ie.DEFAULT_REMOTE_FEATURES}if(r&&this.localSettingsOverridden.size>0){const o=`Your local configuration for ${Array.from(this.localSettingsOverridden).join(", ")} was ignored because a remote configuration was successfully fetched. Please manage these features via your project dashboard on dashboard.reown.com.`;Ot.open({debugMessage:Pt.ALERT_WARNINGS.LOCAL_CONFIGURATION_IGNORED.debugMessage(o)},"warning")}return i}};class Vk{constructor(e){this.chainNamespaces=[],this.features={},this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(s,n)=>{var r,i,o;if(s){const a=(r=E.getCaipNetworks(s))==null?void 0:r.find(d=>d.id===n);if(a)return a;const c=(i=E.getNetworkData(s))==null?void 0:i.caipNetwork;return c||((o=E.getRequestedCaipNetworks(s).filter(d=>d.chainNamespace===s))==null?void 0:o[0])}return E.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{const s=this.getCaipNetwork();if(s)return s.id},this.getCaipNetworks=s=>E.getCaipNetworks(s),this.getActiveChainNamespace=()=>E.state.activeChain,this.setRequestedCaipNetworks=(s,n)=>{E.setRequestedCaipNetworks(s,n)},this.getApprovedCaipNetworkIds=()=>E.getAllApprovedCaipNetworkIds(),this.getCaipAddress=s=>{var n,r;return E.state.activeChain===s||!s?E.state.activeCaipAddress:(r=(n=E.state.chains.get(s))==null?void 0:n.accountState)==null?void 0:r.caipAddress},this.setClientId=s=>{fe.setClientId(s)},this.getProvider=s=>He.getProvider(s),this.getProviderType=s=>He.getProviderId(s),this.getPreferredAccountType=s=>ls(s),this.setCaipAddress=(s,n,r=!1)=>{E.setAccountProp("caipAddress",s,n,r),E.setAccountProp("address",X.getPlainAddress(s),n,r)},this.setBalance=(s,n,r)=>{E.setAccountProp("balance",s,r),E.setAccountProp("balanceSymbol",n,r)},this.setProfileName=(s,n)=>{E.setAccountProp("profileName",s,n)},this.setProfileImage=(s,n)=>{E.setAccountProp("profileImage",s,n)},this.setUser=(s,n)=>{E.setAccountProp("user",s,n)},this.resetAccount=s=>{E.resetAccount(s)},this.setCaipNetwork=s=>{E.setActiveCaipNetwork(s)},this.setCaipNetworkOfNamespace=(s,n)=>{E.setChainNetworkData(n,{caipNetwork:s})},this.setStatus=(s,n)=>{E.setAccountProp("status",s,n),z.isConnected()?F.setConnectionStatus("connected"):F.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=s=>{var n;return(n=E.getAccountData(s))==null?void 0:n.address},this.setConnectors=s=>{const n=[...z.state.allConnectors,...s];z.setConnectors(n)},this.setConnections=(s,n)=>{F.setConnections(s,n),G.setConnections(s,n)},this.fetchIdentity=s=>fe.fetchIdentity(s),this.getReownName=s=>Hi.getNamesForAddress(s),this.getConnectors=()=>z.getConnectors(),this.getConnectorImage=s=>Kf.getConnectorImage(s),this.getConnections=s=>this.remoteFeatures.multiWallet?$a.getConnectionsData(s).connections:(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.getRecentConnections=s=>this.remoteFeatures.multiWallet?$a.getConnectionsData(s).recentConnections:(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.switchConnection=async s=>{if(!this.remoteFeatures.multiWallet){Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}await G.switchConnection(s)},this.deleteConnection=s=>{if(!this.remoteFeatures.multiWallet){Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}F.deleteAddressFromConnection(s),G.syncStorageConnections()},this.setConnectedWalletInfo=(s,n)=>{const r=He.getProviderId(n),i=s?{...s,type:r}:void 0;E.setAccountProp("connectedWalletInfo",i,n)},this.getIsConnectedState=()=>!!E.state.activeCaipAddress,this.addAddressLabel=(s,n,r)=>{var o;const i=((o=E.getAccountData(r))==null?void 0:o.addressLabels)||{};E.setAccountProp("addressLabels",{...i,[s]:n},r)},this.removeAddressLabel=(s,n)=>{var i;const r=((i=E.getAccountData(n))==null?void 0:i.addressLabels)||{};E.setAccountProp("addressLabels",{...r,[s]:void 0},n)},this.getAddress=s=>{var r;const n=s||E.state.activeChain;return(r=E.getAccountData(n))==null?void 0:r.address},this.resetNetwork=s=>{E.resetNetwork(s)},this.addConnector=s=>{z.addConnector(s)},this.resetWcConnection=()=>{G.resetWcConnection()},this.setAddressExplorerUrl=(s,n)=>{E.setAccountProp("addressExplorerUrl",s,n)},this.setSmartAccountDeployed=(s,n)=>{E.setAccountProp("smartAccountDeployed",s,n)},this.setPreferredAccountType=(s,n)=>{E.setAccountProp("preferredAccountType",s,n)},this.setEIP6963Enabled=s=>{$.setEIP6963Enabled(s)},this.handleUnsafeRPCRequest=()=>{if(this.isOpen()){if(this.isTransactionStackEmpty())return;this.redirect("ApproveTransaction")}else this.open({view:"ApproveTransaction"})},this.options=e,this.version=e.sdkVersion,this.caipNetworks=this.extendCaipNetworks(e),this.chainNamespaces=this.getChainNamespacesSet(e.adapters,this.caipNetworks),this.defaultCaipNetwork=this.extendDefaultCaipNetwork(e),this.chainAdapters=this.createAdapters(e.adapters),this.readyPromise=this.initialize(e)}getChainNamespacesSet(e,s){const n=e==null?void 0:e.map(i=>i.namespace).filter(i=>!!i);if(n!=null&&n.length)return[...new Set(n)];const r=s==null?void 0:s.map(i=>i.chainNamespace);return[...new Set(r)]}async initialize(e){var s,n,r,i,o,a;if(this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),(s=e.features)!=null&&s.headless&&!xs.hasInjectedConnectors()&&te.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1,fetchRecommendedWallets:!0}),$.state.enableReconnect?(await this.syncExistingConnection(),await this.syncAdapterConnections()):await this.unSyncExistingConnection(),!e.basic&&!e.manualWCControl&&(this.remoteFeatures=await zk.fetchRemoteFeatures(e)),await te.fetchUsage(),$.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&Ul.setOnrampProviders(this.remoteFeatures.onramp),((n=$.state.remoteFeatures)!=null&&n.email||Array.isArray((r=$.state.remoteFeatures)==null?void 0:r.socials)&&((i=$.state.remoteFeatures)==null?void 0:i.socials.length)>0)&&await this.checkAllowedOrigins(),(o=$.state.features)!=null&&o.reownAuthentication||(a=$.state.remoteFeatures)!=null&&a.reownAuthentication){const{ReownAuthentication:c}=await Dt(async()=>{const{ReownAuthentication:d}=await import("./features-BbA7J1KA.js");return{ReownAuthentication:d}},__vite__mapDeps([6,2,3,4])),l=$.state.siwx;l instanceof c||(l&&console.warn("ReownAuthentication option is enabled, SIWX configuration will be overridden."),$.setSIWX(new c))}}async openSend(e){var i;const s=e.namespace||E.state.activeChain,n=this.getCaipAddress(s),r=(i=this.getCaipNetwork(s))==null?void 0:i.id;if(!n)throw new Error("openSend: caipAddress not found");if((r==null?void 0:r.toString())!==e.chainId.toString()){const o=E.getCaipNetworkById(e.chainId,s);if(!o)throw new Error(`openSend: caipNetwork with chainId ${e.chainId} not found`);await this.switchNetwork(o,{throwOnFailure:!0})}try{const o=hy.getTokenSymbolByAddress(e.assetAddress);o&&await te.fetchTokenImages([o])}catch{}return await Ne.open({view:"WalletSend",data:{send:e}}),new Promise((o,a)=>{const c=_e.subscribeKey("hash",u=>{u&&(d(),o({hash:u}))}),l=Ne.subscribe(u=>{u.open||(d(),a(new Error("Modal closed")))}),d=this.createCleanupHandler([c,l])})}toModalOptions(){function e(n){return(n==null?void 0:n.view)==="Swap"}function s(n){return(n==null?void 0:n.view)==="WalletSend"}return{isSwap:e,isSend:s}}async checkAllowedOrigins(){try{const e=await te.fetchAllowedOrigins();if(!X.isClient())return;const s=window.location.origin;Kn.isOriginAllowed(s,e,U.DEFAULT_ALLOWED_ANCESTORS)||Ot.open(Pt.ALERT_ERRORS.ORIGIN_NOT_ALLOWED,"error")}catch(e){if(!(e instanceof Error))return;switch(e.message){case"RATE_LIMITED":Ot.open(Pt.ALERT_ERRORS.RATE_LIMITED_APP_CONFIGURATION,"error");break;case"SERVER_ERROR":{const s=e.cause instanceof Error?e.cause:e;Ot.open({displayMessage:Pt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.displayMessage,debugMessage:Pt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.debugMessage(s.message)},"error");break}}}}createCleanupHandler(e){return()=>{e.forEach(s=>{try{s()}catch{}})}}sendInitializeEvent(e){var n;const{...s}=e;delete s.adapters,delete s.universalProvider,Ee.sendEvent({type:"track",event:"INITIALIZE",properties:{...s,networks:e.networks.map(r=>r.id),siweConfig:{options:((n=e.siweConfig)==null?void 0:n.options)||{}}}})}initControllers(e){this.initializeOptionsController(e),this.initializeChainController(e),this.initializeThemeController(e),this.initializeConnectionController(e),this.initializeConnectorController()}initAdapterController(){Zf.initialize(this.chainAdapters)}initializeThemeController(e){e.themeMode&&Kt.setThemeMode(e.themeMode),e.themeVariables&&Kt.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient)throw new Error("ConnectionControllerClient must be set");E.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient});const s=this.getDefaultNetwork();s&&E.setActiveCaipNetwork(s)}initializeConnectionController(e){G.initialize(e.adapters??[]),G.setWcBasic(e.basic??!1)}initializeConnectorController(){z.initialize(this.chainNamespaces)}initializeProjectSettings(e){$.setProjectId(e.projectId),$.setSdkVersion(e.sdkVersion)}initializeOptionsController(e){var r;$.setDebug(e.debug!==!1),$.setEnableWalletGuide(e.enableWalletGuide!==!1),$.setEnableWallets(e.enableWallets!==!1),$.setEIP6963Enabled(e.enableEIP6963!==!1),$.setEnableNetworkSwitch(e.enableNetworkSwitch!==!1),$.setEnableReconnect(e.enableReconnect!==!1),$.setEnableMobileFullScreen(e.enableMobileFullScreen===!0),$.setCoinbasePreference(e.coinbasePreference),$.setEnableAuthLogger(e.enableAuthLogger!==!1),$.setCustomRpcUrls(e.customRpcUrls),$.setEnableEmbedded(e.enableEmbedded),$.setAllWallets(e.allWallets),$.setIncludeWalletIds(e.includeWalletIds),$.setExcludeWalletIds(e.excludeWalletIds),$.setFeaturedWalletIds(e.featuredWalletIds),$.setTokens(e.tokens),$.setTermsConditionsUrl(e.termsConditionsUrl),$.setPrivacyPolicyUrl(e.privacyPolicyUrl),$.setCustomWallets(e.customWallets),$.setFeatures(e.features),$.setAllowUnsupportedChain(e.allowUnsupportedChain),$.setUniversalProviderConfigOverride(e.universalProviderConfigOverride),$.setPreferUniversalLinks(e.experimental_preferUniversalLinks),$.setDefaultAccountTypes(e.defaultAccountTypes);const s=this.getDefaultMetaData();if(!e.metadata&&s&&(e.metadata=s),$.setMetadata(e.metadata),$.setDisableAppend(e.disableAppend),$.setEnableEmbedded(e.enableEmbedded),$.setSIWX(e.siwx),this.features=$.state.features??{},!e.projectId){Ot.open(Pt.ALERT_ERRORS.PROJECT_ID_NOT_CONFIGURED,"error");return}if(((r=e.adapters)==null?void 0:r.find(i=>i.namespace===U.CHAIN.EVM))&&e.siweConfig){if(e.siwx)throw new Error("Cannot set both `siweConfig` and `siwx` options");$.setSIWX(e.siweConfig.mapToSIWX())}}getDefaultMetaData(){var e,s,n,r;return X.isClient()?{name:((s=(e=document.getElementsByTagName("title"))==null?void 0:e[0])==null?void 0:s.textContent)||"",description:((n=document.querySelector('meta[property="og:description"]'))==null?void 0:n.content)||"",url:window.location.origin,icons:[((r=document.querySelector('link[rel~="icon"]'))==null?void 0:r.href)||""]}:null}setUnsupportedNetwork(e){const s=this.getActiveChainNamespace();if(s){const n=Gr.getUnsupportedNetwork(`${s}:${e}`);E.setActiveCaipNetwork(n)}}getDefaultNetwork(){return Gr.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,s){return Gr.extendCaipNetwork(e,{customNetworkImageUrls:s.chainImages,projectId:s.projectId})}extendCaipNetworks(e){return Gr.extendCaipNetworks(e.networks,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId})}extendDefaultCaipNetwork(e){const s=e.networks.find(r=>{var i;return r.id===((i=e.defaultNetwork)==null?void 0:i.id)});return s?Gr.extendCaipNetwork(s,{customNetworkImageUrls:e.chainImages,customRpcUrls:e.customRpcUrls,projectId:e.projectId}):void 0}async disconnectConnector(e,s){var n,r;try{this.setLoading(!0,e);let i={connections:[]};const o=this.getAdapter(e);return(((r=(n=E.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.caipAddress)||!$.state.enableReconnect)&&(o!=null&&o.disconnect)&&(i=await o.disconnect({id:s})),this.setLoading(!1,e),i}catch(i){throw this.setLoading(!1,e),new Error(`Failed to disconnect chains: ${i.message}`)}}createClients(){this.connectionControllerClient={connectWalletConnect:async()=>{var l;const e=E.state.activeChain,s=this.getAdapter(e),n=(l=this.getCaipNetwork(e))==null?void 0:l.id,r=G.getConnections(e),i=this.remoteFeatures.multiWallet,o=r.length>0;if(!s)throw new Error("Adapter not found");const a=await s.connectWalletConnect(n);(!o||!i)&&this.close(),this.setClientId((a==null?void 0:a.clientId)||null),F.setConnectedNamespaces([...E.state.chains.keys()]),await this.syncWalletConnectAccount(),await vs.initializeIfEnabled()},connectExternal:async e=>{const s=await this.onConnectExternal(e);return await this.connectInactiveNamespaces(e,s),s?{address:s.address}:void 0},reconnectExternal:async({id:e,info:s,type:n,provider:r})=>{var a;const i=E.state.activeChain,o=this.getAdapter(i);if(!i)throw new Error("reconnectExternal: namespace not found");if(!o)throw new Error("reconnectExternal: adapter not found");o!=null&&o.reconnect&&(await(o==null?void 0:o.reconnect({id:e,info:s,type:n,provider:r,chainId:(a=this.getCaipNetwork())==null?void 0:a.id})),F.addConnectedNamespace(i),this.syncConnectedWalletInfo(i))},disconnectConnector:async e=>{await this.disconnectConnector(e.namespace,e.id)},disconnect:async e=>{var l;const{id:s,chainNamespace:n,initialDisconnect:r}=e||{},i=n||E.state.activeChain,o=z.getConnectorId(i),a=s===U.CONNECTOR_ID.AUTH||o===U.CONNECTOR_ID.AUTH,c=s===U.CONNECTOR_ID.WALLET_CONNECT||o===U.CONNECTOR_ID.WALLET_CONNECT;try{const d=Array.from(E.state.chains.keys());let u=n?[n]:d;(c||a)&&(u=d);const h=u.map(async f=>{const y=z.getConnectorId(f),_=s||y,S=await this.disconnectConnector(f,_);S&&(a&&F.deleteConnectedSocialProvider(),S.connections.forEach(v=>{F.addDisconnectedConnectorId(v.connectorId,f)})),r&&this.onDisconnectNamespace({chainNamespace:f,closeModal:!1})}),p=await Promise.allSettled(h);_e.resetSend(),G.resetWcConnection(),(l=vs.getSIWX())!=null&&l.signOutOnDisconnect&&await vs.clearSessions(),z.setFilterByNamespace(void 0),G.syncStorageConnections();const g=p.filter(f=>f.status==="rejected");if(g.length>0)throw new Error(g.map(f=>f.reason.message).join(", "));Ee.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:n||"all"}})}catch(d){throw new Error(`Failed to disconnect chains: ${d.message}`)}},checkInstalled:e=>e?e.some(s=>{var n;return!!((n=window.ethereum)!=null&&n[String(s)])}):!!window.ethereum,signMessage:async e=>{const s=E.state.activeChain,n=this.getAdapter(E.state.activeChain);if(!s)throw new Error("signMessage: namespace not found");if(!n)throw new Error("signMessage: adapter not found");const r=this.getAddress(s);if(!r)throw new Error("signMessage: address not found");const i=await(n==null?void 0:n.signMessage({message:e,address:r,provider:He.getProvider(s)}));return(i==null?void 0:i.signature)||""},sendTransaction:async e=>{const s=e.chainNamespace;if(!s)throw new Error("sendTransaction: namespace not found");if(Ie.SEND_SUPPORTED_NAMESPACES.includes(s)){const n=this.getAdapter(s);if(!n)throw new Error("sendTransaction: adapter not found");const r=He.getProvider(s),i=await(n==null?void 0:n.sendTransaction({...e,caipNetwork:this.getCaipNetwork(),provider:r}));return(i==null?void 0:i.hash)||""}return""},estimateGas:async e=>{const s=e.chainNamespace;if(s===U.CHAIN.EVM){const n=this.getAdapter(s);if(!n)throw new Error("estimateGas: adapter is required but got undefined");const r=He.getProvider(s),i=this.getCaipNetwork();if(!i)throw new Error("estimateGas: caipNetwork is required but got undefined");const o=await(n==null?void 0:n.estimateGas({...e,provider:r,caipNetwork:i}));return(o==null?void 0:o.gas)||0n}return 0n},getEnsAvatar:async()=>{var r;const e=E.state.activeChain;if(!e)throw new Error("getEnsAvatar: namespace is required but got undefined");const s=this.getAddress(e);if(!s)throw new Error("getEnsAvatar: address not found");await this.syncIdentity({address:s,chainId:Number((r=this.getCaipNetwork())==null?void 0:r.id),chainNamespace:e});const n=E.getAccountData();return(n==null?void 0:n.profileImage)||!1},getEnsAddress:async e=>await Kn.resolveReownName(e),writeContract:async e=>{const s=E.state.activeChain,n=this.getAdapter(s);if(!s)throw new Error("writeContract: namespace is required but got undefined");if(!n)throw new Error("writeContract: adapter is required but got undefined");const r=this.getCaipNetwork(),i=this.getCaipAddress(),o=He.getProvider(s);if(!r||!i)throw new Error("writeContract: caipNetwork or caipAddress is required but got undefined");const a=await(n==null?void 0:n.writeContract({...e,caipNetwork:r,provider:o,caipAddress:i}));return a==null?void 0:a.hash},parseUnits:(e,s)=>{const n=this.getAdapter(E.state.activeChain);if(!n)throw new Error("parseUnits: adapter is required but got undefined");return(n==null?void 0:n.parseUnits({value:e,decimals:s}))??0n},formatUnits:(e,s)=>{const n=this.getAdapter(E.state.activeChain);if(!n)throw new Error("formatUnits: adapter is required but got undefined");return(n==null?void 0:n.formatUnits({value:e,decimals:s}))??"0"},getCapabilities:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("getCapabilities: adapter is required but got undefined");return await(s==null?void 0:s.getCapabilities(e))},grantPermissions:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("grantPermissions: adapter is required but got undefined");return await(s==null?void 0:s.grantPermissions(e))},revokePermissions:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("revokePermissions: adapter is required but got undefined");return s!=null&&s.revokePermissions?await s.revokePermissions(e):"0x"},walletGetAssets:async e=>{const s=this.getAdapter(E.state.activeChain);if(!s)throw new Error("walletGetAssets: adapter is required but got undefined");return await(s==null?void 0:s.walletGetAssets(e))??{}},updateBalance:e=>{const s=this.getAddress(e),n=this.getCaipNetwork(e);!n||!s||this.updateNativeBalance(s,n==null?void 0:n.id,e)}},G.setClient(this.connectionControllerClient)}async onConnectExternal(e){var l,d,u,h,p,g,f,y;const s=E.state.activeChain,n=e.chain||s,r=this.getAdapter(n);let i=!0;if(e.type===Lt.CONNECTOR_TYPE_AUTH&&U.AUTH_CONNECTOR_SUPPORTED_CHAINS.some(v=>z.getConnectorId(v)===U.CONNECTOR_ID.AUTH)&&e.chain!==s&&(i=!1),e.chain&&e.chain!==s&&!e.caipNetwork){const _=this.getCaipNetworks().find(S=>S.chainNamespace===e.chain);_&&i&&this.setCaipNetwork(_)}if(!n)throw new Error("connectExternal: namespace not found");if(!r)throw new Error("connectExternal: adapter not found");const o=this.getCaipNetwork(n),a=e.caipNetwork||o,c=await r.connect({id:e.id,address:e.address,info:e.info,type:e.type,provider:e.provider,socialUri:e.socialUri,chainId:((l=e.caipNetwork)==null?void 0:l.id)||(o==null?void 0:o.id),rpcUrl:((p=(h=(u=(d=e.caipNetwork)==null?void 0:d.rpcUrls)==null?void 0:u.default)==null?void 0:h.http)==null?void 0:p[0])||((y=(f=(g=o==null?void 0:o.rpcUrls)==null?void 0:g.default)==null?void 0:f.http)==null?void 0:y[0])});if(c)return F.addConnectedNamespace(n),this.syncProvider({...c,chainNamespace:n}),this.setStatus("connected",n),this.syncConnectedWalletInfo(n),F.removeDisconnectedConnectorId(e.id,n),{address:c.address,connectedCaipNetwork:a}}async connectInactiveNamespaces(e,s){var a;const n=e.type===Lt.CONNECTOR_TYPE_AUTH,r=wo.getOtherAuthNamespaces((a=s==null?void 0:s.connectedCaipNetwork)==null?void 0:a.chainNamespace),i=E.state.activeCaipNetwork,o=this.getAdapter(i==null?void 0:i.chainNamespace);n&&(await Promise.all(r.map(async c=>{var l,d,u;try{const h=He.getProvider(c),p=this.getCaipNetwork(c),g=this.getAdapter(c);await(g==null?void 0:g.connect({...e,provider:h,socialUri:void 0,chainId:p==null?void 0:p.id,rpcUrl:(u=(d=(l=p==null?void 0:p.rpcUrls)==null?void 0:l.default)==null?void 0:d.http)==null?void 0:u[0]}))&&(F.addConnectedNamespace(c),F.removeDisconnectedConnectorId(e.id,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c))}catch(h){Ot.warn(Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.displayMessage,Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.debugMessage(c,h instanceof Error?h.message:void 0),Pt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.code)}})),i&&await(o==null?void 0:o.switchNetwork({caipNetwork:i})))}getApprovedCaipNetworksData(){var s,n,r,i,o;if(He.getProviderId(E.state.activeChain)===Lt.CONNECTOR_TYPE_WALLET_CONNECT){const a=(n=(s=this.universalProvider)==null?void 0:s.session)==null?void 0:n.namespaces;return{supportsAllNetworks:((o=(i=(r=this.universalProvider)==null?void 0:r.session)==null?void 0:i.peer)==null?void 0:o.metadata.name)==="MetaMask Wallet",approvedCaipNetworkIds:this.getChainsFromNamespaces(a)}}return{supportsAllNetworks:!0,approvedCaipNetworkIds:[]}}async switchCaipNetwork(e){const s=e.chainNamespace;if(this.getAddressByChainNamespace(e.chainNamespace)){const r=He.getProviderId(s);if(e.chainNamespace===E.state.activeChain){const i=this.getAdapter(s);await(i==null?void 0:i.switchNetwork({caipNetwork:e}))}else if(this.setCaipNetwork(e),r===Lt.CONNECTOR_TYPE_WALLET_CONNECT)this.syncWalletConnectAccount();else{const i=this.getAddressByChainNamespace(s);i&&this.syncAccount({address:i,chainId:e.id,chainNamespace:s})}}else this.setCaipNetwork(e)}getChainsFromNamespaces(e={}){return Object.values(e).flatMap(s=>{const n=s.chains||[],r=s.accounts.map(i=>{const{chainId:o,chainNamespace:a}=dt.parseCaipAddress(i);return`${a}:${o}`});return Array.from(new Set([...n,...r]))})}createAdapters(e){return this.createClients(),this.chainNamespaces.reduce((s,n)=>{var i,o;const r=e==null?void 0:e.find(a=>a.namespace===n);return r?(r.construct({namespace:n,projectId:(i=this.options)==null?void 0:i.projectId,networks:(o=this.caipNetworks)==null?void 0:o.filter(({chainNamespace:a})=>a===n)}),s[n]=r):s[n]=new Wk({namespace:n,networks:this.getCaipNetworks()}),s},{})}async initChainAdapter(e){this.onConnectors(e),this.listenAdapter(e);const s=this.getAdapter(e);if(!s)throw new Error("adapter not found");await s.syncConnectors(),await this.createUniversalProviderForAdapter(e)}async initChainAdapters(){await Promise.all(this.chainNamespaces.map(async e=>{await this.initChainAdapter(e)})),this.initAdapterController()}onConnectors(e){const s=this.getAdapter(e);s==null||s.on("connectors",this.setConnectors.bind(this))}listenAdapter(e){const s=this.getAdapter(e);if(!s)return;const n=F.getConnectionStatus();$.state.enableReconnect===!1?this.setStatus("disconnected",e):n==="connected"?this.setStatus("connecting",e):n==="disconnected"?(F.clearAddressCache(),this.setStatus(n,e)):this.setStatus(n,e),s.on("switchNetwork",({address:r,chainId:i})=>{var l,d;const o=this.getCaipNetworks().find(u=>u.id.toString()===i.toString()||u.caipNetworkId.toString()===i.toString()),a=E.state.activeChain===e,c=(d=(l=E.state.chains.get(e))==null?void 0:l.accountState)==null?void 0:d.address;if(o){const u=a&&r?r:c;u&&this.syncAccount({address:u,chainId:o.id,chainNamespace:e})}else this.setUnsupportedNetwork(i)}),s.on("disconnect",()=>{const r=this.remoteFeatures.multiWallet,i=Array.from(G.state.connections.values()).flat();this.onDisconnectNamespace({chainNamespace:e,closeModal:!r||i.length===0})}),s.on("connections",r=>{this.setConnections(r,e)}),s.on("pendingTransactions",()=>{const r=this.getAddress(e),i=E.state.activeCaipNetwork;!r||!(i!=null&&i.id)||this.updateNativeBalance(r,i.id,i.chainNamespace)}),s.on("accountChanged",({address:r,chainId:i,connector:o})=>{var d,u;this.handlePreviousConnectorConnection(o);const a=E.state.activeChain===e;o!=null&&o.provider&&(this.syncProvider({id:o.id,type:o.type,provider:o==null?void 0:o.provider,chainNamespace:e}),this.syncConnectedWalletInfo(e));const c=(u=(d=E.getNetworkData(e))==null?void 0:d.caipNetwork)==null?void 0:u.id,l=i||c;a&&l?this.syncAccount({address:r,chainId:l,chainNamespace:e}):!a&&l?(this.syncAccountInfo(r,l,e),this.syncBalance({address:r,chainId:l,chainNamespace:e})):this.syncAccountInfo(r,i,e),F.addConnectedNamespace(e)})}async handlePreviousConnectorConnection(e){var c;const s=e==null?void 0:e.chain,n=e==null?void 0:e.id,r=z.getConnectorId(s),i=(c=$.state.remoteFeatures)==null?void 0:c.multiWallet,a=s&&n&&r&&r!==n&&!i;try{a&&await G.disconnect({id:r,namespace:s})}catch(l){console.warn("Error disconnecting previous connector",l)}}async createUniversalProviderForAdapter(e){var s,n,r;await this.getUniversalProvider(),this.universalProvider&&await((r=(n=(s=this.chainAdapters)==null?void 0:s[e])==null?void 0:n.setUniversalProvider)==null?void 0:r.call(n,this.universalProvider))}async syncExistingConnection(){await Promise.allSettled(this.chainNamespaces.map(e=>this.syncNamespaceConnection(e)))}async unSyncExistingConnection(){try{await Promise.allSettled(this.chainNamespaces.map(e=>G.disconnect({namespace:e,initialDisconnect:!0})))}catch(e){console.error("Error disconnecting existing connections:",e)}}async reconnectWalletConnect(){await this.syncWalletConnectAccount();const e=this.getAddress();this.getCaipAddress()||F.deleteRecentWallet();const s=F.getRecentWallet();Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:e,properties:{method:X.isMobile()?"mobile":"qrcode",name:(s==null?void 0:s.name)||"Unknown",reconnect:!0,view:ue.state.view,walletRank:s==null?void 0:s.order}})}async syncNamespaceConnection(e){try{e===U.CHAIN.EVM&&X.isSafeApp()&&z.setConnectorId(U.CONNECTOR_ID.SAFE,e);const s=z.getConnectorId(e);switch(this.setStatus("connecting",e),s){case U.CONNECTOR_ID.WALLET_CONNECT:await this.reconnectWalletConnect();break;case U.CONNECTOR_ID.AUTH:break;default:await this.syncAdapterConnection(e)}}catch(s){console.warn("AppKit couldn't sync existing connection",s),this.setStatus("disconnected",e)}}onDisconnectNamespace(e){const{chainNamespace:s,closeModal:n}=e||{};E.resetAccount(s),E.resetNetwork(s),F.removeConnectedNamespace(s);const r=Array.from(E.state.chains.keys());(s?[s]:r).forEach(o=>F.addDisconnectedConnectorId(z.getConnectorId(o)||"",o)),z.removeConnectorId(s),He.resetChain(s),this.setUser(null,s),this.setStatus("disconnected",s),this.setConnectedWalletInfo(null,s),n!==!1&&Ne.close()}async syncAdapterConnections(){await Promise.allSettled(this.chainNamespaces.map(e=>{const s=this.getAdapter(e),n=this.getCaipAddress(e),r=this.getCaipNetwork(e);return s==null?void 0:s.syncConnections({connectToFirstConnector:!n,caipNetwork:r})}))}async syncAdapterConnection(e){var a,c,l,d,u;const s=this.getAdapter(e),n=this.getCaipNetwork(e),r=z.getConnectorId(e),o=z.getConnectors(e).find(h=>h.id===r);try{if(!s||!o)throw new Error(`Adapter or connector not found for namespace ${e}`);if(!(n!=null&&n.id))throw new Error("CaipNetwork not found");const h=await(s==null?void 0:s.syncConnection({namespace:e,id:o.id,chainId:n.id,rpcUrl:(l=(c=(a=n==null?void 0:n.rpcUrls)==null?void 0:a.default)==null?void 0:c.http)==null?void 0:l[0]}));h?(this.syncProvider({...h,chainNamespace:e}),await this.syncAccount({...h,chainNamespace:e}),this.setStatus("connected",e),Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:h.address,properties:{method:"browser",name:((d=o.info)==null?void 0:d.name)||o.name||"Unknown",reconnect:!0,view:ue.state.view,walletRank:(u=o==null?void 0:o.explorerWallet)==null?void 0:u.order}})):this.setStatus("disconnected",e)}catch{this.onDisconnectNamespace({chainNamespace:e,closeModal:!1})}}async syncWalletConnectAccount(){var n,r;const e=Object.keys(((r=(n=this.universalProvider)==null?void 0:n.session)==null?void 0:r.namespaces)||{}),s=this.chainNamespaces.map(async i=>{var u,h,p,g,f;const o=this.getAdapter(i);if(!o)return;const a=((g=(p=(h=(u=this.universalProvider)==null?void 0:u.session)==null?void 0:h.namespaces)==null?void 0:p[i])==null?void 0:g.accounts)||[],c=(f=E.state.activeCaipNetwork)==null?void 0:f.id,l=a.find(y=>{const{chainId:_}=dt.parseCaipAddress(y);return _===(c==null?void 0:c.toString())})||a[0];if(l){const y=dt.validateCaipAddress(l),{chainId:_,address:S}=dt.parseCaipAddress(y);if(He.setProviderId(i,Lt.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&E.state.activeCaipNetwork&&o.namespace!==U.CHAIN.EVM){const v=o.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:E.state.activeCaipNetwork});He.setProvider(i,v)}else He.setProvider(i,this.universalProvider);z.setConnectorId(U.CONNECTOR_ID.WALLET_CONNECT,i),F.addConnectedNamespace(i),await this.syncAccount({address:S,chainId:_,chainNamespace:i})}else e.includes(i)&&this.setStatus("disconnected",i);const d=this.getApprovedCaipNetworksData();this.syncConnectedWalletInfo(i),E.setApprovedCaipNetworksData(i,{approvedCaipNetworkIds:d.approvedCaipNetworkIds,supportsAllNetworks:d.supportsAllNetworks})});await Promise.all(s)}syncProvider({type:e,provider:s,id:n,chainNamespace:r}){He.setProviderId(r,e),He.setProvider(r,s),z.setConnectorId(n,r)}async syncAccount(e){var u,h;const s=e.chainNamespace===E.state.activeChain,n=E.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:r,chainId:i,chainNamespace:o}=e,{chainId:a}=F.getActiveNetworkProps(),c=(n==null?void 0:n.id)||a,l=((u=E.state.activeCaipNetwork)==null?void 0:u.name)===U.UNSUPPORTED_NETWORK_NAME,d=E.getNetworkProp("supportsAllNetworks",o);if(this.setStatus("connected",o),!(l&&!d)&&c){let p=this.getCaipNetworks().find(_=>_.id.toString()===c.toString()),g=this.getCaipNetworks().find(_=>_.chainNamespace===o);if(!d&&!p&&!g){const _=this.getApprovedCaipNetworkIds()||[],S=_.find(C=>{var R;return((R=dt.parseCaipNetworkId(C))==null?void 0:R.chainId)===c.toString()}),v=_.find(C=>{var R;return((R=dt.parseCaipNetworkId(C))==null?void 0:R.chainNamespace)===o});p=this.getCaipNetworks().find(C=>C.caipNetworkId===S),g=this.getCaipNetworks().find(C=>C.caipNetworkId===v||"deprecatedCaipNetworkId"in C&&C.deprecatedCaipNetworkId===v)}const f=p||g;(f==null?void 0:f.chainNamespace)===E.state.activeChain?$.state.enableNetworkSwitch&&!$.state.allowUnsupportedChain&&((h=E.state.activeCaipNetwork)==null?void 0:h.name)===U.UNSUPPORTED_NETWORK_NAME?E.showUnsupportedChainUI():this.setCaipNetwork(f):s||n&&this.setCaipNetworkOfNamespace(n,o),this.syncConnectedWalletInfo(o);const y=this.getAddress(o);wo.isLowerCaseMatch(r,y)||this.syncAccountInfo(r,f==null?void 0:f.id,o),s?await this.syncBalance({address:r,chainId:f==null?void 0:f.id,chainNamespace:o}):await this.syncBalance({address:r,chainId:n==null?void 0:n.id,chainNamespace:o}),this.syncIdentity({address:r,chainId:i,chainNamespace:o})}}async syncAccountInfo(e,s,n){const r=this.getCaipAddress(n),i=s||(r==null?void 0:r.split(":")[1]);if(!i)return;const o=`${n}:${i}:${e}`;this.setCaipAddress(o,n,!0),await this.syncIdentity({address:e,chainId:i,chainNamespace:n})}async syncReownName(e,s){try{const n=await this.getReownName(e);if(n[0]){const r=n[0];this.setProfileName(r.name,s)}else this.setProfileName(null,s)}catch{this.setProfileName(null,s)}}syncConnectedWalletInfo(e){var r;const s=z.getConnectorId(e),n=He.getProviderId(e);if(n===Lt.CONNECTOR_TYPE_ANNOUNCED||n===Lt.CONNECTOR_TYPE_INJECTED){if(s){const o=this.getConnectors().find(a=>{var u,h;const c=a.id===s,l=((u=a.info)==null?void 0:u.rdns)===s,d=(h=a.connectors)==null?void 0:h.some(p=>{var g;return p.id===s||((g=p.info)==null?void 0:g.rdns)===s});return c||l||!!d});if(o){const{info:a,name:c,imageUrl:l}=o,d=l||this.getConnectorImage(o);this.setConnectedWalletInfo({name:c,icon:d,...a},e)}}}else if(n===Lt.CONNECTOR_TYPE_WALLET_CONNECT){const i=He.getProvider(e);i!=null&&i.session&&this.setConnectedWalletInfo({...i.session.peer.metadata,name:i.session.peer.metadata.name,icon:(r=i.session.peer.metadata.icons)==null?void 0:r[0]},e)}else if(s&&(s===U.CONNECTOR_ID.COINBASE_SDK||s===U.CONNECTOR_ID.COINBASE)){const i=this.getConnectors().find(l=>l.id===s),o=(i==null?void 0:i.name)||"Coinbase Wallet",a=(i==null?void 0:i.imageUrl)||this.getConnectorImage(i),c=i==null?void 0:i.info;this.setConnectedWalletInfo({...c,name:o,icon:a},e)}}async syncBalance(e){!Nf.getNetworksByNamespace(this.getCaipNetworks(),e.chainNamespace).find(n=>{var r;return n.id.toString()===((r=e.chainId)==null?void 0:r.toString())})||!e.chainId||await this.updateNativeBalance(e.address,e.chainId,e.chainNamespace)}async ready(){await this.readyPromise}async updateNativeBalance(e,s,n){const r=this.getAdapter(n),i=E.getCaipNetworkByNamespace(n,s);if(r){const o=await r.getBalance({address:e,chainId:s,caipNetwork:i,tokens:this.options.tokens});return this.setBalance(o.balance,o.symbol,n),o}}async initializeUniversalAdapter(){var r,i,o,a,c,l,d,u,h,p;const e=dk.createLogger((g,...f)=>{g&&this.handleAlertError(g),console.error(...f)}),s={projectId:(r=this.options)==null?void 0:r.projectId,metadata:{name:(i=this.options)!=null&&i.metadata?(o=this.options)==null?void 0:o.metadata.name:"",description:(a=this.options)!=null&&a.metadata?(c=this.options)==null?void 0:c.metadata.description:"",url:(l=this.options)!=null&&l.metadata?(d=this.options)==null?void 0:d.metadata.url:"",icons:(u=this.options)!=null&&u.metadata?(h=this.options)==null?void 0:h.metadata.icons:[""]},logger:e};$.setManualWCControl(!!((p=this.options)!=null&&p.manualWCControl)),this.universalProvider=this.options.universalProvider??await Px.init(s);const n=this.universalProvider.disconnect.bind(this.universalProvider);this.universalProvider.disconnect=async()=>{try{return await n()}catch(g){if(g instanceof Error&&g.message.includes("Missing or invalid. Record was recently deleted"))return;throw g}},$.state.enableReconnect===!1&&this.universalProvider.session&&await this.universalProvider.disconnect(),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&this.chainNamespaces.forEach(e=>{Kn.listenWcProvider({universalProvider:this.universalProvider,namespace:e,onDisplayUri:s=>{G.setUri(s)},onConnect:s=>{const{address:n}=X.getAccount(s[0]);G.finalizeWcConnection(n)},onDisconnect:()=>{E.state.noAdapters&&this.resetAccount(e),G.resetWcConnection()},onChainChanged:s=>{const n=E.state.activeChain,r=n&&z.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(E.state.noAdapters||r)){const i=this.getCaipNetworks().find(a=>a.id.toString()===s.toString()||a.caipNetworkId.toString()===s.toString()),o=this.getCaipNetwork();if(!i){this.setUnsupportedNetwork(s);return}(o==null?void 0:o.id.toString())!==(i==null?void 0:i.id.toString())&&(o==null?void 0:o.chainNamespace)===(i==null?void 0:i.chainNamespace)&&this.setCaipNetwork(i)}},onAccountsChanged:s=>{const n=E.state.activeChain,r=n&&z.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(E.state.noAdapters||r)){const i=s==null?void 0:s[0];i&&this.syncAccount({address:i.address,chainId:i.chainId,chainNamespace:i.chainNamespace})}}})})}createUniversalProvider(){var e;return!this.universalProviderInitPromise&&X.isClient()&&((e=this.options)!=null&&e.projectId)&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){Ee.sendEvent({type:"error",event:"INTERNAL_SDK_ERROR",properties:{errorType:"UniversalProviderInitError",errorMessage:e instanceof Error?e.message:"Unknown",uncaught:!1}}),console.error("AppKit:getUniversalProvider - Cannot create provider",e)}return this.universalProvider}getDisabledCaipNetworks(){const e=E.getAllApprovedCaipNetworkIds(),s=E.getAllRequestedCaipNetworks();return X.sortRequestedNetworks(e,s).filter(r=>E.isCaipNetworkDisabled(r))}handleAlertError(e){const s=Object.entries(Pt.UniversalProviderErrors).find(([,{message:a}])=>e.message.includes(a)),[n,r]=s??[],{message:i,alertErrorKey:o}=r??{};if(n&&i&&!this.reportedAlertErrors[n]){const a=Pt.ALERT_ERRORS[o];a&&(Ot.open(a,"error"),this.reportedAlertErrors[n]=!0)}}getAdapter(e){var s;if(e)return(s=this.chainAdapters)==null?void 0:s[e]}createAdapter(e){var r,i;if(!e)return;const s=e.namespace;if(!s)return;this.createClients();const n=e;n.namespace=s,n.construct({namespace:s,projectId:(r=this.options)==null?void 0:r.projectId,networks:(i=this.caipNetworks)==null?void 0:i.filter(({chainNamespace:o})=>o===s)}),this.chainNamespaces.includes(s)||this.chainNamespaces.push(s),this.chainAdapters&&(this.chainAdapters[s]=n)}async open(e){await this.injectModalUi(),e!=null&&e.uri&&G.setUri(e.uri);const{isSwap:s,isSend:n}=this.toModalOptions();return s(e)?Ne.open({...e,data:{swap:e.arguments}}):n(e)&&e.arguments?this.openSend(e.arguments):Ne.open(e)}async close(){await this.injectModalUi(),Ne.close()}setLoading(e,s){Ne.setLoading(e,s)}async disconnect(e){await G.disconnect({namespace:e})}getSIWX(){return $.state.siwx}getError(){return""}getChainId(){var e;return(e=E.state.activeCaipNetwork)==null?void 0:e.id}async switchNetwork(e,{throwOnFailure:s=!1}={}){const n=this.getCaipNetworks().find(r=>r.id===e.id);if(!n){Ot.open(Pt.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await E.switchActiveNetwork(n,{throwOnFailure:s})}getWalletProvider(){return E.state.activeChain?He.state.providers[E.state.activeChain]:null}getWalletProviderType(){return He.getProviderId(E.state.activeChain)}subscribeProviders(e){return He.subscribeProviders(e)}getThemeMode(){return Kt.state.themeMode}getThemeVariables(){return Kt.state.themeVariables}setThemeMode(e){Kt.setThemeMode(e),vd(Kt.state.themeMode)}setTermsConditionsUrl(e){$.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){$.setPrivacyPolicyUrl(e)}setThemeVariables(e){Kt.setThemeVariables(e),Bk(Kt.state.themeVariables)}subscribeTheme(e){return Kt.subscribe(e)}subscribeConnections(e){return this.remoteFeatures.multiWallet?G.subscribe(e):(Ot.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),()=>{})}getWalletInfo(e){var n,r;if(e)return(r=(n=E.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.connectedWalletInfo;const s=E.getAccountData();return s==null?void 0:s.connectedWalletInfo}getAccount(e){const s=e||E.state.activeChain,n=z.getAuthConnector(s),r=E.getAccountData(s),i=F.getConnectedConnectorId(E.state.activeChain),o=G.getConnections(s);if(!s)throw new Error("AppKit:getAccount - namespace is required");const a=o.flatMap(c=>c.accounts.map(({address:l,type:d,publicKey:u})=>X.createAccount(s,l,d||"eoa",u)));if(r)return{allAccounts:a,caipAddress:r.caipAddress,address:X.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:n&&i===U.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:F.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:ls(s),isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,s){const n=()=>{const r=this.getAccount(s);r&&e(r)};s?E.subscribeChainProp("accountState",n,s):E.subscribe(n),z.subscribe(n)}subscribeNetwork(e){return E.subscribe(({activeCaipNetwork:s})=>{e({caipNetwork:s,chainId:s==null?void 0:s.id,caipNetworkId:s==null?void 0:s.caipNetworkId})})}subscribeWalletInfo(e,s){return s?E.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo),s):E.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo))}subscribeShouldUpdateToAddress(e){E.subscribeChainProp("accountState",s=>e(s==null?void 0:s.shouldUpdateToAddress))}subscribeCaipNetworkChange(e){E.subscribeKey("activeCaipNetwork",e)}getState(){return ds.state}getRemoteFeatures(){return $.state.remoteFeatures}subscribeState(e){return ds.subscribe(e)}subscribeRemoteFeatures(e){return $.subscribeKey("remoteFeatures",e)}showErrorMessage(e){Ks.showError(e)}showSuccessMessage(e){Ks.showSuccess(e)}getEvent(){return{...Ee.state}}subscribeEvents(e){return Ee.subscribe(e)}replace(e){ue.replace(e)}redirect(e){ue.push(e)}popTransactionStack(e){ue.popTransactionStack(e)}isOpen(){return Ne.state.open}isTransactionStackEmpty(){return ue.state.transactionStack.length===0}static getInstance(){return this.instance}updateFeatures(e){$.setFeatures(e)}updateRemoteFeatures(e){$.setRemoteFeatures(e)}updateOptions(e){const n={...$.state||{},...e};$.setOptions(n)}setConnectMethodsOrder(e){$.setConnectMethodsOrder(e)}setWalletFeaturesOrder(e){$.setWalletFeaturesOrder(e)}setCollapseWallets(e){$.setCollapseWallets(e)}setSocialsOrder(e){$.setSocialsOrder(e)}getConnectMethodsOrder(){return zn.getConnectOrderMethod($.state.features,z.getConnectors())}addNetwork(e,s){if(this.chainAdapters&&!this.chainAdapters[e])throw new Error(`Adapter for namespace ${e} doesn't exist`);const n=this.extendCaipNetwork(s,this.options);this.getCaipNetworks().find(r=>r.id===n.id)||E.addNetwork(n)}removeNetwork(e,s){if(this.chainAdapters&&!this.chainAdapters[e])throw new Error(`Adapter for namespace ${e} doesn't exist`);this.getCaipNetworks().find(r=>r.id===s)&&E.removeNetwork(e,s)}}let bf=!1;class by extends Vk{async onAuthProviderConnected(e){const s=wo.userChainIdToChainNamespace(e==null?void 0:e.chainId);if(e.message&&e.signature&&e.siwxMessage&&await vs.addEmbeddedWalletSession({chainId:e.siwxMessage.chainId,accountAddress:e.address,notBefore:e.siwxMessage.notBefore,statement:e.siwxMessage.statement,resources:e.siwxMessage.resources,requestId:e.siwxMessage.requestId,issuedAt:e.siwxMessage.issuedAt,domain:e.siwxMessage.domain,uri:e.siwxMessage.uri,version:e.siwxMessage.version,nonce:e.siwxMessage.nonce},e.message,e.signature),!s)throw new Error("AppKit:onAuthProviderConnected - namespace is required");const n=s===U.CHAIN.EVM?`eip155:${e.chainId}:${e.address}`:`${e.chainId}:${e.address}`,r=$.state.defaultAccountTypes[s],i=ls(s),o=e.preferredAccountType||i||r;this.setCaipAddress(n,s);const{signature:a,siwxMessage:c,message:l,...d}=e,u=E.getAccountData(s);this.setUser({...(u==null?void 0:u.user)||{},...d},s),this.setSmartAccountDeployed(!!e.smartAccountDeployed,s),this.setPreferredAccountType(o,s),await Promise.all([this.syncAuthConnectorTheme(this.authProvider),this.syncAccount({address:e.address,chainId:e.chainId,chainNamespace:s})]),this.setLoading(!1,s)}setupAuthConnectorListeners(e){e.onRpcRequest(s=>{cs.checkIfRequestExists(s)?cs.checkIfRequestIsSafe(s)||this.handleUnsafeRPCRequest():(this.open(),console.error(tt.RPC_METHOD_NOT_ALLOWED_MESSAGE,{method:s.method}),setTimeout(()=>{this.showErrorMessage(tt.RPC_METHOD_NOT_ALLOWED_UI_MESSAGE)},300),e.rejectRpcRequests())}),e.onRpcError(()=>{this.isOpen()&&(this.isTransactionStackEmpty()?this.close():this.popTransactionStack("error"))}),e.onRpcSuccess((s,n)=>{const r=cs.checkIfRequestIsSafe(n),i=this.getAddress(),o=E.state.activeCaipNetwork;r||(i&&(o!=null&&o.id)&&this.updateNativeBalance(i,o.id,o.chainNamespace),this.isTransactionStackEmpty()?this.close():this.popTransactionStack("success"))}),e.onNotConnected(()=>{const s=E.state.activeChain;if(!s)throw new Error("AppKit:onNotConnected - namespace is required");z.getConnectorId(s)===U.CONNECTOR_ID.AUTH&&(this.setCaipAddress(null,s),this.setLoading(!1,s))}),e.onConnect(this.onAuthProviderConnected.bind(this)),e.onSocialConnected(this.onAuthProviderConnected.bind(this)),e.onSetPreferredAccount(({address:s,type:n})=>{const r=E.state.activeChain;if(!r)throw new Error("AppKit:onSetPreferredAccount - namespace is required");s&&this.setPreferredAccountType(n,r)})}async syncAuthConnectorTheme(e){if(!e)return;const s=Kt.getSnapshot();await e.syncTheme({themeMode:s.themeMode,themeVariables:s.themeVariables,w3mThemeVariables:Zi(s.themeVariables,s.themeMode)})}async syncAuthConnector(e,s){var d,u,h,p,g,f,y,_,S;const n=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(s),r=s===E.state.activeChain;if(!n)return;this.setLoading(!0,s);const i=e.getLoginEmailUsed();this.setLoading(i,s),i&&this.setStatus("connecting",s);const o=e.getEmail(),a=e.getUsername(),c=((d=E.getAccountData(s))==null?void 0:d.user)||{};this.setUser({...c,username:a,email:o},s),this.setupAuthConnectorListeners(e);const{isConnected:l}=await e.isConnected();if(s&&n&&r)if(l&&((u=this.connectionControllerClient)!=null&&u.connectExternal)){await e.init(),await this.syncAuthConnectorTheme(e),await((g=this.connectionControllerClient)==null?void 0:g.connectExternal({id:U.CONNECTOR_ID.AUTH,info:{name:U.CONNECTOR_ID.AUTH},type:Lt.CONNECTOR_TYPE_AUTH,provider:e,chainId:(p=(h=E.getNetworkData(s))==null?void 0:h.caipNetwork)==null?void 0:p.id,chain:s})),this.setStatus("connected",s);const v=F.getConnectedSocialProvider();v?Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",address:this.getAddress(),properties:{provider:v,reconnect:!0}}):Ee.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:this.getAddress(),properties:{method:"email",name:((S=(_=(y=(f=this.universalProvider)==null?void 0:f.session)==null?void 0:y.peer)==null?void 0:_.metadata)==null?void 0:S.name)||"Unknown",reconnect:!0,view:ue.state.view,walletRank:void 0}})}else z.getConnectorId(s)===U.CONNECTOR_ID.AUTH&&(this.setStatus("disconnected",s),F.removeConnectedNamespace(s));this.setLoading(!1,s)}async checkExistingTelegramSocialConnection(e){var s;try{if(!X.isTelegram())return;const n=F.getTelegramSocialProvider();if(!n||!X.isClient())return;const i=new URL(window.location.href).searchParams.get("result_uri");if(!i)return;n&&E.setAccountProp("socialProvider",n,e),await((s=this.authProvider)==null?void 0:s.init());const o=z.getAuthConnector();n&&o&&(this.setLoading(!0,e),await G.connectExternal({id:o.id,type:o.type,socialUri:i},o.chain),F.setConnectedSocialProvider(n),F.removeTelegramSocialProvider(),Ee.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:n}}))}catch(n){this.setLoading(!1,e),console.error("checkExistingSTelegramocialConnection error",n)}try{const n=new URL(window.location.href);n.searchParams.delete("result_uri"),window.history.replaceState({},document.title,n.toString())}catch(n){console.error("tma social login failed",n)}}createAuthProvider(e){var l,d,u,h;if(!U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(e))return;const n=(l=this.remoteFeatures)==null?void 0:l.email,r=Array.isArray((d=this.remoteFeatures)==null?void 0:d.socials)&&this.remoteFeatures.socials.length>0,i=n||r,a=wo.getActiveNamespaceConnectedToAuth()||e;!this.authProvider&&((u=this.options)!=null&&u.projectId)&&i&&(this.authProvider=zi.getInstance({projectId:this.options.projectId,enableLogger:this.options.enableAuthLogger,chainId:(h=this.getCaipNetwork(a))==null?void 0:h.caipNetworkId,abortController:Pt.EmbeddedWalletAbortController,onTimeout:p=>{p==="iframe_load_failed"?Ot.open(Pt.ALERT_ERRORS.IFRAME_LOAD_FAILED,"error"):p==="iframe_request_timeout"?Ot.open(Pt.ALERT_ERRORS.IFRAME_REQUEST_TIMEOUT,"error"):p==="unverified_domain"&&Ot.open(Pt.ALERT_ERRORS.UNVERIFIED_DOMAIN,"error")},getActiveCaipNetwork:p=>ki(p),getCaipNetworks:p=>E.getCaipNetworks(p)}),ds.subscribeOpen(p=>{var g;!p&&this.isTransactionStackEmpty()&&((g=this.authProvider)==null||g.rejectRpcRequests())}));const c=e===E.state.activeChain&&$.state.enableReconnect;$.state.enableReconnect===!1?this.syncAuthConnectorTheme(this.authProvider):this.authProvider&&c&&(this.syncAuthConnector(this.authProvider,e),this.checkExistingTelegramSocialConnection(e))}createAuthProviderForAdapter(e){var s,n,r;this.createAuthProvider(e),this.authProvider&&((r=(n=(s=this.chainAdapters)==null?void 0:s[e])==null?void 0:n.setAuthProvider)==null||r.call(n,this.authProvider))}initControllers(e){super.initControllers(e),this.options.excludeWalletIds&&te.initializeExcludedWallets({ids:this.options.excludeWalletIds})}async switchCaipNetwork(e){var o,a,c;if(!e)return;const s=E.state.activeChain,n=e.chainNamespace,r=this.getAddressByChainNamespace(n);if(n===s&&((o=E.getAccountData(n))!=null&&o.caipAddress)){const l=this.getAdapter(n);await(l==null?void 0:l.switchNetwork({caipNetwork:e})),this.setCaipNetwork(e)}else{const d=He.getProviderId(s)===Lt.CONNECTOR_TYPE_AUTH,u=He.getProviderId(n),h=u===Lt.CONNECTOR_TYPE_AUTH,p=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.includes(n);if(!n)throw new Error("AppKit:switchCaipNetwork - networkNamespace is required");if((d&&u===void 0||h)&&p)try{if(E.state.activeChain=e.chainNamespace,r){const g=this.getAdapter(n);await(g==null?void 0:g.switchNetwork({caipNetwork:e}))}else await((c=(a=this.connectionControllerClient)==null?void 0:a.connectExternal)==null?void 0:c.call(a,{id:U.CONNECTOR_ID.AUTH,provider:this.authProvider,chain:n,chainId:e.id,type:Lt.CONNECTOR_TYPE_AUTH,caipNetwork:e}));this.setCaipNetwork(e)}catch{const f=this.getAdapter(n);await(f==null?void 0:f.switchNetwork({caipNetwork:e}))}else if(u===Lt.CONNECTOR_TYPE_WALLET_CONNECT){if(!E.state.noAdapters){const g=this.getAdapter(n);await(g==null?void 0:g.switchNetwork({caipNetwork:e}))}this.setCaipNetwork(e),this.syncWalletConnectAccount()}else this.setCaipNetwork(e),r&&this.syncAccount({address:r,chainId:e.id,chainNamespace:n})}}async initialize(e){var s;await super.initialize(e),(s=this.chainNamespaces)==null||s.forEach(n=>{this.createAuthProviderForAdapter(n)}),await this.injectModalUi(),ds.set({initialized:!0})}async syncIdentity({address:e,chainId:s,chainNamespace:n}){var a;const r=`${n}:${s}`,i=(a=this.caipNetworks)==null?void 0:a.find(c=>c.caipNetworkId===r);if(i!=null&&i.testnet){this.setProfileName(null,n),this.setProfileImage(null,n);return}const o=z.getConnectorId(n)===U.CONNECTOR_ID.AUTH;try{const{name:c,avatar:l}=await this.fetchIdentity({address:e});!c&&o?await this.syncReownName(e,n):(this.setProfileName(c,n),this.setProfileImage(l,n))}catch{s!==1&&this.setProfileImage(null,n)}}syncConnectedWalletInfo(e){const s=He.getProviderId(e);if(s===Lt.CONNECTOR_TYPE_AUTH){const n=this.authProvider;if(n){const r=F.getConnectedSocialProvider()??"email",i=n.getEmail()??n.getUsername();this.setConnectedWalletInfo({name:s,identifier:i,social:r},e)}}else super.syncConnectedWalletInfo(e)}async injectModalUi(){if(X.isClient()&&!bf)try{const e={...Ie.DEFAULT_FEATURES,...this.options.features},s=this.remoteFeatures;if(await this.loadModalComponents(e,s),X.isClient()&&!document.querySelector("w3m-modal")){const r=document.createElement("w3m-modal");!$.state.disableAppend&&!$.state.enableEmbedded&&document.body.insertAdjacentElement("beforeend",r)}bf=!0}catch(e){console.error("Error injecting modal UI:",e)}}async loadModalComponents(e,s){if(!X.isClient())return;const n=[];(s.email||s.socials&&s.socials.length>0)&&n.push(Dt(()=>import("./embedded-wallet-CG7TbOV-.js"),__vite__mapDeps([7,8,3,4,9,10,2,11,12,13,14,15,16,17,18,19,20]))),s.email&&n.push(Dt(()=>import("./email-BG_i___x.js"),__vite__mapDeps([21,8,3,4,22,19,12,18,10,11,17,23,15,2]))),s.socials&&n.push(Dt(()=>import("./socials-Dc6QGKNd.js"),__vite__mapDeps([24,8,3,4,10,25,11,26,2,18,27,14,17,12,28,9,29]))),s.swaps&&s.swaps.length>0&&n.push(Dt(()=>import("./swaps-11Cmmiib.js"),__vite__mapDeps([30,8,3,4,17,12,18,10,31,32,33,2,29,34,9,15,11]))),e.send&&n.push(Dt(()=>import("./send-lCTQJ_pv.js"),__vite__mapDeps([35,8,3,4,17,12,18,10,36,11,37,19,34,9,29,33,2,15,38,39]))),e.receive&&n.push(Dt(()=>import("./receive-CcTr-1Qk.js"),__vite__mapDeps([40,8,3,4,10,9,28,2]))),s.onramp&&s.onramp.length>0&&n.push(Dt(()=>import("./onramp-BUHkZqza.js"),__vite__mapDeps([41,8,3,4,10,42,12,25,11,9,43,44,19,17,18,27,15,2]))),s.payWithExchange&&n.push(Dt(()=>import("./pay-with-exchange-sBe4iQtb.js"),__vite__mapDeps([45,8,3,4,10,9,16,42,12,29,17,37,11,19,46,18,15,38,36,2]))),s.activity&&n.push(Dt(()=>import("./transactions-DFf4sRIF.js"),__vite__mapDeps([47,8,3,4,48,18,10,19,9,29,2]))),(e.pay||s.payments)&&n.push(Dt(()=>import("./index-yx1vikfy.js"),__vite__mapDeps([49,8,3,4,10,17,12,50,16,9,42,51,36,52,18,2,27]))),s.emailCapture&&n.push(Dt(()=>import("./data-capture-C6QaYSs8.js"),__vite__mapDeps([53,8,3,4,22,19,12,6,2]))),await Promise.all([...n,Dt(()=>import("./index-3gO2YMOL.js"),__vite__mapDeps([54,8,3,4,10,9,12,39,18,55,44,19,13,14,2,52,16,42,17,46,48,29,38,31,32,36,11,15,51,23,25,26,27,28,20,43])),Dt(()=>import("./w3m-modal-DrW1uZDo.js"),__vite__mapDeps([56,8,3,4,10,50,9,13,14,2,12,18,32,55,44,19,52,33,17]))])}}const Kk="1.8.15";function Gk(t){return new by({...t,sdkVersion:X.generateSdkVersion(t.adapters??[],"html",Kk)})}const B2=Object.freeze(Object.defineProperty({__proto__:null,AppKit:by,CoreHelperUtil:X,WcConstantsUtil:Li,createAppKit:Gk},Symbol.toStringTag,{value:"Module"}));export{Hi as $,yt as A,fe as B,E as C,U2 as D,Ee as E,Qi as F,F as G,cs as H,ae as I,le as J,Lt as K,te as L,Ne as M,iw as N,$ as O,Ev as P,Pt as Q,ue as R,Ks as S,Kt as T,dt as U,He as V,tt as W,lw as X,Zi as Y,lt as Z,_e as _,X as a,Ul as a0,bs as a1,Tr as a2,mn as a3,vs as a4,D2 as a5,Zf as a6,pa as a7,fy as a8,Ed as a9,hi as aa,Hf as ab,vv as ac,bv as ad,zf as ae,Wu as af,Tv as ag,Vo as ah,Ov as ai,Sv as aj,xs as ak,$a as al,wo as am,zn as an,Gr as ao,sC as ap,ki as aq,B2 as ar,N2 as b,I2 as c,Ie as d,Yf as e,R2 as f,T2 as g,O2 as h,_t as i,$2 as j,M2 as k,va as l,k2 as m,Wn as n,G as o,Ge as p,ls as q,L2 as r,At as s,eC as t,Ot as u,Mk as v,As as w,Rd as x,z as y,Kf as z};
|