@dcl/top-scenes 0.0.1-20582064766.commit-81a190a → 0.0.1-20640454925.commit-802e8a8
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/{auto-track-CVZpdcr4.js → auto-track-CmMQxVhy.js} +1 -1
- package/assets/{basic-BH6yc_jn.js → basic-D0dwyfjS.js} +1 -1
- package/assets/{core-Dlj7hx-n.js → core-CD2FzHFH.js} +5 -5
- package/assets/{features-CHnlaMRZ.js → features-BanUs8Cp.js} +1 -1
- package/assets/{fortmatic-o8vzt_EK.js → fortmatic-CeJyq30A.js} +1 -1
- package/assets/{index-2HXs6HoD.js → index-BcjBTImX.js} +1 -1
- package/assets/{index-CnYSbS2q.js → index-C-DG4cQL.js} +1 -1
- package/assets/{index-DVIltX2H.js → index-CKq5iZx_.js} +4 -4
- package/assets/{index-DeV-SOTm.js → index-Cn_4Xm8q.js} +71 -71
- package/assets/{index-riIdW6FG.js → index-DfiWbmEG.js} +1 -1
- package/assets/{index-BvoY5v7t.js → index-Dp0JciDP.js} +1 -1
- package/assets/{index-Bizzaed7.js → index-ObhnD16t.js} +2 -2
- package/assets/{index-BWkgAZ1u.js → index-eTCC3Tyz.js} +1 -1
- package/assets/{index-iGyUmsDB.js → index-j5FOYsQh.js} +1 -1
- package/assets/{index-BHWsSK9-.js → index-v1drZp4X.js} +2 -2
- package/assets/{index.umd-hEyCKGJZ.js → index.umd-vllTdCMe.js} +1 -1
- package/assets/{w3m-modal-BqsJdt5C.js → w3m-modal-Bj2hrG0i.js} +1 -1
- package/index.html +1 -1
- package/package.json +3 -3
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/index-
|
|
2
|
-
import{_ as vo,a as Sf,e as Mn,x as jc}from"./index-DeV-SOTm.js";import{d as Li,s as Eo,a as Rn,c as Nf,b as Tf,k as Of,e as Pf,f as kf,g as El,I as wr,h as Rf,i as Ft,t as bt,j as F,l as ur,C as xf,m as th,n as $f,o as Uf,p as jr,q as Ya,r as br,u as Df,v as Lf,w as Mf,x as Bf,y as jf,z as Ff,A as qf,B as as,D as vr,E as Fc,F as Wf,G as qc,H as Wc,J as Yr,P as Cl,Q as Hf,K as Kf,L as En,M as sh,N as ws,O as os,R as Us,S as nh}from"./index-DVIltX2H.js";var Al={};const U={WC_NAME_SUFFIX:".reown.id",WC_NAME_SUFFIX_LEGACY:".wcn.id",BLOCKCHAIN_API_RPC_URL:"https://rpc.walletconnect.org",PULSE_API_URL:"https://pulse.walletconnect.org",W3M_API_URL:"https://api.web3modal.org",CONNECTOR_ID:{WALLET_CONNECT:"walletConnect",INJECTED:"injected",WALLET_STANDARD:"announced",COINBASE:"coinbaseWallet",COINBASE_SDK:"coinbaseWalletSDK",SAFE:"safe",LEDGER:"ledger",OKX:"okx",EIP6963:"eip6963",AUTH:"AUTH"},CONNECTOR_NAMES:{AUTH:"Auth"},AUTH_CONNECTOR_SUPPORTED_CHAINS:["eip155","solana"],LIMITS:{PENDING_TRANSACTIONS:99},CHAIN:{EVM:"eip155",SOLANA:"solana",POLKADOT:"polkadot",BITCOIN:"bip122"},CHAIN_NAME_MAP:{eip155:"EVM Networks",solana:"Solana",polkadot:"Polkadot",bip122:"Bitcoin",cosmos:"Cosmos",sui:"Sui",stacks:"Stacks"},ADAPTER_TYPES:{BITCOIN:"bitcoin",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5"},USDT_CONTRACT_ADDRESSES:["0xdac17f958d2ee523a2206206994597c13d831ec7","0xc2132d05d31c914a87c6611c10748aeb04b58e8f","0x9702230a8ea53601f5cd2dc00fdbc13d4df4a8c7","0x919C1c267BC06a7039e03fcc2eF738525769109c","0x48065fbBE25f71C9282ddf5e1cD6D6A887483D5e","0x55d398326f99059fF775485246999027B3197955","0xfd086bc7cd5c481dcc9c85ebe478a1c0b69fcbb9"],SOLANA_SPL_TOKEN_ADDRESSES:{SOL:"So11111111111111111111111111111111111111112"},HTTP_STATUS_CODES:{SERVER_ERROR:500,TOO_MANY_REQUESTS:429,SERVICE_UNAVAILABLE:503,FORBIDDEN:403},UNSUPPORTED_NETWORK_NAME:"Unknown Network",SECURE_SITE_SDK_ORIGIN:(typeof process<"u"&&typeof Al<"u"?Al.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",REMOTE_FEATURES_ALERTS:{MULTI_WALLET_NOT_ENABLED:{DEFAULT:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com."},CONNECTIONS_HOOK:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com to use the useAppKitConnections hook."},CONNECTION_HOOK:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com to use the useAppKitConnection hook."}}},IS_DEVELOPMENT:typeof process<"u"&&!1,DEFAULT_ALLOWED_ANCESTORS:["http://localhost:*","https://localhost:*","http://127.0.0.1:*","https://127.0.0.1:*","https://*.pages.dev","https://*.vercel.app","https://*.ngrok-free.app","https://secure-mobile.walletconnect.com","https://secure-mobile.walletconnect.org"]},rh={caipNetworkIdToNumber(t){return t?Number(t.split(":")[1]):void 0},parseEvmChainId(t){return typeof t=="string"?this.caipNetworkIdToNumber(t):t},getNetworksByNamespace(t,e){return(t==null?void 0:t.filter(s=>s.chainNamespace===e))||[]},getFirstNetworkByNamespace(t,e){return this.getNetworksByNamespace(t,e)[0]},getNetworkNameByCaipNetworkId(t,e){var r;if(!e)return;const s=t.find(i=>i.caipNetworkId===e);if(s)return s.name;const[n]=e.split(":");return((r=U.CHAIN_NAME_MAP)==null?void 0:r[n])||void 0}},ih=["eip155","solana","polkadot","bip122","cosmos","sui","stacks"];var zf=20,Vf=1,xn=1e6,Il=1e6,Gf=-7,Yf=21,Jf=!1,Ni="[big.js] ",Bn=Ni+"Invalid ",Wo=Bn+"decimal places",Xf=Bn+"rounding mode",oh=Ni+"Division by zero",_e={},hs=void 0,Zf=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function ah(){function t(e){var s=this;if(!(s instanceof t))return e===hs?ah():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(Bn+"value");e=e===0&&1/e<0?"-0":String(e)}Qf(s,e)}s.constructor=t}return t.prototype=_e,t.DP=zf,t.RM=Vf,t.NE=Gf,t.PE=Yf,t.strict=Jf,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}function Qf(t,e){var s,n,r;if(!Zf.test(e))throw Error(Bn+"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 jn(t,e,s,n){var r=t.c;if(s===hs&&(s=t.constructor.RM),s!==0&&s!==1&&s!==2&&s!==3)throw Error(Xf);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]!==hs))),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]!==hs||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 Fn(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}_e.abs=function(){var t=new this.constructor(this);return t.s=1,t};_e.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};_e.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>xn)throw Error(Wo);if(!r[0])throw Error(oh);if(!n[0])return t.s=i,t.c=[t.e=0],t;var a,c,l,u,d,h=r.slice(),p=a=r.length,g=n.length,f=n.slice(0,a),y=f.length,w=t,b=w.c=[],E=0,N=o+(w.e=e.e-t.e)+1;for(w.s=i,i=N<0?0:N,h.unshift(0);y++<a;)f.push(0);do{for(l=0;l<10;l++){if(a!=(y=f.length))u=a>y?1:-1;else for(d=-1,u=0;++d<a;)if(r[d]!=f[d]){u=r[d]>f[d]?1:-1;break}if(u<0){for(c=y==a?r:h;y;){if(f[--y]<c[y]){for(d=y;d&&!f[--d];)f[d]=9;--f[d],f[y]+=10}f[y]-=c[y]}for(;!f[0];)f.shift()}else break}b[E++]=u?l:++l,f[0]&&u?f[y]=n[p]||0:f=[n[p]]}while((p++<g||f[0]!==hs)&&i--);return!b[0]&&E!=1&&(b.shift(),w.e--,N--),E>N&&jn(w,N,s.RM,f[0]!==hs),w};_e.eq=function(t){return this.cmp(t)===0};_e.gt=function(t){return this.cmp(t)>0};_e.gte=function(t){return this.cmp(t)>-1};_e.lt=function(t){return this.cmp(t)<0};_e.lte=function(t){return this.cmp(t)<1};_e.minus=_e.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(),u=i.e,d=t.c,h=t.e;if(!l[0]||!d[0])return d[0]?t.s=-c:l[0]?t=new o(i):t.s=1,t;if(a=u-h){for((r=a<0)?(a=-a,n=l):(h=u,n=d),n.reverse(),c=a;c--;)n.push(0);n.reverse()}else for(s=((r=l.length<d.length)?l:d).length,a=c=0;c<s;c++)if(l[c]!=d[c]){r=l[c]<d[c];break}if(r&&(n=l,l=d,d=n,t.s=-t.s),(c=(s=d.length)-(e=l.length))>0)for(;c--;)l[e++]=0;for(c=e;s>a;){if(l[--s]<d[s]){for(e=s;e&&!l[--e];)l[e]=9;--l[e],l[s]+=10}l[s]-=d[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};_e.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(oh);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)))};_e.neg=function(){var t=new this.constructor(this);return t.s=-t.s,t};_e.plus=_e.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};_e.pow=function(t){var e=this,s=new e.constructor("1"),n=s,r=t<0;if(t!==~~t||t<-Il||t>Il)throw Error(Bn+"exponent");for(r&&(t=-t);t&1&&(n=n.times(e)),t>>=1,!!t;)e=e.times(e);return r?s.div(n):n};_e.prec=function(t,e){if(t!==~~t||t<1||t>xn)throw Error(Bn+"precision");return jn(new this.constructor(this),t,e)};_e.round=function(t,e){if(t===hs)t=0;else if(t!==~~t||t<-xn||t>xn)throw Error(Wo);return jn(new this.constructor(this),t+this.e+1,e)};_e.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(Ni+"No square root");i=Math.sqrt(+Fn(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 jn(t,(r.DP-=4)+t.e+1,r.RM)};_e.times=_e.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};_e.toExponential=function(t,e){var s=this,n=s.c[0];if(t!==hs){if(t!==~~t||t<0||t>xn)throw Error(Wo);for(s=jn(new s.constructor(s),++t,e);s.c.length<t;)s.c.push(0)}return Fn(s,!0,!!n)};_e.toFixed=function(t,e){var s=this,n=s.c[0];if(t!==hs){if(t!==~~t||t<0||t>xn)throw Error(Wo);for(s=jn(new s.constructor(s),t+s.e+1,e),t=t+s.e+1;s.c.length<t;)s.c.push(0)}return Fn(s,!1,!!n)};_e[Symbol.for("nodejs.util.inspect.custom")]=_e.toJSON=_e.toString=function(){var t=this,e=t.constructor;return Fn(t,t.e<=e.NE||t.e>=e.PE,!!t.c[0])};_e.toNumber=function(){var t=+Fn(this,!0,!0);if(this.constructor.strict===!0&&!this.eq(t.toString()))throw Error(Ni+"Imprecise conversion");return t};_e.toPrecision=function(t,e){var s=this,n=s.constructor,r=s.c[0];if(t!==hs){if(t!==~~t||t<1||t>xn)throw Error(Bn+"precision");for(s=jn(new n(s),t,e);s.c.length<t;)s.c.push(0)}return Fn(s,t<=s.e||s.e<=n.NE||s.e>=n.PE,!!r)};_e.valueOf=function(){var t=this,e=t.constructor;if(e.strict===!0)throw Error(Ni+"valueOf disallowed");return Fn(t,t.e<=e.NE||t.e>=e.PE,!0)};var Ds=ah();const eg={bigNumber(t){return t?new Ds(t):new Ds(0)},multiply(t,e){if(t===void 0||e===void 0)return new Ds(0);const s=new Ds(t),n=new Ds(e);return s.times(n)},toFixed(t,e=2){return t===void 0||t===""?new Ds(0).toFixed(e):new Ds(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 Ds(e).toNumber()}},tg=[{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"}]}],sg=[{type:"function",name:"approve",stateMutability:"nonpayable",inputs:[{name:"spender",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]}],ng=[{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"}]}],rg={getERC20Abi:t=>U.USDT_CONTRACT_ADDRESSES.includes(t)?ng:tg,getSwapAbi:()=>sg},Xe={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}}},_s={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(_s.isRpcProviderError(t)){const e=t.code===_s.RPC_ERROR_CODE.USER_REJECTED_REQUEST,s=t.code===_s.RPC_ERROR_CODE.USER_REJECTED_METHODS;return e||s||_s.isUserRejectedMessage(t.message)}return t instanceof Error?_s.isUserRejectedMessage(t.message):!1}};let ig=class extends Error{constructor(e,s){super(s.message,{cause:e}),this.name=_s.PROVIDER_RPC_ERROR_NAME.PROVIDER_RPC,this.code=s.code}},ch=class extends ig{constructor(e){super(e,{code:_s.RPC_ERROR_CODE.USER_REJECTED_REQUEST,message:"User rejected the request"}),this.name=_s.PROVIDER_RPC_ERROR_NAME.USER_REJECTED_REQUEST}};const Z={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"};function oa(t){if(!t)throw new Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${t}:connected_connector_id`}const Y={setItem(t,e){Ur()&&e!==void 0&&localStorage.setItem(t,e)},getItem(t){if(Ur())return localStorage.getItem(t)||void 0},removeItem(t){Ur()&&localStorage.removeItem(t)},clear(){Ur()&&localStorage.clear()}};function Ur(){return typeof window<"u"&&typeof localStorage<"u"}function Co(t,e){return e==="light"?{"--w3m-accent":(t==null?void 0:t["--w3m-accent"])||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":(t==null?void 0:t["--w3m-accent"])||"hsla(230, 100%, 67%, 1)","--w3m-background":"#202020"}}const og=Symbol(),_l=Object.getPrototypeOf,Ja=new WeakMap,ag=t=>t&&(Ja.has(t)?Ja.get(t):_l(t)===Object.prototype||_l(t)===Array.prototype),cg=t=>ag(t)&&t[og]||null,Sl=(t,e=!0)=>{Ja.set(t,e)},Ao={},Hc=t=>typeof t=="object"&&t!==null,lg=t=>Hc(t)&&!Ti.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),lh=(t,e)=>{const s=Xa.get(t);if((s==null?void 0:s[0])===e)return s[1];const n=Array.isArray(t)?[]:Object.create(Object.getPrototypeOf(t));return Sl(n,!0),Xa.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(Ti.has(i))Sl(i,!1);else if(nn.has(i)){const[c,l]=nn.get(i);a.value=lh(c,l())}Object.defineProperty(n,r,a)}),Object.preventExtensions(n)},ug=(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&&(Nl(l,o)||Jr.has(o)&&Nl(l,Jr.get(o))))return!0;s(i),Hc(o)&&(o=cg(o)||o);const u=!nn.has(o)&&hg(o)?ke(o):o;return e(i,u),Reflect.set(r,i,u,a),n(["set",[i],o,l]),!0}}),nn=new WeakMap,Ti=new WeakSet,Xa=new WeakMap,co=[1],Jr=new WeakMap;let Nl=Object.is,dg=(t,e)=>new Proxy(t,e),hg=lg,pg=lh,fg=ug;function ke(t={}){if(!Hc(t))throw new Error("object required");const e=Jr.get(t);if(e)return e;let s=co[0];const n=new Set,r=(y,w=++co[0])=>{s!==w&&(i=s=w,n.forEach(b=>b(y,w)))};let i=s;const o=(y=co[0])=>(i!==y&&(i=y,c.forEach(([w])=>{const b=w[1](y);b>s&&(s=b)})),s),a=y=>(w,b)=>{const E=[...w];E[1]=[y,...E[1]],r(E,b)},c=new Map,l=(y,w)=>{const b=!Ti.has(w)&&nn.get(w);if(b){if((Ao?"production":void 0)!=="production"&&c.has(y))throw new Error("prop listener already exists");if(n.size){const E=b[2](a(y));c.set(y,[b,E])}else c.set(y,[b])}},u=y=>{var w;const b=c.get(y);b&&(c.delete(y),(w=b[1])==null||w.call(b))},d=y=>(n.add(y),n.size===1&&c.forEach(([b,E],N)=>{if((Ao?"production":void 0)!=="production"&&E)throw new Error("remove already exists");const x=b[2](a(N));c.set(N,[b,x])}),()=>{n.delete(y),n.size===0&&c.forEach(([b,E],N)=>{E&&(E(),c.set(N,[b]))})});let h=!0;const p=fg(()=>h,l,u,r),g=dg(t,p);Jr.set(t,g);const f=[t,o,d];return nn.set(g,f),Reflect.ownKeys(t).forEach(y=>{const w=Object.getOwnPropertyDescriptor(t,y);"value"in w&&w.writable&&(g[y]=t[y])}),h=!1,g}function Ze(t,e,s){const n=nn.get(t);(Ao?"production":void 0)!=="production"&&!n&&console.warn("Please use proxy object");let r;const i=[],o=n[2];let a=!1;const l=o(u=>{i.push(u),r||(r=Promise.resolve().then(()=>{r=void 0,a&&e(i.splice(0))}))});return a=!0,()=>{a=!1,l()}}function Xr(t){const e=nn.get(t);(Ao?"production":void 0)!=="production"&&!e&&console.warn("Please use proxy object");const[s,n]=e;return pg(s,n())}function Zr(t){return Ti.add(t),t}function gg(){return{proxyStateMap:nn,refSet:Ti,snapCache:Xa,versionHolder:co,proxyCache:Jr}}function Qe(t,e,s,n){let r=t[e];return Ze(t,()=>{const i=t[e];Object.is(r,i)||s(r=i)})}const{proxyStateMap:mg,snapCache:yg}=gg(),Mi=t=>mg.has(t);function wg(t){const e=[];let s=0;const n=new Map,r=new WeakMap,i=()=>{const l=yg.get(a),u=l==null?void 0:l[1];if(u&&!r.has(u)){const d=new Map(n);r.set(u,d)}},o=l=>r.get(l)||n,a={data:e,index:s,epoch:0,get size(){return Mi(this)||i(),o(this).size},get(l){const d=o(this).get(l);if(d===void 0){this.epoch;return}return this.data[d]},has(l){const u=o(this);return this.epoch,u.has(l)},set(l,u){if(!Mi(this))throw new Error("Cannot perform mutations on a snapshot");const d=n.get(l);return d===void 0?(n.set(l,this.index),this.data[this.index++]=u):this.data[d]=u,this.epoch++,this},delete(l){if(!Mi(this))throw new Error("Cannot perform mutations on a snapshot");const u=n.get(l);return u===void 0?!1:(delete this.data[u],n.delete(l),this.epoch++,!0)},clear(){if(!Mi(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((d,h)=>{l(this.data[d],h,this)})},*entries(){this.epoch;const l=o(this);for(const[u,d]of l)yield[u,this.data[d]]},*keys(){this.epoch;const l=o(this);for(const u of l.keys())yield u},*values(){this.epoch;const l=o(this);for(const u of l.values())yield this.data[u]},[Symbol.iterator](){return this.entries()},get[Symbol.toStringTag](){return"Map"},toJSON(){return new Map(this.entries())}},c=ke(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 Tl={};const aa=(typeof process<"u"&&typeof Tl<"u"?Tl.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",uh=[{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],bg="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",ye={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:aa,SECURE_SITE_DASHBOARD:`${aa}/dashboard`,SECURE_SITE_FAVICON:`${aa}/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],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x",sui:"0x",stacks:"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},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1,emailCapture:!1,reownAuthentication:!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},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"},SIWX_DEFAULTS:{signOutOnDisconnect:!0}},P={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5,transactionsHistory:15e3,tokenPrice:15e3,latestAppKitVersion:6048e5},isCacheExpired(t,e){return Date.now()-t>e},getActiveNetworkProps(){const t=P.getActiveNamespace(),e=P.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{Y.setItem(Z.DEEPLINK_CHOICE,JSON.stringify({href:e,name:t}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{const t=Y.getItem(Z.DEEPLINK_CHOICE);if(t)return JSON.parse(t)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{Y.removeItem(Z.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(t){try{Y.setItem(Z.ACTIVE_NAMESPACE,t)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(t){try{Y.setItem(Z.ACTIVE_CAIP_NETWORK_ID,t),P.setActiveNamespace(t.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return Y.getItem(Z.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{Y.removeItem(Z.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(t){try{const e=oa(t);Y.removeItem(e)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(t){try{const e=P.getRecentWallets();e.find(n=>n.id===t.id)||(e.unshift(t),e.length>2&&e.pop(),Y.setItem(Z.RECENT_WALLETS,JSON.stringify(e)),Y.setItem(Z.RECENT_WALLET,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{const t=Y.getItem(Z.RECENT_WALLETS);return t?JSON.parse(t):[]}catch{console.info("Unable to get AppKit recent")}return[]},getRecentWallet(){try{const t=Y.getItem(Z.RECENT_WALLET);return t?JSON.parse(t):null}catch{console.info("Unable to get AppKit recent")}return null},deleteRecentWallet(){try{Y.removeItem(Z.RECENT_WALLET)}catch{console.info("Unable to delete AppKit recent")}},setConnectedConnectorId(t,e){try{const s=oa(t);Y.setItem(s,e)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return Y.getItem(Z.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(t){if(t)try{const e=oa(t);return Y.getItem(e)}catch{console.info("Unable to get connected connector id in namespace",t)}},setConnectedSocialProvider(t){try{Y.setItem(Z.CONNECTED_SOCIAL,t)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return Y.getItem(Z.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{Y.removeItem(Z.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return Y.getItem(Z.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){var s;const t=Y.getItem(Z.ACTIVE_CAIP_NETWORK_ID);return(s=t==null?void 0:t.split(":"))==null?void 0:s[1]},setConnectionStatus(t){try{Y.setItem(Z.CONNECTION_STATUS,t)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return Y.getItem(Z.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{const t=Y.getItem(Z.CONNECTED_NAMESPACES);return t!=null&&t.length?t.split(","):[]}catch{return[]}},setConnectedNamespaces(t){try{const e=Array.from(new Set(t));Y.setItem(Z.CONNECTED_NAMESPACES,e.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(t){try{const e=P.getConnectedNamespaces();e.includes(t)||(e.push(t),P.setConnectedNamespaces(e))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(t){try{const e=P.getConnectedNamespaces(),s=e.indexOf(t);s>-1&&(e.splice(s,1),P.setConnectedNamespaces(e))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return Y.getItem(Z.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(t){try{Y.setItem(Z.TELEGRAM_SOCIAL_PROVIDER,t)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{Y.removeItem(Z.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let t={};try{const e=Y.getItem(Z.PORTFOLIO_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromBalanceCache(t){try{const e=P.getBalanceCache();Y.setItem(Z.PORTFOLIO_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getBalanceCacheForCaipAddress(t){try{const s=P.getBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.portfolio))return s.balance;P.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateBalanceCache(t){try{const e=P.getBalanceCache();e[t.caipAddress]=t,Y.setItem(Z.PORTFOLIO_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getNativeBalanceCache(){let t={};try{const e=Y.getItem(Z.NATIVE_BALANCE_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromNativeBalanceCache(t){try{const e=P.getBalanceCache();Y.setItem(Z.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=P.getNativeBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.nativeBalance))return s;console.info("Discarding cache for address",t),P.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateNativeBalanceCache(t){try{const e=P.getNativeBalanceCache();e[t.caipAddress]=t,Y.setItem(Z.NATIVE_BALANCE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getEnsCache(){let t={};try{const e=Y.getItem(Z.ENS_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get ens name cache")}return t},getEnsFromCacheForAddress(t){try{const s=P.getEnsCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.ens))return s.ens;P.removeEnsFromCache(t)}catch{console.info("Unable to get ens name from cache",t)}},updateEnsCache(t){try{const e=P.getEnsCache();e[t.address]=t,Y.setItem(Z.ENS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ens name cache",t)}},removeEnsFromCache(t){try{const e=P.getEnsCache();Y.setItem(Z.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=Y.getItem(Z.IDENTITY_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get identity cache")}return t},getIdentityFromCacheForAddress(t){try{const s=P.getIdentityCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.identity))return s.identity;P.removeIdentityFromCache(t)}catch{console.info("Unable to get identity from cache",t)}},updateIdentityCache(t){try{const e=P.getIdentityCache();e[t.address]={identity:t.identity,timestamp:t.timestamp},Y.setItem(Z.IDENTITY_CACHE,JSON.stringify(e))}catch{console.info("Unable to update identity cache",t)}},removeIdentityFromCache(t){try{const e=P.getIdentityCache();Y.setItem(Z.IDENTITY_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove identity from cache",t)}},clearAddressCache(){try{Y.removeItem(Z.PORTFOLIO_CACHE),Y.removeItem(Z.NATIVE_BALANCE_CACHE),Y.removeItem(Z.ENS_CACHE),Y.removeItem(Z.IDENTITY_CACHE),Y.removeItem(Z.HISTORY_TRANSACTIONS_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(t){try{Y.setItem(Z.PREFERRED_ACCOUNT_TYPES,JSON.stringify(t))}catch{console.info("Unable to set preferred account types",t)}},getPreferredAccountTypes(){try{const t=Y.getItem(Z.PREFERRED_ACCOUNT_TYPES);return t?JSON.parse(t):{}}catch{console.info("Unable to get preferred account types")}return{}},setConnections(t,e){try{const s=P.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(d=>d.address.toLowerCase())),u=o.accounts.filter(d=>!l.has(d.address.toLowerCase()));a.accounts.push(...u)}else r.set(o.connectorId,{...o})}const i={...s,[e]:Array.from(r.values())};Y.setItem(Z.CONNECTIONS,JSON.stringify(i))}catch(s){console.error("Unable to sync connections to storage",s)}},getConnections(){try{const t=Y.getItem(Z.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=P.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())})),Y.setItem(Z.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=Y.getItem(Z.DISCONNECTED_CONNECTOR_IDS);return t?JSON.parse(t):{}}catch{console.info("Unable to get disconnected connector ids")}return{}},addDisconnectedConnectorId(t,e){try{const s=P.getDisconnectedConnectorIds(),n=s[e]??[];n.push(t),Y.setItem(Z.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=P.getDisconnectedConnectorIds();let n=s[e]??[];n=n.filter(r=>r.toLowerCase()!==t.toLowerCase()),Y.setItem(Z.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(P.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=Y.getItem(Z.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=P.getTransactionsCache()[t])==null?void 0:s[e];if(r&&!this.isCacheExpired(r.timestamp,this.cacheExpiry.transactionsHistory))return r.transactions;P.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=P.getTransactionsCache();r[t]={...r[t],[e]:{timestamp:s,transactions:n}},Y.setItem(Z.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=P.getTransactionsCache(),n=(s==null?void 0:s[t])||{},{[e]:r,...i}=n;Y.setItem(Z.HISTORY_TRANSACTIONS_CACHE,JSON.stringify({...s,[t]:i}))}catch{console.info("Unable to remove transactions cache",{address:t,chainId:e})}},getTokenPriceCache(){try{const t=Y.getItem(Z.TOKEN_PRICE_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get token price cache")}return{}},getTokenPriceCacheForAddresses(t){try{const s=P.getTokenPriceCache()[t.join(",")];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.tokenPrice))return s.tokenPrice;P.removeTokenPriceCache(t)}catch{console.info("Unable to get token price cache for addresses",t)}},updateTokenPriceCache(t){try{const e=P.getTokenPriceCache();e[t.addresses.join(",")]={timestamp:t.timestamp,tokenPrice:t.tokenPrice},Y.setItem(Z.TOKEN_PRICE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update token price cache",t)}},removeTokenPriceCache(t){try{const e=P.getTokenPriceCache();Y.setItem(Z.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=Y.getItem(Z.LATEST_APPKIT_VERSION);return t?JSON.parse(t):{}}catch{console.info("Unable to get latest AppKit version cache")}return{}},updateLatestAppKitVersion(t){try{const e=P.getLatestAppKitVersionCache();e.timestamp=t.timestamp,e.version=t.version,Y.setItem(Z.LATEST_APPKIT_VERSION,JSON.stringify(e))}catch{console.info("Unable to update latest AppKit version on local storage",t)}}},V={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 V.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()<=ye.TEN_SEC_MS:!0},isAllowedRetry(t,e=ye.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(V.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()+ye.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(V.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(!V.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()?P.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,V.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?ye.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),u=c+s;return a+u+l}},lo={STORAGE_KEY:"@appkit-wallet/",SMART_ACCOUNT_ENABLED_NETWORKS:"SMART_ACCOUNT_ENABLED_NETWORKS"},Ss={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"}},vg={set(t,e){ca.isClient&&localStorage.setItem(`${lo.STORAGE_KEY}${t}`,e)},get(t){return ca.isClient?localStorage.getItem(`${lo.STORAGE_KEY}${t}`):null},delete(t,e){ca.isClient&&(e?localStorage.removeItem(t):localStorage.removeItem(`${lo.STORAGE_KEY}${t}`))}},ca={isClient:typeof window<"u"};function Eg(t,{strict:e=!0}={}){return!t||typeof t!="string"?!1:e?/^0x[0-9a-fA-F]*$/.test(t):t.startsWith("0x")}function Ol(t){return Eg(t,{strict:!1})?Math.ceil((t.length-2)/2):t.length}const dh="2.42.1";let Ar={getDocsUrl:({docsBaseUrl:t,docsPath:e="",docsSlug:s})=>e?`${t??"https://viem.sh"}${e}${s?`#${s}`:""}`:void 0,version:`viem@${dh}`};class Se extends Error{constructor(e,s={}){var a;const n=(()=>{var c;return s.cause instanceof Se?s.cause.details:(c=s.cause)!=null&&c.message?s.cause.message:s.details})(),r=s.cause instanceof Se&&s.cause.docsPath||s.docsPath,i=(a=Ar.getDocsUrl)==null?void 0:a.call(Ar,{...s,docsPath:r}),o=[e||"An error occurred.","",...s.metaMessages?[...s.metaMessages,""]:[],...i?[`Docs: ${i}`]:[],...n?[`Details: ${n}`]:[],...Ar.version?[`Version: ${Ar.version}`]:[]].join(`
|
|
1
|
+
const __vite__mapDeps=(i,m=__vite__mapDeps,d=(m.f||(m.f=["assets/index-eTCC3Tyz.js","assets/index-Cn_4Xm8q.js","assets/index-CKq5iZx_.js","assets/features-BanUs8Cp.js","assets/basic-D0dwyfjS.js","assets/index-Dp0JciDP.js","assets/w3m-modal-Bj2hrG0i.js"])))=>i.map(i=>d[i]);
|
|
2
|
+
import{_ as vo,a as Sf,e as Mn,x as jc}from"./index-Cn_4Xm8q.js";import{d as Li,s as Eo,a as Rn,c as Nf,b as Tf,k as Of,e as Pf,f as kf,g as El,I as wr,h as Rf,i as Ft,t as bt,j as F,l as ur,C as xf,m as th,n as $f,o as Uf,p as jr,q as Ya,r as br,u as Df,v as Lf,w as Mf,x as Bf,y as jf,z as Ff,A as qf,B as as,D as vr,E as Fc,F as Wf,G as qc,H as Wc,J as Yr,P as Cl,Q as Hf,K as Kf,L as En,M as sh,N as ws,O as os,R as Us,S as nh}from"./index-CKq5iZx_.js";var Al={};const U={WC_NAME_SUFFIX:".reown.id",WC_NAME_SUFFIX_LEGACY:".wcn.id",BLOCKCHAIN_API_RPC_URL:"https://rpc.walletconnect.org",PULSE_API_URL:"https://pulse.walletconnect.org",W3M_API_URL:"https://api.web3modal.org",CONNECTOR_ID:{WALLET_CONNECT:"walletConnect",INJECTED:"injected",WALLET_STANDARD:"announced",COINBASE:"coinbaseWallet",COINBASE_SDK:"coinbaseWalletSDK",SAFE:"safe",LEDGER:"ledger",OKX:"okx",EIP6963:"eip6963",AUTH:"AUTH"},CONNECTOR_NAMES:{AUTH:"Auth"},AUTH_CONNECTOR_SUPPORTED_CHAINS:["eip155","solana"],LIMITS:{PENDING_TRANSACTIONS:99},CHAIN:{EVM:"eip155",SOLANA:"solana",POLKADOT:"polkadot",BITCOIN:"bip122"},CHAIN_NAME_MAP:{eip155:"EVM Networks",solana:"Solana",polkadot:"Polkadot",bip122:"Bitcoin",cosmos:"Cosmos",sui:"Sui",stacks:"Stacks"},ADAPTER_TYPES:{BITCOIN:"bitcoin",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5"},USDT_CONTRACT_ADDRESSES:["0xdac17f958d2ee523a2206206994597c13d831ec7","0xc2132d05d31c914a87c6611c10748aeb04b58e8f","0x9702230a8ea53601f5cd2dc00fdbc13d4df4a8c7","0x919C1c267BC06a7039e03fcc2eF738525769109c","0x48065fbBE25f71C9282ddf5e1cD6D6A887483D5e","0x55d398326f99059fF775485246999027B3197955","0xfd086bc7cd5c481dcc9c85ebe478a1c0b69fcbb9"],SOLANA_SPL_TOKEN_ADDRESSES:{SOL:"So11111111111111111111111111111111111111112"},HTTP_STATUS_CODES:{SERVER_ERROR:500,TOO_MANY_REQUESTS:429,SERVICE_UNAVAILABLE:503,FORBIDDEN:403},UNSUPPORTED_NETWORK_NAME:"Unknown Network",SECURE_SITE_SDK_ORIGIN:(typeof process<"u"&&typeof Al<"u"?Al.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",REMOTE_FEATURES_ALERTS:{MULTI_WALLET_NOT_ENABLED:{DEFAULT:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com."},CONNECTIONS_HOOK:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com to use the useAppKitConnections hook."},CONNECTION_HOOK:{displayMessage:"Multi-Wallet Not Enabled",debugMessage:"Multi-wallet support is not enabled. Please enable it in your AppKit configuration at cloud.reown.com to use the useAppKitConnection hook."}}},IS_DEVELOPMENT:typeof process<"u"&&!1,DEFAULT_ALLOWED_ANCESTORS:["http://localhost:*","https://localhost:*","http://127.0.0.1:*","https://127.0.0.1:*","https://*.pages.dev","https://*.vercel.app","https://*.ngrok-free.app","https://secure-mobile.walletconnect.com","https://secure-mobile.walletconnect.org"]},rh={caipNetworkIdToNumber(t){return t?Number(t.split(":")[1]):void 0},parseEvmChainId(t){return typeof t=="string"?this.caipNetworkIdToNumber(t):t},getNetworksByNamespace(t,e){return(t==null?void 0:t.filter(s=>s.chainNamespace===e))||[]},getFirstNetworkByNamespace(t,e){return this.getNetworksByNamespace(t,e)[0]},getNetworkNameByCaipNetworkId(t,e){var r;if(!e)return;const s=t.find(i=>i.caipNetworkId===e);if(s)return s.name;const[n]=e.split(":");return((r=U.CHAIN_NAME_MAP)==null?void 0:r[n])||void 0}},ih=["eip155","solana","polkadot","bip122","cosmos","sui","stacks"];var zf=20,Vf=1,xn=1e6,Il=1e6,Gf=-7,Yf=21,Jf=!1,Ni="[big.js] ",Bn=Ni+"Invalid ",Wo=Bn+"decimal places",Xf=Bn+"rounding mode",oh=Ni+"Division by zero",_e={},hs=void 0,Zf=/^-?(\d+(\.\d*)?|\.\d+)(e[+-]?\d+)?$/i;function ah(){function t(e){var s=this;if(!(s instanceof t))return e===hs?ah():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(Bn+"value");e=e===0&&1/e<0?"-0":String(e)}Qf(s,e)}s.constructor=t}return t.prototype=_e,t.DP=zf,t.RM=Vf,t.NE=Gf,t.PE=Yf,t.strict=Jf,t.roundDown=0,t.roundHalfUp=1,t.roundHalfEven=2,t.roundUp=3,t}function Qf(t,e){var s,n,r;if(!Zf.test(e))throw Error(Bn+"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 jn(t,e,s,n){var r=t.c;if(s===hs&&(s=t.constructor.RM),s!==0&&s!==1&&s!==2&&s!==3)throw Error(Xf);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]!==hs))),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]!==hs||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 Fn(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}_e.abs=function(){var t=new this.constructor(this);return t.s=1,t};_e.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};_e.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>xn)throw Error(Wo);if(!r[0])throw Error(oh);if(!n[0])return t.s=i,t.c=[t.e=0],t;var a,c,l,u,d,h=r.slice(),p=a=r.length,g=n.length,f=n.slice(0,a),y=f.length,w=t,b=w.c=[],E=0,N=o+(w.e=e.e-t.e)+1;for(w.s=i,i=N<0?0:N,h.unshift(0);y++<a;)f.push(0);do{for(l=0;l<10;l++){if(a!=(y=f.length))u=a>y?1:-1;else for(d=-1,u=0;++d<a;)if(r[d]!=f[d]){u=r[d]>f[d]?1:-1;break}if(u<0){for(c=y==a?r:h;y;){if(f[--y]<c[y]){for(d=y;d&&!f[--d];)f[d]=9;--f[d],f[y]+=10}f[y]-=c[y]}for(;!f[0];)f.shift()}else break}b[E++]=u?l:++l,f[0]&&u?f[y]=n[p]||0:f=[n[p]]}while((p++<g||f[0]!==hs)&&i--);return!b[0]&&E!=1&&(b.shift(),w.e--,N--),E>N&&jn(w,N,s.RM,f[0]!==hs),w};_e.eq=function(t){return this.cmp(t)===0};_e.gt=function(t){return this.cmp(t)>0};_e.gte=function(t){return this.cmp(t)>-1};_e.lt=function(t){return this.cmp(t)<0};_e.lte=function(t){return this.cmp(t)<1};_e.minus=_e.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(),u=i.e,d=t.c,h=t.e;if(!l[0]||!d[0])return d[0]?t.s=-c:l[0]?t=new o(i):t.s=1,t;if(a=u-h){for((r=a<0)?(a=-a,n=l):(h=u,n=d),n.reverse(),c=a;c--;)n.push(0);n.reverse()}else for(s=((r=l.length<d.length)?l:d).length,a=c=0;c<s;c++)if(l[c]!=d[c]){r=l[c]<d[c];break}if(r&&(n=l,l=d,d=n,t.s=-t.s),(c=(s=d.length)-(e=l.length))>0)for(;c--;)l[e++]=0;for(c=e;s>a;){if(l[--s]<d[s]){for(e=s;e&&!l[--e];)l[e]=9;--l[e],l[s]+=10}l[s]-=d[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};_e.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(oh);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)))};_e.neg=function(){var t=new this.constructor(this);return t.s=-t.s,t};_e.plus=_e.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};_e.pow=function(t){var e=this,s=new e.constructor("1"),n=s,r=t<0;if(t!==~~t||t<-Il||t>Il)throw Error(Bn+"exponent");for(r&&(t=-t);t&1&&(n=n.times(e)),t>>=1,!!t;)e=e.times(e);return r?s.div(n):n};_e.prec=function(t,e){if(t!==~~t||t<1||t>xn)throw Error(Bn+"precision");return jn(new this.constructor(this),t,e)};_e.round=function(t,e){if(t===hs)t=0;else if(t!==~~t||t<-xn||t>xn)throw Error(Wo);return jn(new this.constructor(this),t+this.e+1,e)};_e.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(Ni+"No square root");i=Math.sqrt(+Fn(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 jn(t,(r.DP-=4)+t.e+1,r.RM)};_e.times=_e.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};_e.toExponential=function(t,e){var s=this,n=s.c[0];if(t!==hs){if(t!==~~t||t<0||t>xn)throw Error(Wo);for(s=jn(new s.constructor(s),++t,e);s.c.length<t;)s.c.push(0)}return Fn(s,!0,!!n)};_e.toFixed=function(t,e){var s=this,n=s.c[0];if(t!==hs){if(t!==~~t||t<0||t>xn)throw Error(Wo);for(s=jn(new s.constructor(s),t+s.e+1,e),t=t+s.e+1;s.c.length<t;)s.c.push(0)}return Fn(s,!1,!!n)};_e[Symbol.for("nodejs.util.inspect.custom")]=_e.toJSON=_e.toString=function(){var t=this,e=t.constructor;return Fn(t,t.e<=e.NE||t.e>=e.PE,!!t.c[0])};_e.toNumber=function(){var t=+Fn(this,!0,!0);if(this.constructor.strict===!0&&!this.eq(t.toString()))throw Error(Ni+"Imprecise conversion");return t};_e.toPrecision=function(t,e){var s=this,n=s.constructor,r=s.c[0];if(t!==hs){if(t!==~~t||t<1||t>xn)throw Error(Bn+"precision");for(s=jn(new n(s),t,e);s.c.length<t;)s.c.push(0)}return Fn(s,t<=s.e||s.e<=n.NE||s.e>=n.PE,!!r)};_e.valueOf=function(){var t=this,e=t.constructor;if(e.strict===!0)throw Error(Ni+"valueOf disallowed");return Fn(t,t.e<=e.NE||t.e>=e.PE,!0)};var Ds=ah();const eg={bigNumber(t){return t?new Ds(t):new Ds(0)},multiply(t,e){if(t===void 0||e===void 0)return new Ds(0);const s=new Ds(t),n=new Ds(e);return s.times(n)},toFixed(t,e=2){return t===void 0||t===""?new Ds(0).toFixed(e):new Ds(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 Ds(e).toNumber()}},tg=[{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"}]}],sg=[{type:"function",name:"approve",stateMutability:"nonpayable",inputs:[{name:"spender",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]}],ng=[{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"}]}],rg={getERC20Abi:t=>U.USDT_CONTRACT_ADDRESSES.includes(t)?ng:tg,getSwapAbi:()=>sg},Xe={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}}},_s={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(_s.isRpcProviderError(t)){const e=t.code===_s.RPC_ERROR_CODE.USER_REJECTED_REQUEST,s=t.code===_s.RPC_ERROR_CODE.USER_REJECTED_METHODS;return e||s||_s.isUserRejectedMessage(t.message)}return t instanceof Error?_s.isUserRejectedMessage(t.message):!1}};let ig=class extends Error{constructor(e,s){super(s.message,{cause:e}),this.name=_s.PROVIDER_RPC_ERROR_NAME.PROVIDER_RPC,this.code=s.code}},ch=class extends ig{constructor(e){super(e,{code:_s.RPC_ERROR_CODE.USER_REJECTED_REQUEST,message:"User rejected the request"}),this.name=_s.PROVIDER_RPC_ERROR_NAME.USER_REJECTED_REQUEST}};const Z={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"};function oa(t){if(!t)throw new Error("Namespace is required for CONNECTED_CONNECTOR_ID");return`@appkit/${t}:connected_connector_id`}const Y={setItem(t,e){Ur()&&e!==void 0&&localStorage.setItem(t,e)},getItem(t){if(Ur())return localStorage.getItem(t)||void 0},removeItem(t){Ur()&&localStorage.removeItem(t)},clear(){Ur()&&localStorage.clear()}};function Ur(){return typeof window<"u"&&typeof localStorage<"u"}function Co(t,e){return e==="light"?{"--w3m-accent":(t==null?void 0:t["--w3m-accent"])||"hsla(231, 100%, 70%, 1)","--w3m-background":"#fff"}:{"--w3m-accent":(t==null?void 0:t["--w3m-accent"])||"hsla(230, 100%, 67%, 1)","--w3m-background":"#202020"}}const og=Symbol(),_l=Object.getPrototypeOf,Ja=new WeakMap,ag=t=>t&&(Ja.has(t)?Ja.get(t):_l(t)===Object.prototype||_l(t)===Array.prototype),cg=t=>ag(t)&&t[og]||null,Sl=(t,e=!0)=>{Ja.set(t,e)},Ao={},Hc=t=>typeof t=="object"&&t!==null,lg=t=>Hc(t)&&!Ti.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),lh=(t,e)=>{const s=Xa.get(t);if((s==null?void 0:s[0])===e)return s[1];const n=Array.isArray(t)?[]:Object.create(Object.getPrototypeOf(t));return Sl(n,!0),Xa.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(Ti.has(i))Sl(i,!1);else if(nn.has(i)){const[c,l]=nn.get(i);a.value=lh(c,l())}Object.defineProperty(n,r,a)}),Object.preventExtensions(n)},ug=(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&&(Nl(l,o)||Jr.has(o)&&Nl(l,Jr.get(o))))return!0;s(i),Hc(o)&&(o=cg(o)||o);const u=!nn.has(o)&&hg(o)?ke(o):o;return e(i,u),Reflect.set(r,i,u,a),n(["set",[i],o,l]),!0}}),nn=new WeakMap,Ti=new WeakSet,Xa=new WeakMap,co=[1],Jr=new WeakMap;let Nl=Object.is,dg=(t,e)=>new Proxy(t,e),hg=lg,pg=lh,fg=ug;function ke(t={}){if(!Hc(t))throw new Error("object required");const e=Jr.get(t);if(e)return e;let s=co[0];const n=new Set,r=(y,w=++co[0])=>{s!==w&&(i=s=w,n.forEach(b=>b(y,w)))};let i=s;const o=(y=co[0])=>(i!==y&&(i=y,c.forEach(([w])=>{const b=w[1](y);b>s&&(s=b)})),s),a=y=>(w,b)=>{const E=[...w];E[1]=[y,...E[1]],r(E,b)},c=new Map,l=(y,w)=>{const b=!Ti.has(w)&&nn.get(w);if(b){if((Ao?"production":void 0)!=="production"&&c.has(y))throw new Error("prop listener already exists");if(n.size){const E=b[2](a(y));c.set(y,[b,E])}else c.set(y,[b])}},u=y=>{var w;const b=c.get(y);b&&(c.delete(y),(w=b[1])==null||w.call(b))},d=y=>(n.add(y),n.size===1&&c.forEach(([b,E],N)=>{if((Ao?"production":void 0)!=="production"&&E)throw new Error("remove already exists");const x=b[2](a(N));c.set(N,[b,x])}),()=>{n.delete(y),n.size===0&&c.forEach(([b,E],N)=>{E&&(E(),c.set(N,[b]))})});let h=!0;const p=fg(()=>h,l,u,r),g=dg(t,p);Jr.set(t,g);const f=[t,o,d];return nn.set(g,f),Reflect.ownKeys(t).forEach(y=>{const w=Object.getOwnPropertyDescriptor(t,y);"value"in w&&w.writable&&(g[y]=t[y])}),h=!1,g}function Ze(t,e,s){const n=nn.get(t);(Ao?"production":void 0)!=="production"&&!n&&console.warn("Please use proxy object");let r;const i=[],o=n[2];let a=!1;const l=o(u=>{i.push(u),r||(r=Promise.resolve().then(()=>{r=void 0,a&&e(i.splice(0))}))});return a=!0,()=>{a=!1,l()}}function Xr(t){const e=nn.get(t);(Ao?"production":void 0)!=="production"&&!e&&console.warn("Please use proxy object");const[s,n]=e;return pg(s,n())}function Zr(t){return Ti.add(t),t}function gg(){return{proxyStateMap:nn,refSet:Ti,snapCache:Xa,versionHolder:co,proxyCache:Jr}}function Qe(t,e,s,n){let r=t[e];return Ze(t,()=>{const i=t[e];Object.is(r,i)||s(r=i)})}const{proxyStateMap:mg,snapCache:yg}=gg(),Mi=t=>mg.has(t);function wg(t){const e=[];let s=0;const n=new Map,r=new WeakMap,i=()=>{const l=yg.get(a),u=l==null?void 0:l[1];if(u&&!r.has(u)){const d=new Map(n);r.set(u,d)}},o=l=>r.get(l)||n,a={data:e,index:s,epoch:0,get size(){return Mi(this)||i(),o(this).size},get(l){const d=o(this).get(l);if(d===void 0){this.epoch;return}return this.data[d]},has(l){const u=o(this);return this.epoch,u.has(l)},set(l,u){if(!Mi(this))throw new Error("Cannot perform mutations on a snapshot");const d=n.get(l);return d===void 0?(n.set(l,this.index),this.data[this.index++]=u):this.data[d]=u,this.epoch++,this},delete(l){if(!Mi(this))throw new Error("Cannot perform mutations on a snapshot");const u=n.get(l);return u===void 0?!1:(delete this.data[u],n.delete(l),this.epoch++,!0)},clear(){if(!Mi(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((d,h)=>{l(this.data[d],h,this)})},*entries(){this.epoch;const l=o(this);for(const[u,d]of l)yield[u,this.data[d]]},*keys(){this.epoch;const l=o(this);for(const u of l.keys())yield u},*values(){this.epoch;const l=o(this);for(const u of l.values())yield this.data[u]},[Symbol.iterator](){return this.entries()},get[Symbol.toStringTag](){return"Map"},toJSON(){return new Map(this.entries())}},c=ke(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 Tl={};const aa=(typeof process<"u"&&typeof Tl<"u"?Tl.NEXT_PUBLIC_SECURE_SITE_ORIGIN:void 0)||"https://secure.walletconnect.org",uh=[{label:"Meld.io",name:"meld",feeRange:"1-2%",url:"https://meldcrypto.com",supportedChains:["eip155","solana"]}],bg="WXETMuFUQmqqybHuRkSgxv:25B8LJHSfpG6LVjR2ytU5Cwh7Z4Sch2ocoU",ye={FOUR_MINUTES_MS:24e4,TEN_SEC_MS:1e4,FIVE_SEC_MS:5e3,THREE_SEC_MS:3e3,ONE_SEC_MS:1e3,SECURE_SITE:aa,SECURE_SITE_DASHBOARD:`${aa}/dashboard`,SECURE_SITE_FAVICON:`${aa}/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],NATIVE_TOKEN_ADDRESS:{eip155:"0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee",solana:"So11111111111111111111111111111111111111111",polkadot:"0x",bip122:"0x",cosmos:"0x",sui:"0x",stacks:"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},DEFAULT_REMOTE_FEATURES_DISABLED:{email:!1,socials:!1,swaps:!1,onramp:!1,activity:!1,reownBranding:!1,emailCapture:!1,reownAuthentication:!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},DEFAULT_SOCIALS:["google","x","farcaster","discord","apple","github","facebook"],DEFAULT_ACCOUNT_TYPES:{bip122:"payment",eip155:"smartAccount",polkadot:"eoa",solana:"eoa"},ADAPTER_TYPES:{UNIVERSAL:"universal",SOLANA:"solana",WAGMI:"wagmi",ETHERS:"ethers",ETHERS5:"ethers5",BITCOIN:"bitcoin"},SIWX_DEFAULTS:{signOutOnDisconnect:!0}},P={cacheExpiry:{portfolio:3e4,nativeBalance:3e4,ens:3e5,identity:3e5,transactionsHistory:15e3,tokenPrice:15e3,latestAppKitVersion:6048e5},isCacheExpired(t,e){return Date.now()-t>e},getActiveNetworkProps(){const t=P.getActiveNamespace(),e=P.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{Y.setItem(Z.DEEPLINK_CHOICE,JSON.stringify({href:e,name:t}))}catch{console.info("Unable to set WalletConnect deep link")}},getWalletConnectDeepLink(){try{const t=Y.getItem(Z.DEEPLINK_CHOICE);if(t)return JSON.parse(t)}catch{console.info("Unable to get WalletConnect deep link")}},deleteWalletConnectDeepLink(){try{Y.removeItem(Z.DEEPLINK_CHOICE)}catch{console.info("Unable to delete WalletConnect deep link")}},setActiveNamespace(t){try{Y.setItem(Z.ACTIVE_NAMESPACE,t)}catch{console.info("Unable to set active namespace")}},setActiveCaipNetworkId(t){try{Y.setItem(Z.ACTIVE_CAIP_NETWORK_ID,t),P.setActiveNamespace(t.split(":")[0])}catch{console.info("Unable to set active caip network id")}},getActiveCaipNetworkId(){try{return Y.getItem(Z.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to get active caip network id");return}},deleteActiveCaipNetworkId(){try{Y.removeItem(Z.ACTIVE_CAIP_NETWORK_ID)}catch{console.info("Unable to delete active caip network id")}},deleteConnectedConnectorId(t){try{const e=oa(t);Y.removeItem(e)}catch{console.info("Unable to delete connected connector id")}},setAppKitRecent(t){try{const e=P.getRecentWallets();e.find(n=>n.id===t.id)||(e.unshift(t),e.length>2&&e.pop(),Y.setItem(Z.RECENT_WALLETS,JSON.stringify(e)),Y.setItem(Z.RECENT_WALLET,JSON.stringify(t)))}catch{console.info("Unable to set AppKit recent")}},getRecentWallets(){try{const t=Y.getItem(Z.RECENT_WALLETS);return t?JSON.parse(t):[]}catch{console.info("Unable to get AppKit recent")}return[]},getRecentWallet(){try{const t=Y.getItem(Z.RECENT_WALLET);return t?JSON.parse(t):null}catch{console.info("Unable to get AppKit recent")}return null},deleteRecentWallet(){try{Y.removeItem(Z.RECENT_WALLET)}catch{console.info("Unable to delete AppKit recent")}},setConnectedConnectorId(t,e){try{const s=oa(t);Y.setItem(s,e)}catch{console.info("Unable to set Connected Connector Id")}},getActiveNamespace(){try{return Y.getItem(Z.ACTIVE_NAMESPACE)}catch{console.info("Unable to get active namespace")}},getConnectedConnectorId(t){if(t)try{const e=oa(t);return Y.getItem(e)}catch{console.info("Unable to get connected connector id in namespace",t)}},setConnectedSocialProvider(t){try{Y.setItem(Z.CONNECTED_SOCIAL,t)}catch{console.info("Unable to set connected social provider")}},getConnectedSocialProvider(){try{return Y.getItem(Z.CONNECTED_SOCIAL)}catch{console.info("Unable to get connected social provider")}},deleteConnectedSocialProvider(){try{Y.removeItem(Z.CONNECTED_SOCIAL)}catch{console.info("Unable to delete connected social provider")}},getConnectedSocialUsername(){try{return Y.getItem(Z.CONNECTED_SOCIAL_USERNAME)}catch{console.info("Unable to get connected social username")}},getStoredActiveCaipNetworkId(){var s;const t=Y.getItem(Z.ACTIVE_CAIP_NETWORK_ID);return(s=t==null?void 0:t.split(":"))==null?void 0:s[1]},setConnectionStatus(t){try{Y.setItem(Z.CONNECTION_STATUS,t)}catch{console.info("Unable to set connection status")}},getConnectionStatus(){try{return Y.getItem(Z.CONNECTION_STATUS)}catch{return}},getConnectedNamespaces(){try{const t=Y.getItem(Z.CONNECTED_NAMESPACES);return t!=null&&t.length?t.split(","):[]}catch{return[]}},setConnectedNamespaces(t){try{const e=Array.from(new Set(t));Y.setItem(Z.CONNECTED_NAMESPACES,e.join(","))}catch{console.info("Unable to set namespaces in storage")}},addConnectedNamespace(t){try{const e=P.getConnectedNamespaces();e.includes(t)||(e.push(t),P.setConnectedNamespaces(e))}catch{console.info("Unable to add connected namespace")}},removeConnectedNamespace(t){try{const e=P.getConnectedNamespaces(),s=e.indexOf(t);s>-1&&(e.splice(s,1),P.setConnectedNamespaces(e))}catch{console.info("Unable to remove connected namespace")}},getTelegramSocialProvider(){try{return Y.getItem(Z.TELEGRAM_SOCIAL_PROVIDER)}catch{return console.info("Unable to get telegram social provider"),null}},setTelegramSocialProvider(t){try{Y.setItem(Z.TELEGRAM_SOCIAL_PROVIDER,t)}catch{console.info("Unable to set telegram social provider")}},removeTelegramSocialProvider(){try{Y.removeItem(Z.TELEGRAM_SOCIAL_PROVIDER)}catch{console.info("Unable to remove telegram social provider")}},getBalanceCache(){let t={};try{const e=Y.getItem(Z.PORTFOLIO_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromBalanceCache(t){try{const e=P.getBalanceCache();Y.setItem(Z.PORTFOLIO_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove address from balance cache",t)}},getBalanceCacheForCaipAddress(t){try{const s=P.getBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.portfolio))return s.balance;P.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateBalanceCache(t){try{const e=P.getBalanceCache();e[t.caipAddress]=t,Y.setItem(Z.PORTFOLIO_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getNativeBalanceCache(){let t={};try{const e=Y.getItem(Z.NATIVE_BALANCE_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get balance cache")}return t},removeAddressFromNativeBalanceCache(t){try{const e=P.getBalanceCache();Y.setItem(Z.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=P.getNativeBalanceCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.nativeBalance))return s;console.info("Discarding cache for address",t),P.removeAddressFromBalanceCache(t)}catch{console.info("Unable to get balance cache for address",t)}},updateNativeBalanceCache(t){try{const e=P.getNativeBalanceCache();e[t.caipAddress]=t,Y.setItem(Z.NATIVE_BALANCE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update balance cache",t)}},getEnsCache(){let t={};try{const e=Y.getItem(Z.ENS_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get ens name cache")}return t},getEnsFromCacheForAddress(t){try{const s=P.getEnsCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.ens))return s.ens;P.removeEnsFromCache(t)}catch{console.info("Unable to get ens name from cache",t)}},updateEnsCache(t){try{const e=P.getEnsCache();e[t.address]=t,Y.setItem(Z.ENS_CACHE,JSON.stringify(e))}catch{console.info("Unable to update ens name cache",t)}},removeEnsFromCache(t){try{const e=P.getEnsCache();Y.setItem(Z.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=Y.getItem(Z.IDENTITY_CACHE);t=e?JSON.parse(e):{}}catch{console.info("Unable to get identity cache")}return t},getIdentityFromCacheForAddress(t){try{const s=P.getIdentityCache()[t];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.identity))return s.identity;P.removeIdentityFromCache(t)}catch{console.info("Unable to get identity from cache",t)}},updateIdentityCache(t){try{const e=P.getIdentityCache();e[t.address]={identity:t.identity,timestamp:t.timestamp},Y.setItem(Z.IDENTITY_CACHE,JSON.stringify(e))}catch{console.info("Unable to update identity cache",t)}},removeIdentityFromCache(t){try{const e=P.getIdentityCache();Y.setItem(Z.IDENTITY_CACHE,JSON.stringify({...e,[t]:void 0}))}catch{console.info("Unable to remove identity from cache",t)}},clearAddressCache(){try{Y.removeItem(Z.PORTFOLIO_CACHE),Y.removeItem(Z.NATIVE_BALANCE_CACHE),Y.removeItem(Z.ENS_CACHE),Y.removeItem(Z.IDENTITY_CACHE),Y.removeItem(Z.HISTORY_TRANSACTIONS_CACHE)}catch{console.info("Unable to clear address cache")}},setPreferredAccountTypes(t){try{Y.setItem(Z.PREFERRED_ACCOUNT_TYPES,JSON.stringify(t))}catch{console.info("Unable to set preferred account types",t)}},getPreferredAccountTypes(){try{const t=Y.getItem(Z.PREFERRED_ACCOUNT_TYPES);return t?JSON.parse(t):{}}catch{console.info("Unable to get preferred account types")}return{}},setConnections(t,e){try{const s=P.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(d=>d.address.toLowerCase())),u=o.accounts.filter(d=>!l.has(d.address.toLowerCase()));a.accounts.push(...u)}else r.set(o.connectorId,{...o})}const i={...s,[e]:Array.from(r.values())};Y.setItem(Z.CONNECTIONS,JSON.stringify(i))}catch(s){console.error("Unable to sync connections to storage",s)}},getConnections(){try{const t=Y.getItem(Z.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=P.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())})),Y.setItem(Z.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=Y.getItem(Z.DISCONNECTED_CONNECTOR_IDS);return t?JSON.parse(t):{}}catch{console.info("Unable to get disconnected connector ids")}return{}},addDisconnectedConnectorId(t,e){try{const s=P.getDisconnectedConnectorIds(),n=s[e]??[];n.push(t),Y.setItem(Z.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=P.getDisconnectedConnectorIds();let n=s[e]??[];n=n.filter(r=>r.toLowerCase()!==t.toLowerCase()),Y.setItem(Z.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(P.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=Y.getItem(Z.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=P.getTransactionsCache()[t])==null?void 0:s[e];if(r&&!this.isCacheExpired(r.timestamp,this.cacheExpiry.transactionsHistory))return r.transactions;P.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=P.getTransactionsCache();r[t]={...r[t],[e]:{timestamp:s,transactions:n}},Y.setItem(Z.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=P.getTransactionsCache(),n=(s==null?void 0:s[t])||{},{[e]:r,...i}=n;Y.setItem(Z.HISTORY_TRANSACTIONS_CACHE,JSON.stringify({...s,[t]:i}))}catch{console.info("Unable to remove transactions cache",{address:t,chainId:e})}},getTokenPriceCache(){try{const t=Y.getItem(Z.TOKEN_PRICE_CACHE);return t?JSON.parse(t):{}}catch{console.info("Unable to get token price cache")}return{}},getTokenPriceCacheForAddresses(t){try{const s=P.getTokenPriceCache()[t.join(",")];if(s&&!this.isCacheExpired(s.timestamp,this.cacheExpiry.tokenPrice))return s.tokenPrice;P.removeTokenPriceCache(t)}catch{console.info("Unable to get token price cache for addresses",t)}},updateTokenPriceCache(t){try{const e=P.getTokenPriceCache();e[t.addresses.join(",")]={timestamp:t.timestamp,tokenPrice:t.tokenPrice},Y.setItem(Z.TOKEN_PRICE_CACHE,JSON.stringify(e))}catch{console.info("Unable to update token price cache",t)}},removeTokenPriceCache(t){try{const e=P.getTokenPriceCache();Y.setItem(Z.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=Y.getItem(Z.LATEST_APPKIT_VERSION);return t?JSON.parse(t):{}}catch{console.info("Unable to get latest AppKit version cache")}return{}},updateLatestAppKitVersion(t){try{const e=P.getLatestAppKitVersionCache();e.timestamp=t.timestamp,e.version=t.version,Y.setItem(Z.LATEST_APPKIT_VERSION,JSON.stringify(e))}catch{console.info("Unable to update latest AppKit version on local storage",t)}}},V={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 V.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()<=ye.TEN_SEC_MS:!0},isAllowedRetry(t,e=ye.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(V.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()+ye.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(V.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(!V.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()?P.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,V.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?ye.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),u=c+s;return a+u+l}},lo={STORAGE_KEY:"@appkit-wallet/",SMART_ACCOUNT_ENABLED_NETWORKS:"SMART_ACCOUNT_ENABLED_NETWORKS"},Ss={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"}},vg={set(t,e){ca.isClient&&localStorage.setItem(`${lo.STORAGE_KEY}${t}`,e)},get(t){return ca.isClient?localStorage.getItem(`${lo.STORAGE_KEY}${t}`):null},delete(t,e){ca.isClient&&(e?localStorage.removeItem(t):localStorage.removeItem(`${lo.STORAGE_KEY}${t}`))}},ca={isClient:typeof window<"u"};function Eg(t,{strict:e=!0}={}){return!t||typeof t!="string"?!1:e?/^0x[0-9a-fA-F]*$/.test(t):t.startsWith("0x")}function Ol(t){return Eg(t,{strict:!1})?Math.ceil((t.length-2)/2):t.length}const dh="2.42.1";let Ar={getDocsUrl:({docsBaseUrl:t,docsPath:e="",docsSlug:s})=>e?`${t??"https://viem.sh"}${e}${s?`#${s}`:""}`:void 0,version:`viem@${dh}`};class Se extends Error{constructor(e,s={}){var a;const n=(()=>{var c;return s.cause instanceof Se?s.cause.details:(c=s.cause)!=null&&c.message?s.cause.message:s.details})(),r=s.cause instanceof Se&&s.cause.docsPath||s.docsPath,i=(a=Ar.getDocsUrl)==null?void 0:a.call(Ar,{...s,docsPath:r}),o=[e||"An error occurred.","",...s.metaMessages?[...s.metaMessages,""]:[],...i?[`Docs: ${i}`]:[],...n?[`Details: ${n}`]:[],...Ar.version?[`Version: ${Ar.version}`]:[]].join(`
|
|
3
3
|
`);super(o,s.cause?{cause:s.cause}:void 0),Object.defineProperty(this,"details",{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,"metaMessages",{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,"version",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"BaseError"}),this.details=n,this.docsPath=r,this.metaMessages=s.metaMessages,this.name=s.name??this.name,this.shortMessage=e,this.version=dh}walk(e){return hh(this,e)}}function hh(t,e){return e!=null&&e(t)?t:t&&typeof t=="object"&&"cause"in t&&t.cause!==void 0?hh(t.cause,e):e?null:t}class BN extends Se{constructor({offset:e,position:s,size:n}){super(`Slice ${s==="start"?"starting":"ending"} at offset "${e}" is out-of-bounds (size: ${n}).`,{name:"SliceOffsetOutOfBoundsError"})}}class ph extends Se{constructor({size:e,targetSize:s,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} size (${e}) exceeds padding size (${s}).`,{name:"SizeExceedsPaddingSizeError"})}}class jN extends Se{constructor({size:e,targetSize:s,type:n}){super(`${n.charAt(0).toUpperCase()}${n.slice(1).toLowerCase()} is expected to be ${s} ${n} long, but is ${e} ${n} long.`,{name:"InvalidBytesLengthError"})}}function Kc(t,{dir:e,size:s=32}={}){return typeof t=="string"?Cg(t,{dir:e,size:s}):Ag(t,{dir:e,size:s})}function Cg(t,{dir:e,size:s=32}={}){if(s===null)return t;const n=t.replace("0x","");if(n.length>s*2)throw new ph({size:Math.ceil(n.length/2),targetSize:s,type:"hex"});return`0x${n[e==="right"?"padEnd":"padStart"](s*2,"0")}`}function Ag(t,{dir:e,size:s=32}={}){if(s===null)return t;if(t.length>s)throw new ph({size:t.length,targetSize:s,type:"bytes"});const n=new Uint8Array(s);for(let r=0;r<s;r++){const i=e==="right";n[i?r:s-r-1]=t[i?r:t.length-r-1]}return n}class Ig extends Se{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})`}`,{name:"IntegerOutOfRangeError"})}}class FN extends Se{constructor(e){super(`Bytes value "${e}" is not a valid boolean. The bytes array must contain a single byte of either a 0 or 1 value.`,{name:"InvalidBytesBooleanError"})}}class _g extends Se{constructor(e){super(`Hex value "${e}" is not a valid boolean. The hex value must be "0x0" (false) or "0x1" (true).`,{name:"InvalidHexBooleanError"})}}class Sg extends Se{constructor({givenSize:e,maxSize:s}){super(`Size cannot exceed ${s} bytes. Given size: ${e} bytes.`,{name:"SizeOverflowError"})}}function la(t,{dir:e="left"}={}){let s=typeof t=="string"?t.replace("0x",""):t,n=0;for(let r=0;r<s.length-1&&s[e==="left"?r:s.length-r-1].toString()==="0";r++)n++;return s=e==="left"?s.slice(n):s.slice(0,s.length-n),typeof t=="string"?(s.length===1&&e==="right"&&(s=`${s}0`),`0x${s.length%2===1?`0${s}`:s}`):s}function Ho(t,{size:e}){if(Ol(t)>e)throw new Sg({givenSize:Ol(t),maxSize:e})}function Ng(t,e={}){const{signed:s}=e;e.size&&Ho(t,{size:e.size});const n=BigInt(t);if(!s)return n;const r=(t.length-2)/2,i=(1n<<BigInt(r)*8n-1n)-1n;return n<=i?n:n-BigInt(`0x${"f".padStart(r*2,"f")}`)-1n}function qN(t,e={}){let s=t;if(e.size&&(Ho(s,{size:e.size}),s=la(s)),la(s)==="0x00")return!1;if(la(s)==="0x01")return!0;throw new _g(s)}function WN(t,e={}){return Number(Ng(t,e))}const Tg=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function Pl(t,e={}){return typeof t=="number"||typeof t=="bigint"?Pg(t,e):typeof t=="string"?gh(t,e):typeof t=="boolean"?Og(t,e):fh(t,e)}function Og(t,e={}){const s=`0x${Number(t)}`;return typeof e.size=="number"?(Ho(s,{size:e.size}),Kc(s,{size:e.size})):s}function fh(t,e={}){let s="";for(let r=0;r<t.length;r++)s+=Tg[t[r]];const n=`0x${s}`;return typeof e.size=="number"?(Ho(n,{size:e.size}),Kc(n,{dir:"right",size:e.size})):n}function Pg(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 c=typeof t=="bigint"?"n":"";throw new Ig({max:i?`${i}${c}`:void 0,min:`${o}${c}`,signed:s,size:n,value:`${t}${c}`})}const a=`0x${(s&&r<0?(1n<<BigInt(n*8))+BigInt(r):r).toString(16)}`;return n?Kc(a,{size:n}):a}const kg=new TextEncoder;function gh(t,e={}){const s=kg.encode(t);return fh(s,e)}class Rg 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 On=(t,e,s)=>JSON.stringify(t,(n,r)=>typeof r=="bigint"?r.toString():r,s),HN={gwei:9,wei:18},xg={ether:-9,wei:9};function zc(t,e){let s=t.toString();const n=s.startsWith("-");n&&(s=s.slice(1)),s=s.padStart(e,"0");let[r,i]=[s.slice(0,s.length-e),s.slice(s.length-e)];return i=i.replace(/(0+)$/,""),`${n?"-":""}${r||"0"}${i?`.${i}`:""}`}function Io(t,e="wei"){return zc(t,xg[e])}const KN=t=>t,Vc=t=>t;class Fr extends Se{constructor({body:e,cause:s,details:n,headers:r,status:i,url:o}){super("HTTP request failed.",{cause:s,details:n,metaMessages:[i&&`Status: ${i}`,`URL: ${Vc(o)}`,e&&`Request body: ${On(e)}`].filter(Boolean),name:"HttpRequestError"}),Object.defineProperty(this,"body",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"headers",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"status",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"url",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.body=e,this.headers=r,this.status=i,this.url=o}}class mh extends Se{constructor({body:e,error:s,url:n}){super("RPC Request failed.",{cause:s,details:s.message,metaMessages:[`URL: ${Vc(n)}`,`Request body: ${On(e)}`],name:"RpcRequestError"}),Object.defineProperty(this,"code",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"data",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),Object.defineProperty(this,"url",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.code=s.code,this.data=s.data,this.url=n}}class kl extends Se{constructor({body:e,url:s}){super("The request took too long to respond.",{details:"The request timed out.",metaMessages:[`URL: ${Vc(s)}`,`Request body: ${On(e)}`],name:"TimeoutError"}),Object.defineProperty(this,"url",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.url=s}}const $g=-1;class vt extends Se{constructor(e,{code:s,docsPath:n,metaMessages:r,name:i,shortMessage:o}){super(o,{cause:e,docsPath:n,metaMessages:r||(e==null?void 0:e.metaMessages),name:i||"RpcError"}),Object.defineProperty(this,"code",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.name=i||e.name,this.code=e instanceof mh?e.code:s??$g}}class Pt extends vt{constructor(e,s){super(e,s),Object.defineProperty(this,"data",{enumerable:!0,configurable:!0,writable:!0,value:void 0}),this.data=s.data}}class Qr extends vt{constructor(e){super(e,{code:Qr.code,name:"ParseRpcError",shortMessage:"Invalid JSON was received by the server. An error occurred on the server while parsing the JSON text."})}}Object.defineProperty(Qr,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32700});class ei extends vt{constructor(e){super(e,{code:ei.code,name:"InvalidRequestRpcError",shortMessage:"JSON is not a valid request object."})}}Object.defineProperty(ei,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32600});class ti extends vt{constructor(e,{method:s}={}){super(e,{code:ti.code,name:"MethodNotFoundRpcError",shortMessage:`The method${s?` "${s}"`:""} does not exist / is not available.`})}}Object.defineProperty(ti,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32601});class si extends vt{constructor(e){super(e,{code:si.code,name:"InvalidParamsRpcError",shortMessage:["Invalid parameters were provided to the RPC method.","Double check you have provided the correct parameters."].join(`
|
|
4
4
|
`)})}}Object.defineProperty(si,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32602});class dr extends vt{constructor(e){super(e,{code:dr.code,name:"InternalRpcError",shortMessage:"An internal error was received."})}}Object.defineProperty(dr,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32603});class ni extends vt{constructor(e){super(e,{code:ni.code,name:"InvalidInputRpcError",shortMessage:["Missing or invalid parameters.","Double check you have provided the correct parameters."].join(`
|
|
5
5
|
`)})}}Object.defineProperty(ni,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32e3});class ri extends vt{constructor(e){super(e,{code:ri.code,name:"ResourceNotFoundRpcError",shortMessage:"Requested resource not found."}),Object.defineProperty(this,"name",{enumerable:!0,configurable:!0,writable:!0,value:"ResourceNotFoundRpcError"})}}Object.defineProperty(ri,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32001});class ii extends vt{constructor(e){super(e,{code:ii.code,name:"ResourceUnavailableRpcError",shortMessage:"Requested resource not available."})}}Object.defineProperty(ii,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32002});class hr extends vt{constructor(e){super(e,{code:hr.code,name:"TransactionRejectedRpcError",shortMessage:"Transaction creation failed."})}}Object.defineProperty(hr,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32003});class Cn extends vt{constructor(e,{method:s}={}){super(e,{code:Cn.code,name:"MethodNotSupportedRpcError",shortMessage:`Method${s?` "${s}"`:""} is not supported.`})}}Object.defineProperty(Cn,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32004});class pr extends vt{constructor(e){super(e,{code:pr.code,name:"LimitExceededRpcError",shortMessage:"Request exceeds defined limit."})}}Object.defineProperty(pr,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32005});class oi extends vt{constructor(e){super(e,{code:oi.code,name:"JsonRpcVersionUnsupportedError",shortMessage:"Version of JSON-RPC protocol is not supported."})}}Object.defineProperty(oi,"code",{enumerable:!0,configurable:!0,writable:!0,value:-32006});class Pn extends Pt{constructor(e){super(e,{code:Pn.code,name:"UserRejectedRequestError",shortMessage:"User rejected the request."})}}Object.defineProperty(Pn,"code",{enumerable:!0,configurable:!0,writable:!0,value:4001});class ai extends Pt{constructor(e){super(e,{code:ai.code,name:"UnauthorizedProviderError",shortMessage:"The requested method and/or account has not been authorized by the user."})}}Object.defineProperty(ai,"code",{enumerable:!0,configurable:!0,writable:!0,value:4100});class ci extends Pt{constructor(e,{method:s}={}){super(e,{code:ci.code,name:"UnsupportedProviderMethodError",shortMessage:`The Provider does not support the requested method${s?` " ${s}"`:""}.`})}}Object.defineProperty(ci,"code",{enumerable:!0,configurable:!0,writable:!0,value:4200});class li extends Pt{constructor(e){super(e,{code:li.code,name:"ProviderDisconnectedError",shortMessage:"The Provider is disconnected from all chains."})}}Object.defineProperty(li,"code",{enumerable:!0,configurable:!0,writable:!0,value:4900});class ui extends Pt{constructor(e){super(e,{code:ui.code,name:"ChainDisconnectedError",shortMessage:"The Provider is not connected to the requested chain."})}}Object.defineProperty(ui,"code",{enumerable:!0,configurable:!0,writable:!0,value:4901});class di extends Pt{constructor(e){super(e,{code:di.code,name:"SwitchChainError",shortMessage:"An error occurred when attempting to switch chain."})}}Object.defineProperty(di,"code",{enumerable:!0,configurable:!0,writable:!0,value:4902});class hi extends Pt{constructor(e){super(e,{code:hi.code,name:"UnsupportedNonOptionalCapabilityError",shortMessage:"This Wallet does not support a capability that was not marked as optional."})}}Object.defineProperty(hi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5700});class pi extends Pt{constructor(e){super(e,{code:pi.code,name:"UnsupportedChainIdError",shortMessage:"This Wallet does not support the requested chain ID."})}}Object.defineProperty(pi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5710});class fi extends Pt{constructor(e){super(e,{code:fi.code,name:"DuplicateIdError",shortMessage:"There is already a bundle submitted with this ID."})}}Object.defineProperty(fi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5720});class gi extends Pt{constructor(e){super(e,{code:gi.code,name:"UnknownBundleIdError",shortMessage:"This bundle id is unknown / has not been submitted"})}}Object.defineProperty(gi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5730});class mi extends Pt{constructor(e){super(e,{code:mi.code,name:"BundleTooLargeError",shortMessage:"The call bundle is too large for the Wallet to process."})}}Object.defineProperty(mi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5740});class yi extends Pt{constructor(e){super(e,{code:yi.code,name:"AtomicReadyWalletRejectedUpgradeError",shortMessage:"The Wallet can support atomicity after an upgrade, but the user rejected the upgrade."})}}Object.defineProperty(yi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5750});class wi extends Pt{constructor(e){super(e,{code:wi.code,name:"AtomicityNotSupportedError",shortMessage:"The wallet does not support atomic execution but the request requires it."})}}Object.defineProperty(wi,"code",{enumerable:!0,configurable:!0,writable:!0,value:5760});class Ug extends vt{constructor(e){super(e,{name:"UnknownRpcError",shortMessage:"An unknown RPC error occurred."})}}class Gc extends Se{constructor({cause:e,message:s}={}){var r;const n=(r=s==null?void 0:s.replace("execution reverted: ",""))==null?void 0:r.replace("execution reverted","");super(`Execution reverted ${n?`with reason: ${n}`:"for an unknown reason"}.`,{cause:e,name:"ExecutionRevertedError"})}}Object.defineProperty(Gc,"code",{enumerable:!0,configurable:!0,writable:!0,value:3});Object.defineProperty(Gc,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/execution reverted/});class Dg extends Se{constructor({cause:e,maxFeePerGas:s}={}){super(`The fee cap (\`maxFeePerGas\`${s?` = ${Io(s)} gwei`:""}) cannot be higher than the maximum allowed value (2^256-1).`,{cause:e,name:"FeeCapTooHighError"})}}Object.defineProperty(Dg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/max fee per gas higher than 2\^256-1|fee cap higher than 2\^256-1/});class Lg extends Se{constructor({cause:e,maxFeePerGas:s}={}){super(`The fee cap (\`maxFeePerGas\`${s?` = ${Io(s)}`:""} gwei) cannot be lower than the block base fee.`,{cause:e,name:"FeeCapTooLowError"})}}Object.defineProperty(Lg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/max fee per gas less than block base fee|fee cap less than block base fee|transaction is outdated/});class Mg extends Se{constructor({cause:e,nonce:s}={}){super(`Nonce provided for the transaction ${s?`(${s}) `:""}is higher than the next one expected.`,{cause:e,name:"NonceTooHighError"})}}Object.defineProperty(Mg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/nonce too high/});class Bg extends Se{constructor({cause:e,nonce:s}={}){super([`Nonce provided for the transaction ${s?`(${s}) `:""}is lower than the current nonce of the account.`,"Try increasing the nonce or find the latest nonce with `getTransactionCount`."].join(`
|
|
@@ -7,7 +7,7 @@ import{_ as vo,a as Sf,e as Mn,x as jc}from"./index-DeV-SOTm.js";import{d as Li,
|
|
|
7
7
|
`),{cause:e,metaMessages:["This error could arise when the account does not have enough funds to:"," - pay for the total gas fee,"," - pay for the value to send."," ","The cost of the transaction is calculated as `gas * gas fee + value`, where:"," - `gas` is the amount of gas needed for transaction to execute,"," - `gas fee` is the gas fee,"," - `value` is the amount of ether to send to the recipient."],name:"InsufficientFundsError"})}}Object.defineProperty(Fg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/insufficient funds|exceeds transaction sender account balance/});class qg extends Se{constructor({cause:e,gas:s}={}){super(`The amount of gas ${s?`(${s}) `:""}provided for the transaction exceeds the limit allowed for the block.`,{cause:e,name:"IntrinsicGasTooHighError"})}}Object.defineProperty(qg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/intrinsic gas too high|gas limit reached/});class Wg extends Se{constructor({cause:e,gas:s}={}){super(`The amount of gas ${s?`(${s}) `:""}provided for the transaction is too low.`,{cause:e,name:"IntrinsicGasTooLowError"})}}Object.defineProperty(Wg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/intrinsic gas too low/});class Hg extends Se{constructor({cause:e}){super("The transaction type is not supported for this chain.",{cause:e,name:"TransactionTypeNotSupportedError"})}}Object.defineProperty(Hg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/transaction type not valid/});class Kg extends Se{constructor({cause:e,maxPriorityFeePerGas:s,maxFeePerGas:n}={}){super([`The provided tip (\`maxPriorityFeePerGas\`${s?` = ${Io(s)} gwei`:""}) cannot be higher than the fee cap (\`maxFeePerGas\`${n?` = ${Io(n)} gwei`:""}).`].join(`
|
|
8
8
|
`),{cause:e,name:"TipAboveFeeCapError"})}}Object.defineProperty(Kg,"nodeMessage",{enumerable:!0,configurable:!0,writable:!0,value:/max priority fee per gas higher than max fee per gas|tip higher than fee cap/});class zN extends Se{constructor({cause:e}){super(`An error occurred while executing: ${e==null?void 0:e.shortMessage}`,{cause:e,name:"UnknownNodeError"})}}const VN=[{inputs:[{components:[{name:"target",type:"address"},{name:"allowFailure",type:"bool"},{name:"callData",type:"bytes"}],name:"calls",type:"tuple[]"}],name:"aggregate3",outputs:[{components:[{name:"success",type:"bool"},{name:"returnData",type:"bytes"}],name:"returnData",type:"tuple[]"}],stateMutability:"view",type:"function"},{inputs:[],name:"getCurrentBlockTimestamp",outputs:[{internalType:"uint256",name:"timestamp",type:"uint256"}],stateMutability:"view",type:"function"}],GN=[{name:"query",type:"function",stateMutability:"view",inputs:[{type:"tuple[]",name:"queries",components:[{type:"address",name:"sender"},{type:"string[]",name:"urls"},{type:"bytes",name:"data"}]}],outputs:[{type:"bool[]",name:"failures"},{type:"bytes[]",name:"responses"}]},{name:"HttpError",type:"error",inputs:[{type:"uint16",name:"status"},{type:"string",name:"message"}]}],yh=[{inputs:[{name:"dns",type:"bytes"}],name:"DNSDecodingFailed",type:"error"},{inputs:[{name:"ens",type:"string"}],name:"DNSEncodingFailed",type:"error"},{inputs:[],name:"EmptyAddress",type:"error"},{inputs:[{name:"status",type:"uint16"},{name:"message",type:"string"}],name:"HttpError",type:"error"},{inputs:[],name:"InvalidBatchGatewayResponse",type:"error"},{inputs:[{name:"errorData",type:"bytes"}],name:"ResolverError",type:"error"},{inputs:[{name:"name",type:"bytes"},{name:"resolver",type:"address"}],name:"ResolverNotContract",type:"error"},{inputs:[{name:"name",type:"bytes"}],name:"ResolverNotFound",type:"error"},{inputs:[{name:"primary",type:"string"},{name:"primaryAddress",type:"bytes"}],name:"ReverseAddressMismatch",type:"error"},{inputs:[{internalType:"bytes4",name:"selector",type:"bytes4"}],name:"UnsupportedResolverProfile",type:"error"}],YN=[...yh,{name:"resolveWithGateways",type:"function",stateMutability:"view",inputs:[{name:"name",type:"bytes"},{name:"data",type:"bytes"},{name:"gateways",type:"string[]"}],outputs:[{name:"",type:"bytes"},{name:"address",type:"address"}]}],JN=[...yh,{name:"reverseWithGateways",type:"function",stateMutability:"view",inputs:[{type:"bytes",name:"reverseName"},{type:"uint256",name:"coinType"},{type:"string[]",name:"gateways"}],outputs:[{type:"string",name:"resolvedName"},{type:"address",name:"resolver"},{type:"address",name:"reverseResolver"}]}],XN=[{name:"text",type:"function",stateMutability:"view",inputs:[{name:"name",type:"bytes32"},{name:"key",type:"string"}],outputs:[{name:"",type:"string"}]}],ZN=[{name:"addr",type:"function",stateMutability:"view",inputs:[{name:"name",type:"bytes32"}],outputs:[{name:"",type:"address"}]},{name:"addr",type:"function",stateMutability:"view",inputs:[{name:"name",type:"bytes32"},{name:"coinType",type:"uint256"}],outputs:[{name:"",type:"bytes"}]}],QN=[{name:"isValidSignature",type:"function",stateMutability:"view",inputs:[{name:"hash",type:"bytes32"},{name:"signature",type:"bytes"}],outputs:[{name:"",type:"bytes4"}]}],eT=[{inputs:[{name:"_signer",type:"address"},{name:"_hash",type:"bytes32"},{name:"_signature",type:"bytes"}],stateMutability:"nonpayable",type:"constructor"},{inputs:[{name:"_signer",type:"address"},{name:"_hash",type:"bytes32"},{name:"_signature",type:"bytes"}],outputs:[{type:"bool"}],stateMutability:"nonpayable",type:"function",name:"isValidSig"}],Bi=[{type:"event",name:"Approval",inputs:[{indexed:!0,name:"owner",type:"address"},{indexed:!0,name:"spender",type:"address"},{indexed:!1,name:"value",type:"uint256"}]},{type:"event",name:"Transfer",inputs:[{indexed:!0,name:"from",type:"address"},{indexed:!0,name:"to",type:"address"},{indexed:!1,name:"value",type:"uint256"}]},{type:"function",name:"allowance",stateMutability:"view",inputs:[{name:"owner",type:"address"},{name:"spender",type:"address"}],outputs:[{type:"uint256"}]},{type:"function",name:"approve",stateMutability:"nonpayable",inputs:[{name:"spender",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]},{type:"function",name:"balanceOf",stateMutability:"view",inputs:[{name:"account",type:"address"}],outputs:[{type:"uint256"}]},{type:"function",name:"decimals",stateMutability:"view",inputs:[],outputs:[{type:"uint8"}]},{type:"function",name:"name",stateMutability:"view",inputs:[],outputs:[{type:"string"}]},{type:"function",name:"symbol",stateMutability:"view",inputs:[],outputs:[{type:"string"}]},{type:"function",name:"totalSupply",stateMutability:"view",inputs:[],outputs:[{type:"uint256"}]},{type:"function",name:"transfer",stateMutability:"nonpayable",inputs:[{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]},{type:"function",name:"transferFrom",stateMutability:"nonpayable",inputs:[{name:"sender",type:"address"},{name:"recipient",type:"address"},{name:"amount",type:"uint256"}],outputs:[{type:"bool"}]}];function zg(){let t=()=>{},e=()=>{};return{promise:new Promise((n,r)=>{t=n,e=r}),resolve:t,reject:e}}const ua=new Map;function Vg({fn:t,id:e,shouldSplitBatch:s,wait:n=0,sort:r}){const i=async()=>{const u=c();o();const d=u.map(({args:h})=>h);d.length!==0&&t(d).then(h=>{r&&Array.isArray(h)&&h.sort(r);for(let p=0;p<u.length;p++){const{resolve:g}=u[p];g==null||g([h[p],h])}}).catch(h=>{for(let p=0;p<u.length;p++){const{reject:g}=u[p];g==null||g(h)}})},o=()=>ua.delete(e),a=()=>c().map(({args:u})=>u),c=()=>ua.get(e)||[],l=u=>ua.set(e,[...c(),u]);return{flush:o,async schedule(u){const{promise:d,resolve:h,reject:p}=zg();return(s==null?void 0:s([...a(),u]))&&i(),c().length>0?(l({args:u,resolve:h,reject:p}),d):(l({args:u,resolve:h,reject:p}),setTimeout(i,n),d)}}}async function wh(t){return new Promise(e=>setTimeout(e,t))}function Gg(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 u=typeof e=="function"?e({count:a,error:l}):e;u&&await wh(u),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 Za=256;let ji=Za,Fi;function Yg(t=11){if(!Fi||ji+t>Za*2){Fi="",ji=0;for(let e=0;e<Za;e++)Fi+=(256+Math.random()*256|0).toString(16).substring(1)}return Fi.substring(ji,ji+++t)}const qi=new Rg(8192);function Jg(t,{enabled:e=!0,id:s}){if(!e||!s)return t();if(qi.get(s))return qi.get(s);const n=t().finally(()=>qi.delete(s));return qi.set(s,n),n}function Xg(t,e={}){return async(s,n={})=>{var d;const{dedupe:r=!1,methods:i,retryDelay:o=150,retryCount:a=3,uid:c}={...e,...n},{method:l}=s;if((d=i==null?void 0:i.exclude)!=null&&d.includes(l))throw new Cn(new Error("method not supported"),{method:l});if(i!=null&&i.include&&!i.include.includes(l))throw new Cn(new Error("method not supported"),{method:l});const u=r?gh(`${c}.${On(s)}`):void 0;return Jg(()=>Gg(async()=>{try{return await t(s)}catch(h){const p=h;switch(p.code){case Qr.code:throw new Qr(p);case ei.code:throw new ei(p);case ti.code:throw new ti(p,{method:s.method});case si.code:throw new si(p);case dr.code:throw new dr(p);case ni.code:throw new ni(p);case ri.code:throw new ri(p);case ii.code:throw new ii(p);case hr.code:throw new hr(p);case Cn.code:throw new Cn(p,{method:s.method});case pr.code:throw new pr(p);case oi.code:throw new oi(p);case Pn.code:throw new Pn(p);case ai.code:throw new ai(p);case ci.code:throw new ci(p);case li.code:throw new li(p);case ui.code:throw new ui(p);case di.code:throw new di(p);case hi.code:throw new hi(p);case pi.code:throw new pi(p);case fi.code:throw new fi(p);case gi.code:throw new gi(p);case mi.code:throw new mi(p);case yi.code:throw new yi(p);case wi.code:throw new wi(p);case 5e3:throw new Pn(p);default:throw h instanceof Se?h:new Ug(p)}}},{delay:({count:h,error:p})=>{var g;if(p&&p instanceof Fr){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})=>Zg(h)}),{enabled:r,id:u})}}function Zg(t){return"code"in t&&typeof t.code=="number"?t.code===-1||t.code===pr.code||t.code===dr.code:t instanceof Fr&&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 Qg(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 em(){return{current:0,take(){return this.current++},reset(){this.current=0}}}const Rl=em();function tm(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:u,signal:d}=c;try{const p=await Qg(async({signal:f})=>{const y={...c,body:Array.isArray(n)?On(n.map(N=>({jsonrpc:"2.0",id:N.id??Rl.take(),...N}))):On({jsonrpc:"2.0",id:n.id??Rl.take(),...n}),headers:{"Content-Type":"application/json",...l},method:u||"POST",signal:d||(a>0?f:null)},w=new Request(t,y),b=await(i==null?void 0:i(w,y))??{...y,url:t};return await r(b.url??t,b)},{errorInstance:new kl({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 Fr({body:n,details:On(g.error)||p.statusText,headers:p.headers,status:p.status,url:t});return g}catch(p){throw p instanceof Fr||p instanceof kl?p:new Fr({body:n,cause:p,url:t})}}}}function bh({key:t,methods:e,name:s,request:n,retryCount:r=3,retryDelay:i=150,timeout:o,type:a},c){const l=Yg();return{config:{key:t,methods:e,name:s,request:n,retryCount:r,retryDelay:i,timeout:o,type:a},request:Xg(n,{methods:e,retryCount:r,retryDelay:i,uid:l}),value:c}}function xl(t,e={}){const{key:s="fallback",name:n="Fallback",rank:r=!1,shouldThrow:i=sm,retryCount:o,retryDelay:a}=e;return({chain:c,pollingInterval:l=4e3,timeout:u,...d})=>{let h=t,p=()=>{};const g=bh({key:s,name:n,async request({method:f,params:y}){let w;const b=async(E=0)=>{const N=h[E]({...d,chain:c,retryCount:0,timeout:u});try{const x=await N.request({method:f,params:y});return p({method:f,params:y,response:x,transport:N,status:"success"}),x}catch(x){if(p({error:x,method:f,params:y,transport:N,status:"error"}),i(x)||E===h.length-1||(w??(w=h.slice(E+1).some($=>{const{include:W,exclude:G}=$({chain:c}).config.methods||{};return W?W.includes(f):G?!G.includes(f):!0})),!w))throw x;return b(E+1)}};return b()},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:{};nm({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 sm(t){return!!("code"in t&&typeof t.code=="number"&&(t.code===hr.code||t.code===Pn.code||Gc.nodeMessage.test(t.message)||t.code===5e3))}function nm({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,u=[],d=async()=>{const h=await Promise.all(o.map(async f=>{const y=f({chain:t,retryCount:0,timeout:i}),w=Date.now();let b,E;try{await(n?n({transport:y}):y.request({method:"net_listening"})),E=1}catch{E=0}finally{b=Date.now()}return{latency:b-w,success:E}}));u.push(h),u.length>r&&u.shift();const p=Math.max(...u.map(f=>Math.max(...f.map(({latency:y})=>y)))),g=o.map((f,y)=>{const w=u.map($=>$[y].latency),E=1-w.reduce(($,W)=>$+W,0)/w.length/p,N=u.map($=>$[y].success),x=N.reduce(($,W)=>$+W,0)/N.length;return x===0?[0,y]:[l*E+c*x,y]}).sort((f,y)=>y[0]-f[0]);s(g.map(([,f])=>o[f])),await wh(e),d()};d()}class rm extends Se{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 Wi(t,e={}){const{batch:s,fetchFn:n,fetchOptions:r,key:i="http",methods:o,name:a="HTTP JSON-RPC",onFetchRequest:c,onFetchResponse:l,retryDelay:u,raw:d}=e;return({chain:h,retryCount:p,timeout:g})=>{const{batchSize:f=1e3,wait:y=0}=typeof s=="object"?s:{},w=e.retryCount??p,b=g??e.timeout??1e4,E=t||(h==null?void 0:h.rpcUrls.default.http[0]);if(!E)throw new rm;const N=tm(E,{fetchFn:n,fetchOptions:r,onRequest:c,onResponse:l,timeout:b});return bh({key:i,methods:o,name:a,async request({method:x,params:$}){const W={method:x,params:$},{schedule:G}=Vg({id:E,wait:y,shouldSplitBatch(T){return T.length>f},fn:T=>N.request({body:T}),sort:(T,v)=>T.id-v.id}),k=async T=>s?G(T):[await N.request({body:T})],[{error:Q,result:se}]=await k(W);if(d)return{error:Q,result:se};if(Q)throw new mh({body:W,error:Q,url:E});return se},retryCount:w,retryDelay:u,timeout:b,type:"http"},{fetchOptions:r,url:E})}}async function Ir(...t){const e=await fetch(...t);if(!e.ok)throw new Error(`HTTP status code: ${e.status}`,{cause:e});return e}class Oi{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 Ir(i,{method:"GET",headers:e,signal:s,cache:n})).json()}async getBlob({headers:e,signal:s,...n}){const r=this.createUrl(n);return(await Ir(r,{method:"GET",headers:e,signal:s})).blob()}async post({body:e,headers:s,signal:n,...r}){const i=this.createUrl(r);return(await Ir(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 Ir(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 Ir(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 Qa={getFeatureValue(t,e){const s=e==null?void 0:e[t];return s===void 0?ye.DEFAULT_FEATURES[t]:s},filterSocialsByPlatform(t){if(!t||!t.length)return t;let e=t;return V.isTelegram()&&(V.isIos()&&(e=e.filter(s=>s!=="google")),V.isMac()&&(e=e.filter(s=>s!=="x")),V.isAndroid()&&(e=e.filter(s=>!["facebook","x"].includes(s)))),V.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)}},X=ke({features:ye.DEFAULT_FEATURES,projectId:"",sdkType:"appkit",sdkVersion:"html-wagmi-undefined",defaultAccountTypes:ye.DEFAULT_ACCOUNT_TYPES,enableNetworkSwitch:!0,experimental_preferUniversalLinks:!1,remoteFeatures:{},enableMobileFullScreen:!1,coinbasePreference:"all"}),_={state:X,subscribeKey(t,e){return Qe(X,t,e)},setOptions(t){Object.assign(X,t)},setRemoteFeatures(t){var s,n;if(!t)return;const e={...X.remoteFeatures,...t};X.remoteFeatures=e,(s=X.remoteFeatures)!=null&&s.socials&&(X.remoteFeatures.socials=Qa.filterSocialsByPlatform(X.remoteFeatures.socials)),(n=X.features)!=null&&n.pay&&(X.remoteFeatures.email=!1,X.remoteFeatures.socials=!1)},setFeatures(t){var s;if(!t)return;X.features||(X.features=ye.DEFAULT_FEATURES);const e={...X.features,...t};X.features=e,(s=X.features)!=null&&s.pay&&X.remoteFeatures&&(X.remoteFeatures.email=!1,X.remoteFeatures.socials=!1)},setProjectId(t){X.projectId=t},setCustomRpcUrls(t){X.customRpcUrls=t},setAllWallets(t){X.allWallets=t},setIncludeWalletIds(t){X.includeWalletIds=t},setExcludeWalletIds(t){X.excludeWalletIds=t},setFeaturedWalletIds(t){X.featuredWalletIds=t},setTokens(t){X.tokens=t},setTermsConditionsUrl(t){X.termsConditionsUrl=t},setPrivacyPolicyUrl(t){X.privacyPolicyUrl=t},setCustomWallets(t){X.customWallets=t},setIsSiweEnabled(t){X.isSiweEnabled=t},setIsUniversalProvider(t){X.isUniversalProvider=t},setSdkVersion(t){X.sdkVersion=t},setMetadata(t){X.metadata=t},setDisableAppend(t){X.disableAppend=t},setEIP6963Enabled(t){X.enableEIP6963=t},setDebug(t){X.debug=t},setEnableWalletGuide(t){X.enableWalletGuide=t},setEnableAuthLogger(t){X.enableAuthLogger=t},setEnableWallets(t){X.enableWallets=t},setPreferUniversalLinks(t){X.experimental_preferUniversalLinks=t},setSIWX(t){if(t)for(const[e,s]of Object.entries(ye.SIWX_DEFAULTS))t[e]??(t[e]=s);X.siwx=t},setConnectMethodsOrder(t){X.features={...X.features,connectMethodsOrder:t}},setWalletFeaturesOrder(t){X.features={...X.features,walletFeaturesOrder:t}},setSocialsOrder(t){X.remoteFeatures={...X.remoteFeatures,socials:t}},setCollapseWallets(t){X.features={...X.features,collapseWallets:t}},setEnableEmbedded(t){X.enableEmbedded=t},setAllowUnsupportedChain(t){X.allowUnsupportedChain=t},setManualWCControl(t){X.manualWCControl=t},setEnableNetworkSwitch(t){X.enableNetworkSwitch=t},setEnableMobileFullScreen(t){X.enableMobileFullScreen=V.isMobile()&&t},setEnableReconnect(t){X.enableReconnect=t},setCoinbasePreference(t){X.coinbasePreference=t},setDefaultAccountTypes(t={}){Object.entries(t).forEach(([e,s])=>{s&&(X.defaultAccountTypes[e]=s)})},setUniversalProviderConfigOverride(t){X.universalProviderConfigOverride=t},getUniversalProviderConfigOverride(){return X.universalProviderConfigOverride},getSnapshot(){return Xr(X)}},mn=Object.freeze({message:"",variant:"success",svg:void 0,open:!1,autoClose:!0}),Fe=ke({...mn}),im={state:Fe,subscribeKey(t,e){return Qe(Fe,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=V.parseError(t);this._showMessage({message:e,variant:"error"})},hide(){Fe.message=mn.message,Fe.variant=mn.variant,Fe.svg=mn.svg,Fe.open=mn.open,Fe.autoClose=mn.autoClose},_showMessage({message:t,svg:e,variant:s="success",autoClose:n=mn.autoClose}){Fe.open?(Fe.open=!1,setTimeout(()=>{Fe.message=t,Fe.variant=s,Fe.svg=e,Fe.open=!0,Fe.autoClose=n},150)):(Fe.message=t,Fe.variant=s,Fe.svg=e,Fe.open=!0,Fe.autoClose=n)}},ls=im,om={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"}]}]},vh=V.getBlockchainApiUrl(),ut=ke({clientId:null,api:new Oi({baseUrl:vh,clientId:null}),supportedChains:{http:[],ws:[]}}),te={state:ut,async get(t){const{st:e,sv:s}=te.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 te.getSupportedNetworks()}catch{return!1}return ut.supportedChains.http.includes(t)},async getSupportedNetworks(){try{const t=await te.get({path:"v1/supported-chains"});return ut.supportedChains=t,t}catch{return ut.supportedChains}},async fetchIdentity({address:t}){const e=P.getIdentityFromCacheForAddress(t);if(e)return e;const s=await te.get({path:`/v1/identity/${t}`,params:{sender:m.state.activeCaipAddress?V.getPlainAddress(m.state.activeCaipAddress):void 0}});return P.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 te.isNetworkSupported((c=m.state.activeCaipNetwork)==null?void 0:c.caipNetworkId))return{data:[],next:void 0};const o=P.getTransactionsCacheForAddress({address:t,chainId:r});if(o)return o;const a=await te.get({path:`/v1/account/${t}/history`,params:{cursor:e,chainId:r},signal:s,cache:n});return P.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 te.isNetworkSupported((o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId)?te.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 te.isNetworkSupported((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?te.get({path:"/v1/convert/tokens",params:{chainId:t}}):{tokens:[]}},async fetchTokenPrice({addresses:t}){var r;if(!await te.isNetworkSupported((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))return{fungibles:[]};const s=P.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 P.updateTokenPriceCache({addresses:t,timestamp:Date.now(),tokenPrice:n}),n},async fetchSwapAllowance({tokenAddress:t,userAddress:e}){var n;return await te.isNetworkSupported((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)?te.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}=te.getSdkProperties();if(!await te.isNetworkSupported((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId))throw new Error("Network not supported for Gas Price");return te.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 te.isNetworkSupported((o=m.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:ye.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}=te.getSdkProperties();if(!await te.isNetworkSupported((o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId))throw new Error("Network not supported for Swaps");return te.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}=te.getSdkProperties();if(!await te.isNetworkSupported((l=m.state.activeCaipNetwork)==null?void 0:l.caipNetworkId))return ls.showError("Token Balance Unavailable"),{balances:[]};const o=`${e}:${t}`,a=P.getBalanceCacheForCaipAddress(o);if(a)return a;const c=await te.get({path:`/v1/account/${t}/balance`,params:{currency:"usd",chainId:e,forceUpdate:s,st:n,sv:r}});return P.updateBalanceCache({caipAddress:o,balance:c,timestamp:Date.now()}),c},async lookupEnsName(t){var s;return await te.isNetworkSupported((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?te.get({path:`/v1/profile/account/${t}`,params:{apiVersion:"2"}}):{addresses:{},attributes:[]}},async reverseLookupEnsName({address:t}){var n,r;if(!await te.isNetworkSupported((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId))return[];const s=(r=m.getAccountData())==null?void 0:r.address;return te.get({path:`/v1/profile/reverse/${t}`,params:{sender:s,apiVersion:"2"}})},async getEnsNameSuggestions(t){var s;return await te.isNetworkSupported((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?te.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 te.isNetworkSupported((i=m.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 te.isNetworkSupported((a=m.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 te.isNetworkSupported((e=m.state.activeCaipNetwork)==null?void 0:e.caipNetworkId))return{paymentCurrencies:[],purchaseCurrencies:[]};try{return await te.get({path:"/v1/onramp/options"})}catch{return om}},async getOnrampQuote({purchaseCurrency:t,paymentCurrency:e,amount:s,network:n}){var r;try{return await te.isNetworkSupported((r=m.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 te.isNetworkSupported((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)?te.get({path:`/v1/sessions/${t}`}):[]},async revokeSmartSession(t,e,s){var r;return await te.isNetworkSupported((r=m.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 Oi({baseUrl:vh,clientId:t})}},Lt={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"}},am={handleMobileDeeplinkRedirect(t,e){const s=window.location.href,n=encodeURIComponent(s);if(t===Lt.PHANTOM.id&&!("phantom"in window)){const r=s.startsWith("https")?"https":"http",i=s.split("/")[2],o=encodeURIComponent(`${r}://${i}`);window.location.href=`${Lt.PHANTOM.url}/ul/browse/${n}?ref=${o}`}if(t===Lt.SOLFLARE.id&&!("solflare"in window)&&(window.location.href=`${Lt.SOLFLARE.url}/ul/v1/browse/${n}?ref=${n}`),e===U.CHAIN.SOLANA&&t===Lt.COINBASE.id&&!("coinbaseSolana"in window)&&(window.location.href=`${Lt.COINBASE.url}/dapp?cb_url=${n}`),e===U.CHAIN.BITCOIN&&t===Lt.BINANCE.id&&!("binancew3w"in window)){const r=m.state.activeCaipNetwork,i=window.btoa("/pages/browser/index"),o=window.btoa(`url=${n}&defaultChainId=${(r==null?void 0:r.id)??1}`),a=new URL(Lt.BINANCE.deeplink);a.searchParams.set("appId",Lt.BINANCE.appId),a.searchParams.set("startPagePath",i),a.searchParams.set("startPageQuery",o);const c=new URL(Lt.BINANCE.url);c.searchParams.set("_dp",window.btoa(a.toString())),window.location.href=c.toString()}}},cm=Object.freeze({enabled:!0,events:[]}),lm=new Oi({baseUrl:V.getAnalyticsUrl(),clientId:null}),um=5,dm=60*1e3,Ls=ke({...cm}),hm={state:Ls,subscribeKey(t,e){return Qe(Ls,t,e)},async sendError(t,e){if(!Ls.enabled)return;const s=Date.now();if(Ls.events.filter(i=>{const o=new Date(i.properties.timestamp||"").getTime();return s-o<dm}).length>=um)return;const r={type:"error",event:e,properties:{errorType:t.name,errorMessage:t.message,stackTrace:t.stack,timestamp:new Date().toISOString()}};Ls.events.push(r);try{if(typeof window>"u")return;const{projectId:i,sdkType:o,sdkVersion:a}=_.state;await lm.post({path:"/e",params:{projectId:i,st:o,sv:a||"html-wagmi-4.2.2"},body:{eventId:V.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(){Ls.enabled=!0},disable(){Ls.enabled=!1},clearEvents(){Ls.events=[]}};class $n 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,$n.prototype);let r=!1;if(n instanceof Error&&typeof n.stack=="string"&&n.stack){const i=n.stack,o=i.indexOf(`
|
|
9
9
|
`);if(o>-1){const a=i.substring(o+1);this.stack=`${this.name}: ${this.message}
|
|
10
|
-
${a}`,r=!0}}r||(Error.captureStackTrace?Error.captureStackTrace(this,$n):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function $l(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 $n?t:new $n(s,e,t);throw hm.sendError(n,n.category),n}function Ht(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 $l(a,e)}}:i=(...o)=>{try{return r(...o)}catch(a){return $l(a,e)}},s[n]=i}else s[n]=r}),s}const Ct=ke({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),pm={state:Ct,subscribeNetworkImages(t){return Ze(Ct.networkImages,()=>t(Ct.networkImages))},subscribeKey(t,e){return Qe(Ct,t,e)},subscribe(t){return Ze(Ct,()=>t(Ct))},setWalletImage(t,e){Ct.walletImages[t]=e},setNetworkImage(t,e){Ct.networkImages[t]=e},setChainImage(t,e){Ct.chainImages[t]=e},setConnectorImage(t,e){Ct.connectorImages={...Ct.connectorImages,[t]:e}},setTokenImage(t,e){Ct.tokenImages[t]=e},setCurrencyImage(t,e){Ct.currencyImages[t]=e}},jt=Ht(pm),fm={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:"",sui:"",stacks:""},da=ke({networkImagePromises:{}}),Eh={async fetchWalletImage(t){if(t)return await J._fetchWalletImage(t),this.getWalletImageById(t)},async fetchNetworkImage(t){if(!t)return;const e=this.getNetworkImageById(t);return e||(da.networkImagePromises[t]||(da.networkImagePromises[t]=J._fetchNetworkImage(t)),await da.networkImagePromises[t],this.getNetworkImageById(t))},getWalletImageById(t){if(t)return jt.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 jt.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 jt.state.networkImages[t.assets.imageId]},getNetworkImageById(t){if(t)return jt.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 jt.state.connectorImages[t.imageId]},getChainImage(t){return jt.state.networkImages[fm[t]]},getTokenImage(t){if(t)return jt.state.tokenImages[t]}},gm=V.getAnalyticsUrl(),mm=new Oi({baseUrl:gm,clientId:null}),ym=["MODAL_CREATED"],wm=45,Ul=1e3*10,Ue=ke({timestamp:Date.now(),lastFlush:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"},pendingEvents:[],subscribedToVisibilityChange:!1,walletImpressions:[]}),ae={state:Ue,subscribe(t){return Ze(Ue,()=>t(Ue))},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(Ue.pendingEvents).length/1024>wm,e=Ue.lastFlush+Ul<Date.now();return t||e},_setPendingEvent(t){var e,s;try{let n=(e=m.getAccountData())==null?void 0:e.address;if("address"in t.data&&t.data.address&&(n=t.data.address),ym.includes(t.data.event)||typeof window>"u")return;const r=(s=m.getActiveCaipNetwork())==null?void 0:s.caipNetworkId;this.state.pendingEvents.push({eventId:V.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}}}),Ue.reportedErrors.FORBIDDEN=!1,ae.shouldFlushEvents()&&ae._submitPendingEvents()}catch(n){console.warn("_setPendingEvent",n)}},sendEvent(t){var s;Ue.timestamp=Date.now(),Ue.data=t;const e=["INITIALIZE","CONNECT_SUCCESS","SOCIAL_LOGIN_SUCCESS"];((s=_.state.features)!=null&&s.analytics||e.includes(t.event))&&ae._setPendingEvent(Ue),this.subscribeToFlushTriggers()},sendWalletImpressionEvent(t){Ue.walletImpressions.push(t)},_transformPendingEventsForBatch(t){try{return t.filter(e=>e.props.event!=="WALLET_IMPRESSION_V2")}catch{return t}},_submitPendingEvents(){if(Ue.lastFlush=Date.now(),!(Ue.pendingEvents.length===0&&Ue.walletImpressions.length===0))try{const t=ae._transformPendingEventsForBatch(Ue.pendingEvents);Ue.walletImpressions.length&&t.push({eventId:V.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:Date.now(),props:{type:"track",event:"WALLET_IMPRESSION_V2",items:[...Ue.walletImpressions]}}),mm.sendBeacon({path:"/batch",params:ae.getSdkProperties(),body:t}),Ue.reportedErrors.FORBIDDEN=!1,Ue.pendingEvents=[],Ue.walletImpressions=[]}catch{Ue.reportedErrors.FORBIDDEN=!0}},subscribeToFlushTriggers(){var t,e,s;Ue.subscribedToVisibilityChange||typeof document>"u"||(Ue.subscribedToVisibilityChange=!0,(t=document==null?void 0:document.addEventListener)==null||t.call(document,"visibilitychange",()=>{document.visibilityState==="hidden"&&ae._submitPendingEvents()}),(e=document==null?void 0:document.addEventListener)==null||e.call(document,"freeze",()=>{ae._submitPendingEvents()}),(s=window==null?void 0:window.addEventListener)==null||s.call(window,"pagehide",()=>{ae._submitPendingEvents()}),setInterval(()=>{ae._submitPendingEvents()},Ul))}},bm=V.getApiUrl(),at=new Oi({baseUrl:bm,clientId:null}),vm=40,Dl=4,Em=20,re=ke({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}}}),J={state:re,subscribeKey(t,e){return Qe(re,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=`${at.baseUrl}/getWalletImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setWalletImage(t,URL.createObjectURL(s))},async _fetchNetworkImage(t){const e=`${at.baseUrl}/public/getAssetImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setNetworkImage(t,URL.createObjectURL(s))},async _fetchConnectorImage(t){const e=`${at.baseUrl}/public/getAssetImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setConnectorImage(t,URL.createObjectURL(s))},async _fetchCurrencyImage(t){const e=`${at.baseUrl}/public/getCurrencyImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setCurrencyImage(t,URL.createObjectURL(s))},async _fetchTokenImage(t){const e=`${at.baseUrl}/public/getTokenImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setTokenImage(t,URL.createObjectURL(s))},_filterWalletsByPlatform(t){const e=t.length,s=V.isMobile()?t==null?void 0:t.filter(r=>r.mobile_link||r.webapp_link?!0:Object.values(Lt).map(o=>o.id).includes(r.id)):t,n=e-s.length;return{filteredWallets:s,mobileFilteredOutWalletsLength:n}},async fetchProjectConfig(){return(await at.get({path:"/appkit/v1/config",params:J._getSdkProperties()})).features},async fetchUsage(){try{const t=await at.get({path:"/appkit/v1/project-limits",params:J._getSdkProperties()}),{tier:e,isAboveMauLimit:s,isAboveRpcLimit:n}=t.planLimits,r=e==="starter",i=s||n;J.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 at.get({path:"/projects/v1/origins",params:J._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=m.getAllRequestedCaipNetworks(),e=t==null?void 0:t.map(({assets:s})=>s==null?void 0:s.imageId).filter(Boolean).filter(s=>!Eh.getNetworkImageById(s));e&&await Promise.allSettled(e.map(s=>J._fetchNetworkImage(s)))},async fetchConnectorImages(){const{connectors:t}=L.state,e=t.map(({imageId:s})=>s).filter(Boolean);await Promise.allSettled(e.map(s=>J._fetchConnectorImage(s)))},async fetchCurrencyImages(t=[]){await Promise.allSettled(t.map(e=>J._fetchCurrencyImage(e)))},async fetchTokenImages(t=[]){await Promise.allSettled(t.map(e=>J._fetchTokenImage(e)))},async fetchWallets(t){var o;const e=t.exclude??[];J._getSdkProperties().sv.startsWith("html-core-")&&e.push(...Object.values(Lt).map(a=>a.id));const n=await at.get({path:"/getWallets",params:{...J._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}=J._filterWalletsByPlatform(n==null?void 0:n.data);return{data:r||[],count:n==null?void 0:n.count,mobileFilteredOutWalletsLength:i}},async prefetchWalletRanks(){const t=L.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(","),m.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 J.fetchWallets(e);re.explorerWallets=s;const n=m.getRequestedCaipNetworkIds().join(",");re.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={...J._getSdkProperties(),page:1,entries:(t==null?void 0:t.length)??Dl,include:t},{data:s}=await J.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=>J._fetchWalletImage(i))),re.featured=n,re.allFeatured=n}},async fetchRecommendedWallets(){try{re.isFetchingRecommendedWallets=!0;const{includeWalletIds:t,excludeWalletIds:e,featuredWalletIds:s}=_.state,n=[...e??[],...s??[]].filter(Boolean),r=m.getRequestedCaipNetworkIds().join(","),i={page:1,entries:Dl,include:t,exclude:n,chains:r},{data:o,count:a}=await J.fetchWallets(i),c=P.getRecentWallets(),l=o.map(d=>d.image_id).filter(Boolean),u=c.map(d=>d.image_id).filter(Boolean);await Promise.allSettled([...l,...u].map(d=>J._fetchWalletImage(d))),re.recommended=o,re.allRecommended=o,re.count=a??0}catch{}finally{re.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:t}){const{includeWalletIds:e,excludeWalletIds:s,featuredWalletIds:n}=_.state,r=m.getRequestedCaipNetworkIds().join(","),i=[...re.recommended.map(({id:d})=>d),...s??[],...n??[]].filter(Boolean),o={page:t,entries:vm,include:e,exclude:i,chains:r},{data:a,count:c,mobileFilteredOutWalletsLength:l}=await J.fetchWallets(o);re.mobileFilteredOutWalletsLength=l+(re.mobileFilteredOutWalletsLength??0);const u=a.slice(0,Em).map(d=>d.image_id).filter(Boolean);await Promise.allSettled(u.map(d=>J._fetchWalletImage(d))),re.wallets=V.uniqueBy([...re.wallets,...J._filterOutExtensions(a)],"id").filter(d=>{var h;return(h=d.chains)==null?void 0:h.some(p=>r.includes(p))}),re.count=c>re.count?c:re.count,re.page=t},async initializeExcludedWallets({ids:t}){const e={page:1,entries:t.length,include:t},{data:s}=await J.fetchWallets(e);s&&s.forEach(n=>{re.excludedWallets.push({rdns:n.rdns,name:n.name})})},async searchWallet({search:t,badge:e}){const{includeWalletIds:s,excludeWalletIds:n}=_.state,r=m.getRequestedCaipNetworkIds().join(",");re.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 J.fetchWallets(i);ae.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=>J._fetchWalletImage(c)),V.wait(300)]),re.search=J._filterOutExtensions(o)},initPromise(t,e){const s=re.promises[t];return s||(re.promises[t]=e())},prefetch({fetchConnectorImages:t=!0,fetchFeaturedWallets:e=!0,fetchRecommendedWallets:s=!0,fetchNetworkImages:n=!0,fetchWalletRanks:r=!0}={}){const i=[t&&J.initPromise("connectorImages",J.fetchConnectorImages),e&&J.initPromise("featuredWallets",J.fetchFeaturedWallets),s&&J.initPromise("recommendedWallets",J.fetchRecommendedWallets),n&&J.initPromise("networkImages",J.fetchNetworkImages),r&&J.initPromise("walletRanks",J.prefetchWalletRanks)].filter(Boolean);return Promise.allSettled(i)},prefetchAnalyticsConfig(){var t;(t=_.state.features)!=null&&t.analytics&&J.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{const{isAnalyticsEnabled:t}=await at.get({path:"/getAnalyticsConfig",params:J._getSdkProperties()});_.setFeatures({analytics:t})}catch{_.setFeatures({analytics:!1})}},filterByNamespaces(t){if(!(t!=null&&t.length)){re.featured=re.allFeatured,re.recommended=re.allRecommended;return}const e=m.getRequestedCaipNetworkIds().join(",");re.featured=re.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.recommended=re.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.filteredWallets=re.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})},clearFilterByNamespaces(){re.filteredWallets=[]},setFilterByNamespace(t){if(!t){re.featured=re.allFeatured,re.recommended=re.allRecommended;return}const e=m.getRequestedCaipNetworkIds().join(",");re.featured=re.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.recommended=re.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.filteredWallets=re.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})}},Cm=["ConnectingExternal","ConnectingMultiChain","ConnectingSocial","ConnectingFarcaster"],Ce=ke({view:"Connect",history:["Connect"],transactionStack:[]}),Am={state:Ce,subscribeKey(t,e){return Qe(Ce,t,e)},pushTransactionStack(t){Ce.transactionStack.push(t)},popTransactionStack(t){const e=Ce.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(),ee.goBack();break;case"cancel":r==null||r(),ee.goBack();break}},push(t,e){let s=t,n=e;J.state.plan.hasExceededUsageLimit&&Cm.includes(t)&&(s="UsageExceeded",n=void 0),s!==Ce.view&&(Ce.view=s,Ce.history.push(s),Ce.data=n)},reset(t,e){Ce.view=t,Ce.history=[t],Ce.data=e},replace(t,e){Ce.history.at(-1)===t||(Ce.view=t,Ce.history[Ce.history.length-1]=t,Ce.data=e)},goBack(){var n,r;const t=m.state.activeCaipAddress,e=ee.state.view==="ConnectingFarcaster",s=!t&&e;if(Ce.history.length>1){Ce.history.pop();const[i]=Ce.history.slice(-1);i&&(t&&i==="Connect"?Ce.view="Account":Ce.view=i)}else de.close();(n=Ce.data)!=null&&n.wallet&&(Ce.data.wallet=void 0),(r=Ce.data)!=null&&r.redirectView&&(Ce.data.redirectView=void 0),setTimeout(()=>{var i,o,a;if(s){m.setAccountProp("farcasterUrl",void 0,m.state.activeChain);const c=L.getAuthConnector();(i=c==null?void 0:c.provider)==null||i.reload();const l=Xr(_.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(Ce.history.length>1){Ce.history=Ce.history.slice(0,t+1);const[e]=Ce.history.slice(-1);e&&(Ce.view=e)}},goBackOrCloseModal(){ee.state.history.length>1?ee.goBack():de.close()}},ee=Ht(Am),ms=ke({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),ec={state:ms,subscribe(t){return Ze(ms,()=>t(ms))},setThemeMode(t){ms.themeMode=t;try{const e=L.getAuthConnector();if(e){const s=ec.getSnapshot().themeVariables;e.provider.syncTheme({themeMode:t,themeVariables:s,w3mThemeVariables:Co(s,t)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(t){ms.themeVariables={...ms.themeVariables,...t};try{const e=L.getAuthConnector();if(e){const s=ec.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:s,w3mThemeVariables:Co(ms.themeVariables,ms.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot(){return Xr(ms)}},St=Ht(ec),Ch=Object.fromEntries(ih.map(t=>[t,void 0])),Im=Object.fromEntries(ih.map(t=>[t,!0])),be=ke({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:Ch,filterByNamespaceMap:Im}),_m={state:be,subscribe(t){return Ze(be,()=>{t(be)})},subscribeKey(t,e){return Qe(be,t,e)},initialize(t){t.forEach(e=>{const s=P.getConnectedConnectorId(e);s&&L.setConnectorId(s,e)})},setActiveConnector(t){t&&(be.activeConnector=Zr(t))},setConnectors(t){t.filter(r=>!be.allConnectors.some(i=>i.id===r.id&&L.getConnectorName(i.name)===L.getConnectorName(r.name)&&i.chain===r.chain)).forEach(r=>{r.type!=="MULTI_CHAIN"&&be.allConnectors.push(Zr(r))});const s=L.getEnabledNamespaces(),n=L.getEnabledConnectors(s);be.connectors=L.mergeMultiChainConnectors(n)},filterByNamespaces(t){Object.keys(be.filterByNamespaceMap).forEach(e=>{be.filterByNamespaceMap[e]=!1}),t.forEach(e=>{be.filterByNamespaceMap[e]=!0}),L.updateConnectorsForEnabledNamespaces()},filterByNamespace(t,e){be.filterByNamespaceMap[t]=e,L.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){const t=L.getEnabledNamespaces(),e=L.getEnabledConnectors(t),s=L.areAllNamespacesEnabled();be.connectors=L.mergeMultiChainConnectors(e),s?J.clearFilterByNamespaces():J.filterByNamespaces(t)},getEnabledNamespaces(){return Object.entries(be.filterByNamespaceMap).filter(([t,e])=>e).map(([t])=>t)},getEnabledConnectors(t){return be.allConnectors.filter(e=>t.includes(e.chain))},areAllNamespacesEnabled(){return Object.values(be.filterByNamespaceMap).every(t=>t)},mergeMultiChainConnectors(t){const e=L.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=L.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=Xr(_.state),o=St.getSnapshot().themeMode,a=St.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:Co(a,o)}),L.setConnectors([t])}else L.setConnectors([t])},getAuthConnector(t){var n;const e=t||m.state.activeChain,s=be.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 be.connectors.filter(t=>t.type==="ANNOUNCED").map(t=>{var e;return(e=t.info)==null?void 0:e.rdns})},getConnectorById(t){return be.allConnectors.find(e=>e.id===t)},getConnector({id:t,rdns:e,namespace:s}){const n=s||m.state.activeChain;return be.allConnectors.filter(i=>i.chain===n).find(i=>{var o;return i.explorerId===t||((o=i.info)==null?void 0:o.rdns)===e})},syncIfAuthConnector(t){var i,o;if(t.id!=="AUTH")return;const e=t,s=Xr(_.state),n=St.getSnapshot().themeMode,r=St.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:Co(r,n)})},getConnectorsByNamespace(t){const e=be.allConnectors.filter(s=>s.chain===t);return L.mergeMultiChainConnectors(e)},canSwitchToSmartAccount(t){return m.checkIfSmartAccountEnabled()&&qt(t)===Ss.ACCOUNT_TYPES.EOA},selectWalletConnector(t){var n;const e=(n=ee.state.data)==null?void 0:n.redirectView,s=L.getConnector({id:t.id,rdns:t.rdns});am.handleMobileDeeplinkRedirect((s==null?void 0:s.explorerId)||t.id,m.state.activeChain),s?ee.push("ConnectingExternal",{connector:s,wallet:t,redirectView:e}):ee.push("ConnectingWalletConnect",{wallet:t,redirectView:e})},getConnectors(t){return t?L.getConnectorsByNamespace(t):L.mergeMultiChainConnectors(be.allConnectors)},setFilterByNamespace(t){be.filterByNamespace=t,be.connectors=L.getConnectors(t),J.setFilterByNamespace(t)},setConnectorId(t,e){t&&(be.activeConnectorIds={...be.activeConnectorIds,[e]:t},P.setConnectedConnectorId(e,t))},removeConnectorId(t){be.activeConnectorIds={...be.activeConnectorIds,[t]:void 0},P.deleteConnectedConnectorId(t)},getConnectorId(t){if(t)return be.activeConnectorIds[t]},isConnected(t){return t?!!be.activeConnectorIds[t]:Object.values(be.activeConnectorIds).some(e=>!!e)},resetConnectorIds(){be.activeConnectorIds={...Ch}}},L=Ht(_m),Sm=1e3,_r={checkNamespaceConnectorId(t,e){return L.getConnectorId(t)===e},isSocialProvider(t){return ye.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&&L.setActiveConnector(e),r==null||r(V.isMobile()&&t),n){const l=de.subscribeKey("open",u=>{u||(ee.state.view!==n&&ee.replace(n),l(),a(new Error("Modal closed")))})}const c=m.subscribeKey("activeCaipAddress",l=>{l&&(i==null||i(),s&&de.close(),c(),o(Xe.parseCaipAddress(l)))})})},connectExternal(t){return new Promise((e,s)=>{const n=m.subscribeKey("activeCaipAddress",r=>{r&&(de.close(),n(),e(Xe.parseCaipAddress(r)))});j.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||m.state.activeChain,l=m.subscribeKey("activeCaipAddress",u=>{u&&(s&&de.close(),l())});return new Promise((u,d)=>{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=L.getAuthConnector(c);if(y&&!o){i&&i.close(),o=!0;const w=g.data.resultUri;ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_REQUEST_USER_DATA",properties:{provider:t}}),P.setConnectedSocialProvider(t),await j.connectExternal({id:y.id,type:y.type,socialUri:w},y.chain);const b=m.state.activeCaipAddress;if(!b){d(new Error("Failed to connect"));return}u(Xe.parseCaipAddress(b)),ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:t}})}}catch(y){ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:V.parseError(y)}}),d(new Error("Failed to connect"))}}else ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:"Untrusted Origin"}})}async function p(){if(ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_STARTED",properties:{provider:t}}),t==="farcaster"){n==null||n();const g=de.subscribeKey("open",y=>{!y&&t==="farcaster"&&(d(new Error("Popup closed")),r==null||r(),g())}),f=L.getAuthConnector();if(f){const y=m.getAccountData(c);if(!(y!=null&&y.farcasterUrl))try{const{url:w}=await f.provider.getFarcasterUri();m.setAccountProp("farcasterUrl",w,c)}catch{d(new Error("Failed to connect to farcaster"))}}}else{const g=L.getAuthConnector();a=V.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&&(d(new Error("Popup closed")),clearInterval(y))},1e3);window.addEventListener("message",h,!1)}else a==null||a.close(),d(new Error("Failed to initiate social connection"))}}catch{d(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=de.subscribeKey("open",c=>{c||(ee.state.view!==e&&ee.replace(e),a(),i(new Error("Modal closed")))})}const o=m.subscribeKey("activeCaipAddress",a=>{a&&(n==null||n(),t&&de.close(),o(),r(Xe.parseCaipAddress(a)))})})},async updateEmail(){const t=P.getConnectedConnectorId(m.state.activeChain),e=L.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 de.open({view:"UpdateEmailWallet",data:{email:s,redirectView:void 0}}),new Promise((n,r)=>{const i=setInterval(()=>{const a=e.provider.getEmail()??"";a!==s&&(de.close(),clearInterval(i),o(),n({email:a}))},Sm),o=de.subscribeKey("open",a=>{a||(ee.state.view!=="Connect"&&ee.push("Connect"),clearInterval(i),o(),r(new Error("Modal closed")))})})},canSwitchToSmartAccount(t){return m.checkIfSmartAccountEnabled()&&qt(t)===Ss.ACCOUNT_TYPES.EOA}};function Ah(){var n,r;const t=((n=m.state.activeCaipNetwork)==null?void 0:n.chainNamespace)||"eip155",e=((r=m.state.activeCaipNetwork)==null?void 0:r.id)||1,s=ye.NATIVE_TOKEN_ADDRESS[t];return`${t}:${e}:${s}`}function qt(t){var s;return(s=m.getAccountData(t))==null?void 0:s.preferredAccountType}function Hi(t){return m.state.activeCaipNetwork}const _o={getConnectionStatus(t,e){const s=L.state.activeConnectorIds[e],n=j.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=L.state.activeConnectorIds[t],n=j.getConnections(t),i=(j.state.recentConnections.get(t)??[]).filter(c=>L.getConnectorById(c.connectorId)),o=_o.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:[]}}},Re=ke({transactions:[],transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),Nm={state:Re,subscribe(t){return Ze(Re,()=>t(Re))},setLastNetworkInView(t){Re.lastNetworkInView=t},async fetchTransactions(t){var e;if(!t)throw new Error("Transactions can't be fetched without an accountAddress");Re.loading=!0;try{const s=await te.fetchTransactions({account:t,cursor:Re.next,chainId:(e=m.state.activeCaipNetwork)==null?void 0:e.caipNetworkId}),n=uo.filterSpamTransactions(s.data),r=uo.filterByConnectedChain(n),i=[...Re.transactions,...r];Re.loading=!1,Re.transactions=i,Re.transactionsByYear=uo.groupTransactionsByYearAndMonth(Re.transactionsByYear,r),Re.empty=i.length===0,Re.next=s.next?s.next:void 0}catch{const n=m.state.activeChain;ae.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:t,projectId:_.state.projectId,cursor:Re.next,isSmartAccount:qt(n)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT}}),ls.showError("Failed to fetch transactions"),Re.loading=!1,Re.empty=!0,Re.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,u)=>new Date(u.metadata.minedAt).getTime()-new Date(l.metadata.minedAt).getTime())}}),s},filterSpamTransactions(t){return t.filter(e=>!e.transfers.every(n=>{var r;return((r=n.nft_info)==null?void 0:r.flags.is_spam)===!0}))},filterByConnectedChain(t){var n;const e=(n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId;return t.filter(r=>r.metadata.chain===e)},clearCursor(){Re.next=void 0},resetTransactions(){Re.transactions=[],Re.transactionsByYear={},Re.lastNetworkInView=void 0,Re.loading=!1,Re.empty=!1,Re.next=void 0}},uo=Ht(Nm,"API_ERROR"),ge=ke({connections:new Map,recentConnections:new Map,isSwitchingConnection:!1,wcError:!1,buffering:!1,status:"disconnected"});let ln;const Tm={state:ge,subscribe(t){return Ze(ge,()=>t(ge))},subscribeKey(t,e){return Qe(ge,t,e)},_getClient(){return ge._client},setClient(t){ge._client=Zr(t)},initialize(t){const e=t.filter(s=>!!s.namespace).map(s=>s.namespace);j.syncStorageConnections(e)},syncStorageConnections(t){const e=P.getConnections(),s=t??Array.from(m.state.chains.keys());for(const n of s){const r=e[n]??[],i=new Map(ge.recentConnections);i.set(n,r),ge.recentConnections=i}},getConnections(t){return t?ge.connections.get(t)??[]:[]},hasAnyConnection(t){const e=j.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;const e=V.isTelegram()||V.isSafari()&&V.isIos();if(t==="always"||t==="auto"&&e){if(ln){await ln,ln=void 0;return}if(!V.isPairingExpired(ge==null?void 0:ge.wcPairingExpiry)){const o=ge.wcUri;ge.wcUri=o;return}ln=(n=(s=j._getClient())==null?void 0:s.connectWalletConnect)==null?void 0:n.call(s).catch(()=>{}),j.state.status="connecting",await ln,ln=void 0,ge.wcPairingExpiry=void 0,j.state.status="connected"}else await((i=(r=j._getClient())==null?void 0:r.connectWalletConnect)==null?void 0:i.call(r))},async connectExternal(t,e,s=!0){var r,i;const n=await((i=(r=j._getClient())==null?void 0:r.connectExternal)==null?void 0:i.call(r,t));return s&&m.setActiveNamespace(e),n},async reconnectExternal(t){var s,n;await((n=(s=j._getClient())==null?void 0:s.reconnectExternal)==null?void 0:n.call(s,t));const e=t.chain||m.state.activeChain;e&&L.setConnectorId(t.id,e)},async setPreferredAccountType(t,e){var n;if(!e)return;de.setLoading(!0,m.state.activeChain);const s=L.getAuthConnector();s&&(m.setAccountProp("preferredAccountType",t,e),await s.provider.setPreferredAccount(t),P.setPreferredAccountTypes(Object.entries(m.state.chains).reduce((r,[i,o])=>{const a=i,c=qt(a);return c!==void 0&&(r[a]=c),r},{})),await j.reconnectExternal(s),de.setLoading(!1,m.state.activeChain),ae.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:t,network:((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}}))},async signMessage(t){var e;return(e=j._getClient())==null?void 0:e.signMessage(t)},parseUnits(t,e){var s;return(s=j._getClient())==null?void 0:s.parseUnits(t,e)},formatUnits(t,e){var s;return(s=j._getClient())==null?void 0:s.formatUnits(t,e)},updateBalance(t){var e;return(e=j._getClient())==null?void 0:e.updateBalance(t)},async sendTransaction(t){var e;return(e=j._getClient())==null?void 0:e.sendTransaction(t)},async getCapabilities(t){var e;return(e=j._getClient())==null?void 0:e.getCapabilities(t)},async grantPermissions(t){var e;return(e=j._getClient())==null?void 0:e.grantPermissions(t)},async walletGetAssets(t){var e;return((e=j._getClient())==null?void 0:e.walletGetAssets(t))??{}},async estimateGas(t){var e;return(e=j._getClient())==null?void 0:e.estimateGas(t)},async writeContract(t){var e;return(e=j._getClient())==null?void 0:e.writeContract(t)},async getEnsAddress(t){var e;return(e=j._getClient())==null?void 0:e.getEnsAddress(t)},async getEnsAvatar(t){var e;return(e=j._getClient())==null?void 0:e.getEnsAvatar(t)},checkInstalled(t){var e,s;return((s=(e=j._getClient())==null?void 0:e.checkInstalled)==null?void 0:s.call(e,t))||!1},resetWcConnection(){ge.wcUri=void 0,ge.wcPairingExpiry=void 0,ge.wcLinking=void 0,ge.recentWallet=void 0,ge.status="disconnected",uo.resetTransactions(),P.deleteWalletConnectDeepLink(),P.deleteRecentWallet()},resetUri(){ge.wcUri=void 0,ge.wcPairingExpiry=void 0,ln=void 0},finalizeWcConnection(t){var n,r;const{wcLinking:e,recentWallet:s}=j.state;e&&P.setWalletConnectDeepLink(e),s&&P.setAppKitRecent(s),t&&ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:t,properties:{method:e?"mobile":"qrcode",name:((r=(n=ee.state.data)==null?void 0:n.wallet)==null?void 0:r.name)||"Unknown",view:ee.state.view,walletRank:s==null?void 0:s.order}})},setWcBasic(t){ge.wcBasic=t},setUri(t){ge.wcUri=t,ge.wcPairingExpiry=V.getPairingExpiry()},setWcLinking(t){ge.wcLinking=t},setWcError(t){ge.wcError=t,ge.buffering=!1},setRecentWallet(t){ge.recentWallet=t},setBuffering(t){ge.buffering=t},setStatus(t){ge.status=t},setIsSwitchingConnection(t){ge.isSwitchingConnection=t},async disconnect({id:t,namespace:e,initialDisconnect:s}={}){var n;try{await((n=j._getClient())==null?void 0:n.disconnect({id:t,chainNamespace:e,initialDisconnect:s}))}catch(r){throw new $n("Failed to disconnect","INTERNAL_SDK_ERROR",r)}},async disconnectConnector({id:t,namespace:e}){var s;try{await((s=j._getClient())==null?void 0:s.disconnectConnector({id:t,namespace:e}))}catch(n){throw new $n("Failed to disconnect connector","INTERNAL_SDK_ERROR",n)}},setConnections(t,e){const s=new Map(ge.connections);s.set(e,t),ge.connections=s},async handleAuthAccountSwitch({address:t,namespace:e}){var i,o;const s=m.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()&&_r.canSwitchToSmartAccount(e)?"smartAccount":"eoa";await j.setPreferredAccountType(r,e)},async handleActiveConnection({connection:t,namespace:e,address:s}){const n=L.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 j.handleAuthAccountSwitch({address:s,namespace:e});else{const i=await j.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,u;const r=L.getConnectorById(t.connectorId),i=(u=(l=t.auth)==null?void 0:l.name)==null?void 0:u.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&&_r.isSocialProvider(i)){const{address:d}=await _r.connectSocial({social:i,closeModalOnConnect:n,onOpenFarcaster(){de.open({view:"ConnectingFarcaster"})},onConnect(){ee.replace("ProfileWallets")}});c=d}else{const{address:d}=await _r.connectEmail({closeModalOnConnect:n,onOpen(){de.open({view:"EmailLogin"})},onConnect(){ee.replace("ProfileWallets")}});c=d}else if(a){const{address:d}=await _r.connectWalletConnect({walletConnect:!0,connector:r,closeModalOnConnect:n,onOpen(h){const p=h?"AllWallets":"ConnectingWalletConnect";de.state.open?ee.push(p):de.open({view:p})},onConnect(){ee.replace("ProfileWallets")}});c=d}else{const d=await j.connectExternal({id:r.id,type:r.type,provider:r.provider,chain:e},e);d&&(c=d.address)}return o&&s&&await j.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=m.getAccountData(s))==null?void 0:c.caipAddress;if(o){const{address:l}=Xe.parseCaipAddress(o);i=l}const a=_o.getConnectionStatus(t,s);switch(a){case"connected":case"active":{const l=await j.handleActiveConnection({connection:t,namespace:s,address:e});if(i&&l){const u=l.toLowerCase()!==i.toLowerCase();r==null||r({address:l,namespace:s,hasSwitchedAccount:u,hasSwitchedWallet:a==="active"})}break}case"disconnected":{const l=await j.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}`)}}},j=Ht(Tm),ha={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 zc(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 pa;async function Ll(){if(!pa){const{createPublicClient:t,http:e,defineChain:s}=await vo(async()=>{const{createPublicClient:n,http:r,defineChain:i}=await import("./index-BWkgAZ1u.js");return{createPublicClient:n,http:r,defineChain:i}},__vite__mapDeps([0,1,2]));pa={createPublicClient:t,http:e,defineChain:s}}return pa}const tc={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 Ll(),{chainId:s}=Xe.parseCaipNetworkId(t.caipNetworkId);return e({...t,id:Number(s)})},async createViemPublicClient(t){const{createPublicClient:e,http:s}=await Ll(),n=_.state.projectId,r=await tc.getViemChain(t);if(!r)throw new Error(`Chain ${t.caipNetworkId} not found in viem/chains`);return e({chain:r,transport:s(tc.getBlockchainApiRpcUrl(t.caipNetworkId,n))})}},Yc={async getMyTokensWithBalance(t){var a;const e=(a=m.getAccountData())==null?void 0:a.address,s=m.state.activeCaipNetwork,n=L.getConnectorId("eip155")===U.CONNECTOR_ID.AUTH;if(!e||!s)return[];const r=`${s.caipNetworkId}:${e}`,i=P.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 te.getBalance(e,s.caipNetworkId,t);return this.filterLowQualityTokens(o.balances)},async getEIP155Balances(t,e){var s,n;try{const r=ha.getChainIdHexFromCAIP2ChainId(e.caipNetworkId),i=await j.getCapabilities(t);if(!((n=(s=i==null?void 0:i[r])==null?void 0:s.assetDiscovery)!=null&&n.supported))return null;const o=await j.walletGetAssets({account:t,chainFilter:[r]});if(!ha.isWalletGetAssetsResponse(o))return null;const c=(o[r]||[]).map(l=>ha.createBalance(l,e.caipNetworkId));return P.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 tc.createViemPublicClient(s),{address:r}=Xe.parseCaipAddress(t),[{result:i},{result:o},{result:a},{result:c}]=await n.multicall({contracts:[{address:e,functionName:"name",args:[],abi:Bi},{address:e,functionName:"symbol",args:[],abi:Bi},{address:e,functionName:"balanceOf",args:[r],abi:Bi},{address:e,functionName:"decimals",args:[],abi:Bi}]});return{name:i,symbol:o,decimals:c,balance:a&&c?zc(a,c):"0"}}},fa={adapters:{}},Ih={state:fa,initialize(t){fa.adapters={...t}},get(t){return fa.adapters[t]}},So={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0,sui:void 0,stacks:void 0},dt=ke({providers:{...So},providerIds:{...So}}),xe={state:dt,subscribeKey(t,e){return Qe(dt,t,e)},subscribe(t){return Ze(dt,()=>{t(dt)})},subscribeProviders(t){return Ze(dt.providers,()=>t(dt.providers))},setProvider(t,e){t&&e&&(dt.providers[t]=Zr(e))},getProvider(t){if(t)return dt.providers[t]},setProviderId(t,e){e&&(dt.providerIds[t]=e)},getProviderId(t){if(t)return dt.providerIds[t]},reset(){dt.providers={...So},dt.providerIds={...So}},resetChain(t){dt.providers[t]=void 0,dt.providerIds[t]=void 0}},Kn=ke({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1}),Ns={state:Kn,subscribe(t){return Ze(Kn,()=>t(Kn))},subscribeOpen(t){return Qe(Kn,"open",t)},set(t){Object.assign(Kn,{...Kn,...t})}},Om={async getTokenList(t){var n;const e=await te.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=m.state.activeCaipNetwork;if(!t)return null;try{switch(t.chainNamespace){case"solana":const s=(e=await(j==null?void 0:j.estimateGas({chainNamespace:"solana"})))==null?void 0:e.toString();return{standard:s,fast:s,instant:s};case"eip155":default:return await te.fetchGasPrice({chainId:t.caipNetworkId})}}catch{return null}},async fetchSwapAllowance({tokenAddress:t,userAddress:e,sourceTokenAmount:s,sourceTokenDecimals:n}){const r=await te.fetchSwapAllowance({tokenAddress:t,userAddress:e});if(r!=null&&r.allowance&&s&&n){const i=j.parseUnits(s,n)||0;return BigInt(r.allowance)>=i}return!1},async getMyTokensWithBalance(t){const e=await Yc.getMyTokensWithBalance(t);return m.setAccountProp("tokenBalance",e,m.state.activeChain),this.mapBalancesToSwapTokens(e)},mapBalancesToSwapTokens(t){return(t==null?void 0:t.map(e=>({...e,address:e!=null&&e.address?e.address:Ah(),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}}},me=ke({tokenBalances:[],loading:!1}),Pm={state:me,subscribe(t){return Ze(me,()=>t(me))},subscribeKey(t,e){return Qe(me,t,e)},setToken(t){t&&(me.token=Zr(t))},setTokenAmount(t){me.sendTokenAmount=t},setReceiverAddress(t){me.receiverAddress=t},setReceiverProfileImageUrl(t){me.receiverProfileImageUrl=t},setReceiverProfileName(t){me.receiverProfileName=t},setNetworkBalanceInUsd(t){me.networkBalanceInUSD=t},setLoading(t){me.loading=t},getSdkEventProperties(t){var e,s;return{message:V.parseError(t),isSmartAccount:qt(m.state.activeChain)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((e=me.token)==null?void 0:e.symbol)||"",amount:me.sendTokenAmount??0,network:((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||""}},async sendToken(){var t;try{switch(oe.setLoading(!0),(t=m.state.activeCaipNetwork)==null?void 0:t.chainNamespace){case"eip155":await oe.sendEvmToken();return;case"solana":await oe.sendSolanaToken();return;default:throw new Error("Unsupported chain")}}catch(e){throw _s.isUserRejectedRequestError(e)?new ch(e):e}finally{oe.setLoading(!1)}},async sendEvmToken(){var s,n,r;const t=m.state.activeChain;if(!t)throw new Error("SendController:sendEvmToken - activeChainNamespace is required");const e=qt(t);if(!oe.state.sendTokenAmount||!oe.state.receiverAddress)throw new Error("An amount and receiver address are required");if(!oe.state.token)throw new Error("A token is required");if((s=oe.state.token)!=null&&s.address){ae.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:oe.state.token.address,amount:oe.state.sendTokenAmount,network:((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}});const{hash:i}=await oe.sendERC20Token({receiverAddress:oe.state.receiverAddress,tokenAddress:oe.state.token.address,sendTokenAmount:oe.state.sendTokenAmount,decimals:oe.state.token.quantity.decimals});i&&(me.hash=i)}else{ae.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:oe.state.token.symbol||"",amount:oe.state.sendTokenAmount,network:((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||""}});const{hash:i}=await oe.sendNativeToken({receiverAddress:oe.state.receiverAddress,sendTokenAmount:oe.state.sendTokenAmount,decimals:oe.state.token.quantity.decimals});i&&(me.hash=i)}},async fetchTokenBalance(t){var o,a,c;me.loading=!0;const e=m.state.activeChain,s=(o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=m.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=((c=m.getAccountData(e))==null?void 0:c.caipAddress)??m.state.activeCaipAddress,i=r?V.getPlainAddress(r):void 0;if(me.lastRetry&&!V.isAllowedRetry(me.lastRetry,30*ye.ONE_SEC_MS))return me.loading=!1,[];try{if(i&&s&&n){const l=await Yc.getMyTokensWithBalance();return me.tokenBalances=l,me.lastRetry=void 0,l}}catch(l){me.lastRetry=Date.now(),t==null||t(l),ls.showError("Token Balance Unavailable")}finally{me.loading=!1}return[]},fetchNetworkBalance(){if(me.tokenBalances.length===0)return;const t=Om.mapBalancesToSwapTokens(me.tokenBalances);if(!t)return;const e=t.find(s=>s.address===Ah());e&&(me.networkBalanceInUSD=e?eg.multiply(e.quantity.numeric,e.price).toString():"0")},async sendNativeToken(t){var o,a,c,l;ee.pushTransactionStack({});const e=t.receiverAddress,s=(o=m.getAccountData())==null?void 0:o.address,n=j.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),i=await j.sendTransaction({chainNamespace:U.CHAIN.EVM,to:e,address:s,data:"0x",value:n??BigInt(0)});return ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:qt("eip155")===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((a=oe.state.token)==null?void 0:a.symbol)||"",amount:t.sendTokenAmount,network:((c=m.state.activeCaipNetwork)==null?void 0:c.caipNetworkId)||"",hash:i||""}}),(l=j._getClient())==null||l.updateBalance("eip155"),oe.resetSend(),{hash:i}},async sendERC20Token(t){var n,r,i;ee.pushTransactionStack({onSuccess(){ee.replace("Account")}});const e=j.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),s=(n=m.getAccountData())==null?void 0:n.address;if(s&&t.sendTokenAmount&&t.receiverAddress&&t.tokenAddress){const o=V.getPlainAddress(t.tokenAddress);if(!o)throw new Error("SendController:sendERC20Token - tokenAddress is required");const a=await j.writeContract({fromAddress:s,tokenAddress:o,args:[t.receiverAddress,e??BigInt(0)],method:"transfer",abi:rg.getERC20Abi(o),chainNamespace:U.CHAIN.EVM});return ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:qt("eip155")===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((r=oe.state.token)==null?void 0:r.symbol)||"",amount:t.sendTokenAmount,network:((i=m.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)||"",hash:a||""}}),oe.resetSend(),{hash:a}}return{hash:void 0}},async sendSolanaToken(){var s,n,r;if(!oe.state.sendTokenAmount||!oe.state.receiverAddress)throw new Error("An amount and receiver address are required");ee.pushTransactionStack({onSuccess(){ee.replace("Account")}});let t;oe.state.token&&oe.state.token.address!==ye.SOLANA_NATIVE_TOKEN_ADDRESS&&(V.isCaipAddress(oe.state.token.address)?t=V.getPlainAddress(oe.state.token.address):t=oe.state.token.address);const e=await j.sendTransaction({chainNamespace:"solana",tokenMint:t,to:oe.state.receiverAddress,value:oe.state.sendTokenAmount});e&&(me.hash=e),(s=j._getClient())==null||s.updateBalance("solana"),ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:!1,token:((n=oe.state.token)==null?void 0:n.symbol)||"",amount:oe.state.sendTokenAmount,network:((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||"",hash:e||""}}),oe.resetSend()},resetSend(){me.token=void 0,me.sendTokenAmount=void 0,me.receiverAddress=void 0,me.receiverProfileImageUrl=void 0,me.receiverProfileName=void 0,me.loading=!1,me.tokenBalances=[]}},oe=Ht(Pm),ga={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,user:void 0,preferredAccountType:void 0},Ki={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},q=ke({chains:wg(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{connectionControllerClient:void 0},isSwitchingNamespace:!1}),_h={state:q,subscribe(t){return Ze(q,()=>{t(q)})},subscribeKey(t,e){return Qe(q,t,e)},subscribeAccountStateProp(t,e,s){var r;const n=s||q.activeChain;return n?Qe(((r=q.chains.get(n))==null?void 0:r.accountState)||{},t,e):()=>{}},subscribeChainProp(t,e,s){let n;return Ze(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}=P.getActiveNetworkProps(),i=e==null?void 0:e.find(u=>u.id.toString()===(n==null?void 0:n.toString())),a=t.find(u=>(u==null?void 0:u.namespace)===r)||(t==null?void 0:t[0]),c=t.map(u=>u.namespace).filter(u=>u!==void 0),l=_.state.enableEmbedded?new Set([...c]):new Set([...(e==null?void 0:e.map(u=>u.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,m.setChainNetworkData(a==null?void 0:a.namespace,{caipNetwork:i}),q.activeChain&&Ns.set({activeChain:a==null?void 0:a.namespace})),l.forEach(u=>{const d=e==null?void 0:e.filter(g=>g.chainNamespace===u),h=P.getPreferredAccountTypes()||{},p={..._.state.defaultAccountTypes,...h};m.state.chains.set(u,{namespace:u,networkState:ke({...Ki,caipNetwork:d==null?void 0:d[0]}),accountState:ke({...ga,preferredAccountType:p[u]}),caipNetworks:d??[],...s}),m.setRequestedCaipNetworks(d??[],u)})},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&&m.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:{...Ki,caipNetwork:s[0]},accountState:{...ga},caipNetworks:s,connectionControllerClient:e}),m.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}),m.setRequestedCaipNetworks(n,t.chainNamespace),L.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])&&m.setActiveCaipNetwork(s.caipNetworks[0]),q.chains.set(t,{...s,caipNetworks:a}),m.setRequestedCaipNetworks(a||[],t),a.length===0&&L.filterByNamespace(t,!1)}},setAdapterNetworkState(t,e){const s=q.chains.get(t);s&&(s.networkState={...s.networkState||Ki,...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||ga,...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||Ki,...e};q.chains.set(t,{...s,networkState:n})}},setAccountProp(t,e,s,n=!0){m.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,m.setChainNetworkData(t,{caipNetwork:s}),P.setActiveCaipNetworkId(s==null?void 0:s.caipNetworkId),Ns.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||m.setIsSwitchingNamespace(!0);const s=q.chains.get(t.chainNamespace);q.activeChain=t.chainNamespace,q.activeCaipNetwork=t,m.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}=Xe.parseCaipAddress(q.activeCaipAddress);n=a,q.activeCaipAddress=`${t.caipNetworkId}:${n}`}else q.activeCaipAddress=void 0;m.setChainAccountData(t.chainNamespace,{address:n,caipAddress:q.activeCaipAddress}),oe.resetSend(),Ns.set({activeChain:q.activeChain,selectedNetworkId:(o=q.activeCaipNetwork)==null?void 0:o.caipNetworkId}),P.setActiveCaipNetworkId(t.caipNetworkId),!m.checkIfSupportedNetwork(t.chainNamespace)&&_.state.enableNetworkSwitch&&!_.state.allowUnsupportedChain&&!j.state.wcBasic&&m.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!==m.state.activeChain,s=(r=m.getNetworkData(t))==null?void 0:r.caipNetwork,n=m.getCaipNetworkByNamespace(t,s==null?void 0:s.id);e&&n&&await m.switchActiveNetwork(n)},async switchActiveNetwork(t,{throwOnFailure:e=!1}={}){var o;const s=m.state.activeChain;if(!s)throw new Error("ChainController:switchActiveNetwork - namespace is required");const n=xe.getProviderId(q.activeChain)==="AUTH",r=(o=m.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=Ih.get(t.chainNamespace);if(!a)throw new Error("Adapter not found");await a.switchNetwork({caipNetwork:t})}m.setActiveCaipNetwork(t)}catch(a){if(e)throw a}ae.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 V.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=m.getRequestedCaipNetworks(e.namespace);t.push(...s)}),t},setRequestedCaipNetworks(t,e){m.setAdapterNetworkState(e,{requestedCaipNetworks:t});const n=m.getAllRequestedCaipNetworks().map(i=>i.chainNamespace),r=Array.from(new Set(n));L.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=m.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){m.setAdapterNetworkState(t,e)},checkIfSupportedNetwork(t,e){var r;const s=e||((r=q.activeCaipNetwork)==null?void 0:r.caipNetworkId),n=m.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=m.getRequestedCaipNetworks(q.activeChain);return e==null?void 0:e.some(s=>s.id===t)},checkIfSmartAccountEnabled(){var n,r;const t=rh.caipNetworkIdToNumber((n=q.activeCaipNetwork)==null?void 0:n.caipNetworkId);if(!q.activeChain||!t)return!1;const s=((r=vg.get(lo.SMART_ACCOUNT_ENABLED_NETWORKS))==null?void 0:r.split(","))||[];return!!(s!=null&&s.includes(t.toString()))},showUnsupportedChainUI(){de.open({view:"UnsupportedChain"})},checkIfNamesSupported(){const t=q.activeCaipNetwork;return!!(t!=null&&t.chainNamespace&&ye.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(t.chainNamespace))},resetNetwork(t){m.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=m.state.chains.get(e))==null?void 0:r.accountState)==null?void 0:i.preferredAccountType,n=_.state.defaultAccountTypes[e];q.activeCaipAddress=void 0,m.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"}),L.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=m.state.chains.get(e))==null?void 0:s.accountState},getNetworkData(t){var s;const e=t||q.activeChain;if(e)return(s=m.state.chains.get(e))==null?void 0:s.networkState},getCaipNetworkByNamespace(t,e){var r,i,o;if(!t)return;const s=m.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=L.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?m.getRequestedCaipNetworks(t):m.getAllRequestedCaipNetworks()},getCaipNetworkById(t,e){return _h.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=m.getAccountData();if(!e)return[];const s=(o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=m.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=m.state.activeCaipAddress,i=r?V.getPlainAddress(r):void 0;if(m.setAccountProp("balanceLoading",!0,n),e.lastRetry&&!V.isAllowedRetry(e.lastRetry,30*ye.ONE_SEC_MS))return m.setAccountProp("balanceLoading",!1,n),[];try{if(i&&s&&n){const c=await Yc.getMyTokensWithBalance();return m.setAccountProp("tokenBalance",c,n),m.setAccountProp("lastRetry",void 0,n),m.setAccountProp("balanceLoading",!1,n),c}}catch(c){m.setAccountProp("lastRetry",Date.now(),n),t==null||t(c),ls.showError("Token Balance Unavailable")}finally{m.setAccountProp("balanceLoading",!1,n)}return[]},isCaipNetworkDisabled(t){var c;const e=t.chainNamespace,s=!!((c=m.getAccountData(e))!=null&&c.caipAddress),n=m.getAllApprovedCaipNetworkIds(),r=m.getNetworkProp("supportsAllNetworks",e)!==!1,i=L.getConnectorId(e),o=L.getAuthConnector(),a=i===U.CONNECTOR_ID.AUTH&&o;return!s||r||a?!1:!(n!=null&&n.includes(t.caipNetworkId))}},m=Ht(_h),km={onSwitchNetwork({network:t,ignoreSwitchConfirmation:e=!1}){var h,p;const s=m.state.activeCaipNetwork,n=m.state.activeChain,r=ee.state.data;if(t.id===(s==null?void 0:s.id))return;const o=!!((h=m.getAccountData(n))!=null&&h.address),a=!!((p=m.getAccountData(t.chainNamespace))!=null&&p.address),c=t.chainNamespace!==n,u=L.getConnectorId(n)===U.CONNECTOR_ID.AUTH,d=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(g=>g===t.chainNamespace);e||u&&d?ee.push("SwitchNetwork",{...r,network:t}):o&&c&&!a?ee.push("SwitchActiveChain",{switchToChain:t.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:t}):ee.push("SwitchNetwork",{...r,network:t})}},ht=ke({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),Rm={state:ht,subscribe(t){return Ze(ht,()=>t(ht))},subscribeKey(t,e){return Qe(ht,t,e)},async open(t){var o,a;const e=t==null?void 0:t.namespace,s=m.state.activeChain,n=e&&e!==s,r=(o=m.getAccountData(t==null?void 0:t.namespace))==null?void 0:o.caipAddress,i=m.state.noAdapters;if(j.state.wcBasic?J.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1}):await J.prefetch(),L.setFilterByNamespace(t==null?void 0:t.namespace),de.setLoading(!0,e),e&&n){const c=((a=m.getNetworkData(e))==null?void 0:a.caipNetwork)||m.getRequestedCaipNetworks(e)[0];c&&(i?(await m.switchActiveNetwork(c),ee.push("ConnectingWalletConnectBasic")):km.onSwitchNetwork({network:c,ignoreSwitchConfirmation:!0}))}else _.state.manualWCControl||i&&!r?V.isMobile()?ee.reset("AllWallets"):ee.reset("ConnectingWalletConnectBasic"):t!=null&&t.view?ee.reset(t.view,t.data):r?ee.reset("Account"):ee.reset("Connect");ht.open=!0,Ns.set({open:!0}),ae.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!r}})},close(){const t=_.state.enableEmbedded,e=!!m.state.activeCaipAddress;ht.open&&ae.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:e}}),ht.open=!1,ee.reset("Connect"),de.clearLoading(),t?e?ee.replace("Account"):ee.push("Connect"):Ns.set({open:!1}),j.resetUri()},setLoading(t,e){e&&ht.loadingNamespaceMap.set(e,t),ht.loading=t,Ns.set({loading:t})},clearLoading(){ht.loadingNamespaceMap.clear(),ht.loading=!1,Ns.set({loading:!1})},shake(){ht.shake||(ht.shake=!0,setTimeout(()=>{ht.shake=!1},500))}},de=Ht(Rm),qr={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"}]},sc={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},xm={providers:uh,selectedProvider:null,error:null,purchaseCurrency:qr,paymentCurrency:sc,purchaseCurrencies:[qr],paymentCurrencies:[],quotesLoading:!1},we=ke(xm),$m={state:we,subscribe(t){return Ze(we,()=>t(we))},subscribeKey(t,e){return Qe(we,t,e)},setSelectedProvider(t){var e,s;if(t&&t.name==="meld"){const n=m.state.activeChain,r=n===U.CHAIN.SOLANA?"SOL":"USDC",i=n?((s=(e=m.state.chains.get(n))==null?void 0:e.accountState)==null?void 0:s.address)??"":"",o=new URL(t.url);o.searchParams.append("publicKey",bg),o.searchParams.append("destinationCurrencyCode",r),o.searchParams.append("walletAddress",i),o.searchParams.append("externalCustomerId",_.state.projectId),we.selectedProvider={...t,url:o.toString()}}else we.selectedProvider=t},setOnrampProviders(t){if(Array.isArray(t)&&t.every(e=>typeof e=="string")){const e=t,s=uh.filter(n=>e.includes(n.name));we.providers=s}else we.providers=[]},setPurchaseCurrency(t){we.purchaseCurrency=t},setPaymentCurrency(t){we.paymentCurrency=t},setPurchaseAmount(t){nc.state.purchaseAmount=t},setPaymentAmount(t){nc.state.paymentAmount=t},async getAvailableCurrencies(){const t=await te.getOnrampOptions();we.purchaseCurrencies=t.purchaseCurrencies,we.paymentCurrencies=t.paymentCurrencies,we.paymentCurrency=t.paymentCurrencies[0]||sc,we.purchaseCurrency=t.purchaseCurrencies[0]||qr,await J.fetchCurrencyImages(t.paymentCurrencies.map(e=>e.id)),await J.fetchTokenImages(t.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){var t,e;we.quotesLoading=!0;try{const s=await te.getOnrampQuote({purchaseCurrency:we.purchaseCurrency,paymentCurrency:we.paymentCurrency,amount:((t=we.paymentAmount)==null?void 0:t.toString())||"0",network:(e=we.purchaseCurrency)==null?void 0:e.symbol});return we.quotesLoading=!1,we.purchaseAmount=Number(s==null?void 0:s.purchaseAmount.amount),s}catch(s){return we.error=s.message,we.quotesLoading=!1,null}finally{we.quotesLoading=!1}},resetState(){we.selectedProvider=null,we.error=null,we.purchaseCurrency=qr,we.paymentCurrency=sc,we.purchaseCurrencies=[qr],we.paymentCurrencies=[],we.paymentAmount=void 0,we.purchaseAmount=void 0,we.quotesLoading=!1}},nc=Ht($m);var Ko={exports:{}};function Um(t){try{return JSON.stringify(t)}catch{return'"[Circular]"'}}var Dm=Lm;function Lm(t,e,s){var n=s&&s.stringify||Um,r=1;if(typeof t=="object"&&t!==null){var i=e.length+r;if(i===1)return t;var o=new Array(i);o[0]=n(t);for(var a=1;a<i;a++)o[a]=n(e[a]);return o.join(" ")}if(typeof t!="string")return t;var c=e.length;if(c===0)return t;for(var l="",u=1-r,d=-1,h=t&&t.length||0,p=0;p<h;){if(t.charCodeAt(p)===37&&p+1<h){switch(d=d>-1?d:0,t.charCodeAt(p+1)){case 100:case 102:if(u>=c||e[u]==null)break;d<p&&(l+=t.slice(d,p)),l+=Number(e[u]),d=p+2,p++;break;case 105:if(u>=c||e[u]==null)break;d<p&&(l+=t.slice(d,p)),l+=Math.floor(Number(e[u])),d=p+2,p++;break;case 79:case 111:case 106:if(u>=c||e[u]===void 0)break;d<p&&(l+=t.slice(d,p));var g=typeof e[u];if(g==="string"){l+="'"+e[u]+"'",d=p+2,p++;break}if(g==="function"){l+=e[u].name||"<anonymous>",d=p+2,p++;break}l+=n(e[u]),d=p+2,p++;break;case 115:if(u>=c)break;d<p&&(l+=t.slice(d,p)),l+=String(e[u]),d=p+2,p++;break;case 37:d<p&&(l+=t.slice(d,p)),l+="%",d=p+2,p++,u--;break}++u}++p}return d===-1?t:(d<h&&(l+=t.slice(d)),l)}const Ml=Dm;Ko.exports=Rs;const bi=Zm().console||{},Mm={mapHttpRequest:zi,mapHttpResponse:zi,wrapRequestSerializer:ma,wrapResponseSerializer:ma,wrapErrorSerializer:ma,req:zi,res:zi,err:jl,errWithCause:jl};function Qs(t,e){return t==="silent"?1/0:e.levels.values[t]}const Jc=Symbol("pino.logFuncs"),rc=Symbol("pino.hierarchy"),Bm={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function Bl(t,e){const s={logger:e,parent:t[rc]};e[rc]=s}function jm(t,e,s){const n={};e.forEach(r=>{n[r]=s[r]?s[r]:bi[r]||bi[Bm[r]||"log"]||rr}),t[Jc]=n}function Fm(t,e){return Array.isArray(t)?t.filter(function(n){return n!=="!stdSerializers.err"}):t===!0?Object.keys(e):!1}function Rs(t){t=t||{},t.browser=t.browser||{};const e=t.browser.transmit;if(e&&typeof e.send!="function")throw Error("pino: transmit option must have a send function");const s=t.browser.write||bi;t.browser.write&&(t.browser.asObject=!0);const n=t.serializers||{},r=Fm(t.browser.serialize,n);let i=t.browser.serialize;Array.isArray(t.browser.serialize)&&t.browser.serialize.indexOf("!stdSerializers.err")>-1&&(i=!1);const o=Object.keys(t.customLevels||{}),a=["error","fatal","warn","info","debug","trace"].concat(o);typeof s=="function"&&a.forEach(function(f){s[f]=s}),(t.enabled===!1||t.browser.disabled)&&(t.level="silent");const c=t.level||"info",l=Object.create(s);l.log||(l.log=rr),jm(l,a,s),Bl({},l),Object.defineProperty(l,"levelVal",{get:d}),Object.defineProperty(l,"level",{get:h,set:p});const u={transmit:e,serialize:r,asObject:t.browser.asObject,asObjectBindingsOnly:t.browser.asObjectBindingsOnly,formatters:t.browser.formatters,levels:a,timestamp:Ym(t),messageKey:t.messageKey||"msg",onChild:t.onChild||rr};l.levels=qm(t),l.level=c,l.isLevelEnabled=function(f){return this.levels.values[f]?this.levels.values[f]>=this.levels.values[this.level]:!1},l.setMaxListeners=l.getMaxListeners=l.emit=l.addListener=l.on=l.prependListener=l.once=l.prependOnceListener=l.removeListener=l.removeAllListeners=l.listeners=l.listenerCount=l.eventNames=l.write=l.flush=rr,l.serializers=n,l._serialize=r,l._stdErrSerialize=i,l.child=function(...f){return g.call(this,u,...f)},e&&(l._logEvent=ic());function d(){return Qs(this.level,this)}function h(){return this._level}function p(f){if(f!=="silent"&&!this.levels.values[f])throw Error("unknown level "+f);this._level=f,un(this,u,l,"error"),un(this,u,l,"fatal"),un(this,u,l,"warn"),un(this,u,l,"info"),un(this,u,l,"debug"),un(this,u,l,"trace"),o.forEach(y=>{un(this,u,l,y)})}function g(f,y,w){if(!y)throw new Error("missing bindings for child Pino");w=w||{},r&&y.serializers&&(w.serializers=y.serializers);const b=w.serializers;if(r&&b){var E=Object.assign({},n,b),N=t.browser.serialize===!0?Object.keys(E):r;delete y.serializers,Xc([y],N,E,this._stdErrSerialize)}function x(W){this._childLevel=(W._childLevel|0)+1,this.bindings=y,E&&(this.serializers=E,this._serialize=N),e&&(this._logEvent=ic([].concat(W._logEvent.bindings,y)))}x.prototype=this;const $=new x(this);return Bl(this,$),$.child=function(...W){return g.call(this,f,...W)},$.level=w.level||this.level,f.onChild($),$}return l}function qm(t){const e=t.customLevels||{},s=Object.assign({},Rs.levels.values,e),n=Object.assign({},Rs.levels.labels,Wm(e));return{values:s,labels:n}}function Wm(t){const e={};return Object.keys(t).forEach(function(s){e[t[s]]=s}),e}Rs.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"}};Rs.stdSerializers=Mm;Rs.stdTimeFunctions=Object.assign({},{nullTime:Sh,epochTime:Nh,unixTime:Jm,isoTime:Xm});function Hm(t){const e=[];t.bindings&&e.push(t.bindings);let s=t[rc];for(;s.parent;)s=s.parent,s.logger.bindings&&e.push(s.logger.bindings);return e.reverse()}function un(t,e,s,n){if(Object.defineProperty(t,n,{value:Qs(t.level,s)>Qs(n,s)?rr:s[Jc][n],writable:!0,enumerable:!0,configurable:!0}),t[n]===rr){if(!e.transmit)return;const i=e.transmit.level||t.level,o=Qs(i,s);if(Qs(n,s)<o)return}t[n]=zm(t,e,s,n);const r=Hm(t);r.length!==0&&(t[n]=Km(r,t[n]))}function Km(t,e){return function(){return e.apply(this,[...t,...arguments])}}function zm(t,e,s,n){return function(r){return function(){const o=e.timestamp(),a=new Array(arguments.length),c=Object.getPrototypeOf&&Object.getPrototypeOf(this)===bi?bi:this;for(var l=0;l<a.length;l++)a[l]=arguments[l];var u=!1;if(e.serialize&&(Xc(a,this._serialize,this.serializers,this._stdErrSerialize),u=!0),e.asObject||e.formatters?r.call(c,...Vm(this,n,a,o,e)):r.apply(c,a),e.transmit){const d=e.transmit.level||t._level,h=Qs(d,s),p=Qs(n,s);if(p<h)return;Gm(this,{ts:o,methodLevel:n,methodValue:p,transmitValue:s.levels.values[e.transmit.level||t._level],send:e.transmit.send,val:Qs(t._level,s)},a,u)}}}(t[Jc][n])}function Vm(t,e,s,n,r){const{level:i,log:o=d=>d}=r.formatters||{},a=s.slice();let c=a[0];const l={};let u=(t._childLevel|0)+1;if(u<1&&(u=1),n&&(l.time=n),i){const d=i(e,t.levels.values[e]);Object.assign(l,d)}else l.level=t.levels.values[e];if(r.asObjectBindingsOnly){if(c!==null&&typeof c=="object")for(;u--&&typeof a[0]=="object";)Object.assign(l,a.shift());return[o(l),...a]}else{if(c!==null&&typeof c=="object"){for(;u--&&typeof a[0]=="object";)Object.assign(l,a.shift());c=a.length?Ml(a.shift(),a):void 0}else typeof c=="string"&&(c=Ml(a.shift(),a));return c!==void 0&&(l[r.messageKey]=c),[o(l)]}}function Xc(t,e,s,n){for(const r in t)if(n&&t[r]instanceof Error)t[r]=Rs.stdSerializers.err(t[r]);else if(typeof t[r]=="object"&&!Array.isArray(t[r])&&e)for(const i in t[r])e.indexOf(i)>-1&&i in s&&(t[r][i]=s[i](t[r][i]))}function Gm(t,e,s,n=!1){const r=e.send,i=e.ts,o=e.methodLevel,a=e.methodValue,c=e.val,l=t._logEvent.bindings;n||Xc(s,t._serialize||Object.keys(t.serializers),t.serializers,t._stdErrSerialize===void 0?!0:t._stdErrSerialize),t._logEvent.ts=i,t._logEvent.messages=s.filter(function(u){return l.indexOf(u)===-1}),t._logEvent.level.label=o,t._logEvent.level.value=a,r(o,t._logEvent,c),t._logEvent=ic(l)}function ic(t){return{ts:0,messages:[],bindings:t||[],level:{label:"",value:0}}}function jl(t){const e={type:t.constructor.name,msg:t.message,stack:t.stack};for(const s in t)e[s]===void 0&&(e[s]=t[s]);return e}function Ym(t){return typeof t.timestamp=="function"?t.timestamp:t.timestamp===!1?Sh:Nh}function zi(){return{}}function ma(t){return t}function rr(){}function Sh(){return!1}function Nh(){return Date.now()}function Jm(){return Math.round(Date.now()/1e3)}function Xm(){return new Date(Date.now()).toISOString()}function Zm(){function t(e){return typeof e<"u"&&e}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 t(self)||t(window)||t(this)||{}}}Ko.exports.default=Rs;Ko.exports.pino=Rs;var Qt=Ko.exports;const zo=Sf(Qt),Fl=2147483648,Qm={convertEVMChainIdToCoinType(t){if(t>=Fl)throw new Error("Invalid chainId");return(Fl|t)>>>0}},Rt=ke({suggestions:[],loading:!1}),ey={state:Rt,subscribe(t){return Ze(Rt,()=>t(Rt))},subscribeKey(t,e){return Qe(Rt,t,e)},async resolveName(t){var e,s;try{return await te.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 te.lookupEnsName(t),!0}catch{return!1}},async getSuggestions(t){try{Rt.loading=!0,Rt.suggestions=[];const e=await te.getEnsNameSuggestions(t);return Rt.suggestions=e.suggestions||[],Rt.suggestions}catch(e){const s=Wr.parseEnsApiError(e,"Error fetching name suggestions");throw new Error(s)}finally{Rt.loading=!1}},async getNamesForAddress(t){try{if(!m.state.activeCaipNetwork)return[];const s=P.getEnsFromCacheForAddress(t);if(s)return s;const n=await te.reverseLookupEnsName({address:t});return P.updateEnsCache({address:t,ens:n,timestamp:Date.now()}),n}catch(e){const s=Wr.parseEnsApiError(e,"Error fetching names for address");throw new Error(s)}},async registerName(t){var r;const e=m.state.activeCaipNetwork,s=(r=m.getAccountData(e==null?void 0:e.chainNamespace))==null?void 0:r.address,n=L.getAuthConnector();if(!e)throw new Error("Network not found");if(!s||!n)throw new Error("Address or auth connector not found");Rt.loading=!0;try{const i=JSON.stringify({name:t,attributes:{},timestamp:Math.floor(Date.now()/1e3)});ee.pushTransactionStack({onCancel(){ee.replace("RegisterAccountName")}});const o=await j.signMessage(i);Rt.loading=!1;const a=e.id;if(!a)throw new Error("Network not found");const c=Qm.convertEVMChainIdToCoinType(Number(a));await te.registerEnsName({coinType:c,address:s,signature:o,message:i}),m.setAccountProp("profileName",t,e.chainNamespace),P.updateEnsCache({address:s,ens:[{name:t,registered_at:new Date().toISOString(),updated_at:void 0,addresses:{},attributes:[]}],timestamp:Date.now()}),ee.replace("RegisterAccountNameSuccess")}catch(i){const o=Wr.parseEnsApiError(i,`Error registering name ${t}`);throw ee.replace("RegisterAccountName"),new Error(o)}finally{Rt.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}},Wr=Ht(ey),ty={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"]},en={RPC_ERROR_CODE:{USER_REJECTED:5e3,USER_REJECTED_METHODS:5002},getMethodsByChainNamespace(t){return ty[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}`,u=n[o];switch(u.chains.push(l),l){case"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":u.chains.push("solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ");break;case"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1":u.chains.push("solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K");break}return u!=null&&u.rpcMap&&c&&(u.rpcMap[i]=c),n},{});return this.applyNamespaceOverrides(s,e)},resolveReownName:async t=>{var n;const e=await Wr.resolveName(t);return((n=(Object.values(e==null?void 0: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===en.RPC_ERROR_CODE.USER_REJECTED_METHODS,r=s&&e.code===en.RPC_ERROR_CODE.USER_REJECTED;return n||r}return!1}catch{return!1}},isOriginAllowed(t,e,s){for(const n of[...e,...s])if(n.includes("*")){const i=`^${n.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&").replace(/\\\*/gu,".*")}$`;if(new RegExp(i,"u").test(t))return!0}else try{if(new URL(n).origin===t)return!0}catch{if(n===t)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=en.getWalletConnectAccounts(t,e);s(a)}),n&&t.on("disconnect",()=>{n()}),r&&t.on("accountsChanged",a=>{var c,l,u,d,h;try{const p=((u=(l=(c=t.session)==null?void 0:c.namespaces)==null?void 0:l[e])==null?void 0:u.accounts)||[],g=(h=(d=t.rpcProviders)==null?void 0:d[e])==null?void 0:h.getDefaultChain(),f=a.map(y=>{const w=p.find(N=>N.includes(`${e}:${g}:${y}`));if(!w)return;const{chainId:b,chainNamespace:E}=Xe.parseCaipAddress(w);return{address:y,chainId:b,chainNamespace:E}}).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=>Xe.parseCaipAddress(c)).filter(({address:c})=>s.has(c.toLowerCase())?!1:(s.add(c.toLowerCase()),!0));return n&&n.length>0?n:[]}},sy=[U.CONNECTOR_ID.AUTH,U.CONNECTOR_ID.WALLET_CONNECT];class ny{constructor(e){this.availableConnectors=[],this.availableConnections=[],this.providerHandlers={},this.eventListeners=new Map,this.getCaipNetworks=s=>m.getCaipNetworks(s),this.getConnectorId=s=>L.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){m.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 en.isUserRejectedRequestError(s)?new ch(s):s}}async switchNetwork(e){var i;const{caipNetwork:s}=e,n=xe.getProviderId(s.chainNamespace),r=xe.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=L.getAuthConnector())==null?void 0:i.provider;if(!o)throw new Error("Auth provider not found");const a=qt(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}=V.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}=V.getAccount(a);return{address:c}}),caipNetwork:i}))}}onAccountsChanged(e,s,n=!0){var r,i;if(e.length>0){const{address:o}=V.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}=V.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(sy.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 dn=null;const Zt={getSIWX(){return _.state.siwx},async initializeIfEnabled(t=m.getActiveCaipAddress()){var i,o,a;const e=_.state.siwx;if(!(e&&t))return;const[s,n,r]=t.split(":");if(m.checkIfSupportedNetwork(s,`${s}:${n}`))try{if((i=_.state.remoteFeatures)!=null&&i.emailCapture){const l=(o=m.getAccountData(s))==null?void 0:o.user;await de.open({view:"DataCapture",data:{email:(l==null?void 0:l.email)??void 0}});return}if(dn&&await dn,(await e.getSessions(`${s}:${n}`,r)).length)return;await de.open({view:"SIWXSignMessage"})}catch(c){console.error("SIWXUtil:initializeIfEnabled",c),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(c)}),await((a=j._getClient())==null?void 0:a.disconnect().catch(console.error)),ee.reset("Connect"),ls.showError("A problem occurred while trying initialize authentication")}},async isAuthenticated(t=m.getActiveCaipAddress()){if(!_.state.siwx||!t)return!0;const{chainNamespace:s,chainId:n,address:r}=Xe.parseCaipAddress(t),i=`${s}:${n}`;return(await Zt.getSessions({address:r,caipNetworkId:i})).length>0},async requestSignMessage(){const t=_.state.siwx,e=V.getPlainAddress(m.getActiveCaipAddress()),s=Hi(),n=j._getClient();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");if(!n)throw new Error("No ConnectionController client found");try{const r=await t.createMessage({chainId:s.caipNetworkId,accountAddress:e}),i=r.toString();L.getConnectorId(s.chainNamespace)===U.CONNECTOR_ID.AUTH&&ee.pushTransactionStack({});const a=await n.signMessage(i);await t.addSession({data:r,message:i,signature:a}),m.setLastConnectedSIWECaipNetwork(s),de.close(),ae.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(r){(!de.state.open||ee.state.view==="ApproveTransaction")&&await de.open({view:"SIWXSignMessage"}),ls.showError("Error signing message"),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(r)}),console.error("SWIXUtil:requestSignMessage",r)}},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=m.getLastConnectedSIWECaipNetwork();if(n){const r=await(e==null?void 0:e.getSessions(n==null?void 0:n.caipNetworkId,V.getPlainAddress(m.getActiveCaipAddress())||""));r&&r.length>0?await m.switchActiveNetwork(n):await j.disconnect()}else await j.disconnect()}else de.close();de.close(),ae.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getAllSessions(){const t=this.getSIWX(),e=m.getAllRequestedCaipNetworks(),s=[];return await Promise.all(e.map(async n=>{const r=await(t==null?void 0:t.getSessions(n.caipNetworkId,V.getPlainAddress(m.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=m.getActiveCaipAddress();s=V.getPlainAddress(r)}let n=t==null?void 0:t.caipNetworkId;if(!n){const r=m.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=ee.state.view==="ApproveTransaction",n=ee.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 d;const i=Zt.getSIWX(),o=Hi();if(!i||!r.includes(U.CHAIN.EVM)||(d=_.state.remoteFeatures)!=null&&d.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()},u=await t.connect({chainId:e,socialUri:s,siwxMessage:l,preferredAccountType:n});return l.accountAddress=u.address,l.serializedMessage=u.message||"",u.signature&&u.message&&await Zt.addEmbeddedWalletSession(l,u.message,u.signature),m.setLastConnectedSIWECaipNetwork(o),{address:u.address,chainId:u.chainId,accounts:u.accounts}},async addEmbeddedWalletSession(t,e,s){if(dn)return dn;const n=Zt.getSIWX();return n?(dn=n.addSession({data:t,message:e,signature:s}).finally(()=>{dn=null}),dn):Promise.resolve()},async universalProviderAuthenticate({universalProvider:t,chains:e,methods:s}){var l,u,d;const n=Zt.getSIWX(),r=Hi(),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=Hi())==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)]});ls.showLoading("Authenticating...",{autoClose:!1});const c={...a.session.peer.metadata,name:a.session.peer.metadata.name,icon:(u=a.session.peer.metadata.icons)==null?void 0:u[0],type:"WALLET_CONNECT"};if(m.setAccountProp("connectedWalletInfo",c,Array.from(i)[0]),(d=a==null?void 0:a.auths)!=null&&d.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&&m.setLastConnectedSIWECaipNetwork(r),ae.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:Zt.getSIWXEventProperties()})}catch(p){throw console.error("SIWX:universalProviderAuth - failed to set sessions",p),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:Zt.getSIWXEventProperties(p)}),await t.disconnect().catch(console.error),p}finally{ls.hide()}}return!0},getSIWXEventProperties(t){var s;const e=m.state.activeChain;if(!e)throw new Error("SIWXUtil:getSIWXEventProperties - namespace is required");return{network:((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||"",isSmartAccount:qt(e)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,message:t?V.parseError(t):void 0}},async clearSessions(){const t=this.getSIWX();t&&await t.setSessions([])}};class ry{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=m.getCaipNetworks.bind(m),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=en.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 Zt.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:iy})}}const iy=["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"],zt=ke({message:"",variant:"info",open:!1}),oy={state:zt,subscribeKey(t,e){return Qe(zt,t,e)},open(t,e){const{debug:s}=_.state,{code:n,displayMessage:r,debugMessage:i}=t;r&&s&&(zt.message=r,zt.variant=e,zt.open=!0),i&&console.error(typeof i=="function"?i():i,n?{code:n}:void 0)},warn(t,e,s){zt.open=!0,zt.message=t,zt.variant="warning",e&&console.warn(e,s)},close(){zt.open=!1,zt.message="",zt.variant="info"}},It=Ht(oy),ay={asset:"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913"},cy={asset:"0x036CbD53842c5426634e7929541eC2318f3dCF7e"};function ly(t){return!t||typeof t.then!="function"?Promise.resolve(t):t}function ze(t,...e){try{return ly(t(...e))}catch(s){return Promise.reject(s)}}function uy(t){const e=typeof t;return t===null||e!=="object"&&e!=="function"}function dy(t){const e=Object.getPrototypeOf(t);return!e||e.isPrototypeOf(Object)}function ho(t){if(uy(t))return String(t);if(dy(t)||Array.isArray(t))return JSON.stringify(t);if(typeof t.toJSON=="function")return ho(t.toJSON());throw new Error("[unstorage] Cannot stringify value!")}const oc="base64:";function hy(t){return typeof t=="string"?t:oc+gy(t)}function py(t){return typeof t!="string"||!t.startsWith(oc)?t:fy(t.slice(oc.length))}function fy(t){return globalThis.Buffer?Buffer.from(t,"base64"):Uint8Array.from(globalThis.atob(t),e=>e.codePointAt(0))}function gy(t){return globalThis.Buffer?Buffer.from(t).toString("base64"):globalThis.btoa(String.fromCodePoint(...t))}function ft(t){var e;return t&&((e=t.split("?")[0])==null?void 0:e.replace(/[/\\]/g,":").replace(/:+/g,":").replace(/^:|:$/g,""))||""}function my(...t){return ft(t.join(":"))}function Vi(t){return t=ft(t),t?t+":":""}function yy(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 wy(t,e){return e?t.startsWith(e)&&t[t.length-1]!=="$":t[t.length-1]!=="$"}const by="memory",vy=()=>{const t=new Map;return{name:by,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 Ey(t={}){const e={mounts:{"":t.driver||vy()},mountpoints:[""],watching:!1,watchListeners:[],unwatch:{}},s=l=>{for(const u of e.mountpoints)if(l.startsWith(u))return{base:u,relativeKey:l.slice(u.length),driver:e.mounts[u]};return{base:"",relativeKey:l,driver:e.mounts[""]}},n=(l,u)=>e.mountpoints.filter(d=>d.startsWith(l)||u&&l.startsWith(d)).map(d=>({relativeBase:l.length>d.length?l.slice(d.length):void 0,mountpoint:d,driver:e.mounts[d]})),r=(l,u)=>{if(e.watching){u=ft(u);for(const d of e.watchListeners)d(l,u)}},i=async()=>{if(!e.watching){e.watching=!0;for(const l in e.mounts)e.unwatch[l]=await ql(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,u,d)=>{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=ft(f?g:g.key),w=f?void 0:g.value,b=f||!g.options?u:{...u,...g.options},E=s(y);p(E).items.push({key:y,value:w,relativeKey:E.relativeKey,options:b})}return Promise.all([...h.values()].map(g=>d(g))).then(g=>g.flat())},c={hasItem(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return ze(h.hasItem,d,u)},getItem(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return ze(h.getItem,d,u).then(p=>Li(p))},getItems(l,u={}){return a(l,u,d=>d.driver.getItems?ze(d.driver.getItems,d.items.map(h=>({key:h.relativeKey,options:h.options})),u).then(h=>h.map(p=>({key:my(d.base,p.key),value:Li(p.value)}))):Promise.all(d.items.map(h=>ze(d.driver.getItem,h.relativeKey,h.options).then(p=>({key:h.key,value:Li(p)})))))},getItemRaw(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return h.getItemRaw?ze(h.getItemRaw,d,u):ze(h.getItem,d,u).then(p=>py(p))},async setItem(l,u,d={}){if(u===void 0)return c.removeItem(l);l=ft(l);const{relativeKey:h,driver:p}=s(l);p.setItem&&(await ze(p.setItem,h,ho(u),d),p.watch||r("update",l))},async setItems(l,u){await a(l,u,async d=>{if(d.driver.setItems)return ze(d.driver.setItems,d.items.map(h=>({key:h.relativeKey,value:ho(h.value),options:h.options})),u);d.driver.setItem&&await Promise.all(d.items.map(h=>ze(d.driver.setItem,h.relativeKey,ho(h.value),h.options)))})},async setItemRaw(l,u,d={}){if(u===void 0)return c.removeItem(l,d);l=ft(l);const{relativeKey:h,driver:p}=s(l);if(p.setItemRaw)await ze(p.setItemRaw,h,u,d);else if(p.setItem)await ze(p.setItem,h,hy(u),d);else return;p.watch||r("update",l)},async removeItem(l,u={}){typeof u=="boolean"&&(u={removeMeta:u}),l=ft(l);const{relativeKey:d,driver:h}=s(l);h.removeItem&&(await ze(h.removeItem,d,u),(u.removeMeta||u.removeMata)&&await ze(h.removeItem,d+"$",u),h.watch||r("remove",l))},async getMeta(l,u={}){typeof u=="boolean"&&(u={nativeOnly:u}),l=ft(l);const{relativeKey:d,driver:h}=s(l),p=Object.create(null);if(h.getMeta&&Object.assign(p,await ze(h.getMeta,d,u)),!u.nativeOnly){const g=await ze(h.getItem,d+"$",u).then(f=>Li(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,u,d={}){return this.setItem(l+"$",u,d)},removeMeta(l,u={}){return this.removeItem(l+"$",u)},async getKeys(l,u={}){var y;l=Vi(l);const d=n(l,!0);let h=[];const p=[];let g=!0;for(const w of d){(y=w.driver.flags)!=null&&y.maxDepth||(g=!1);const b=await ze(w.driver.getKeys,w.relativeBase,u);for(const E of b){const N=w.mountpoint+ft(E);h.some(x=>N.startsWith(x))||p.push(N)}h=[w.mountpoint,...h.filter(E=>!E.startsWith(w.mountpoint))]}const f=u.maxDepth!==void 0&&!g;return p.filter(w=>(!f||yy(w,u.maxDepth))&&wy(w,l))},async clear(l,u={}){l=Vi(l),await Promise.all(n(l,!1).map(async d=>{if(d.driver.clear)return ze(d.driver.clear,d.relativeBase,u);if(d.driver.removeItem){const h=await d.driver.getKeys(d.relativeBase||"",u);return Promise.all(h.map(p=>d.driver.removeItem(p,u)))}}))},async dispose(){await Promise.all(Object.values(e.mounts).map(l=>Wl(l)))},async watch(l){return await i(),e.watchListeners.push(l),async()=>{e.watchListeners=e.watchListeners.filter(u=>u!==l),e.watchListeners.length===0&&await o()}},async unwatch(){e.watchListeners=[],await o()},mount(l,u){if(l=Vi(l),l&&e.mounts[l])throw new Error(`already mounted at ${l}`);return l&&(e.mountpoints.push(l),e.mountpoints.sort((d,h)=>h.length-d.length)),e.mounts[l]=u,e.watching&&Promise.resolve(ql(u,r,l)).then(d=>{e.unwatch[l]=d}).catch(console.error),c},async unmount(l,u=!0){var d,h;l=Vi(l),!(!l||!e.mounts[l])&&(e.watching&&l in e.unwatch&&((h=(d=e.unwatch)[l])==null||h.call(d),delete e.unwatch[l]),u&&await Wl(e.mounts[l]),e.mountpoints=e.mountpoints.filter(p=>p!==l),delete e.mounts[l])},getMount(l=""){l=ft(l)+":";const u=s(l);return{driver:u.driver,base:u.base}},getMounts(l="",u={}){return l=ft(l),n(l,u.parents).map(h=>({driver:h.driver,base:h.mountpoint}))},keys:(l,u={})=>c.getKeys(l,u),get:(l,u={})=>c.getItem(l,u),set:(l,u,d={})=>c.setItem(l,u,d),has:(l,u={})=>c.hasItem(l,u),del:(l,u={})=>c.removeItem(l,u),remove:(l,u={})=>c.removeItem(l,u)};return c}function ql(t,e,s){return t.watch?t.watch((n,r)=>e(n,s+r)):()=>{}}async function Wl(t){typeof t.dispose=="function"&&await ze(t.dispose)}const Cy="idb-keyval";var Ay=(t={})=>{const e=t.base&&t.base.length>0?`${t.base}:`:"",s=r=>e+r;let n;return t.dbName&&t.storeName&&(n=Nf(t.dbName,t.storeName)),{name:Cy,options:t,async hasItem(r){return!(typeof await El(s(r),n)>"u")},async getItem(r){return await El(s(r),n)??null},setItem(r,i){return kf(s(r),i,n)},removeItem(r){return Pf(s(r),n)},getKeys(){return Of(n)},clear(){return Tf(n)}}};const Iy="WALLET_CONNECT_V2_INDEXED_DB",_y="keyvaluestorage";let Sy=class{constructor(){this.indexedDb=Ey({driver:Ay({dbName:Iy,storeName:_y})})}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,Rn(s))}async removeItem(e){await this.indexedDb.removeItem(e)}};var ya=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},po={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 ya<"u"&&ya.localStorage?po.exports=ya.localStorage:typeof window<"u"&&window.localStorage?po.exports=window.localStorage:po.exports=new e})();function Ny(t){var e;return[t[0],Eo((e=t[1])!=null?e:"")]}let Ty=class{constructor(){this.localStorage=po.exports}async getKeys(){return Object.keys(this.localStorage)}async getEntries(){return Object.entries(this.localStorage).map(Ny)}async getItem(e){const s=this.localStorage.getItem(e);if(s!==null)return Eo(s)}async setItem(e,s){this.localStorage.setItem(e,Rn(s))}async removeItem(e){this.localStorage.removeItem(e)}};const Oy="wc_storage_version",Hl=1,Py=async(t,e,s)=>{const n=Oy,r=await e.getItem(n);if(r&&r>=Hl){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,Hl),s(e),ky(t,o)},ky=async(t,e)=>{e.length&&e.forEach(async s=>{await t.removeItem(s)})};let Ry=class{constructor(){this.initialized=!1,this.setInitialized=s=>{this.storage=s,this.initialized=!0};const e=new Ty;this.storage=e;try{const s=new Sy;Py(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)})}};const xy={level:"info"},Vo="custom_context",Zc=1e3*1024;var $y=Object.defineProperty,Uy=(t,e,s)=>e in t?$y(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Vs=(t,e,s)=>Uy(t,typeof e!="symbol"?e+"":e,s);let Dy=class{constructor(e){Vs(this,"nodeValue"),Vs(this,"sizeInBytes"),Vs(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}},Kl=class{constructor(e){Vs(this,"lengthInNodes"),Vs(this,"sizeInBytes"),Vs(this,"head"),Vs(this,"tail"),Vs(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new Dy(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 Ly=Object.defineProperty,My=(t,e,s)=>e in t?Ly(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gi=(t,e,s)=>My(t,typeof e!="symbol"?e+"":e,s);let Th=class{constructor(e,s=Zc){Gi(this,"logs"),Gi(this,"level"),Gi(this,"levelValue"),Gi(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Qt.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Kl(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Qt.levels.values.error?console.error(e):s===Qt.levels.values.warn?console.warn(e):s===Qt.levels.values.debug?console.debug(e):s===Qt.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Rn({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 Kl(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Rn({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var By=Object.defineProperty,jy=(t,e,s)=>e in t?By(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fy=(t,e,s)=>jy(t,e+"",s);let qy=class{constructor(e,s=Zc){Fy(this,"baseChunkLogger"),this.baseChunkLogger=new Th(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 Wy=Object.defineProperty,Hy=(t,e,s)=>e in t?Wy(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ky=(t,e,s)=>Hy(t,e+"",s);let zy=class{constructor(e,s=Zc){Ky(this,"baseChunkLogger"),this.baseChunkLogger=new Th(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 Vy=Object.defineProperty,Gy=Object.defineProperties,Yy=Object.getOwnPropertyDescriptors,zl=Object.getOwnPropertySymbols,Jy=Object.prototype.hasOwnProperty,Xy=Object.prototype.propertyIsEnumerable,Vl=(t,e,s)=>e in t?Vy(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,No=(t,e)=>{for(var s in e||(e={}))Jy.call(e,s)&&Vl(t,s,e[s]);if(zl)for(var s of zl(e))Xy.call(e,s)&&Vl(t,s,e[s]);return t},To=(t,e)=>Gy(t,Yy(e));function Zy(t){return To(No({},t),{level:(t==null?void 0:t.level)||xy.level})}function Qy(t,e,s=Vo){return t[s]=e,t}function Et(t,e=Vo){return t[e]||""}function ew(t,e,s=Vo){const n=Et(t,s);return n.trim()?`${n}/${e}`:e}function kt(t,e,s=Vo){const n=ew(t,e,s),r=t.child({context:n});return Qy(r,n,s)}function tw(t){var e,s;const n=new qy((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(To(No({},t.opts),{level:"trace",browser:To(No({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function sw(t){var e;const s=new zy((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(To(No({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function Oh(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?tw(t):sw(t)}var nw=Object.defineProperty,rw=(t,e,s)=>e in t?nw(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gl=(t,e,s)=>rw(t,typeof e!="symbol"?e+"":e,s);let iw=class extends wr{constructor(e){super(),this.opts=e,Gl(this,"protocol","wc"),Gl(this,"version",2)}};var ow=Object.defineProperty,aw=(t,e,s)=>e in t?ow(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,cw=(t,e,s)=>aw(t,e+"",s);let lw=class extends wr{constructor(e,s){super(),this.core=e,this.logger=s,cw(this,"records",new Map)}},uw=class{constructor(e,s){this.logger=e,this.core=s}},dw=class extends wr{constructor(e,s){super(),this.relayer=e,this.logger=s}},hw=class extends wr{constructor(e){super()}},pw=class{constructor(e,s,n,r){this.core=e,this.logger=s,this.name=n}},fw=class extends wr{constructor(e,s){super(),this.relayer=e,this.logger=s}},gw=class extends wr{constructor(e,s){super(),this.core=e,this.logger=s}},mw=class{constructor(e,s,n){this.core=e,this.logger=s,this.store=n}},yw=class{constructor(e,s){this.projectId=e,this.logger=s}},ww=class{constructor(e,s,n){this.core=e,this.logger=s,this.telemetryEnabled=n}};var bw=Object.defineProperty,vw=(t,e,s)=>e in t?bw(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Yl=(t,e,s)=>vw(t,typeof e!="symbol"?e+"":e,s);let Ew=class{constructor(e){this.opts=e,Yl(this,"protocol","wc"),Yl(this,"version",2)}},Cw=class{constructor(e){this.client=e}};var Aw={};const Iw=":";function Os(t){const[e,s]=t.split(Iw);return{namespace:e,reference:s}}function Ph(t,e){return t.includes(":")?[t]:e.chains||[]}var _w=Object.defineProperty,Sw=Object.defineProperties,Nw=Object.getOwnPropertyDescriptors,Jl=Object.getOwnPropertySymbols,Tw=Object.prototype.hasOwnProperty,Ow=Object.prototype.propertyIsEnumerable,ac=(t,e,s)=>e in t?_w(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xl=(t,e)=>{for(var s in e||(e={}))Tw.call(e,s)&&ac(t,s,e[s]);if(Jl)for(var s of Jl(e))Ow.call(e,s)&&ac(t,s,e[s]);return t},Pw=(t,e)=>Sw(t,Nw(e)),Zl=(t,e,s)=>ac(t,typeof e!="symbol"?e+"":e,s);const kw="ReactNative",Ot={reactNative:"react-native",node:"node",browser:"browser",unknown:"unknown"},Rw="js";function Oo(){return typeof process<"u"&&typeof process.versions<"u"&&typeof process.versions.node<"u"}function on(){return!ur()&&!!th()&&navigator.product===kw}function xw(){return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"&&(global==null?void 0:global.Platform.OS)==="android"}function $w(){return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"&&(global==null?void 0:global.Platform.OS)==="ios"}function Er(){return!Oo()&&!!th()&&!!ur()}function Pi(){return on()?Ot.reactNative:Oo()?Ot.node:Er()?Ot.browser:Ot.unknown}function Ql(){var t;try{return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Application)<"u"?(t=global.Application)==null?void 0:t.applicationId:void 0}catch{return}}function Uw(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 Dw(t){var e,s;const n=kh();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!=="")),Pw(Xl(Xl({},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 kh(){return Rf()||{name:"",description:"",url:"",icons:[""]}}function Lw(){if(Pi()===Ot.reactNative&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"){const{OS:s,Version:n}=global.Platform;return[s,n].join("-")}const t=$f();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 Mw(){var t;const e=Pi();return e===Ot.browser?[e,((t=Uf())==null?void 0:t.host)||"unknown"].join(":"):e}function Rh(t,e,s){const n=Lw(),r=Mw();return[[t,e].join("-"),[Rw,s].join("-"),n,r].join("/")}function Bw({protocol:t,version:e,relayUrl:s,sdkVersion:n,auth:r,projectId:i,useOnCloseEvent:o,bundleId:a,packageName:c}){const l=s.split("?"),u=Rh(t,e,n),d={auth:r,ua:u,projectId:i,useOnCloseEvent:o,packageName:c||void 0,bundleId:a||void 0},h=Uw(l[1]||"",d);return l[0]+"?"+h}function An(t,e){return t.filter(s=>e.includes(s)).length===t.length}function cc(t){return Object.fromEntries(t.entries())}function lc(t){return new Map(Object.entries(t))}function yn(t=F.FIVE_MINUTES,e){const s=F.toMiliseconds(t||F.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 us(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 xh(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 jw(t){return xh("topic",t)}function Fw(t){return xh("id",t)}function $h(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 Be(t,e){return F.fromMiliseconds(Date.now()+F.toMiliseconds(t))}function cs(t){return Date.now()>=F.toMiliseconds(t)}function Ae(t,e){return`${t}${e?`:${e}`:""}`}function ps(t=[],e=[]){return[...new Set([...t,...e])]}async function qw({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=Ww(i,t,e),a=Pi();if(a===Ot.browser){if(!((n=ur())!=null&&n.hasFocus())){console.warn("Document does not have focus, skipping deeplink.");return}Hw(o)}else a===Ot.reactNative&&typeof(global==null?void 0:global.Linking)<"u"&&await global.Linking.openURL(o)}catch(r){console.error(r)}}function Ww(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}${Gw(n,!0)}`}else r=`${r}/wc?${n}`;return r}function Hw(t){let e="_self";Vw()?e="_top":(zw()||t.startsWith("https://")||t.startsWith("http://"))&&(e="_blank"),window.open(t,e,"noreferrer noopener")}async function Kw(t,e){let s="";try{if(Er()&&(s=localStorage.getItem(e),s))return s;s=await t.getItem(e)}catch(n){console.error(n)}return s}function eu(t,e){if(!t.includes(e))return null;const s=t.split(/([&,?,=])/),n=s.indexOf(e);return s[n+2]}function tu(){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 Qc(){return typeof process<"u"&&Aw.IS_VITEST==="true"}function zw(){return typeof window<"u"&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)}function Vw(){try{return window.self!==window.top}catch{return!1}}function Gw(t,e=!1){const s=Buffer.from(t).toString("base64");return e?s.replace(/[=]/g,""):s}function Uh(t){return Buffer.from(t,"base64").toString("utf-8")}function Yw(t){return new Promise(e=>setTimeout(e,t))}let Jw=class{constructor({limit:e}){Zl(this,"limit"),Zl(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 Yi=BigInt(2**32-1),su=BigInt(32);function Dh(t,e=!1){return e?{h:Number(t&Yi),l:Number(t>>su&Yi)}:{h:Number(t>>su&Yi)|0,l:Number(t&Yi)|0}}function Lh(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}=Dh(t[i],e);[n[i],r[i]]=[o,a]}return[n,r]}const nu=(t,e,s)=>t>>>s,ru=(t,e,s)=>t<<32-s|e>>>s,Hs=(t,e,s)=>t>>>s|e<<32-s,Ks=(t,e,s)=>t<<32-s|e>>>s,Dr=(t,e,s)=>t<<64-s|e>>>s-32,Lr=(t,e,s)=>t>>>s-32|e<<64-s,Xw=(t,e)=>e,Zw=(t,e)=>t,Qw=(t,e,s)=>t<<s|e>>>32-s,eb=(t,e,s)=>e<<s|t>>>32-s,tb=(t,e,s)=>e<<s-32|t>>>64-s,sb=(t,e,s)=>t<<s-32|e>>>64-s;function Jt(t,e,s,n){const r=(e>>>0)+(n>>>0);return{h:t+s+(r/2**32|0)|0,l:r|0}}const el=(t,e,s)=>(t>>>0)+(e>>>0)+(s>>>0),tl=(t,e,s,n)=>e+s+n+(t/2**32|0)|0,nb=(t,e,s,n)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0),rb=(t,e,s,n,r)=>e+s+n+r+(t/2**32|0)|0,ib=(t,e,s,n,r)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0)+(r>>>0),ob=(t,e,s,n,r,i)=>e+s+n+r+i+(t/2**32|0)|0,zn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Go(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function xs(t){if(!Number.isSafeInteger(t)||t<0)throw new Error("positive integer expected, got "+t)}function ts(t,...e){if(!Go(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 Yo(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");xs(t.outputLen),xs(t.blockLen)}function rn(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 sl(t,e){ts(t);const s=e.outputLen;if(t.length<s)throw new Error("digestInto() expects output buffer of length at least "+s)}function vi(t){return new Uint32Array(t.buffer,t.byteOffset,Math.floor(t.byteLength/4))}function Wt(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function wa(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function ss(t,e){return t<<32-e|t>>>e}const Mh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Bh(t){return t<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}const bs=Mh?t=>t:t=>Bh(t);function ab(t){for(let e=0;e<t.length;e++)t[e]=Bh(t[e]);return t}const zs=Mh?t=>t:ab,jh=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",cb=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function ir(t){if(ts(t),jh)return t.toHex();let e="";for(let s=0;s<t.length;s++)e+=cb[t[s]];return e}const ys={_0:48,_9:57,A:65,F:70,a:97,f:102};function iu(t){if(t>=ys._0&&t<=ys._9)return t-ys._0;if(t>=ys.A&&t<=ys.F)return t-(ys.A-10);if(t>=ys.a&&t<=ys.f)return t-(ys.a-10)}function Po(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(jh)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=iu(t.charCodeAt(i)),a=iu(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 Fh(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function es(t){return typeof t=="string"&&(t=Fh(t)),ts(t),t}function Gs(...t){let e=0;for(let n=0;n<t.length;n++){const r=t[n];ts(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}class Jo{}function ki(t){const e=n=>t().update(es(n)).digest(),s=t();return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=()=>t(),e}function lb(t){const e=(n,r)=>t(r).update(es(n)).digest(),s=t({});return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=n=>t(n),e}function qn(t=32){if(zn&&typeof zn.getRandomValues=="function")return zn.getRandomValues(new Uint8Array(t));if(zn&&typeof zn.randomBytes=="function")return Uint8Array.from(zn.randomBytes(t));throw new Error("crypto.getRandomValues must be defined")}const ub=BigInt(0),Sr=BigInt(1),db=BigInt(2),hb=BigInt(7),pb=BigInt(256),fb=BigInt(113),qh=[],Wh=[],Hh=[];for(let t=0,e=Sr,s=1,n=0;t<24;t++){[s,n]=[n,(2*s+3*n)%5],qh.push(2*(5*n+s)),Wh.push((t+1)*(t+2)/2%64);let r=ub;for(let i=0;i<7;i++)e=(e<<Sr^(e>>hb)*fb)%pb,e&db&&(r^=Sr<<(Sr<<BigInt(i))-Sr);Hh.push(r)}const Kh=Lh(Hh,!0),gb=Kh[0],mb=Kh[1],ou=(t,e,s)=>s>32?tb(t,e,s):Qw(t,e,s),au=(t,e,s)=>s>32?sb(t,e,s):eb(t,e,s);function yb(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],u=s[c+1],d=ou(l,u,1)^s[a],h=au(l,u,1)^s[a+1];for(let p=0;p<50;p+=10)t[o+p]^=d,t[o+p+1]^=h}let r=t[2],i=t[3];for(let o=0;o<24;o++){const a=Wh[o],c=ou(r,i,a),l=au(r,i,a),u=qh[o];r=t[u],i=t[u+1],t[u]=c,t[u+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]^=gb[n],t[1]^=mb[n]}Wt(s)}let wb=class zh extends Jo{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,xs(n),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=vi(this.state)}clone(){return this._cloneInto()}keccak(){zs(this.state32),yb(this.state32,this.rounds),zs(this.state32),this.posOut=0,this.pos=0}update(e){rn(this),e=es(e),ts(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&&n===r-1&&this.keccak(),e[r-1]^=128,this.keccak()}writeInto(e){rn(this,!1),ts(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 xs(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(sl(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,Wt(this.state)}_cloneInto(e){const{blockLen:s,suffix:n,outputLen:r,rounds:i,enableXOF:o}=this;return e||(e=new zh(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 bb=(t,e,s)=>ki(()=>new wb(e,t,s)),vb=bb(1,136,256/8);function Eb(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 Cb(t,e,s){return t&e^~t&s}function Ab(t,e,s){return t&e^t&s^e&s}let Vh=class extends Jo{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=wa(this.buffer)}update(e){rn(this),e=es(e),ts(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=wa(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){rn(this),sl(e,this),this.finished=!0;const{buffer:s,view:n,blockLen:r,isLE:i}=this;let{pos:o}=this;s[o++]=128,Wt(this.buffer.subarray(o)),this.padOffset>r-o&&(this.process(n,0),o=0);for(let d=o;d<r;d++)s[d]=0;Eb(n,r-8,BigInt(this.length*8),i),this.process(n,0);const a=wa(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let d=0;d<l;d++)a.setUint32(4*d,u[d],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 Ms=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),tt=Uint32Array.from([3418070365,3238371032,1654270250,914150663,2438529370,812702999,355462360,4144912697,1731405415,4290775857,2394180231,1750603025,3675008525,1694076839,1203062813,3204075428]),st=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]),Ib=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]),Bs=new Uint32Array(64);class _b extends Vh{constructor(e=32){super(64,e,8,!1),this.A=Ms[0]|0,this.B=Ms[1]|0,this.C=Ms[2]|0,this.D=Ms[3]|0,this.E=Ms[4]|0,this.F=Ms[5]|0,this.G=Ms[6]|0,this.H=Ms[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 d=0;d<16;d++,s+=4)Bs[d]=e.getUint32(s,!1);for(let d=16;d<64;d++){const h=Bs[d-15],p=Bs[d-2],g=ss(h,7)^ss(h,18)^h>>>3,f=ss(p,17)^ss(p,19)^p>>>10;Bs[d]=f+Bs[d-7]+g+Bs[d-16]|0}let{A:n,B:r,C:i,D:o,E:a,F:c,G:l,H:u}=this;for(let d=0;d<64;d++){const h=ss(a,6)^ss(a,11)^ss(a,25),p=u+h+Cb(a,c,l)+Ib[d]+Bs[d]|0,g=(ss(n,2)^ss(n,13)^ss(n,22))+Ab(n,r,i)|0;u=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,u=u+this.H|0,this.set(n,r,i,o,a,c,l,u)}roundClean(){Wt(Bs)}destroy(){this.set(0,0,0,0,0,0,0,0),Wt(this.buffer)}}const Gh=Lh(["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))),Sb=Gh[0],Nb=Gh[1],js=new Uint32Array(80),Fs=new Uint32Array(80);let nl=class extends Vh{constructor(e=64){super(128,e,16,!1),this.Ah=st[0]|0,this.Al=st[1]|0,this.Bh=st[2]|0,this.Bl=st[3]|0,this.Ch=st[4]|0,this.Cl=st[5]|0,this.Dh=st[6]|0,this.Dl=st[7]|0,this.Eh=st[8]|0,this.El=st[9]|0,this.Fh=st[10]|0,this.Fl=st[11]|0,this.Gh=st[12]|0,this.Gl=st[13]|0,this.Hh=st[14]|0,this.Hl=st[15]|0}get(){const{Ah:e,Al:s,Bh:n,Bl:r,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:u,Fh:d,Fl:h,Gh:p,Gl:g,Hh:f,Hl:y}=this;return[e,s,n,r,i,o,a,c,l,u,d,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,u,d,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=u|0,this.Fh=d|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 E=0;E<16;E++,s+=4)js[E]=e.getUint32(s),Fs[E]=e.getUint32(s+=4);for(let E=16;E<80;E++){const N=js[E-15]|0,x=Fs[E-15]|0,$=Hs(N,x,1)^Hs(N,x,8)^nu(N,x,7),W=Ks(N,x,1)^Ks(N,x,8)^ru(N,x,7),G=js[E-2]|0,k=Fs[E-2]|0,Q=Hs(G,k,19)^Dr(G,k,61)^nu(G,k,6),se=Ks(G,k,19)^Lr(G,k,61)^ru(G,k,6),T=nb(W,se,Fs[E-7],Fs[E-16]),v=rb(T,$,Q,js[E-7],js[E-16]);js[E]=v|0,Fs[E]=T|0}let{Ah:n,Al:r,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:u,Eh:d,El:h,Fh:p,Fl:g,Gh:f,Gl:y,Hh:w,Hl:b}=this;for(let E=0;E<80;E++){const N=Hs(d,h,14)^Hs(d,h,18)^Dr(d,h,41),x=Ks(d,h,14)^Ks(d,h,18)^Lr(d,h,41),$=d&p^~d&f,W=h&g^~h&y,G=ib(b,x,W,Nb[E],Fs[E]),k=ob(G,w,N,$,Sb[E],js[E]),Q=G|0,se=Hs(n,r,28)^Dr(n,r,34)^Dr(n,r,39),T=Ks(n,r,28)^Lr(n,r,34)^Lr(n,r,39),v=n&i^n&a^i&a,C=r&o^r&c^o&c;w=f|0,b=y|0,f=p|0,y=g|0,p=d|0,g=h|0,{h:d,l:h}=Jt(l|0,u|0,k|0,Q|0),l=a|0,u=c|0,a=i|0,c=o|0,i=n|0,o=r|0;const A=el(Q,T,C);n=tl(A,k,se,v),r=A|0}({h:n,l:r}=Jt(this.Ah|0,this.Al|0,n|0,r|0)),{h:i,l:o}=Jt(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=Jt(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=Jt(this.Dh|0,this.Dl|0,l|0,u|0),{h:d,l:h}=Jt(this.Eh|0,this.El|0,d|0,h|0),{h:p,l:g}=Jt(this.Fh|0,this.Fl|0,p|0,g|0),{h:f,l:y}=Jt(this.Gh|0,this.Gl|0,f|0,y|0),{h:w,l:b}=Jt(this.Hh|0,this.Hl|0,w|0,b|0),this.set(n,r,i,o,a,c,l,u,d,h,p,g,f,y,w,b)}roundClean(){Wt(js,Fs)}destroy(){Wt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};class Tb extends nl{constructor(){super(48),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 nt=Uint32Array.from([573645204,4230739756,2673172387,3360449730,596883563,1867755857,2520282905,1497426621,2519219938,2827943907,3193839141,1401305490,721525244,746961066,246885852,2177182882]);class Ob extends nl{constructor(){super(32),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}}const Xo=ki(()=>new _b),Pb=ki(()=>new nl),kb=ki(()=>new Tb),Rb=ki(()=>new Ob),xb=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]),qe=Uint32Array.from([4089235720,1779033703,2227873595,3144134277,4271175723,1013904242,1595750129,2773480762,2917565137,1359893119,725511199,2600822924,4215389547,528734635,327033209,1541459225]),H=new Uint32Array(32);function qs(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=H[2*t],l=H[2*t+1],u=H[2*e],d=H[2*e+1],h=H[2*s],p=H[2*s+1],g=H[2*n],f=H[2*n+1],y=el(c,u,o);l=tl(y,l,d,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:Xw(f,g),Dl:Zw(f)},{h:p,l:h}=Jt(p,h,f,g),{Bh:d,Bl:u}={Bh:d^p,Bl:u^h},{Bh:d,Bl:u}={Bh:Hs(d,u,24),Bl:Ks(d,u,24)},H[2*t]=c,H[2*t+1]=l,H[2*e]=u,H[2*e+1]=d,H[2*s]=h,H[2*s+1]=p,H[2*n]=g,H[2*n+1]=f}function Ws(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=H[2*t],l=H[2*t+1],u=H[2*e],d=H[2*e+1],h=H[2*s],p=H[2*s+1],g=H[2*n],f=H[2*n+1],y=el(c,u,o);l=tl(y,l,d,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:Hs(f,g,16),Dl:Ks(f,g,16)},{h:p,l:h}=Jt(p,h,f,g),{Bh:d,Bl:u}={Bh:d^p,Bl:u^h},{Bh:d,Bl:u}={Bh:Dr(d,u,63),Bl:Lr(d,u,63)},H[2*t]=c,H[2*t+1]=l,H[2*e]=u,H[2*e+1]=d,H[2*s]=h,H[2*s+1]=p,H[2*n]=g,H[2*n+1]=f}function $b(t,e={},s,n,r){if(xs(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 Ub extends Jo{constructor(e,s){super(),this.finished=!1,this.destroyed=!1,this.length=0,this.pos=0,xs(e),xs(s),this.blockLen=e,this.outputLen=s,this.buffer=new Uint8Array(e),this.buffer32=vi(this.buffer)}update(e){rn(this),e=es(e),ts(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&&(zs(r),this.compress(r,0,!1),zs(r),this.pos=0);const l=Math.min(s-this.pos,i-c),u=o+c;if(l===s&&!(u%4)&&c+l<i){const d=new Uint32Array(a,u,Math.floor((i-c)/4));zs(d);for(let h=0;c+s<i;h+=r.length,c+=s)this.length+=s,this.compress(d,h,!1);zs(d);continue}n.set(e.subarray(c,c+l),this.pos),this.pos+=l,this.length+=l,c+=l}return this}digestInto(e){rn(this),sl(e,this);const{pos:s,buffer32:n}=this;this.finished=!0,Wt(this.buffer.subarray(s)),zs(n),this.compress(n,0,!0),zs(n);const r=vi(e);this.get().forEach((i,o)=>r[o]=bs(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 Db extends Ub{constructor(e={}){const s=e.dkLen===void 0?64:e.dkLen;super(128,s),this.v0l=qe[0]|0,this.v0h=qe[1]|0,this.v1l=qe[2]|0,this.v1h=qe[3]|0,this.v2l=qe[4]|0,this.v2h=qe[5]|0,this.v3l=qe[6]|0,this.v3h=qe[7]|0,this.v4l=qe[8]|0,this.v4h=qe[9]|0,this.v5l=qe[10]|0,this.v5h=qe[11]|0,this.v6l=qe[12]|0,this.v6h=qe[13]|0,this.v7l=qe[14]|0,this.v7h=qe[15]|0,$b(s,e,64,16,16);let{key:n,personalization:r,salt:i}=e,o=0;if(n!==void 0&&(n=es(n),o=n.length),this.v0l^=this.outputLen|o<<8|65536|1<<24,i!==void 0){i=es(i);const a=vi(i);this.v4l^=bs(a[0]),this.v4h^=bs(a[1]),this.v5l^=bs(a[2]),this.v5h^=bs(a[3])}if(r!==void 0){r=es(r);const a=vi(r);this.v6l^=bs(a[0]),this.v6h^=bs(a[1]),this.v7l^=bs(a[2]),this.v7h^=bs(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:u,v5l:d,v5h:h,v6l:p,v6h:g,v7l:f,v7h:y}=this;return[e,s,n,r,i,o,a,c,l,u,d,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,u,d,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=u|0,this.v5l=d|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)=>H[l]=c),H.set(qe,16);let{h:r,l:i}=Dh(BigInt(this.length));H[24]=qe[8]^i,H[25]=qe[9]^r,n&&(H[28]=~H[28],H[29]=~H[29]);let o=0;const a=xb;for(let c=0;c<12;c++)qs(0,4,8,12,e,s+2*a[o++]),Ws(0,4,8,12,e,s+2*a[o++]),qs(1,5,9,13,e,s+2*a[o++]),Ws(1,5,9,13,e,s+2*a[o++]),qs(2,6,10,14,e,s+2*a[o++]),Ws(2,6,10,14,e,s+2*a[o++]),qs(3,7,11,15,e,s+2*a[o++]),Ws(3,7,11,15,e,s+2*a[o++]),qs(0,5,10,15,e,s+2*a[o++]),Ws(0,5,10,15,e,s+2*a[o++]),qs(1,6,11,12,e,s+2*a[o++]),Ws(1,6,11,12,e,s+2*a[o++]),qs(2,7,8,13,e,s+2*a[o++]),Ws(2,7,8,13,e,s+2*a[o++]),qs(3,4,9,14,e,s+2*a[o++]),Ws(3,4,9,14,e,s+2*a[o++]);this.v0l^=H[0]^H[16],this.v0h^=H[1]^H[17],this.v1l^=H[2]^H[18],this.v1h^=H[3]^H[19],this.v2l^=H[4]^H[20],this.v2h^=H[5]^H[21],this.v3l^=H[6]^H[22],this.v3h^=H[7]^H[23],this.v4l^=H[8]^H[24],this.v4h^=H[9]^H[25],this.v5l^=H[10]^H[26],this.v5h^=H[11]^H[27],this.v6l^=H[12]^H[28],this.v6h^=H[13]^H[29],this.v7l^=H[14]^H[30],this.v7h^=H[15]^H[31],Wt(H)}destroy(){this.destroyed=!0,Wt(this.buffer32),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}}const Lb=lb(t=>new Db(t)),Mb="https://rpc.walletconnect.org/v1";function Yh(t){const e=`Ethereum Signed Message:
|
|
10
|
+
${a}`,r=!0}}r||(Error.captureStackTrace?Error.captureStackTrace(this,$n):this.stack||(this.stack=`${this.name}: ${this.message}`))}}function $l(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 $n?t:new $n(s,e,t);throw hm.sendError(n,n.category),n}function Ht(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 $l(a,e)}}:i=(...o)=>{try{return r(...o)}catch(a){return $l(a,e)}},s[n]=i}else s[n]=r}),s}const Ct=ke({walletImages:{},networkImages:{},chainImages:{},connectorImages:{},tokenImages:{},currencyImages:{}}),pm={state:Ct,subscribeNetworkImages(t){return Ze(Ct.networkImages,()=>t(Ct.networkImages))},subscribeKey(t,e){return Qe(Ct,t,e)},subscribe(t){return Ze(Ct,()=>t(Ct))},setWalletImage(t,e){Ct.walletImages[t]=e},setNetworkImage(t,e){Ct.networkImages[t]=e},setChainImage(t,e){Ct.chainImages[t]=e},setConnectorImage(t,e){Ct.connectorImages={...Ct.connectorImages,[t]:e}},setTokenImage(t,e){Ct.tokenImages[t]=e},setCurrencyImage(t,e){Ct.currencyImages[t]=e}},jt=Ht(pm),fm={eip155:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",solana:"a1b58899-f671-4276-6a5e-56ca5bd59700",polkadot:"",bip122:"0b4838db-0161-4ffe-022d-532bf03dba00",cosmos:"",sui:"",stacks:""},da=ke({networkImagePromises:{}}),Eh={async fetchWalletImage(t){if(t)return await J._fetchWalletImage(t),this.getWalletImageById(t)},async fetchNetworkImage(t){if(!t)return;const e=this.getNetworkImageById(t);return e||(da.networkImagePromises[t]||(da.networkImagePromises[t]=J._fetchNetworkImage(t)),await da.networkImagePromises[t],this.getNetworkImageById(t))},getWalletImageById(t){if(t)return jt.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 jt.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 jt.state.networkImages[t.assets.imageId]},getNetworkImageById(t){if(t)return jt.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 jt.state.connectorImages[t.imageId]},getChainImage(t){return jt.state.networkImages[fm[t]]},getTokenImage(t){if(t)return jt.state.tokenImages[t]}},gm=V.getAnalyticsUrl(),mm=new Oi({baseUrl:gm,clientId:null}),ym=["MODAL_CREATED"],wm=45,Ul=1e3*10,Ue=ke({timestamp:Date.now(),lastFlush:Date.now(),reportedErrors:{},data:{type:"track",event:"MODAL_CREATED"},pendingEvents:[],subscribedToVisibilityChange:!1,walletImpressions:[]}),ae={state:Ue,subscribe(t){return Ze(Ue,()=>t(Ue))},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(Ue.pendingEvents).length/1024>wm,e=Ue.lastFlush+Ul<Date.now();return t||e},_setPendingEvent(t){var e,s;try{let n=(e=m.getAccountData())==null?void 0:e.address;if("address"in t.data&&t.data.address&&(n=t.data.address),ym.includes(t.data.event)||typeof window>"u")return;const r=(s=m.getActiveCaipNetwork())==null?void 0:s.caipNetworkId;this.state.pendingEvents.push({eventId:V.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}}}),Ue.reportedErrors.FORBIDDEN=!1,ae.shouldFlushEvents()&&ae._submitPendingEvents()}catch(n){console.warn("_setPendingEvent",n)}},sendEvent(t){var s;Ue.timestamp=Date.now(),Ue.data=t;const e=["INITIALIZE","CONNECT_SUCCESS","SOCIAL_LOGIN_SUCCESS"];((s=_.state.features)!=null&&s.analytics||e.includes(t.event))&&ae._setPendingEvent(Ue),this.subscribeToFlushTriggers()},sendWalletImpressionEvent(t){Ue.walletImpressions.push(t)},_transformPendingEventsForBatch(t){try{return t.filter(e=>e.props.event!=="WALLET_IMPRESSION_V2")}catch{return t}},_submitPendingEvents(){if(Ue.lastFlush=Date.now(),!(Ue.pendingEvents.length===0&&Ue.walletImpressions.length===0))try{const t=ae._transformPendingEventsForBatch(Ue.pendingEvents);Ue.walletImpressions.length&&t.push({eventId:V.getUUID(),url:window.location.href,domain:window.location.hostname,timestamp:Date.now(),props:{type:"track",event:"WALLET_IMPRESSION_V2",items:[...Ue.walletImpressions]}}),mm.sendBeacon({path:"/batch",params:ae.getSdkProperties(),body:t}),Ue.reportedErrors.FORBIDDEN=!1,Ue.pendingEvents=[],Ue.walletImpressions=[]}catch{Ue.reportedErrors.FORBIDDEN=!0}},subscribeToFlushTriggers(){var t,e,s;Ue.subscribedToVisibilityChange||typeof document>"u"||(Ue.subscribedToVisibilityChange=!0,(t=document==null?void 0:document.addEventListener)==null||t.call(document,"visibilitychange",()=>{document.visibilityState==="hidden"&&ae._submitPendingEvents()}),(e=document==null?void 0:document.addEventListener)==null||e.call(document,"freeze",()=>{ae._submitPendingEvents()}),(s=window==null?void 0:window.addEventListener)==null||s.call(window,"pagehide",()=>{ae._submitPendingEvents()}),setInterval(()=>{ae._submitPendingEvents()},Ul))}},bm=V.getApiUrl(),at=new Oi({baseUrl:bm,clientId:null}),vm=40,Dl=4,Em=20,re=ke({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}}}),J={state:re,subscribeKey(t,e){return Qe(re,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=`${at.baseUrl}/getWalletImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setWalletImage(t,URL.createObjectURL(s))},async _fetchNetworkImage(t){const e=`${at.baseUrl}/public/getAssetImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setNetworkImage(t,URL.createObjectURL(s))},async _fetchConnectorImage(t){const e=`${at.baseUrl}/public/getAssetImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setConnectorImage(t,URL.createObjectURL(s))},async _fetchCurrencyImage(t){const e=`${at.baseUrl}/public/getCurrencyImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setCurrencyImage(t,URL.createObjectURL(s))},async _fetchTokenImage(t){const e=`${at.baseUrl}/public/getTokenImage/${t}`,s=await at.getBlob({path:e,params:J._getSdkProperties()});jt.setTokenImage(t,URL.createObjectURL(s))},_filterWalletsByPlatform(t){const e=t.length,s=V.isMobile()?t==null?void 0:t.filter(r=>r.mobile_link||r.webapp_link?!0:Object.values(Lt).map(o=>o.id).includes(r.id)):t,n=e-s.length;return{filteredWallets:s,mobileFilteredOutWalletsLength:n}},async fetchProjectConfig(){return(await at.get({path:"/appkit/v1/config",params:J._getSdkProperties()})).features},async fetchUsage(){try{const t=await at.get({path:"/appkit/v1/project-limits",params:J._getSdkProperties()}),{tier:e,isAboveMauLimit:s,isAboveRpcLimit:n}=t.planLimits,r=e==="starter",i=s||n;J.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 at.get({path:"/projects/v1/origins",params:J._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=m.getAllRequestedCaipNetworks(),e=t==null?void 0:t.map(({assets:s})=>s==null?void 0:s.imageId).filter(Boolean).filter(s=>!Eh.getNetworkImageById(s));e&&await Promise.allSettled(e.map(s=>J._fetchNetworkImage(s)))},async fetchConnectorImages(){const{connectors:t}=L.state,e=t.map(({imageId:s})=>s).filter(Boolean);await Promise.allSettled(e.map(s=>J._fetchConnectorImage(s)))},async fetchCurrencyImages(t=[]){await Promise.allSettled(t.map(e=>J._fetchCurrencyImage(e)))},async fetchTokenImages(t=[]){await Promise.allSettled(t.map(e=>J._fetchTokenImage(e)))},async fetchWallets(t){var o;const e=t.exclude??[];J._getSdkProperties().sv.startsWith("html-core-")&&e.push(...Object.values(Lt).map(a=>a.id));const n=await at.get({path:"/getWallets",params:{...J._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}=J._filterWalletsByPlatform(n==null?void 0:n.data);return{data:r||[],count:n==null?void 0:n.count,mobileFilteredOutWalletsLength:i}},async prefetchWalletRanks(){const t=L.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(","),m.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 J.fetchWallets(e);re.explorerWallets=s;const n=m.getRequestedCaipNetworkIds().join(",");re.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={...J._getSdkProperties(),page:1,entries:(t==null?void 0:t.length)??Dl,include:t},{data:s}=await J.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=>J._fetchWalletImage(i))),re.featured=n,re.allFeatured=n}},async fetchRecommendedWallets(){try{re.isFetchingRecommendedWallets=!0;const{includeWalletIds:t,excludeWalletIds:e,featuredWalletIds:s}=_.state,n=[...e??[],...s??[]].filter(Boolean),r=m.getRequestedCaipNetworkIds().join(","),i={page:1,entries:Dl,include:t,exclude:n,chains:r},{data:o,count:a}=await J.fetchWallets(i),c=P.getRecentWallets(),l=o.map(d=>d.image_id).filter(Boolean),u=c.map(d=>d.image_id).filter(Boolean);await Promise.allSettled([...l,...u].map(d=>J._fetchWalletImage(d))),re.recommended=o,re.allRecommended=o,re.count=a??0}catch{}finally{re.isFetchingRecommendedWallets=!1}},async fetchWalletsByPage({page:t}){const{includeWalletIds:e,excludeWalletIds:s,featuredWalletIds:n}=_.state,r=m.getRequestedCaipNetworkIds().join(","),i=[...re.recommended.map(({id:d})=>d),...s??[],...n??[]].filter(Boolean),o={page:t,entries:vm,include:e,exclude:i,chains:r},{data:a,count:c,mobileFilteredOutWalletsLength:l}=await J.fetchWallets(o);re.mobileFilteredOutWalletsLength=l+(re.mobileFilteredOutWalletsLength??0);const u=a.slice(0,Em).map(d=>d.image_id).filter(Boolean);await Promise.allSettled(u.map(d=>J._fetchWalletImage(d))),re.wallets=V.uniqueBy([...re.wallets,...J._filterOutExtensions(a)],"id").filter(d=>{var h;return(h=d.chains)==null?void 0:h.some(p=>r.includes(p))}),re.count=c>re.count?c:re.count,re.page=t},async initializeExcludedWallets({ids:t}){const e={page:1,entries:t.length,include:t},{data:s}=await J.fetchWallets(e);s&&s.forEach(n=>{re.excludedWallets.push({rdns:n.rdns,name:n.name})})},async searchWallet({search:t,badge:e}){const{includeWalletIds:s,excludeWalletIds:n}=_.state,r=m.getRequestedCaipNetworkIds().join(",");re.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 J.fetchWallets(i);ae.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=>J._fetchWalletImage(c)),V.wait(300)]),re.search=J._filterOutExtensions(o)},initPromise(t,e){const s=re.promises[t];return s||(re.promises[t]=e())},prefetch({fetchConnectorImages:t=!0,fetchFeaturedWallets:e=!0,fetchRecommendedWallets:s=!0,fetchNetworkImages:n=!0,fetchWalletRanks:r=!0}={}){const i=[t&&J.initPromise("connectorImages",J.fetchConnectorImages),e&&J.initPromise("featuredWallets",J.fetchFeaturedWallets),s&&J.initPromise("recommendedWallets",J.fetchRecommendedWallets),n&&J.initPromise("networkImages",J.fetchNetworkImages),r&&J.initPromise("walletRanks",J.prefetchWalletRanks)].filter(Boolean);return Promise.allSettled(i)},prefetchAnalyticsConfig(){var t;(t=_.state.features)!=null&&t.analytics&&J.fetchAnalyticsConfig()},async fetchAnalyticsConfig(){try{const{isAnalyticsEnabled:t}=await at.get({path:"/getAnalyticsConfig",params:J._getSdkProperties()});_.setFeatures({analytics:t})}catch{_.setFeatures({analytics:!1})}},filterByNamespaces(t){if(!(t!=null&&t.length)){re.featured=re.allFeatured,re.recommended=re.allRecommended;return}const e=m.getRequestedCaipNetworkIds().join(",");re.featured=re.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.recommended=re.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.filteredWallets=re.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})},clearFilterByNamespaces(){re.filteredWallets=[]},setFilterByNamespace(t){if(!t){re.featured=re.allFeatured,re.recommended=re.allRecommended;return}const e=m.getRequestedCaipNetworkIds().join(",");re.featured=re.allFeatured.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.recommended=re.allRecommended.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))}),re.filteredWallets=re.wallets.filter(s=>{var n;return(n=s.chains)==null?void 0:n.some(r=>e.includes(r))})}},Cm=["ConnectingExternal","ConnectingMultiChain","ConnectingSocial","ConnectingFarcaster"],Ce=ke({view:"Connect",history:["Connect"],transactionStack:[]}),Am={state:Ce,subscribeKey(t,e){return Qe(Ce,t,e)},pushTransactionStack(t){Ce.transactionStack.push(t)},popTransactionStack(t){const e=Ce.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(),ee.goBack();break;case"cancel":r==null||r(),ee.goBack();break}},push(t,e){let s=t,n=e;J.state.plan.hasExceededUsageLimit&&Cm.includes(t)&&(s="UsageExceeded",n=void 0),s!==Ce.view&&(Ce.view=s,Ce.history.push(s),Ce.data=n)},reset(t,e){Ce.view=t,Ce.history=[t],Ce.data=e},replace(t,e){Ce.history.at(-1)===t||(Ce.view=t,Ce.history[Ce.history.length-1]=t,Ce.data=e)},goBack(){var n,r;const t=m.state.activeCaipAddress,e=ee.state.view==="ConnectingFarcaster",s=!t&&e;if(Ce.history.length>1){Ce.history.pop();const[i]=Ce.history.slice(-1);i&&(t&&i==="Connect"?Ce.view="Account":Ce.view=i)}else de.close();(n=Ce.data)!=null&&n.wallet&&(Ce.data.wallet=void 0),(r=Ce.data)!=null&&r.redirectView&&(Ce.data.redirectView=void 0),setTimeout(()=>{var i,o,a;if(s){m.setAccountProp("farcasterUrl",void 0,m.state.activeChain);const c=L.getAuthConnector();(i=c==null?void 0:c.provider)==null||i.reload();const l=Xr(_.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(Ce.history.length>1){Ce.history=Ce.history.slice(0,t+1);const[e]=Ce.history.slice(-1);e&&(Ce.view=e)}},goBackOrCloseModal(){ee.state.history.length>1?ee.goBack():de.close()}},ee=Ht(Am),ms=ke({themeMode:"dark",themeVariables:{},w3mThemeVariables:void 0}),ec={state:ms,subscribe(t){return Ze(ms,()=>t(ms))},setThemeMode(t){ms.themeMode=t;try{const e=L.getAuthConnector();if(e){const s=ec.getSnapshot().themeVariables;e.provider.syncTheme({themeMode:t,themeVariables:s,w3mThemeVariables:Co(s,t)})}}catch{console.info("Unable to sync theme to auth connector")}},setThemeVariables(t){ms.themeVariables={...ms.themeVariables,...t};try{const e=L.getAuthConnector();if(e){const s=ec.getSnapshot().themeVariables;e.provider.syncTheme({themeVariables:s,w3mThemeVariables:Co(ms.themeVariables,ms.themeMode)})}}catch{console.info("Unable to sync theme to auth connector")}},getSnapshot(){return Xr(ms)}},St=Ht(ec),Ch=Object.fromEntries(ih.map(t=>[t,void 0])),Im=Object.fromEntries(ih.map(t=>[t,!0])),be=ke({allConnectors:[],connectors:[],activeConnector:void 0,filterByNamespace:void 0,activeConnectorIds:Ch,filterByNamespaceMap:Im}),_m={state:be,subscribe(t){return Ze(be,()=>{t(be)})},subscribeKey(t,e){return Qe(be,t,e)},initialize(t){t.forEach(e=>{const s=P.getConnectedConnectorId(e);s&&L.setConnectorId(s,e)})},setActiveConnector(t){t&&(be.activeConnector=Zr(t))},setConnectors(t){t.filter(r=>!be.allConnectors.some(i=>i.id===r.id&&L.getConnectorName(i.name)===L.getConnectorName(r.name)&&i.chain===r.chain)).forEach(r=>{r.type!=="MULTI_CHAIN"&&be.allConnectors.push(Zr(r))});const s=L.getEnabledNamespaces(),n=L.getEnabledConnectors(s);be.connectors=L.mergeMultiChainConnectors(n)},filterByNamespaces(t){Object.keys(be.filterByNamespaceMap).forEach(e=>{be.filterByNamespaceMap[e]=!1}),t.forEach(e=>{be.filterByNamespaceMap[e]=!0}),L.updateConnectorsForEnabledNamespaces()},filterByNamespace(t,e){be.filterByNamespaceMap[t]=e,L.updateConnectorsForEnabledNamespaces()},updateConnectorsForEnabledNamespaces(){const t=L.getEnabledNamespaces(),e=L.getEnabledConnectors(t),s=L.areAllNamespacesEnabled();be.connectors=L.mergeMultiChainConnectors(e),s?J.clearFilterByNamespaces():J.filterByNamespaces(t)},getEnabledNamespaces(){return Object.entries(be.filterByNamespaceMap).filter(([t,e])=>e).map(([t])=>t)},getEnabledConnectors(t){return be.allConnectors.filter(e=>t.includes(e.chain))},areAllNamespacesEnabled(){return Object.values(be.filterByNamespaceMap).every(t=>t)},mergeMultiChainConnectors(t){const e=L.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=L.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=Xr(_.state),o=St.getSnapshot().themeMode,a=St.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:Co(a,o)}),L.setConnectors([t])}else L.setConnectors([t])},getAuthConnector(t){var n;const e=t||m.state.activeChain,s=be.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 be.connectors.filter(t=>t.type==="ANNOUNCED").map(t=>{var e;return(e=t.info)==null?void 0:e.rdns})},getConnectorById(t){return be.allConnectors.find(e=>e.id===t)},getConnector({id:t,rdns:e,namespace:s}){const n=s||m.state.activeChain;return be.allConnectors.filter(i=>i.chain===n).find(i=>{var o;return i.explorerId===t||((o=i.info)==null?void 0:o.rdns)===e})},syncIfAuthConnector(t){var i,o;if(t.id!=="AUTH")return;const e=t,s=Xr(_.state),n=St.getSnapshot().themeMode,r=St.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:Co(r,n)})},getConnectorsByNamespace(t){const e=be.allConnectors.filter(s=>s.chain===t);return L.mergeMultiChainConnectors(e)},canSwitchToSmartAccount(t){return m.checkIfSmartAccountEnabled()&&qt(t)===Ss.ACCOUNT_TYPES.EOA},selectWalletConnector(t){var n;const e=(n=ee.state.data)==null?void 0:n.redirectView,s=L.getConnector({id:t.id,rdns:t.rdns});am.handleMobileDeeplinkRedirect((s==null?void 0:s.explorerId)||t.id,m.state.activeChain),s?ee.push("ConnectingExternal",{connector:s,wallet:t,redirectView:e}):ee.push("ConnectingWalletConnect",{wallet:t,redirectView:e})},getConnectors(t){return t?L.getConnectorsByNamespace(t):L.mergeMultiChainConnectors(be.allConnectors)},setFilterByNamespace(t){be.filterByNamespace=t,be.connectors=L.getConnectors(t),J.setFilterByNamespace(t)},setConnectorId(t,e){t&&(be.activeConnectorIds={...be.activeConnectorIds,[e]:t},P.setConnectedConnectorId(e,t))},removeConnectorId(t){be.activeConnectorIds={...be.activeConnectorIds,[t]:void 0},P.deleteConnectedConnectorId(t)},getConnectorId(t){if(t)return be.activeConnectorIds[t]},isConnected(t){return t?!!be.activeConnectorIds[t]:Object.values(be.activeConnectorIds).some(e=>!!e)},resetConnectorIds(){be.activeConnectorIds={...Ch}}},L=Ht(_m),Sm=1e3,_r={checkNamespaceConnectorId(t,e){return L.getConnectorId(t)===e},isSocialProvider(t){return ye.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&&L.setActiveConnector(e),r==null||r(V.isMobile()&&t),n){const l=de.subscribeKey("open",u=>{u||(ee.state.view!==n&&ee.replace(n),l(),a(new Error("Modal closed")))})}const c=m.subscribeKey("activeCaipAddress",l=>{l&&(i==null||i(),s&&de.close(),c(),o(Xe.parseCaipAddress(l)))})})},connectExternal(t){return new Promise((e,s)=>{const n=m.subscribeKey("activeCaipAddress",r=>{r&&(de.close(),n(),e(Xe.parseCaipAddress(r)))});j.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||m.state.activeChain,l=m.subscribeKey("activeCaipAddress",u=>{u&&(s&&de.close(),l())});return new Promise((u,d)=>{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=L.getAuthConnector(c);if(y&&!o){i&&i.close(),o=!0;const w=g.data.resultUri;ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_REQUEST_USER_DATA",properties:{provider:t}}),P.setConnectedSocialProvider(t),await j.connectExternal({id:y.id,type:y.type,socialUri:w},y.chain);const b=m.state.activeCaipAddress;if(!b){d(new Error("Failed to connect"));return}u(Xe.parseCaipAddress(b)),ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_SUCCESS",properties:{provider:t}})}}catch(y){ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:V.parseError(y)}}),d(new Error("Failed to connect"))}}else ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_ERROR",properties:{provider:t,message:"Untrusted Origin"}})}async function p(){if(ae.sendEvent({type:"track",event:"SOCIAL_LOGIN_STARTED",properties:{provider:t}}),t==="farcaster"){n==null||n();const g=de.subscribeKey("open",y=>{!y&&t==="farcaster"&&(d(new Error("Popup closed")),r==null||r(),g())}),f=L.getAuthConnector();if(f){const y=m.getAccountData(c);if(!(y!=null&&y.farcasterUrl))try{const{url:w}=await f.provider.getFarcasterUri();m.setAccountProp("farcasterUrl",w,c)}catch{d(new Error("Failed to connect to farcaster"))}}}else{const g=L.getAuthConnector();a=V.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&&(d(new Error("Popup closed")),clearInterval(y))},1e3);window.addEventListener("message",h,!1)}else a==null||a.close(),d(new Error("Failed to initiate social connection"))}}catch{d(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=de.subscribeKey("open",c=>{c||(ee.state.view!==e&&ee.replace(e),a(),i(new Error("Modal closed")))})}const o=m.subscribeKey("activeCaipAddress",a=>{a&&(n==null||n(),t&&de.close(),o(),r(Xe.parseCaipAddress(a)))})})},async updateEmail(){const t=P.getConnectedConnectorId(m.state.activeChain),e=L.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 de.open({view:"UpdateEmailWallet",data:{email:s,redirectView:void 0}}),new Promise((n,r)=>{const i=setInterval(()=>{const a=e.provider.getEmail()??"";a!==s&&(de.close(),clearInterval(i),o(),n({email:a}))},Sm),o=de.subscribeKey("open",a=>{a||(ee.state.view!=="Connect"&&ee.push("Connect"),clearInterval(i),o(),r(new Error("Modal closed")))})})},canSwitchToSmartAccount(t){return m.checkIfSmartAccountEnabled()&&qt(t)===Ss.ACCOUNT_TYPES.EOA}};function Ah(){var n,r;const t=((n=m.state.activeCaipNetwork)==null?void 0:n.chainNamespace)||"eip155",e=((r=m.state.activeCaipNetwork)==null?void 0:r.id)||1,s=ye.NATIVE_TOKEN_ADDRESS[t];return`${t}:${e}:${s}`}function qt(t){var s;return(s=m.getAccountData(t))==null?void 0:s.preferredAccountType}function Hi(t){return m.state.activeCaipNetwork}const _o={getConnectionStatus(t,e){const s=L.state.activeConnectorIds[e],n=j.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=L.state.activeConnectorIds[t],n=j.getConnections(t),i=(j.state.recentConnections.get(t)??[]).filter(c=>L.getConnectorById(c.connectorId)),o=_o.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:[]}}},Re=ke({transactions:[],transactionsByYear:{},lastNetworkInView:void 0,loading:!1,empty:!1,next:void 0}),Nm={state:Re,subscribe(t){return Ze(Re,()=>t(Re))},setLastNetworkInView(t){Re.lastNetworkInView=t},async fetchTransactions(t){var e;if(!t)throw new Error("Transactions can't be fetched without an accountAddress");Re.loading=!0;try{const s=await te.fetchTransactions({account:t,cursor:Re.next,chainId:(e=m.state.activeCaipNetwork)==null?void 0:e.caipNetworkId}),n=uo.filterSpamTransactions(s.data),r=uo.filterByConnectedChain(n),i=[...Re.transactions,...r];Re.loading=!1,Re.transactions=i,Re.transactionsByYear=uo.groupTransactionsByYearAndMonth(Re.transactionsByYear,r),Re.empty=i.length===0,Re.next=s.next?s.next:void 0}catch{const n=m.state.activeChain;ae.sendEvent({type:"track",event:"ERROR_FETCH_TRANSACTIONS",properties:{address:t,projectId:_.state.projectId,cursor:Re.next,isSmartAccount:qt(n)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT}}),ls.showError("Failed to fetch transactions"),Re.loading=!1,Re.empty=!0,Re.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,u)=>new Date(u.metadata.minedAt).getTime()-new Date(l.metadata.minedAt).getTime())}}),s},filterSpamTransactions(t){return t.filter(e=>!e.transfers.every(n=>{var r;return((r=n.nft_info)==null?void 0:r.flags.is_spam)===!0}))},filterByConnectedChain(t){var n;const e=(n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId;return t.filter(r=>r.metadata.chain===e)},clearCursor(){Re.next=void 0},resetTransactions(){Re.transactions=[],Re.transactionsByYear={},Re.lastNetworkInView=void 0,Re.loading=!1,Re.empty=!1,Re.next=void 0}},uo=Ht(Nm,"API_ERROR"),ge=ke({connections:new Map,recentConnections:new Map,isSwitchingConnection:!1,wcError:!1,buffering:!1,status:"disconnected"});let ln;const Tm={state:ge,subscribe(t){return Ze(ge,()=>t(ge))},subscribeKey(t,e){return Qe(ge,t,e)},_getClient(){return ge._client},setClient(t){ge._client=Zr(t)},initialize(t){const e=t.filter(s=>!!s.namespace).map(s=>s.namespace);j.syncStorageConnections(e)},syncStorageConnections(t){const e=P.getConnections(),s=t??Array.from(m.state.chains.keys());for(const n of s){const r=e[n]??[],i=new Map(ge.recentConnections);i.set(n,r),ge.recentConnections=i}},getConnections(t){return t?ge.connections.get(t)??[]:[]},hasAnyConnection(t){const e=j.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;const e=V.isTelegram()||V.isSafari()&&V.isIos();if(t==="always"||t==="auto"&&e){if(ln){await ln,ln=void 0;return}if(!V.isPairingExpired(ge==null?void 0:ge.wcPairingExpiry)){const o=ge.wcUri;ge.wcUri=o;return}ln=(n=(s=j._getClient())==null?void 0:s.connectWalletConnect)==null?void 0:n.call(s).catch(()=>{}),j.state.status="connecting",await ln,ln=void 0,ge.wcPairingExpiry=void 0,j.state.status="connected"}else await((i=(r=j._getClient())==null?void 0:r.connectWalletConnect)==null?void 0:i.call(r))},async connectExternal(t,e,s=!0){var r,i;const n=await((i=(r=j._getClient())==null?void 0:r.connectExternal)==null?void 0:i.call(r,t));return s&&m.setActiveNamespace(e),n},async reconnectExternal(t){var s,n;await((n=(s=j._getClient())==null?void 0:s.reconnectExternal)==null?void 0:n.call(s,t));const e=t.chain||m.state.activeChain;e&&L.setConnectorId(t.id,e)},async setPreferredAccountType(t,e){var n;if(!e)return;de.setLoading(!0,m.state.activeChain);const s=L.getAuthConnector();s&&(m.setAccountProp("preferredAccountType",t,e),await s.provider.setPreferredAccount(t),P.setPreferredAccountTypes(Object.entries(m.state.chains).reduce((r,[i,o])=>{const a=i,c=qt(a);return c!==void 0&&(r[a]=c),r},{})),await j.reconnectExternal(s),de.setLoading(!1,m.state.activeChain),ae.sendEvent({type:"track",event:"SET_PREFERRED_ACCOUNT_TYPE",properties:{accountType:t,network:((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}}))},async signMessage(t){var e;return(e=j._getClient())==null?void 0:e.signMessage(t)},parseUnits(t,e){var s;return(s=j._getClient())==null?void 0:s.parseUnits(t,e)},formatUnits(t,e){var s;return(s=j._getClient())==null?void 0:s.formatUnits(t,e)},updateBalance(t){var e;return(e=j._getClient())==null?void 0:e.updateBalance(t)},async sendTransaction(t){var e;return(e=j._getClient())==null?void 0:e.sendTransaction(t)},async getCapabilities(t){var e;return(e=j._getClient())==null?void 0:e.getCapabilities(t)},async grantPermissions(t){var e;return(e=j._getClient())==null?void 0:e.grantPermissions(t)},async walletGetAssets(t){var e;return((e=j._getClient())==null?void 0:e.walletGetAssets(t))??{}},async estimateGas(t){var e;return(e=j._getClient())==null?void 0:e.estimateGas(t)},async writeContract(t){var e;return(e=j._getClient())==null?void 0:e.writeContract(t)},async getEnsAddress(t){var e;return(e=j._getClient())==null?void 0:e.getEnsAddress(t)},async getEnsAvatar(t){var e;return(e=j._getClient())==null?void 0:e.getEnsAvatar(t)},checkInstalled(t){var e,s;return((s=(e=j._getClient())==null?void 0:e.checkInstalled)==null?void 0:s.call(e,t))||!1},resetWcConnection(){ge.wcUri=void 0,ge.wcPairingExpiry=void 0,ge.wcLinking=void 0,ge.recentWallet=void 0,ge.status="disconnected",uo.resetTransactions(),P.deleteWalletConnectDeepLink(),P.deleteRecentWallet()},resetUri(){ge.wcUri=void 0,ge.wcPairingExpiry=void 0,ln=void 0},finalizeWcConnection(t){var n,r;const{wcLinking:e,recentWallet:s}=j.state;e&&P.setWalletConnectDeepLink(e),s&&P.setAppKitRecent(s),t&&ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:t,properties:{method:e?"mobile":"qrcode",name:((r=(n=ee.state.data)==null?void 0:n.wallet)==null?void 0:r.name)||"Unknown",view:ee.state.view,walletRank:s==null?void 0:s.order}})},setWcBasic(t){ge.wcBasic=t},setUri(t){ge.wcUri=t,ge.wcPairingExpiry=V.getPairingExpiry()},setWcLinking(t){ge.wcLinking=t},setWcError(t){ge.wcError=t,ge.buffering=!1},setRecentWallet(t){ge.recentWallet=t},setBuffering(t){ge.buffering=t},setStatus(t){ge.status=t},setIsSwitchingConnection(t){ge.isSwitchingConnection=t},async disconnect({id:t,namespace:e,initialDisconnect:s}={}){var n;try{await((n=j._getClient())==null?void 0:n.disconnect({id:t,chainNamespace:e,initialDisconnect:s}))}catch(r){throw new $n("Failed to disconnect","INTERNAL_SDK_ERROR",r)}},async disconnectConnector({id:t,namespace:e}){var s;try{await((s=j._getClient())==null?void 0:s.disconnectConnector({id:t,namespace:e}))}catch(n){throw new $n("Failed to disconnect connector","INTERNAL_SDK_ERROR",n)}},setConnections(t,e){const s=new Map(ge.connections);s.set(e,t),ge.connections=s},async handleAuthAccountSwitch({address:t,namespace:e}){var i,o;const s=m.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()&&_r.canSwitchToSmartAccount(e)?"smartAccount":"eoa";await j.setPreferredAccountType(r,e)},async handleActiveConnection({connection:t,namespace:e,address:s}){const n=L.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 j.handleAuthAccountSwitch({address:s,namespace:e});else{const i=await j.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,u;const r=L.getConnectorById(t.connectorId),i=(u=(l=t.auth)==null?void 0:l.name)==null?void 0:u.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&&_r.isSocialProvider(i)){const{address:d}=await _r.connectSocial({social:i,closeModalOnConnect:n,onOpenFarcaster(){de.open({view:"ConnectingFarcaster"})},onConnect(){ee.replace("ProfileWallets")}});c=d}else{const{address:d}=await _r.connectEmail({closeModalOnConnect:n,onOpen(){de.open({view:"EmailLogin"})},onConnect(){ee.replace("ProfileWallets")}});c=d}else if(a){const{address:d}=await _r.connectWalletConnect({walletConnect:!0,connector:r,closeModalOnConnect:n,onOpen(h){const p=h?"AllWallets":"ConnectingWalletConnect";de.state.open?ee.push(p):de.open({view:p})},onConnect(){ee.replace("ProfileWallets")}});c=d}else{const d=await j.connectExternal({id:r.id,type:r.type,provider:r.provider,chain:e},e);d&&(c=d.address)}return o&&s&&await j.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=m.getAccountData(s))==null?void 0:c.caipAddress;if(o){const{address:l}=Xe.parseCaipAddress(o);i=l}const a=_o.getConnectionStatus(t,s);switch(a){case"connected":case"active":{const l=await j.handleActiveConnection({connection:t,namespace:s,address:e});if(i&&l){const u=l.toLowerCase()!==i.toLowerCase();r==null||r({address:l,namespace:s,hasSwitchedAccount:u,hasSwitchedWallet:a==="active"})}break}case"disconnected":{const l=await j.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}`)}}},j=Ht(Tm),ha={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 zc(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 pa;async function Ll(){if(!pa){const{createPublicClient:t,http:e,defineChain:s}=await vo(async()=>{const{createPublicClient:n,http:r,defineChain:i}=await import("./index-eTCC3Tyz.js");return{createPublicClient:n,http:r,defineChain:i}},__vite__mapDeps([0,1,2]));pa={createPublicClient:t,http:e,defineChain:s}}return pa}const tc={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 Ll(),{chainId:s}=Xe.parseCaipNetworkId(t.caipNetworkId);return e({...t,id:Number(s)})},async createViemPublicClient(t){const{createPublicClient:e,http:s}=await Ll(),n=_.state.projectId,r=await tc.getViemChain(t);if(!r)throw new Error(`Chain ${t.caipNetworkId} not found in viem/chains`);return e({chain:r,transport:s(tc.getBlockchainApiRpcUrl(t.caipNetworkId,n))})}},Yc={async getMyTokensWithBalance(t){var a;const e=(a=m.getAccountData())==null?void 0:a.address,s=m.state.activeCaipNetwork,n=L.getConnectorId("eip155")===U.CONNECTOR_ID.AUTH;if(!e||!s)return[];const r=`${s.caipNetworkId}:${e}`,i=P.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 te.getBalance(e,s.caipNetworkId,t);return this.filterLowQualityTokens(o.balances)},async getEIP155Balances(t,e){var s,n;try{const r=ha.getChainIdHexFromCAIP2ChainId(e.caipNetworkId),i=await j.getCapabilities(t);if(!((n=(s=i==null?void 0:i[r])==null?void 0:s.assetDiscovery)!=null&&n.supported))return null;const o=await j.walletGetAssets({account:t,chainFilter:[r]});if(!ha.isWalletGetAssetsResponse(o))return null;const c=(o[r]||[]).map(l=>ha.createBalance(l,e.caipNetworkId));return P.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 tc.createViemPublicClient(s),{address:r}=Xe.parseCaipAddress(t),[{result:i},{result:o},{result:a},{result:c}]=await n.multicall({contracts:[{address:e,functionName:"name",args:[],abi:Bi},{address:e,functionName:"symbol",args:[],abi:Bi},{address:e,functionName:"balanceOf",args:[r],abi:Bi},{address:e,functionName:"decimals",args:[],abi:Bi}]});return{name:i,symbol:o,decimals:c,balance:a&&c?zc(a,c):"0"}}},fa={adapters:{}},Ih={state:fa,initialize(t){fa.adapters={...t}},get(t){return fa.adapters[t]}},So={eip155:void 0,solana:void 0,polkadot:void 0,bip122:void 0,cosmos:void 0,sui:void 0,stacks:void 0},dt=ke({providers:{...So},providerIds:{...So}}),xe={state:dt,subscribeKey(t,e){return Qe(dt,t,e)},subscribe(t){return Ze(dt,()=>{t(dt)})},subscribeProviders(t){return Ze(dt.providers,()=>t(dt.providers))},setProvider(t,e){t&&e&&(dt.providers[t]=Zr(e))},getProvider(t){if(t)return dt.providers[t]},setProviderId(t,e){e&&(dt.providerIds[t]=e)},getProviderId(t){if(t)return dt.providerIds[t]},reset(){dt.providers={...So},dt.providerIds={...So}},resetChain(t){dt.providers[t]=void 0,dt.providerIds[t]=void 0}},Kn=ke({loading:!1,open:!1,selectedNetworkId:void 0,activeChain:void 0,initialized:!1}),Ns={state:Kn,subscribe(t){return Ze(Kn,()=>t(Kn))},subscribeOpen(t){return Qe(Kn,"open",t)},set(t){Object.assign(Kn,{...Kn,...t})}},Om={async getTokenList(t){var n;const e=await te.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=m.state.activeCaipNetwork;if(!t)return null;try{switch(t.chainNamespace){case"solana":const s=(e=await(j==null?void 0:j.estimateGas({chainNamespace:"solana"})))==null?void 0:e.toString();return{standard:s,fast:s,instant:s};case"eip155":default:return await te.fetchGasPrice({chainId:t.caipNetworkId})}}catch{return null}},async fetchSwapAllowance({tokenAddress:t,userAddress:e,sourceTokenAmount:s,sourceTokenDecimals:n}){const r=await te.fetchSwapAllowance({tokenAddress:t,userAddress:e});if(r!=null&&r.allowance&&s&&n){const i=j.parseUnits(s,n)||0;return BigInt(r.allowance)>=i}return!1},async getMyTokensWithBalance(t){const e=await Yc.getMyTokensWithBalance(t);return m.setAccountProp("tokenBalance",e,m.state.activeChain),this.mapBalancesToSwapTokens(e)},mapBalancesToSwapTokens(t){return(t==null?void 0:t.map(e=>({...e,address:e!=null&&e.address?e.address:Ah(),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}}},me=ke({tokenBalances:[],loading:!1}),Pm={state:me,subscribe(t){return Ze(me,()=>t(me))},subscribeKey(t,e){return Qe(me,t,e)},setToken(t){t&&(me.token=Zr(t))},setTokenAmount(t){me.sendTokenAmount=t},setReceiverAddress(t){me.receiverAddress=t},setReceiverProfileImageUrl(t){me.receiverProfileImageUrl=t},setReceiverProfileName(t){me.receiverProfileName=t},setNetworkBalanceInUsd(t){me.networkBalanceInUSD=t},setLoading(t){me.loading=t},getSdkEventProperties(t){var e,s;return{message:V.parseError(t),isSmartAccount:qt(m.state.activeChain)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((e=me.token)==null?void 0:e.symbol)||"",amount:me.sendTokenAmount??0,network:((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||""}},async sendToken(){var t;try{switch(oe.setLoading(!0),(t=m.state.activeCaipNetwork)==null?void 0:t.chainNamespace){case"eip155":await oe.sendEvmToken();return;case"solana":await oe.sendSolanaToken();return;default:throw new Error("Unsupported chain")}}catch(e){throw _s.isUserRejectedRequestError(e)?new ch(e):e}finally{oe.setLoading(!1)}},async sendEvmToken(){var s,n,r;const t=m.state.activeChain;if(!t)throw new Error("SendController:sendEvmToken - activeChainNamespace is required");const e=qt(t);if(!oe.state.sendTokenAmount||!oe.state.receiverAddress)throw new Error("An amount and receiver address are required");if(!oe.state.token)throw new Error("A token is required");if((s=oe.state.token)!=null&&s.address){ae.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:oe.state.token.address,amount:oe.state.sendTokenAmount,network:((n=m.state.activeCaipNetwork)==null?void 0:n.caipNetworkId)||""}});const{hash:i}=await oe.sendERC20Token({receiverAddress:oe.state.receiverAddress,tokenAddress:oe.state.token.address,sendTokenAmount:oe.state.sendTokenAmount,decimals:oe.state.token.quantity.decimals});i&&(me.hash=i)}else{ae.sendEvent({type:"track",event:"SEND_INITIATED",properties:{isSmartAccount:e===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:oe.state.token.symbol||"",amount:oe.state.sendTokenAmount,network:((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||""}});const{hash:i}=await oe.sendNativeToken({receiverAddress:oe.state.receiverAddress,sendTokenAmount:oe.state.sendTokenAmount,decimals:oe.state.token.quantity.decimals});i&&(me.hash=i)}},async fetchTokenBalance(t){var o,a,c;me.loading=!0;const e=m.state.activeChain,s=(o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=m.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=((c=m.getAccountData(e))==null?void 0:c.caipAddress)??m.state.activeCaipAddress,i=r?V.getPlainAddress(r):void 0;if(me.lastRetry&&!V.isAllowedRetry(me.lastRetry,30*ye.ONE_SEC_MS))return me.loading=!1,[];try{if(i&&s&&n){const l=await Yc.getMyTokensWithBalance();return me.tokenBalances=l,me.lastRetry=void 0,l}}catch(l){me.lastRetry=Date.now(),t==null||t(l),ls.showError("Token Balance Unavailable")}finally{me.loading=!1}return[]},fetchNetworkBalance(){if(me.tokenBalances.length===0)return;const t=Om.mapBalancesToSwapTokens(me.tokenBalances);if(!t)return;const e=t.find(s=>s.address===Ah());e&&(me.networkBalanceInUSD=e?eg.multiply(e.quantity.numeric,e.price).toString():"0")},async sendNativeToken(t){var o,a,c,l;ee.pushTransactionStack({});const e=t.receiverAddress,s=(o=m.getAccountData())==null?void 0:o.address,n=j.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),i=await j.sendTransaction({chainNamespace:U.CHAIN.EVM,to:e,address:s,data:"0x",value:n??BigInt(0)});return ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:qt("eip155")===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((a=oe.state.token)==null?void 0:a.symbol)||"",amount:t.sendTokenAmount,network:((c=m.state.activeCaipNetwork)==null?void 0:c.caipNetworkId)||"",hash:i||""}}),(l=j._getClient())==null||l.updateBalance("eip155"),oe.resetSend(),{hash:i}},async sendERC20Token(t){var n,r,i;ee.pushTransactionStack({onSuccess(){ee.replace("Account")}});const e=j.parseUnits(t.sendTokenAmount.toString(),Number(t.decimals)),s=(n=m.getAccountData())==null?void 0:n.address;if(s&&t.sendTokenAmount&&t.receiverAddress&&t.tokenAddress){const o=V.getPlainAddress(t.tokenAddress);if(!o)throw new Error("SendController:sendERC20Token - tokenAddress is required");const a=await j.writeContract({fromAddress:s,tokenAddress:o,args:[t.receiverAddress,e??BigInt(0)],method:"transfer",abi:rg.getERC20Abi(o),chainNamespace:U.CHAIN.EVM});return ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:qt("eip155")===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,token:((r=oe.state.token)==null?void 0:r.symbol)||"",amount:t.sendTokenAmount,network:((i=m.state.activeCaipNetwork)==null?void 0:i.caipNetworkId)||"",hash:a||""}}),oe.resetSend(),{hash:a}}return{hash:void 0}},async sendSolanaToken(){var s,n,r;if(!oe.state.sendTokenAmount||!oe.state.receiverAddress)throw new Error("An amount and receiver address are required");ee.pushTransactionStack({onSuccess(){ee.replace("Account")}});let t;oe.state.token&&oe.state.token.address!==ye.SOLANA_NATIVE_TOKEN_ADDRESS&&(V.isCaipAddress(oe.state.token.address)?t=V.getPlainAddress(oe.state.token.address):t=oe.state.token.address);const e=await j.sendTransaction({chainNamespace:"solana",tokenMint:t,to:oe.state.receiverAddress,value:oe.state.sendTokenAmount});e&&(me.hash=e),(s=j._getClient())==null||s.updateBalance("solana"),ae.sendEvent({type:"track",event:"SEND_SUCCESS",properties:{isSmartAccount:!1,token:((n=oe.state.token)==null?void 0:n.symbol)||"",amount:oe.state.sendTokenAmount,network:((r=m.state.activeCaipNetwork)==null?void 0:r.caipNetworkId)||"",hash:e||""}}),oe.resetSend()},resetSend(){me.token=void 0,me.sendTokenAmount=void 0,me.receiverAddress=void 0,me.receiverProfileImageUrl=void 0,me.receiverProfileName=void 0,me.loading=!1,me.tokenBalances=[]}},oe=Ht(Pm),ga={currentTab:0,tokenBalance:[],smartAccountDeployed:!1,addressLabels:new Map,user:void 0,preferredAccountType:void 0},Ki={caipNetwork:void 0,supportsAllNetworks:!0,smartAccountEnabledNetworks:[]},q=ke({chains:wg(),activeCaipAddress:void 0,activeChain:void 0,activeCaipNetwork:void 0,noAdapters:!1,universalAdapter:{connectionControllerClient:void 0},isSwitchingNamespace:!1}),_h={state:q,subscribe(t){return Ze(q,()=>{t(q)})},subscribeKey(t,e){return Qe(q,t,e)},subscribeAccountStateProp(t,e,s){var r;const n=s||q.activeChain;return n?Qe(((r=q.chains.get(n))==null?void 0:r.accountState)||{},t,e):()=>{}},subscribeChainProp(t,e,s){let n;return Ze(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}=P.getActiveNetworkProps(),i=e==null?void 0:e.find(u=>u.id.toString()===(n==null?void 0:n.toString())),a=t.find(u=>(u==null?void 0:u.namespace)===r)||(t==null?void 0:t[0]),c=t.map(u=>u.namespace).filter(u=>u!==void 0),l=_.state.enableEmbedded?new Set([...c]):new Set([...(e==null?void 0:e.map(u=>u.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,m.setChainNetworkData(a==null?void 0:a.namespace,{caipNetwork:i}),q.activeChain&&Ns.set({activeChain:a==null?void 0:a.namespace})),l.forEach(u=>{const d=e==null?void 0:e.filter(g=>g.chainNamespace===u),h=P.getPreferredAccountTypes()||{},p={..._.state.defaultAccountTypes,...h};m.state.chains.set(u,{namespace:u,networkState:ke({...Ki,caipNetwork:d==null?void 0:d[0]}),accountState:ke({...ga,preferredAccountType:p[u]}),caipNetworks:d??[],...s}),m.setRequestedCaipNetworks(d??[],u)})},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&&m.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:{...Ki,caipNetwork:s[0]},accountState:{...ga},caipNetworks:s,connectionControllerClient:e}),m.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}),m.setRequestedCaipNetworks(n,t.chainNamespace),L.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])&&m.setActiveCaipNetwork(s.caipNetworks[0]),q.chains.set(t,{...s,caipNetworks:a}),m.setRequestedCaipNetworks(a||[],t),a.length===0&&L.filterByNamespace(t,!1)}},setAdapterNetworkState(t,e){const s=q.chains.get(t);s&&(s.networkState={...s.networkState||Ki,...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||ga,...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||Ki,...e};q.chains.set(t,{...s,networkState:n})}},setAccountProp(t,e,s,n=!0){m.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,m.setChainNetworkData(t,{caipNetwork:s}),P.setActiveCaipNetworkId(s==null?void 0:s.caipNetworkId),Ns.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||m.setIsSwitchingNamespace(!0);const s=q.chains.get(t.chainNamespace);q.activeChain=t.chainNamespace,q.activeCaipNetwork=t,m.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}=Xe.parseCaipAddress(q.activeCaipAddress);n=a,q.activeCaipAddress=`${t.caipNetworkId}:${n}`}else q.activeCaipAddress=void 0;m.setChainAccountData(t.chainNamespace,{address:n,caipAddress:q.activeCaipAddress}),oe.resetSend(),Ns.set({activeChain:q.activeChain,selectedNetworkId:(o=q.activeCaipNetwork)==null?void 0:o.caipNetworkId}),P.setActiveCaipNetworkId(t.caipNetworkId),!m.checkIfSupportedNetwork(t.chainNamespace)&&_.state.enableNetworkSwitch&&!_.state.allowUnsupportedChain&&!j.state.wcBasic&&m.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!==m.state.activeChain,s=(r=m.getNetworkData(t))==null?void 0:r.caipNetwork,n=m.getCaipNetworkByNamespace(t,s==null?void 0:s.id);e&&n&&await m.switchActiveNetwork(n)},async switchActiveNetwork(t,{throwOnFailure:e=!1}={}){var o;const s=m.state.activeChain;if(!s)throw new Error("ChainController:switchActiveNetwork - namespace is required");const n=xe.getProviderId(q.activeChain)==="AUTH",r=(o=m.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=Ih.get(t.chainNamespace);if(!a)throw new Error("Adapter not found");await a.switchNetwork({caipNetwork:t})}m.setActiveCaipNetwork(t)}catch(a){if(e)throw a}ae.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 V.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=m.getRequestedCaipNetworks(e.namespace);t.push(...s)}),t},setRequestedCaipNetworks(t,e){m.setAdapterNetworkState(e,{requestedCaipNetworks:t});const n=m.getAllRequestedCaipNetworks().map(i=>i.chainNamespace),r=Array.from(new Set(n));L.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=m.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){m.setAdapterNetworkState(t,e)},checkIfSupportedNetwork(t,e){var r;const s=e||((r=q.activeCaipNetwork)==null?void 0:r.caipNetworkId),n=m.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=m.getRequestedCaipNetworks(q.activeChain);return e==null?void 0:e.some(s=>s.id===t)},checkIfSmartAccountEnabled(){var n,r;const t=rh.caipNetworkIdToNumber((n=q.activeCaipNetwork)==null?void 0:n.caipNetworkId);if(!q.activeChain||!t)return!1;const s=((r=vg.get(lo.SMART_ACCOUNT_ENABLED_NETWORKS))==null?void 0:r.split(","))||[];return!!(s!=null&&s.includes(t.toString()))},showUnsupportedChainUI(){de.open({view:"UnsupportedChain"})},checkIfNamesSupported(){const t=q.activeCaipNetwork;return!!(t!=null&&t.chainNamespace&&ye.NAMES_SUPPORTED_CHAIN_NAMESPACES.includes(t.chainNamespace))},resetNetwork(t){m.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=m.state.chains.get(e))==null?void 0:r.accountState)==null?void 0:i.preferredAccountType,n=_.state.defaultAccountTypes[e];q.activeCaipAddress=void 0,m.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"}),L.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=m.state.chains.get(e))==null?void 0:s.accountState},getNetworkData(t){var s;const e=t||q.activeChain;if(e)return(s=m.state.chains.get(e))==null?void 0:s.networkState},getCaipNetworkByNamespace(t,e){var r,i,o;if(!t)return;const s=m.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=L.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?m.getRequestedCaipNetworks(t):m.getAllRequestedCaipNetworks()},getCaipNetworkById(t,e){return _h.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=m.getAccountData();if(!e)return[];const s=(o=m.state.activeCaipNetwork)==null?void 0:o.caipNetworkId,n=(a=m.state.activeCaipNetwork)==null?void 0:a.chainNamespace,r=m.state.activeCaipAddress,i=r?V.getPlainAddress(r):void 0;if(m.setAccountProp("balanceLoading",!0,n),e.lastRetry&&!V.isAllowedRetry(e.lastRetry,30*ye.ONE_SEC_MS))return m.setAccountProp("balanceLoading",!1,n),[];try{if(i&&s&&n){const c=await Yc.getMyTokensWithBalance();return m.setAccountProp("tokenBalance",c,n),m.setAccountProp("lastRetry",void 0,n),m.setAccountProp("balanceLoading",!1,n),c}}catch(c){m.setAccountProp("lastRetry",Date.now(),n),t==null||t(c),ls.showError("Token Balance Unavailable")}finally{m.setAccountProp("balanceLoading",!1,n)}return[]},isCaipNetworkDisabled(t){var c;const e=t.chainNamespace,s=!!((c=m.getAccountData(e))!=null&&c.caipAddress),n=m.getAllApprovedCaipNetworkIds(),r=m.getNetworkProp("supportsAllNetworks",e)!==!1,i=L.getConnectorId(e),o=L.getAuthConnector(),a=i===U.CONNECTOR_ID.AUTH&&o;return!s||r||a?!1:!(n!=null&&n.includes(t.caipNetworkId))}},m=Ht(_h),km={onSwitchNetwork({network:t,ignoreSwitchConfirmation:e=!1}){var h,p;const s=m.state.activeCaipNetwork,n=m.state.activeChain,r=ee.state.data;if(t.id===(s==null?void 0:s.id))return;const o=!!((h=m.getAccountData(n))!=null&&h.address),a=!!((p=m.getAccountData(t.chainNamespace))!=null&&p.address),c=t.chainNamespace!==n,u=L.getConnectorId(n)===U.CONNECTOR_ID.AUTH,d=U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(g=>g===t.chainNamespace);e||u&&d?ee.push("SwitchNetwork",{...r,network:t}):o&&c&&!a?ee.push("SwitchActiveChain",{switchToChain:t.chainNamespace,navigateTo:"Connect",navigateWithReplace:!0,network:t}):ee.push("SwitchNetwork",{...r,network:t})}},ht=ke({loading:!1,loadingNamespaceMap:new Map,open:!1,shake:!1,namespace:void 0}),Rm={state:ht,subscribe(t){return Ze(ht,()=>t(ht))},subscribeKey(t,e){return Qe(ht,t,e)},async open(t){var o,a;const e=t==null?void 0:t.namespace,s=m.state.activeChain,n=e&&e!==s,r=(o=m.getAccountData(t==null?void 0:t.namespace))==null?void 0:o.caipAddress,i=m.state.noAdapters;if(j.state.wcBasic?J.prefetch({fetchNetworkImages:!1,fetchConnectorImages:!1,fetchWalletRanks:!1}):await J.prefetch(),L.setFilterByNamespace(t==null?void 0:t.namespace),de.setLoading(!0,e),e&&n){const c=((a=m.getNetworkData(e))==null?void 0:a.caipNetwork)||m.getRequestedCaipNetworks(e)[0];c&&(i?(await m.switchActiveNetwork(c),ee.push("ConnectingWalletConnectBasic")):km.onSwitchNetwork({network:c,ignoreSwitchConfirmation:!0}))}else _.state.manualWCControl||i&&!r?V.isMobile()?ee.reset("AllWallets"):ee.reset("ConnectingWalletConnectBasic"):t!=null&&t.view?ee.reset(t.view,t.data):r?ee.reset("Account"):ee.reset("Connect");ht.open=!0,Ns.set({open:!0}),ae.sendEvent({type:"track",event:"MODAL_OPEN",properties:{connected:!!r}})},close(){const t=_.state.enableEmbedded,e=!!m.state.activeCaipAddress;ht.open&&ae.sendEvent({type:"track",event:"MODAL_CLOSE",properties:{connected:e}}),ht.open=!1,ee.reset("Connect"),de.clearLoading(),t?e?ee.replace("Account"):ee.push("Connect"):Ns.set({open:!1}),j.resetUri()},setLoading(t,e){e&&ht.loadingNamespaceMap.set(e,t),ht.loading=t,Ns.set({loading:t})},clearLoading(){ht.loadingNamespaceMap.clear(),ht.loading=!1,Ns.set({loading:!1})},shake(){ht.shake||(ht.shake=!0,setTimeout(()=>{ht.shake=!1},500))}},de=Ht(Rm),qr={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"}]},sc={id:"USD",payment_method_limits:[{id:"card",min:"10.00",max:"7500.00"},{id:"ach_bank_account",min:"10.00",max:"25000.00"}]},xm={providers:uh,selectedProvider:null,error:null,purchaseCurrency:qr,paymentCurrency:sc,purchaseCurrencies:[qr],paymentCurrencies:[],quotesLoading:!1},we=ke(xm),$m={state:we,subscribe(t){return Ze(we,()=>t(we))},subscribeKey(t,e){return Qe(we,t,e)},setSelectedProvider(t){var e,s;if(t&&t.name==="meld"){const n=m.state.activeChain,r=n===U.CHAIN.SOLANA?"SOL":"USDC",i=n?((s=(e=m.state.chains.get(n))==null?void 0:e.accountState)==null?void 0:s.address)??"":"",o=new URL(t.url);o.searchParams.append("publicKey",bg),o.searchParams.append("destinationCurrencyCode",r),o.searchParams.append("walletAddress",i),o.searchParams.append("externalCustomerId",_.state.projectId),we.selectedProvider={...t,url:o.toString()}}else we.selectedProvider=t},setOnrampProviders(t){if(Array.isArray(t)&&t.every(e=>typeof e=="string")){const e=t,s=uh.filter(n=>e.includes(n.name));we.providers=s}else we.providers=[]},setPurchaseCurrency(t){we.purchaseCurrency=t},setPaymentCurrency(t){we.paymentCurrency=t},setPurchaseAmount(t){nc.state.purchaseAmount=t},setPaymentAmount(t){nc.state.paymentAmount=t},async getAvailableCurrencies(){const t=await te.getOnrampOptions();we.purchaseCurrencies=t.purchaseCurrencies,we.paymentCurrencies=t.paymentCurrencies,we.paymentCurrency=t.paymentCurrencies[0]||sc,we.purchaseCurrency=t.purchaseCurrencies[0]||qr,await J.fetchCurrencyImages(t.paymentCurrencies.map(e=>e.id)),await J.fetchTokenImages(t.purchaseCurrencies.map(e=>e.symbol))},async getQuote(){var t,e;we.quotesLoading=!0;try{const s=await te.getOnrampQuote({purchaseCurrency:we.purchaseCurrency,paymentCurrency:we.paymentCurrency,amount:((t=we.paymentAmount)==null?void 0:t.toString())||"0",network:(e=we.purchaseCurrency)==null?void 0:e.symbol});return we.quotesLoading=!1,we.purchaseAmount=Number(s==null?void 0:s.purchaseAmount.amount),s}catch(s){return we.error=s.message,we.quotesLoading=!1,null}finally{we.quotesLoading=!1}},resetState(){we.selectedProvider=null,we.error=null,we.purchaseCurrency=qr,we.paymentCurrency=sc,we.purchaseCurrencies=[qr],we.paymentCurrencies=[],we.paymentAmount=void 0,we.purchaseAmount=void 0,we.quotesLoading=!1}},nc=Ht($m);var Ko={exports:{}};function Um(t){try{return JSON.stringify(t)}catch{return'"[Circular]"'}}var Dm=Lm;function Lm(t,e,s){var n=s&&s.stringify||Um,r=1;if(typeof t=="object"&&t!==null){var i=e.length+r;if(i===1)return t;var o=new Array(i);o[0]=n(t);for(var a=1;a<i;a++)o[a]=n(e[a]);return o.join(" ")}if(typeof t!="string")return t;var c=e.length;if(c===0)return t;for(var l="",u=1-r,d=-1,h=t&&t.length||0,p=0;p<h;){if(t.charCodeAt(p)===37&&p+1<h){switch(d=d>-1?d:0,t.charCodeAt(p+1)){case 100:case 102:if(u>=c||e[u]==null)break;d<p&&(l+=t.slice(d,p)),l+=Number(e[u]),d=p+2,p++;break;case 105:if(u>=c||e[u]==null)break;d<p&&(l+=t.slice(d,p)),l+=Math.floor(Number(e[u])),d=p+2,p++;break;case 79:case 111:case 106:if(u>=c||e[u]===void 0)break;d<p&&(l+=t.slice(d,p));var g=typeof e[u];if(g==="string"){l+="'"+e[u]+"'",d=p+2,p++;break}if(g==="function"){l+=e[u].name||"<anonymous>",d=p+2,p++;break}l+=n(e[u]),d=p+2,p++;break;case 115:if(u>=c)break;d<p&&(l+=t.slice(d,p)),l+=String(e[u]),d=p+2,p++;break;case 37:d<p&&(l+=t.slice(d,p)),l+="%",d=p+2,p++,u--;break}++u}++p}return d===-1?t:(d<h&&(l+=t.slice(d)),l)}const Ml=Dm;Ko.exports=Rs;const bi=Zm().console||{},Mm={mapHttpRequest:zi,mapHttpResponse:zi,wrapRequestSerializer:ma,wrapResponseSerializer:ma,wrapErrorSerializer:ma,req:zi,res:zi,err:jl,errWithCause:jl};function Qs(t,e){return t==="silent"?1/0:e.levels.values[t]}const Jc=Symbol("pino.logFuncs"),rc=Symbol("pino.hierarchy"),Bm={error:"log",fatal:"error",warn:"error",info:"log",debug:"log",trace:"log"};function Bl(t,e){const s={logger:e,parent:t[rc]};e[rc]=s}function jm(t,e,s){const n={};e.forEach(r=>{n[r]=s[r]?s[r]:bi[r]||bi[Bm[r]||"log"]||rr}),t[Jc]=n}function Fm(t,e){return Array.isArray(t)?t.filter(function(n){return n!=="!stdSerializers.err"}):t===!0?Object.keys(e):!1}function Rs(t){t=t||{},t.browser=t.browser||{};const e=t.browser.transmit;if(e&&typeof e.send!="function")throw Error("pino: transmit option must have a send function");const s=t.browser.write||bi;t.browser.write&&(t.browser.asObject=!0);const n=t.serializers||{},r=Fm(t.browser.serialize,n);let i=t.browser.serialize;Array.isArray(t.browser.serialize)&&t.browser.serialize.indexOf("!stdSerializers.err")>-1&&(i=!1);const o=Object.keys(t.customLevels||{}),a=["error","fatal","warn","info","debug","trace"].concat(o);typeof s=="function"&&a.forEach(function(f){s[f]=s}),(t.enabled===!1||t.browser.disabled)&&(t.level="silent");const c=t.level||"info",l=Object.create(s);l.log||(l.log=rr),jm(l,a,s),Bl({},l),Object.defineProperty(l,"levelVal",{get:d}),Object.defineProperty(l,"level",{get:h,set:p});const u={transmit:e,serialize:r,asObject:t.browser.asObject,asObjectBindingsOnly:t.browser.asObjectBindingsOnly,formatters:t.browser.formatters,levels:a,timestamp:Ym(t),messageKey:t.messageKey||"msg",onChild:t.onChild||rr};l.levels=qm(t),l.level=c,l.isLevelEnabled=function(f){return this.levels.values[f]?this.levels.values[f]>=this.levels.values[this.level]:!1},l.setMaxListeners=l.getMaxListeners=l.emit=l.addListener=l.on=l.prependListener=l.once=l.prependOnceListener=l.removeListener=l.removeAllListeners=l.listeners=l.listenerCount=l.eventNames=l.write=l.flush=rr,l.serializers=n,l._serialize=r,l._stdErrSerialize=i,l.child=function(...f){return g.call(this,u,...f)},e&&(l._logEvent=ic());function d(){return Qs(this.level,this)}function h(){return this._level}function p(f){if(f!=="silent"&&!this.levels.values[f])throw Error("unknown level "+f);this._level=f,un(this,u,l,"error"),un(this,u,l,"fatal"),un(this,u,l,"warn"),un(this,u,l,"info"),un(this,u,l,"debug"),un(this,u,l,"trace"),o.forEach(y=>{un(this,u,l,y)})}function g(f,y,w){if(!y)throw new Error("missing bindings for child Pino");w=w||{},r&&y.serializers&&(w.serializers=y.serializers);const b=w.serializers;if(r&&b){var E=Object.assign({},n,b),N=t.browser.serialize===!0?Object.keys(E):r;delete y.serializers,Xc([y],N,E,this._stdErrSerialize)}function x(W){this._childLevel=(W._childLevel|0)+1,this.bindings=y,E&&(this.serializers=E,this._serialize=N),e&&(this._logEvent=ic([].concat(W._logEvent.bindings,y)))}x.prototype=this;const $=new x(this);return Bl(this,$),$.child=function(...W){return g.call(this,f,...W)},$.level=w.level||this.level,f.onChild($),$}return l}function qm(t){const e=t.customLevels||{},s=Object.assign({},Rs.levels.values,e),n=Object.assign({},Rs.levels.labels,Wm(e));return{values:s,labels:n}}function Wm(t){const e={};return Object.keys(t).forEach(function(s){e[t[s]]=s}),e}Rs.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"}};Rs.stdSerializers=Mm;Rs.stdTimeFunctions=Object.assign({},{nullTime:Sh,epochTime:Nh,unixTime:Jm,isoTime:Xm});function Hm(t){const e=[];t.bindings&&e.push(t.bindings);let s=t[rc];for(;s.parent;)s=s.parent,s.logger.bindings&&e.push(s.logger.bindings);return e.reverse()}function un(t,e,s,n){if(Object.defineProperty(t,n,{value:Qs(t.level,s)>Qs(n,s)?rr:s[Jc][n],writable:!0,enumerable:!0,configurable:!0}),t[n]===rr){if(!e.transmit)return;const i=e.transmit.level||t.level,o=Qs(i,s);if(Qs(n,s)<o)return}t[n]=zm(t,e,s,n);const r=Hm(t);r.length!==0&&(t[n]=Km(r,t[n]))}function Km(t,e){return function(){return e.apply(this,[...t,...arguments])}}function zm(t,e,s,n){return function(r){return function(){const o=e.timestamp(),a=new Array(arguments.length),c=Object.getPrototypeOf&&Object.getPrototypeOf(this)===bi?bi:this;for(var l=0;l<a.length;l++)a[l]=arguments[l];var u=!1;if(e.serialize&&(Xc(a,this._serialize,this.serializers,this._stdErrSerialize),u=!0),e.asObject||e.formatters?r.call(c,...Vm(this,n,a,o,e)):r.apply(c,a),e.transmit){const d=e.transmit.level||t._level,h=Qs(d,s),p=Qs(n,s);if(p<h)return;Gm(this,{ts:o,methodLevel:n,methodValue:p,transmitValue:s.levels.values[e.transmit.level||t._level],send:e.transmit.send,val:Qs(t._level,s)},a,u)}}}(t[Jc][n])}function Vm(t,e,s,n,r){const{level:i,log:o=d=>d}=r.formatters||{},a=s.slice();let c=a[0];const l={};let u=(t._childLevel|0)+1;if(u<1&&(u=1),n&&(l.time=n),i){const d=i(e,t.levels.values[e]);Object.assign(l,d)}else l.level=t.levels.values[e];if(r.asObjectBindingsOnly){if(c!==null&&typeof c=="object")for(;u--&&typeof a[0]=="object";)Object.assign(l,a.shift());return[o(l),...a]}else{if(c!==null&&typeof c=="object"){for(;u--&&typeof a[0]=="object";)Object.assign(l,a.shift());c=a.length?Ml(a.shift(),a):void 0}else typeof c=="string"&&(c=Ml(a.shift(),a));return c!==void 0&&(l[r.messageKey]=c),[o(l)]}}function Xc(t,e,s,n){for(const r in t)if(n&&t[r]instanceof Error)t[r]=Rs.stdSerializers.err(t[r]);else if(typeof t[r]=="object"&&!Array.isArray(t[r])&&e)for(const i in t[r])e.indexOf(i)>-1&&i in s&&(t[r][i]=s[i](t[r][i]))}function Gm(t,e,s,n=!1){const r=e.send,i=e.ts,o=e.methodLevel,a=e.methodValue,c=e.val,l=t._logEvent.bindings;n||Xc(s,t._serialize||Object.keys(t.serializers),t.serializers,t._stdErrSerialize===void 0?!0:t._stdErrSerialize),t._logEvent.ts=i,t._logEvent.messages=s.filter(function(u){return l.indexOf(u)===-1}),t._logEvent.level.label=o,t._logEvent.level.value=a,r(o,t._logEvent,c),t._logEvent=ic(l)}function ic(t){return{ts:0,messages:[],bindings:t||[],level:{label:"",value:0}}}function jl(t){const e={type:t.constructor.name,msg:t.message,stack:t.stack};for(const s in t)e[s]===void 0&&(e[s]=t[s]);return e}function Ym(t){return typeof t.timestamp=="function"?t.timestamp:t.timestamp===!1?Sh:Nh}function zi(){return{}}function ma(t){return t}function rr(){}function Sh(){return!1}function Nh(){return Date.now()}function Jm(){return Math.round(Date.now()/1e3)}function Xm(){return new Date(Date.now()).toISOString()}function Zm(){function t(e){return typeof e<"u"&&e}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 t(self)||t(window)||t(this)||{}}}Ko.exports.default=Rs;Ko.exports.pino=Rs;var Qt=Ko.exports;const zo=Sf(Qt),Fl=2147483648,Qm={convertEVMChainIdToCoinType(t){if(t>=Fl)throw new Error("Invalid chainId");return(Fl|t)>>>0}},Rt=ke({suggestions:[],loading:!1}),ey={state:Rt,subscribe(t){return Ze(Rt,()=>t(Rt))},subscribeKey(t,e){return Qe(Rt,t,e)},async resolveName(t){var e,s;try{return await te.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 te.lookupEnsName(t),!0}catch{return!1}},async getSuggestions(t){try{Rt.loading=!0,Rt.suggestions=[];const e=await te.getEnsNameSuggestions(t);return Rt.suggestions=e.suggestions||[],Rt.suggestions}catch(e){const s=Wr.parseEnsApiError(e,"Error fetching name suggestions");throw new Error(s)}finally{Rt.loading=!1}},async getNamesForAddress(t){try{if(!m.state.activeCaipNetwork)return[];const s=P.getEnsFromCacheForAddress(t);if(s)return s;const n=await te.reverseLookupEnsName({address:t});return P.updateEnsCache({address:t,ens:n,timestamp:Date.now()}),n}catch(e){const s=Wr.parseEnsApiError(e,"Error fetching names for address");throw new Error(s)}},async registerName(t){var r;const e=m.state.activeCaipNetwork,s=(r=m.getAccountData(e==null?void 0:e.chainNamespace))==null?void 0:r.address,n=L.getAuthConnector();if(!e)throw new Error("Network not found");if(!s||!n)throw new Error("Address or auth connector not found");Rt.loading=!0;try{const i=JSON.stringify({name:t,attributes:{},timestamp:Math.floor(Date.now()/1e3)});ee.pushTransactionStack({onCancel(){ee.replace("RegisterAccountName")}});const o=await j.signMessage(i);Rt.loading=!1;const a=e.id;if(!a)throw new Error("Network not found");const c=Qm.convertEVMChainIdToCoinType(Number(a));await te.registerEnsName({coinType:c,address:s,signature:o,message:i}),m.setAccountProp("profileName",t,e.chainNamespace),P.updateEnsCache({address:s,ens:[{name:t,registered_at:new Date().toISOString(),updated_at:void 0,addresses:{},attributes:[]}],timestamp:Date.now()}),ee.replace("RegisterAccountNameSuccess")}catch(i){const o=Wr.parseEnsApiError(i,`Error registering name ${t}`);throw ee.replace("RegisterAccountName"),new Error(o)}finally{Rt.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}},Wr=Ht(ey),ty={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"]},en={RPC_ERROR_CODE:{USER_REJECTED:5e3,USER_REJECTED_METHODS:5002},getMethodsByChainNamespace(t){return ty[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}`,u=n[o];switch(u.chains.push(l),l){case"solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":u.chains.push("solana:4sGjMW1sUnHzSxGspuhpqLDx6wiyjNtZ");break;case"solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1":u.chains.push("solana:8E9rvCKLFQia2Y35HXjjpWzj8weVo44K");break}return u!=null&&u.rpcMap&&c&&(u.rpcMap[i]=c),n},{});return this.applyNamespaceOverrides(s,e)},resolveReownName:async t=>{var n;const e=await Wr.resolveName(t);return((n=(Object.values(e==null?void 0: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===en.RPC_ERROR_CODE.USER_REJECTED_METHODS,r=s&&e.code===en.RPC_ERROR_CODE.USER_REJECTED;return n||r}return!1}catch{return!1}},isOriginAllowed(t,e,s){for(const n of[...e,...s])if(n.includes("*")){const i=`^${n.replace(/[.*+?^${}()|[\]\\]/gu,"\\$&").replace(/\\\*/gu,".*")}$`;if(new RegExp(i,"u").test(t))return!0}else try{if(new URL(n).origin===t)return!0}catch{if(n===t)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=en.getWalletConnectAccounts(t,e);s(a)}),n&&t.on("disconnect",()=>{n()}),r&&t.on("accountsChanged",a=>{var c,l,u,d,h;try{const p=((u=(l=(c=t.session)==null?void 0:c.namespaces)==null?void 0:l[e])==null?void 0:u.accounts)||[],g=(h=(d=t.rpcProviders)==null?void 0:d[e])==null?void 0:h.getDefaultChain(),f=a.map(y=>{const w=p.find(N=>N.includes(`${e}:${g}:${y}`));if(!w)return;const{chainId:b,chainNamespace:E}=Xe.parseCaipAddress(w);return{address:y,chainId:b,chainNamespace:E}}).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=>Xe.parseCaipAddress(c)).filter(({address:c})=>s.has(c.toLowerCase())?!1:(s.add(c.toLowerCase()),!0));return n&&n.length>0?n:[]}},sy=[U.CONNECTOR_ID.AUTH,U.CONNECTOR_ID.WALLET_CONNECT];class ny{constructor(e){this.availableConnectors=[],this.availableConnections=[],this.providerHandlers={},this.eventListeners=new Map,this.getCaipNetworks=s=>m.getCaipNetworks(s),this.getConnectorId=s=>L.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){m.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 en.isUserRejectedRequestError(s)?new ch(s):s}}async switchNetwork(e){var i;const{caipNetwork:s}=e,n=xe.getProviderId(s.chainNamespace),r=xe.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=L.getAuthConnector())==null?void 0:i.provider;if(!o)throw new Error("Auth provider not found");const a=qt(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}=V.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}=V.getAccount(a);return{address:c}}),caipNetwork:i}))}}onAccountsChanged(e,s,n=!0){var r,i;if(e.length>0){const{address:o}=V.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}=V.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(sy.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 dn=null;const Zt={getSIWX(){return _.state.siwx},async initializeIfEnabled(t=m.getActiveCaipAddress()){var i,o,a;const e=_.state.siwx;if(!(e&&t))return;const[s,n,r]=t.split(":");if(m.checkIfSupportedNetwork(s,`${s}:${n}`))try{if((i=_.state.remoteFeatures)!=null&&i.emailCapture){const l=(o=m.getAccountData(s))==null?void 0:o.user;await de.open({view:"DataCapture",data:{email:(l==null?void 0:l.email)??void 0}});return}if(dn&&await dn,(await e.getSessions(`${s}:${n}`,r)).length)return;await de.open({view:"SIWXSignMessage"})}catch(c){console.error("SIWXUtil:initializeIfEnabled",c),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(c)}),await((a=j._getClient())==null?void 0:a.disconnect().catch(console.error)),ee.reset("Connect"),ls.showError("A problem occurred while trying initialize authentication")}},async isAuthenticated(t=m.getActiveCaipAddress()){if(!_.state.siwx||!t)return!0;const{chainNamespace:s,chainId:n,address:r}=Xe.parseCaipAddress(t),i=`${s}:${n}`;return(await Zt.getSessions({address:r,caipNetworkId:i})).length>0},async requestSignMessage(){const t=_.state.siwx,e=V.getPlainAddress(m.getActiveCaipAddress()),s=Hi(),n=j._getClient();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");if(!n)throw new Error("No ConnectionController client found");try{const r=await t.createMessage({chainId:s.caipNetworkId,accountAddress:e}),i=r.toString();L.getConnectorId(s.chainNamespace)===U.CONNECTOR_ID.AUTH&&ee.pushTransactionStack({});const a=await n.signMessage(i);await t.addSession({data:r,message:i,signature:a}),m.setLastConnectedSIWECaipNetwork(s),de.close(),ae.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:this.getSIWXEventProperties()})}catch(r){(!de.state.open||ee.state.view==="ApproveTransaction")&&await de.open({view:"SIWXSignMessage"}),ls.showError("Error signing message"),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:this.getSIWXEventProperties(r)}),console.error("SWIXUtil:requestSignMessage",r)}},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=m.getLastConnectedSIWECaipNetwork();if(n){const r=await(e==null?void 0:e.getSessions(n==null?void 0:n.caipNetworkId,V.getPlainAddress(m.getActiveCaipAddress())||""));r&&r.length>0?await m.switchActiveNetwork(n):await j.disconnect()}else await j.disconnect()}else de.close();de.close(),ae.sendEvent({event:"CLICK_CANCEL_SIWX",type:"track",properties:this.getSIWXEventProperties()})}catch(e){console.error("SIWXUtil:cancelSignMessage",e)}},async getAllSessions(){const t=this.getSIWX(),e=m.getAllRequestedCaipNetworks(),s=[];return await Promise.all(e.map(async n=>{const r=await(t==null?void 0:t.getSessions(n.caipNetworkId,V.getPlainAddress(m.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=m.getActiveCaipAddress();s=V.getPlainAddress(r)}let n=t==null?void 0:t.caipNetworkId;if(!n){const r=m.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=ee.state.view==="ApproveTransaction",n=ee.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 d;const i=Zt.getSIWX(),o=Hi();if(!i||!r.includes(U.CHAIN.EVM)||(d=_.state.remoteFeatures)!=null&&d.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()},u=await t.connect({chainId:e,socialUri:s,siwxMessage:l,preferredAccountType:n});return l.accountAddress=u.address,l.serializedMessage=u.message||"",u.signature&&u.message&&await Zt.addEmbeddedWalletSession(l,u.message,u.signature),m.setLastConnectedSIWECaipNetwork(o),{address:u.address,chainId:u.chainId,accounts:u.accounts}},async addEmbeddedWalletSession(t,e,s){if(dn)return dn;const n=Zt.getSIWX();return n?(dn=n.addSession({data:t,message:e,signature:s}).finally(()=>{dn=null}),dn):Promise.resolve()},async universalProviderAuthenticate({universalProvider:t,chains:e,methods:s}){var l,u,d;const n=Zt.getSIWX(),r=Hi(),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=Hi())==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)]});ls.showLoading("Authenticating...",{autoClose:!1});const c={...a.session.peer.metadata,name:a.session.peer.metadata.name,icon:(u=a.session.peer.metadata.icons)==null?void 0:u[0],type:"WALLET_CONNECT"};if(m.setAccountProp("connectedWalletInfo",c,Array.from(i)[0]),(d=a==null?void 0:a.auths)!=null&&d.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&&m.setLastConnectedSIWECaipNetwork(r),ae.sendEvent({type:"track",event:"SIWX_AUTH_SUCCESS",properties:Zt.getSIWXEventProperties()})}catch(p){throw console.error("SIWX:universalProviderAuth - failed to set sessions",p),ae.sendEvent({type:"track",event:"SIWX_AUTH_ERROR",properties:Zt.getSIWXEventProperties(p)}),await t.disconnect().catch(console.error),p}finally{ls.hide()}}return!0},getSIWXEventProperties(t){var s;const e=m.state.activeChain;if(!e)throw new Error("SIWXUtil:getSIWXEventProperties - namespace is required");return{network:((s=m.state.activeCaipNetwork)==null?void 0:s.caipNetworkId)||"",isSmartAccount:qt(e)===Ss.ACCOUNT_TYPES.SMART_ACCOUNT,message:t?V.parseError(t):void 0}},async clearSessions(){const t=this.getSIWX();t&&await t.setSessions([])}};class ry{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=m.getCaipNetworks.bind(m),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=en.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 Zt.universalProviderAuthenticate({universalProvider:this.provider,chains:e,methods:iy})}}const iy=["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"],zt=ke({message:"",variant:"info",open:!1}),oy={state:zt,subscribeKey(t,e){return Qe(zt,t,e)},open(t,e){const{debug:s}=_.state,{code:n,displayMessage:r,debugMessage:i}=t;r&&s&&(zt.message=r,zt.variant=e,zt.open=!0),i&&console.error(typeof i=="function"?i():i,n?{code:n}:void 0)},warn(t,e,s){zt.open=!0,zt.message=t,zt.variant="warning",e&&console.warn(e,s)},close(){zt.open=!1,zt.message="",zt.variant="info"}},It=Ht(oy),ay={asset:"0x833589fcd6edb6e08f4c7c32d4f71b54bda02913"},cy={asset:"0x036CbD53842c5426634e7929541eC2318f3dCF7e"};function ly(t){return!t||typeof t.then!="function"?Promise.resolve(t):t}function ze(t,...e){try{return ly(t(...e))}catch(s){return Promise.reject(s)}}function uy(t){const e=typeof t;return t===null||e!=="object"&&e!=="function"}function dy(t){const e=Object.getPrototypeOf(t);return!e||e.isPrototypeOf(Object)}function ho(t){if(uy(t))return String(t);if(dy(t)||Array.isArray(t))return JSON.stringify(t);if(typeof t.toJSON=="function")return ho(t.toJSON());throw new Error("[unstorage] Cannot stringify value!")}const oc="base64:";function hy(t){return typeof t=="string"?t:oc+gy(t)}function py(t){return typeof t!="string"||!t.startsWith(oc)?t:fy(t.slice(oc.length))}function fy(t){return globalThis.Buffer?Buffer.from(t,"base64"):Uint8Array.from(globalThis.atob(t),e=>e.codePointAt(0))}function gy(t){return globalThis.Buffer?Buffer.from(t).toString("base64"):globalThis.btoa(String.fromCodePoint(...t))}function ft(t){var e;return t&&((e=t.split("?")[0])==null?void 0:e.replace(/[/\\]/g,":").replace(/:+/g,":").replace(/^:|:$/g,""))||""}function my(...t){return ft(t.join(":"))}function Vi(t){return t=ft(t),t?t+":":""}function yy(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 wy(t,e){return e?t.startsWith(e)&&t[t.length-1]!=="$":t[t.length-1]!=="$"}const by="memory",vy=()=>{const t=new Map;return{name:by,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 Ey(t={}){const e={mounts:{"":t.driver||vy()},mountpoints:[""],watching:!1,watchListeners:[],unwatch:{}},s=l=>{for(const u of e.mountpoints)if(l.startsWith(u))return{base:u,relativeKey:l.slice(u.length),driver:e.mounts[u]};return{base:"",relativeKey:l,driver:e.mounts[""]}},n=(l,u)=>e.mountpoints.filter(d=>d.startsWith(l)||u&&l.startsWith(d)).map(d=>({relativeBase:l.length>d.length?l.slice(d.length):void 0,mountpoint:d,driver:e.mounts[d]})),r=(l,u)=>{if(e.watching){u=ft(u);for(const d of e.watchListeners)d(l,u)}},i=async()=>{if(!e.watching){e.watching=!0;for(const l in e.mounts)e.unwatch[l]=await ql(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,u,d)=>{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=ft(f?g:g.key),w=f?void 0:g.value,b=f||!g.options?u:{...u,...g.options},E=s(y);p(E).items.push({key:y,value:w,relativeKey:E.relativeKey,options:b})}return Promise.all([...h.values()].map(g=>d(g))).then(g=>g.flat())},c={hasItem(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return ze(h.hasItem,d,u)},getItem(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return ze(h.getItem,d,u).then(p=>Li(p))},getItems(l,u={}){return a(l,u,d=>d.driver.getItems?ze(d.driver.getItems,d.items.map(h=>({key:h.relativeKey,options:h.options})),u).then(h=>h.map(p=>({key:my(d.base,p.key),value:Li(p.value)}))):Promise.all(d.items.map(h=>ze(d.driver.getItem,h.relativeKey,h.options).then(p=>({key:h.key,value:Li(p)})))))},getItemRaw(l,u={}){l=ft(l);const{relativeKey:d,driver:h}=s(l);return h.getItemRaw?ze(h.getItemRaw,d,u):ze(h.getItem,d,u).then(p=>py(p))},async setItem(l,u,d={}){if(u===void 0)return c.removeItem(l);l=ft(l);const{relativeKey:h,driver:p}=s(l);p.setItem&&(await ze(p.setItem,h,ho(u),d),p.watch||r("update",l))},async setItems(l,u){await a(l,u,async d=>{if(d.driver.setItems)return ze(d.driver.setItems,d.items.map(h=>({key:h.relativeKey,value:ho(h.value),options:h.options})),u);d.driver.setItem&&await Promise.all(d.items.map(h=>ze(d.driver.setItem,h.relativeKey,ho(h.value),h.options)))})},async setItemRaw(l,u,d={}){if(u===void 0)return c.removeItem(l,d);l=ft(l);const{relativeKey:h,driver:p}=s(l);if(p.setItemRaw)await ze(p.setItemRaw,h,u,d);else if(p.setItem)await ze(p.setItem,h,hy(u),d);else return;p.watch||r("update",l)},async removeItem(l,u={}){typeof u=="boolean"&&(u={removeMeta:u}),l=ft(l);const{relativeKey:d,driver:h}=s(l);h.removeItem&&(await ze(h.removeItem,d,u),(u.removeMeta||u.removeMata)&&await ze(h.removeItem,d+"$",u),h.watch||r("remove",l))},async getMeta(l,u={}){typeof u=="boolean"&&(u={nativeOnly:u}),l=ft(l);const{relativeKey:d,driver:h}=s(l),p=Object.create(null);if(h.getMeta&&Object.assign(p,await ze(h.getMeta,d,u)),!u.nativeOnly){const g=await ze(h.getItem,d+"$",u).then(f=>Li(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,u,d={}){return this.setItem(l+"$",u,d)},removeMeta(l,u={}){return this.removeItem(l+"$",u)},async getKeys(l,u={}){var y;l=Vi(l);const d=n(l,!0);let h=[];const p=[];let g=!0;for(const w of d){(y=w.driver.flags)!=null&&y.maxDepth||(g=!1);const b=await ze(w.driver.getKeys,w.relativeBase,u);for(const E of b){const N=w.mountpoint+ft(E);h.some(x=>N.startsWith(x))||p.push(N)}h=[w.mountpoint,...h.filter(E=>!E.startsWith(w.mountpoint))]}const f=u.maxDepth!==void 0&&!g;return p.filter(w=>(!f||yy(w,u.maxDepth))&&wy(w,l))},async clear(l,u={}){l=Vi(l),await Promise.all(n(l,!1).map(async d=>{if(d.driver.clear)return ze(d.driver.clear,d.relativeBase,u);if(d.driver.removeItem){const h=await d.driver.getKeys(d.relativeBase||"",u);return Promise.all(h.map(p=>d.driver.removeItem(p,u)))}}))},async dispose(){await Promise.all(Object.values(e.mounts).map(l=>Wl(l)))},async watch(l){return await i(),e.watchListeners.push(l),async()=>{e.watchListeners=e.watchListeners.filter(u=>u!==l),e.watchListeners.length===0&&await o()}},async unwatch(){e.watchListeners=[],await o()},mount(l,u){if(l=Vi(l),l&&e.mounts[l])throw new Error(`already mounted at ${l}`);return l&&(e.mountpoints.push(l),e.mountpoints.sort((d,h)=>h.length-d.length)),e.mounts[l]=u,e.watching&&Promise.resolve(ql(u,r,l)).then(d=>{e.unwatch[l]=d}).catch(console.error),c},async unmount(l,u=!0){var d,h;l=Vi(l),!(!l||!e.mounts[l])&&(e.watching&&l in e.unwatch&&((h=(d=e.unwatch)[l])==null||h.call(d),delete e.unwatch[l]),u&&await Wl(e.mounts[l]),e.mountpoints=e.mountpoints.filter(p=>p!==l),delete e.mounts[l])},getMount(l=""){l=ft(l)+":";const u=s(l);return{driver:u.driver,base:u.base}},getMounts(l="",u={}){return l=ft(l),n(l,u.parents).map(h=>({driver:h.driver,base:h.mountpoint}))},keys:(l,u={})=>c.getKeys(l,u),get:(l,u={})=>c.getItem(l,u),set:(l,u,d={})=>c.setItem(l,u,d),has:(l,u={})=>c.hasItem(l,u),del:(l,u={})=>c.removeItem(l,u),remove:(l,u={})=>c.removeItem(l,u)};return c}function ql(t,e,s){return t.watch?t.watch((n,r)=>e(n,s+r)):()=>{}}async function Wl(t){typeof t.dispose=="function"&&await ze(t.dispose)}const Cy="idb-keyval";var Ay=(t={})=>{const e=t.base&&t.base.length>0?`${t.base}:`:"",s=r=>e+r;let n;return t.dbName&&t.storeName&&(n=Nf(t.dbName,t.storeName)),{name:Cy,options:t,async hasItem(r){return!(typeof await El(s(r),n)>"u")},async getItem(r){return await El(s(r),n)??null},setItem(r,i){return kf(s(r),i,n)},removeItem(r){return Pf(s(r),n)},getKeys(){return Of(n)},clear(){return Tf(n)}}};const Iy="WALLET_CONNECT_V2_INDEXED_DB",_y="keyvaluestorage";let Sy=class{constructor(){this.indexedDb=Ey({driver:Ay({dbName:Iy,storeName:_y})})}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,Rn(s))}async removeItem(e){await this.indexedDb.removeItem(e)}};var ya=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},po={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 ya<"u"&&ya.localStorage?po.exports=ya.localStorage:typeof window<"u"&&window.localStorage?po.exports=window.localStorage:po.exports=new e})();function Ny(t){var e;return[t[0],Eo((e=t[1])!=null?e:"")]}let Ty=class{constructor(){this.localStorage=po.exports}async getKeys(){return Object.keys(this.localStorage)}async getEntries(){return Object.entries(this.localStorage).map(Ny)}async getItem(e){const s=this.localStorage.getItem(e);if(s!==null)return Eo(s)}async setItem(e,s){this.localStorage.setItem(e,Rn(s))}async removeItem(e){this.localStorage.removeItem(e)}};const Oy="wc_storage_version",Hl=1,Py=async(t,e,s)=>{const n=Oy,r=await e.getItem(n);if(r&&r>=Hl){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,Hl),s(e),ky(t,o)},ky=async(t,e)=>{e.length&&e.forEach(async s=>{await t.removeItem(s)})};let Ry=class{constructor(){this.initialized=!1,this.setInitialized=s=>{this.storage=s,this.initialized=!0};const e=new Ty;this.storage=e;try{const s=new Sy;Py(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)})}};const xy={level:"info"},Vo="custom_context",Zc=1e3*1024;var $y=Object.defineProperty,Uy=(t,e,s)=>e in t?$y(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Vs=(t,e,s)=>Uy(t,typeof e!="symbol"?e+"":e,s);let Dy=class{constructor(e){Vs(this,"nodeValue"),Vs(this,"sizeInBytes"),Vs(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}},Kl=class{constructor(e){Vs(this,"lengthInNodes"),Vs(this,"sizeInBytes"),Vs(this,"head"),Vs(this,"tail"),Vs(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new Dy(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 Ly=Object.defineProperty,My=(t,e,s)=>e in t?Ly(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gi=(t,e,s)=>My(t,typeof e!="symbol"?e+"":e,s);let Th=class{constructor(e,s=Zc){Gi(this,"logs"),Gi(this,"level"),Gi(this,"levelValue"),Gi(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Qt.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Kl(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Qt.levels.values.error?console.error(e):s===Qt.levels.values.warn?console.warn(e):s===Qt.levels.values.debug?console.debug(e):s===Qt.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Rn({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 Kl(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Rn({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var By=Object.defineProperty,jy=(t,e,s)=>e in t?By(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fy=(t,e,s)=>jy(t,e+"",s);let qy=class{constructor(e,s=Zc){Fy(this,"baseChunkLogger"),this.baseChunkLogger=new Th(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 Wy=Object.defineProperty,Hy=(t,e,s)=>e in t?Wy(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ky=(t,e,s)=>Hy(t,e+"",s);let zy=class{constructor(e,s=Zc){Ky(this,"baseChunkLogger"),this.baseChunkLogger=new Th(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 Vy=Object.defineProperty,Gy=Object.defineProperties,Yy=Object.getOwnPropertyDescriptors,zl=Object.getOwnPropertySymbols,Jy=Object.prototype.hasOwnProperty,Xy=Object.prototype.propertyIsEnumerable,Vl=(t,e,s)=>e in t?Vy(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,No=(t,e)=>{for(var s in e||(e={}))Jy.call(e,s)&&Vl(t,s,e[s]);if(zl)for(var s of zl(e))Xy.call(e,s)&&Vl(t,s,e[s]);return t},To=(t,e)=>Gy(t,Yy(e));function Zy(t){return To(No({},t),{level:(t==null?void 0:t.level)||xy.level})}function Qy(t,e,s=Vo){return t[s]=e,t}function Et(t,e=Vo){return t[e]||""}function ew(t,e,s=Vo){const n=Et(t,s);return n.trim()?`${n}/${e}`:e}function kt(t,e,s=Vo){const n=ew(t,e,s),r=t.child({context:n});return Qy(r,n,s)}function tw(t){var e,s;const n=new qy((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(To(No({},t.opts),{level:"trace",browser:To(No({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function sw(t){var e;const s=new zy((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(To(No({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function Oh(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?tw(t):sw(t)}var nw=Object.defineProperty,rw=(t,e,s)=>e in t?nw(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gl=(t,e,s)=>rw(t,typeof e!="symbol"?e+"":e,s);let iw=class extends wr{constructor(e){super(),this.opts=e,Gl(this,"protocol","wc"),Gl(this,"version",2)}};var ow=Object.defineProperty,aw=(t,e,s)=>e in t?ow(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,cw=(t,e,s)=>aw(t,e+"",s);let lw=class extends wr{constructor(e,s){super(),this.core=e,this.logger=s,cw(this,"records",new Map)}},uw=class{constructor(e,s){this.logger=e,this.core=s}},dw=class extends wr{constructor(e,s){super(),this.relayer=e,this.logger=s}},hw=class extends wr{constructor(e){super()}},pw=class{constructor(e,s,n,r){this.core=e,this.logger=s,this.name=n}},fw=class extends wr{constructor(e,s){super(),this.relayer=e,this.logger=s}},gw=class extends wr{constructor(e,s){super(),this.core=e,this.logger=s}},mw=class{constructor(e,s,n){this.core=e,this.logger=s,this.store=n}},yw=class{constructor(e,s){this.projectId=e,this.logger=s}},ww=class{constructor(e,s,n){this.core=e,this.logger=s,this.telemetryEnabled=n}};var bw=Object.defineProperty,vw=(t,e,s)=>e in t?bw(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Yl=(t,e,s)=>vw(t,typeof e!="symbol"?e+"":e,s);let Ew=class{constructor(e){this.opts=e,Yl(this,"protocol","wc"),Yl(this,"version",2)}},Cw=class{constructor(e){this.client=e}};var Aw={};const Iw=":";function Os(t){const[e,s]=t.split(Iw);return{namespace:e,reference:s}}function Ph(t,e){return t.includes(":")?[t]:e.chains||[]}var _w=Object.defineProperty,Sw=Object.defineProperties,Nw=Object.getOwnPropertyDescriptors,Jl=Object.getOwnPropertySymbols,Tw=Object.prototype.hasOwnProperty,Ow=Object.prototype.propertyIsEnumerable,ac=(t,e,s)=>e in t?_w(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xl=(t,e)=>{for(var s in e||(e={}))Tw.call(e,s)&&ac(t,s,e[s]);if(Jl)for(var s of Jl(e))Ow.call(e,s)&&ac(t,s,e[s]);return t},Pw=(t,e)=>Sw(t,Nw(e)),Zl=(t,e,s)=>ac(t,typeof e!="symbol"?e+"":e,s);const kw="ReactNative",Ot={reactNative:"react-native",node:"node",browser:"browser",unknown:"unknown"},Rw="js";function Oo(){return typeof process<"u"&&typeof process.versions<"u"&&typeof process.versions.node<"u"}function on(){return!ur()&&!!th()&&navigator.product===kw}function xw(){return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"&&(global==null?void 0:global.Platform.OS)==="android"}function $w(){return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"&&(global==null?void 0:global.Platform.OS)==="ios"}function Er(){return!Oo()&&!!th()&&!!ur()}function Pi(){return on()?Ot.reactNative:Oo()?Ot.node:Er()?Ot.browser:Ot.unknown}function Ql(){var t;try{return on()&&typeof global<"u"&&typeof(global==null?void 0:global.Application)<"u"?(t=global.Application)==null?void 0:t.applicationId:void 0}catch{return}}function Uw(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 Dw(t){var e,s;const n=kh();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!=="")),Pw(Xl(Xl({},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 kh(){return Rf()||{name:"",description:"",url:"",icons:[""]}}function Lw(){if(Pi()===Ot.reactNative&&typeof global<"u"&&typeof(global==null?void 0:global.Platform)<"u"){const{OS:s,Version:n}=global.Platform;return[s,n].join("-")}const t=$f();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 Mw(){var t;const e=Pi();return e===Ot.browser?[e,((t=Uf())==null?void 0:t.host)||"unknown"].join(":"):e}function Rh(t,e,s){const n=Lw(),r=Mw();return[[t,e].join("-"),[Rw,s].join("-"),n,r].join("/")}function Bw({protocol:t,version:e,relayUrl:s,sdkVersion:n,auth:r,projectId:i,useOnCloseEvent:o,bundleId:a,packageName:c}){const l=s.split("?"),u=Rh(t,e,n),d={auth:r,ua:u,projectId:i,useOnCloseEvent:o,packageName:c||void 0,bundleId:a||void 0},h=Uw(l[1]||"",d);return l[0]+"?"+h}function An(t,e){return t.filter(s=>e.includes(s)).length===t.length}function cc(t){return Object.fromEntries(t.entries())}function lc(t){return new Map(Object.entries(t))}function yn(t=F.FIVE_MINUTES,e){const s=F.toMiliseconds(t||F.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 us(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 xh(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 jw(t){return xh("topic",t)}function Fw(t){return xh("id",t)}function $h(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 Be(t,e){return F.fromMiliseconds(Date.now()+F.toMiliseconds(t))}function cs(t){return Date.now()>=F.toMiliseconds(t)}function Ae(t,e){return`${t}${e?`:${e}`:""}`}function ps(t=[],e=[]){return[...new Set([...t,...e])]}async function qw({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=Ww(i,t,e),a=Pi();if(a===Ot.browser){if(!((n=ur())!=null&&n.hasFocus())){console.warn("Document does not have focus, skipping deeplink.");return}Hw(o)}else a===Ot.reactNative&&typeof(global==null?void 0:global.Linking)<"u"&&await global.Linking.openURL(o)}catch(r){console.error(r)}}function Ww(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}${Gw(n,!0)}`}else r=`${r}/wc?${n}`;return r}function Hw(t){let e="_self";Vw()?e="_top":(zw()||t.startsWith("https://")||t.startsWith("http://"))&&(e="_blank"),window.open(t,e,"noreferrer noopener")}async function Kw(t,e){let s="";try{if(Er()&&(s=localStorage.getItem(e),s))return s;s=await t.getItem(e)}catch(n){console.error(n)}return s}function eu(t,e){if(!t.includes(e))return null;const s=t.split(/([&,?,=])/),n=s.indexOf(e);return s[n+2]}function tu(){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 Qc(){return typeof process<"u"&&Aw.IS_VITEST==="true"}function zw(){return typeof window<"u"&&(!!window.TelegramWebviewProxy||!!window.Telegram||!!window.TelegramWebviewProxyProto)}function Vw(){try{return window.self!==window.top}catch{return!1}}function Gw(t,e=!1){const s=Buffer.from(t).toString("base64");return e?s.replace(/[=]/g,""):s}function Uh(t){return Buffer.from(t,"base64").toString("utf-8")}function Yw(t){return new Promise(e=>setTimeout(e,t))}let Jw=class{constructor({limit:e}){Zl(this,"limit"),Zl(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 Yi=BigInt(2**32-1),su=BigInt(32);function Dh(t,e=!1){return e?{h:Number(t&Yi),l:Number(t>>su&Yi)}:{h:Number(t>>su&Yi)|0,l:Number(t&Yi)|0}}function Lh(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}=Dh(t[i],e);[n[i],r[i]]=[o,a]}return[n,r]}const nu=(t,e,s)=>t>>>s,ru=(t,e,s)=>t<<32-s|e>>>s,Hs=(t,e,s)=>t>>>s|e<<32-s,Ks=(t,e,s)=>t<<32-s|e>>>s,Dr=(t,e,s)=>t<<64-s|e>>>s-32,Lr=(t,e,s)=>t>>>s-32|e<<64-s,Xw=(t,e)=>e,Zw=(t,e)=>t,Qw=(t,e,s)=>t<<s|e>>>32-s,eb=(t,e,s)=>e<<s|t>>>32-s,tb=(t,e,s)=>e<<s-32|t>>>64-s,sb=(t,e,s)=>t<<s-32|e>>>64-s;function Jt(t,e,s,n){const r=(e>>>0)+(n>>>0);return{h:t+s+(r/2**32|0)|0,l:r|0}}const el=(t,e,s)=>(t>>>0)+(e>>>0)+(s>>>0),tl=(t,e,s,n)=>e+s+n+(t/2**32|0)|0,nb=(t,e,s,n)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0),rb=(t,e,s,n,r)=>e+s+n+r+(t/2**32|0)|0,ib=(t,e,s,n,r)=>(t>>>0)+(e>>>0)+(s>>>0)+(n>>>0)+(r>>>0),ob=(t,e,s,n,r,i)=>e+s+n+r+i+(t/2**32|0)|0,zn=typeof globalThis=="object"&&"crypto"in globalThis?globalThis.crypto:void 0;function Go(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function xs(t){if(!Number.isSafeInteger(t)||t<0)throw new Error("positive integer expected, got "+t)}function ts(t,...e){if(!Go(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 Yo(t){if(typeof t!="function"||typeof t.create!="function")throw new Error("Hash should be wrapped by utils.createHasher");xs(t.outputLen),xs(t.blockLen)}function rn(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 sl(t,e){ts(t);const s=e.outputLen;if(t.length<s)throw new Error("digestInto() expects output buffer of length at least "+s)}function vi(t){return new Uint32Array(t.buffer,t.byteOffset,Math.floor(t.byteLength/4))}function Wt(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function wa(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}function ss(t,e){return t<<32-e|t>>>e}const Mh=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function Bh(t){return t<<24&4278190080|t<<8&16711680|t>>>8&65280|t>>>24&255}const bs=Mh?t=>t:t=>Bh(t);function ab(t){for(let e=0;e<t.length;e++)t[e]=Bh(t[e]);return t}const zs=Mh?t=>t:ab,jh=typeof Uint8Array.from([]).toHex=="function"&&typeof Uint8Array.fromHex=="function",cb=Array.from({length:256},(t,e)=>e.toString(16).padStart(2,"0"));function ir(t){if(ts(t),jh)return t.toHex();let e="";for(let s=0;s<t.length;s++)e+=cb[t[s]];return e}const ys={_0:48,_9:57,A:65,F:70,a:97,f:102};function iu(t){if(t>=ys._0&&t<=ys._9)return t-ys._0;if(t>=ys.A&&t<=ys.F)return t-(ys.A-10);if(t>=ys.a&&t<=ys.f)return t-(ys.a-10)}function Po(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);if(jh)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=iu(t.charCodeAt(i)),a=iu(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 Fh(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function es(t){return typeof t=="string"&&(t=Fh(t)),ts(t),t}function Gs(...t){let e=0;for(let n=0;n<t.length;n++){const r=t[n];ts(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}class Jo{}function ki(t){const e=n=>t().update(es(n)).digest(),s=t();return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=()=>t(),e}function lb(t){const e=(n,r)=>t(r).update(es(n)).digest(),s=t({});return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=n=>t(n),e}function qn(t=32){if(zn&&typeof zn.getRandomValues=="function")return zn.getRandomValues(new Uint8Array(t));if(zn&&typeof zn.randomBytes=="function")return Uint8Array.from(zn.randomBytes(t));throw new Error("crypto.getRandomValues must be defined")}const ub=BigInt(0),Sr=BigInt(1),db=BigInt(2),hb=BigInt(7),pb=BigInt(256),fb=BigInt(113),qh=[],Wh=[],Hh=[];for(let t=0,e=Sr,s=1,n=0;t<24;t++){[s,n]=[n,(2*s+3*n)%5],qh.push(2*(5*n+s)),Wh.push((t+1)*(t+2)/2%64);let r=ub;for(let i=0;i<7;i++)e=(e<<Sr^(e>>hb)*fb)%pb,e&db&&(r^=Sr<<(Sr<<BigInt(i))-Sr);Hh.push(r)}const Kh=Lh(Hh,!0),gb=Kh[0],mb=Kh[1],ou=(t,e,s)=>s>32?tb(t,e,s):Qw(t,e,s),au=(t,e,s)=>s>32?sb(t,e,s):eb(t,e,s);function yb(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],u=s[c+1],d=ou(l,u,1)^s[a],h=au(l,u,1)^s[a+1];for(let p=0;p<50;p+=10)t[o+p]^=d,t[o+p+1]^=h}let r=t[2],i=t[3];for(let o=0;o<24;o++){const a=Wh[o],c=ou(r,i,a),l=au(r,i,a),u=qh[o];r=t[u],i=t[u+1],t[u]=c,t[u+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]^=gb[n],t[1]^=mb[n]}Wt(s)}let wb=class zh extends Jo{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,xs(n),!(0<e&&e<200))throw new Error("only keccak-f1600 function is supported");this.state=new Uint8Array(200),this.state32=vi(this.state)}clone(){return this._cloneInto()}keccak(){zs(this.state32),yb(this.state32,this.rounds),zs(this.state32),this.posOut=0,this.pos=0}update(e){rn(this),e=es(e),ts(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&&n===r-1&&this.keccak(),e[r-1]^=128,this.keccak()}writeInto(e){rn(this,!1),ts(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 xs(e),this.xofInto(new Uint8Array(e))}digestInto(e){if(sl(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,Wt(this.state)}_cloneInto(e){const{blockLen:s,suffix:n,outputLen:r,rounds:i,enableXOF:o}=this;return e||(e=new zh(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 bb=(t,e,s)=>ki(()=>new wb(e,t,s)),vb=bb(1,136,256/8);function Eb(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 Cb(t,e,s){return t&e^~t&s}function Ab(t,e,s){return t&e^t&s^e&s}let Vh=class extends Jo{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=wa(this.buffer)}update(e){rn(this),e=es(e),ts(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=wa(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){rn(this),sl(e,this),this.finished=!0;const{buffer:s,view:n,blockLen:r,isLE:i}=this;let{pos:o}=this;s[o++]=128,Wt(this.buffer.subarray(o)),this.padOffset>r-o&&(this.process(n,0),o=0);for(let d=o;d<r;d++)s[d]=0;Eb(n,r-8,BigInt(this.length*8),i),this.process(n,0);const a=wa(e),c=this.outputLen;if(c%4)throw new Error("_sha2: outputLen should be aligned to 32bit");const l=c/4,u=this.get();if(l>u.length)throw new Error("_sha2: outputLen bigger than state");for(let d=0;d<l;d++)a.setUint32(4*d,u[d],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 Ms=Uint32Array.from([1779033703,3144134277,1013904242,2773480762,1359893119,2600822924,528734635,1541459225]),tt=Uint32Array.from([3418070365,3238371032,1654270250,914150663,2438529370,812702999,355462360,4144912697,1731405415,4290775857,2394180231,1750603025,3675008525,1694076839,1203062813,3204075428]),st=Uint32Array.from([1779033703,4089235720,3144134277,2227873595,1013904242,4271175723,2773480762,1595750129,1359893119,2917565137,2600822924,725511199,528734635,4215389547,1541459225,327033209]),Ib=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]),Bs=new Uint32Array(64);class _b extends Vh{constructor(e=32){super(64,e,8,!1),this.A=Ms[0]|0,this.B=Ms[1]|0,this.C=Ms[2]|0,this.D=Ms[3]|0,this.E=Ms[4]|0,this.F=Ms[5]|0,this.G=Ms[6]|0,this.H=Ms[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 d=0;d<16;d++,s+=4)Bs[d]=e.getUint32(s,!1);for(let d=16;d<64;d++){const h=Bs[d-15],p=Bs[d-2],g=ss(h,7)^ss(h,18)^h>>>3,f=ss(p,17)^ss(p,19)^p>>>10;Bs[d]=f+Bs[d-7]+g+Bs[d-16]|0}let{A:n,B:r,C:i,D:o,E:a,F:c,G:l,H:u}=this;for(let d=0;d<64;d++){const h=ss(a,6)^ss(a,11)^ss(a,25),p=u+h+Cb(a,c,l)+Ib[d]+Bs[d]|0,g=(ss(n,2)^ss(n,13)^ss(n,22))+Ab(n,r,i)|0;u=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,u=u+this.H|0,this.set(n,r,i,o,a,c,l,u)}roundClean(){Wt(Bs)}destroy(){this.set(0,0,0,0,0,0,0,0),Wt(this.buffer)}}const Gh=Lh(["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))),Sb=Gh[0],Nb=Gh[1],js=new Uint32Array(80),Fs=new Uint32Array(80);let nl=class extends Vh{constructor(e=64){super(128,e,16,!1),this.Ah=st[0]|0,this.Al=st[1]|0,this.Bh=st[2]|0,this.Bl=st[3]|0,this.Ch=st[4]|0,this.Cl=st[5]|0,this.Dh=st[6]|0,this.Dl=st[7]|0,this.Eh=st[8]|0,this.El=st[9]|0,this.Fh=st[10]|0,this.Fl=st[11]|0,this.Gh=st[12]|0,this.Gl=st[13]|0,this.Hh=st[14]|0,this.Hl=st[15]|0}get(){const{Ah:e,Al:s,Bh:n,Bl:r,Ch:i,Cl:o,Dh:a,Dl:c,Eh:l,El:u,Fh:d,Fl:h,Gh:p,Gl:g,Hh:f,Hl:y}=this;return[e,s,n,r,i,o,a,c,l,u,d,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,u,d,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=u|0,this.Fh=d|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 E=0;E<16;E++,s+=4)js[E]=e.getUint32(s),Fs[E]=e.getUint32(s+=4);for(let E=16;E<80;E++){const N=js[E-15]|0,x=Fs[E-15]|0,$=Hs(N,x,1)^Hs(N,x,8)^nu(N,x,7),W=Ks(N,x,1)^Ks(N,x,8)^ru(N,x,7),G=js[E-2]|0,k=Fs[E-2]|0,Q=Hs(G,k,19)^Dr(G,k,61)^nu(G,k,6),se=Ks(G,k,19)^Lr(G,k,61)^ru(G,k,6),T=nb(W,se,Fs[E-7],Fs[E-16]),v=rb(T,$,Q,js[E-7],js[E-16]);js[E]=v|0,Fs[E]=T|0}let{Ah:n,Al:r,Bh:i,Bl:o,Ch:a,Cl:c,Dh:l,Dl:u,Eh:d,El:h,Fh:p,Fl:g,Gh:f,Gl:y,Hh:w,Hl:b}=this;for(let E=0;E<80;E++){const N=Hs(d,h,14)^Hs(d,h,18)^Dr(d,h,41),x=Ks(d,h,14)^Ks(d,h,18)^Lr(d,h,41),$=d&p^~d&f,W=h&g^~h&y,G=ib(b,x,W,Nb[E],Fs[E]),k=ob(G,w,N,$,Sb[E],js[E]),Q=G|0,se=Hs(n,r,28)^Dr(n,r,34)^Dr(n,r,39),T=Ks(n,r,28)^Lr(n,r,34)^Lr(n,r,39),v=n&i^n&a^i&a,C=r&o^r&c^o&c;w=f|0,b=y|0,f=p|0,y=g|0,p=d|0,g=h|0,{h:d,l:h}=Jt(l|0,u|0,k|0,Q|0),l=a|0,u=c|0,a=i|0,c=o|0,i=n|0,o=r|0;const A=el(Q,T,C);n=tl(A,k,se,v),r=A|0}({h:n,l:r}=Jt(this.Ah|0,this.Al|0,n|0,r|0)),{h:i,l:o}=Jt(this.Bh|0,this.Bl|0,i|0,o|0),{h:a,l:c}=Jt(this.Ch|0,this.Cl|0,a|0,c|0),{h:l,l:u}=Jt(this.Dh|0,this.Dl|0,l|0,u|0),{h:d,l:h}=Jt(this.Eh|0,this.El|0,d|0,h|0),{h:p,l:g}=Jt(this.Fh|0,this.Fl|0,p|0,g|0),{h:f,l:y}=Jt(this.Gh|0,this.Gl|0,f|0,y|0),{h:w,l:b}=Jt(this.Hh|0,this.Hl|0,w|0,b|0),this.set(n,r,i,o,a,c,l,u,d,h,p,g,f,y,w,b)}roundClean(){Wt(js,Fs)}destroy(){Wt(this.buffer),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}};class Tb extends nl{constructor(){super(48),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 nt=Uint32Array.from([573645204,4230739756,2673172387,3360449730,596883563,1867755857,2520282905,1497426621,2519219938,2827943907,3193839141,1401305490,721525244,746961066,246885852,2177182882]);class Ob extends nl{constructor(){super(32),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}}const Xo=ki(()=>new _b),Pb=ki(()=>new nl),kb=ki(()=>new Tb),Rb=ki(()=>new Ob),xb=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]),qe=Uint32Array.from([4089235720,1779033703,2227873595,3144134277,4271175723,1013904242,1595750129,2773480762,2917565137,1359893119,725511199,2600822924,4215389547,528734635,327033209,1541459225]),H=new Uint32Array(32);function qs(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=H[2*t],l=H[2*t+1],u=H[2*e],d=H[2*e+1],h=H[2*s],p=H[2*s+1],g=H[2*n],f=H[2*n+1],y=el(c,u,o);l=tl(y,l,d,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:Xw(f,g),Dl:Zw(f)},{h:p,l:h}=Jt(p,h,f,g),{Bh:d,Bl:u}={Bh:d^p,Bl:u^h},{Bh:d,Bl:u}={Bh:Hs(d,u,24),Bl:Ks(d,u,24)},H[2*t]=c,H[2*t+1]=l,H[2*e]=u,H[2*e+1]=d,H[2*s]=h,H[2*s+1]=p,H[2*n]=g,H[2*n+1]=f}function Ws(t,e,s,n,r,i){const o=r[i],a=r[i+1];let c=H[2*t],l=H[2*t+1],u=H[2*e],d=H[2*e+1],h=H[2*s],p=H[2*s+1],g=H[2*n],f=H[2*n+1],y=el(c,u,o);l=tl(y,l,d,a),c=y|0,{Dh:f,Dl:g}={Dh:f^l,Dl:g^c},{Dh:f,Dl:g}={Dh:Hs(f,g,16),Dl:Ks(f,g,16)},{h:p,l:h}=Jt(p,h,f,g),{Bh:d,Bl:u}={Bh:d^p,Bl:u^h},{Bh:d,Bl:u}={Bh:Dr(d,u,63),Bl:Lr(d,u,63)},H[2*t]=c,H[2*t+1]=l,H[2*e]=u,H[2*e+1]=d,H[2*s]=h,H[2*s+1]=p,H[2*n]=g,H[2*n+1]=f}function $b(t,e={},s,n,r){if(xs(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 Ub extends Jo{constructor(e,s){super(),this.finished=!1,this.destroyed=!1,this.length=0,this.pos=0,xs(e),xs(s),this.blockLen=e,this.outputLen=s,this.buffer=new Uint8Array(e),this.buffer32=vi(this.buffer)}update(e){rn(this),e=es(e),ts(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&&(zs(r),this.compress(r,0,!1),zs(r),this.pos=0);const l=Math.min(s-this.pos,i-c),u=o+c;if(l===s&&!(u%4)&&c+l<i){const d=new Uint32Array(a,u,Math.floor((i-c)/4));zs(d);for(let h=0;c+s<i;h+=r.length,c+=s)this.length+=s,this.compress(d,h,!1);zs(d);continue}n.set(e.subarray(c,c+l),this.pos),this.pos+=l,this.length+=l,c+=l}return this}digestInto(e){rn(this),sl(e,this);const{pos:s,buffer32:n}=this;this.finished=!0,Wt(this.buffer.subarray(s)),zs(n),this.compress(n,0,!0),zs(n);const r=vi(e);this.get().forEach((i,o)=>r[o]=bs(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 Db extends Ub{constructor(e={}){const s=e.dkLen===void 0?64:e.dkLen;super(128,s),this.v0l=qe[0]|0,this.v0h=qe[1]|0,this.v1l=qe[2]|0,this.v1h=qe[3]|0,this.v2l=qe[4]|0,this.v2h=qe[5]|0,this.v3l=qe[6]|0,this.v3h=qe[7]|0,this.v4l=qe[8]|0,this.v4h=qe[9]|0,this.v5l=qe[10]|0,this.v5h=qe[11]|0,this.v6l=qe[12]|0,this.v6h=qe[13]|0,this.v7l=qe[14]|0,this.v7h=qe[15]|0,$b(s,e,64,16,16);let{key:n,personalization:r,salt:i}=e,o=0;if(n!==void 0&&(n=es(n),o=n.length),this.v0l^=this.outputLen|o<<8|65536|1<<24,i!==void 0){i=es(i);const a=vi(i);this.v4l^=bs(a[0]),this.v4h^=bs(a[1]),this.v5l^=bs(a[2]),this.v5h^=bs(a[3])}if(r!==void 0){r=es(r);const a=vi(r);this.v6l^=bs(a[0]),this.v6h^=bs(a[1]),this.v7l^=bs(a[2]),this.v7h^=bs(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:u,v5l:d,v5h:h,v6l:p,v6h:g,v7l:f,v7h:y}=this;return[e,s,n,r,i,o,a,c,l,u,d,h,p,g,f,y]}set(e,s,n,r,i,o,a,c,l,u,d,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=u|0,this.v5l=d|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)=>H[l]=c),H.set(qe,16);let{h:r,l:i}=Dh(BigInt(this.length));H[24]=qe[8]^i,H[25]=qe[9]^r,n&&(H[28]=~H[28],H[29]=~H[29]);let o=0;const a=xb;for(let c=0;c<12;c++)qs(0,4,8,12,e,s+2*a[o++]),Ws(0,4,8,12,e,s+2*a[o++]),qs(1,5,9,13,e,s+2*a[o++]),Ws(1,5,9,13,e,s+2*a[o++]),qs(2,6,10,14,e,s+2*a[o++]),Ws(2,6,10,14,e,s+2*a[o++]),qs(3,7,11,15,e,s+2*a[o++]),Ws(3,7,11,15,e,s+2*a[o++]),qs(0,5,10,15,e,s+2*a[o++]),Ws(0,5,10,15,e,s+2*a[o++]),qs(1,6,11,12,e,s+2*a[o++]),Ws(1,6,11,12,e,s+2*a[o++]),qs(2,7,8,13,e,s+2*a[o++]),Ws(2,7,8,13,e,s+2*a[o++]),qs(3,4,9,14,e,s+2*a[o++]),Ws(3,4,9,14,e,s+2*a[o++]);this.v0l^=H[0]^H[16],this.v0h^=H[1]^H[17],this.v1l^=H[2]^H[18],this.v1h^=H[3]^H[19],this.v2l^=H[4]^H[20],this.v2h^=H[5]^H[21],this.v3l^=H[6]^H[22],this.v3h^=H[7]^H[23],this.v4l^=H[8]^H[24],this.v4h^=H[9]^H[25],this.v5l^=H[10]^H[26],this.v5h^=H[11]^H[27],this.v6l^=H[12]^H[28],this.v6h^=H[13]^H[29],this.v7l^=H[14]^H[30],this.v7h^=H[15]^H[31],Wt(H)}destroy(){this.destroyed=!0,Wt(this.buffer32),this.set(0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0)}}const Lb=lb(t=>new Db(t)),Mb="https://rpc.walletconnect.org/v1";function Yh(t){const e=`Ethereum Signed Message:
|
|
11
11
|
${t.length}`,s=new TextEncoder().encode(e+t);return"0x"+Buffer.from(vb(s)).toString("hex")}async function Bb(t,e,s,n,r,i){switch(s.t){case"eip191":return await jb(t,e,s.s);case"eip1271":return await Fb(t,e,s.s,n,r,i);default:throw new Error(`verifySignature failed: Attempted to verify CacaoSignature with unknown type: ${s.t}`)}}function jb(t,e,s){const n=jf(s);return Ff({payload:Yh(e),signature:n}).toLowerCase()===t.toLowerCase()}async function Fb(t,e,s,n,r,i){const o=Os(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),u=(l.length/2).toString(16).padStart(64,"0"),d=(e.startsWith("0x")?e:Yh(e)).substring(2),h=a+d+c+u+l,p=await fetch(`${i||Mb}/?chainId=${n}&projectId=${r}`,{headers:{"Content-Type":"application/json"},method:"POST",body:JSON.stringify({id:qb(),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 qb(){return Date.now()+Math.floor(Math.random()*1e3)}function Wb(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=Buffer.from(t,"base64").slice(1,65);return br.encode(i)}function Hb(t){const e=new Uint8Array(Buffer.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=Lb(n,{dkLen:32});return br.encode(r)}function cu(t){const e=new Uint8Array(Xo(Kb(t)));return br.encode(e)}function Kb(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 lu(t){const e=Buffer.from(t,"base64"),s=Df(e).txn;if(!s)throw new Error("Invalid signed transaction: missing 'txn' field");const n=Lf(s),r=Buffer.from("TX"),i=Buffer.concat([r,Buffer.from(n)]),o=Rb(i);return Mf.encode(o).replace(/=+$/,"")}function ba(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)),Buffer.from(e)}function zb(t){const e=Buffer.from(t.signed.bodyBytes,"base64"),s=Buffer.from(t.signed.authInfoBytes,"base64"),n=Buffer.from(t.signature.signature,"base64"),r=[];r.push(Buffer.from([10])),r.push(ba(e.length)),r.push(e),r.push(Buffer.from([18])),r.push(ba(s.length)),r.push(s),r.push(Buffer.from([26])),r.push(ba(n.length)),r.push(n);const i=Buffer.concat(r),o=Xo(i);return Buffer.from(o).toString("hex").toUpperCase()}function Vb(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 Gb=Object.defineProperty,Yb=Object.defineProperties,Jb=Object.getOwnPropertyDescriptors,uu=Object.getOwnPropertySymbols,Xb=Object.prototype.hasOwnProperty,Zb=Object.prototype.propertyIsEnumerable,du=(t,e,s)=>e in t?Gb(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Qb=(t,e)=>{for(var s in e||(e={}))Xb.call(e,s)&&du(t,s,e[s]);if(uu)for(var s of uu(e))Zb.call(e,s)&&du(t,s,e[s]);return t},ev=(t,e)=>Yb(t,Jb(e));const tv="did:pkh:",rl=t=>t==null?void 0:t.split(":"),sv=t=>{const e=t&&rl(t);if(e)return t.includes(tv)?e[3]:e[1]},uc=t=>{const e=t&&rl(t);if(e)return e[2]+":"+e[3]},ko=t=>{const e=t&&rl(t);if(e)return e.pop()};async function hu(t){const{cacao:e,projectId:s}=t,{s:n,p:r}=e,i=Jh(r,r.iss),o=ko(r.iss);return await Bb(o,i,n,uc(r.iss),s)}const Jh=(t,e)=>{const s=`${t.domain} wants you to sign in with your Ethereum account:`,n=ko(e);if(!t.aud&&!t.uri)throw new Error("Either `aud` or `uri` is required to construct the message");let r=t.statement||void 0;const i=`URI: ${t.aud||t.uri}`,o=`Version: ${t.version}`,a=`Chain ID: ${sv(e)}`,c=`Nonce: ${t.nonce}`,l=`Issued At: ${t.iat}`,u=t.exp?`Expiration Time: ${t.exp}`:void 0,d=t.nbf?`Not Before: ${t.nbf}`:void 0,h=t.requestId?`Request ID: ${t.requestId}`:void 0,p=t.resources?`Resources:${t.resources.map(f=>`
|
|
12
12
|
- ${f}`).join("")}`:void 0,g=fo(t.resources);if(g){const f=Ei(g);r=dv(r,f)}return[s,n,"",r,"",i,o,a,c,l,u,d,h,p].filter(f=>f!=null).join(`
|
|
13
13
|
`)};function nv(t){return Buffer.from(JSON.stringify(t)).toString("base64")}function rv(t){return JSON.parse(Buffer.from(t,"base64").toString("utf-8"))}function Un(t){if(!t)throw new Error("No recap provided, value is undefined");if(!t.att)throw new Error("No `att` property found");const e=Object.keys(t.att);if(!(e!=null&&e.length))throw new Error("No resources found in `att` property");e.forEach(s=>{const n=t.att[s];if(Array.isArray(n))throw new Error(`Resource must be an object: ${s}`);if(typeof n!="object")throw new Error(`Resource must be an object: ${s}`);if(!Object.keys(n).length)throw new Error(`Resource object is empty: ${s}`);Object.keys(n).forEach(r=>{const i=n[r];if(!Array.isArray(i))throw new Error(`Ability limits ${r} must be an array of objects, found: ${i}`);if(!i.length)throw new Error(`Value of ${r} is empty array, must be an array with objects`);i.forEach(o=>{if(typeof o!="object")throw new Error(`Ability limits (${r}) must be an array of objects, found: ${o}`)})})})}function iv(t,e,s,n={}){return s==null||s.sort((r,i)=>r.localeCompare(i)),{att:{[t]:ov(e,s,n)}}}function ov(t,e,s={}){e=e==null?void 0:e.sort((r,i)=>r.localeCompare(i));const n=e.map(r=>({[`${t}/${r}`]:[s]}));return Object.assign({},...n)}function Xh(t){return Un(t),`urn:recap:${nv(t).replace(/=/g,"")}`}function Ei(t){const e=rv(t.replace("urn:recap:",""));return Un(e),e}function av(t,e,s){const n=iv(t,e,s);return Xh(n)}function cv(t){return t&&t.includes("urn:recap:")}function lv(t,e){const s=Ei(t),n=Ei(e),r=uv(s,n);return Xh(r)}function uv(t,e){Un(t),Un(e);const s=Object.keys(t.att).concat(Object.keys(e.att)).sort((r,i)=>r.localeCompare(i)),n={att:{}};return s.forEach(r=>{var i,o;Object.keys(((i=t.att)==null?void 0:i[r])||{}).concat(Object.keys(((o=e.att)==null?void 0:o[r])||{})).sort((a,c)=>a.localeCompare(c)).forEach(a=>{var c,l;n.att[r]=ev(Qb({},n.att[r]),{[a]:((c=t.att[r])==null?void 0:c[a])||((l=e.att[r])==null?void 0:l[a])})})}),n}function dv(t="",e){Un(e);const s="I further authorize the stated URI to perform the following actions on my behalf: ";if(t.includes(s))return t;const n=[];let r=0;Object.keys(e.att).forEach(a=>{const c=Object.keys(e.att[a]).map(d=>({ability:d.split("/")[0],action:d.split("/")[1]}));c.sort((d,h)=>d.action.localeCompare(h.action));const l={};c.forEach(d=>{l[d.ability]||(l[d.ability]=[]),l[d.ability].push(d.action)});const u=Object.keys(l).map(d=>(r++,`(${r}) '${d}': '${l[d].join("', '")}' for '${a}'.`));n.push(u.join(", ").replace(".,","."))});const i=n.join(" "),o=`${s}${i}`;return`${t?t+" ":""}${o}`}function pu(t){var e;const s=Ei(t);Un(s);const n=(e=s.att)==null?void 0:e.eip155;return n?Object.keys(n).map(r=>r.split("/")[1]):[]}function fu(t){const e=Ei(t);Un(e);const s=[];return Object.values(e.att).forEach(n=>{Object.values(n).forEach(r=>{var i;(i=r==null?void 0:r[0])!=null&&i.chains&&s.push(r[0].chains)})}),[...new Set(s.flat())]}function fo(t){if(!t)return;const e=t==null?void 0:t[t.length-1];return cv(e)?e:void 0}/*! noble-ciphers - MIT License (c) 2023 Paul Miller (paulmillr.com) */function Zh(t){return t instanceof Uint8Array||ArrayBuffer.isView(t)&&t.constructor.name==="Uint8Array"}function dc(t){if(typeof t!="boolean")throw new Error(`boolean expected, not ${t}`)}function va(t){if(!Number.isSafeInteger(t)||t<0)throw new Error("positive integer expected, got "+t)}function mt(t,...e){if(!Zh(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 gu(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 hv(t,e){mt(t);const s=e.outputLen;if(t.length<s)throw new Error("digestInto() expects output buffer of length at least "+s)}function tn(t){return new Uint32Array(t.buffer,t.byteOffset,Math.floor(t.byteLength/4))}function fr(...t){for(let e=0;e<t.length;e++)t[e].fill(0)}function pv(t){return new DataView(t.buffer,t.byteOffset,t.byteLength)}const fv=new Uint8Array(new Uint32Array([287454020]).buffer)[0]===68;function gv(t){if(typeof t!="string")throw new Error("string expected");return new Uint8Array(new TextEncoder().encode(t))}function hc(t){if(typeof t=="string")t=gv(t);else if(Zh(t))t=pc(t);else throw new Error("Uint8Array expected, got "+typeof t);return t}function mv(t,e){if(e==null||typeof e!="object")throw new Error("options must be defined");return Object.assign(t,e)}function yv(t,e){if(t.length!==e.length)return!1;let s=0;for(let n=0;n<t.length;n++)s|=t[n]^e[n];return s===0}const wv=(t,e)=>{function s(n,...r){if(mt(n),!fv)throw new Error("Non little-endian hardware is not yet supported");if(t.nonceLength!==void 0){const l=r[0];if(!l)throw new Error("nonce / iv required");t.varSizeNonce?mt(l):mt(l,t.nonceLength)}const i=t.tagLength;i&&r[1]!==void 0&&mt(r[1]);const o=e(n,...r),a=(l,u)=>{if(u!==void 0){if(l!==2)throw new Error("cipher output not supported");mt(u)}};let c=!1;return{encrypt(l,u){if(c)throw new Error("cannot encrypt() twice with same key + nonce");return c=!0,mt(l),a(o.encrypt.length,u),o.encrypt(l,u)},decrypt(l,u){if(mt(l),i&&l.length<i)throw new Error("invalid ciphertext length: smaller than tagLength="+i);return a(o.decrypt.length,u),o.decrypt(l,u)}}}return Object.assign(s,t),s};function mu(t,e,s=!0){if(e===void 0)return new Uint8Array(t);if(e.length!==t)throw new Error("invalid output length, expected "+t+", got: "+e.length);if(s&&!vv(e))throw new Error("invalid output, must be aligned");return e}function yu(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);t.setUint32(e+4,o,n),t.setUint32(e+0,a,n)}function bv(t,e,s){dc(s);const n=new Uint8Array(16),r=pv(n);return yu(r,0,BigInt(e),s),yu(r,8,BigInt(t),s),n}function vv(t){return t.byteOffset%4===0}function pc(t){return Uint8Array.from(t)}const Qh=t=>Uint8Array.from(t.split("").map(e=>e.charCodeAt(0))),Ev=Qh("expand 16-byte k"),Cv=Qh("expand 32-byte k"),Av=tn(Ev),Iv=tn(Cv);function ve(t,e){return t<<e|t>>>32-e}function fc(t){return t.byteOffset%4===0}const Ji=64,_v=16,ep=2**32-1,wu=new Uint32Array;function Sv(t,e,s,n,r,i,o,a){const c=r.length,l=new Uint8Array(Ji),u=tn(l),d=fc(r)&&fc(i),h=d?tn(r):wu,p=d?tn(i):wu;for(let g=0;g<c;o++){if(t(e,s,n,u,o,a),o>=ep)throw new Error("arx: counter overflow");const f=Math.min(Ji,c-g);if(d&&f===Ji){const y=g/4;if(g%4!==0)throw new Error("arx: invalid block position");for(let w=0,b;w<_v;w++)b=y+w,p[b]=h[b]^u[w];g+=Ji;continue}for(let y=0,w;y<f;y++)w=g+y,i[w]=r[w]^l[y];g+=f}}function Nv(t,e){const{allowShortKeys:s,extendNonceFn:n,counterLength:r,counterRight:i,rounds:o}=mv({allowShortKeys:!1,counterLength:8,counterRight:!1,rounds:20},e);if(typeof t!="function")throw new Error("core must be a function");return va(r),va(o),dc(i),dc(s),(a,c,l,u,d=0)=>{mt(a),mt(c),mt(l);const h=l.length;if(u===void 0&&(u=new Uint8Array(h)),mt(u),va(d),d<0||d>=ep)throw new Error("arx: counter overflow");if(u.length<h)throw new Error(`arx: output (${u.length}) is shorter than data (${h})`);const p=[];let g=a.length,f,y;if(g===32)p.push(f=pc(a)),y=Iv;else if(g===16&&s)f=new Uint8Array(32),f.set(a),f.set(a,16),y=Av,p.push(f);else throw new Error(`arx: invalid 32-byte key, got length=${g}`);fc(c)||p.push(c=pc(c));const w=tn(f);if(n){if(c.length!==24)throw new Error("arx: extended nonce must be 24 bytes");n(y,w,tn(c.subarray(0,16)),w),c=c.subarray(16)}const b=16-r;if(b!==c.length)throw new Error(`arx: nonce must be ${b} or 16 bytes`);if(b!==12){const N=new Uint8Array(12);N.set(c,i?0:12-c.length),c=N,p.push(c)}const E=tn(c);return Sv(t,y,w,E,l,u,d,o),fr(...p),u}}const Ge=(t,e)=>t[e++]&255|(t[e++]&255)<<8;class Tv{constructor(e){this.blockLen=16,this.outputLen=16,this.buffer=new Uint8Array(16),this.r=new Uint16Array(10),this.h=new Uint16Array(10),this.pad=new Uint16Array(8),this.pos=0,this.finished=!1,e=hc(e),mt(e,32);const s=Ge(e,0),n=Ge(e,2),r=Ge(e,4),i=Ge(e,6),o=Ge(e,8),a=Ge(e,10),c=Ge(e,12),l=Ge(e,14);this.r[0]=s&8191,this.r[1]=(s>>>13|n<<3)&8191,this.r[2]=(n>>>10|r<<6)&7939,this.r[3]=(r>>>7|i<<9)&8191,this.r[4]=(i>>>4|o<<12)&255,this.r[5]=o>>>1&8190,this.r[6]=(o>>>14|a<<2)&8191,this.r[7]=(a>>>11|c<<5)&8065,this.r[8]=(c>>>8|l<<8)&8191,this.r[9]=l>>>5&127;for(let u=0;u<8;u++)this.pad[u]=Ge(e,16+2*u)}process(e,s,n=!1){const r=n?0:2048,{h:i,r:o}=this,a=o[0],c=o[1],l=o[2],u=o[3],d=o[4],h=o[5],p=o[6],g=o[7],f=o[8],y=o[9],w=Ge(e,s+0),b=Ge(e,s+2),E=Ge(e,s+4),N=Ge(e,s+6),x=Ge(e,s+8),$=Ge(e,s+10),W=Ge(e,s+12),G=Ge(e,s+14);let k=i[0]+(w&8191),Q=i[1]+((w>>>13|b<<3)&8191),se=i[2]+((b>>>10|E<<6)&8191),T=i[3]+((E>>>7|N<<9)&8191),v=i[4]+((N>>>4|x<<12)&8191),C=i[5]+(x>>>1&8191),A=i[6]+((x>>>14|$<<2)&8191),S=i[7]+(($>>>11|W<<5)&8191),D=i[8]+((W>>>8|G<<8)&8191),B=i[9]+(G>>>5|r),I=0,R=I+k*a+Q*(5*y)+se*(5*f)+T*(5*g)+v*(5*p);I=R>>>13,R&=8191,R+=C*(5*h)+A*(5*d)+S*(5*u)+D*(5*l)+B*(5*c),I+=R>>>13,R&=8191;let z=I+k*c+Q*a+se*(5*y)+T*(5*f)+v*(5*g);I=z>>>13,z&=8191,z+=C*(5*p)+A*(5*h)+S*(5*d)+D*(5*u)+B*(5*l),I+=z>>>13,z&=8191;let K=I+k*l+Q*c+se*a+T*(5*y)+v*(5*f);I=K>>>13,K&=8191,K+=C*(5*g)+A*(5*p)+S*(5*h)+D*(5*d)+B*(5*u),I+=K>>>13,K&=8191;let he=I+k*u+Q*l+se*c+T*a+v*(5*y);I=he>>>13,he&=8191,he+=C*(5*f)+A*(5*g)+S*(5*p)+D*(5*h)+B*(5*d),I+=he>>>13,he&=8191;let ie=I+k*d+Q*u+se*l+T*c+v*a;I=ie>>>13,ie&=8191,ie+=C*(5*y)+A*(5*f)+S*(5*g)+D*(5*p)+B*(5*h),I+=ie>>>13,ie&=8191;let ne=I+k*h+Q*d+se*u+T*l+v*c;I=ne>>>13,ne&=8191,ne+=C*a+A*(5*y)+S*(5*f)+D*(5*g)+B*(5*p),I+=ne>>>13,ne&=8191;let ue=I+k*p+Q*h+se*d+T*u+v*l;I=ue>>>13,ue&=8191,ue+=C*c+A*a+S*(5*y)+D*(5*f)+B*(5*g),I+=ue>>>13,ue&=8191;let ce=I+k*g+Q*p+se*h+T*d+v*u;I=ce>>>13,ce&=8191,ce+=C*l+A*c+S*a+D*(5*y)+B*(5*f),I+=ce>>>13,ce&=8191;let Oe=I+k*f+Q*g+se*p+T*h+v*d;I=Oe>>>13,Oe&=8191,Oe+=C*u+A*l+S*c+D*a+B*(5*y),I+=Oe>>>13,Oe&=8191;let le=I+k*y+Q*f+se*g+T*p+v*h;I=le>>>13,le&=8191,le+=C*d+A*u+S*l+D*c+B*a,I+=le>>>13,le&=8191,I=(I<<2)+I|0,I=I+R|0,R=I&8191,I=I>>>13,z+=I,i[0]=R,i[1]=z,i[2]=K,i[3]=he,i[4]=ie,i[5]=ne,i[6]=ue,i[7]=ce,i[8]=Oe,i[9]=le}finalize(){const{h:e,pad:s}=this,n=new Uint16Array(10);let r=e[1]>>>13;e[1]&=8191;for(let a=2;a<10;a++)e[a]+=r,r=e[a]>>>13,e[a]&=8191;e[0]+=r*5,r=e[0]>>>13,e[0]&=8191,e[1]+=r,r=e[1]>>>13,e[1]&=8191,e[2]+=r,n[0]=e[0]+5,r=n[0]>>>13,n[0]&=8191;for(let a=1;a<10;a++)n[a]=e[a]+r,r=n[a]>>>13,n[a]&=8191;n[9]-=8192;let i=(r^1)-1;for(let a=0;a<10;a++)n[a]&=i;i=~i;for(let a=0;a<10;a++)e[a]=e[a]&i|n[a];e[0]=(e[0]|e[1]<<13)&65535,e[1]=(e[1]>>>3|e[2]<<10)&65535,e[2]=(e[2]>>>6|e[3]<<7)&65535,e[3]=(e[3]>>>9|e[4]<<4)&65535,e[4]=(e[4]>>>12|e[5]<<1|e[6]<<14)&65535,e[5]=(e[6]>>>2|e[7]<<11)&65535,e[6]=(e[7]>>>5|e[8]<<8)&65535,e[7]=(e[8]>>>8|e[9]<<5)&65535;let o=e[0]+s[0];e[0]=o&65535;for(let a=1;a<8;a++)o=(e[a]+s[a]|0)+(o>>>16)|0,e[a]=o&65535;fr(n)}update(e){gu(this),e=hc(e),mt(e);const{buffer:s,blockLen:n}=this,r=e.length;for(let i=0;i<r;){const o=Math.min(n-this.pos,r-i);if(o===n){for(;n<=r-i;i+=n)this.process(e,i);continue}s.set(e.subarray(i,i+o),this.pos),this.pos+=o,i+=o,this.pos===n&&(this.process(s,0,!1),this.pos=0)}return this}destroy(){fr(this.h,this.r,this.buffer,this.pad)}digestInto(e){gu(this),hv(e,this),this.finished=!0;const{buffer:s,h:n}=this;let{pos:r}=this;if(r){for(s[r++]=1;r<16;r++)s[r]=0;this.process(s,0,!0)}this.finalize();let i=0;for(let o=0;o<8;o++)e[i++]=n[o]>>>0,e[i++]=n[o]>>>8;return e}digest(){const{buffer:e,outputLen:s}=this;this.digestInto(e);const n=e.slice(0,s);return this.destroy(),n}}function Ov(t){const e=(n,r)=>t(r).update(hc(n)).digest(),s=t(new Uint8Array(32));return e.outputLen=s.outputLen,e.blockLen=s.blockLen,e.create=n=>t(n),e}const Pv=Ov(t=>new Tv(t));function kv(t,e,s,n,r,i=20){let o=t[0],a=t[1],c=t[2],l=t[3],u=e[0],d=e[1],h=e[2],p=e[3],g=e[4],f=e[5],y=e[6],w=e[7],b=r,E=s[0],N=s[1],x=s[2],$=o,W=a,G=c,k=l,Q=u,se=d,T=h,v=p,C=g,A=f,S=y,D=w,B=b,I=E,R=N,z=x;for(let he=0;he<i;he+=2)$=$+Q|0,B=ve(B^$,16),C=C+B|0,Q=ve(Q^C,12),$=$+Q|0,B=ve(B^$,8),C=C+B|0,Q=ve(Q^C,7),W=W+se|0,I=ve(I^W,16),A=A+I|0,se=ve(se^A,12),W=W+se|0,I=ve(I^W,8),A=A+I|0,se=ve(se^A,7),G=G+T|0,R=ve(R^G,16),S=S+R|0,T=ve(T^S,12),G=G+T|0,R=ve(R^G,8),S=S+R|0,T=ve(T^S,7),k=k+v|0,z=ve(z^k,16),D=D+z|0,v=ve(v^D,12),k=k+v|0,z=ve(z^k,8),D=D+z|0,v=ve(v^D,7),$=$+se|0,z=ve(z^$,16),S=S+z|0,se=ve(se^S,12),$=$+se|0,z=ve(z^$,8),S=S+z|0,se=ve(se^S,7),W=W+T|0,B=ve(B^W,16),D=D+B|0,T=ve(T^D,12),W=W+T|0,B=ve(B^W,8),D=D+B|0,T=ve(T^D,7),G=G+v|0,I=ve(I^G,16),C=C+I|0,v=ve(v^C,12),G=G+v|0,I=ve(I^G,8),C=C+I|0,v=ve(v^C,7),k=k+Q|0,R=ve(R^k,16),A=A+R|0,Q=ve(Q^A,12),k=k+Q|0,R=ve(R^k,8),A=A+R|0,Q=ve(Q^A,7);let K=0;n[K++]=o+$|0,n[K++]=a+W|0,n[K++]=c+G|0,n[K++]=l+k|0,n[K++]=u+Q|0,n[K++]=d+se|0,n[K++]=h+T|0,n[K++]=p+v|0,n[K++]=g+C|0,n[K++]=f+A|0,n[K++]=y+S|0,n[K++]=w+D|0,n[K++]=b+B|0,n[K++]=E+I|0,n[K++]=N+R|0,n[K++]=x+z|0}const Rv=Nv(kv,{counterRight:!1,counterLength:4,allowShortKeys:!1}),xv=new Uint8Array(16),bu=(t,e)=>{t.update(e);const s=e.length%16;s&&t.update(xv.subarray(s))},$v=new Uint8Array(32);function vu(t,e,s,n,r){const i=t(e,s,$v),o=Pv.create(i);r&&bu(o,r),bu(o,n);const a=bv(n.length,r?r.length:0,!0);o.update(a);const c=o.digest();return fr(i,a),c}const Uv=t=>(e,s,n)=>({encrypt(r,i){const o=r.length;i=mu(o+16,i,!1),i.set(r);const a=i.subarray(0,-16);t(e,s,a,a,1);const c=vu(t,e,s,a,n);return i.set(c,o),fr(c),i},decrypt(r,i){i=mu(r.length-16,i,!1);const o=r.subarray(0,-16),a=r.subarray(-16),c=vu(t,e,s,o,n);if(!yv(a,c))throw new Error("invalid tag");return i.set(r.subarray(0,-16)),t(e,s,i,i,1),fr(c),i}}),tp=wv({blockSize:64,nonceLength:12,tagLength:16},Uv(Rv));let sp=class extends Jo{constructor(e,s){super(),this.finished=!1,this.destroyed=!1,Yo(e);const n=es(s);if(this.iHash=e.create(),typeof this.iHash.update!="function")throw new Error("Expected instance of class which extends utils.Hash");this.blockLen=this.iHash.blockLen,this.outputLen=this.iHash.outputLen;const r=this.blockLen,i=new Uint8Array(r);i.set(n.length>r?e.create().update(n).digest():n);for(let o=0;o<i.length;o++)i[o]^=54;this.iHash.update(i),this.oHash=e.create();for(let o=0;o<i.length;o++)i[o]^=106;this.oHash.update(i),Wt(i)}update(e){return rn(this),this.iHash.update(e),this}digestInto(e){rn(this),ts(e,this.outputLen),this.finished=!0,this.iHash.digestInto(e),this.oHash.update(e),this.oHash.digestInto(e),this.destroy()}digest(){const e=new Uint8Array(this.oHash.outputLen);return this.digestInto(e),e}_cloneInto(e){e||(e=Object.create(Object.getPrototypeOf(this),{}));const{oHash:s,iHash:n,finished:r,destroyed:i,blockLen:o,outputLen:a}=this;return e=e,e.finished=r,e.destroyed=i,e.blockLen=o,e.outputLen=a,e.oHash=s._cloneInto(e.oHash),e.iHash=n._cloneInto(e.iHash),e}clone(){return this._cloneInto()}destroy(){this.destroyed=!0,this.oHash.destroy(),this.iHash.destroy()}};const Zo=(t,e,s)=>new sp(t,e).update(s).digest();Zo.create=(t,e)=>new sp(t,e);function Dv(t,e,s){return Yo(t),s===void 0&&(s=new Uint8Array(t.outputLen)),Zo(t,es(s),es(e))}const Ea=Uint8Array.from([0]),Eu=Uint8Array.of();function Lv(t,e,s,n=32){Yo(t),xs(n);const r=t.outputLen;if(n>255*r)throw new Error("Length should be <= 255*HashLen");const i=Math.ceil(n/r);s===void 0&&(s=Eu);const o=new Uint8Array(i*r),a=Zo.create(t,e),c=a._cloneInto(),l=new Uint8Array(a.outputLen);for(let u=0;u<i;u++)Ea[0]=u+1,c.update(u===0?Eu:l).update(s).update(Ea).digestInto(l),o.set(l,r*u),a._cloneInto(c);return a.destroy(),c.destroy(),Wt(l,Ea),o.slice(0,n)}const Mv=(t,e,s,n,r)=>Lv(t,Dv(t,e,s),n,r),Qo=Xo,il=BigInt(0),gc=BigInt(1);function Ro(t,e=""){if(typeof t!="boolean"){const s=e&&`"${e}"`;throw new Error(s+"expected boolean, got type="+typeof t)}return t}function In(t,e,s=""){const n=Go(t),r=t==null?void 0:t.length,i=e!==void 0;if(!n||i&&r!==e){const o=s&&`"${s}" `,a=i?` of length ${e}`:"",c=n?`length=${r}`:`type=${typeof t}`;throw new Error(o+"expected Uint8Array"+a+", got "+c)}return t}function Xi(t){const e=t.toString(16);return e.length&1?"0"+e:e}function np(t){if(typeof t!="string")throw new Error("hex string expected, got "+typeof t);return t===""?il:BigInt("0x"+t)}function ea(t){return np(ir(t))}function xo(t){return ts(t),np(ir(Uint8Array.from(t).reverse()))}function ol(t,e){return Po(t.toString(16).padStart(e*2,"0"))}function al(t,e){return ol(t,e).reverse()}function ot(t,e,s){let n;if(typeof e=="string")try{n=Po(e)}catch(i){throw new Error(t+" must be hex string or Uint8Array, cause: "+i)}else if(Go(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}const Ca=t=>typeof t=="bigint"&&il<=t;function Bv(t,e,s){return Ca(t)&&Ca(e)&&Ca(s)&&e<=t&&t<s}function mc(t,e,s,n){if(!Bv(e,s,n))throw new Error("expected valid "+t+": "+s+" <= n < "+n+", got "+e)}function rp(t){let e;for(e=0;t>il;t>>=gc,e+=1);return e}const Ri=t=>(gc<<BigInt(t))-gc;function jv(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");const n=h=>new Uint8Array(h),r=h=>Uint8Array.of(h);let i=n(t),o=n(t),a=0;const c=()=>{i.fill(1),o.fill(0),a=0},l=(...h)=>s(o,i,...h),u=(h=n(0))=>{o=l(r(0),h),i=l(),h.length!==0&&(o=l(r(1),h),i=l())},d=()=>{if(a++>=1e3)throw new Error("drbg: tried 1000 values");let h=0;const p=[];for(;h<e;){i=l();const g=i.slice();p.push(g),h+=i.length}return Gs(...p)};return(h,p)=>{c(),u(h);let g;for(;!(g=p(d()));)u();return c(),g}}function ta(t,e,s={}){if(!t||typeof t!="object")throw new Error("expected valid options object");function n(r,i,o){const a=t[r];if(o&&a===void 0)return;const c=typeof a;if(c!==i||a===null)throw new Error(`param "${r}" is invalid: expected ${i}, got ${c}`)}Object.entries(e).forEach(([r,i])=>n(r,i,!1)),Object.entries(s).forEach(([r,i])=>n(r,i,!0))}function Cu(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}}const wt=BigInt(0),ct=BigInt(1),_n=BigInt(2),ip=BigInt(3),op=BigInt(4),ap=BigInt(5),Fv=BigInt(7),cp=BigInt(8),qv=BigInt(9),lp=BigInt(16);function Nt(t,e){const s=t%e;return s>=wt?s:e+s}function Yt(t,e,s){let n=t;for(;e-- >wt;)n*=n,n%=s;return n}function Au(t,e){if(t===wt)throw new Error("invert: expected non-zero number");if(e<=wt)throw new Error("invert: expected positive modulus, got "+e);let s=Nt(t,e),n=e,r=wt,i=ct;for(;s!==wt;){const o=n/s,a=n%s,c=r-i*o;n=s,s=a,r=i,i=c}if(n!==ct)throw new Error("invert: does not exist");return Nt(r,e)}function cl(t,e,s){if(!t.eql(t.sqr(e),s))throw new Error("Cannot find square root")}function up(t,e){const s=(t.ORDER+ct)/op,n=t.pow(e,s);return cl(t,n,e),n}function Wv(t,e){const s=(t.ORDER-ap)/cp,n=t.mul(e,_n),r=t.pow(n,s),i=t.mul(e,r),o=t.mul(t.mul(i,_n),r),a=t.mul(i,t.sub(o,t.ONE));return cl(t,a,e),a}function Hv(t){const e=an(t),s=dp(t),n=s(e,e.neg(e.ONE)),r=s(e,n),i=s(e,e.neg(n)),o=(t+Fv)/lp;return(a,c)=>{let l=a.pow(c,o),u=a.mul(l,n);const d=a.mul(l,r),h=a.mul(l,i),p=a.eql(a.sqr(u),c),g=a.eql(a.sqr(d),c);l=a.cmov(l,u,p),u=a.cmov(h,d,g);const f=a.eql(a.sqr(u),c),y=a.cmov(l,u,f);return cl(a,y,c),y}}function dp(t){if(t<ip)throw new Error("sqrt is not defined for small field");let e=t-ct,s=0;for(;e%_n===wt;)e/=_n,s++;let n=_n;const r=an(t);for(;Iu(r,n)===1;)if(n++>1e3)throw new Error("Cannot find square root: probably non-prime P");if(s===1)return up;let i=r.pow(n,e);const o=(e+ct)/_n;return function(a,c){if(a.is0(c))return c;if(Iu(a,c)!==1)throw new Error("Cannot find square root");let l=s,u=a.mul(a.ONE,i),d=a.pow(c,e),h=a.pow(c,o);for(;!a.eql(d,a.ONE);){if(a.is0(d))return a.ZERO;let p=1,g=a.sqr(d);for(;!a.eql(g,a.ONE);)if(p++,g=a.sqr(g),p===l)throw new Error("Cannot find square root");const f=ct<<BigInt(l-p-1),y=a.pow(u,f);l=p,u=a.sqr(y),d=a.mul(d,u),h=a.mul(h,y)}return h}}function Kv(t){return t%op===ip?up:t%cp===ap?Wv:t%lp===qv?Hv(t):dp(t)}const zv=["create","isValid","is0","neg","inv","sqrt","sqr","eql","add","sub","mul","pow","div","addN","subN","mulN","sqrN"];function Vv(t){const e={ORDER:"bigint",MASK:"bigint",BYTES:"number",BITS:"number"},s=zv.reduce((n,r)=>(n[r]="function",n),e);return ta(t,s),t}function Gv(t,e,s){if(s<wt)throw new Error("invalid exponent, negatives unsupported");if(s===wt)return t.ONE;if(s===ct)return e;let n=t.ONE,r=e;for(;s>wt;)s&ct&&(n=t.mul(n,r)),r=t.sqr(r),s>>=ct;return n}function hp(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 Iu(t,e){const s=(t.ORDER-ct)/_n,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 pp(t,e){e!==void 0&&xs(e);const s=e!==void 0?e:t.toString(2).length,n=Math.ceil(s/8);return{nBitLength:s,nByteLength:n}}function an(t,e,s=!1,n={}){if(t<=wt)throw new Error("invalid field: expected ORDER > 0, got "+t);let r,i,o=!1,a;if(typeof e=="object"&&e!=null){if(n.sqrt||s)throw new Error("cannot specify opts in two arguments");const h=e;h.BITS&&(r=h.BITS),h.sqrt&&(i=h.sqrt),typeof h.isLE=="boolean"&&(s=h.isLE),typeof h.modFromBytes=="boolean"&&(o=h.modFromBytes),a=h.allowedLengths}else typeof e=="number"&&(r=e),n.sqrt&&(i=n.sqrt);const{nBitLength:c,nByteLength:l}=pp(t,r);if(l>2048)throw new Error("invalid field: expected ORDER of <= 2048 bytes");let u;const d=Object.freeze({ORDER:t,isLE:s,BITS:c,BYTES:l,MASK:Ri(c),ZERO:wt,ONE:ct,allowedLengths:a,create:h=>Nt(h,t),isValid:h=>{if(typeof h!="bigint")throw new Error("invalid field element: expected bigint, got "+typeof h);return wt<=h&&h<t},is0:h=>h===wt,isValidNot0:h=>!d.is0(h)&&d.isValid(h),isOdd:h=>(h&ct)===ct,neg:h=>Nt(-h,t),eql:(h,p)=>h===p,sqr:h=>Nt(h*h,t),add:(h,p)=>Nt(h+p,t),sub:(h,p)=>Nt(h-p,t),mul:(h,p)=>Nt(h*p,t),pow:(h,p)=>Gv(d,h,p),div:(h,p)=>Nt(h*Au(p,t),t),sqrN:h=>h*h,addN:(h,p)=>h+p,subN:(h,p)=>h-p,mulN:(h,p)=>h*p,inv:h=>Au(h,t),sqrt:i||(h=>(u||(u=Kv(t)),u(d,h))),toBytes:h=>s?al(h,l):ol(h,l),fromBytes:(h,p=!0)=>{if(a){if(!a.includes(h.length)||h.length>l)throw new Error("Field.fromBytes: expected "+a+" bytes, got "+h.length);const f=new Uint8Array(l);f.set(h,s?0:f.length-h.length),h=f}if(h.length!==l)throw new Error("Field.fromBytes: expected "+l+" bytes, got "+h.length);let g=s?xo(h):ea(h);if(o&&(g=Nt(g,t)),!p&&!d.isValid(g))throw new Error("invalid field element: outside of range 0..ORDER");return g},invertBatch:h=>hp(d,h),cmov:(h,p,g)=>g?p:h});return Object.freeze(d)}function fp(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 gp(t){const e=fp(t);return e+Math.ceil(e/2)}function Yv(t,e,s=!1){const n=t.length,r=fp(e),i=gp(e);if(n<16||n<i||n>1024)throw new Error("expected "+i+"-1024 bytes of input, got "+n);const o=s?xo(t):ea(t),a=Nt(o,e-ct)+ct;return s?al(a,r):ol(a,r)}const gr=BigInt(0),Sn=BigInt(1);function $o(t,e){const s=e.negate();return t?s:e}function Aa(t,e){const s=hp(t.Fp,e.map(n=>n.Z));return e.map((n,r)=>t.fromAffine(n.toAffine(s[r])))}function mp(t,e){if(!Number.isSafeInteger(t)||t<=0||t>e)throw new Error("invalid window size, expected [1.."+e+"], got W="+t)}function Ia(t,e){mp(t,e);const s=Math.ceil(e/t)+1,n=2**(t-1),r=2**t,i=Ri(t),o=BigInt(t);return{windows:s,windowSize:n,mask:i,maxNumber:r,shiftBy:o}}function _u(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+=Sn);const l=e*n,u=l+Math.abs(a)-1,d=a===0,h=a<0,p=e%2!==0;return{nextN:c,offset:u,isZero:d,isNeg:h,isNegF:p,offsetF:l}}function Jv(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 Xv(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 _a=new WeakMap,yp=new WeakMap;function Sa(t){return yp.get(t)||1}function Su(t){if(t!==gr)throw new Error("invalid wNAF")}class Zv{constructor(e,s){this.BASE=e.BASE,this.ZERO=e.ZERO,this.Fn=e.Fn,this.bits=s}_unsafeLadder(e,s,n=this.ZERO){let r=e;for(;s>gr;)s&Sn&&(n=n.add(r)),r=r.double(),s>>=Sn;return n}precomputeWindow(e,s){const{windows:n,windowSize:r}=Ia(s,this.bits),i=[];let o=e,a=o;for(let c=0;c<n;c++){a=o,i.push(a);for(let l=1;l<r;l++)a=a.add(o),i.push(a);o=a.double()}return i}wNAF(e,s,n){if(!this.Fn.isValid(n))throw new Error("invalid scalar");let r=this.ZERO,i=this.BASE;const o=Ia(e,this.bits);for(let a=0;a<o.windows;a++){const{nextN:c,offset:l,isZero:u,isNeg:d,isNegF:h,offsetF:p}=_u(n,a,o);n=c,u?i=i.add($o(h,s[p])):r=r.add($o(d,s[l]))}return Su(n),{p:r,f:i}}wNAFUnsafe(e,s,n,r=this.ZERO){const i=Ia(e,this.bits);for(let o=0;o<i.windows&&n!==gr;o++){const{nextN:a,offset:c,isZero:l,isNeg:u}=_u(n,o,i);if(n=a,!l){const d=s[c];r=r.add(u?d.negate():d)}}return Su(n),r}getPrecomputes(e,s,n){let r=_a.get(s);return r||(r=this.precomputeWindow(s,e),e!==1&&(typeof n=="function"&&(r=n(r)),_a.set(s,r))),r}cached(e,s,n){const r=Sa(e);return this.wNAF(r,this.getPrecomputes(r,e,n),s)}unsafe(e,s,n,r){const i=Sa(e);return i===1?this._unsafeLadder(e,s,r):this.wNAFUnsafe(i,this.getPrecomputes(i,e,n),s,r)}createCache(e,s){mp(s,this.bits),yp.set(e,s),_a.delete(e)}hasCache(e){return Sa(e)!==1}}function Qv(t,e,s,n){let r=e,i=t.ZERO,o=t.ZERO;for(;s>gr||n>gr;)s&Sn&&(i=i.add(r)),n&Sn&&(o=o.add(r)),r=r.double(),s>>=Sn,n>>=Sn;return{p1:i,p2:o}}function e0(t,e,s,n){Jv(s,t),Xv(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=rp(BigInt(r));let c=1;a>12?c=a-3:a>4?c=a-2:a>0&&(c=2);const l=Ri(c),u=new Array(Number(l)+1).fill(o),d=Math.floor((e.BITS-1)/c)*c;let h=o;for(let p=d;p>=0;p-=c){u.fill(o);for(let f=0;f<i;f++){const y=n[f],w=Number(y>>BigInt(p)&l);u[w]=u[w].add(s[f])}let g=o;for(let f=u.length-1,y=o;f>0;f--)y=y.add(u[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 Nu(t,e,s){if(e){if(e.ORDER!==t)throw new Error("Field.ORDER must match order: Fp == p, Fn == n");return Vv(e),e}else return an(t,{isLE:s})}function t0(t,e,s={},n){if(n===void 0&&(n=t==="edwards"),!e||typeof e!="object")throw new Error(`expected valid ${t} CURVE object`);for(const a of["p","n","h"]){const c=e[a];if(!(typeof c=="bigint"&&c>gr))throw new Error(`CURVE.${a} must be positive bigint`)}const r=Nu(e.p,s.Fp,n),i=Nu(e.n,s.Fn,n),o=["Gx","Gy","a","b"];for(const a of o)if(!r.isValid(e[a]))throw new Error(`CURVE.${a} must be valid field element of CURVE.Fp`);return e=Object.freeze(Object.assign({},e)),{CURVE:e,Fp:r,Fn:i}}BigInt(0),BigInt(1),BigInt(2),BigInt(8),Fh("HashToScalar-");const Nr=BigInt(0),Vn=BigInt(1),Zi=BigInt(2);function s0(t){return ta(t,{adjustScalarBytes:"function",powPminus2:"function"}),Object.freeze({...t})}function n0(t){const e=s0(t),{P:s,type:n,adjustScalarBytes:r,powPminus2:i,randomBytes:o}=e,a=n==="x25519";if(!a&&n!=="x448")throw new Error("invalid type");const c=o||qn,l=a?255:448,u=a?32:56,d=BigInt(a?9:5),h=BigInt(a?121665:39081),p=a?Zi**BigInt(254):Zi**BigInt(447),g=a?BigInt(8)*Zi**BigInt(251)-Vn:BigInt(4)*Zi**BigInt(445)-Vn,f=p+g+Vn,y=T=>Nt(T,s),w=b(d);function b(T){return al(y(T),u)}function E(T){const v=ot("u coordinate",T,u);return a&&(v[31]&=127),y(xo(v))}function N(T){return xo(r(ot("scalar",T,u)))}function x(T,v){const C=G(E(v),N(T));if(C===Nr)throw new Error("invalid private or public key received");return b(C)}function $(T){return x(T,w)}function W(T,v,C){const A=y(T*(v-C));return v=y(v-A),C=y(C+A),{x_2:v,x_3:C}}function G(T,v){mc("u",T,Nr,s),mc("scalar",v,p,f);const C=v,A=T;let S=Vn,D=Nr,B=T,I=Vn,R=Nr;for(let K=BigInt(l-1);K>=Nr;K--){const he=C>>K&Vn;R^=he,{x_2:S,x_3:B}=W(R,S,B),{x_2:D,x_3:I}=W(R,D,I),R=he;const ie=S+D,ne=y(ie*ie),ue=S-D,ce=y(ue*ue),Oe=ne-ce,le=B+I,De=B-I,Kt=y(De*ie),$s=y(le*ue),cn=Kt+$s,Hn=Kt-$s;B=y(cn*cn),I=y(A*y(Hn*Hn)),S=y(ne*ce),D=y(Oe*(ne+y(h*Oe)))}({x_2:S,x_3:B}=W(R,S,B)),{x_2:D,x_3:I}=W(R,D,I);const z=i(D);return y(S*z)}const k={secretKey:u,publicKey:u,seed:u},Q=(T=c(u))=>(ts(T,k.seed),T);function se(T){const v=Q(T);return{secretKey:v,publicKey:$(v)}}return{keygen:se,getSharedSecret:(T,v)=>x(T,v),getPublicKey:T=>$(T),scalarMult:x,scalarMultBase:$,utils:{randomSecretKey:Q,randomPrivateKey:Q},GuBytes:w.slice(),lengths:k}}const r0=BigInt(1),Tu=BigInt(2),i0=BigInt(3),o0=BigInt(5);BigInt(8);const wp=BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffed"),a0={p:wp,n:BigInt("0x1000000000000000000000000000000014def9dea2f79cd65812631a5cf5d3ed"),a:BigInt("0x7fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffec"),d:BigInt("0x52036cee2b6ffe738cc740797779e89800700a4d4141d8ab75eb4dca135978a3"),Gx:BigInt("0x216936d3cd6e53fec0a4e231fdd6dc5c692cc7609525a7b2c9562d608f25d51a"),Gy:BigInt("0x6666666666666666666666666666666666666666666666666666666666666658")};function c0(t){const e=BigInt(10),s=BigInt(20),n=BigInt(40),r=BigInt(80),i=wp,o=t*t%i*t%i,a=Yt(o,Tu,i)*o%i,c=Yt(a,r0,i)*t%i,l=Yt(c,o0,i)*c%i,u=Yt(l,e,i)*l%i,d=Yt(u,s,i)*u%i,h=Yt(d,n,i)*d%i,p=Yt(h,r,i)*h%i,g=Yt(p,r,i)*h%i,f=Yt(g,e,i)*l%i;return{pow_p_5_8:Yt(f,Tu,i)*t%i,b2:o}}function l0(t){return t[0]&=248,t[31]&=127,t[31]|=64,t}const u0=an(a0.p,{isLE:!0}),yc=(()=>{const t=u0.ORDER;return n0({P:t,type:"x25519",powPminus2:e=>{const{pow_p_5_8:s,b2:n}=c0(e);return Nt(Yt(s,i0,t)*n,t)},adjustScalarBytes:l0})})(),Ou=(t,e)=>(t+(t>=0?e:-e)/bp)/e;function d0(t,e,s){const[[n,r],[i,o]]=e,a=Ou(o*t,s),c=Ou(-r*t,s);let l=t-a*n-c*i,u=-a*r-c*o;const d=l<Ts,h=u<Ts;d&&(l=-l),h&&(u=-u);const p=Ri(Math.ceil(rp(s)/2))+or;if(l<Ts||l>=p||u<Ts||u>=p)throw new Error("splitScalar (endomorphism): failed, k="+t);return{k1neg:d,k1:l,k2neg:h,k2:u}}function wc(t){if(!["compact","recovered","der"].includes(t))throw new Error('Signature format must be "compact", "recovered", or "der"');return t}function Na(t,e){const s={};for(let n of Object.keys(e))s[n]=t[n]===void 0?e[n]:t[n];return Ro(s.lowS,"lowS"),Ro(s.prehash,"prehash"),s.format!==void 0&&wc(s.format),s}class h0 extends Error{constructor(e=""){super(e)}}const Is={Err:h0,_tlv:{encode:(t,e)=>{const{Err:s}=Is;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=Xi(n);if(r.length/2&128)throw new s("tlv.encode: long form length too big");const i=n>127?Xi(r.length/2|128):"";return Xi(t)+i+r+e},decode(t,e){const{Err:s}=Is;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 u of l)o=o<<8|u;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}=Is;if(t<Ts)throw new e("integer: negative integers are not allowed");let s=Xi(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}=Is;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 ea(t)}},toSig(t){const{Err:e,_int:s,_tlv:n}=Is,r=ot("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:u}=n.decode(2,c);if(u.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}=Is,n=e.encode(2,s.encode(t.r)),r=e.encode(2,s.encode(t.s)),i=n+r;return e.encode(48,i)}},Ts=BigInt(0),or=BigInt(1),bp=BigInt(2),Qi=BigInt(3),p0=BigInt(4);function er(t,e){const{BYTES:s}=t;let n;if(typeof e=="bigint")n=e;else{let r=ot("private key",e);try{n=t.fromBytes(r)}catch{throw new Error(`invalid private key: expected ui8a of size ${s}, got ${typeof e}`)}}if(!t.isValidNot0(n))throw new Error("invalid private key: out of range [1..N-1]");return n}function f0(t,e={}){const s=t0("weierstrass",t,e),{Fp:n,Fn:r}=s;let i=s.CURVE;const{h:o,n:a}=i;ta(e,{},{allowInfinityPoint:"boolean",clearCofactor:"function",isTorsionFree:"function",fromBytes:"function",toBytes:"function",endo:"object",wrapPrivateKey:"boolean"});const{endo:c}=e;if(c&&(!n.is0(i.a)||typeof c.beta!="bigint"||!Array.isArray(c.basises)))throw new Error('invalid endo: expected "beta": bigint and "basises": array');const l=Ep(n,r);function u(){if(!n.isOdd)throw new Error("compression is not supported: Field does not have .isOdd()")}function d(T,v,C){const{x:A,y:S}=v.toAffine(),D=n.toBytes(A);if(Ro(C,"isCompressed"),C){u();const B=!n.isOdd(S);return Gs(vp(B),D)}else return Gs(Uint8Array.of(4),D,n.toBytes(S))}function h(T){In(T,void 0,"Point");const{publicKey:v,publicKeyUncompressed:C}=l,A=T.length,S=T[0],D=T.subarray(1);if(A===v&&(S===2||S===3)){const B=n.fromBytes(D);if(!n.isValid(B))throw new Error("bad point: is not on curve, wrong x");const I=f(B);let R;try{R=n.sqrt(I)}catch(K){const he=K instanceof Error?": "+K.message:"";throw new Error("bad point: is not on curve, sqrt error"+he)}u();const z=n.isOdd(R);return(S&1)===1!==z&&(R=n.neg(R)),{x:B,y:R}}else if(A===C&&S===4){const B=n.BYTES,I=n.fromBytes(D.subarray(0,B)),R=n.fromBytes(D.subarray(B,B*2));if(!y(I,R))throw new Error("bad point: is not on curve");return{x:I,y:R}}else throw new Error(`bad point: got length ${A}, expected compressed=${v} or uncompressed=${C}`)}const p=e.toBytes||d,g=e.fromBytes||h;function f(T){const v=n.sqr(T),C=n.mul(v,T);return n.add(n.add(C,n.mul(T,i.a)),i.b)}function y(T,v){const C=n.sqr(v),A=f(T);return n.eql(C,A)}if(!y(i.Gx,i.Gy))throw new Error("bad curve params: generator point");const w=n.mul(n.pow(i.a,Qi),p0),b=n.mul(n.sqr(i.b),BigInt(27));if(n.is0(n.add(w,b)))throw new Error("bad curve params: a or b");function E(T,v,C=!1){if(!n.isValid(v)||C&&n.is0(v))throw new Error(`bad point coordinate ${T}`);return v}function N(T){if(!(T instanceof k))throw new Error("ProjectivePoint expected")}function x(T){if(!c||!c.basises)throw new Error("no endo");return d0(T,c.basises,r.ORDER)}const $=Cu((T,v)=>{const{X:C,Y:A,Z:S}=T;if(n.eql(S,n.ONE))return{x:C,y:A};const D=T.is0();v==null&&(v=D?n.ONE:n.inv(S));const B=n.mul(C,v),I=n.mul(A,v),R=n.mul(S,v);if(D)return{x:n.ZERO,y:n.ZERO};if(!n.eql(R,n.ONE))throw new Error("invZ was invalid");return{x:B,y:I}}),W=Cu(T=>{if(T.is0()){if(e.allowInfinityPoint&&!n.is0(T.Y))return;throw new Error("bad point: ZERO")}const{x:v,y:C}=T.toAffine();if(!n.isValid(v)||!n.isValid(C))throw new Error("bad point: x or y not field elements");if(!y(v,C))throw new Error("bad point: equation left != right");if(!T.isTorsionFree())throw new Error("bad point: not in prime-order subgroup");return!0});function G(T,v,C,A,S){return C=new k(n.mul(C.X,T),C.Y,C.Z),v=$o(A,v),C=$o(S,C),v.add(C)}class k{constructor(v,C,A){this.X=E("x",v),this.Y=E("y",C,!0),this.Z=E("z",A),Object.freeze(this)}static CURVE(){return i}static fromAffine(v){const{x:C,y:A}=v||{};if(!v||!n.isValid(C)||!n.isValid(A))throw new Error("invalid affine point");if(v instanceof k)throw new Error("projective point not allowed");return n.is0(C)&&n.is0(A)?k.ZERO:new k(C,A,n.ONE)}static fromBytes(v){const C=k.fromAffine(g(In(v,void 0,"point")));return C.assertValidity(),C}static fromHex(v){return k.fromBytes(ot("pointHex",v))}get x(){return this.toAffine().x}get y(){return this.toAffine().y}precompute(v=8,C=!0){return se.createCache(this,v),C||this.multiply(Qi),this}assertValidity(){W(this)}hasEvenY(){const{y:v}=this.toAffine();if(!n.isOdd)throw new Error("Field doesn't support isOdd");return!n.isOdd(v)}equals(v){N(v);const{X:C,Y:A,Z:S}=this,{X:D,Y:B,Z:I}=v,R=n.eql(n.mul(C,I),n.mul(D,S)),z=n.eql(n.mul(A,I),n.mul(B,S));return R&&z}negate(){return new k(this.X,n.neg(this.Y),this.Z)}double(){const{a:v,b:C}=i,A=n.mul(C,Qi),{X:S,Y:D,Z:B}=this;let I=n.ZERO,R=n.ZERO,z=n.ZERO,K=n.mul(S,S),he=n.mul(D,D),ie=n.mul(B,B),ne=n.mul(S,D);return ne=n.add(ne,ne),z=n.mul(S,B),z=n.add(z,z),I=n.mul(v,z),R=n.mul(A,ie),R=n.add(I,R),I=n.sub(he,R),R=n.add(he,R),R=n.mul(I,R),I=n.mul(ne,I),z=n.mul(A,z),ie=n.mul(v,ie),ne=n.sub(K,ie),ne=n.mul(v,ne),ne=n.add(ne,z),z=n.add(K,K),K=n.add(z,K),K=n.add(K,ie),K=n.mul(K,ne),R=n.add(R,K),ie=n.mul(D,B),ie=n.add(ie,ie),K=n.mul(ie,ne),I=n.sub(I,K),z=n.mul(ie,he),z=n.add(z,z),z=n.add(z,z),new k(I,R,z)}add(v){N(v);const{X:C,Y:A,Z:S}=this,{X:D,Y:B,Z:I}=v;let R=n.ZERO,z=n.ZERO,K=n.ZERO;const he=i.a,ie=n.mul(i.b,Qi);let ne=n.mul(C,D),ue=n.mul(A,B),ce=n.mul(S,I),Oe=n.add(C,A),le=n.add(D,B);Oe=n.mul(Oe,le),le=n.add(ne,ue),Oe=n.sub(Oe,le),le=n.add(C,S);let De=n.add(D,I);return le=n.mul(le,De),De=n.add(ne,ce),le=n.sub(le,De),De=n.add(A,S),R=n.add(B,I),De=n.mul(De,R),R=n.add(ue,ce),De=n.sub(De,R),K=n.mul(he,le),R=n.mul(ie,ce),K=n.add(R,K),R=n.sub(ue,K),K=n.add(ue,K),z=n.mul(R,K),ue=n.add(ne,ne),ue=n.add(ue,ne),ce=n.mul(he,ce),le=n.mul(ie,le),ue=n.add(ue,ce),ce=n.sub(ne,ce),ce=n.mul(he,ce),le=n.add(le,ce),ne=n.mul(ue,le),z=n.add(z,ne),ne=n.mul(De,le),R=n.mul(Oe,R),R=n.sub(R,ne),ne=n.mul(Oe,ue),K=n.mul(De,K),K=n.add(K,ne),new k(R,z,K)}subtract(v){return this.add(v.negate())}is0(){return this.equals(k.ZERO)}multiply(v){const{endo:C}=e;if(!r.isValidNot0(v))throw new Error("invalid scalar: out of range");let A,S;const D=B=>se.cached(this,B,I=>Aa(k,I));if(C){const{k1neg:B,k1:I,k2neg:R,k2:z}=x(v),{p:K,f:he}=D(I),{p:ie,f:ne}=D(z);S=he.add(ne),A=G(C.beta,K,ie,B,R)}else{const{p:B,f:I}=D(v);A=B,S=I}return Aa(k,[A,S])[0]}multiplyUnsafe(v){const{endo:C}=e,A=this;if(!r.isValid(v))throw new Error("invalid scalar: out of range");if(v===Ts||A.is0())return k.ZERO;if(v===or)return A;if(se.hasCache(this))return this.multiply(v);if(C){const{k1neg:S,k1:D,k2neg:B,k2:I}=x(v),{p1:R,p2:z}=Qv(k,A,D,I);return G(C.beta,R,z,S,B)}else return se.unsafe(A,v)}multiplyAndAddUnsafe(v,C,A){const S=this.multiplyUnsafe(C).add(v.multiplyUnsafe(A));return S.is0()?void 0:S}toAffine(v){return $(this,v)}isTorsionFree(){const{isTorsionFree:v}=e;return o===or?!0:v?v(k,this):se.unsafe(this,a).is0()}clearCofactor(){const{clearCofactor:v}=e;return o===or?this:v?v(k,this):this.multiplyUnsafe(o)}isSmallOrder(){return this.multiplyUnsafe(o).is0()}toBytes(v=!0){return Ro(v,"isCompressed"),this.assertValidity(),p(k,this,v)}toHex(v=!0){return ir(this.toBytes(v))}toString(){return`<Point ${this.is0()?"ZERO":this.toHex()}>`}get px(){return this.X}get py(){return this.X}get pz(){return this.Z}toRawBytes(v=!0){return this.toBytes(v)}_setWindowSize(v){this.precompute(v)}static normalizeZ(v){return Aa(k,v)}static msm(v,C){return e0(k,r,v,C)}static fromPrivateKey(v){return k.BASE.multiply(er(r,v))}}k.BASE=new k(i.Gx,i.Gy,n.ONE),k.ZERO=new k(n.ZERO,n.ONE,n.ZERO),k.Fp=n,k.Fn=r;const Q=r.BITS,se=new Zv(k,e.endo?Math.ceil(Q/2):Q);return k.BASE.precompute(8),k}function vp(t){return Uint8Array.of(t?2:3)}function Ep(t,e){return{secretKey:e.BYTES,publicKey:1+t.BYTES,publicKeyUncompressed:1+2*t.BYTES,publicKeyHasPrefix:!0,signature:2*e.BYTES}}function g0(t,e={}){const{Fn:s}=t,n=e.randomBytes||qn,r=Object.assign(Ep(t.Fp,s),{seed:gp(s.ORDER)});function i(h){try{return!!er(s,h)}catch{return!1}}function o(h,p){const{publicKey:g,publicKeyUncompressed:f}=r;try{const y=h.length;return p===!0&&y!==g||p===!1&&y!==f?!1:!!t.fromBytes(h)}catch{return!1}}function a(h=n(r.seed)){return Yv(In(h,r.seed,"seed"),s.ORDER)}function c(h,p=!0){return t.BASE.multiply(er(s,h)).toBytes(p)}function l(h){const p=a(h);return{secretKey:p,publicKey:c(p)}}function u(h){if(typeof h=="bigint")return!1;if(h instanceof t)return!0;const{secretKey:p,publicKey:g,publicKeyUncompressed:f}=r;if(s.allowedLengths||p===g)return;const y=ot("key",h).length;return y===g||y===f}function d(h,p,g=!0){if(u(h)===!0)throw new Error("first arg must be private key");if(u(p)===!1)throw new Error("second arg must be public key");const f=er(s,h);return t.fromHex(p).multiply(f).toBytes(g)}return Object.freeze({getPublicKey:c,getSharedSecret:d,keygen:l,Point:t,utils:{isValidSecretKey:i,isValidPublicKey:o,randomSecretKey:a,isValidPrivateKey:i,randomPrivateKey:a,normPrivateKeyToScalar:h=>er(s,h),precompute(h=8,p=t.BASE){return p.precompute(h,!1)}},lengths:r})}function m0(t,e,s={}){Yo(e),ta(s,{},{hmac:"function",lowS:"boolean",randomBytes:"function",bits2int:"function",bits2int_modN:"function"});const n=s.randomBytes||qn,r=s.hmac||((C,...A)=>Zo(e,C,Gs(...A))),{Fp:i,Fn:o}=t,{ORDER:a,BITS:c}=o,{keygen:l,getPublicKey:u,getSharedSecret:d,utils:h,lengths:p}=g0(t,s),g={prehash:!1,lowS:typeof s.lowS=="boolean"?s.lowS:!1,format:void 0,extraEntropy:!1},f="compact";function y(C){const A=a>>or;return C>A}function w(C,A){if(!o.isValidNot0(A))throw new Error(`invalid signature ${C}: out of range 1..Point.Fn.ORDER`);return A}function b(C,A){wc(A);const S=p.signature,D=A==="compact"?S:A==="recovered"?S+1:void 0;return In(C,D,`${A} signature`)}class E{constructor(A,S,D){this.r=w("r",A),this.s=w("s",S),D!=null&&(this.recovery=D),Object.freeze(this)}static fromBytes(A,S=f){b(A,S);let D;if(S==="der"){const{r:z,s:K}=Is.toSig(In(A));return new E(z,K)}S==="recovered"&&(D=A[0],S="compact",A=A.subarray(1));const B=o.BYTES,I=A.subarray(0,B),R=A.subarray(B,B*2);return new E(o.fromBytes(I),o.fromBytes(R),D)}static fromHex(A,S){return this.fromBytes(Po(A),S)}addRecoveryBit(A){return new E(this.r,this.s,A)}recoverPublicKey(A){const S=i.ORDER,{r:D,s:B,recovery:I}=this;if(I==null||![0,1,2,3].includes(I))throw new Error("recovery id invalid");if(a*bp<S&&I>1)throw new Error("recovery id is ambiguous for h>1 curve");const R=I===2||I===3?D+a:D;if(!i.isValid(R))throw new Error("recovery id 2 or 3 invalid");const z=i.toBytes(R),K=t.fromBytes(Gs(vp((I&1)===0),z)),he=o.inv(R),ie=x(ot("msgHash",A)),ne=o.create(-ie*he),ue=o.create(B*he),ce=t.BASE.multiplyUnsafe(ne).add(K.multiplyUnsafe(ue));if(ce.is0())throw new Error("point at infinify");return ce.assertValidity(),ce}hasHighS(){return y(this.s)}toBytes(A=f){if(wc(A),A==="der")return Po(Is.hexFromSig(this));const S=o.toBytes(this.r),D=o.toBytes(this.s);if(A==="recovered"){if(this.recovery==null)throw new Error("recovery bit must be present");return Gs(Uint8Array.of(this.recovery),S,D)}return Gs(S,D)}toHex(A){return ir(this.toBytes(A))}assertValidity(){}static fromCompact(A){return E.fromBytes(ot("sig",A),"compact")}static fromDER(A){return E.fromBytes(ot("sig",A),"der")}normalizeS(){return this.hasHighS()?new E(this.r,o.neg(this.s),this.recovery):this}toDERRawBytes(){return this.toBytes("der")}toDERHex(){return ir(this.toBytes("der"))}toCompactRawBytes(){return this.toBytes("compact")}toCompactHex(){return ir(this.toBytes("compact"))}}const N=s.bits2int||function(C){if(C.length>8192)throw new Error("input is too large");const A=ea(C),S=C.length*8-c;return S>0?A>>BigInt(S):A},x=s.bits2int_modN||function(C){return o.create(N(C))},$=Ri(c);function W(C){return mc("num < 2^"+c,C,Ts,$),o.toBytes(C)}function G(C,A){return In(C,void 0,"message"),A?In(e(C),void 0,"prehashed message"):C}function k(C,A,S){if(["recovered","canonical"].some(ue=>ue in S))throw new Error("sign() legacy options not supported");const{lowS:D,prehash:B,extraEntropy:I}=Na(S,g);C=G(C,B);const R=x(C),z=er(o,A),K=[W(z),W(R)];if(I!=null&&I!==!1){const ue=I===!0?n(p.secretKey):I;K.push(ot("extraEntropy",ue))}const he=Gs(...K),ie=R;function ne(ue){const ce=N(ue);if(!o.isValidNot0(ce))return;const Oe=o.inv(ce),le=t.BASE.multiply(ce).toAffine(),De=o.create(le.x);if(De===Ts)return;const Kt=o.create(Oe*o.create(ie+De*z));if(Kt===Ts)return;let $s=(le.x===De?0:2)|Number(le.y&or),cn=Kt;return D&&y(Kt)&&(cn=o.neg(Kt),$s^=1),new E(De,cn,$s)}return{seed:he,k2sig:ne}}function Q(C,A,S={}){C=ot("message",C);const{seed:D,k2sig:B}=k(C,A,S);return jv(e.outputLen,o.BYTES,r)(D,B)}function se(C){let A;const S=typeof C=="string"||Go(C),D=!S&&C!==null&&typeof C=="object"&&typeof C.r=="bigint"&&typeof C.s=="bigint";if(!S&&!D)throw new Error("invalid signature, expected Uint8Array, hex string or Signature instance");if(D)A=new E(C.r,C.s);else if(S){try{A=E.fromBytes(ot("sig",C),"der")}catch(B){if(!(B instanceof Is.Err))throw B}if(!A)try{A=E.fromBytes(ot("sig",C),"compact")}catch{return!1}}return A||!1}function T(C,A,S,D={}){const{lowS:B,prehash:I,format:R}=Na(D,g);if(S=ot("publicKey",S),A=G(ot("message",A),I),"strict"in D)throw new Error("options.strict was renamed to lowS");const z=R===void 0?se(C):E.fromBytes(ot("sig",C),R);if(z===!1)return!1;try{const K=t.fromBytes(S);if(B&&z.hasHighS())return!1;const{r:he,s:ie}=z,ne=x(A),ue=o.inv(ie),ce=o.create(ne*ue),Oe=o.create(he*ue),le=t.BASE.multiplyUnsafe(ce).add(K.multiplyUnsafe(Oe));return le.is0()?!1:o.create(le.x)===he}catch{return!1}}function v(C,A,S={}){const{prehash:D}=Na(S,g);return A=G(A,D),E.fromBytes(C,"recovered").recoverPublicKey(A).toBytes()}return Object.freeze({keygen:l,getPublicKey:u,getSharedSecret:d,utils:h,lengths:p,Point:t,sign:Q,verify:T,recoverPublicKey:v,Signature:E,hash:e})}function y0(t){const e={a:t.a,b:t.b,p:t.Fp.ORDER,n:t.n,h:t.h,Gx:t.Gx,Gy:t.Gy},s=t.Fp;let n=t.allowedPrivateKeyLengths?Array.from(new Set(t.allowedPrivateKeyLengths.map(o=>Math.ceil(o/2)))):void 0;const r=an(e.n,{BITS:t.nBitLength,allowedLengths:n,modFromBytes:t.wrapPrivateKey}),i={Fp:s,Fn:r,allowInfinityPoint:t.allowInfinityPoint,endo:t.endo,isTorsionFree:t.isTorsionFree,clearCofactor:t.clearCofactor,fromBytes:t.fromBytes,toBytes:t.toBytes};return{CURVE:e,curveOpts:i}}function w0(t){const{CURVE:e,curveOpts:s}=y0(t),n={hmac:t.hmac,randomBytes:t.randomBytes,lowS:t.lowS,bits2int:t.bits2int,bits2int_modN:t.bits2int_modN};return{CURVE:e,curveOpts:s,hash:t.hash,ecdsaOpts:n}}function b0(t,e){const s=e.Point;return Object.assign({},e,{ProjectivePoint:s,CURVE:Object.assign({},t,pp(s.Fn.ORDER,s.Fn.BITS))})}function v0(t){const{CURVE:e,curveOpts:s,hash:n,ecdsaOpts:r}=w0(t),i=f0(e,s),o=m0(i,n,r);return b0(t,o)}function bc(t,e){const s=n=>v0({...t,hash:n});return{...s(e),create:s}}const Cp={p:BigInt("0xffffffff00000001000000000000000000000000ffffffffffffffffffffffff"),n:BigInt("0xffffffff00000000ffffffffffffffffbce6faada7179e84f3b9cac2fc632551"),h:BigInt(1),a:BigInt("0xffffffff00000001000000000000000000000000fffffffffffffffffffffffc"),b:BigInt("0x5ac635d8aa3a93e7b3ebbd55769886bc651d06b0cc53b0f63bce3c3e27d2604b"),Gx:BigInt("0x6b17d1f2e12c4247f8bce6e563a440f277037d812deb33a0f4a13945d898c296"),Gy:BigInt("0x4fe342e2fe1a7f9b8ee7eb4a7c0f9e162bce33576b315ececbb6406837bf51f5")},Ap={p:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffeffffffff0000000000000000ffffffff"),n:BigInt("0xffffffffffffffffffffffffffffffffffffffffffffffffc7634d81f4372ddf581a0db248b0a77aecec196accc52973"),h:BigInt(1),a:BigInt("0xfffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffeffffffff0000000000000000fffffffc"),b:BigInt("0xb3312fa7e23ee7e4988e056be3f82d19181d9c6efe8141120314088f5013875ac656398d8a2ed19d2a85c8edd3ec2aef"),Gx:BigInt("0xaa87ca22be8b05378eb1c71ef320ad746e1d3b628ba79b9859f741e082542a385502f25dbf55296c3a545e3872760ab7"),Gy:BigInt("0x3617de4a96262c6f5d9e98bf9292dc29f8f41dbd289a147ce9da3113b5f0b8c00a60b1ce1d7e819d7a431d7c90ea0e5f")},Ip={p:BigInt("0x1ffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffff"),n:BigInt("0x01fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffa51868783bf2f966b7fcc0148f709a5d03bb5c9b8899c47aebb6fb71e91386409"),h:BigInt(1),a:BigInt("0x1fffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffffc"),b:BigInt("0x0051953eb9618e1c9a1f929a21a0b68540eea2da725b99b315f3b8b489918ef109e156193951ec7e937b1652c0bd3bb1bf073573df883d2c34f1ef451fd46b503f00"),Gx:BigInt("0x00c6858e06b70404e9cd9e3ecb662395b4429c648139053fb521f828af606b4d3dbaa14b5e77efe75928fe1dc127a2ffa8de3348b3c1856a429bf97e7e31c2e5bd66"),Gy:BigInt("0x011839296a789a3bc0045c8a5fb42c7d1bd998f54449579b446817afbd17273e662c97ee72995ef42640c550b9013fad0761353c7086a272c24088be94769fd16650")},E0=an(Cp.p),C0=an(Ap.p),A0=an(Ip.p),I0=bc({...Cp,Fp:E0,lowS:!1},Xo);bc({...Ap,Fp:C0,lowS:!1},kb),bc({...Ip,Fp:A0,lowS:!1,allowedPrivateKeyLengths:[130,131,132]},Pb);const _0=I0,_p="base10",lt="base16",yt="base64pad",Ys="base64url",xi="utf8",Sp=0,Ps=1,$i=2,S0=0,Pu=1,Hr=12,ll=32;function N0(){const t=yc.utils.randomPrivateKey(),e=yc.getPublicKey(t);return{privateKey:bt(t,lt),publicKey:bt(e,lt)}}function vc(){const t=qn(ll);return bt(t,lt)}function T0(t,e){const s=yc.getSharedSecret(Ft(t,lt),Ft(e,lt)),n=Mv(Qo,s,void 0,void 0,ll);return bt(n,lt)}function go(t){const e=Qo(Ft(t,lt));return bt(e,lt)}function Bt(t){const e=Qo(Ft(t,xi));return bt(e,lt)}function Np(t){return Ft(`${t}`,_p)}function Dn(t){return Number(bt(t,_p))}function Tp(t){return t.replace(/\+/g,"-").replace(/\//g,"_").replace(/=/g,"")}function Op(t){const e=t.replace(/-/g,"+").replace(/_/g,"/"),s=(4-e.length%4)%4;return e+"=".repeat(s)}function O0(t){const e=Np(typeof t.type<"u"?t.type:Sp);if(Dn(e)===Ps&&typeof t.senderPublicKey>"u")throw new Error("Missing sender public key for type 1 envelope");const s=typeof t.senderPublicKey<"u"?Ft(t.senderPublicKey,lt):void 0,n=typeof t.iv<"u"?Ft(t.iv,lt):qn(Hr),r=Ft(t.symKey,lt),i=tp(r,n).encrypt(Ft(t.message,xi)),o=Pp({type:e,sealed:i,iv:n,senderPublicKey:s});return t.encoding===Ys?Tp(o):o}function P0(t){const e=Ft(t.symKey,lt),{sealed:s,iv:n}=Ci({encoded:t.encoded,encoding:t.encoding}),r=tp(e,n).decrypt(s);if(r===null)throw new Error("Failed to decrypt");return bt(r,xi)}function k0(t,e){const s=Np($i),n=qn(Hr),r=Ft(t,xi),i=Pp({type:s,sealed:r,iv:n});return e===Ys?Tp(i):i}function R0(t,e){const{sealed:s}=Ci({encoded:t,encoding:e});return bt(s,xi)}function Pp(t){if(Dn(t.type)===$i)return bt(jr([t.type,t.sealed]),yt);if(Dn(t.type)===Ps){if(typeof t.senderPublicKey>"u")throw new Error("Missing sender public key for type 1 envelope");return bt(jr([t.type,t.senderPublicKey,t.iv,t.sealed]),yt)}return bt(jr([t.type,t.iv,t.sealed]),yt)}function Ci(t){const e=(t.encoding||yt)===Ys?Op(t.encoded):t.encoded,s=Ft(e,yt),n=s.slice(S0,Pu),r=Pu;if(Dn(n)===Ps){const c=r+ll,l=c+Hr,u=s.slice(r,c),d=s.slice(c,l),h=s.slice(l);return{type:n,sealed:h,iv:d,senderPublicKey:u}}if(Dn(n)===$i){const c=s.slice(r),l=qn(Hr);return{type:n,sealed:c,iv:l}}const i=r+Hr,o=s.slice(r,i),a=s.slice(i);return{type:n,sealed:a,iv:o}}function x0(t,e){const s=Ci({encoded:t,encoding:e==null?void 0:e.encoding});return kp({type:Dn(s.type),senderPublicKey:typeof s.senderPublicKey<"u"?bt(s.senderPublicKey,lt):void 0,receiverPublicKey:e==null?void 0:e.receiverPublicKey})}function kp(t){const e=(t==null?void 0:t.type)||Sp;if(e===Ps){if(typeof(t==null?void 0:t.senderPublicKey)>"u")throw new Error("missing sender public key");if(typeof(t==null?void 0:t.receiverPublicKey)>"u")throw new Error("missing receiver public key")}return{type:e,senderPublicKey:t==null?void 0:t.senderPublicKey,receiverPublicKey:t==null?void 0:t.receiverPublicKey}}function ku(t){return t.type===Ps&&typeof t.senderPublicKey=="string"&&typeof t.receiverPublicKey=="string"}function Ru(t){return t.type===$i}function $0(t){const e=Buffer.from(t.x,"base64"),s=Buffer.from(t.y,"base64");return jr([new Uint8Array([4]),e,s])}function U0(t,e){const[s,n,r]=t.split("."),i=Buffer.from(Op(r),"base64");if(i.length!==64)throw new Error("Invalid signature length");const o=i.slice(0,32),a=i.slice(32,64),c=`${s}.${n}`,l=Qo(c),u=$0(e);if(!_0.verify(jr([o,a]),l,u))throw new Error("Invalid signature");return Ya(t).payload}const D0="irn";function Uo(t){return(t==null?void 0:t.relay)||{protocol:D0}}function tr(t){const e=xf[t];if(typeof e>"u")throw new Error(`Relay Protocol not supported: ${t}`);return e}var L0=Object.defineProperty,M0=Object.defineProperties,B0=Object.getOwnPropertyDescriptors,xu=Object.getOwnPropertySymbols,j0=Object.prototype.hasOwnProperty,F0=Object.prototype.propertyIsEnumerable,$u=(t,e,s)=>e in t?L0(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ta=(t,e)=>{for(var s in e||(e={}))j0.call(e,s)&&$u(t,s,e[s]);if(xu)for(var s of xu(e))F0.call(e,s)&&$u(t,s,e[s]);return t},q0=(t,e)=>M0(t,B0(e));function W0(t,e="-"){const s={},n="relay"+e;return Object.keys(t).forEach(r=>{if(r.startsWith(n)){const i=r.replace(n,""),o=t[r];s[i]=o}}),s}function Uu(t){if(!t.includes("wc:")){const l=Uh(t);l!=null&&l.includes("wc:")&&(t=l)}t=t.includes("wc://")?t.replace("wc://",""):t,t=t.includes("wc:")?t.replace("wc:",""):t;const e=t.indexOf(":"),s=t.indexOf("?")!==-1?t.indexOf("?"):void 0,n=t.substring(0,e),r=t.substring(e+1,s).split("@"),i=typeof s<"u"?t.substring(s):"",o=new URLSearchParams(i),a=Object.fromEntries(o.entries()),c=typeof a.methods=="string"?a.methods.split(","):void 0;return{protocol:n,topic:H0(r[0]),version:parseInt(r[1],10),symKey:a.symKey,relay:W0(a),methods:c,expiryTimestamp:a.expiryTimestamp?parseInt(a.expiryTimestamp,10):void 0}}function H0(t){return t.startsWith("//")?t.substring(2):t}function K0(t,e="-"){const s="relay",n={};return Object.keys(t).forEach(r=>{const i=r,o=s+e+i;t[i]&&(n[o]=t[i])}),n}function Du(t){const e=new URLSearchParams,s=Ta(Ta(q0(Ta({},K0(t.relay)),{symKey:t.symKey}),t.expiryTimestamp&&{expiryTimestamp:t.expiryTimestamp.toString()}),t.methods&&{methods:t.methods.join(",")});return Object.entries(s).sort(([n],[r])=>n.localeCompare(r)).forEach(([n,r])=>{r!==void 0&&e.append(n,String(r))}),`${t.protocol}:${t.topic}@${t.version}?${e}`}function eo(t,e,s){return`${t}?wc_ev=${s}&topic=${e}`}var z0=Object.defineProperty,V0=Object.defineProperties,G0=Object.getOwnPropertyDescriptors,Lu=Object.getOwnPropertySymbols,Y0=Object.prototype.hasOwnProperty,J0=Object.prototype.propertyIsEnumerable,Mu=(t,e,s)=>e in t?z0(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,X0=(t,e)=>{for(var s in e||(e={}))Y0.call(e,s)&&Mu(t,s,e[s]);if(Lu)for(var s of Lu(e))J0.call(e,s)&&Mu(t,s,e[s]);return t},Z0=(t,e)=>V0(t,G0(e));function Cr(t){const e=[];return t.forEach(s=>{const[n,r]=s.split(":");e.push(`${n}:${r}`)}),e}function Q0(t){const e=[];return Object.values(t).forEach(s=>{e.push(...Cr(s.accounts))}),e}function eE(t,e){const s=[];return Object.values(t).forEach(n=>{Cr(n.accounts).includes(e)&&s.push(...n.methods)}),s}function tE(t,e){const s=[];return Object.values(t).forEach(n=>{Cr(n.accounts).includes(e)&&s.push(...n.events)}),s}function sa(t){return t.includes(":")}function sr(t){return sa(t)?t.split(":")[0]:t}function Bu(t){var e,s,n;const r={};if(!fs(t))return r;for(const[i,o]of Object.entries(t)){const a=sa(i)?[i]:o.chains,c=o.methods||[],l=o.events||[],u=sr(i);r[u]=Z0(X0({},r[u]),{chains:ps(a,(e=r[u])==null?void 0:e.chains),methods:ps(c,(s=r[u])==null?void 0:s.methods),events:ps(l,(n=r[u])==null?void 0:n.events)})}return r}function sE(t){const e={};return t==null||t.forEach(s=>{var n;const[r,i]=s.split(":");e[r]||(e[r]={accounts:[],chains:[],events:[],methods:[]}),e[r].accounts.push(s),(n=e[r].chains)==null||n.push(`${r}:${i}`)}),e}function ju(t,e){e=e.map(n=>n.replace("did:pkh:",""));const s=sE(e);for(const[n,r]of Object.entries(s))r.methods?r.methods=ps(r.methods,t):r.methods=t,r.events=["chainChanged","accountsChanged"];return s}function nE(t,e){var s,n,r,i,o,a;const c=Bu(t),l=Bu(e),u={},d=Object.keys(c).concat(Object.keys(l));for(const h of d)u[h]={chains:ps((s=c[h])==null?void 0:s.chains,(n=l[h])==null?void 0:n.chains),methods:ps((r=c[h])==null?void 0:r.methods,(i=l[h])==null?void 0:i.methods),events:ps((o=c[h])==null?void 0:o.events,(a=l[h])==null?void 0:a.events)};return u}const rE={INVALID_METHOD:{message:"Invalid method.",code:1001},INVALID_EVENT:{message:"Invalid event.",code:1002},INVALID_UPDATE_REQUEST:{message:"Invalid update request.",code:1003},INVALID_EXTEND_REQUEST:{message:"Invalid extend request.",code:1004},INVALID_SESSION_SETTLE_REQUEST:{message:"Invalid session settle request.",code:1005},UNAUTHORIZED_METHOD:{message:"Unauthorized method.",code:3001},UNAUTHORIZED_EVENT:{message:"Unauthorized event.",code:3002},UNAUTHORIZED_UPDATE_REQUEST:{message:"Unauthorized update request.",code:3003},UNAUTHORIZED_EXTEND_REQUEST:{message:"Unauthorized extend request.",code:3004},USER_REJECTED:{message:"User rejected.",code:5e3},USER_REJECTED_CHAINS:{message:"User rejected chains.",code:5001},USER_REJECTED_METHODS:{message:"User rejected methods.",code:5002},USER_REJECTED_EVENTS:{message:"User rejected events.",code:5003},UNSUPPORTED_CHAINS:{message:"Unsupported chains.",code:5100},UNSUPPORTED_METHODS:{message:"Unsupported methods.",code:5101},UNSUPPORTED_EVENTS:{message:"Unsupported events.",code:5102},UNSUPPORTED_ACCOUNTS:{message:"Unsupported accounts.",code:5103},UNSUPPORTED_NAMESPACE_KEY:{message:"Unsupported namespace key.",code:5104},USER_DISCONNECTED:{message:"User disconnected.",code:6e3},SESSION_SETTLEMENT_FAILED:{message:"Session settlement failed.",code:7e3},WC_METHOD_UNSUPPORTED:{message:"Unsupported wc_ method.",code:10001}},iE={NOT_INITIALIZED:{message:"Not initialized.",code:1},NO_MATCHING_KEY:{message:"No matching key.",code:2},RESTORE_WILL_OVERRIDE:{message:"Restore will override.",code:3},RESUBSCRIBED:{message:"Resubscribed.",code:4},MISSING_OR_INVALID:{message:"Missing or invalid.",code:5},EXPIRED:{message:"Expired.",code:6},UNKNOWN_TYPE:{message:"Unknown type.",code:7},MISMATCHED_TOPIC:{message:"Mismatched topic.",code:8},NON_CONFORMING_NAMESPACES:{message:"Non conforming namespaces.",code:9}};function M(t,e){const{message:s,code:n}=iE[t];return{message:e?`${s} ${e}`:s,code:n}}function $e(t,e){const{message:s,code:n}=rE[t];return{message:e?`${s} ${e}`:s,code:n}}function ks(t,e){return!!Array.isArray(t)}function fs(t){return Object.getPrototypeOf(t)===Object.prototype&&Object.keys(t).length}function We(t){return typeof t>"u"}function je(t,e){return e&&We(t)?!0:typeof t=="string"&&!!t.trim().length}function ul(t,e){return e&&We(t)?!0:typeof t=="number"&&!isNaN(t)}function oE(t,e){const{requiredNamespaces:s}=e,n=Object.keys(t.namespaces),r=Object.keys(s);let i=!0;return An(r,n)?(n.forEach(o=>{const{accounts:a,methods:c,events:l}=t.namespaces[o],u=Cr(a),d=s[o];(!An(Ph(o,d),u)||!An(d.methods,c)||!An(d.events,l))&&(i=!1)}),i):!1}function Do(t){return je(t,!1)&&t.includes(":")?t.split(":").length===2:!1}function aE(t){if(je(t,!1)&&t.includes(":")){const e=t.split(":");if(e.length===3){const s=e[0]+":"+e[1];return!!e[2]&&Do(s)}}return!1}function cE(t){function e(s){try{return typeof new URL(s)<"u"}catch{return!1}}try{if(je(t,!1)){if(e(t))return!0;const s=Uh(t);return e(s)}}catch{}return!1}function lE(t){var e;return(e=t==null?void 0:t.proposer)==null?void 0:e.publicKey}function uE(t){return t==null?void 0:t.topic}function dE(t,e){let s=null;return je(t==null?void 0:t.publicKey,!1)||(s=M("MISSING_OR_INVALID",`${e} controller public key should be a string`)),s}function Fu(t){let e=!0;return ks(t)?t.length&&(e=t.every(s=>je(s,!1))):e=!1,e}function hE(t,e,s){let n=null;return ks(e)&&e.length?e.forEach(r=>{n||Do(r)||(n=$e("UNSUPPORTED_CHAINS",`${s}, chain ${r} should be a string and conform to "namespace:chainId" format`))}):Do(t)||(n=$e("UNSUPPORTED_CHAINS",`${s}, chains must be defined as "namespace:chainId" e.g. "eip155:1": {...} in the namespace key OR as an array of CAIP-2 chainIds e.g. eip155: { chains: ["eip155:1", "eip155:5"] }`)),n}function pE(t,e,s){let n=null;return Object.entries(t).forEach(([r,i])=>{if(n)return;const o=hE(r,Ph(r,i),`${e} ${s}`);o&&(n=o)}),n}function fE(t,e){let s=null;return ks(t)?t.forEach(n=>{s||aE(n)||(s=$e("UNSUPPORTED_ACCOUNTS",`${e}, account ${n} should be a string and conform to "namespace:chainId:address" format`))}):s=$e("UNSUPPORTED_ACCOUNTS",`${e}, accounts should be an array of strings conforming to "namespace:chainId:address" format`),s}function gE(t,e){let s=null;return Object.values(t).forEach(n=>{if(s)return;const r=fE(n==null?void 0:n.accounts,`${e} namespace`);r&&(s=r)}),s}function mE(t,e){let s=null;return Fu(t==null?void 0:t.methods)?Fu(t==null?void 0:t.events)||(s=$e("UNSUPPORTED_EVENTS",`${e}, events should be an array of strings or empty array for no events`)):s=$e("UNSUPPORTED_METHODS",`${e}, methods should be an array of strings or empty array for no methods`),s}function Rp(t,e){let s=null;return Object.values(t).forEach(n=>{if(s)return;const r=mE(n,`${e}, namespace`);r&&(s=r)}),s}function yE(t,e,s){let n=null;if(t&&fs(t)){const r=Rp(t,e);r&&(n=r);const i=pE(t,e,s);i&&(n=i)}else n=M("MISSING_OR_INVALID",`${e}, ${s} should be an object with data`);return n}function Oa(t,e){let s=null;if(t&&fs(t)){const n=Rp(t,e);n&&(s=n);const r=gE(t,e);r&&(s=r)}else s=M("MISSING_OR_INVALID",`${e}, namespaces should be an object with data`);return s}function xp(t){return je(t.protocol,!0)}function wE(t,e){let s=!1;return t?t&&ks(t)&&t.length&&t.forEach(n=>{s=xp(n)}):s=!0,s}function bE(t){return typeof t=="number"}function gt(t){return typeof t<"u"&&typeof t!==null}function vE(t){return!(!t||typeof t!="object"||!t.code||!ul(t.code,!1)||!t.message||!je(t.message,!1))}function EE(t){return!(We(t)||!je(t.method,!1))}function CE(t){return!(We(t)||We(t.result)&&We(t.error)||!ul(t.id,!1)||!je(t.jsonrpc,!1))}function AE(t){return!(We(t)||!je(t.name,!1))}function qu(t,e){return!(!Do(e)||!Q0(t).includes(e))}function IE(t,e,s){return je(s,!1)?eE(t,e).includes(s):!1}function _E(t,e,s){return je(s,!1)?tE(t,e).includes(s):!1}function Wu(t,e,s){let n=null;const r=SE(t),i=NE(e),o=Object.keys(r),a=Object.keys(i),c=Hu(Object.keys(t)),l=Hu(Object.keys(e)),u=c.filter(d=>!l.includes(d));return u.length&&(n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces keys don't satisfy requiredNamespaces.
|
|
@@ -16,7 +16,7 @@ ${t.length}`,s=new TextEncoder().encode(e+t);return"0x"+Buffer.from(vb(s)).toStr
|
|
|
16
16
|
Required: ${o.toString()}
|
|
17
17
|
Approved: ${a.toString()}`)),Object.keys(e).forEach(d=>{if(!d.includes(":")||n)return;const h=Cr(e[d].accounts);h.includes(d)||(n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces accounts don't satisfy namespace accounts for ${d}
|
|
18
18
|
Required: ${d}
|
|
19
|
-
Approved: ${h.toString()}`))}),o.forEach(d=>{n||(An(r[d].methods,i[d].methods)?An(r[d].events,i[d].events)||(n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces events don't satisfy namespace events for ${d}`)):n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces methods don't satisfy namespace methods for ${d}`))}),n}function SE(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 Hu(t){return[...new Set(t.map(e=>e.includes(":")?e.split(":")[0]:e))]}function NE(t){const e={};return Object.keys(t).forEach(s=>{if(s.includes(":"))e[s]=t[s];else{const n=Cr(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 TE(t,e){return ul(t,!1)&&t<=e.max&&t>=e.min}function Ku(){const t=Pi();return new Promise(e=>{switch(t){case Ot.browser:e(OE());break;case Ot.reactNative:e(PE());break;case Ot.node:e(kE());break;default:e(!0)}})}function OE(){return Er()&&(navigator==null?void 0:navigator.onLine)}async function PE(){if(on()&&typeof global<"u"&&global!=null&&global.NetInfo){const t=await(global==null?void 0:global.NetInfo.fetch());return t==null?void 0:t.isConnected}return!0}function kE(){return!0}function RE(t){switch(Pi()){case Ot.browser:xE(t);break;case Ot.reactNative:$E(t);break}}function xE(t){!on()&&Er()&&(window.addEventListener("online",()=>t(!0)),window.addEventListener("offline",()=>t(!1)))}function $E(t){on()&&typeof global<"u"&&global!=null&&global.NetInfo&&(global==null||global.NetInfo.addEventListener(e=>t(e==null?void 0:e.isConnected)))}function UE(){var t;return Er()&&ur()?((t=ur())==null?void 0:t.visibilityState)==="visible":!0}const Pa={};class Tr{static get(e){return Pa[e]}static set(e,s){Pa[e]=s}static delete(e){delete Pa[e]}}function DE(t){const e=br.decode(t);if(e.length<33)throw new Error("Too short to contain a public key");return e.slice(1,33)}function LE({publicKey:t,signature:e,payload:s}){var n;const r=Ec(s.method),i=128|parseInt(((n=s.version)==null?void 0:n.toString())||"4"),o=jE(s.address),a=s.era==="00"?new Uint8Array([0]):Ec(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]),u=BigInt(`0x${BE(s.tip)}`),d=qE(u),h=new Uint8Array([0,...t,o,...e,...a,...l,...d,...r]),p=FE(h.length+1);return new Uint8Array([...p,i,...h])}function ME(t){const e=Ec(t),s=Bf.blake2b(e,void 0,32);return"0x"+Buffer.from(s).toString("hex")}function Ec(t){return new Uint8Array(t.replace(/^0x/,"").match(/.{1,2}/g).map(e=>parseInt(e,16)))}function BE(t){return t.startsWith("0x")?t.slice(2):t}function jE(t){const e=br.decode(t)[0];return e===42?0:e===60?2:1}function FE(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 qE(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 WE(t){const e=Uint8Array.from(Buffer.from(t.signature,"hex")),s=DE(t.transaction.address),n=LE({publicKey:s,signature:e,payload:t.transaction}),r=Buffer.from(n).toString("hex");return ME(r)}function dl({logger:t,name:e}){const s=typeof t=="string"?Oh({opts:{level:t,name:e}}).logger:t;return s.level=typeof t=="string"?t:t.level,s}var HE={};const $p="wc",Up=2,Cc="core",gs=`${$p}@2:${Cc}:`,KE={logger:"error"},zE={database:":memory:"},VE="crypto",zu="client_ed25519_seed",GE=F.ONE_DAY,YE="keychain",JE="0.3",XE="messages",ZE="0.3",QE=F.SIX_HOURS,eC="publisher",Dp="irn",tC="error",Lp="wss://relay.walletconnect.org",sC="relayer",Le={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"},nC="_subscription",xt={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},rC=.1,Ac="2.22.4",Pe={link_mode:"link_mode",relay:"relay"},mo={inbound:"inbound",outbound:"outbound"},iC="0.3",oC="WALLETCONNECT_CLIENT_ID",Vu="WALLETCONNECT_LINK_MODE_APPS",_t={created:"subscription_created",deleted:"subscription_deleted",expired:"subscription_expired",disabled:"subscription_disabled",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},aC="subscription",cC="0.3",lC="pairing",uC="0.3",Or={wc_pairingDelete:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:F.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:F.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:F.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:F.ONE_DAY,prompt:!1,tag:0},res:{ttl:F.ONE_DAY,prompt:!1,tag:0}}},wn={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},Vt={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},dC="history",hC="0.3",pC="expirer",Mt={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},fC="0.3",gC="verify-api",mC="https://verify.walletconnect.com",Mp="https://verify.walletconnect.org",Kr=Mp,yC=`${Kr}/v3`,wC=[mC,Mp],bC="echo",vC="https://echo.walletconnect.com",is={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"},vs={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"},Gt={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"},hn={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"},pn={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"},Pr={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"},EC=.1,CC="event-client",AC=86400,IC="https://pulse.walletconnect.org/batch";function _C(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),u=Math.log(256)/Math.log(a);function d(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,w=0,b=g.length;w!==b&&g[w]===0;)w++,f++;for(var E=(b-w)*u+1>>>0,N=new Uint8Array(E);w!==b;){for(var x=g[w],$=0,W=E-1;(x!==0||$<y)&&W!==-1;W--,$++)x+=256*N[W]>>>0,N[W]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");y=$,w++}for(var G=E-y;G!==E&&N[G]===0;)G++;for(var k=c.repeat(f);G<E;++G)k+=t.charAt(N[G]);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,w=0;g[f]===c;)y++,f++;for(var b=(g.length-f)*l+1>>>0,E=new Uint8Array(b);g[f];){var N=s[g.charCodeAt(f)];if(N===255)return;for(var x=0,$=b-1;(N!==0||x<w)&&$!==-1;$--,x++)N+=a*E[$]>>>0,E[$]=N%256>>>0,N=N/256>>>0;if(N!==0)throw new Error("Non-zero carry");w=x,f++}if(g[f]!==" "){for(var W=b-w;W!==b&&E[W]===0;)W++;for(var G=new Uint8Array(y+(b-W)),k=y;W!==b;)G[k++]=E[W++];return G}}}function p(g){var f=h(g);if(f)return f;throw new Error(`Non-${e} character`)}return{encode:d,decodeUnsafe:h,decode:p}}var SC=_C,NC=SC;const Bp=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")},TC=t=>new TextEncoder().encode(t),OC=t=>new TextDecoder().decode(t);class PC{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 kC{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 jp(this,e)}}class RC{constructor(e){this.decoders=e}or(e){return jp(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 jp=(t,e)=>new RC({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}});class xC{constructor(e,s,n,r){this.name=e,this.prefix=s,this.baseEncode=n,this.baseDecode=r,this.encoder=new PC(e,s,n),this.decoder=new kC(e,s,r)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const na=({name:t,prefix:e,encode:s,decode:n})=>new xC(t,e,s,n),Ui=({prefix:t,name:e,alphabet:s})=>{const{encode:n,decode:r}=NC(s,e);return na({prefix:t,name:e,encode:n,decode:i=>Bp(r(i))})},$C=(t,e,s,n)=>{const r={};for(let u=0;u<e.length;++u)r[e[u]]=u;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 u=0;u<i;++u){const d=r[t[u]];if(d===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<s|d,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},UC=(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},et=({name:t,prefix:e,bitsPerChar:s,alphabet:n})=>na({prefix:e,name:t,encode(r){return UC(r,n,s)},decode(r){return $C(r,n,s,t)}}),DC=na({prefix:"\0",name:"identity",encode:t=>OC(t),decode:t=>TC(t)});var LC=Object.freeze({__proto__:null,identity:DC});const MC=et({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var BC=Object.freeze({__proto__:null,base2:MC});const jC=et({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var FC=Object.freeze({__proto__:null,base8:jC});const qC=Ui({prefix:"9",name:"base10",alphabet:"0123456789"});var WC=Object.freeze({__proto__:null,base10:qC});const HC=et({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),KC=et({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var zC=Object.freeze({__proto__:null,base16:HC,base16upper:KC});const VC=et({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),GC=et({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),YC=et({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),JC=et({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),XC=et({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ZC=et({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),QC=et({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),e1=et({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),t1=et({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var s1=Object.freeze({__proto__:null,base32:VC,base32upper:GC,base32pad:YC,base32padupper:JC,base32hex:XC,base32hexupper:ZC,base32hexpad:QC,base32hexpadupper:e1,base32z:t1});const n1=Ui({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),r1=Ui({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var i1=Object.freeze({__proto__:null,base36:n1,base36upper:r1});const o1=Ui({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),a1=Ui({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var c1=Object.freeze({__proto__:null,base58btc:o1,base58flickr:a1});const l1=et({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),u1=et({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),d1=et({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),h1=et({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var p1=Object.freeze({__proto__:null,base64:l1,base64pad:u1,base64url:d1,base64urlpad:h1});const Fp=Array.from("🚀🪐☄🛰🌌🌑🌒🌓🌔🌕🌖🌗🌘🌍🌏🌎🐉☀💻🖥💾💿😂❤😍🤣😊🙏💕😭😘👍😅👏😁🔥🥰💔💖💙😢🤔😆🙄💪😉☺👌🤗💜😔😎😇🌹🤦🎉💞✌✨🤷😱😌🌸🙌😋💗💚😏💛🙂💓🤩😄😀🖤😃💯🙈👇🎶😒🤭❣😜💋👀😪😑💥🙋😞😩😡🤪👊🥳😥🤤👉💃😳✋😚😝😴🌟😬🙃🍀🌷😻😓⭐✅🥺🌈😈🤘💦✔😣🏃💐☹🎊💘😠☝😕🌺🎂🌻😐🖕💝🙊😹🗣💫💀👑🎵🤞😛🔴😤🌼😫⚽🤙☕🏆🤫👈😮🙆🍻🍃🐶💁😲🌿🧡🎁⚡🌞🎈❌✊👋😰🤨😶🤝🚶💰🍓💢🤟🙁🚨💨🤬✈🎀🍺🤓😙💟🌱😖👶🥴▶➡❓💎💸⬇😨🌚🦋😷🕺⚠🙅😟😵👎🤲🤠🤧📌🔵💅🧐🐾🍒😗🤑🌊🤯🐷☎💧😯💆👆🎤🙇🍑❄🌴💣🐸💌📍🥀🤢👅💡💩👐📸👻🤐🤮🎼🥵🚩🍎🍊👼💍📣🥂"),f1=Fp.reduce((t,e,s)=>(t[s]=e,t),[]),g1=Fp.reduce((t,e,s)=>(t[e.codePointAt(0)]=s,t),[]);function m1(t){return t.reduce((e,s)=>(e+=f1[s],e),"")}function y1(t){const e=[];for(const s of t){const n=g1[s.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${s}`);e.push(n)}return new Uint8Array(e)}const w1=na({prefix:"🚀",name:"base256emoji",encode:m1,decode:y1});var b1=Object.freeze({__proto__:null,base256emoji:w1}),v1=qp,Gu=128,E1=-128,C1=Math.pow(2,31);function qp(t,e,s){e=e||[],s=s||0;for(var n=s;t>=C1;)e[s++]=t&255|Gu,t/=128;for(;t&E1;)e[s++]=t&255|Gu,t>>>=7;return e[s]=t|0,qp.bytes=s-n+1,e}var A1=Ic,I1=128,Yu=127;function Ic(t,n){var s=0,n=n||0,r=0,i=n,o,a=t.length;do{if(i>=a)throw Ic.bytes=0,new RangeError("Could not decode varint");o=t[i++],s+=r<28?(o&Yu)<<r:(o&Yu)*Math.pow(2,r),r+=7}while(o>=I1);return Ic.bytes=i-n,s}var _1=Math.pow(2,7),S1=Math.pow(2,14),N1=Math.pow(2,21),T1=Math.pow(2,28),O1=Math.pow(2,35),P1=Math.pow(2,42),k1=Math.pow(2,49),R1=Math.pow(2,56),x1=Math.pow(2,63),$1=function(t){return t<_1?1:t<S1?2:t<N1?3:t<T1?4:t<O1?5:t<P1?6:t<k1?7:t<R1?8:t<x1?9:10},U1={encode:v1,decode:A1,encodingLength:$1},Wp=U1;const Ju=(t,e,s=0)=>(Wp.encode(t,e,s),e),Xu=t=>Wp.encodingLength(t),_c=(t,e)=>{const s=e.byteLength,n=Xu(t),r=n+Xu(s),i=new Uint8Array(r+s);return Ju(t,i,0),Ju(s,i,n),i.set(e,r),new D1(t,s,e,i)};class D1{constructor(e,s,n,r){this.code=e,this.size=s,this.digest=n,this.bytes=r}}const Hp=({name:t,code:e,encode:s})=>new L1(t,e,s);class L1{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?_c(this.code,s):s.then(n=>_c(this.code,n))}else throw Error("Unknown type, must be binary type")}}const Kp=t=>async e=>new Uint8Array(await crypto.subtle.digest(t,e)),M1=Hp({name:"sha2-256",code:18,encode:Kp("SHA-256")}),B1=Hp({name:"sha2-512",code:19,encode:Kp("SHA-512")});var j1=Object.freeze({__proto__:null,sha256:M1,sha512:B1});const zp=0,F1="identity",Vp=Bp,q1=t=>_c(zp,Vp(t)),W1={code:zp,name:F1,encode:Vp,digest:q1};var H1=Object.freeze({__proto__:null,identity:W1});new TextEncoder,new TextDecoder;const Zu={...LC,...BC,...FC,...WC,...zC,...s1,...i1,...c1,...p1,...b1};({...j1,...H1});function Gp(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function K1(t=0){return globalThis.Buffer!=null&&globalThis.Buffer.allocUnsafe!=null?Gp(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Yp(t,e,s,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:s},decoder:{decode:n}}}const Qu=Yp("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),ka=Yp("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=K1(t.length);for(let s=0;s<t.length;s++)e[s]=t.charCodeAt(s);return e}),z1={utf8:Qu,"utf-8":Qu,hex:Zu.base16,latin1:ka,ascii:ka,binary:ka,...Zu};function V1(t,e="utf8"){const s=z1[e];if(!s)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Gp(globalThis.Buffer.from(t,"utf-8")):s.decoder.decode(`${s.prefix}${t}`)}var G1=Object.defineProperty,Y1=(t,e,s)=>e in t?G1(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ns=(t,e,s)=>Y1(t,typeof e!="symbol"?e+"":e,s);class J1{constructor(e,s){this.core=e,this.logger=s,ns(this,"keychain",new Map),ns(this,"name",YE),ns(this,"version",JE),ns(this,"initialized",!1),ns(this,"storagePrefix",gs),ns(this,"init",async()=>{if(!this.initialized){const n=await this.getKeyChain();typeof n<"u"&&(this.keychain=n),this.initialized=!0}}),ns(this,"has",n=>(this.isInitialized(),this.keychain.has(n))),ns(this,"set",async(n,r)=>{this.isInitialized(),this.keychain.set(n,r),await this.persist()}),ns(this,"get",n=>{this.isInitialized();const r=this.keychain.get(n);if(typeof r>"u"){const{message:i}=M("NO_MATCHING_KEY",`${this.name}: ${n}`);throw new Error(i)}return r}),ns(this,"del",async n=>{this.isInitialized(),this.keychain.delete(n),await this.persist()}),this.core=e,this.logger=kt(s,this.name)}get context(){return Et(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,cc(e))}async getKeyChain(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?lc(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var X1=Object.defineProperty,Z1=(t,e,s)=>e in t?X1(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,He=(t,e,s)=>Z1(t,typeof e!="symbol"?e+"":e,s);class Q1{constructor(e,s,n){this.core=e,this.logger=s,He(this,"name",VE),He(this,"keychain"),He(this,"randomSessionIdentifier",vc()),He(this,"initialized",!1),He(this,"clientId"),He(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),He(this,"hasKeys",r=>(this.isInitialized(),this.keychain.has(r))),He(this,"getClientId",async()=>{if(this.isInitialized(),this.clientId)return this.clientId;const r=await this.getClientSeed(),i=Cl(r),o=Hf(i.publicKey);return this.clientId=o,o}),He(this,"generateKeyPair",()=>{this.isInitialized();const r=N0();return this.setPrivateKey(r.publicKey,r.privateKey)}),He(this,"signJWT",async r=>{this.isInitialized();const i=await this.getClientSeed(),o=Cl(i),a=this.randomSessionIdentifier;return await Kf(a,r,GE,o)}),He(this,"generateSharedKey",(r,i,o)=>{this.isInitialized();const a=this.getPrivateKey(r),c=T0(a,i);return this.setSymKey(c,o)}),He(this,"setSymKey",async(r,i)=>{this.isInitialized();const o=i||go(r);return await this.keychain.set(o,r),o}),He(this,"deleteKeyPair",async r=>{this.isInitialized(),await this.keychain.del(r)}),He(this,"deleteSymKey",async r=>{this.isInitialized(),await this.keychain.del(r)}),He(this,"encode",async(r,i,o)=>{this.isInitialized();const a=kp(o),c=Rn(i);if(Ru(a))return k0(c,o==null?void 0:o.encoding);if(ku(a)){const h=a.senderPublicKey,p=a.receiverPublicKey;r=await this.generateSharedKey(h,p)}const l=this.getSymKey(r),{type:u,senderPublicKey:d}=a;return O0({type:u,symKey:l,message:c,senderPublicKey:d,encoding:o==null?void 0:o.encoding})}),He(this,"decode",async(r,i,o)=>{this.isInitialized();const a=x0(i,o);if(Ru(a)){const c=R0(i,o==null?void 0:o.encoding);return Eo(c)}if(ku(a)){const c=a.receiverPublicKey,l=a.senderPublicKey;r=await this.generateSharedKey(c,l)}try{const c=this.getSymKey(r),l=P0({symKey:c,encoded:i,encoding:o==null?void 0:o.encoding});return Eo(l)}catch(c){this.logger.error(`Failed to decode message from topic: '${r}', clientId: '${await this.getClientId()}'`),this.logger.error(c)}}),He(this,"getPayloadType",(r,i=yt)=>{const o=Ci({encoded:r,encoding:i});return Dn(o.type)}),He(this,"getPayloadSenderPublicKey",(r,i=yt)=>{const o=Ci({encoded:r,encoding:i});return o.senderPublicKey?bt(o.senderPublicKey,lt):void 0}),this.core=e,this.logger=kt(s,this.name),this.keychain=n||new J1(this.core,this.logger)}get context(){return Et(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(zu)}catch{e=vc(),await this.keychain.set(zu,e)}return V1(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var eA=Object.defineProperty,tA=Object.defineProperties,sA=Object.getOwnPropertyDescriptors,ed=Object.getOwnPropertySymbols,nA=Object.prototype.hasOwnProperty,rA=Object.prototype.propertyIsEnumerable,Sc=(t,e,s)=>e in t?eA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,iA=(t,e)=>{for(var s in e||(e={}))nA.call(e,s)&&Sc(t,s,e[s]);if(ed)for(var s of ed(e))rA.call(e,s)&&Sc(t,s,e[s]);return t},oA=(t,e)=>tA(t,sA(e)),At=(t,e,s)=>Sc(t,typeof e!="symbol"?e+"":e,s);class aA extends uw{constructor(e,s){super(e,s),this.logger=e,this.core=s,At(this,"messages",new Map),At(this,"messagesWithoutClientAck",new Map),At(this,"name",XE),At(this,"version",ZE),At(this,"initialized",!1),At(this,"storagePrefix",gs),At(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}}}),At(this,"set",async(n,r,i)=>{this.isInitialized();const o=Bt(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===mo.inbound){const c=this.messagesWithoutClientAck.get(n)||{};this.messagesWithoutClientAck.set(n,oA(iA({},c),{[o]:r}))}return await this.persist(),o}),At(this,"get",n=>{this.isInitialized();let r=this.messages.get(n);return typeof r>"u"&&(r={}),r}),At(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}),At(this,"has",(n,r)=>{this.isInitialized();const i=this.get(n),o=Bt(r);return typeof i[o]<"u"}),At(this,"ack",async(n,r)=>{this.isInitialized();const i=this.messagesWithoutClientAck.get(n);if(typeof i>"u")return;const o=Bt(r);delete i[o],Object.keys(i).length===0?this.messagesWithoutClientAck.delete(n):this.messagesWithoutClientAck.set(n,i),await this.persist()}),At(this,"del",async n=>{this.isInitialized(),this.messages.delete(n),this.messagesWithoutClientAck.delete(n),await this.persist()}),this.logger=kt(e,this.name),this.core=s}get context(){return Et(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,cc(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,cc(e))}async getRelayerMessages(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?lc(e):void 0}async getRelayerMessagesWithoutClientAck(){const e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return typeof e<"u"?lc(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var cA=Object.defineProperty,lA=Object.defineProperties,uA=Object.getOwnPropertyDescriptors,td=Object.getOwnPropertySymbols,dA=Object.prototype.hasOwnProperty,hA=Object.prototype.propertyIsEnumerable,Nc=(t,e,s)=>e in t?cA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gn=(t,e)=>{for(var s in e||(e={}))dA.call(e,s)&&Nc(t,s,e[s]);if(td)for(var s of td(e))hA.call(e,s)&&Nc(t,s,e[s]);return t},sd=(t,e)=>lA(t,uA(e)),$t=(t,e,s)=>Nc(t,typeof e!="symbol"?e+"":e,s);class pA extends dw{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,$t(this,"events",new Mn.EventEmitter),$t(this,"name",eC),$t(this,"queue",new Map),$t(this,"publishTimeout",F.toMiliseconds(F.ONE_MINUTE)),$t(this,"initialPublishTimeout",F.toMiliseconds(F.ONE_SECOND*15)),$t(this,"needsTransportRestart",!1),$t(this,"publish",async(n,r,i)=>{var o,a,c,l,u;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:n,message:r,opts:i}});const d=(i==null?void 0:i.ttl)||QE,h=(i==null?void 0:i.prompt)||!1,p=(i==null?void 0:i.tag)||0,g=(i==null?void 0:i.id)||En().toString(),f=tr(Uo().protocol),y={id:g,method:(i==null?void 0:i.publishMethod)||f.publish,params:Gn({topic:n,message:r,ttl:d,prompt:h,tag:p,attestation:i==null?void 0:i.attestation},i==null?void 0:i.tvf)},w=`Failed to publish payload, please try again. id:${g} tag:${p}`;try{We((o=y.params)==null?void 0:o.prompt)&&((a=y.params)==null||delete a.prompt),We((c=y.params)==null?void 0:c.tag)&&((l=y.params)==null||delete l.tag);const b=new Promise(async E=>{const N=({id:$})=>{var W;((W=y.id)==null?void 0:W.toString())===$.toString()&&(this.removeRequestFromQueue($),this.relayer.events.removeListener(Le.publish,N),E())};this.relayer.events.on(Le.publish,N);const x=us(new Promise(($,W)=>{this.rpcPublish(y,i).then($).catch(G=>{this.logger.warn(G,G==null?void 0:G.message),W(G)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${g} tag:${p}`);try{await x,this.events.removeListener(Le.publish,N)}catch($){this.queue.set(g,{request:y,opts:i,attempt:1}),this.logger.warn($,$==null?void 0:$.message)}});this.logger.trace({type:"method",method:"publish",params:{id:g,topic:n,message:r,opts:i}}),await us(b,this.publishTimeout,w)}catch(b){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(b),(u=i==null?void 0:i.internal)!=null&&u.throwOnFailedPublish)throw b}finally{this.queue.delete(g)}}),$t(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:u={}}=n,{attestation:d,tvf:h,publishMethod:p,prompt:g,tag:f,ttl:y=F.FIVE_MINUTES}=u,w=u.id||En().toString(),b=tr(Uo().protocol),E=p||b.publish,N={id:w,method:E,params:Gn(sd(Gn({},l),{ttl:y,prompt:g,tag:f,attestation:d}),h)},x=`Failed to publish custom payload, please try again. id:${w} tag:${f}`;try{We((r=N.params)==null?void 0:r.prompt)&&((i=N.params)==null||delete i.prompt),We((o=N.params)==null?void 0:o.tag)&&((a=N.params)==null||delete a.tag);const $=new Promise(async W=>{const G=({id:Q})=>{var se;((se=N.id)==null?void 0:se.toString())===Q.toString()&&(this.removeRequestFromQueue(Q),this.relayer.events.removeListener(Le.publish,G),W())};this.relayer.events.on(Le.publish,G);const k=us(new Promise((Q,se)=>{this.rpcPublish(N,u).then(Q).catch(T=>{this.logger.warn(T,T==null?void 0:T.message),se(T)})}),this.initialPublishTimeout,`Failed initial custom payload publish, retrying.... method:${E} id:${w} tag:${f}`);try{await k,this.events.removeListener(Le.publish,G)}catch(Q){this.queue.set(w,{request:N,opts:u,attempt:1}),this.logger.warn(Q,Q==null?void 0:Q.message)}});this.logger.trace({type:"method",method:"publish",params:{id:w,payload:l,opts:u}}),await us($,this.publishTimeout,x)}catch($){if(this.logger.debug("Failed to Publish Payload"),this.logger.error($),(c=u==null?void 0:u.internal)!=null&&c.throwOnFailedPublish)throw $}finally{this.queue.delete(w)}}),$t(this,"on",(n,r)=>{this.events.on(n,r)}),$t(this,"once",(n,r)=>{this.events.once(n,r)}),$t(this,"off",(n,r)=>{this.events.off(n,r)}),$t(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.relayer=e,this.logger=kt(s,this.name),this.registerEventListeners()}get context(){return Et(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(Le.publish,Gn(Gn({},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,sd(Gn({},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(vr.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(Le.connection_stalled);return}this.checkQueue()}),this.relayer.on(Le.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var fA=Object.defineProperty,gA=(t,e,s)=>e in t?fA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Yn=(t,e,s)=>gA(t,typeof e!="symbol"?e+"":e,s);class mA{constructor(){Yn(this,"map",new Map),Yn(this,"set",(e,s)=>{const n=this.get(e);this.exists(e,s)||this.map.set(e,[...n,s])}),Yn(this,"get",e=>this.map.get(e)||[]),Yn(this,"exists",(e,s)=>this.get(e).includes(s)),Yn(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)}),Yn(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var yA=Object.defineProperty,wA=Object.defineProperties,bA=Object.getOwnPropertyDescriptors,nd=Object.getOwnPropertySymbols,vA=Object.prototype.hasOwnProperty,EA=Object.prototype.propertyIsEnumerable,Tc=(t,e,s)=>e in t?yA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kr=(t,e)=>{for(var s in e||(e={}))vA.call(e,s)&&Tc(t,s,e[s]);if(nd)for(var s of nd(e))EA.call(e,s)&&Tc(t,s,e[s]);return t},Ra=(t,e)=>wA(t,bA(e)),Ne=(t,e,s)=>Tc(t,typeof e!="symbol"?e+"":e,s);class CA extends fw{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,Ne(this,"subscriptions",new Map),Ne(this,"topicMap",new mA),Ne(this,"events",new Mn.EventEmitter),Ne(this,"name",aC),Ne(this,"version",cC),Ne(this,"pending",new Map),Ne(this,"cached",[]),Ne(this,"initialized",!1),Ne(this,"storagePrefix",gs),Ne(this,"subscribeTimeout",F.toMiliseconds(F.ONE_MINUTE)),Ne(this,"initialSubscribeTimeout",F.toMiliseconds(F.ONE_SECOND*15)),Ne(this,"clientId"),Ne(this,"batchSubscribeTopicsLimit",500),Ne(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),Ne(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=Uo(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}}),Ne(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)}),Ne(this,"isSubscribed",n=>new Promise(r=>{r(this.topicMap.topics.includes(n))})),Ne(this,"isKnownTopic",n=>new Promise(r=>{r(this.topicMap.topics.includes(n)||this.pending.has(n)||this.cached.some(i=>i.topic===n))})),Ne(this,"on",(n,r)=>{this.events.on(n,r)}),Ne(this,"once",(n,r)=>{this.events.once(n,r)}),Ne(this,"off",(n,r)=>{this.events.off(n,r)}),Ne(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),Ne(this,"start",async()=>{await this.onConnect()}),Ne(this,"stop",async()=>{await this.onDisconnect()}),Ne(this,"restart",async()=>{await this.restore(),await this.onRestart()}),Ne(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)}),Ne(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(vr.pulse,async()=>{await this.checkPending()}),this.events.on(_t.created,async n=>{const r=_t.created;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()}),this.events.on(_t.deleted,async n=>{const r=_t.deleted;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()})}),this.relayer=e,this.logger=kt(s,this.name),this.clientId=""}get context(){return Et(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=Uo(n);await this.restartToComplete({topic:e,id:s,relay:r}),await this.rpcUnsubscribe(e,s,r);const i=$e("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)===Pe.relay)&&await this.restartToComplete({topic:e,id:e,relay:s});const a={method:tr(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)===Pe.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(a).catch(d=>this.logger.warn(d))},F.toMiliseconds(F.ONE_SECOND)),o;const l=new Promise(async d=>{const h=p=>{p.topic===e&&(this.events.removeListener(_t.created,h),d(p.id))};this.events.on(_t.created,h);try{const p=await us(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(_t.created,h),d(p)}catch{}}),u=await us(l,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!u&&c)throw new Error(`Subscribing to ${e} failed, please try again`);return u?o:null}catch(l){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(Le.connection_stalled),c)throw l}return null}async rpcBatchSubscribe(e){if(!e.length)return;const s=e[0].relay,n={method:tr(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 us(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(Le.connection_stalled)}}async rpcBatchFetchMessages(e){if(!e.length)return;const s=e[0].relay,n={method:tr(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 us(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(Le.connection_stalled)}return r}rpcUnsubscribe(e,s,n){const r={method:tr(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,Ra(kr({},s),{id:e})),this.pending.delete(s.topic)}onBatchSubscribe(e){e.length&&e.forEach(s=>{this.setSubscription(s.id,kr({},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,kr({},s)),this.topicMap.set(s.topic,e),this.events.emit(_t.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}=M("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(_t.deleted,Ra(kr({},n),{reason:s}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(_t.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(_t.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}=M("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=>Ra(kr({},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 Yw(F.toMiliseconds(F.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}=M("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 Bt(e+await this.getClientId())}}var AA=Object.defineProperty,rd=Object.getOwnPropertySymbols,IA=Object.prototype.hasOwnProperty,_A=Object.prototype.propertyIsEnumerable,Oc=(t,e,s)=>e in t?AA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,id=(t,e)=>{for(var s in e||(e={}))IA.call(e,s)&&Oc(t,s,e[s]);if(rd)for(var s of rd(e))_A.call(e,s)&&Oc(t,s,e[s]);return t},Ee=(t,e,s)=>Oc(t,typeof e!="symbol"?e+"":e,s);class SA extends hw{constructor(e){var s;super(e),Ee(this,"protocol","wc"),Ee(this,"version",2),Ee(this,"core"),Ee(this,"logger"),Ee(this,"events",new Mn.EventEmitter),Ee(this,"provider"),Ee(this,"messages"),Ee(this,"subscriber"),Ee(this,"publisher"),Ee(this,"name",sC),Ee(this,"transportExplicitlyClosed",!1),Ee(this,"initialized",!1),Ee(this,"connectionAttemptInProgress",!1),Ee(this,"relayUrl"),Ee(this,"projectId"),Ee(this,"packageName"),Ee(this,"bundleId"),Ee(this,"hasExperiencedNetworkDisruption",!1),Ee(this,"pingTimeout"),Ee(this,"heartBeatTimeout",F.toMiliseconds(F.THIRTY_SECONDS+F.FIVE_SECONDS)),Ee(this,"reconnectTimeout"),Ee(this,"connectPromise"),Ee(this,"reconnectInProgress",!1),Ee(this,"requestsInFlight",[]),Ee(this,"connectTimeout",F.toMiliseconds(F.ONE_SECOND*15)),Ee(this,"request",async n=>{var r,i;this.logger.debug("Publishing Request Payload");const o=n.id||En().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}}),Ee(this,"resetPingTimeout",()=>{Oo()&&(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))}),Ee(this,"onPayloadHandler",n=>{this.onProviderPayload(n),this.resetPingTimeout()}),Ee(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected 🛜"),this.startPingTimeout(),this.events.emit(Le.connect)}),Ee(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected 🛑"),this.requestsInFlight=[],this.onProviderDisconnect()}),Ee(this,"onProviderErrorHandler",n=>{this.logger.fatal(`Fatal socket error: ${n.message}`),this.events.emit(Le.error,n),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),Ee(this,"registerProviderListeners",()=>{this.provider.on(xt.payload,this.onPayloadHandler),this.provider.on(xt.connect,this.onConnectHandler),this.provider.on(xt.disconnect,this.onDisconnectHandler),this.provider.on(xt.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger=dl({logger:(s=e.logger)!=null?s:tC,name:this.name}),this.messages=new aA(this.logger,e.core),this.subscriber=new CA(this,this.logger),this.publisher=new pA(this,this.logger),this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||Lp,xw()?this.packageName=Ql():$w()&&(this.bundleId=Ql()),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 Et(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:Pe.relay},mo.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=u=>{u.topic===e&&(this.subscriber.off(_t.created,l),c())};return await Promise.all([new Promise(u=>{c=u,this.subscriber.on(_t.created,l)}),new Promise(async(u,d)=>{a=await this.subscriber.subscribe(e,id({internal:{throwOnFailedPublish:o}},s)).catch(h=>{o&&d(h)})||a,u()})]),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 us(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 Ku())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=Be(F.FIVE_MINUTES),i={topic:n,expiry:r,relay:{protocol:"irn"},active:!1};await this.core.pairing.pairings.set(n,i)}this.events.emit(Le.message,e),await this.recordMessageEvent(e,mo.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(xt.disconnect,i),await us(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(xt.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(xt.disconnect,c),await this.subscriber.start().then(o).catch(a).finally(()=>{this.provider.off(xt.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,F.toMiliseconds(s*1))),s++}}startPingTimeout(){var e,s,n,r,i;if(Oo())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 Fc(new Wf(Bw({sdkVersion:Ac,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}),qc(e)){if(!e.method.endsWith(nC))return;const s=e.params,{topic:n,message:r,publishedAt:i,attestation:o}=s.data,a={topic:n,message:r,publishedAt:i,transportType:Pe.relay,attestation:o};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(id({type:"event",event:s.id},a)),this.events.emit(s.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else Wc(e)&&this.events.emit(Le.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,mo.inbound),this.events.emit(Le.message,e))}async acknowledgePayload(e){const s=Yr(e.id,!0);await this.provider.connection.send(s)}unregisterProviderListeners(){this.provider.off(xt.payload,this.onPayloadHandler),this.provider.off(xt.connect,this.onConnectHandler),this.provider.off(xt.disconnect,this.onDisconnectHandler),this.provider.off(xt.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await Ku();RE(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(vr.pulse,async()=>{if(!this.transportExplicitlyClosed&&!this.connected&&UE())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(Le.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},F.toMiliseconds(rC)))))}isInitialized(){if(!this.initialized){const{message:e}=M("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 NA(t,e){return t===e||Number.isNaN(t)&&Number.isNaN(e)}function od(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function ad(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const TA="[object RegExp]",OA="[object String]",PA="[object Number]",kA="[object Boolean]",cd="[object Arguments]",RA="[object Symbol]",xA="[object Date]",$A="[object Map]",UA="[object Set]",DA="[object Array]",LA="[object Function]",MA="[object ArrayBuffer]",xa="[object Object]",BA="[object Error]",jA="[object DataView]",FA="[object Uint8Array]",qA="[object Uint8ClampedArray]",WA="[object Uint16Array]",HA="[object Uint32Array]",KA="[object BigUint64Array]",zA="[object Int8Array]",VA="[object Int16Array]",GA="[object Int32Array]",YA="[object BigInt64Array]",JA="[object Float32Array]",XA="[object Float64Array]";function ZA(){}function ld(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 QA(t,e,s){return Mr(t,e,void 0,void 0,void 0,void 0,s)}function Mr(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 zr(t,e,i,o)}return zr(t,e,i,o)}function zr(t,e,s,n){if(Object.is(t,e))return!0;let r=ad(t),i=ad(e);if(r===cd&&(r=xa),i===cd&&(i=xa),r!==i)return!1;switch(r){case OA:return t.toString()===e.toString();case PA:{const c=t.valueOf(),l=e.valueOf();return NA(c,l)}case kA:case xA:case RA:return Object.is(t.valueOf(),e.valueOf());case TA:return t.source===e.source&&t.flags===e.flags;case LA: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 $A:{if(t.size!==e.size)return!1;for(const[c,l]of t.entries())if(!e.has(c)||!Mr(l,e.get(c),c,t,e,s,n))return!1;return!0}case UA:{if(t.size!==e.size)return!1;const c=Array.from(t.values()),l=Array.from(e.values());for(let u=0;u<c.length;u++){const d=c[u],h=l.findIndex(p=>Mr(d,p,void 0,t,e,s,n));if(h===-1)return!1;l.splice(h,1)}return!0}case DA:case FA:case qA:case WA:case HA:case KA:case zA:case VA:case GA:case YA:case JA:case XA:{if(typeof Buffer<"u"&&Buffer.isBuffer(t)!==Buffer.isBuffer(e)||t.length!==e.length)return!1;for(let c=0;c<t.length;c++)if(!Mr(t[c],e[c],c,t,e,s,n))return!1;return!0}case MA:return t.byteLength!==e.byteLength?!1:zr(new Uint8Array(t),new Uint8Array(e),s,n);case jA:return t.byteLength!==e.byteLength||t.byteOffset!==e.byteOffset?!1:zr(new Uint8Array(t),new Uint8Array(e),s,n);case BA:return t.name===e.name&&t.message===e.message;case xa:{if(!(zr(t.constructor,e.constructor,s,n)||ld(t)&&ld(e)))return!1;const c=[...Object.keys(t),...od(t)],l=[...Object.keys(e),...od(e)];if(c.length!==l.length)return!1;for(let u=0;u<c.length;u++){const d=c[u],h=t[d];if(!Object.hasOwn(e,d))return!1;const p=e[d];if(!Mr(h,p,d,t,e,s,n))return!1}return!0}default:return!1}}finally{s.delete(t),s.delete(e)}}function eI(t,e){return QA(t,e,ZA)}var tI=Object.defineProperty,ud=Object.getOwnPropertySymbols,sI=Object.prototype.hasOwnProperty,nI=Object.prototype.propertyIsEnumerable,Pc=(t,e,s)=>e in t?tI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,dd=(t,e)=>{for(var s in e||(e={}))sI.call(e,s)&&Pc(t,s,e[s]);if(ud)for(var s of ud(e))nI.call(e,s)&&Pc(t,s,e[s]);return t},pt=(t,e,s)=>Pc(t,typeof e!="symbol"?e+"":e,s);class Wn extends pw{constructor(e,s,n,r=gs,i=void 0){super(e,s,n,r),this.core=e,this.logger=s,this.name=n,pt(this,"map",new Map),pt(this,"version",iC),pt(this,"cached",[]),pt(this,"initialized",!1),pt(this,"getKey"),pt(this,"storagePrefix",gs),pt(this,"recentlyDeleted",[]),pt(this,"recentlyDeletedLimit",200),pt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(o=>{this.getKey&&o!==null&&!We(o)?this.map.set(this.getKey(o),o):lE(o)?this.map.set(o.id,o):uE(o)&&this.map.set(o.topic,o)}),this.cached=[],this.initialized=!0)}),pt(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())}),pt(this,"get",o=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:o}),this.getData(o))),pt(this,"getAll",o=>(this.isInitialized(),o?this.values.filter(a=>Object.keys(o).every(c=>eI(a[c],o[c]))):this.values)),pt(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=dd(dd({},this.getData(o)),a);this.map.set(o,c),await this.persist()}),pt(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=kt(s,this.name),this.storagePrefix=r,this.getKey=i}get context(){return Et(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}=M("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(r),new Error(r)}const{message:n}=M("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}=M("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}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var rI=Object.defineProperty,iI=(t,e,s)=>e in t?rI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,pe=(t,e,s)=>iI(t,typeof e!="symbol"?e+"":e,s);class oI{constructor(e,s){this.core=e,this.logger=s,pe(this,"name",lC),pe(this,"version",uC),pe(this,"events",new jc),pe(this,"pairings"),pe(this,"initialized",!1),pe(this,"storagePrefix",gs),pe(this,"ignoredPayloadTypes",[Ps]),pe(this,"registeredMethods",[]),pe(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),pe(this,"register",({methods:n})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...n])]}),pe(this,"create",async n=>{this.isInitialized();const r=vc(),i=await this.core.crypto.setSymKey(r),o=Be(F.FIVE_MINUTES),a={protocol:Dp},c={topic:i,expiry:o,relay:a,active:!1,methods:n==null?void 0:n.methods},l=Du({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(wn.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}}),pe(this,"pair",async n=>{this.isInitialized();const r=this.core.eventClient.createEvent({properties:{topic:n==null?void 0:n.uri,trace:[is.pairing_started]}});this.isValidPair(n,r);const{topic:i,symKey:o,relay:a,expiryTimestamp:c,methods:l}=Uu(n.uri);r.props.properties.topic=i,r.addTrace(is.pairing_uri_validation_success),r.addTrace(is.pairing_uri_not_expired);let u;if(this.pairings.keys.includes(i)){if(u=this.pairings.get(i),r.addTrace(is.existing_pairing),u.active)throw r.setError(vs.active_pairing_already_exists),new Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(is.pairing_not_expired)}const d=c||Be(F.FIVE_MINUTES),h={topic:i,relay:a,expiry:d,active:!1,methods:l};this.core.expirer.set(i,d),await this.pairings.set(i,h),r.addTrace(is.store_new_pairing),n.activatePairing&&await this.activate({topic:i}),this.events.emit(wn.create,h),r.addTrace(is.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(o,i),r.addTrace(is.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(vs.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:a})}catch(p){throw r.setError(vs.subscribe_pairing_topic_failure),p}return r.addTrace(is.subscribe_pairing_topic_success),h}),pe(this,"activate",async({topic:n})=>{this.isInitialized();const r=Be(F.FIVE_MINUTES);this.core.expirer.set(n,r),await this.pairings.update(n,{active:!0,expiry:r})}),pe(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}=yn();this.events.once(Ae("pairing_ping",i),({error:l})=>{l?c(l):a()}),await o()}}),pe(this,"updateExpiry",async({topic:n,expiry:r})=>{this.isInitialized(),await this.pairings.update(n,{expiry:r})}),pe(this,"updateMetadata",async({topic:n,metadata:r})=>{this.isInitialized(),await this.pairings.update(n,{peerMetadata:r})}),pe(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),pe(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",$e("USER_DISCONNECTED")),await this.deletePairing(r))}),pe(this,"formatUriFromPairing",n=>{this.isInitialized();const{topic:r,relay:i,expiry:o,methods:a}=n,c=this.core.crypto.keychain.get(r);return Du({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:c,relay:i,expiryTimestamp:o,methods:a})}),pe(this,"sendRequest",async(n,r,i)=>{const o=as(r,i),a=await this.core.crypto.encode(n,o),c=Or[r].req;return this.core.history.set(n,o),this.core.relayer.publish(n,a,c),o.id}),pe(this,"sendResult",async(n,r,i)=>{const o=Yr(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Or[c].res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),pe(this,"sendError",async(n,r,i)=>{const o=sh(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Or[c]?Or[c].res:Or.unregistered_method.res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),pe(this,"deletePairing",async(n,r)=>{await this.core.relayer.unsubscribe(n),await Promise.all([this.pairings.delete(n,$e("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(n),r?Promise.resolve():this.core.expirer.del(n)])}),pe(this,"cleanup",async()=>{const n=this.pairings.getAll().filter(r=>cs(r.expiry));await Promise.all(n.map(r=>this.deletePairing(r.topic)))}),pe(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)}}),pe(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)}}),pe(this,"onPairingPingRequest",async(n,r)=>{const{id:i}=r;try{this.isValidPing({topic:n}),await this.sendResult(i,n,!0),this.events.emit(wn.ping,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),pe(this,"onPairingPingResponse",(n,r)=>{const{id:i}=r;setTimeout(()=>{ws(r)?this.events.emit(Ae("pairing_ping",i),{}):os(r)&&this.events.emit(Ae("pairing_ping",i),{error:r.error})},500)}),pe(this,"onPairingDeleteRequest",async(n,r)=>{const{id:i}=r;try{this.isValidDisconnect({topic:n}),await this.deletePairing(n),this.events.emit(wn.delete,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),pe(this,"onUnknownRpcMethodRequest",async(n,r)=>{const{id:i,method:o}=r;try{if(this.registeredMethods.includes(o))return;const a=$e("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)}}),pe(this,"onUnknownRpcMethodResponse",n=>{this.registeredMethods.includes(n)||this.logger.error($e("WC_METHOD_UNSUPPORTED",n))}),pe(this,"isValidPair",(n,r)=>{var i;if(!gt(n)){const{message:a}=M("MISSING_OR_INVALID",`pair() params: ${n}`);throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(!cE(n.uri)){const{message:a}=M("MISSING_OR_INVALID",`pair() uri: ${n.uri}`);throw r.setError(vs.malformed_pairing_uri),new Error(a)}const o=Uu(n==null?void 0:n.uri);if(!((i=o==null?void 0:o.relay)!=null&&i.protocol)){const{message:a}=M("MISSING_OR_INVALID","pair() uri#relay-protocol");throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(!(o!=null&&o.symKey)){const{message:a}=M("MISSING_OR_INVALID","pair() uri#symKey");throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(o!=null&&o.expiryTimestamp&&F.toMiliseconds(o==null?void 0:o.expiryTimestamp)<Date.now()){r.setError(vs.pairing_expired);const{message:a}=M("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw new Error(a)}}),pe(this,"isValidPing",async n=>{if(!gt(n)){const{message:i}=M("MISSING_OR_INVALID",`ping() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),pe(this,"isValidDisconnect",async n=>{if(!gt(n)){const{message:i}=M("MISSING_OR_INVALID",`disconnect() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),pe(this,"isValidPairingTopic",async n=>{if(!je(n,!1)){const{message:r}=M("MISSING_OR_INVALID",`pairing topic should be a string: ${n}`);throw new Error(r)}if(!this.pairings.keys.includes(n)){const{message:r}=M("NO_MATCHING_KEY",`pairing topic doesn't exist: ${n}`);throw new Error(r)}if(cs(this.pairings.get(n).expiry)){await this.deletePairing(n);const{message:r}=M("EXPIRED",`pairing topic: ${n}`);throw new Error(r)}}),this.core=e,this.logger=kt(s,this.name),this.pairings=new Wn(this.core,this.logger,this.name,this.storagePrefix)}get context(){return Et(this.logger)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}registerRelayerEvents(){this.core.relayer.on(Le.message,async e=>{const{topic:s,message:n,transportType:r}=e;if(this.pairings.keys.includes(s)&&r!==Pe.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(n)))try{const i=await this.core.crypto.decode(s,n);qc(i)?(this.core.history.set(s,i),await this.onRelayEventRequest({topic:s,payload:i})):Wc(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(Mt.expired,async e=>{const{topic:s}=$h(e.target);s&&this.pairings.keys.includes(s)&&(await this.deletePairing(s,!0),this.events.emit(wn.expire,{topic:s}))})}}var aI=Object.defineProperty,cI=(t,e,s)=>e in t?aI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ye=(t,e,s)=>cI(t,typeof e!="symbol"?e+"":e,s);class lI extends lw{constructor(e,s){super(e,s),this.core=e,this.logger=s,Ye(this,"records",new Map),Ye(this,"events",new Mn.EventEmitter),Ye(this,"name",dC),Ye(this,"version",hC),Ye(this,"cached",[]),Ye(this,"initialized",!1),Ye(this,"storagePrefix",gs),Ye(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)}),Ye(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:Be(F.THIRTY_DAYS)};this.records.set(o.id,o),this.persist(),this.events.emit(Vt.created,o)}),Ye(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=os(n)?{error:n.error}:{result:n.result},this.records.set(r.id,r),this.persist(),this.events.emit(Vt.updated,r))}),Ye(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))),Ye(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(Vt.deleted,i)}}),this.persist()}),Ye(this,"exists",async(n,r)=>(this.isInitialized(),this.records.has(r)?(await this.getRecord(r)).topic===n:!1)),Ye(this,"on",(n,r)=>{this.events.on(n,r)}),Ye(this,"once",(n,r)=>{this.events.once(n,r)}),Ye(this,"off",(n,r)=>{this.events.off(n,r)}),Ye(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=kt(s,this.name)}get context(){return Et(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:as(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}=M("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(Vt.sync)}async restore(){try{const e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){const{message:s}=M("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(Vt.created,e=>{const s=Vt.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Vt.updated,e=>{const s=Vt.updated;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Vt.deleted,e=>{const s=Vt.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.core.heartbeat.on(vr.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(s=>{F.toMiliseconds(s.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${s.id}`),this.records.delete(s.id),this.events.emit(Vt.deleted,s,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var uI=Object.defineProperty,dI=(t,e,s)=>e in t?uI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,rt=(t,e,s)=>dI(t,typeof e!="symbol"?e+"":e,s);class hI extends gw{constructor(e,s){super(e,s),this.core=e,this.logger=s,rt(this,"expirations",new Map),rt(this,"events",new Mn.EventEmitter),rt(this,"name",pC),rt(this,"version",fC),rt(this,"cached",[]),rt(this,"initialized",!1),rt(this,"storagePrefix",gs),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(Mt.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(Mt.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=kt(s,this.name)}get context(){return Et(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 jw(e);if(typeof e=="number")return Fw(e);const{message:s}=M("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(Mt.sync)}async restore(){try{const e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){const{message:s}=M("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}=M("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(n),new Error(n)}return s}checkExpiry(e,s){const{expiry:n}=s;F.toMiliseconds(n)-Date.now()<=0&&this.expire(e,s)}expire(e,s){this.expirations.delete(e),this.events.emit(Mt.expired,{target:e,expiration:s})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,s)=>this.checkExpiry(s,e))}registerEventListeners(){this.core.heartbeat.on(vr.pulse,()=>this.checkExpirations()),this.events.on(Mt.created,e=>{const s=Mt.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(Mt.expired,e=>{const s=Mt.expired;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(Mt.deleted,e=>{const s=Mt.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()})}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var pI=Object.defineProperty,fI=(t,e,s)=>e in t?pI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Me=(t,e,s)=>fI(t,typeof e!="symbol"?e+"":e,s);class gI extends mw{constructor(e,s,n){super(e,s,n),this.core=e,this.logger=s,this.store=n,Me(this,"name",gC),Me(this,"abortController"),Me(this,"isDevEnv"),Me(this,"verifyUrlV3",yC),Me(this,"storagePrefix",gs),Me(this,"version",Up),Me(this,"publicKey"),Me(this,"fetchPromise"),Me(this,"init",async()=>{var r;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&F.toMiliseconds((r=this.publicKey)==null?void 0:r.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),Me(this,"register",async r=>{if(!Er()||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=ur(),u=this.startAbortTimer(F.ONE_SECOND*5),d=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=w=>{if(w.data&&typeof w.data=="string")try{const b=JSON.parse(w.data);if(b.type==="verify_attestation"){if(Ya(b.attestation).payload.id!==o)return;clearInterval(u),l.body.removeChild(f),this.abortController.signal.removeEventListener("abort",g),window.removeEventListener("message",y),h(b.attestation===null?"":b.attestation)}}catch(b){this.logger.warn(b)}};l.body.appendChild(f),window.addEventListener("message",y,{signal:this.abortController.signal})});return this.logger.debug(d,"jwt attestation"),d}catch(l){this.logger.warn(l)}return""}),Me(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(Ya(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)}),Me(this,"fetchAttestation",async(r,i)=>{this.logger.debug(`resolving attestation: ${r} from url: ${i}`);const o=this.startAbortTimer(F.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}),Me(this,"getVerifyUrl",r=>{let i=r||Kr;return wC.includes(i)||(this.logger.info(`verify url: ${i}, not included in trusted list, assigning default: ${Kr}`),i=Kr),i}),Me(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);const r=this.startAbortTimer(F.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)}}),Me(this,"persistPublicKey",async r=>{this.logger.debug(r,"persisting public key to local storage"),await this.store.setItem(this.storeKey,r),this.publicKey=r}),Me(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),Me(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")}}),Me(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),Me(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}),Me(this,"validateAttestation",(r,i)=>{const o=U0(r,i.publicKey),a={hasExpired:F.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=kt(s,this.name),this.abortController=new AbortController,this.isDevEnv=Qc(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return Et(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),F.toMiliseconds(e))}}var mI=Object.defineProperty,yI=(t,e,s)=>e in t?mI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,hd=(t,e,s)=>yI(t,typeof e!="symbol"?e+"":e,s);class wI extends yw{constructor(e,s){super(e,s),this.projectId=e,this.logger=s,hd(this,"context",bC),hd(this,"registerDeviceToken",async n=>{const{clientId:r,token:i,notificationType:o,enableEncrypted:a=!1}=n,c=`${vC}/${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=kt(s,this.context)}}var bI=Object.defineProperty,pd=Object.getOwnPropertySymbols,vI=Object.prototype.hasOwnProperty,EI=Object.prototype.propertyIsEnumerable,kc=(t,e,s)=>e in t?bI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Rr=(t,e)=>{for(var s in e||(e={}))vI.call(e,s)&&kc(t,s,e[s]);if(pd)for(var s of pd(e))EI.call(e,s)&&kc(t,s,e[s]);return t},Ke=(t,e,s)=>kc(t,typeof e!="symbol"?e+"":e,s);class CI extends ww{constructor(e,s,n=!0){super(e,s,n),this.core=e,this.logger=s,Ke(this,"context",CC),Ke(this,"storagePrefix",gs),Ke(this,"storageVersion",EC),Ke(this,"events",new Map),Ke(this,"shouldPersist",!1),Ke(this,"init",async()=>{if(!Qc())try{const r={eventId:tu(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:Rh(this.core.relayer.protocol,this.core.relayer.version,Ac)}}};await this.sendEvent([r])}catch(r){this.logger.warn(r)}}),Ke(this,"createEvent",r=>{const{event:i="ERROR",type:o="",properties:{topic:a,trace:c}}=r,l=tu(),u=this.core.projectId||"",d=Date.now(),h=Rr({eventId:l,timestamp:d,props:{event:i,type:o,properties:{topic:a,trace:c}},bundleId:u,domain:this.getAppDomain()},this.setMethods(l));return this.telemetryEnabled&&(this.events.set(l,h),this.shouldPersist=!0),h}),Ke(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 Rr(Rr({},a),this.setMethods(a.eventId))}),Ke(this,"deleteEvent",r=>{const{eventId:i}=r;this.events.delete(i),this.shouldPersist=!0}),Ke(this,"setEventListeners",()=>{this.core.heartbeat.on(vr.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(r=>{F.fromMiliseconds(Date.now())-F.fromMiliseconds(r.timestamp)>AC&&(this.events.delete(r.eventId),this.shouldPersist=!0)})})}),Ke(this,"setMethods",r=>({addTrace:i=>this.addTrace(r,i),setError:i=>this.setError(r,i)})),Ke(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)}),Ke(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)}),Ke(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),Ke(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,Rr(Rr({},i),this.setMethods(i.eventId)))})}catch(r){this.logger.warn(r)}}),Ke(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)}}),Ke(this,"sendEvent",async r=>{const i=this.getAppDomain()?"":"&sp=desktop";return await fetch(`${IC}?projectId=${this.core.projectId}&st=events_sdk&sv=js-${Ac}${i}`,{method:"POST",body:JSON.stringify(r)})}),Ke(this,"getAppDomain",()=>kh().url),this.logger=kt(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 AI=Object.defineProperty,fd=Object.getOwnPropertySymbols,II=Object.prototype.hasOwnProperty,_I=Object.prototype.propertyIsEnumerable,Rc=(t,e,s)=>e in t?AI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,gd=(t,e)=>{for(var s in e||(e={}))II.call(e,s)&&Rc(t,s,e[s]);if(fd)for(var s of fd(e))_I.call(e,s)&&Rc(t,s,e[s]);return t},Te=(t,e,s)=>Rc(t,typeof e!="symbol"?e+"":e,s);let SI=class Jp extends iw{constructor(e){var s;super(e),Te(this,"protocol",$p),Te(this,"version",Up),Te(this,"name",Cc),Te(this,"relayUrl"),Te(this,"projectId"),Te(this,"customStoragePrefix"),Te(this,"events",new Mn.EventEmitter),Te(this,"logger"),Te(this,"heartbeat"),Te(this,"relayer"),Te(this,"crypto"),Te(this,"storage"),Te(this,"history"),Te(this,"expirer"),Te(this,"pairing"),Te(this,"verify"),Te(this,"echoClient"),Te(this,"linkModeSupportedApps"),Te(this,"eventClient"),Te(this,"initialized",!1),Te(this,"logChunkController"),Te(this,"on",(a,c)=>this.events.on(a,c)),Te(this,"once",(a,c)=>this.events.once(a,c)),Te(this,"off",(a,c)=>this.events.off(a,c)),Te(this,"removeListener",(a,c)=>this.events.removeListener(a,c)),Te(this,"dispatchEnvelope",({topic:a,message:c,sessionExists:l})=>{if(!a||!c)return;const u={topic:a,message:c,publishedAt:Date.now(),transportType:Pe.link_mode};this.relayer.onLinkMessageEvent(u,{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)||Lp,this.customStoragePrefix=e!=null&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";const r=Zy({level:typeof(e==null?void 0:e.logger)=="string"&&e.logger?e.logger:KE.logger,name:Cc}),{logger:i,chunkLoggerController:o}=Oh({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=kt(i,this.name),this.heartbeat=new qf,this.crypto=new Q1(this,this.logger,e==null?void 0:e.keychain),this.history=new lI(this,this.logger),this.expirer=new hI(this,this.logger),this.storage=e!=null&&e.storage?e.storage:new Ry(gd(gd({},zE),e==null?void 0:e.storageOptions)),this.relayer=new SA({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new oI(this,this.logger),this.verify=new gI(this,this.logger,this.storage),this.echoClient=new wI(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new CI(this,this.logger,e==null?void 0:e.telemetryEnabled),this.setGlobalCore(this)}static async init(e){const s=new Jp(e);await s.initialize();const n=await s.crypto.getClientId();return await s.storage.setItem(oC,n),s}get context(){return Et(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(Vu,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(Vu)||[],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 process<"u"&&HE.DISABLE_GLOBAL_CORE==="true"}catch{return!0}}};const NI=SI,Xp="wc",Zp=2,Qp="client",hl=`${Xp}@${Zp}:${Qp}:`,$a={name:Qp,logger:"error"},md="WALLETCONNECT_DEEPLINK_CHOICE",TI="proposal",yd="Proposal expired",OI="session",Jn=F.SEVEN_DAYS,PI="engine",Je={wc_sessionPropose:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1104},res:{ttl:F.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1106},res:{ttl:F.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1112},res:{ttl:F.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1114},res:{ttl:F.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:F.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:F.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1119}}},Ua={min:F.FIVE_MINUTES,max:F.SEVEN_DAYS},rs={idle:"IDLE",active:"ACTIVE"},kI={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:""}},RI="request",xI=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],$I="wc",UI="auth",DI="authKeys",LI="pairingTopics",MI="requests",ra=`${$I}@${1.5}:${UI}:`,yo=`${ra}:PUB_KEY`;var BI=Object.defineProperty,jI=Object.defineProperties,FI=Object.getOwnPropertyDescriptors,wd=Object.getOwnPropertySymbols,qI=Object.prototype.hasOwnProperty,WI=Object.prototype.propertyIsEnumerable,xc=(t,e,s)=>e in t?BI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ie=(t,e)=>{for(var s in e||(e={}))qI.call(e,s)&&xc(t,s,e[s]);if(wd)for(var s of wd(e))WI.call(e,s)&&xc(t,s,e[s]);return t},it=(t,e)=>jI(t,FI(e)),O=(t,e,s)=>xc(t,typeof e!="symbol"?e+"":e,s);class HI extends Cw{constructor(e){super(e),O(this,"name",PI),O(this,"events",new jc),O(this,"initialized",!1),O(this,"requestQueue",{state:rs.idle,queue:[]}),O(this,"sessionRequestQueue",{state:rs.idle,queue:[]}),O(this,"emittedSessionRequests",new Jw({limit:500})),O(this,"requestQueueDelay",F.ONE_SECOND),O(this,"expectedPairingMethodMap",new Map),O(this,"recentlyDeletedMap",new Map),O(this,"recentlyDeletedLimit",200),O(this,"relayMessageCache",[]),O(this,"pendingSessions",new Map),O(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(Je)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},F.toMiliseconds(this.requestQueueDelay)))}),O(this,"connect",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();const n=it(Ie({},s),{requiredNamespaces:s.requiredNamespaces||{},optionalNamespaces:s.optionalNamespaces||{}});await this.isValidConnect(n),n.optionalNamespaces=nE(n.requiredNamespaces,n.optionalNamespaces),n.requiredNamespaces={};const{pairingTopic:r,requiredNamespaces:i,optionalNamespaces:o,sessionProperties:a,scopedProperties:c,relays:l}=n;let u=r,d,h=!1;try{if(u){const $=this.client.core.pairing.pairings.get(u);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),h=$.active}}catch($){throw this.client.logger.error(`connect() -> pairing.get(${u}) failed`),$}if(!u||!h){const{topic:$,uri:W}=await this.client.core.pairing.create({internal:{skipSubscribe:!0}});u=$,d=W}if(!u){const{message:$}=M("NO_MATCHING_KEY",`connect() pairing topic: ${u}`);throw new Error($)}const p=await this.client.core.crypto.generateKeyPair(),g=Je.wc_sessionPropose.req.ttl||F.FIVE_MINUTES,f=Be(g),y=it(Ie(Ie({requiredNamespaces:i,optionalNamespaces:o,relays:l??[{protocol:Dp}],proposer:{publicKey:p,metadata:this.client.metadata},expiryTimestamp:f,pairingTopic:u},a&&{sessionProperties:a}),c&&{scopedProperties:c}),{id:Us()}),w=Ae("session_connect",y.id),{reject:b,resolve:E,done:N}=yn(g,yd),x=({id:$})=>{$===y.id&&(this.client.events.off("proposal_expire",x),this.pendingSessions.delete(y.id),this.events.emit(w,{error:{message:yd,code:0}}))};return this.client.events.on("proposal_expire",x),this.events.once(w,({error:$,session:W})=>{this.client.events.off("proposal_expire",x),$?b($):W&&E(W)}),await this.sendProposeSession({proposal:y,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:y.id}}}),await this.setProposal(y.id,y),{uri:d,approval:N}}),O(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}}),O(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:[Gt.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(k){throw o.setError(hn.no_internet_connection),k}try{await this.isValidProposalId(s==null?void 0:s.id)}catch(k){throw this.client.logger.error(`approve() -> proposal.get(${s==null?void 0:s.id}) failed`),o.setError(hn.proposal_not_found),k}try{await this.isValidApprove(s)}catch(k){throw this.client.logger.error("approve() -> isValidApprove() failed"),o.setError(hn.session_approve_namespace_validation_failure),k}const{id:a,relayProtocol:c,namespaces:l,sessionProperties:u,scopedProperties:d,sessionConfig:h}=s,p=this.client.proposal.get(a);this.client.core.eventClient.deleteEvent({eventId:o.eventId});const{pairingTopic:g,proposer:f,requiredNamespaces:y,optionalNamespaces:w}=p;let b=(r=this.client.core.eventClient)==null?void 0:r.getEvent({topic:g});b||(b=(i=this.client.core.eventClient)==null?void 0:i.createEvent({type:Gt.session_approve_started,properties:{topic:g,trace:[Gt.session_approve_started,Gt.session_namespaces_validation_success]}}));const E=await this.client.core.crypto.generateKeyPair(),N=f.publicKey,x=await this.client.core.crypto.generateSharedKey(E,N),$=Ie(Ie(Ie({relay:{protocol:c??"irn"},namespaces:l,controller:{publicKey:E,metadata:this.client.metadata},expiry:Be(Jn)},u&&{sessionProperties:u}),d&&{scopedProperties:d}),h&&{sessionConfig:h}),W=Pe.relay;b.addTrace(Gt.subscribing_session_topic);try{await this.client.core.relayer.subscribe(x,{transportType:W,internal:{skipSubscribe:!0}})}catch(k){throw b.setError(hn.subscribe_session_topic_failure),k}b.addTrace(Gt.subscribe_session_topic_success);const G=it(Ie({},$),{topic:x,requiredNamespaces:y,optionalNamespaces:w,pairingTopic:g,acknowledged:!1,self:$.controller,peer:{publicKey:f.publicKey,metadata:f.metadata},controller:E,transportType:Pe.relay});await this.client.session.set(x,G),b.addTrace(Gt.store_session);try{await this.sendApproveSession({sessionTopic:x,proposal:p,pairingProposalResponse:{relay:{protocol:c??"irn"},responderPublicKey:E},sessionSettleRequest:$,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:a}}}),b.addTrace(Gt.session_approve_publish_success)}catch(k){throw this.client.logger.error(k),this.client.session.delete(x,$e("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(x),k}return this.client.core.eventClient.deleteEvent({eventId:b.eventId}),await this.client.core.pairing.updateMetadata({topic:g,metadata:f.metadata}),await this.deleteProposal(a),await this.client.core.pairing.activate({topic:g}),await this.setExpiry(x,Be(Jn)),{topic:x,acknowledged:()=>Promise.resolve(this.client.session.get(x))}}),O(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:Je.wc_sessionPropose.reject}),await this.deleteProposal(n)}),O(this,"update",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(s)}catch(d){throw this.client.logger.error("update() -> isValidUpdate() failed"),d}const{topic:n,namespaces:r}=s,{done:i,resolve:o,reject:a}=yn(),c=Us(),l=En().toString(),u=this.client.session.get(n).namespaces;return this.events.once(Ae("session_update",c),({error:d})=>{d?a(d):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(d=>{this.client.logger.error(d),this.client.session.update(n,{namespaces:u}),a(d)}),{acknowledged:i}}),O(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=Us(),{done:i,resolve:o,reject:a}=yn();return this.events.once(Ae("session_extend",r),({error:c})=>{c?a(c):o()}),await this.setExpiry(n,Be(Jn)),this.sendRequest({topic:n,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(c=>{a(c)}),{acknowledged:i}}),O(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=Je.wc_sessionRequest.req.ttl}=s,a=this.client.session.get(i);(a==null?void 0:a.transportType)===Pe.relay&&await this.confirmOnlineStateOrThrow();const c=Us(),l=En().toString(),{done:u,resolve:d,reject:h}=yn(o,"Request expired. Please try again.");this.events.once(Ae("session_request",c),({error:y,result:w})=>{y?h(y):d(w)});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:it(Ie({},r),{expiryTimestamp:Be(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 u();const f={request:it(Ie({},r),{expiryTimestamp:Be(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(w=>h(w)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),y()}),new Promise(async y=>{var w;if(!((w=a.sessionConfig)!=null&&w.disableDeepLink)){const b=await Kw(this.client.core.storage,md);await qw({id:c,topic:i,wcDeepLink:b})}y()}),u()]).then(y=>y[2])}),O(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:[Gt.session_request_response_started]}});try{await this.isValidRespond(s)}catch(d){throw i.addTrace(d==null?void 0:d.message),i.setError(hn.session_request_response_validation_failure),d}i.addTrace(Gt.session_request_response_validation_success);const{topic:o,response:a}=s,{id:c}=a,l=this.client.session.get(o);l.transportType===Pe.relay&&await this.confirmOnlineStateOrThrow();const u=this.getAppLinkIfEnabled(l.peer.metadata,l.transportType);try{i.addTrace(Gt.session_request_response_publish_started),ws(a)?await this.sendResult({id:c,topic:o,result:a.result,throwOnFailedPublish:!0,appLink:u}):os(a)&&await this.sendError({id:c,topic:o,error:a.error,appLink:u}),this.cleanupAfterResponse(s)}catch(d){throw i.addTrace(d==null?void 0:d.message),i.setError(hn.session_request_response_publish_failure),d}}),O(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=Us(),i=En().toString(),{done:o,resolve:a,reject:c}=yn();this.events.once(Ae("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}))}),O(this,"emit",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(s);const{topic:n,event:r,chainId:i}=s,o=En().toString(),a=Us();await this.sendRequest({topic:n,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:o,clientRpcId:a})}),O(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:$e("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}=M("MISMATCHED_TOPIC",`Session or pairing topic not found: ${n}`);throw new Error(r)}}),O(this,"find",s=>(this.isInitialized(),this.client.session.getAll().filter(n=>oE(n,s)))),O(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),O(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?Pe.link_mode:Pe.relay;o===Pe.relay&&await this.confirmOnlineStateOrThrow();const{chains:a,statement:c="",uri:l,domain:u,nonce:d,type:h,exp:p,nbf:g,methods:f=[],expiry:y}=s,w=[...s.resources||[]],{topic:b,uri:E}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:b,uri:E}});const N=await this.client.core.crypto.generateKeyPair(),x=go(N);if(await Promise.all([this.client.auth.authKeys.set(yo,{responseTopic:x,publicKey:N}),this.client.auth.pairingTopics.set(x,{topic:x,pairingTopic:b})]),await this.client.core.relayer.subscribe(x,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${b}`),f.length>0){const{namespace:I}=Os(a[0]);let R=av(I,"request",f);fo(w)&&(R=lv(R,w.pop())),w.push(R)}const $=y&&y>Je.wc_sessionAuthenticate.req.ttl?y:Je.wc_sessionAuthenticate.req.ttl,W={authPayload:{type:h??"caip122",chains:a,statement:c,aud:l,domain:u,version:"1",nonce:d,iat:new Date().toISOString(),exp:p,nbf:g,resources:w},requester:{publicKey:N,metadata:this.client.metadata},expiryTimestamp:Be($)},G={eip155:{chains:a,methods:[...new Set(["personal_sign",...f])],events:["chainChanged","accountsChanged"]}},k={requiredNamespaces:{},optionalNamespaces:G,relays:[{protocol:"irn"}],pairingTopic:b,proposer:{publicKey:N,metadata:this.client.metadata},expiryTimestamp:Be(Je.wc_sessionPropose.req.ttl),id:Us()},{done:Q,resolve:se,reject:T}=yn($,"Request expired"),v=Us(),C=Ae("session_connect",k.id),A=Ae("session_request",v),S=async({error:I,session:R})=>{this.events.off(A,D),I?T(I):R&&se({session:R})},D=async I=>{var R,z,K;if(await this.deletePendingAuthRequest(v,{message:"fulfilled",code:0}),I.error){const le=$e("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return I.error.code===le.code?void 0:(this.events.off(C,S),T(I.error.message))}await this.deleteProposal(k.id),this.events.off(C,S);const{cacaos:he,responder:ie}=I.result,ne=[],ue=[];for(const le of he){await hu({cacao:le,projectId:this.client.core.projectId})||(this.client.logger.error(le,"Signature verification failed"),T($e("SESSION_SETTLEMENT_FAILED","Signature verification failed")));const{p:De}=le,Kt=fo(De.resources),$s=[uc(De.iss)],cn=ko(De.iss);if(Kt){const Hn=pu(Kt),_f=fu(Kt);ne.push(...Hn),$s.push(..._f)}for(const Hn of $s)ue.push(`${Hn}:${cn}`)}const ce=await this.client.core.crypto.generateSharedKey(N,ie.publicKey);let Oe;ne.length>0&&(Oe={topic:ce,acknowledged:!0,self:{publicKey:N,metadata:this.client.metadata},peer:ie,controller:ie.publicKey,expiry:Be(Jn),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:b,namespaces:ju([...new Set(ne)],[...new Set(ue)]),transportType:o},await this.client.core.relayer.subscribe(ce,{transportType:o}),await this.client.session.set(ce,Oe),b&&await this.client.core.pairing.updateMetadata({topic:b,metadata:ie.metadata}),Oe=this.client.session.get(ce)),(R=this.client.metadata.redirect)!=null&&R.linkMode&&(z=ie.metadata.redirect)!=null&&z.linkMode&&(K=ie.metadata.redirect)!=null&&K.universal&&n&&(this.client.core.addLinkModeSupportedApp(ie.metadata.redirect.universal),this.client.session.update(ce,{transportType:Pe.link_mode})),se({auths:he,session:Oe})};this.events.once(C,S),this.events.once(A,D);let B;try{if(i){const I=as("wc_sessionAuthenticate",W,v);this.client.core.history.set(b,I);const R=await this.client.core.crypto.encode("",I,{type:$i,encoding:Ys});B=eo(n,b,R)}else await Promise.all([this.sendRequest({topic:b,method:"wc_sessionAuthenticate",params:W,expiry:s.expiry,throwOnFailedPublish:!0,clientRpcId:v}),this.sendRequest({topic:b,method:"wc_sessionPropose",params:k,expiry:Je.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:k.id})])}catch(I){throw this.events.off(C,S),this.events.off(A,D),I}return await this.setProposal(k.id,k),await this.setAuthRequest(v,{request:it(Ie({},W),{verifyContext:{}}),pairingTopic:b,transportType:o}),{uri:B??E,response:Q}}),O(this,"approveSessionAuthenticate",async s=>{const{id:n,auths:r}=s,i=this.client.core.eventClient.createEvent({properties:{topic:n.toString(),trace:[pn.authenticated_session_approve_started]}});try{this.isInitialized()}catch(y){throw i.setError(Pr.no_internet_connection),y}const o=this.getPendingAuthRequest(n);if(!o)throw i.setError(Pr.authenticated_session_pending_request_not_found),new Error(`Could not find pending auth request with id ${n}`);const a=o.transportType||Pe.relay;a===Pe.relay&&await this.confirmOnlineStateOrThrow();const c=o.requester.publicKey,l=await this.client.core.crypto.generateKeyPair(),u=go(c),d={type:Ps,receiverPublicKey:c,senderPublicKey:l},h=[],p=[];for(const y of r){if(!await hu({cacao:y,projectId:this.client.core.projectId})){i.setError(Pr.invalid_cacao);const x=$e("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:n,topic:u,error:x,encodeOpts:d}),new Error(x.message)}i.addTrace(pn.cacaos_verified);const{p:w}=y,b=fo(w.resources),E=[uc(w.iss)],N=ko(w.iss);if(b){const x=pu(b),$=fu(b);h.push(...x),E.push(...$)}for(const x of E)p.push(`${x}:${N}`)}const g=await this.client.core.crypto.generateSharedKey(l,c);i.addTrace(pn.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:Be(Jn),authentication:r,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:o.pairingTopic,namespaces:ju([...new Set(h)],[...new Set(p)]),transportType:a},i.addTrace(pn.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(g,{transportType:a})}catch(y){throw i.setError(Pr.subscribe_authenticated_session_topic_failure),y}i.addTrace(pn.subscribe_authenticated_session_topic_success),await this.client.session.set(g,f),i.addTrace(pn.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:o.pairingTopic,metadata:o.requester.metadata})}i.addTrace(pn.publishing_authenticated_session_approve);try{await this.sendResult({topic:u,id:n,result:{cacaos:r,responder:{publicKey:l,metadata:this.client.metadata}},encodeOpts:d,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(o.requester.metadata,a)})}catch(y){throw i.setError(Pr.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}}),O(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===Pe.relay&&await this.confirmOnlineStateOrThrow();const o=i.requester.publicKey,a=await this.client.core.crypto.generateKeyPair(),c=go(o),l={type:Ps,receiverPublicKey:o,senderPublicKey:a};await this.sendError({id:n,topic:c,error:r,encodeOpts:l,rpcOpts:Je.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)}),O(this,"formatAuthMessage",s=>{this.isInitialized();const{request:n,iss:r}=s;return Jh(n,r)}),O(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)}),O(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)}}),O(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,$e("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(md).catch(l=>this.client.logger.warn(l)),this.getPendingSessionRequests().forEach(l=>{l.topic===r&&this.deletePendingSessionRequest(l.id,$e("USER_DISCONNECTED"))}),r===((n=this.sessionRequestQueue.queue[0])==null?void 0:n.topic)&&(this.sessionRequestQueue.state=rs.idle),o&&this.client.events.emit("session_delete",{id:a,topic:r})}),O(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(hn.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(s,$e("USER_DISCONNECTED")),n?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"proposal")}),O(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=rs.idle,this.client.events.emit("session_request_expire",{id:s}))}),O(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)])}),O(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}))}),O(this,"setProposal",async(s,n)=>{this.client.core.expirer.set(s,Be(Je.wc_sessionPropose.req.ttl)),await this.client.proposal.set(s,n)}),O(this,"setAuthRequest",async(s,n)=>{const{request:r,pairingTopic:i,transportType:o=Pe.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})}),O(this,"setPendingSessionRequest",async s=>{const{id:n,topic:r,params:i,verifyContext:o}=s,a=i.request.expiryTimestamp||Be(Je.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})}),O(this,"sendRequest",async s=>{const{topic:n,method:r,params:i,expiry:o,relayRpcId:a,clientRpcId:c,throwOnFailedPublish:l,appLink:u,tvf:d,publishOpts:h={}}=s,p=as(r,i,c);let g;const f=!!u;try{const b=f?Ys:yt;g=await this.client.core.crypto.encode(n,p,{encoding:b})}catch(b){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${n} failed`),b}let y;if(xI.includes(r)){const b=Bt(JSON.stringify(p)),E=Bt(g);y=await this.client.core.verify.register({id:E,decryptedId:b})}const w=Ie(Ie({},Je[r].req),h);if(w.attestation=y,o&&(w.ttl=o),a&&(w.id=a),this.client.core.history.set(n,p),f){const b=eo(u,n,g);await global.Linking.openURL(b,this.client.name)}else w.tvf=it(Ie({},d),{correlationId:p.id}),l?(w.internal=it(Ie({},w.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,g,w)):this.client.core.relayer.publish(n,g,w).catch(b=>this.client.logger.error(b));return p.id}),O(this,"sendProposeSession",async s=>{const{proposal:n,publishOpts:r}=s,i=as("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:yt}),a=Bt(JSON.stringify(i)),c=Bt(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:it(Ie({},r),{publishMethod:"wc_proposeSession",attestation:l})})}),O(this,"sendApproveSession",async s=>{const{sessionTopic:n,pairingProposalResponse:r,proposal:i,sessionSettleRequest:o,publishOpts:a}=s,c=Yr(i.id,r),l=await this.client.core.crypto.encode(i.pairingTopic,c,{encoding:yt}),u=as("wc_sessionSettle",o,a==null?void 0:a.id),d=await this.client.core.crypto.encode(n,u,{encoding:yt});this.client.core.history.set(n,u),await this.client.core.relayer.publishCustom({payload:{sessionTopic:n,pairingTopic:i.pairingTopic,sessionProposalResponse:l,sessionSettlementRequest:d},opts:it(Ie({},a),{publishMethod:"wc_approveSession"})})}),O(this,"sendResult",async s=>{const{id:n,topic:r,result:i,throwOnFailedPublish:o,encodeOpts:a,appLink:c}=s,l=Yr(n,i);let u;const d=c&&typeof(global==null?void 0:global.Linking)<"u";try{const g=d?Ys:yt;u=await this.client.core.crypto.encode(r,l,it(Ie({},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(d){const g=eo(c,r,u);await global.Linking.openURL(g,this.client.name)}else{const g=h.request.method,f=Je[g].res;f.tvf=it(Ie({},p),{correlationId:n}),o?(f.internal=it(Ie({},f.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(r,u,f)):this.client.core.relayer.publish(r,u,f).catch(y=>this.client.logger.error(y))}await this.client.core.history.resolve(l)}),O(this,"sendError",async s=>{const{id:n,topic:r,error:i,encodeOpts:o,rpcOpts:a,appLink:c}=s,l=sh(n,i);let u;const d=c&&typeof(global==null?void 0:global.Linking)<"u";try{const p=d?Ys:yt;u=await this.client.core.crypto.encode(r,l,it(Ie({},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(d){const p=eo(c,r,u);await global.Linking.openURL(p,this.client.name)}else{const p=h.request.method,g=a||Je[p].res;this.client.core.relayer.publish(r,u,g)}await this.client.core.history.resolve(l)}),O(this,"cleanup",async()=>{const s=[],n=[];this.client.session.getAll().forEach(r=>{let i=!1;cs(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=>{cs(r.expiryTimestamp)&&n.push(r.id)}),await Promise.all([...s.map(r=>this.deleteSession({topic:r})),...n.map(r=>this.deleteProposal(r))])}),O(this,"onProviderMessageEvent",async s=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(s):await this.onRelayMessage(s)}),O(this,"onRelayEventRequest",async s=>{this.requestQueue.queue.push(s),await this.processRequestsQueue()}),O(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===rs.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=rs.active;const s=this.requestQueue.queue.shift();if(s)try{await this.processRequest(s)}catch(n){this.client.logger.warn(n)}}this.requestQueue.state=rs.idle}),O(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}`)}}),O(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}`)}}),O(this,"onRelayEventUnknownPayload",s=>{const{topic:n}=s,{message:r}=M("MISSING_OR_INVALID",`Decoded payload on topic ${n} is not identifiable as a JSON-RPC request or a response.`);throw new Error(r)}),O(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)}),O(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(vs.proposal_listener_not_found)),this.isValidConnect(Ie({},r.params));const u=a.expiryTimestamp||Be(Je.wc_sessionPropose.req.ttl),d=Ie({id:c,pairingTopic:n,expiryTimestamp:u,attestation:i,encryptedId:o},a);await this.setProposal(c,d);const h=await this.getVerifyContext({attestationId:i,hash:Bt(JSON.stringify(r)),encryptedId:o,metadata:d.proposer.metadata});l==null||l.addTrace(is.emit_session_proposal),this.client.events.emit("session_proposal",{id:c,params:d,verifyContext:h})}catch(l){await this.sendError({id:c,topic:n,error:l,rpcOpts:Je.wc_sessionPropose.autoReject}),this.client.logger.error(l)}}),O(this,"onSessionProposeResponse",async(s,n,r)=>{const{id:i}=n;if(ws(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 u=await this.client.core.crypto.generateSharedKey(c,l);this.pendingSessions.set(i,{sessionTopic:u,pairingTopic:s,proposalId:i,publicKey:c});const d=await this.client.core.relayer.subscribe(u,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:d}),await this.client.core.pairing.activate({topic:s})}else if(os(n)){await this.deleteProposal(i);const o=Ae("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})}}),O(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:u,scopedProperties:d,sessionConfig:h}=n.params,p=[...this.pendingSessions.values()].find(y=>y.sessionTopic===s);if(!p)return this.client.logger.error(`Pending session not found for topic ${s}`);const g=this.client.proposal.get(p.proposalId),f=it(Ie(Ie(Ie({topic:s,relay:o,expiry:c,namespaces:l,acknowledged:!0,pairingTopic:p.pairingTopic,requiredNamespaces:g.requiredNamespaces,optionalNamespaces:g.optionalNamespaces,controller:a.publicKey,self:{publicKey:p.publicKey,metadata:this.client.metadata},peer:{publicKey:a.publicKey,metadata:a.metadata}},u&&{sessionProperties:u}),d&&{scopedProperties:d}),h&&{sessionConfig:h}),{transportType:Pe.relay});await this.client.session.set(f.topic,f),await this.setExpiry(f.topic,f.expiry),await this.client.core.pairing.updateMetadata({topic:p.pairingTopic,metadata:f.peer.metadata}),this.client.events.emit("session_connect",{session:f}),this.events.emit(Ae("session_connect",p.proposalId),{session:f}),this.pendingSessions.delete(p.proposalId),this.deleteProposal(p.proposalId,!1),this.cleanupDuplicatePairings(f),await this.sendResult({id:n.id,topic:s,result:!0})}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),O(this,"onSessionSettleResponse",async(s,n)=>{const{id:r}=n;ws(n)?(await this.client.session.update(s,{acknowledged:!0}),this.events.emit(Ae("session_approve",r),{})):os(n)&&(await this.client.session.delete(s,$e("USER_DISCONNECTED")),this.events.emit(Ae("session_approve",r),{error:n.error}))}),O(this,"onSessionUpdateRequest",async(s,n)=>{const{params:r,id:i}=n;try{const o=`${s}_session_update`,a=Tr.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:$e("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(Ie({topic:s},r));try{Tr.set(o,i),await this.client.session.update(s,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:s,result:!0})}catch(c){throw Tr.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)}}),O(this,"isRequestOutOfSync",(s,n)=>n.toString().slice(0,-3)<s.toString().slice(0,-3)),O(this,"onSessionUpdateResponse",(s,n)=>{const{id:r}=n,i=Ae("session_update",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_update",r),{}):os(n)&&this.events.emit(Ae("session_update",r),{error:n.error})}),O(this,"onSessionExtendRequest",async(s,n)=>{const{id:r}=n;try{this.isValidExtend({topic:s}),await this.setExpiry(s,Be(Jn)),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)}}),O(this,"onSessionExtendResponse",(s,n)=>{const{id:r}=n,i=Ae("session_extend",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_extend",r),{}):os(n)&&this.events.emit(Ae("session_extend",r),{error:n.error})}),O(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)}}),O(this,"onSessionPingResponse",(s,n)=>{const{id:r}=n,i=Ae("session_ping",r);setTimeout(()=>{if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners 2176`);ws(n)?this.events.emit(Ae("session_ping",r),{}):os(n)&&this.events.emit(Ae("session_ping",r),{error:n.error})},500)}),O(this,"onSessionDeleteRequest",async(s,n)=>{const{id:r}=n;try{this.isValidDisconnect({topic:s,reason:n.params}),await Promise.all([new Promise(i=>{this.client.core.relayer.once(Le.publish,async()=>{i(await this.deleteSession({topic:s,id:r}))})}),this.sendResult({id:r,topic:s,result:!0}),this.cleanupPendingSentRequestsForTopic({topic:s,error:$e("USER_DISCONNECTED")})]).catch(i=>this.client.logger.error(i))}catch(i){this.client.logger.error(i)}}),O(this,"onSessionRequest",async s=>{var n,r,i;const{topic:o,payload:a,attestation:c,encryptedId:l,transportType:u}=s,{id:d,params:h}=a;try{await this.isValidRequest(Ie({topic:o},h));const p=this.client.session.get(o),g=await this.getVerifyContext({attestationId:c,hash:Bt(JSON.stringify(as("wc_sessionRequest",h,d))),encryptedId:l,metadata:p.peer.metadata,transportType:u}),f={id:d,topic:o,params:h,verifyContext:g};await this.setPendingSessionRequest(f),u===Pe.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:d,topic:o,error:p}),this.client.logger.error(p)}}),O(this,"onSessionRequestResponse",(s,n)=>{const{id:r}=n,i=Ae("session_request",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_request",r),{result:n.result}):os(n)&&this.events.emit(Ae("session_request",r),{error:n.error})}),O(this,"onSessionEventRequest",async(s,n)=>{const{id:r,params:i}=n;try{const o=`${s}_session_event_${i.event.name}`,a=Tr.get(o);if(a&&this.isRequestOutOfSync(a,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(Ie({topic:s},i)),this.client.events.emit("session_event",{id:r,topic:s,params:i}),Tr.set(o,r)}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),O(this,"onSessionAuthenticateResponse",(s,n)=>{const{id:r}=n;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:s,payload:n}),ws(n)?this.events.emit(Ae("session_request",r),{result:n.result}):os(n)&&this.events.emit(Ae("session_request",r),{error:n.error})}),O(this,"onSessionAuthenticateRequest",async s=>{var n;const{topic:r,payload:i,attestation:o,encryptedId:a,transportType:c}=s;try{const{requester:l,authPayload:u,expiryTimestamp:d}=i.params,h=await this.getVerifyContext({attestationId:o,hash:Bt(JSON.stringify(i)),encryptedId:a,metadata:l.metadata,transportType:c}),p={requester:l,pairingTopic:r,id:i.id,authPayload:u,verifyContext:h,expiryTimestamp:d};await this.setAuthRequest(i.id,{request:p,pairingTopic:r,transportType:c}),c===Pe.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 u=i.params.requester.publicKey,d=await this.client.core.crypto.generateKeyPair(),h=this.getAppLinkIfEnabled(i.params.requester.metadata,c),p={type:Ps,receiverPublicKey:u,senderPublicKey:d};await this.sendError({id:i.id,topic:r,error:l,encodeOpts:p,rpcOpts:Je.wc_sessionAuthenticate.autoReject,appLink:h})}}),O(this,"addSessionRequestToSessionRequestQueue",s=>{this.sessionRequestQueue.queue.push(s)}),O(this,"cleanupAfterResponse",s=>{this.deletePendingSessionRequest(s.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=rs.idle,this.processSessionRequestQueue()},F.toMiliseconds(this.requestQueueDelay))}),O(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=>{const o=i.request.id,a=Ae("session_request",o);if(this.events.listenerCount(a)===0)throw new Error(`emitting ${a} without any listeners`);this.events.emit(Ae("session_request",i.request.id),{error:n})})}),O(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===rs.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)}}),O(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=rs.active,this.emittedSessionRequests.add(s.id),this.client.events.emit("session_request",s)}),O(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:as("wc_sessionPropose",it(Ie({},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})}),O(this,"isValidConnect",async s=>{if(!gt(s)){const{message:l}=M("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(We(n)||await this.isValidPairingTopic(n),!wE(c)){const{message:l}=M("MISSING_OR_INVALID",`connect() relays: ${c}`);throw new Error(l)}if(r&&!We(r)&&fs(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&&!We(i)&&fs(i)!==0&&this.validateNamespaces(i,"optionalNamespaces"),o&&!We(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!We(a)){this.validateSessionProps(a,"scopedProperties");const l=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(a).every(u=>l.includes(u.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)}`)}}),O(this,"validateNamespaces",(s,n)=>{const r=yE(s,"connect()",n);if(r)throw new Error(r.message)}),O(this,"isValidApprove",async s=>{if(!gt(s))throw new Error(M("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=Oa(r,"approve()");if(l)throw new Error(l.message);const u=Wu(c.requiredNamespaces,r,"approve()");if(u)throw new Error(u.message);if(!je(i,!0)){const{message:d}=M("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw new Error(d)}if(o&&!We(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!We(a)){this.validateSessionProps(a,"scopedProperties");const d=new Set(Object.keys(r));if(!Object.keys(a).every(h=>d.has(h.split(":")[0])))throw new Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(a)}, approved namespaces: ${Array.from(d).join(", ")}`)}}),O(this,"isValidReject",async s=>{if(!gt(s)){const{message:i}=M("MISSING_OR_INVALID",`reject() params: ${s}`);throw new Error(i)}const{id:n,reason:r}=s;if(this.checkRecentlyDeleted(n),await this.isValidProposalId(n),!vE(r)){const{message:i}=M("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw new Error(i)}}),O(this,"isValidSessionSettleRequest",s=>{if(!gt(s)){const{message:l}=M("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${s}`);throw new Error(l)}const{relay:n,controller:r,namespaces:i,expiry:o}=s;if(!xp(n)){const{message:l}=M("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw new Error(l)}const a=dE(r,"onSessionSettleRequest()");if(a)throw new Error(a.message);const c=Oa(i,"onSessionSettleRequest()");if(c)throw new Error(c.message);if(cs(o)){const{message:l}=M("EXPIRED","onSessionSettleRequest()");throw new Error(l)}}),O(this,"isValidUpdate",async s=>{if(!gt(s)){const{message:c}=M("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=Oa(r,"update()");if(o)throw new Error(o.message);const a=Wu(i.requiredNamespaces,r,"update()");if(a)throw new Error(a.message)}),O(this,"isValidExtend",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`extend() params: ${s}`);throw new Error(r)}const{topic:n}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n)}),O(this,"isValidRequest",async s=>{if(!gt(s)){const{message:c}=M("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(!qu(a,i)){const{message:c}=M("MISSING_OR_INVALID",`request() chainId: ${i}`);throw new Error(c)}if(!EE(r)){const{message:c}=M("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw new Error(c)}if(!IE(a,i,r.method)){const{message:c}=M("MISSING_OR_INVALID",`request() method: ${r.method}`);throw new Error(c)}if(o&&!TE(o,Ua)){const{message:c}=M("MISSING_OR_INVALID",`request() expiry: ${o}. Expiry must be a number (in seconds) between ${Ua.min} and ${Ua.max}`);throw new Error(c)}}),O(this,"isValidRespond",async s=>{var n;if(!gt(s)){const{message:a}=M("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(!CE(i)){const{message:a}=M("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}=M("MISMATCHED_TOPIC",`Request response topic mismatch. reqId: ${i.id}, expected topic: ${o.topic}, received topic: ${r}`);throw new Error(a)}}),O(this,"isValidPing",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`ping() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),O(this,"isValidEmit",async s=>{if(!gt(s)){const{message:a}=M("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(!qu(o,i)){const{message:a}=M("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw new Error(a)}if(!AE(r)){const{message:a}=M("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}if(!_E(o,i,r.name)){const{message:a}=M("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}}),O(this,"isValidDisconnect",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`disconnect() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),O(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(!je(r,!1))throw new Error("uri is required parameter");if(!je(i,!1))throw new Error("domain is required parameter");if(!je(o,!1))throw new Error("nonce is required parameter");if([...new Set(n.map(c=>Os(c).namespace))].length>1)throw new Error("Multi-namespace requests are not supported. Please request single namespace only.");const{namespace:a}=Os(n[0]);if(a!=="eip155")throw new Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),O(this,"getVerifyContext",async s=>{const{attestationId:n,hash:r,encryptedId:i,metadata:o,transportType:a}=s,c={verified:{verifyUrl:o.verifyUrl||Kr,validation:"UNKNOWN",origin:o.url||""}};try{if(a===Pe.link_mode){const u=this.getAppLinkIfEnabled(o,a);return c.verified.validation=u&&new URL(u).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}),O(this,"validateSessionProps",(s,n)=>{Object.values(s).forEach((r,i)=>{if(r==null){const{message:o}=M("MISSING_OR_INVALID",`${n} must contain an existing value for each key. Received: ${r} for key ${Object.keys(s)[i]}`);throw new Error(o)}})}),O(this,"getPendingAuthRequest",s=>{const n=this.client.auth.requests.get(s);return typeof n=="object"?n:void 0}),O(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)}}}),O(this,"checkRecentlyDeleted",s=>{const n=this.recentlyDeletedMap.get(s);if(n){const{message:r}=M("MISSING_OR_INVALID",`Record was recently deleted - ${n}: ${s}`);throw new Error(r)}}),O(this,"isLinkModeEnabled",(s,n)=>{var r,i,o,a,c,l,u,d,h;return!s||n!==Pe.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)!==""&&((u=s==null?void 0:s.redirect)==null?void 0:u.universal)!==void 0&&((d=s==null?void 0:s.redirect)==null?void 0:d.universal)!==""&&((h=s==null?void 0:s.redirect)==null?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(s.redirect.universal)&&typeof(global==null?void 0:global.Linking)<"u"}),O(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}),O(this,"handleLinkModeMessage",({url:s})=>{if(!s||!s.includes("wc_ev")||!s.includes("topic"))return;const n=eu(s,"topic")||"",r=decodeURIComponent(eu(s,"wc_ev")||""),i=this.client.session.keys.includes(n);i&&this.client.session.update(n,{transportType:Pe.link_mode}),this.client.core.dispatchEnvelope({topic:n,message:r,sessionExists:i})}),O(this,"registerLinkModeListeners",async()=>{var s;if(Qc()||on()&&(s=this.client.metadata.redirect)!=null&&s.linkMode){const n=global==null?void 0:global.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)}}}),O(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}),O(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}),O(this,"extractTxHashesFromResult",(s,n)=>{var r;try{if(!n)return[];const i=s.method,o=kI[i];if(i==="sui_signTransaction")return[Hb(n.transactionBytes)];if(i==="near_signTransaction")return[cu(n)];if(i==="near_signTransactions")return n.map(c=>cu(c));if(i==="xrpl_signTransactionFor"||i==="xrpl_signTransaction")return[(r=n.tx_json)==null?void 0:r.hash];if(i==="polkadot_signTransaction")return[WE({transaction:s.params.transactionPayload,signature:n.signature})];if(i==="algo_signTxn")return ks(n)?n.map(c=>lu(c)):[lu(n)];if(i==="cosmos_signDirect")return[zb(n)];if(i==="wallet_sendCalls")return Vb(n);if(typeof n=="string")return[n];const a=n[o.key];if(ks(a))return i==="solana_signAllTransactions"?a.map(c=>Wb(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}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(Le.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(yo)?this.client.auth.authKeys.get(yo):{publicKey:void 0};try{const a=await this.client.core.crypto.decode(s,n,{receiverPublicKey:o,encoding:i===Pe.link_mode?Ys:yt});qc(a)?(this.client.core.history.set(s,a),await this.onRelayEventRequest({topic:s,payload:a,attestation:r,transportType:i,encryptedId:Bt(n)})):Wc(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)):await this.onRelayEventUnknownPayload({topic:s,payload:a,transportType:i}),await this.client.core.relayer.messages.ack(s,n)}catch(a){this.client.logger.error(a)}}registerExpirerEvents(){this.client.core.expirer.on(Mt.expired,async e=>{const{topic:s,id:n}=$h(e.target);if(n&&this.client.pendingRequest.keys.includes(n))return await this.deletePendingSessionRequest(n,M("EXPIRED"),!0);if(n&&this.client.auth.requests.keys.includes(n))return await this.deletePendingAuthRequest(n,M("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(wn.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(wn.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!je(e,!1)){const{message:s}=M("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}=M("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.core.pairing.pairings.get(e).expiry)){const{message:s}=M("EXPIRED",`pairing topic: ${e}`);throw new Error(s)}}async isValidSessionTopic(e){if(!je(e,!1)){const{message:s}=M("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}=M("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});const{message:s}=M("EXPIRED",`session topic: ${e}`);throw new Error(s)}if(!this.client.core.crypto.keychain.has(e)){const{message:s}=M("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(je(e,!1)){const{message:s}=M("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw new Error(s)}else{const{message:s}=M("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw new Error(s)}}async isValidProposalId(e){if(!bE(e)){const{message:s}=M("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw new Error(s)}if(!this.client.proposal.keys.includes(e)){const{message:s}=M("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);const{message:s}=M("EXPIRED",`proposal id: ${e}`);throw new Error(s)}}}class KI extends Wn{constructor(e,s){super(e,s,TI,hl),this.core=e,this.logger=s}}let zI=class extends Wn{constructor(e,s){super(e,s,OI,hl),this.core=e,this.logger=s}};class VI extends Wn{constructor(e,s){super(e,s,RI,hl,n=>n.id),this.core=e,this.logger=s}}class GI extends Wn{constructor(e,s){super(e,s,DI,ra,()=>yo),this.core=e,this.logger=s}}class YI extends Wn{constructor(e,s){super(e,s,LI,ra),this.core=e,this.logger=s}}class JI extends Wn{constructor(e,s){super(e,s,MI,ra,n=>n.id),this.core=e,this.logger=s}}var XI=Object.defineProperty,ZI=(t,e,s)=>e in t?XI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Da=(t,e,s)=>ZI(t,typeof e!="symbol"?e+"":e,s);class QI{constructor(e,s){this.core=e,this.logger=s,Da(this,"authKeys"),Da(this,"pairingTopics"),Da(this,"requests"),this.authKeys=new GI(this.core,this.logger),this.pairingTopics=new YI(this.core,this.logger),this.requests=new JI(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var e_=Object.defineProperty,t_=(t,e,s)=>e in t?e_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,fe=(t,e,s)=>t_(t,typeof e!="symbol"?e+"":e,s);let s_=class ef extends Ew{constructor(e){super(e),fe(this,"protocol",Xp),fe(this,"version",Zp),fe(this,"name",$a.name),fe(this,"metadata"),fe(this,"core"),fe(this,"logger"),fe(this,"events",new Mn.EventEmitter),fe(this,"engine"),fe(this,"session"),fe(this,"proposal"),fe(this,"pendingRequest"),fe(this,"auth"),fe(this,"signConfig"),fe(this,"on",(n,r)=>this.events.on(n,r)),fe(this,"once",(n,r)=>this.events.once(n,r)),fe(this,"off",(n,r)=>this.events.off(n,r)),fe(this,"removeListener",(n,r)=>this.events.removeListener(n,r)),fe(this,"removeAllListeners",n=>this.events.removeAllListeners(n)),fe(this,"connect",async n=>{try{return await this.engine.connect(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"pair",async n=>{try{return await this.engine.pair(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"approve",async n=>{try{return await this.engine.approve(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"reject",async n=>{try{return await this.engine.reject(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"update",async n=>{try{return await this.engine.update(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"extend",async n=>{try{return await this.engine.extend(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"request",async n=>{try{return await this.engine.request(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"respond",async n=>{try{return await this.engine.respond(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"ping",async n=>{try{return await this.engine.ping(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"emit",async n=>{try{return await this.engine.emit(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"disconnect",async n=>{try{return await this.engine.disconnect(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"find",n=>{try{return this.engine.find(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(n){throw this.logger.error(n.message),n}}),fe(this,"authenticate",async(n,r)=>{try{return await this.engine.authenticate(n,r)}catch(i){throw this.logger.error(i.message),i}}),fe(this,"formatAuthMessage",n=>{try{return this.engine.formatAuthMessage(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"approveSessionAuthenticate",async n=>{try{return await this.engine.approveSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),fe(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)||$a.name,this.metadata=Dw(e==null?void 0:e.metadata),this.signConfig=e==null?void 0:e.signConfig;const s=dl({logger:(e==null?void 0:e.logger)||$a.logger,name:this.name});this.logger=s,this.core=(e==null?void 0:e.core)||new NI(e),this.session=new zI(this.core,this.logger),this.proposal=new KI(this.core,this.logger),this.pendingRequest=new VI(this.core,this.logger),this.engine=new HI(this),this.auth=new QI(this.core,this.logger)}static async init(e){const s=new ef(e);return await s.initialize(),s}get context(){return Et(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 n_=s_;function pl(t){return t==null||typeof t!="object"&&typeof t!="function"}function tf(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function sf(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const r_="[object RegExp]",nf="[object String]",rf="[object Number]",of="[object Boolean]",af="[object Arguments]",i_="[object Symbol]",o_="[object Date]",a_="[object Map]",c_="[object Set]",l_="[object Array]",u_="[object ArrayBuffer]",d_="[object Object]",h_="[object DataView]",p_="[object Uint8Array]",f_="[object Uint8ClampedArray]",g_="[object Uint16Array]",m_="[object Uint32Array]",y_="[object Int8Array]",w_="[object Int16Array]",b_="[object Int32Array]",v_="[object Float32Array]",E_="[object Float64Array]";function fl(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)}function C_(t,e){return nr(t,void 0,t,new Map,e)}function nr(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(pl(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]=nr(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,nr(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(nr(a,void 0,s,n,r));return o}if(typeof Buffer<"u"&&Buffer.isBuffer(t))return t.subarray();if(fl(t)){const o=new(Object.getPrototypeOf(t)).constructor(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=nr(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),bn(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),bn(o,t,s,n,r),o}if(t instanceof Blob){const o=new Blob([t],{type:t.type});return n.set(t,o),bn(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,bn(o,t,s,n,r),o}if(typeof t=="object"&&A_(t)){const o=Object.create(Object.getPrototypeOf(t));return n.set(t,o),bn(o,t,s,n,r),o}return t}function bn(t,e,s=t,n,r){const i=[...Object.keys(e),...tf(e)];for(let o=0;o<i.length;o++){const a=i[o],c=Object.getOwnPropertyDescriptor(t,a);(c==null||c.writable)&&(t[a]=nr(e[a],a,s,n,r))}}function A_(t){switch(sf(t)){case af:case l_:case u_:case h_:case of:case o_:case v_:case E_:case y_:case w_:case b_:case a_:case rf:case d_:case r_:case c_:case nf:case i_:case p_:case f_:case g_:case m_:return!0;default:return!1}}function I_(t,e){return C_(t,(s,n,r,i)=>{if(typeof t=="object")switch(Object.prototype.toString.call(t)){case rf:case nf:case of:{const o=new t.constructor(t==null?void 0:t.valueOf());return bn(o,t),o}case af:{const o={};return bn(o,t),o.length=t.length,o[Symbol.iterator]=t[Symbol.iterator],o}default:return}})}function bd(t){return I_(t)}function vd(t){return t!==null&&typeof t=="object"&&sf(t)==="[object Arguments]"}function Ed(t){return typeof t=="object"&&t!==null}function __(){}function S_(t){return fl(t)}function N_(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 T_(t){if(pl(t))return t;if(Array.isArray(t)||fl(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 O_(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=$c(r,o,n,new Map)}return r}function $c(t,e,s,n){if(pl(t)&&(t=Object(t)),e==null||typeof e!="object")return t;if(n.has(e))return T_(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),...tf(e)];for(let i=0;i<r.length;i++){const o=r[i];let a=e[o],c=t[o];if(vd(a)&&(a={...a}),vd(c)&&(c={...c}),typeof Buffer<"u"&&Buffer.isBuffer(a)&&(a=bd(a)),Array.isArray(a))if(typeof c=="object"&&c!=null){const u=[],d=Reflect.ownKeys(c);for(let h=0;h<d.length;h++){const p=d[h];u[p]=c[p]}c=u}else c=[];const l=s(c,a,o,t,e,n);l!=null?t[o]=l:Array.isArray(a)||Ed(c)&&Ed(a)?t[o]=$c(c,a,s,n):c==null&&N_(a)?t[o]=$c({},a,s,n):c==null&&S_(a)?t[o]=bd(a):(c===void 0||a!==void 0)&&(t[o]=a)}return t}function P_(t,...e){return O_(t,...e,__)}const Cd="error",k_="wss://relay.walletconnect.org",R_="wc",cf="universal_provider",to=`${R_}@2:${cf}:`,lf="https://rpc.walletconnect.org/v1/",uf="generic",x_=`${lf}bundler`,ar="call_status",$_=86400,gl={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};var U_=Object.defineProperty,D_=Object.defineProperties,L_=Object.getOwnPropertyDescriptors,Ad=Object.getOwnPropertySymbols,M_=Object.prototype.hasOwnProperty,B_=Object.prototype.propertyIsEnumerable,Id=(t,e,s)=>e in t?U_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,so=(t,e)=>{for(var s in e||(e={}))M_.call(e,s)&&Id(t,s,e[s]);if(Ad)for(var s of Ad(e))B_.call(e,s)&&Id(t,s,e[s]);return t},j_=(t,e)=>D_(t,L_(e));function df(t,e,s){var n;const r=Os(t);return((n=e.rpcMap)==null?void 0:n[r.reference])||`${lf}?chainId=${r.namespace}:${r.reference}&projectId=${s}`}function F_(t){return t.includes(":")?t.split(":")[1]:t}function hf(t){return t.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function q_(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 _d(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 no(t={},e={}){const s=_d(Sd(t)),n=_d(Sd(e));return P_(s,n)}function Sd(t){var e,s,n,r,i;const o={};if(!fs(t))return o;for(const[a,c]of Object.entries(t)){const l=sa(a)?[a]:c.chains,u=c.methods||[],d=c.events||[],h=c.rpcMap||{},p=sr(a);o[p]=j_(so(so({},o[p]),c),{chains:ps(l,(e=o[p])==null?void 0:e.chains),methods:ps(u,(s=o[p])==null?void 0:s.methods),events:ps(d,(n=o[p])==null?void 0:n.events)}),(fs(h)||fs(((r=o[p])==null?void 0:r.rpcMap)||{}))&&(o[p].rpcMap=so(so({},h),(i=o[p])==null?void 0:i.rpcMap))}return o}function Nd(t){return t.includes(":")?t.split(":")[2]:t}function Td(t){const e={};for(const[s,n]of Object.entries(t)){const r=n.methods||[],i=n.events||[],o=n.accounts||[],a=sa(s)?[s]:n.chains?n.chains:hf(n.accounts);e[s]={chains:a,methods:r,events:i,accounts:o}}return e}function La(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 W_(t){try{const e=JSON.parse(t);return typeof e=="object"&&e!==null&&!Array.isArray(e)}catch{return!1}}const pf={},cr=t=>pf[t],Ma=(t,e)=>{pf[t]=e};var H_=Object.defineProperty,Od=Object.getOwnPropertySymbols,K_=Object.prototype.hasOwnProperty,z_=Object.prototype.propertyIsEnumerable,Pd=(t,e,s)=>e in t?H_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kd=(t,e)=>{for(var s in e||(e={}))K_.call(e,s)&&Pd(t,s,e[s]);if(Od)for(var s of Od(e))z_.call(e,s)&&Pd(t,s,e[s]);return t};const Rd="eip155",V_=["atomic","flow-control","paymasterService","sessionKeys","auxiliaryFunds"],G_=t=>t&&t.startsWith("0x")?BigInt(t).toString(10):t,Ba=t=>t&&t.startsWith("0x")?t:`0x${BigInt(t).toString(16)}`,xd=t=>Object.keys(t).filter(e=>V_.includes(e)).reduce((e,s)=>(e[s]=Y_(t[s]),e),{}),Y_=t=>typeof t=="string"&&W_(t)?JSON.parse(t):t,J_=(t,e,s)=>{const{sessionProperties:n={},scopedProperties:r={}}=t,i={};if(!fs(r)&&!fs(n))return;const o=xd(n);for(const a of s){const c=G_(a);if(!c)continue;i[Ba(c)]=o;const l=r==null?void 0:r[`${Rd}:${c}`];if(l){const u=l==null?void 0:l[`${Rd}:${c}:${e}`];i[Ba(c)]=kd(kd({},i[Ba(c)]),xd(u||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 X_=Object.defineProperty,Z_=(t,e,s)=>e in t?X_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Q_=(t,e,s)=>Z_(t,e+"",s);let ja;class ml{constructor(e){Q_(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 ja||(ja=new ml(e)),ja}}var eS=Object.defineProperty,tS=Object.defineProperties,sS=Object.getOwnPropertyDescriptors,$d=Object.getOwnPropertySymbols,nS=Object.prototype.hasOwnProperty,rS=Object.prototype.propertyIsEnumerable,Ud=(t,e,s)=>e in t?eS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,iS=(t,e)=>{for(var s in e||(e={}))nS.call(e,s)&&Ud(t,s,e[s]);if($d)for(var s of $d(e))rS.call(e,s)&&Ud(t,s,e[s]);return t},oS=(t,e)=>tS(t,sS(e));async function aS(t,e){const s=Os(t.result.capabilities.caip345.caip2),n=t.result.capabilities.caip345.transactionHashes,r=await Promise.allSettled(n.map(d=>cS(s.reference,d,e))),i=r.filter(d=>d.status==="fulfilled").map(d=>d.value).filter(d=>d);r.filter(d=>d.status==="rejected").forEach(d=>console.warn("Failed to fetch transaction receipt:",d.reason));const o=!i.length||i.some(d=>!d),a=i.every(d=>(d==null?void 0:d.status)==="0x1"),c=i.every(d=>(d==null?void 0:d.status)==="0x0"),l=i.some(d=>(d==null?void 0:d.status)==="0x0");let u;return o?u=100:a?u=200:c?u=500:l&&(u=600),{id:t.result.id,version:t.request.version,atomic:t.request.atomicRequired,chainId:t.request.chainId,capabilities:t.result.capabilities,receipts:i,status:u}}async function cS(t,e,s){return await s(parseInt(t)).request(as("eth_getTransactionReceipt",[e]))}async function lS({sendCalls:t,storage:e}){const s=await e.getItem(ar);await e.setItem(ar,oS(iS({},s),{[t.result.id]:{request:t.request,result:t.result,expiry:Be($_)}}))}async function uS({resultId:t,storage:e}){const s=await e.getItem(ar);if(s){delete s[t],await e.setItem(ar,s);for(const n in s)cs(s[n].expiry)&&delete s[n];await e.setItem(ar,s)}}async function dS({resultId:t,storage:e}){const s=await e.getItem(ar),n=s==null?void 0:s[t];if(n&&!cs(n.expiry))return n;await uS({resultId:t,storage:e})}var hS=Object.defineProperty,pS=Object.defineProperties,fS=Object.getOwnPropertyDescriptors,Dd=Object.getOwnPropertySymbols,gS=Object.prototype.hasOwnProperty,mS=Object.prototype.propertyIsEnumerable,Uc=(t,e,s)=>e in t?hS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fa=(t,e)=>{for(var s in e||(e={}))gS.call(e,s)&&Uc(t,s,e[s]);if(Dd)for(var s of Dd(e))mS.call(e,s)&&Uc(t,s,e[s]);return t},qa=(t,e)=>pS(t,fS(e)),fn=(t,e,s)=>Uc(t,typeof e!="symbol"?e+"":e,s);class yS{constructor(e){fn(this,"name","eip155"),fn(this,"client"),fn(this,"chainId"),fn(this,"namespace"),fn(this,"httpProviders"),fn(this,"events"),fn(this,"storage"),this.namespace=e.namespace,this.events=cr("events"),this.client=cr("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain()),this.storage=ml.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(gl.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||df(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Fc(new nh(n,cr("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(F_(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=qa(Fa({},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),u=((o=l==null?void 0:l.sessionProperties)==null?void 0:o.capabilities)||{},d=`${a}${c.join(",")}`,h=u==null?void 0:u[d];if(h)return h;let p;try{p=J_(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:qa(Fa({},l.sessionProperties||{}),{capabilities:qa(Fa({},u||{}),{[d]: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(u){console.warn("Failed to fetch call status from bundler",u,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 dS({resultId:(r=e.request.params)==null?void 0:r[0],storage:this.storage});if(c)try{return await aS(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(as("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`${x_}?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,u=(r=c==null?void 0:c.caip345)==null?void 0:r.transactionHashes;return!a||!l||!(u!=null&&u.length)||await lS({sendCalls:{request:o,result:i},storage:this.storage}),i}}var wS=Object.defineProperty,bS=(t,e,s)=>e in t?wS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xn=(t,e,s)=>bS(t,typeof e!="symbol"?e+"":e,s);class vS{constructor(e){Xn(this,"name",uf),Xn(this,"client"),Xn(this,"httpProviders"),Xn(this,"events"),Xn(this,"namespace"),Xn(this,"chainId"),this.namespace=e.namespace,this.events=cr("events"),this.client=cr("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(gl.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 Os(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=Os(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=Os(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||df(e,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Fc(new nh(n,cr("disableProviderPing")))}}var ES=Object.defineProperty,CS=Object.defineProperties,AS=Object.getOwnPropertyDescriptors,Ld=Object.getOwnPropertySymbols,IS=Object.prototype.hasOwnProperty,_S=Object.prototype.propertyIsEnumerable,Dc=(t,e,s)=>e in t?ES(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,xr=(t,e)=>{for(var s in e||(e={}))IS.call(e,s)&&Dc(t,s,e[s]);if(Ld)for(var s of Ld(e))_S.call(e,s)&&Dc(t,s,e[s]);return t},ro=(t,e)=>CS(t,AS(e)),Ut=(t,e,s)=>Dc(t,typeof e!="symbol"?e+"":e,s);let SS=class ff{constructor(e){Ut(this,"client"),Ut(this,"namespaces"),Ut(this,"optionalNamespaces"),Ut(this,"sessionProperties"),Ut(this,"scopedProperties"),Ut(this,"events",new jc),Ut(this,"rpcProviders",{}),Ut(this,"session"),Ut(this,"providerOpts"),Ut(this,"logger"),Ut(this,"uri"),Ut(this,"disableProviderPing",!1);var s,n;this.providerOpts=e,this.logger=dl({logger:(s=e.logger)!=null?s:Cd,name:(n=this.providerOpts.name)!=null?n:cf}),this.disableProviderPing=(e==null?void 0:e.disableProviderPing)||!1}static async init(e){const s=new ff(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:xr({},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,Yr(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:$e("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw new Error("Sign Client not initialized");if(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=Td(this.session.namespaces);this.namespaces=no(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){const{uri:s,approval:n}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties});s&&(this.uri=s,this.events.emit("display_uri",s));const r=await n();this.session=r;const i=Td(r.namespaces);return this.namespaces=no(this.namespaces,i),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(!ks(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 n_.init({core:this.providerOpts.core,logger:this.providerOpts.logger||Cd,relayUrl:this.providerOpts.relayUrl||k_,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=>sr(s)))];Ma("client",this.client),Ma("events",this.events),Ma("disableProviderPing",this.disableProviderPing),e.forEach(s=>{if(!this.session)return;const n=q_(s,this.session);if((n==null?void 0:n.length)===0)return;const r=hf(n),i=no(this.namespaces,this.optionalNamespaces),o=ro(xr({},i[s]),{accounts:n,chains:r});switch(s){case"eip155":this.rpcProviders[s]=new yS({namespace:o});break;default:this.rpcProviders[s]=new vS({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&&ks(o)&&this.events.emit("accountsChanged",o.map(Nd))}else if(i.name==="chainChanged"){const o=n.chainId,a=n.event.data,c=sr(o),l=La(o)!==La(a)?`${c}:${La(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=ro(xr({},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",ro(xr({},$e("USER_DISCONNECTED")),{data:e.topic})))}),this.on(gl.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(ro(xr({},e),{internal:!0}))})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[uf]}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=no(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=>sr(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=sr(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(Nd);if(!ks(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.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(`${to}/${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(`${to}/${e}${n}`)}async deleteFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";await this.client.core.storage.removeItem(`${to}/${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(to)&&await this.client.core.storage.removeItem(n)}catch(s){this.logger.warn(s,"Failed to cleanup storage")}}};const Es={EIP155:U.CHAIN.EVM,CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH"},NS={NetworkImageIds:{1:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",42161:"3bff954d-5cb0-47a0-9a23-d20192e74600",43114:"30c46e53-e989-45fb-4549-be3bd4eb3b00",56:"93564157-2e8e-4ce7-81df-b264dbee9b00",250:"06b26297-fe0c-4733-5d6b-ffa5498aac00",10:"ab9c186a-c52f-464b-2906-ca59d760a400",137:"41d04d42-da3b-4453-8506-668cc0727900",5e3:"e86fae9b-b770-4eea-e520-150e12c81100",295:"6a97d510-cac8-4e58-c7ce-e8681b044c00",11155111:"e909ea0a-f92a-4512-c8fc-748044ea6800",84532:"a18a7ecd-e307-4360-4746-283182228e00",1301:"4eeea7ef-0014-4649-5d1d-07271a80f600",130:"2257980a-3463-48c6-cbac-a42d2a956e00",10143:"0a728e83-bacb-46db-7844-948f05434900",100:"02b53f6a-e3d4-479e-1cb4-21178987d100",9001:"f926ff41-260d-4028-635e-91913fc28e00",324:"b310f07f-4ef7-49f3-7073-2a0a39685800",314:"5a73b3dd-af74-424e-cae0-0de859ee9400",4689:"34e68754-e536-40da-c153-6ef2e7188a00",1088:"3897a66d-40b9-4833-162f-a2c90531c900",1284:"161038da-44ae-4ec7-1208-0ea569454b00",1285:"f1d73bb6-5450-4e18-38f7-fb6484264a00",7777777:"845c60df-d429-4991-e687-91ae45791600",42220:"ab781bbc-ccc6-418d-d32d-789b15da1f00",8453:"7289c336-3981-4081-c5f4-efc26ac64a00",1313161554:"3ff73439-a619-4894-9262-4470c773a100",2020:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",2021:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",80094:"e329c2c9-59b0-4a02-83e4-212ff3779900",2741:"fc2427d1-5af9-4a9c-8da5-6f94627cd900","5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":"a1b58899-f671-4276-6a5e-56ca5bd59700","4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z":"a1b58899-f671-4276-6a5e-56ca5bd59700",EtWTRABZaYq6iMfeYKouRu166VU2xqa1:"a1b58899-f671-4276-6a5e-56ca5bd59700","000000000019d6689c085ae165831e93":"0b4838db-0161-4ffe-022d-532bf03dba00","000000000933ea01ad0ee984209779ba":"39354064-d79b-420b-065d-f980c4b78200","00000008819873e925422c1ff0f99f7c":"b3406e4a-bbfc-44fb-e3a6-89673c78b700"}},Ai={getCaipTokens(t){if(!t)return;const e={};return Object.entries(t).forEach(([s,n])=>{e[`${Es.EIP155}:${s}`]=n}),e},isLowerCaseMatch(t,e){return(t==null?void 0:t.toLowerCase())===(e==null?void 0:e.toLowerCase())},getActiveNamespaceConnectedToAuth(){const t=m.state.activeChain;return U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(e=>L.getConnectorId(e)===U.CONNECTOR_ID.AUTH&&e===t)},withRetry({conditionFn:t,intervalMs:e,maxRetries:s}){let n=0;return new Promise(r=>{async function i(){return n+=1,await t()?r(!0):n>=s?r(!1):(setTimeout(i,e),null)}i()})},userChainIdToChainNamespace(t){if(typeof t=="number")return U.CHAIN.EVM;const[e]=t.split(":");return e},getOtherAuthNamespaces(t){return t?U.AUTH_CONNECTOR_SUPPORTED_CHAINS.filter(n=>n!==t):[]},getConnectorStorageInfo(t,e){const n=P.getConnections()[e]??[];return{hasDisconnected:P.isConnectorDisconnected(t,e),hasConnected:n.some(r=>Ai.isLowerCaseMatch(r.connectorId,t))}}},TS=new AbortController,Dt={EmbeddedWalletAbortController:TS,UniversalProviderErrors:{UNAUTHORIZED_DOMAIN_NOT_ALLOWED:{message:"Unauthorized: origin not allowed",alertErrorKey:"ORIGIN_NOT_ALLOWED"},JWT_VALIDATION_ERROR:{message:"JWT validation error: JWT Token is not yet valid",alertErrorKey:"JWT_TOKEN_NOT_VALID"},INVALID_KEY:{message:"Unauthorized: invalid key",alertErrorKey:"INVALID_PROJECT_ID"}},ALERT_ERRORS:{SWITCH_NETWORK_NOT_FOUND:{code:"APKT001",displayMessage:"Network Not Found",debugMessage:"The specified network is not recognized. Please ensure it is included in the `networks` array of your `createAppKit` configuration."},ORIGIN_NOT_ALLOWED:{code:"APKT002",displayMessage:"Invalid App Configuration",debugMessage:()=>`The origin ${Ur()?window.origin:"unknown"} is not in your allow list. Please update your allowed domains at https://dashboard.reown.com. [PID: ${_.state.projectId}]`},IFRAME_LOAD_FAILED:{code:"APKT003",displayMessage:"Network Error: Wallet Load Failed",debugMessage:()=>"Failed to load the embedded wallet. This may be due to network issues or server downtime. Please check your network connection and try again shortly. Contact support if the issue persists."},IFRAME_REQUEST_TIMEOUT:{code:"APKT004",displayMessage:"Wallet Request Timeout",debugMessage:()=>"The request to the embedded wallet timed out. Please check your network connection and try again shortly. Contact support if the issue persists."},UNVERIFIED_DOMAIN:{code:"APKT005",displayMessage:"Unverified Domain",debugMessage:()=>"Embedded wallet load failed. Ensure your domain is verified in https://dashboard.reown.com."},JWT_TOKEN_NOT_VALID:{code:"APKT006",displayMessage:"Session Expired",debugMessage:"Your session is invalid or expired. Please check your system’s date and time settings, then reconnect."},INVALID_PROJECT_ID:{code:"APKT007",displayMessage:"Invalid Project ID",debugMessage:"The specified project ID is invalid. Please visit https://dashboard.reown.com to obtain a valid project ID."},PROJECT_ID_NOT_CONFIGURED:{code:"APKT008",displayMessage:"Project ID Missing",debugMessage:"No project ID is configured. You can create and configure a project ID at https://dashboard.reown.com."},SERVER_ERROR_APP_CONFIGURATION:{code:"APKT009",displayMessage:"Server Error",debugMessage:t=>`Unable to fetch App Configuration. ${t}. Please check your network connection and try again shortly. Contact support if the issue persists.`},RATE_LIMITED_APP_CONFIGURATION:{code:"APKT010",displayMessage:"Rate Limited",debugMessage:"You have been rate limited while retrieving App Configuration. Please wait a few minutes and try again. Contact support if the issue persists."}},ALERT_WARNINGS:{LOCAL_CONFIGURATION_IGNORED:{debugMessage:t=>`[Reown Config Notice] ${t}`},INACTIVE_NAMESPACE_NOT_CONNECTED:{code:"APKTW001",displayMessage:"Inactive Namespace Not Connected",debugMessage:(t,e)=>`An error occurred while connecting an inactive namespace ${t}: "${e}"`},INVALID_EMAIL:{code:"APKTW002",displayMessage:"Invalid Email Address",debugMessage:"Please enter a valid email address"}}},gf={TOKEN_ADDRESSES_BY_SYMBOL:{USDC:{8453:ay.asset,84532:cy.asset}},getTokenSymbolByAddress(t){if(!t)return;const[e]=Object.entries(gf.TOKEN_ADDRESSES_BY_SYMBOL).find(([s,n])=>Object.values(n).includes(t))??[];return e}},OS={level:"info"},yl=1e3*1024;var PS=Object.defineProperty,kS=(t,e,s)=>e in t?PS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Js=(t,e,s)=>kS(t,typeof e!="symbol"?e+"":e,s);let RS=class{constructor(e){Js(this,"nodeValue"),Js(this,"sizeInBytes"),Js(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}},Md=class{constructor(e){Js(this,"lengthInNodes"),Js(this,"sizeInBytes"),Js(this,"head"),Js(this,"tail"),Js(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new RS(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 xS=Object.defineProperty,$S=(t,e,s)=>e in t?xS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,io=(t,e,s)=>$S(t,typeof e!="symbol"?e+"":e,s);let mf=class{constructor(e,s=yl){io(this,"logs"),io(this,"level"),io(this,"levelValue"),io(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Qt.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Md(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Qt.levels.values.error?console.error(e):s===Qt.levels.values.warn?console.warn(e):s===Qt.levels.values.debug?console.debug(e):s===Qt.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Rn({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 Md(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Rn({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var US=Object.defineProperty,DS=(t,e,s)=>e in t?US(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,LS=(t,e,s)=>DS(t,e+"",s);let MS=class{constructor(e,s=yl){LS(this,"baseChunkLogger"),this.baseChunkLogger=new mf(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 BS=Object.defineProperty,jS=(t,e,s)=>e in t?BS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,FS=(t,e,s)=>jS(t,e+"",s);let qS=class{constructor(e,s=yl){FS(this,"baseChunkLogger"),this.baseChunkLogger=new mf(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 WS=Object.defineProperty,HS=Object.defineProperties,KS=Object.getOwnPropertyDescriptors,Bd=Object.getOwnPropertySymbols,zS=Object.prototype.hasOwnProperty,VS=Object.prototype.propertyIsEnumerable,jd=(t,e,s)=>e in t?WS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Lo=(t,e)=>{for(var s in e||(e={}))zS.call(e,s)&&jd(t,s,e[s]);if(Bd)for(var s of Bd(e))VS.call(e,s)&&jd(t,s,e[s]);return t},Mo=(t,e)=>HS(t,KS(e));function GS(t){return Mo(Lo({},t),{level:(t==null?void 0:t.level)||OS.level})}function YS(t){var e,s;const n=new MS((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(Mo(Lo({},t.opts),{level:"trace",browser:Mo(Lo({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function JS(t){var e;const s=new qS((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(Mo(Lo({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function XS(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?YS(t):JS(t)}const ZS={createLogger(t,e="error"){const s=GS({level:e}),{logger:n}=XS({opts:s});return n.error=(...r)=>{for(const i of r)if(i instanceof Error){t(i,...r);return}t(void 0,...r)},n}},QS="rpc.walletconnect.org";function Fd(t,e){const s=new URL("https://rpc.walletconnect.org/v1/");return s.searchParams.set("chainId",t),s.searchParams.set("projectId",e),s.toString()}const Wa=["near:mainnet","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","eip155:1101","eip155:56","eip155:42161","eip155:7777777","eip155:59144","eip155:324","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1","eip155:5000","solana:4sgjmw1sunhzsxgspuhpqldx6wiyjntz","eip155:80084","eip155:5003","eip155:100","eip155:8453","eip155:42220","eip155:1313161555","eip155:17000","eip155:1","eip155:300","eip155:1313161554","eip155:1329","eip155:84532","eip155:421614","eip155:11155111","eip155:8217","eip155:43114","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","eip155:999999999","eip155:11155420","eip155:80002","eip155:97","eip155:43113","eip155:137","eip155:10","eip155:1301","eip155:80094","eip155:80069","eip155:560048","eip155:31","eip155:2818","eip155:57054","eip155:911867","eip155:534351","eip155:1112","eip155:534352","eip155:1111","eip155:146","eip155:130","eip155:1284","eip155:30","eip155:2810","bip122:000000000019d6689c085ae165831e93","bip122:000000000933ea01ad0ee984209779ba"],Zn={extendRpcUrlWithProjectId(t,e){let s=!1;try{s=new URL(t).host===QS}catch{s=!1}if(s){const n=new URL(t);return n.searchParams.has("projectId")||n.searchParams.set("projectId",e),n.toString()}return t},isCaipNetwork(t){return"chainNamespace"in t&&"caipNetworkId"in t},getChainNamespace(t){return this.isCaipNetwork(t)?t.chainNamespace:U.CHAIN.EVM},getCaipNetworkId(t){return this.isCaipNetwork(t)?t.caipNetworkId:`${U.CHAIN.EVM}:${t.id}`},getDefaultRpcUrl(t,e,s){var r,i,o;const n=(o=(i=(r=t.rpcUrls)==null?void 0:r.default)==null?void 0:i.http)==null?void 0:o[0];return Wa.includes(e)?Fd(e,s):n||""},extendCaipNetwork(t,{customNetworkImageUrls:e,projectId:s,customRpcUrls:n}){var h,p,g,f,y,w,b;const r=this.getChainNamespace(t),i=this.getCaipNetworkId(t),o=(g=(p=(h=t.rpcUrls)==null?void 0:h.default)==null?void 0:p.http)==null?void 0:g[0],a=this.getDefaultRpcUrl(t,i,s),c=((w=(y=(f=t==null?void 0:t.rpcUrls)==null?void 0:f.chainDefault)==null?void 0:y.http)==null?void 0:w[0])||o,l=((b=n==null?void 0:n[i])==null?void 0:b.map(E=>E.url))||[],u=[...l,...a?[a]:[]],d=[...l];return c&&!d.includes(c)&&d.push(c),{...t,chainNamespace:r,caipNetworkId:i,assets:{imageId:NS.NetworkImageIds[t.id],imageUrl:e==null?void 0:e[t.id]},rpcUrls:{...t.rpcUrls,default:{http:u},chainDefault:{http:d}}}},extendCaipNetworks(t,{customNetworkImageUrls:e,projectId:s,customRpcUrls:n}){return t.map(r=>Zn.extendCaipNetwork(r,{customNetworkImageUrls:e,customRpcUrls:n,projectId:s}))},getViemTransport(t,e,s){var r,i,o;const n=[];return s==null||s.forEach(a=>{n.push(Wi(a.url,a.config))}),Wa.includes(t.caipNetworkId)&&n.push(Wi(Fd(t.caipNetworkId,e),{fetchOptions:{headers:{"Content-Type":"text/plain"}}})),(o=(i=(r=t==null?void 0:t.rpcUrls)==null?void 0:r.default)==null?void 0:i.http)==null||o.forEach(a=>{n.push(Wi(a))}),xl(n)},extendWagmiTransports(t,e,s){if(Wa.includes(t.caipNetworkId)){const n=this.getDefaultRpcUrl(t,t.caipNetworkId,e);return xl([s,Wi(n)])}return s},getUnsupportedNetwork(t){return{id:t.split(":")[1],caipNetworkId:t,name:U.UNSUPPORTED_NETWORK_NAME,chainNamespace:t.split(":")[0],nativeCurrency:{name:"",decimals:0,symbol:""},rpcUrls:{default:{http:[]}}}},getCaipNetworkFromStorage(t){var c;const e=P.getActiveCaipNetworkId(),s=m.getAllRequestedCaipNetworks(),n=Array.from(((c=m.state.chains)==null?void 0:c.keys())||[]),r=e==null?void 0:e.split(":")[0],i=r?n.includes(r):!1,o=s==null?void 0:s.find(l=>l.caipNetworkId===e);return i&&!o&&e?this.getUnsupportedNetwork(e):o||t||(s==null?void 0:s[0])}},eN={ACCOUNT_TABS:[{label:"Tokens"},{label:"Activity"}],VIEW_DIRECTION:{Next:"next",Prev:"prev"},DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"],ANIMATION_DURATIONS:{HeaderText:120},VIEWS_WITH_LEGAL_FOOTER:["Connect","ConnectWallets","OnRampTokenSelect","OnRampFiatSelect","OnRampProviders"],VIEWS_WITH_DEFAULT_FOOTER:["Networks"]},Br={filterOutDuplicatesByRDNS(t){const e=_.state.enableEIP6963?L.state.connectors:[],s=P.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")&&V.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=L.state.connectors.filter(a=>a.type==="ANNOUNCED"||a.type==="INJECTED"),s=P.getRecentWallets(),n=e.map(a=>a.explorerId),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}=L.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),u=s.indexOf(a.id);if(l!==-1&&u!==-1)return l-u;if(l!==-1)return-1;if(u!==-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||L.state.connectors;if(s)return s;const{injected:r,announced:i}=Ha.getConnectorsByType(n,J.state.recommended,J.state.featured),o=r.filter(Ha.showConnector),a=i.filter(Ha.showConnector);return o.length||a.length?["wallet","email","social"]:eN.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(t){const e=!!t.rdns&&J.state.excludedWallets.some(n=>n.rdns===t.rdns),s=!!t.name&&J.state.excludedWallets.some(n=>Ai.isLowerCaseMatch(n.name,t.name));return e||s},markWalletsWithDisplayIndex(t){return t.map((e,s)=>({...e,display_index:s}))}},Ha={getConnectorsByType(t,e,s){const{customWallets:n}=_.state,r=P.getRecentWallets(),i=Br.filterOutDuplicateWallets(e),o=Br.filterOutDuplicateWallets(s),a=t.filter(d=>d.type==="MULTI_CHAIN"),c=t.filter(d=>d.type==="ANNOUNCED"),l=t.filter(d=>d.type==="INJECTED"),u=t.filter(d=>d.type==="EXTERNAL");return{custom:n,recent:r,external:u,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&&J.state.excludedWallets.some(i=>!!i.rdns&&i.rdns===e),n=!!t.name&&J.state.excludedWallets.some(i=>Ai.isLowerCaseMatch(i.name,t.name));return!(t.type==="INJECTED"&&(t.name==="Browser Wallet"&&(!V.isMobile()||V.isMobile()&&!e&&!j.checkInstalled())||s||n)||(t.type==="ANNOUNCED"||t.type==="EXTERNAL")&&(s||n))},getIsConnectedWithWC(){return Array.from(m.state.chains.values()).some(s=>L.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 d=[{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(d.map(f=>f.type)),p=c.filter(f=>h.has(f)).map(f=>({type:f,isEnabled:!0})),g=d.filter(({type:f})=>!p.some(({type:w})=>w===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"&&!V.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=P.getRecentWallets(),s=L.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")&&V.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 L.state.connectors.some(e=>e.id===t.id||e.name===t.name)},isWalletCompatibleWithCurrentChain(t){const e=m.state.activeChain;return e&&t.chains?t.chains.some(s=>{const n=s.split(":")[0];return e===n}):!0},getFilteredRecentWallets(){return P.getRecentWallets().filter(s=>!Br.isExcluded(s)).filter(s=>!this.hasWalletConnector(s)).filter(s=>this.isWalletCompatibleWithCurrentChain(s))},getCappedRecommendedWallets(t){const{connectors:e}=L.state,{customWallets:s,featuredWalletIds:n}=_.state,r=e.find(b=>b.id==="walletConnect"),i=e.filter(b=>b.type==="INJECTED"||b.type==="ANNOUNCED"||b.type==="MULTI_CHAIN");if(!r&&!i.length&&!(s!=null&&s.length))return[];const o=Qa.isEmailEnabled(),a=Qa.isSocialsEnabled(),c=i.filter(b=>b.name!=="Browser Wallet"),l=(n==null?void 0:n.length)||0,u=(s==null?void 0:s.length)||0,d=c.length||0,h=o?1:0,p=a?1:0,g=l+u+d+h+p,y=Math.max(0,4-g);return y<=0?[]:Br.filterOutDuplicateWallets(t).slice(0,y)}};/**
|
|
19
|
+
Approved: ${h.toString()}`))}),o.forEach(d=>{n||(An(r[d].methods,i[d].methods)?An(r[d].events,i[d].events)||(n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces events don't satisfy namespace events for ${d}`)):n=M("NON_CONFORMING_NAMESPACES",`${s} namespaces methods don't satisfy namespace methods for ${d}`))}),n}function SE(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 Hu(t){return[...new Set(t.map(e=>e.includes(":")?e.split(":")[0]:e))]}function NE(t){const e={};return Object.keys(t).forEach(s=>{if(s.includes(":"))e[s]=t[s];else{const n=Cr(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 TE(t,e){return ul(t,!1)&&t<=e.max&&t>=e.min}function Ku(){const t=Pi();return new Promise(e=>{switch(t){case Ot.browser:e(OE());break;case Ot.reactNative:e(PE());break;case Ot.node:e(kE());break;default:e(!0)}})}function OE(){return Er()&&(navigator==null?void 0:navigator.onLine)}async function PE(){if(on()&&typeof global<"u"&&global!=null&&global.NetInfo){const t=await(global==null?void 0:global.NetInfo.fetch());return t==null?void 0:t.isConnected}return!0}function kE(){return!0}function RE(t){switch(Pi()){case Ot.browser:xE(t);break;case Ot.reactNative:$E(t);break}}function xE(t){!on()&&Er()&&(window.addEventListener("online",()=>t(!0)),window.addEventListener("offline",()=>t(!1)))}function $E(t){on()&&typeof global<"u"&&global!=null&&global.NetInfo&&(global==null||global.NetInfo.addEventListener(e=>t(e==null?void 0:e.isConnected)))}function UE(){var t;return Er()&&ur()?((t=ur())==null?void 0:t.visibilityState)==="visible":!0}const Pa={};class Tr{static get(e){return Pa[e]}static set(e,s){Pa[e]=s}static delete(e){delete Pa[e]}}function DE(t){const e=br.decode(t);if(e.length<33)throw new Error("Too short to contain a public key");return e.slice(1,33)}function LE({publicKey:t,signature:e,payload:s}){var n;const r=Ec(s.method),i=128|parseInt(((n=s.version)==null?void 0:n.toString())||"4"),o=jE(s.address),a=s.era==="00"?new Uint8Array([0]):Ec(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]),u=BigInt(`0x${BE(s.tip)}`),d=qE(u),h=new Uint8Array([0,...t,o,...e,...a,...l,...d,...r]),p=FE(h.length+1);return new Uint8Array([...p,i,...h])}function ME(t){const e=Ec(t),s=Bf.blake2b(e,void 0,32);return"0x"+Buffer.from(s).toString("hex")}function Ec(t){return new Uint8Array(t.replace(/^0x/,"").match(/.{1,2}/g).map(e=>parseInt(e,16)))}function BE(t){return t.startsWith("0x")?t.slice(2):t}function jE(t){const e=br.decode(t)[0];return e===42?0:e===60?2:1}function FE(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 qE(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 WE(t){const e=Uint8Array.from(Buffer.from(t.signature,"hex")),s=DE(t.transaction.address),n=LE({publicKey:s,signature:e,payload:t.transaction}),r=Buffer.from(n).toString("hex");return ME(r)}function dl({logger:t,name:e}){const s=typeof t=="string"?Oh({opts:{level:t,name:e}}).logger:t;return s.level=typeof t=="string"?t:t.level,s}var HE={VITE_SEGMENT_PROD_API_KEY:"J46ds5KOLHjFZ1GJQCYm4oNXpeWy9hpV"};const $p="wc",Up=2,Cc="core",gs=`${$p}@2:${Cc}:`,KE={logger:"error"},zE={database:":memory:"},VE="crypto",zu="client_ed25519_seed",GE=F.ONE_DAY,YE="keychain",JE="0.3",XE="messages",ZE="0.3",QE=F.SIX_HOURS,eC="publisher",Dp="irn",tC="error",Lp="wss://relay.walletconnect.org",sC="relayer",Le={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"},nC="_subscription",xt={payload:"payload",connect:"connect",disconnect:"disconnect",error:"error"},rC=.1,Ac="2.22.4",Pe={link_mode:"link_mode",relay:"relay"},mo={inbound:"inbound",outbound:"outbound"},iC="0.3",oC="WALLETCONNECT_CLIENT_ID",Vu="WALLETCONNECT_LINK_MODE_APPS",_t={created:"subscription_created",deleted:"subscription_deleted",expired:"subscription_expired",disabled:"subscription_disabled",sync:"subscription_sync",resubscribed:"subscription_resubscribed"},aC="subscription",cC="0.3",lC="pairing",uC="0.3",Or={wc_pairingDelete:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1e3},res:{ttl:F.ONE_DAY,prompt:!1,tag:1001}},wc_pairingPing:{req:{ttl:F.THIRTY_SECONDS,prompt:!1,tag:1002},res:{ttl:F.THIRTY_SECONDS,prompt:!1,tag:1003}},unregistered_method:{req:{ttl:F.ONE_DAY,prompt:!1,tag:0},res:{ttl:F.ONE_DAY,prompt:!1,tag:0}}},wn={create:"pairing_create",expire:"pairing_expire",delete:"pairing_delete",ping:"pairing_ping"},Vt={created:"history_created",updated:"history_updated",deleted:"history_deleted",sync:"history_sync"},dC="history",hC="0.3",pC="expirer",Mt={created:"expirer_created",deleted:"expirer_deleted",expired:"expirer_expired",sync:"expirer_sync"},fC="0.3",gC="verify-api",mC="https://verify.walletconnect.com",Mp="https://verify.walletconnect.org",Kr=Mp,yC=`${Kr}/v3`,wC=[mC,Mp],bC="echo",vC="https://echo.walletconnect.com",is={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"},vs={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"},Gt={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"},hn={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"},pn={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"},Pr={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"},EC=.1,CC="event-client",AC=86400,IC="https://pulse.walletconnect.org/batch";function _C(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),u=Math.log(256)/Math.log(a);function d(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,w=0,b=g.length;w!==b&&g[w]===0;)w++,f++;for(var E=(b-w)*u+1>>>0,N=new Uint8Array(E);w!==b;){for(var x=g[w],$=0,W=E-1;(x!==0||$<y)&&W!==-1;W--,$++)x+=256*N[W]>>>0,N[W]=x%a>>>0,x=x/a>>>0;if(x!==0)throw new Error("Non-zero carry");y=$,w++}for(var G=E-y;G!==E&&N[G]===0;)G++;for(var k=c.repeat(f);G<E;++G)k+=t.charAt(N[G]);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,w=0;g[f]===c;)y++,f++;for(var b=(g.length-f)*l+1>>>0,E=new Uint8Array(b);g[f];){var N=s[g.charCodeAt(f)];if(N===255)return;for(var x=0,$=b-1;(N!==0||x<w)&&$!==-1;$--,x++)N+=a*E[$]>>>0,E[$]=N%256>>>0,N=N/256>>>0;if(N!==0)throw new Error("Non-zero carry");w=x,f++}if(g[f]!==" "){for(var W=b-w;W!==b&&E[W]===0;)W++;for(var G=new Uint8Array(y+(b-W)),k=y;W!==b;)G[k++]=E[W++];return G}}}function p(g){var f=h(g);if(f)return f;throw new Error(`Non-${e} character`)}return{encode:d,decodeUnsafe:h,decode:p}}var SC=_C,NC=SC;const Bp=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")},TC=t=>new TextEncoder().encode(t),OC=t=>new TextDecoder().decode(t);class PC{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 kC{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 jp(this,e)}}class RC{constructor(e){this.decoders=e}or(e){return jp(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 jp=(t,e)=>new RC({...t.decoders||{[t.prefix]:t},...e.decoders||{[e.prefix]:e}});class xC{constructor(e,s,n,r){this.name=e,this.prefix=s,this.baseEncode=n,this.baseDecode=r,this.encoder=new PC(e,s,n),this.decoder=new kC(e,s,r)}encode(e){return this.encoder.encode(e)}decode(e){return this.decoder.decode(e)}}const na=({name:t,prefix:e,encode:s,decode:n})=>new xC(t,e,s,n),Ui=({prefix:t,name:e,alphabet:s})=>{const{encode:n,decode:r}=NC(s,e);return na({prefix:t,name:e,encode:n,decode:i=>Bp(r(i))})},$C=(t,e,s,n)=>{const r={};for(let u=0;u<e.length;++u)r[e[u]]=u;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 u=0;u<i;++u){const d=r[t[u]];if(d===void 0)throw new SyntaxError(`Non-${n} character`);c=c<<s|d,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},UC=(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},et=({name:t,prefix:e,bitsPerChar:s,alphabet:n})=>na({prefix:e,name:t,encode(r){return UC(r,n,s)},decode(r){return $C(r,n,s,t)}}),DC=na({prefix:"\0",name:"identity",encode:t=>OC(t),decode:t=>TC(t)});var LC=Object.freeze({__proto__:null,identity:DC});const MC=et({prefix:"0",name:"base2",alphabet:"01",bitsPerChar:1});var BC=Object.freeze({__proto__:null,base2:MC});const jC=et({prefix:"7",name:"base8",alphabet:"01234567",bitsPerChar:3});var FC=Object.freeze({__proto__:null,base8:jC});const qC=Ui({prefix:"9",name:"base10",alphabet:"0123456789"});var WC=Object.freeze({__proto__:null,base10:qC});const HC=et({prefix:"f",name:"base16",alphabet:"0123456789abcdef",bitsPerChar:4}),KC=et({prefix:"F",name:"base16upper",alphabet:"0123456789ABCDEF",bitsPerChar:4});var zC=Object.freeze({__proto__:null,base16:HC,base16upper:KC});const VC=et({prefix:"b",name:"base32",alphabet:"abcdefghijklmnopqrstuvwxyz234567",bitsPerChar:5}),GC=et({prefix:"B",name:"base32upper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567",bitsPerChar:5}),YC=et({prefix:"c",name:"base32pad",alphabet:"abcdefghijklmnopqrstuvwxyz234567=",bitsPerChar:5}),JC=et({prefix:"C",name:"base32padupper",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZ234567=",bitsPerChar:5}),XC=et({prefix:"v",name:"base32hex",alphabet:"0123456789abcdefghijklmnopqrstuv",bitsPerChar:5}),ZC=et({prefix:"V",name:"base32hexupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV",bitsPerChar:5}),QC=et({prefix:"t",name:"base32hexpad",alphabet:"0123456789abcdefghijklmnopqrstuv=",bitsPerChar:5}),e1=et({prefix:"T",name:"base32hexpadupper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUV=",bitsPerChar:5}),t1=et({prefix:"h",name:"base32z",alphabet:"ybndrfg8ejkmcpqxot1uwisza345h769",bitsPerChar:5});var s1=Object.freeze({__proto__:null,base32:VC,base32upper:GC,base32pad:YC,base32padupper:JC,base32hex:XC,base32hexupper:ZC,base32hexpad:QC,base32hexpadupper:e1,base32z:t1});const n1=Ui({prefix:"k",name:"base36",alphabet:"0123456789abcdefghijklmnopqrstuvwxyz"}),r1=Ui({prefix:"K",name:"base36upper",alphabet:"0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ"});var i1=Object.freeze({__proto__:null,base36:n1,base36upper:r1});const o1=Ui({name:"base58btc",prefix:"z",alphabet:"123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"}),a1=Ui({name:"base58flickr",prefix:"Z",alphabet:"123456789abcdefghijkmnopqrstuvwxyzABCDEFGHJKLMNPQRSTUVWXYZ"});var c1=Object.freeze({__proto__:null,base58btc:o1,base58flickr:a1});const l1=et({prefix:"m",name:"base64",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/",bitsPerChar:6}),u1=et({prefix:"M",name:"base64pad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=",bitsPerChar:6}),d1=et({prefix:"u",name:"base64url",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_",bitsPerChar:6}),h1=et({prefix:"U",name:"base64urlpad",alphabet:"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789-_=",bitsPerChar:6});var p1=Object.freeze({__proto__:null,base64:l1,base64pad:u1,base64url:d1,base64urlpad:h1});const Fp=Array.from("🚀🪐☄🛰🌌🌑🌒🌓🌔🌕🌖🌗🌘🌍🌏🌎🐉☀💻🖥💾💿😂❤😍🤣😊🙏💕😭😘👍😅👏😁🔥🥰💔💖💙😢🤔😆🙄💪😉☺👌🤗💜😔😎😇🌹🤦🎉💞✌✨🤷😱😌🌸🙌😋💗💚😏💛🙂💓🤩😄😀🖤😃💯🙈👇🎶😒🤭❣😜💋👀😪😑💥🙋😞😩😡🤪👊🥳😥🤤👉💃😳✋😚😝😴🌟😬🙃🍀🌷😻😓⭐✅🥺🌈😈🤘💦✔😣🏃💐☹🎊💘😠☝😕🌺🎂🌻😐🖕💝🙊😹🗣💫💀👑🎵🤞😛🔴😤🌼😫⚽🤙☕🏆🤫👈😮🙆🍻🍃🐶💁😲🌿🧡🎁⚡🌞🎈❌✊👋😰🤨😶🤝🚶💰🍓💢🤟🙁🚨💨🤬✈🎀🍺🤓😙💟🌱😖👶🥴▶➡❓💎💸⬇😨🌚🦋😷🕺⚠🙅😟😵👎🤲🤠🤧📌🔵💅🧐🐾🍒😗🤑🌊🤯🐷☎💧😯💆👆🎤🙇🍑❄🌴💣🐸💌📍🥀🤢👅💡💩👐📸👻🤐🤮🎼🥵🚩🍎🍊👼💍📣🥂"),f1=Fp.reduce((t,e,s)=>(t[s]=e,t),[]),g1=Fp.reduce((t,e,s)=>(t[e.codePointAt(0)]=s,t),[]);function m1(t){return t.reduce((e,s)=>(e+=f1[s],e),"")}function y1(t){const e=[];for(const s of t){const n=g1[s.codePointAt(0)];if(n===void 0)throw new Error(`Non-base256emoji character: ${s}`);e.push(n)}return new Uint8Array(e)}const w1=na({prefix:"🚀",name:"base256emoji",encode:m1,decode:y1});var b1=Object.freeze({__proto__:null,base256emoji:w1}),v1=qp,Gu=128,E1=-128,C1=Math.pow(2,31);function qp(t,e,s){e=e||[],s=s||0;for(var n=s;t>=C1;)e[s++]=t&255|Gu,t/=128;for(;t&E1;)e[s++]=t&255|Gu,t>>>=7;return e[s]=t|0,qp.bytes=s-n+1,e}var A1=Ic,I1=128,Yu=127;function Ic(t,n){var s=0,n=n||0,r=0,i=n,o,a=t.length;do{if(i>=a)throw Ic.bytes=0,new RangeError("Could not decode varint");o=t[i++],s+=r<28?(o&Yu)<<r:(o&Yu)*Math.pow(2,r),r+=7}while(o>=I1);return Ic.bytes=i-n,s}var _1=Math.pow(2,7),S1=Math.pow(2,14),N1=Math.pow(2,21),T1=Math.pow(2,28),O1=Math.pow(2,35),P1=Math.pow(2,42),k1=Math.pow(2,49),R1=Math.pow(2,56),x1=Math.pow(2,63),$1=function(t){return t<_1?1:t<S1?2:t<N1?3:t<T1?4:t<O1?5:t<P1?6:t<k1?7:t<R1?8:t<x1?9:10},U1={encode:v1,decode:A1,encodingLength:$1},Wp=U1;const Ju=(t,e,s=0)=>(Wp.encode(t,e,s),e),Xu=t=>Wp.encodingLength(t),_c=(t,e)=>{const s=e.byteLength,n=Xu(t),r=n+Xu(s),i=new Uint8Array(r+s);return Ju(t,i,0),Ju(s,i,n),i.set(e,r),new D1(t,s,e,i)};class D1{constructor(e,s,n,r){this.code=e,this.size=s,this.digest=n,this.bytes=r}}const Hp=({name:t,code:e,encode:s})=>new L1(t,e,s);class L1{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?_c(this.code,s):s.then(n=>_c(this.code,n))}else throw Error("Unknown type, must be binary type")}}const Kp=t=>async e=>new Uint8Array(await crypto.subtle.digest(t,e)),M1=Hp({name:"sha2-256",code:18,encode:Kp("SHA-256")}),B1=Hp({name:"sha2-512",code:19,encode:Kp("SHA-512")});var j1=Object.freeze({__proto__:null,sha256:M1,sha512:B1});const zp=0,F1="identity",Vp=Bp,q1=t=>_c(zp,Vp(t)),W1={code:zp,name:F1,encode:Vp,digest:q1};var H1=Object.freeze({__proto__:null,identity:W1});new TextEncoder,new TextDecoder;const Zu={...LC,...BC,...FC,...WC,...zC,...s1,...i1,...c1,...p1,...b1};({...j1,...H1});function Gp(t){return globalThis.Buffer!=null?new Uint8Array(t.buffer,t.byteOffset,t.byteLength):t}function K1(t=0){return globalThis.Buffer!=null&&globalThis.Buffer.allocUnsafe!=null?Gp(globalThis.Buffer.allocUnsafe(t)):new Uint8Array(t)}function Yp(t,e,s,n){return{name:t,prefix:e,encoder:{name:t,prefix:e,encode:s},decoder:{decode:n}}}const Qu=Yp("utf8","u",t=>"u"+new TextDecoder("utf8").decode(t),t=>new TextEncoder().encode(t.substring(1))),ka=Yp("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=K1(t.length);for(let s=0;s<t.length;s++)e[s]=t.charCodeAt(s);return e}),z1={utf8:Qu,"utf-8":Qu,hex:Zu.base16,latin1:ka,ascii:ka,binary:ka,...Zu};function V1(t,e="utf8"){const s=z1[e];if(!s)throw new Error(`Unsupported encoding "${e}"`);return(e==="utf8"||e==="utf-8")&&globalThis.Buffer!=null&&globalThis.Buffer.from!=null?Gp(globalThis.Buffer.from(t,"utf-8")):s.decoder.decode(`${s.prefix}${t}`)}var G1=Object.defineProperty,Y1=(t,e,s)=>e in t?G1(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,ns=(t,e,s)=>Y1(t,typeof e!="symbol"?e+"":e,s);class J1{constructor(e,s){this.core=e,this.logger=s,ns(this,"keychain",new Map),ns(this,"name",YE),ns(this,"version",JE),ns(this,"initialized",!1),ns(this,"storagePrefix",gs),ns(this,"init",async()=>{if(!this.initialized){const n=await this.getKeyChain();typeof n<"u"&&(this.keychain=n),this.initialized=!0}}),ns(this,"has",n=>(this.isInitialized(),this.keychain.has(n))),ns(this,"set",async(n,r)=>{this.isInitialized(),this.keychain.set(n,r),await this.persist()}),ns(this,"get",n=>{this.isInitialized();const r=this.keychain.get(n);if(typeof r>"u"){const{message:i}=M("NO_MATCHING_KEY",`${this.name}: ${n}`);throw new Error(i)}return r}),ns(this,"del",async n=>{this.isInitialized(),this.keychain.delete(n),await this.persist()}),this.core=e,this.logger=kt(s,this.name)}get context(){return Et(this.logger)}get storageKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//"+this.name}async setKeyChain(e){await this.core.storage.setItem(this.storageKey,cc(e))}async getKeyChain(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?lc(e):void 0}async persist(){await this.setKeyChain(this.keychain)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var X1=Object.defineProperty,Z1=(t,e,s)=>e in t?X1(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,He=(t,e,s)=>Z1(t,typeof e!="symbol"?e+"":e,s);class Q1{constructor(e,s,n){this.core=e,this.logger=s,He(this,"name",VE),He(this,"keychain"),He(this,"randomSessionIdentifier",vc()),He(this,"initialized",!1),He(this,"clientId"),He(this,"init",async()=>{this.initialized||(await this.keychain.init(),this.initialized=!0)}),He(this,"hasKeys",r=>(this.isInitialized(),this.keychain.has(r))),He(this,"getClientId",async()=>{if(this.isInitialized(),this.clientId)return this.clientId;const r=await this.getClientSeed(),i=Cl(r),o=Hf(i.publicKey);return this.clientId=o,o}),He(this,"generateKeyPair",()=>{this.isInitialized();const r=N0();return this.setPrivateKey(r.publicKey,r.privateKey)}),He(this,"signJWT",async r=>{this.isInitialized();const i=await this.getClientSeed(),o=Cl(i),a=this.randomSessionIdentifier;return await Kf(a,r,GE,o)}),He(this,"generateSharedKey",(r,i,o)=>{this.isInitialized();const a=this.getPrivateKey(r),c=T0(a,i);return this.setSymKey(c,o)}),He(this,"setSymKey",async(r,i)=>{this.isInitialized();const o=i||go(r);return await this.keychain.set(o,r),o}),He(this,"deleteKeyPair",async r=>{this.isInitialized(),await this.keychain.del(r)}),He(this,"deleteSymKey",async r=>{this.isInitialized(),await this.keychain.del(r)}),He(this,"encode",async(r,i,o)=>{this.isInitialized();const a=kp(o),c=Rn(i);if(Ru(a))return k0(c,o==null?void 0:o.encoding);if(ku(a)){const h=a.senderPublicKey,p=a.receiverPublicKey;r=await this.generateSharedKey(h,p)}const l=this.getSymKey(r),{type:u,senderPublicKey:d}=a;return O0({type:u,symKey:l,message:c,senderPublicKey:d,encoding:o==null?void 0:o.encoding})}),He(this,"decode",async(r,i,o)=>{this.isInitialized();const a=x0(i,o);if(Ru(a)){const c=R0(i,o==null?void 0:o.encoding);return Eo(c)}if(ku(a)){const c=a.receiverPublicKey,l=a.senderPublicKey;r=await this.generateSharedKey(c,l)}try{const c=this.getSymKey(r),l=P0({symKey:c,encoded:i,encoding:o==null?void 0:o.encoding});return Eo(l)}catch(c){this.logger.error(`Failed to decode message from topic: '${r}', clientId: '${await this.getClientId()}'`),this.logger.error(c)}}),He(this,"getPayloadType",(r,i=yt)=>{const o=Ci({encoded:r,encoding:i});return Dn(o.type)}),He(this,"getPayloadSenderPublicKey",(r,i=yt)=>{const o=Ci({encoded:r,encoding:i});return o.senderPublicKey?bt(o.senderPublicKey,lt):void 0}),this.core=e,this.logger=kt(s,this.name),this.keychain=n||new J1(this.core,this.logger)}get context(){return Et(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(zu)}catch{e=vc(),await this.keychain.set(zu,e)}return V1(e,"base16")}getSymKey(e){return this.keychain.get(e)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var eA=Object.defineProperty,tA=Object.defineProperties,sA=Object.getOwnPropertyDescriptors,ed=Object.getOwnPropertySymbols,nA=Object.prototype.hasOwnProperty,rA=Object.prototype.propertyIsEnumerable,Sc=(t,e,s)=>e in t?eA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,iA=(t,e)=>{for(var s in e||(e={}))nA.call(e,s)&&Sc(t,s,e[s]);if(ed)for(var s of ed(e))rA.call(e,s)&&Sc(t,s,e[s]);return t},oA=(t,e)=>tA(t,sA(e)),At=(t,e,s)=>Sc(t,typeof e!="symbol"?e+"":e,s);class aA extends uw{constructor(e,s){super(e,s),this.logger=e,this.core=s,At(this,"messages",new Map),At(this,"messagesWithoutClientAck",new Map),At(this,"name",XE),At(this,"version",ZE),At(this,"initialized",!1),At(this,"storagePrefix",gs),At(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}}}),At(this,"set",async(n,r,i)=>{this.isInitialized();const o=Bt(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===mo.inbound){const c=this.messagesWithoutClientAck.get(n)||{};this.messagesWithoutClientAck.set(n,oA(iA({},c),{[o]:r}))}return await this.persist(),o}),At(this,"get",n=>{this.isInitialized();let r=this.messages.get(n);return typeof r>"u"&&(r={}),r}),At(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}),At(this,"has",(n,r)=>{this.isInitialized();const i=this.get(n),o=Bt(r);return typeof i[o]<"u"}),At(this,"ack",async(n,r)=>{this.isInitialized();const i=this.messagesWithoutClientAck.get(n);if(typeof i>"u")return;const o=Bt(r);delete i[o],Object.keys(i).length===0?this.messagesWithoutClientAck.delete(n):this.messagesWithoutClientAck.set(n,i),await this.persist()}),At(this,"del",async n=>{this.isInitialized(),this.messages.delete(n),this.messagesWithoutClientAck.delete(n),await this.persist()}),this.logger=kt(e,this.name),this.core=s}get context(){return Et(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,cc(e))}async setRelayerMessagesWithoutClientAck(e){await this.core.storage.setItem(this.storageKeyWithoutClientAck,cc(e))}async getRelayerMessages(){const e=await this.core.storage.getItem(this.storageKey);return typeof e<"u"?lc(e):void 0}async getRelayerMessagesWithoutClientAck(){const e=await this.core.storage.getItem(this.storageKeyWithoutClientAck);return typeof e<"u"?lc(e):void 0}async persist(){await this.setRelayerMessages(this.messages),await this.setRelayerMessagesWithoutClientAck(this.messagesWithoutClientAck)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var cA=Object.defineProperty,lA=Object.defineProperties,uA=Object.getOwnPropertyDescriptors,td=Object.getOwnPropertySymbols,dA=Object.prototype.hasOwnProperty,hA=Object.prototype.propertyIsEnumerable,Nc=(t,e,s)=>e in t?cA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Gn=(t,e)=>{for(var s in e||(e={}))dA.call(e,s)&&Nc(t,s,e[s]);if(td)for(var s of td(e))hA.call(e,s)&&Nc(t,s,e[s]);return t},sd=(t,e)=>lA(t,uA(e)),$t=(t,e,s)=>Nc(t,typeof e!="symbol"?e+"":e,s);class pA extends dw{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,$t(this,"events",new Mn.EventEmitter),$t(this,"name",eC),$t(this,"queue",new Map),$t(this,"publishTimeout",F.toMiliseconds(F.ONE_MINUTE)),$t(this,"initialPublishTimeout",F.toMiliseconds(F.ONE_SECOND*15)),$t(this,"needsTransportRestart",!1),$t(this,"publish",async(n,r,i)=>{var o,a,c,l,u;this.logger.debug("Publishing Payload"),this.logger.trace({type:"method",method:"publish",params:{topic:n,message:r,opts:i}});const d=(i==null?void 0:i.ttl)||QE,h=(i==null?void 0:i.prompt)||!1,p=(i==null?void 0:i.tag)||0,g=(i==null?void 0:i.id)||En().toString(),f=tr(Uo().protocol),y={id:g,method:(i==null?void 0:i.publishMethod)||f.publish,params:Gn({topic:n,message:r,ttl:d,prompt:h,tag:p,attestation:i==null?void 0:i.attestation},i==null?void 0:i.tvf)},w=`Failed to publish payload, please try again. id:${g} tag:${p}`;try{We((o=y.params)==null?void 0:o.prompt)&&((a=y.params)==null||delete a.prompt),We((c=y.params)==null?void 0:c.tag)&&((l=y.params)==null||delete l.tag);const b=new Promise(async E=>{const N=({id:$})=>{var W;((W=y.id)==null?void 0:W.toString())===$.toString()&&(this.removeRequestFromQueue($),this.relayer.events.removeListener(Le.publish,N),E())};this.relayer.events.on(Le.publish,N);const x=us(new Promise(($,W)=>{this.rpcPublish(y,i).then($).catch(G=>{this.logger.warn(G,G==null?void 0:G.message),W(G)})}),this.initialPublishTimeout,`Failed initial publish, retrying.... id:${g} tag:${p}`);try{await x,this.events.removeListener(Le.publish,N)}catch($){this.queue.set(g,{request:y,opts:i,attempt:1}),this.logger.warn($,$==null?void 0:$.message)}});this.logger.trace({type:"method",method:"publish",params:{id:g,topic:n,message:r,opts:i}}),await us(b,this.publishTimeout,w)}catch(b){if(this.logger.debug("Failed to Publish Payload"),this.logger.error(b),(u=i==null?void 0:i.internal)!=null&&u.throwOnFailedPublish)throw b}finally{this.queue.delete(g)}}),$t(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:u={}}=n,{attestation:d,tvf:h,publishMethod:p,prompt:g,tag:f,ttl:y=F.FIVE_MINUTES}=u,w=u.id||En().toString(),b=tr(Uo().protocol),E=p||b.publish,N={id:w,method:E,params:Gn(sd(Gn({},l),{ttl:y,prompt:g,tag:f,attestation:d}),h)},x=`Failed to publish custom payload, please try again. id:${w} tag:${f}`;try{We((r=N.params)==null?void 0:r.prompt)&&((i=N.params)==null||delete i.prompt),We((o=N.params)==null?void 0:o.tag)&&((a=N.params)==null||delete a.tag);const $=new Promise(async W=>{const G=({id:Q})=>{var se;((se=N.id)==null?void 0:se.toString())===Q.toString()&&(this.removeRequestFromQueue(Q),this.relayer.events.removeListener(Le.publish,G),W())};this.relayer.events.on(Le.publish,G);const k=us(new Promise((Q,se)=>{this.rpcPublish(N,u).then(Q).catch(T=>{this.logger.warn(T,T==null?void 0:T.message),se(T)})}),this.initialPublishTimeout,`Failed initial custom payload publish, retrying.... method:${E} id:${w} tag:${f}`);try{await k,this.events.removeListener(Le.publish,G)}catch(Q){this.queue.set(w,{request:N,opts:u,attempt:1}),this.logger.warn(Q,Q==null?void 0:Q.message)}});this.logger.trace({type:"method",method:"publish",params:{id:w,payload:l,opts:u}}),await us($,this.publishTimeout,x)}catch($){if(this.logger.debug("Failed to Publish Payload"),this.logger.error($),(c=u==null?void 0:u.internal)!=null&&c.throwOnFailedPublish)throw $}finally{this.queue.delete(w)}}),$t(this,"on",(n,r)=>{this.events.on(n,r)}),$t(this,"once",(n,r)=>{this.events.once(n,r)}),$t(this,"off",(n,r)=>{this.events.off(n,r)}),$t(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.relayer=e,this.logger=kt(s,this.name),this.registerEventListeners()}get context(){return Et(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(Le.publish,Gn(Gn({},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,sd(Gn({},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(vr.pulse,()=>{if(this.needsTransportRestart){this.needsTransportRestart=!1,this.relayer.events.emit(Le.connection_stalled);return}this.checkQueue()}),this.relayer.on(Le.message_ack,e=>{this.removeRequestFromQueue(e.id.toString())})}}var fA=Object.defineProperty,gA=(t,e,s)=>e in t?fA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Yn=(t,e,s)=>gA(t,typeof e!="symbol"?e+"":e,s);class mA{constructor(){Yn(this,"map",new Map),Yn(this,"set",(e,s)=>{const n=this.get(e);this.exists(e,s)||this.map.set(e,[...n,s])}),Yn(this,"get",e=>this.map.get(e)||[]),Yn(this,"exists",(e,s)=>this.get(e).includes(s)),Yn(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)}),Yn(this,"clear",()=>{this.map.clear()})}get topics(){return Array.from(this.map.keys())}}var yA=Object.defineProperty,wA=Object.defineProperties,bA=Object.getOwnPropertyDescriptors,nd=Object.getOwnPropertySymbols,vA=Object.prototype.hasOwnProperty,EA=Object.prototype.propertyIsEnumerable,Tc=(t,e,s)=>e in t?yA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kr=(t,e)=>{for(var s in e||(e={}))vA.call(e,s)&&Tc(t,s,e[s]);if(nd)for(var s of nd(e))EA.call(e,s)&&Tc(t,s,e[s]);return t},Ra=(t,e)=>wA(t,bA(e)),Ne=(t,e,s)=>Tc(t,typeof e!="symbol"?e+"":e,s);class CA extends fw{constructor(e,s){super(e,s),this.relayer=e,this.logger=s,Ne(this,"subscriptions",new Map),Ne(this,"topicMap",new mA),Ne(this,"events",new Mn.EventEmitter),Ne(this,"name",aC),Ne(this,"version",cC),Ne(this,"pending",new Map),Ne(this,"cached",[]),Ne(this,"initialized",!1),Ne(this,"storagePrefix",gs),Ne(this,"subscribeTimeout",F.toMiliseconds(F.ONE_MINUTE)),Ne(this,"initialSubscribeTimeout",F.toMiliseconds(F.ONE_SECOND*15)),Ne(this,"clientId"),Ne(this,"batchSubscribeTopicsLimit",500),Ne(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),this.registerEventListeners(),await this.restore()),this.initialized=!0}),Ne(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=Uo(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}}),Ne(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)}),Ne(this,"isSubscribed",n=>new Promise(r=>{r(this.topicMap.topics.includes(n))})),Ne(this,"isKnownTopic",n=>new Promise(r=>{r(this.topicMap.topics.includes(n)||this.pending.has(n)||this.cached.some(i=>i.topic===n))})),Ne(this,"on",(n,r)=>{this.events.on(n,r)}),Ne(this,"once",(n,r)=>{this.events.once(n,r)}),Ne(this,"off",(n,r)=>{this.events.off(n,r)}),Ne(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),Ne(this,"start",async()=>{await this.onConnect()}),Ne(this,"stop",async()=>{await this.onDisconnect()}),Ne(this,"restart",async()=>{await this.restore(),await this.onRestart()}),Ne(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)}),Ne(this,"registerEventListeners",()=>{this.relayer.core.heartbeat.on(vr.pulse,async()=>{await this.checkPending()}),this.events.on(_t.created,async n=>{const r=_t.created;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()}),this.events.on(_t.deleted,async n=>{const r=_t.deleted;this.logger.info(`Emitting ${r}`),this.logger.debug({type:"event",event:r,data:n}),await this.persist()})}),this.relayer=e,this.logger=kt(s,this.name),this.clientId=""}get context(){return Et(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=Uo(n);await this.restartToComplete({topic:e,id:s,relay:r}),await this.rpcUnsubscribe(e,s,r);const i=$e("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)===Pe.relay)&&await this.restartToComplete({topic:e,id:e,relay:s});const a={method:tr(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)===Pe.link_mode)return setTimeout(()=>{(this.relayer.connected||this.relayer.connecting)&&this.relayer.request(a).catch(d=>this.logger.warn(d))},F.toMiliseconds(F.ONE_SECOND)),o;const l=new Promise(async d=>{const h=p=>{p.topic===e&&(this.events.removeListener(_t.created,h),d(p.id))};this.events.on(_t.created,h);try{const p=await us(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(_t.created,h),d(p)}catch{}}),u=await us(l,this.subscribeTimeout,`Subscribing to ${e} failed, please try again`);if(!u&&c)throw new Error(`Subscribing to ${e} failed, please try again`);return u?o:null}catch(l){if(this.logger.debug("Outgoing Relay Subscribe Payload stalled"),this.relayer.events.emit(Le.connection_stalled),c)throw l}return null}async rpcBatchSubscribe(e){if(!e.length)return;const s=e[0].relay,n={method:tr(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 us(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(Le.connection_stalled)}}async rpcBatchFetchMessages(e){if(!e.length)return;const s=e[0].relay,n={method:tr(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 us(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(Le.connection_stalled)}return r}rpcUnsubscribe(e,s,n){const r={method:tr(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,Ra(kr({},s),{id:e})),this.pending.delete(s.topic)}onBatchSubscribe(e){e.length&&e.forEach(s=>{this.setSubscription(s.id,kr({},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,kr({},s)),this.topicMap.set(s.topic,e),this.events.emit(_t.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}=M("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(_t.deleted,Ra(kr({},n),{reason:s}))}async persist(){await this.setRelayerSubscriptions(this.values),this.events.emit(_t.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(_t.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}=M("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=>Ra(kr({},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 Yw(F.toMiliseconds(F.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}=M("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 Bt(e+await this.getClientId())}}var AA=Object.defineProperty,rd=Object.getOwnPropertySymbols,IA=Object.prototype.hasOwnProperty,_A=Object.prototype.propertyIsEnumerable,Oc=(t,e,s)=>e in t?AA(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,id=(t,e)=>{for(var s in e||(e={}))IA.call(e,s)&&Oc(t,s,e[s]);if(rd)for(var s of rd(e))_A.call(e,s)&&Oc(t,s,e[s]);return t},Ee=(t,e,s)=>Oc(t,typeof e!="symbol"?e+"":e,s);class SA extends hw{constructor(e){var s;super(e),Ee(this,"protocol","wc"),Ee(this,"version",2),Ee(this,"core"),Ee(this,"logger"),Ee(this,"events",new Mn.EventEmitter),Ee(this,"provider"),Ee(this,"messages"),Ee(this,"subscriber"),Ee(this,"publisher"),Ee(this,"name",sC),Ee(this,"transportExplicitlyClosed",!1),Ee(this,"initialized",!1),Ee(this,"connectionAttemptInProgress",!1),Ee(this,"relayUrl"),Ee(this,"projectId"),Ee(this,"packageName"),Ee(this,"bundleId"),Ee(this,"hasExperiencedNetworkDisruption",!1),Ee(this,"pingTimeout"),Ee(this,"heartBeatTimeout",F.toMiliseconds(F.THIRTY_SECONDS+F.FIVE_SECONDS)),Ee(this,"reconnectTimeout"),Ee(this,"connectPromise"),Ee(this,"reconnectInProgress",!1),Ee(this,"requestsInFlight",[]),Ee(this,"connectTimeout",F.toMiliseconds(F.ONE_SECOND*15)),Ee(this,"request",async n=>{var r,i;this.logger.debug("Publishing Request Payload");const o=n.id||En().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}}),Ee(this,"resetPingTimeout",()=>{Oo()&&(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))}),Ee(this,"onPayloadHandler",n=>{this.onProviderPayload(n),this.resetPingTimeout()}),Ee(this,"onConnectHandler",()=>{this.logger.warn({},"Relayer connected 🛜"),this.startPingTimeout(),this.events.emit(Le.connect)}),Ee(this,"onDisconnectHandler",()=>{this.logger.warn({},"Relayer disconnected 🛑"),this.requestsInFlight=[],this.onProviderDisconnect()}),Ee(this,"onProviderErrorHandler",n=>{this.logger.fatal(`Fatal socket error: ${n.message}`),this.events.emit(Le.error,n),this.logger.fatal("Fatal socket error received, closing transport"),this.transportClose()}),Ee(this,"registerProviderListeners",()=>{this.provider.on(xt.payload,this.onPayloadHandler),this.provider.on(xt.connect,this.onConnectHandler),this.provider.on(xt.disconnect,this.onDisconnectHandler),this.provider.on(xt.error,this.onProviderErrorHandler)}),this.core=e.core,this.logger=dl({logger:(s=e.logger)!=null?s:tC,name:this.name}),this.messages=new aA(this.logger,e.core),this.subscriber=new CA(this,this.logger),this.publisher=new pA(this,this.logger),this.projectId=e==null?void 0:e.projectId,this.relayUrl=(e==null?void 0:e.relayUrl)||Lp,xw()?this.packageName=Ql():$w()&&(this.bundleId=Ql()),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 Et(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:Pe.relay},mo.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=u=>{u.topic===e&&(this.subscriber.off(_t.created,l),c())};return await Promise.all([new Promise(u=>{c=u,this.subscriber.on(_t.created,l)}),new Promise(async(u,d)=>{a=await this.subscriber.subscribe(e,id({internal:{throwOnFailedPublish:o}},s)).catch(h=>{o&&d(h)})||a,u()})]),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 us(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 Ku())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=Be(F.FIVE_MINUTES),i={topic:n,expiry:r,relay:{protocol:"irn"},active:!1};await this.core.pairing.pairings.set(n,i)}this.events.emit(Le.message,e),await this.recordMessageEvent(e,mo.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(xt.disconnect,i),await us(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(xt.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(xt.disconnect,c),await this.subscriber.start().then(o).catch(a).finally(()=>{this.provider.off(xt.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,F.toMiliseconds(s*1))),s++}}startPingTimeout(){var e,s,n,r,i;if(Oo())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 Fc(new Wf(Bw({sdkVersion:Ac,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}),qc(e)){if(!e.method.endsWith(nC))return;const s=e.params,{topic:n,message:r,publishedAt:i,attestation:o}=s.data,a={topic:n,message:r,publishedAt:i,transportType:Pe.relay,attestation:o};this.logger.debug("Emitting Relayer Payload"),this.logger.trace(id({type:"event",event:s.id},a)),this.events.emit(s.id,a),await this.acknowledgePayload(e),await this.onMessageEvent(a)}else Wc(e)&&this.events.emit(Le.message_ack,e)}async onMessageEvent(e){await this.shouldIgnoreMessageEvent(e)||(await this.recordMessageEvent(e,mo.inbound),this.events.emit(Le.message,e))}async acknowledgePayload(e){const s=Yr(e.id,!0);await this.provider.connection.send(s)}unregisterProviderListeners(){this.provider.off(xt.payload,this.onPayloadHandler),this.provider.off(xt.connect,this.onConnectHandler),this.provider.off(xt.disconnect,this.onDisconnectHandler),this.provider.off(xt.error,this.onProviderErrorHandler),clearTimeout(this.pingTimeout)}async registerEventListeners(){let e=await Ku();RE(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(vr.pulse,async()=>{if(!this.transportExplicitlyClosed&&!this.connected&&UE())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(Le.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},F.toMiliseconds(rC)))))}isInitialized(){if(!this.initialized){const{message:e}=M("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 NA(t,e){return t===e||Number.isNaN(t)&&Number.isNaN(e)}function od(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function ad(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const TA="[object RegExp]",OA="[object String]",PA="[object Number]",kA="[object Boolean]",cd="[object Arguments]",RA="[object Symbol]",xA="[object Date]",$A="[object Map]",UA="[object Set]",DA="[object Array]",LA="[object Function]",MA="[object ArrayBuffer]",xa="[object Object]",BA="[object Error]",jA="[object DataView]",FA="[object Uint8Array]",qA="[object Uint8ClampedArray]",WA="[object Uint16Array]",HA="[object Uint32Array]",KA="[object BigUint64Array]",zA="[object Int8Array]",VA="[object Int16Array]",GA="[object Int32Array]",YA="[object BigInt64Array]",JA="[object Float32Array]",XA="[object Float64Array]";function ZA(){}function ld(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 QA(t,e,s){return Mr(t,e,void 0,void 0,void 0,void 0,s)}function Mr(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 zr(t,e,i,o)}return zr(t,e,i,o)}function zr(t,e,s,n){if(Object.is(t,e))return!0;let r=ad(t),i=ad(e);if(r===cd&&(r=xa),i===cd&&(i=xa),r!==i)return!1;switch(r){case OA:return t.toString()===e.toString();case PA:{const c=t.valueOf(),l=e.valueOf();return NA(c,l)}case kA:case xA:case RA:return Object.is(t.valueOf(),e.valueOf());case TA:return t.source===e.source&&t.flags===e.flags;case LA: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 $A:{if(t.size!==e.size)return!1;for(const[c,l]of t.entries())if(!e.has(c)||!Mr(l,e.get(c),c,t,e,s,n))return!1;return!0}case UA:{if(t.size!==e.size)return!1;const c=Array.from(t.values()),l=Array.from(e.values());for(let u=0;u<c.length;u++){const d=c[u],h=l.findIndex(p=>Mr(d,p,void 0,t,e,s,n));if(h===-1)return!1;l.splice(h,1)}return!0}case DA:case FA:case qA:case WA:case HA:case KA:case zA:case VA:case GA:case YA:case JA:case XA:{if(typeof Buffer<"u"&&Buffer.isBuffer(t)!==Buffer.isBuffer(e)||t.length!==e.length)return!1;for(let c=0;c<t.length;c++)if(!Mr(t[c],e[c],c,t,e,s,n))return!1;return!0}case MA:return t.byteLength!==e.byteLength?!1:zr(new Uint8Array(t),new Uint8Array(e),s,n);case jA:return t.byteLength!==e.byteLength||t.byteOffset!==e.byteOffset?!1:zr(new Uint8Array(t),new Uint8Array(e),s,n);case BA:return t.name===e.name&&t.message===e.message;case xa:{if(!(zr(t.constructor,e.constructor,s,n)||ld(t)&&ld(e)))return!1;const c=[...Object.keys(t),...od(t)],l=[...Object.keys(e),...od(e)];if(c.length!==l.length)return!1;for(let u=0;u<c.length;u++){const d=c[u],h=t[d];if(!Object.hasOwn(e,d))return!1;const p=e[d];if(!Mr(h,p,d,t,e,s,n))return!1}return!0}default:return!1}}finally{s.delete(t),s.delete(e)}}function eI(t,e){return QA(t,e,ZA)}var tI=Object.defineProperty,ud=Object.getOwnPropertySymbols,sI=Object.prototype.hasOwnProperty,nI=Object.prototype.propertyIsEnumerable,Pc=(t,e,s)=>e in t?tI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,dd=(t,e)=>{for(var s in e||(e={}))sI.call(e,s)&&Pc(t,s,e[s]);if(ud)for(var s of ud(e))nI.call(e,s)&&Pc(t,s,e[s]);return t},pt=(t,e,s)=>Pc(t,typeof e!="symbol"?e+"":e,s);class Wn extends pw{constructor(e,s,n,r=gs,i=void 0){super(e,s,n,r),this.core=e,this.logger=s,this.name=n,pt(this,"map",new Map),pt(this,"version",iC),pt(this,"cached",[]),pt(this,"initialized",!1),pt(this,"getKey"),pt(this,"storagePrefix",gs),pt(this,"recentlyDeleted",[]),pt(this,"recentlyDeletedLimit",200),pt(this,"init",async()=>{this.initialized||(this.logger.trace("Initialized"),await this.restore(),this.cached.forEach(o=>{this.getKey&&o!==null&&!We(o)?this.map.set(this.getKey(o),o):lE(o)?this.map.set(o.id,o):uE(o)&&this.map.set(o.topic,o)}),this.cached=[],this.initialized=!0)}),pt(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())}),pt(this,"get",o=>(this.isInitialized(),this.logger.debug("Getting value"),this.logger.trace({type:"method",method:"get",key:o}),this.getData(o))),pt(this,"getAll",o=>(this.isInitialized(),o?this.values.filter(a=>Object.keys(o).every(c=>eI(a[c],o[c]))):this.values)),pt(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=dd(dd({},this.getData(o)),a);this.map.set(o,c),await this.persist()}),pt(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=kt(s,this.name),this.storagePrefix=r,this.getKey=i}get context(){return Et(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}=M("MISSING_OR_INVALID",`Record was recently deleted - ${this.name}: ${e}`);throw this.logger.error(r),new Error(r)}const{message:n}=M("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}=M("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}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var rI=Object.defineProperty,iI=(t,e,s)=>e in t?rI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,pe=(t,e,s)=>iI(t,typeof e!="symbol"?e+"":e,s);class oI{constructor(e,s){this.core=e,this.logger=s,pe(this,"name",lC),pe(this,"version",uC),pe(this,"events",new jc),pe(this,"pairings"),pe(this,"initialized",!1),pe(this,"storagePrefix",gs),pe(this,"ignoredPayloadTypes",[Ps]),pe(this,"registeredMethods",[]),pe(this,"init",async()=>{this.initialized||(await this.pairings.init(),await this.cleanup(),this.registerRelayerEvents(),this.registerExpirerEvents(),this.initialized=!0,this.logger.trace("Initialized"))}),pe(this,"register",({methods:n})=>{this.isInitialized(),this.registeredMethods=[...new Set([...this.registeredMethods,...n])]}),pe(this,"create",async n=>{this.isInitialized();const r=vc(),i=await this.core.crypto.setSymKey(r),o=Be(F.FIVE_MINUTES),a={protocol:Dp},c={topic:i,expiry:o,relay:a,active:!1,methods:n==null?void 0:n.methods},l=Du({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(wn.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}}),pe(this,"pair",async n=>{this.isInitialized();const r=this.core.eventClient.createEvent({properties:{topic:n==null?void 0:n.uri,trace:[is.pairing_started]}});this.isValidPair(n,r);const{topic:i,symKey:o,relay:a,expiryTimestamp:c,methods:l}=Uu(n.uri);r.props.properties.topic=i,r.addTrace(is.pairing_uri_validation_success),r.addTrace(is.pairing_uri_not_expired);let u;if(this.pairings.keys.includes(i)){if(u=this.pairings.get(i),r.addTrace(is.existing_pairing),u.active)throw r.setError(vs.active_pairing_already_exists),new Error(`Pairing already exists: ${i}. Please try again with a new connection URI.`);r.addTrace(is.pairing_not_expired)}const d=c||Be(F.FIVE_MINUTES),h={topic:i,relay:a,expiry:d,active:!1,methods:l};this.core.expirer.set(i,d),await this.pairings.set(i,h),r.addTrace(is.store_new_pairing),n.activatePairing&&await this.activate({topic:i}),this.events.emit(wn.create,h),r.addTrace(is.emit_inactive_pairing),this.core.crypto.keychain.has(i)||await this.core.crypto.setSymKey(o,i),r.addTrace(is.subscribing_pairing_topic);try{await this.core.relayer.confirmOnlineStateOrThrow()}catch{r.setError(vs.no_internet_connection)}try{await this.core.relayer.subscribe(i,{relay:a})}catch(p){throw r.setError(vs.subscribe_pairing_topic_failure),p}return r.addTrace(is.subscribe_pairing_topic_success),h}),pe(this,"activate",async({topic:n})=>{this.isInitialized();const r=Be(F.FIVE_MINUTES);this.core.expirer.set(n,r),await this.pairings.update(n,{active:!0,expiry:r})}),pe(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}=yn();this.events.once(Ae("pairing_ping",i),({error:l})=>{l?c(l):a()}),await o()}}),pe(this,"updateExpiry",async({topic:n,expiry:r})=>{this.isInitialized(),await this.pairings.update(n,{expiry:r})}),pe(this,"updateMetadata",async({topic:n,metadata:r})=>{this.isInitialized(),await this.pairings.update(n,{peerMetadata:r})}),pe(this,"getPairings",()=>(this.isInitialized(),this.pairings.values)),pe(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",$e("USER_DISCONNECTED")),await this.deletePairing(r))}),pe(this,"formatUriFromPairing",n=>{this.isInitialized();const{topic:r,relay:i,expiry:o,methods:a}=n,c=this.core.crypto.keychain.get(r);return Du({protocol:this.core.protocol,version:this.core.version,topic:r,symKey:c,relay:i,expiryTimestamp:o,methods:a})}),pe(this,"sendRequest",async(n,r,i)=>{const o=as(r,i),a=await this.core.crypto.encode(n,o),c=Or[r].req;return this.core.history.set(n,o),this.core.relayer.publish(n,a,c),o.id}),pe(this,"sendResult",async(n,r,i)=>{const o=Yr(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Or[c].res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),pe(this,"sendError",async(n,r,i)=>{const o=sh(n,i),a=await this.core.crypto.encode(r,o),c=(await this.core.history.get(r,n)).request.method,l=Or[c]?Or[c].res:Or.unregistered_method.res;await this.core.relayer.publish(r,a,l),await this.core.history.resolve(o)}),pe(this,"deletePairing",async(n,r)=>{await this.core.relayer.unsubscribe(n),await Promise.all([this.pairings.delete(n,$e("USER_DISCONNECTED")),this.core.crypto.deleteSymKey(n),r?Promise.resolve():this.core.expirer.del(n)])}),pe(this,"cleanup",async()=>{const n=this.pairings.getAll().filter(r=>cs(r.expiry));await Promise.all(n.map(r=>this.deletePairing(r.topic)))}),pe(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)}}),pe(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)}}),pe(this,"onPairingPingRequest",async(n,r)=>{const{id:i}=r;try{this.isValidPing({topic:n}),await this.sendResult(i,n,!0),this.events.emit(wn.ping,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),pe(this,"onPairingPingResponse",(n,r)=>{const{id:i}=r;setTimeout(()=>{ws(r)?this.events.emit(Ae("pairing_ping",i),{}):os(r)&&this.events.emit(Ae("pairing_ping",i),{error:r.error})},500)}),pe(this,"onPairingDeleteRequest",async(n,r)=>{const{id:i}=r;try{this.isValidDisconnect({topic:n}),await this.deletePairing(n),this.events.emit(wn.delete,{id:i,topic:n})}catch(o){await this.sendError(i,n,o),this.logger.error(o)}}),pe(this,"onUnknownRpcMethodRequest",async(n,r)=>{const{id:i,method:o}=r;try{if(this.registeredMethods.includes(o))return;const a=$e("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)}}),pe(this,"onUnknownRpcMethodResponse",n=>{this.registeredMethods.includes(n)||this.logger.error($e("WC_METHOD_UNSUPPORTED",n))}),pe(this,"isValidPair",(n,r)=>{var i;if(!gt(n)){const{message:a}=M("MISSING_OR_INVALID",`pair() params: ${n}`);throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(!cE(n.uri)){const{message:a}=M("MISSING_OR_INVALID",`pair() uri: ${n.uri}`);throw r.setError(vs.malformed_pairing_uri),new Error(a)}const o=Uu(n==null?void 0:n.uri);if(!((i=o==null?void 0:o.relay)!=null&&i.protocol)){const{message:a}=M("MISSING_OR_INVALID","pair() uri#relay-protocol");throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(!(o!=null&&o.symKey)){const{message:a}=M("MISSING_OR_INVALID","pair() uri#symKey");throw r.setError(vs.malformed_pairing_uri),new Error(a)}if(o!=null&&o.expiryTimestamp&&F.toMiliseconds(o==null?void 0:o.expiryTimestamp)<Date.now()){r.setError(vs.pairing_expired);const{message:a}=M("EXPIRED","pair() URI has expired. Please try again with a new connection URI.");throw new Error(a)}}),pe(this,"isValidPing",async n=>{if(!gt(n)){const{message:i}=M("MISSING_OR_INVALID",`ping() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),pe(this,"isValidDisconnect",async n=>{if(!gt(n)){const{message:i}=M("MISSING_OR_INVALID",`disconnect() params: ${n}`);throw new Error(i)}const{topic:r}=n;await this.isValidPairingTopic(r)}),pe(this,"isValidPairingTopic",async n=>{if(!je(n,!1)){const{message:r}=M("MISSING_OR_INVALID",`pairing topic should be a string: ${n}`);throw new Error(r)}if(!this.pairings.keys.includes(n)){const{message:r}=M("NO_MATCHING_KEY",`pairing topic doesn't exist: ${n}`);throw new Error(r)}if(cs(this.pairings.get(n).expiry)){await this.deletePairing(n);const{message:r}=M("EXPIRED",`pairing topic: ${n}`);throw new Error(r)}}),this.core=e,this.logger=kt(s,this.name),this.pairings=new Wn(this.core,this.logger,this.name,this.storagePrefix)}get context(){return Et(this.logger)}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}registerRelayerEvents(){this.core.relayer.on(Le.message,async e=>{const{topic:s,message:n,transportType:r}=e;if(this.pairings.keys.includes(s)&&r!==Pe.link_mode&&!this.ignoredPayloadTypes.includes(this.core.crypto.getPayloadType(n)))try{const i=await this.core.crypto.decode(s,n);qc(i)?(this.core.history.set(s,i),await this.onRelayEventRequest({topic:s,payload:i})):Wc(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(Mt.expired,async e=>{const{topic:s}=$h(e.target);s&&this.pairings.keys.includes(s)&&(await this.deletePairing(s,!0),this.events.emit(wn.expire,{topic:s}))})}}var aI=Object.defineProperty,cI=(t,e,s)=>e in t?aI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ye=(t,e,s)=>cI(t,typeof e!="symbol"?e+"":e,s);class lI extends lw{constructor(e,s){super(e,s),this.core=e,this.logger=s,Ye(this,"records",new Map),Ye(this,"events",new Mn.EventEmitter),Ye(this,"name",dC),Ye(this,"version",hC),Ye(this,"cached",[]),Ye(this,"initialized",!1),Ye(this,"storagePrefix",gs),Ye(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)}),Ye(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:Be(F.THIRTY_DAYS)};this.records.set(o.id,o),this.persist(),this.events.emit(Vt.created,o)}),Ye(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=os(n)?{error:n.error}:{result:n.result},this.records.set(r.id,r),this.persist(),this.events.emit(Vt.updated,r))}),Ye(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))),Ye(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(Vt.deleted,i)}}),this.persist()}),Ye(this,"exists",async(n,r)=>(this.isInitialized(),this.records.has(r)?(await this.getRecord(r)).topic===n:!1)),Ye(this,"on",(n,r)=>{this.events.on(n,r)}),Ye(this,"once",(n,r)=>{this.events.once(n,r)}),Ye(this,"off",(n,r)=>{this.events.off(n,r)}),Ye(this,"removeListener",(n,r)=>{this.events.removeListener(n,r)}),this.logger=kt(s,this.name)}get context(){return Et(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:as(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}=M("NO_MATCHING_KEY",`${this.name}: ${e}`);throw new Error(n)}return s}async persist(){await this.setJsonRpcRecords(this.values),this.events.emit(Vt.sync)}async restore(){try{const e=await this.getJsonRpcRecords();if(typeof e>"u"||!e.length)return;if(this.records.size){const{message:s}=M("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(Vt.created,e=>{const s=Vt.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Vt.updated,e=>{const s=Vt.updated;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.events.on(Vt.deleted,e=>{const s=Vt.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,record:e})}),this.core.heartbeat.on(vr.pulse,()=>{this.cleanup()})}cleanup(){try{this.isInitialized();let e=!1;this.records.forEach(s=>{F.toMiliseconds(s.expiry||0)-Date.now()<=0&&(this.logger.info(`Deleting expired history log: ${s.id}`),this.records.delete(s.id),this.events.emit(Vt.deleted,s,!1),e=!0)}),e&&this.persist()}catch(e){this.logger.warn(e)}}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var uI=Object.defineProperty,dI=(t,e,s)=>e in t?uI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,rt=(t,e,s)=>dI(t,typeof e!="symbol"?e+"":e,s);class hI extends gw{constructor(e,s){super(e,s),this.core=e,this.logger=s,rt(this,"expirations",new Map),rt(this,"events",new Mn.EventEmitter),rt(this,"name",pC),rt(this,"version",fC),rt(this,"cached",[]),rt(this,"initialized",!1),rt(this,"storagePrefix",gs),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(Mt.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(Mt.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=kt(s,this.name)}get context(){return Et(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 jw(e);if(typeof e=="number")return Fw(e);const{message:s}=M("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(Mt.sync)}async restore(){try{const e=await this.getExpirations();if(typeof e>"u"||!e.length)return;if(this.expirations.size){const{message:s}=M("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}=M("NO_MATCHING_KEY",`${this.name}: ${e}`);throw this.logger.warn(n),new Error(n)}return s}checkExpiry(e,s){const{expiry:n}=s;F.toMiliseconds(n)-Date.now()<=0&&this.expire(e,s)}expire(e,s){this.expirations.delete(e),this.events.emit(Mt.expired,{target:e,expiration:s})}checkExpirations(){this.core.relayer.connected&&this.expirations.forEach((e,s)=>this.checkExpiry(s,e))}registerEventListeners(){this.core.heartbeat.on(vr.pulse,()=>this.checkExpirations()),this.events.on(Mt.created,e=>{const s=Mt.created;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(Mt.expired,e=>{const s=Mt.expired;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()}),this.events.on(Mt.deleted,e=>{const s=Mt.deleted;this.logger.info(`Emitting ${s}`),this.logger.debug({type:"event",event:s,data:e}),this.persist()})}isInitialized(){if(!this.initialized){const{message:e}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}}var pI=Object.defineProperty,fI=(t,e,s)=>e in t?pI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Me=(t,e,s)=>fI(t,typeof e!="symbol"?e+"":e,s);class gI extends mw{constructor(e,s,n){super(e,s,n),this.core=e,this.logger=s,this.store=n,Me(this,"name",gC),Me(this,"abortController"),Me(this,"isDevEnv"),Me(this,"verifyUrlV3",yC),Me(this,"storagePrefix",gs),Me(this,"version",Up),Me(this,"publicKey"),Me(this,"fetchPromise"),Me(this,"init",async()=>{var r;this.isDevEnv||(this.publicKey=await this.store.getItem(this.storeKey),this.publicKey&&F.toMiliseconds((r=this.publicKey)==null?void 0:r.expiresAt)<Date.now()&&(this.logger.debug("verify v2 public key expired"),await this.removePublicKey()))}),Me(this,"register",async r=>{if(!Er()||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=ur(),u=this.startAbortTimer(F.ONE_SECOND*5),d=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=w=>{if(w.data&&typeof w.data=="string")try{const b=JSON.parse(w.data);if(b.type==="verify_attestation"){if(Ya(b.attestation).payload.id!==o)return;clearInterval(u),l.body.removeChild(f),this.abortController.signal.removeEventListener("abort",g),window.removeEventListener("message",y),h(b.attestation===null?"":b.attestation)}}catch(b){this.logger.warn(b)}};l.body.appendChild(f),window.addEventListener("message",y,{signal:this.abortController.signal})});return this.logger.debug(d,"jwt attestation"),d}catch(l){this.logger.warn(l)}return""}),Me(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(Ya(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)}),Me(this,"fetchAttestation",async(r,i)=>{this.logger.debug(`resolving attestation: ${r} from url: ${i}`);const o=this.startAbortTimer(F.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}),Me(this,"getVerifyUrl",r=>{let i=r||Kr;return wC.includes(i)||(this.logger.info(`verify url: ${i}, not included in trusted list, assigning default: ${Kr}`),i=Kr),i}),Me(this,"fetchPublicKey",async()=>{try{this.logger.debug(`fetching public key from: ${this.verifyUrlV3}`);const r=this.startAbortTimer(F.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)}}),Me(this,"persistPublicKey",async r=>{this.logger.debug(r,"persisting public key to local storage"),await this.store.setItem(this.storeKey,r),this.publicKey=r}),Me(this,"removePublicKey",async()=>{this.logger.debug("removing verify v2 public key from storage"),await this.store.removeItem(this.storeKey),this.publicKey=void 0}),Me(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")}}),Me(this,"getPublicKey",async()=>this.publicKey?this.publicKey:await this.fetchAndPersistPublicKey()),Me(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}),Me(this,"validateAttestation",(r,i)=>{const o=U0(r,i.publicKey),a={hasExpired:F.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=kt(s,this.name),this.abortController=new AbortController,this.isDevEnv=Qc(),this.init()}get storeKey(){return this.storagePrefix+this.version+this.core.customStoragePrefix+"//verify:public:key"}get context(){return Et(this.logger)}startAbortTimer(e){return this.abortController=new AbortController,setTimeout(()=>this.abortController.abort(),F.toMiliseconds(e))}}var mI=Object.defineProperty,yI=(t,e,s)=>e in t?mI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,hd=(t,e,s)=>yI(t,typeof e!="symbol"?e+"":e,s);class wI extends yw{constructor(e,s){super(e,s),this.projectId=e,this.logger=s,hd(this,"context",bC),hd(this,"registerDeviceToken",async n=>{const{clientId:r,token:i,notificationType:o,enableEncrypted:a=!1}=n,c=`${vC}/${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=kt(s,this.context)}}var bI=Object.defineProperty,pd=Object.getOwnPropertySymbols,vI=Object.prototype.hasOwnProperty,EI=Object.prototype.propertyIsEnumerable,kc=(t,e,s)=>e in t?bI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Rr=(t,e)=>{for(var s in e||(e={}))vI.call(e,s)&&kc(t,s,e[s]);if(pd)for(var s of pd(e))EI.call(e,s)&&kc(t,s,e[s]);return t},Ke=(t,e,s)=>kc(t,typeof e!="symbol"?e+"":e,s);class CI extends ww{constructor(e,s,n=!0){super(e,s,n),this.core=e,this.logger=s,Ke(this,"context",CC),Ke(this,"storagePrefix",gs),Ke(this,"storageVersion",EC),Ke(this,"events",new Map),Ke(this,"shouldPersist",!1),Ke(this,"init",async()=>{if(!Qc())try{const r={eventId:tu(),timestamp:Date.now(),domain:this.getAppDomain(),props:{event:"INIT",type:"",properties:{client_id:await this.core.crypto.getClientId(),user_agent:Rh(this.core.relayer.protocol,this.core.relayer.version,Ac)}}};await this.sendEvent([r])}catch(r){this.logger.warn(r)}}),Ke(this,"createEvent",r=>{const{event:i="ERROR",type:o="",properties:{topic:a,trace:c}}=r,l=tu(),u=this.core.projectId||"",d=Date.now(),h=Rr({eventId:l,timestamp:d,props:{event:i,type:o,properties:{topic:a,trace:c}},bundleId:u,domain:this.getAppDomain()},this.setMethods(l));return this.telemetryEnabled&&(this.events.set(l,h),this.shouldPersist=!0),h}),Ke(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 Rr(Rr({},a),this.setMethods(a.eventId))}),Ke(this,"deleteEvent",r=>{const{eventId:i}=r;this.events.delete(i),this.shouldPersist=!0}),Ke(this,"setEventListeners",()=>{this.core.heartbeat.on(vr.pulse,async()=>{this.shouldPersist&&await this.persist(),this.events.forEach(r=>{F.fromMiliseconds(Date.now())-F.fromMiliseconds(r.timestamp)>AC&&(this.events.delete(r.eventId),this.shouldPersist=!0)})})}),Ke(this,"setMethods",r=>({addTrace:i=>this.addTrace(r,i),setError:i=>this.setError(r,i)})),Ke(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)}),Ke(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)}),Ke(this,"persist",async()=>{await this.core.storage.setItem(this.storageKey,Array.from(this.events.values())),this.shouldPersist=!1}),Ke(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,Rr(Rr({},i),this.setMethods(i.eventId)))})}catch(r){this.logger.warn(r)}}),Ke(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)}}),Ke(this,"sendEvent",async r=>{const i=this.getAppDomain()?"":"&sp=desktop";return await fetch(`${IC}?projectId=${this.core.projectId}&st=events_sdk&sv=js-${Ac}${i}`,{method:"POST",body:JSON.stringify(r)})}),Ke(this,"getAppDomain",()=>kh().url),this.logger=kt(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 AI=Object.defineProperty,fd=Object.getOwnPropertySymbols,II=Object.prototype.hasOwnProperty,_I=Object.prototype.propertyIsEnumerable,Rc=(t,e,s)=>e in t?AI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,gd=(t,e)=>{for(var s in e||(e={}))II.call(e,s)&&Rc(t,s,e[s]);if(fd)for(var s of fd(e))_I.call(e,s)&&Rc(t,s,e[s]);return t},Te=(t,e,s)=>Rc(t,typeof e!="symbol"?e+"":e,s);let SI=class Jp extends iw{constructor(e){var s;super(e),Te(this,"protocol",$p),Te(this,"version",Up),Te(this,"name",Cc),Te(this,"relayUrl"),Te(this,"projectId"),Te(this,"customStoragePrefix"),Te(this,"events",new Mn.EventEmitter),Te(this,"logger"),Te(this,"heartbeat"),Te(this,"relayer"),Te(this,"crypto"),Te(this,"storage"),Te(this,"history"),Te(this,"expirer"),Te(this,"pairing"),Te(this,"verify"),Te(this,"echoClient"),Te(this,"linkModeSupportedApps"),Te(this,"eventClient"),Te(this,"initialized",!1),Te(this,"logChunkController"),Te(this,"on",(a,c)=>this.events.on(a,c)),Te(this,"once",(a,c)=>this.events.once(a,c)),Te(this,"off",(a,c)=>this.events.off(a,c)),Te(this,"removeListener",(a,c)=>this.events.removeListener(a,c)),Te(this,"dispatchEnvelope",({topic:a,message:c,sessionExists:l})=>{if(!a||!c)return;const u={topic:a,message:c,publishedAt:Date.now(),transportType:Pe.link_mode};this.relayer.onLinkMessageEvent(u,{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)||Lp,this.customStoragePrefix=e!=null&&e.customStoragePrefix?`:${e.customStoragePrefix}`:"";const r=Zy({level:typeof(e==null?void 0:e.logger)=="string"&&e.logger?e.logger:KE.logger,name:Cc}),{logger:i,chunkLoggerController:o}=Oh({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=kt(i,this.name),this.heartbeat=new qf,this.crypto=new Q1(this,this.logger,e==null?void 0:e.keychain),this.history=new lI(this,this.logger),this.expirer=new hI(this,this.logger),this.storage=e!=null&&e.storage?e.storage:new Ry(gd(gd({},zE),e==null?void 0:e.storageOptions)),this.relayer=new SA({core:this,logger:this.logger,relayUrl:this.relayUrl,projectId:this.projectId}),this.pairing=new oI(this,this.logger),this.verify=new gI(this,this.logger,this.storage),this.echoClient=new wI(this.projectId||"",this.logger),this.linkModeSupportedApps=[],this.eventClient=new CI(this,this.logger,e==null?void 0:e.telemetryEnabled),this.setGlobalCore(this)}static async init(e){const s=new Jp(e);await s.initialize();const n=await s.crypto.getClientId();return await s.storage.setItem(oC,n),s}get context(){return Et(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(Vu,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(Vu)||[],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 process<"u"&&HE.DISABLE_GLOBAL_CORE==="true"}catch{return!0}}};const NI=SI,Xp="wc",Zp=2,Qp="client",hl=`${Xp}@${Zp}:${Qp}:`,$a={name:Qp,logger:"error"},md="WALLETCONNECT_DEEPLINK_CHOICE",TI="proposal",yd="Proposal expired",OI="session",Jn=F.SEVEN_DAYS,PI="engine",Je={wc_sessionPropose:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1100},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1101},reject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1120},autoReject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1121}},wc_sessionSettle:{req:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1102},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1103}},wc_sessionUpdate:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1104},res:{ttl:F.ONE_DAY,prompt:!1,tag:1105}},wc_sessionExtend:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1106},res:{ttl:F.ONE_DAY,prompt:!1,tag:1107}},wc_sessionRequest:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1108},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1109}},wc_sessionEvent:{req:{ttl:F.FIVE_MINUTES,prompt:!0,tag:1110},res:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1111}},wc_sessionDelete:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1112},res:{ttl:F.ONE_DAY,prompt:!1,tag:1113}},wc_sessionPing:{req:{ttl:F.ONE_DAY,prompt:!1,tag:1114},res:{ttl:F.ONE_DAY,prompt:!1,tag:1115}},wc_sessionAuthenticate:{req:{ttl:F.ONE_HOUR,prompt:!0,tag:1116},res:{ttl:F.ONE_HOUR,prompt:!1,tag:1117},reject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1118},autoReject:{ttl:F.FIVE_MINUTES,prompt:!1,tag:1119}}},Ua={min:F.FIVE_MINUTES,max:F.SEVEN_DAYS},rs={idle:"IDLE",active:"ACTIVE"},kI={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:""}},RI="request",xI=["wc_sessionPropose","wc_sessionRequest","wc_authRequest","wc_sessionAuthenticate"],$I="wc",UI="auth",DI="authKeys",LI="pairingTopics",MI="requests",ra=`${$I}@${1.5}:${UI}:`,yo=`${ra}:PUB_KEY`;var BI=Object.defineProperty,jI=Object.defineProperties,FI=Object.getOwnPropertyDescriptors,wd=Object.getOwnPropertySymbols,qI=Object.prototype.hasOwnProperty,WI=Object.prototype.propertyIsEnumerable,xc=(t,e,s)=>e in t?BI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Ie=(t,e)=>{for(var s in e||(e={}))qI.call(e,s)&&xc(t,s,e[s]);if(wd)for(var s of wd(e))WI.call(e,s)&&xc(t,s,e[s]);return t},it=(t,e)=>jI(t,FI(e)),O=(t,e,s)=>xc(t,typeof e!="symbol"?e+"":e,s);class HI extends Cw{constructor(e){super(e),O(this,"name",PI),O(this,"events",new jc),O(this,"initialized",!1),O(this,"requestQueue",{state:rs.idle,queue:[]}),O(this,"sessionRequestQueue",{state:rs.idle,queue:[]}),O(this,"emittedSessionRequests",new Jw({limit:500})),O(this,"requestQueueDelay",F.ONE_SECOND),O(this,"expectedPairingMethodMap",new Map),O(this,"recentlyDeletedMap",new Map),O(this,"recentlyDeletedLimit",200),O(this,"relayMessageCache",[]),O(this,"pendingSessions",new Map),O(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(Je)}),this.initialized=!0,setTimeout(async()=>{await this.processPendingMessageEvents(),this.sessionRequestQueue.queue=this.getPendingSessionRequests(),this.processSessionRequestQueue()},F.toMiliseconds(this.requestQueueDelay)))}),O(this,"connect",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();const n=it(Ie({},s),{requiredNamespaces:s.requiredNamespaces||{},optionalNamespaces:s.optionalNamespaces||{}});await this.isValidConnect(n),n.optionalNamespaces=nE(n.requiredNamespaces,n.optionalNamespaces),n.requiredNamespaces={};const{pairingTopic:r,requiredNamespaces:i,optionalNamespaces:o,sessionProperties:a,scopedProperties:c,relays:l}=n;let u=r,d,h=!1;try{if(u){const $=this.client.core.pairing.pairings.get(u);this.client.logger.warn("connect() with existing pairing topic is deprecated and will be removed in the next major release."),h=$.active}}catch($){throw this.client.logger.error(`connect() -> pairing.get(${u}) failed`),$}if(!u||!h){const{topic:$,uri:W}=await this.client.core.pairing.create({internal:{skipSubscribe:!0}});u=$,d=W}if(!u){const{message:$}=M("NO_MATCHING_KEY",`connect() pairing topic: ${u}`);throw new Error($)}const p=await this.client.core.crypto.generateKeyPair(),g=Je.wc_sessionPropose.req.ttl||F.FIVE_MINUTES,f=Be(g),y=it(Ie(Ie({requiredNamespaces:i,optionalNamespaces:o,relays:l??[{protocol:Dp}],proposer:{publicKey:p,metadata:this.client.metadata},expiryTimestamp:f,pairingTopic:u},a&&{sessionProperties:a}),c&&{scopedProperties:c}),{id:Us()}),w=Ae("session_connect",y.id),{reject:b,resolve:E,done:N}=yn(g,yd),x=({id:$})=>{$===y.id&&(this.client.events.off("proposal_expire",x),this.pendingSessions.delete(y.id),this.events.emit(w,{error:{message:yd,code:0}}))};return this.client.events.on("proposal_expire",x),this.events.once(w,({error:$,session:W})=>{this.client.events.off("proposal_expire",x),$?b($):W&&E(W)}),await this.sendProposeSession({proposal:y,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:y.id}}}),await this.setProposal(y.id,y),{uri:d,approval:N}}),O(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}}),O(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:[Gt.session_approve_started]}});try{this.isInitialized(),await this.confirmOnlineStateOrThrow()}catch(k){throw o.setError(hn.no_internet_connection),k}try{await this.isValidProposalId(s==null?void 0:s.id)}catch(k){throw this.client.logger.error(`approve() -> proposal.get(${s==null?void 0:s.id}) failed`),o.setError(hn.proposal_not_found),k}try{await this.isValidApprove(s)}catch(k){throw this.client.logger.error("approve() -> isValidApprove() failed"),o.setError(hn.session_approve_namespace_validation_failure),k}const{id:a,relayProtocol:c,namespaces:l,sessionProperties:u,scopedProperties:d,sessionConfig:h}=s,p=this.client.proposal.get(a);this.client.core.eventClient.deleteEvent({eventId:o.eventId});const{pairingTopic:g,proposer:f,requiredNamespaces:y,optionalNamespaces:w}=p;let b=(r=this.client.core.eventClient)==null?void 0:r.getEvent({topic:g});b||(b=(i=this.client.core.eventClient)==null?void 0:i.createEvent({type:Gt.session_approve_started,properties:{topic:g,trace:[Gt.session_approve_started,Gt.session_namespaces_validation_success]}}));const E=await this.client.core.crypto.generateKeyPair(),N=f.publicKey,x=await this.client.core.crypto.generateSharedKey(E,N),$=Ie(Ie(Ie({relay:{protocol:c??"irn"},namespaces:l,controller:{publicKey:E,metadata:this.client.metadata},expiry:Be(Jn)},u&&{sessionProperties:u}),d&&{scopedProperties:d}),h&&{sessionConfig:h}),W=Pe.relay;b.addTrace(Gt.subscribing_session_topic);try{await this.client.core.relayer.subscribe(x,{transportType:W,internal:{skipSubscribe:!0}})}catch(k){throw b.setError(hn.subscribe_session_topic_failure),k}b.addTrace(Gt.subscribe_session_topic_success);const G=it(Ie({},$),{topic:x,requiredNamespaces:y,optionalNamespaces:w,pairingTopic:g,acknowledged:!1,self:$.controller,peer:{publicKey:f.publicKey,metadata:f.metadata},controller:E,transportType:Pe.relay});await this.client.session.set(x,G),b.addTrace(Gt.store_session);try{await this.sendApproveSession({sessionTopic:x,proposal:p,pairingProposalResponse:{relay:{protocol:c??"irn"},responderPublicKey:E},sessionSettleRequest:$,publishOpts:{internal:{throwOnFailedPublish:!0},tvf:{correlationId:a}}}),b.addTrace(Gt.session_approve_publish_success)}catch(k){throw this.client.logger.error(k),this.client.session.delete(x,$e("USER_DISCONNECTED")),await this.client.core.relayer.unsubscribe(x),k}return this.client.core.eventClient.deleteEvent({eventId:b.eventId}),await this.client.core.pairing.updateMetadata({topic:g,metadata:f.metadata}),await this.deleteProposal(a),await this.client.core.pairing.activate({topic:g}),await this.setExpiry(x,Be(Jn)),{topic:x,acknowledged:()=>Promise.resolve(this.client.session.get(x))}}),O(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:Je.wc_sessionPropose.reject}),await this.deleteProposal(n)}),O(this,"update",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow();try{await this.isValidUpdate(s)}catch(d){throw this.client.logger.error("update() -> isValidUpdate() failed"),d}const{topic:n,namespaces:r}=s,{done:i,resolve:o,reject:a}=yn(),c=Us(),l=En().toString(),u=this.client.session.get(n).namespaces;return this.events.once(Ae("session_update",c),({error:d})=>{d?a(d):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(d=>{this.client.logger.error(d),this.client.session.update(n,{namespaces:u}),a(d)}),{acknowledged:i}}),O(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=Us(),{done:i,resolve:o,reject:a}=yn();return this.events.once(Ae("session_extend",r),({error:c})=>{c?a(c):o()}),await this.setExpiry(n,Be(Jn)),this.sendRequest({topic:n,method:"wc_sessionExtend",params:{},clientRpcId:r,throwOnFailedPublish:!0}).catch(c=>{a(c)}),{acknowledged:i}}),O(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=Je.wc_sessionRequest.req.ttl}=s,a=this.client.session.get(i);(a==null?void 0:a.transportType)===Pe.relay&&await this.confirmOnlineStateOrThrow();const c=Us(),l=En().toString(),{done:u,resolve:d,reject:h}=yn(o,"Request expired. Please try again.");this.events.once(Ae("session_request",c),({error:y,result:w})=>{y?h(y):d(w)});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:it(Ie({},r),{expiryTimestamp:Be(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 u();const f={request:it(Ie({},r),{expiryTimestamp:Be(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(w=>h(w)),this.client.events.emit("session_request_sent",{topic:i,request:r,chainId:n,id:c}),y()}),new Promise(async y=>{var w;if(!((w=a.sessionConfig)!=null&&w.disableDeepLink)){const b=await Kw(this.client.core.storage,md);await qw({id:c,topic:i,wcDeepLink:b})}y()}),u()]).then(y=>y[2])}),O(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:[Gt.session_request_response_started]}});try{await this.isValidRespond(s)}catch(d){throw i.addTrace(d==null?void 0:d.message),i.setError(hn.session_request_response_validation_failure),d}i.addTrace(Gt.session_request_response_validation_success);const{topic:o,response:a}=s,{id:c}=a,l=this.client.session.get(o);l.transportType===Pe.relay&&await this.confirmOnlineStateOrThrow();const u=this.getAppLinkIfEnabled(l.peer.metadata,l.transportType);try{i.addTrace(Gt.session_request_response_publish_started),ws(a)?await this.sendResult({id:c,topic:o,result:a.result,throwOnFailedPublish:!0,appLink:u}):os(a)&&await this.sendError({id:c,topic:o,error:a.error,appLink:u}),this.cleanupAfterResponse(s)}catch(d){throw i.addTrace(d==null?void 0:d.message),i.setError(hn.session_request_response_publish_failure),d}}),O(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=Us(),i=En().toString(),{done:o,resolve:a,reject:c}=yn();this.events.once(Ae("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}))}),O(this,"emit",async s=>{this.isInitialized(),await this.confirmOnlineStateOrThrow(),await this.isValidEmit(s);const{topic:n,event:r,chainId:i}=s,o=En().toString(),a=Us();await this.sendRequest({topic:n,method:"wc_sessionEvent",params:{event:r,chainId:i},throwOnFailedPublish:!0,relayRpcId:o,clientRpcId:a})}),O(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:$e("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}=M("MISMATCHED_TOPIC",`Session or pairing topic not found: ${n}`);throw new Error(r)}}),O(this,"find",s=>(this.isInitialized(),this.client.session.getAll().filter(n=>oE(n,s)))),O(this,"getPendingSessionRequests",()=>this.client.pendingRequest.getAll()),O(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?Pe.link_mode:Pe.relay;o===Pe.relay&&await this.confirmOnlineStateOrThrow();const{chains:a,statement:c="",uri:l,domain:u,nonce:d,type:h,exp:p,nbf:g,methods:f=[],expiry:y}=s,w=[...s.resources||[]],{topic:b,uri:E}=await this.client.core.pairing.create({methods:["wc_sessionAuthenticate"],transportType:o});this.client.logger.info({message:"Generated new pairing",pairing:{topic:b,uri:E}});const N=await this.client.core.crypto.generateKeyPair(),x=go(N);if(await Promise.all([this.client.auth.authKeys.set(yo,{responseTopic:x,publicKey:N}),this.client.auth.pairingTopics.set(x,{topic:x,pairingTopic:b})]),await this.client.core.relayer.subscribe(x,{transportType:o}),this.client.logger.info(`sending request to new pairing topic: ${b}`),f.length>0){const{namespace:I}=Os(a[0]);let R=av(I,"request",f);fo(w)&&(R=lv(R,w.pop())),w.push(R)}const $=y&&y>Je.wc_sessionAuthenticate.req.ttl?y:Je.wc_sessionAuthenticate.req.ttl,W={authPayload:{type:h??"caip122",chains:a,statement:c,aud:l,domain:u,version:"1",nonce:d,iat:new Date().toISOString(),exp:p,nbf:g,resources:w},requester:{publicKey:N,metadata:this.client.metadata},expiryTimestamp:Be($)},G={eip155:{chains:a,methods:[...new Set(["personal_sign",...f])],events:["chainChanged","accountsChanged"]}},k={requiredNamespaces:{},optionalNamespaces:G,relays:[{protocol:"irn"}],pairingTopic:b,proposer:{publicKey:N,metadata:this.client.metadata},expiryTimestamp:Be(Je.wc_sessionPropose.req.ttl),id:Us()},{done:Q,resolve:se,reject:T}=yn($,"Request expired"),v=Us(),C=Ae("session_connect",k.id),A=Ae("session_request",v),S=async({error:I,session:R})=>{this.events.off(A,D),I?T(I):R&&se({session:R})},D=async I=>{var R,z,K;if(await this.deletePendingAuthRequest(v,{message:"fulfilled",code:0}),I.error){const le=$e("WC_METHOD_UNSUPPORTED","wc_sessionAuthenticate");return I.error.code===le.code?void 0:(this.events.off(C,S),T(I.error.message))}await this.deleteProposal(k.id),this.events.off(C,S);const{cacaos:he,responder:ie}=I.result,ne=[],ue=[];for(const le of he){await hu({cacao:le,projectId:this.client.core.projectId})||(this.client.logger.error(le,"Signature verification failed"),T($e("SESSION_SETTLEMENT_FAILED","Signature verification failed")));const{p:De}=le,Kt=fo(De.resources),$s=[uc(De.iss)],cn=ko(De.iss);if(Kt){const Hn=pu(Kt),_f=fu(Kt);ne.push(...Hn),$s.push(..._f)}for(const Hn of $s)ue.push(`${Hn}:${cn}`)}const ce=await this.client.core.crypto.generateSharedKey(N,ie.publicKey);let Oe;ne.length>0&&(Oe={topic:ce,acknowledged:!0,self:{publicKey:N,metadata:this.client.metadata},peer:ie,controller:ie.publicKey,expiry:Be(Jn),requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:b,namespaces:ju([...new Set(ne)],[...new Set(ue)]),transportType:o},await this.client.core.relayer.subscribe(ce,{transportType:o}),await this.client.session.set(ce,Oe),b&&await this.client.core.pairing.updateMetadata({topic:b,metadata:ie.metadata}),Oe=this.client.session.get(ce)),(R=this.client.metadata.redirect)!=null&&R.linkMode&&(z=ie.metadata.redirect)!=null&&z.linkMode&&(K=ie.metadata.redirect)!=null&&K.universal&&n&&(this.client.core.addLinkModeSupportedApp(ie.metadata.redirect.universal),this.client.session.update(ce,{transportType:Pe.link_mode})),se({auths:he,session:Oe})};this.events.once(C,S),this.events.once(A,D);let B;try{if(i){const I=as("wc_sessionAuthenticate",W,v);this.client.core.history.set(b,I);const R=await this.client.core.crypto.encode("",I,{type:$i,encoding:Ys});B=eo(n,b,R)}else await Promise.all([this.sendRequest({topic:b,method:"wc_sessionAuthenticate",params:W,expiry:s.expiry,throwOnFailedPublish:!0,clientRpcId:v}),this.sendRequest({topic:b,method:"wc_sessionPropose",params:k,expiry:Je.wc_sessionPropose.req.ttl,throwOnFailedPublish:!0,clientRpcId:k.id})])}catch(I){throw this.events.off(C,S),this.events.off(A,D),I}return await this.setProposal(k.id,k),await this.setAuthRequest(v,{request:it(Ie({},W),{verifyContext:{}}),pairingTopic:b,transportType:o}),{uri:B??E,response:Q}}),O(this,"approveSessionAuthenticate",async s=>{const{id:n,auths:r}=s,i=this.client.core.eventClient.createEvent({properties:{topic:n.toString(),trace:[pn.authenticated_session_approve_started]}});try{this.isInitialized()}catch(y){throw i.setError(Pr.no_internet_connection),y}const o=this.getPendingAuthRequest(n);if(!o)throw i.setError(Pr.authenticated_session_pending_request_not_found),new Error(`Could not find pending auth request with id ${n}`);const a=o.transportType||Pe.relay;a===Pe.relay&&await this.confirmOnlineStateOrThrow();const c=o.requester.publicKey,l=await this.client.core.crypto.generateKeyPair(),u=go(c),d={type:Ps,receiverPublicKey:c,senderPublicKey:l},h=[],p=[];for(const y of r){if(!await hu({cacao:y,projectId:this.client.core.projectId})){i.setError(Pr.invalid_cacao);const x=$e("SESSION_SETTLEMENT_FAILED","Signature verification failed");throw await this.sendError({id:n,topic:u,error:x,encodeOpts:d}),new Error(x.message)}i.addTrace(pn.cacaos_verified);const{p:w}=y,b=fo(w.resources),E=[uc(w.iss)],N=ko(w.iss);if(b){const x=pu(b),$=fu(b);h.push(...x),E.push(...$)}for(const x of E)p.push(`${x}:${N}`)}const g=await this.client.core.crypto.generateSharedKey(l,c);i.addTrace(pn.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:Be(Jn),authentication:r,requiredNamespaces:{},optionalNamespaces:{},relay:{protocol:"irn"},pairingTopic:o.pairingTopic,namespaces:ju([...new Set(h)],[...new Set(p)]),transportType:a},i.addTrace(pn.subscribing_authenticated_session_topic);try{await this.client.core.relayer.subscribe(g,{transportType:a})}catch(y){throw i.setError(Pr.subscribe_authenticated_session_topic_failure),y}i.addTrace(pn.subscribe_authenticated_session_topic_success),await this.client.session.set(g,f),i.addTrace(pn.store_authenticated_session),await this.client.core.pairing.updateMetadata({topic:o.pairingTopic,metadata:o.requester.metadata})}i.addTrace(pn.publishing_authenticated_session_approve);try{await this.sendResult({topic:u,id:n,result:{cacaos:r,responder:{publicKey:l,metadata:this.client.metadata}},encodeOpts:d,throwOnFailedPublish:!0,appLink:this.getAppLinkIfEnabled(o.requester.metadata,a)})}catch(y){throw i.setError(Pr.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}}),O(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===Pe.relay&&await this.confirmOnlineStateOrThrow();const o=i.requester.publicKey,a=await this.client.core.crypto.generateKeyPair(),c=go(o),l={type:Ps,receiverPublicKey:o,senderPublicKey:a};await this.sendError({id:n,topic:c,error:r,encodeOpts:l,rpcOpts:Je.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)}),O(this,"formatAuthMessage",s=>{this.isInitialized();const{request:n,iss:r}=s;return Jh(n,r)}),O(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)}),O(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)}}),O(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,$e("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(md).catch(l=>this.client.logger.warn(l)),this.getPendingSessionRequests().forEach(l=>{l.topic===r&&this.deletePendingSessionRequest(l.id,$e("USER_DISCONNECTED"))}),r===((n=this.sessionRequestQueue.queue[0])==null?void 0:n.topic)&&(this.sessionRequestQueue.state=rs.idle),o&&this.client.events.emit("session_delete",{id:a,topic:r})}),O(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(hn.proposal_expired)}catch{}await Promise.all([this.client.proposal.delete(s,$e("USER_DISCONNECTED")),n?Promise.resolve():this.client.core.expirer.del(s)]),this.addToRecentlyDeleted(s,"proposal")}),O(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=rs.idle,this.client.events.emit("session_request_expire",{id:s}))}),O(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)])}),O(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}))}),O(this,"setProposal",async(s,n)=>{this.client.core.expirer.set(s,Be(Je.wc_sessionPropose.req.ttl)),await this.client.proposal.set(s,n)}),O(this,"setAuthRequest",async(s,n)=>{const{request:r,pairingTopic:i,transportType:o=Pe.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})}),O(this,"setPendingSessionRequest",async s=>{const{id:n,topic:r,params:i,verifyContext:o}=s,a=i.request.expiryTimestamp||Be(Je.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})}),O(this,"sendRequest",async s=>{const{topic:n,method:r,params:i,expiry:o,relayRpcId:a,clientRpcId:c,throwOnFailedPublish:l,appLink:u,tvf:d,publishOpts:h={}}=s,p=as(r,i,c);let g;const f=!!u;try{const b=f?Ys:yt;g=await this.client.core.crypto.encode(n,p,{encoding:b})}catch(b){throw await this.cleanup(),this.client.logger.error(`sendRequest() -> core.crypto.encode() for topic ${n} failed`),b}let y;if(xI.includes(r)){const b=Bt(JSON.stringify(p)),E=Bt(g);y=await this.client.core.verify.register({id:E,decryptedId:b})}const w=Ie(Ie({},Je[r].req),h);if(w.attestation=y,o&&(w.ttl=o),a&&(w.id=a),this.client.core.history.set(n,p),f){const b=eo(u,n,g);await global.Linking.openURL(b,this.client.name)}else w.tvf=it(Ie({},d),{correlationId:p.id}),l?(w.internal=it(Ie({},w.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(n,g,w)):this.client.core.relayer.publish(n,g,w).catch(b=>this.client.logger.error(b));return p.id}),O(this,"sendProposeSession",async s=>{const{proposal:n,publishOpts:r}=s,i=as("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:yt}),a=Bt(JSON.stringify(i)),c=Bt(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:it(Ie({},r),{publishMethod:"wc_proposeSession",attestation:l})})}),O(this,"sendApproveSession",async s=>{const{sessionTopic:n,pairingProposalResponse:r,proposal:i,sessionSettleRequest:o,publishOpts:a}=s,c=Yr(i.id,r),l=await this.client.core.crypto.encode(i.pairingTopic,c,{encoding:yt}),u=as("wc_sessionSettle",o,a==null?void 0:a.id),d=await this.client.core.crypto.encode(n,u,{encoding:yt});this.client.core.history.set(n,u),await this.client.core.relayer.publishCustom({payload:{sessionTopic:n,pairingTopic:i.pairingTopic,sessionProposalResponse:l,sessionSettlementRequest:d},opts:it(Ie({},a),{publishMethod:"wc_approveSession"})})}),O(this,"sendResult",async s=>{const{id:n,topic:r,result:i,throwOnFailedPublish:o,encodeOpts:a,appLink:c}=s,l=Yr(n,i);let u;const d=c&&typeof(global==null?void 0:global.Linking)<"u";try{const g=d?Ys:yt;u=await this.client.core.crypto.encode(r,l,it(Ie({},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(d){const g=eo(c,r,u);await global.Linking.openURL(g,this.client.name)}else{const g=h.request.method,f=Je[g].res;f.tvf=it(Ie({},p),{correlationId:n}),o?(f.internal=it(Ie({},f.internal),{throwOnFailedPublish:!0}),await this.client.core.relayer.publish(r,u,f)):this.client.core.relayer.publish(r,u,f).catch(y=>this.client.logger.error(y))}await this.client.core.history.resolve(l)}),O(this,"sendError",async s=>{const{id:n,topic:r,error:i,encodeOpts:o,rpcOpts:a,appLink:c}=s,l=sh(n,i);let u;const d=c&&typeof(global==null?void 0:global.Linking)<"u";try{const p=d?Ys:yt;u=await this.client.core.crypto.encode(r,l,it(Ie({},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(d){const p=eo(c,r,u);await global.Linking.openURL(p,this.client.name)}else{const p=h.request.method,g=a||Je[p].res;this.client.core.relayer.publish(r,u,g)}await this.client.core.history.resolve(l)}),O(this,"cleanup",async()=>{const s=[],n=[];this.client.session.getAll().forEach(r=>{let i=!1;cs(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=>{cs(r.expiryTimestamp)&&n.push(r.id)}),await Promise.all([...s.map(r=>this.deleteSession({topic:r})),...n.map(r=>this.deleteProposal(r))])}),O(this,"onProviderMessageEvent",async s=>{!this.initialized||this.relayMessageCache.length>0?this.relayMessageCache.push(s):await this.onRelayMessage(s)}),O(this,"onRelayEventRequest",async s=>{this.requestQueue.queue.push(s),await this.processRequestsQueue()}),O(this,"processRequestsQueue",async()=>{if(this.requestQueue.state===rs.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=rs.active;const s=this.requestQueue.queue.shift();if(s)try{await this.processRequest(s)}catch(n){this.client.logger.warn(n)}}this.requestQueue.state=rs.idle}),O(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}`)}}),O(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}`)}}),O(this,"onRelayEventUnknownPayload",s=>{const{topic:n}=s,{message:r}=M("MISSING_OR_INVALID",`Decoded payload on topic ${n} is not identifiable as a JSON-RPC request or a response.`);throw new Error(r)}),O(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)}),O(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(vs.proposal_listener_not_found)),this.isValidConnect(Ie({},r.params));const u=a.expiryTimestamp||Be(Je.wc_sessionPropose.req.ttl),d=Ie({id:c,pairingTopic:n,expiryTimestamp:u,attestation:i,encryptedId:o},a);await this.setProposal(c,d);const h=await this.getVerifyContext({attestationId:i,hash:Bt(JSON.stringify(r)),encryptedId:o,metadata:d.proposer.metadata});l==null||l.addTrace(is.emit_session_proposal),this.client.events.emit("session_proposal",{id:c,params:d,verifyContext:h})}catch(l){await this.sendError({id:c,topic:n,error:l,rpcOpts:Je.wc_sessionPropose.autoReject}),this.client.logger.error(l)}}),O(this,"onSessionProposeResponse",async(s,n,r)=>{const{id:i}=n;if(ws(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 u=await this.client.core.crypto.generateSharedKey(c,l);this.pendingSessions.set(i,{sessionTopic:u,pairingTopic:s,proposalId:i,publicKey:c});const d=await this.client.core.relayer.subscribe(u,{transportType:r});this.client.logger.trace({type:"method",method:"onSessionProposeResponse",subscriptionId:d}),await this.client.core.pairing.activate({topic:s})}else if(os(n)){await this.deleteProposal(i);const o=Ae("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})}}),O(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:u,scopedProperties:d,sessionConfig:h}=n.params,p=[...this.pendingSessions.values()].find(y=>y.sessionTopic===s);if(!p)return this.client.logger.error(`Pending session not found for topic ${s}`);const g=this.client.proposal.get(p.proposalId),f=it(Ie(Ie(Ie({topic:s,relay:o,expiry:c,namespaces:l,acknowledged:!0,pairingTopic:p.pairingTopic,requiredNamespaces:g.requiredNamespaces,optionalNamespaces:g.optionalNamespaces,controller:a.publicKey,self:{publicKey:p.publicKey,metadata:this.client.metadata},peer:{publicKey:a.publicKey,metadata:a.metadata}},u&&{sessionProperties:u}),d&&{scopedProperties:d}),h&&{sessionConfig:h}),{transportType:Pe.relay});await this.client.session.set(f.topic,f),await this.setExpiry(f.topic,f.expiry),await this.client.core.pairing.updateMetadata({topic:p.pairingTopic,metadata:f.peer.metadata}),this.client.events.emit("session_connect",{session:f}),this.events.emit(Ae("session_connect",p.proposalId),{session:f}),this.pendingSessions.delete(p.proposalId),this.deleteProposal(p.proposalId,!1),this.cleanupDuplicatePairings(f),await this.sendResult({id:n.id,topic:s,result:!0})}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),O(this,"onSessionSettleResponse",async(s,n)=>{const{id:r}=n;ws(n)?(await this.client.session.update(s,{acknowledged:!0}),this.events.emit(Ae("session_approve",r),{})):os(n)&&(await this.client.session.delete(s,$e("USER_DISCONNECTED")),this.events.emit(Ae("session_approve",r),{error:n.error}))}),O(this,"onSessionUpdateRequest",async(s,n)=>{const{params:r,id:i}=n;try{const o=`${s}_session_update`,a=Tr.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:$e("INVALID_UPDATE_REQUEST")});return}this.isValidUpdate(Ie({topic:s},r));try{Tr.set(o,i),await this.client.session.update(s,{namespaces:r.namespaces}),await this.sendResult({id:i,topic:s,result:!0})}catch(c){throw Tr.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)}}),O(this,"isRequestOutOfSync",(s,n)=>n.toString().slice(0,-3)<s.toString().slice(0,-3)),O(this,"onSessionUpdateResponse",(s,n)=>{const{id:r}=n,i=Ae("session_update",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_update",r),{}):os(n)&&this.events.emit(Ae("session_update",r),{error:n.error})}),O(this,"onSessionExtendRequest",async(s,n)=>{const{id:r}=n;try{this.isValidExtend({topic:s}),await this.setExpiry(s,Be(Jn)),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)}}),O(this,"onSessionExtendResponse",(s,n)=>{const{id:r}=n,i=Ae("session_extend",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_extend",r),{}):os(n)&&this.events.emit(Ae("session_extend",r),{error:n.error})}),O(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)}}),O(this,"onSessionPingResponse",(s,n)=>{const{id:r}=n,i=Ae("session_ping",r);setTimeout(()=>{if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners 2176`);ws(n)?this.events.emit(Ae("session_ping",r),{}):os(n)&&this.events.emit(Ae("session_ping",r),{error:n.error})},500)}),O(this,"onSessionDeleteRequest",async(s,n)=>{const{id:r}=n;try{this.isValidDisconnect({topic:s,reason:n.params}),await Promise.all([new Promise(i=>{this.client.core.relayer.once(Le.publish,async()=>{i(await this.deleteSession({topic:s,id:r}))})}),this.sendResult({id:r,topic:s,result:!0}),this.cleanupPendingSentRequestsForTopic({topic:s,error:$e("USER_DISCONNECTED")})]).catch(i=>this.client.logger.error(i))}catch(i){this.client.logger.error(i)}}),O(this,"onSessionRequest",async s=>{var n,r,i;const{topic:o,payload:a,attestation:c,encryptedId:l,transportType:u}=s,{id:d,params:h}=a;try{await this.isValidRequest(Ie({topic:o},h));const p=this.client.session.get(o),g=await this.getVerifyContext({attestationId:c,hash:Bt(JSON.stringify(as("wc_sessionRequest",h,d))),encryptedId:l,metadata:p.peer.metadata,transportType:u}),f={id:d,topic:o,params:h,verifyContext:g};await this.setPendingSessionRequest(f),u===Pe.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:d,topic:o,error:p}),this.client.logger.error(p)}}),O(this,"onSessionRequestResponse",(s,n)=>{const{id:r}=n,i=Ae("session_request",r);if(this.events.listenerCount(i)===0)throw new Error(`emitting ${i} without any listeners`);ws(n)?this.events.emit(Ae("session_request",r),{result:n.result}):os(n)&&this.events.emit(Ae("session_request",r),{error:n.error})}),O(this,"onSessionEventRequest",async(s,n)=>{const{id:r,params:i}=n;try{const o=`${s}_session_event_${i.event.name}`,a=Tr.get(o);if(a&&this.isRequestOutOfSync(a,r)){this.client.logger.info(`Discarding out of sync request - ${r}`);return}this.isValidEmit(Ie({topic:s},i)),this.client.events.emit("session_event",{id:r,topic:s,params:i}),Tr.set(o,r)}catch(o){await this.sendError({id:r,topic:s,error:o}),this.client.logger.error(o)}}),O(this,"onSessionAuthenticateResponse",(s,n)=>{const{id:r}=n;this.client.logger.trace({type:"method",method:"onSessionAuthenticateResponse",topic:s,payload:n}),ws(n)?this.events.emit(Ae("session_request",r),{result:n.result}):os(n)&&this.events.emit(Ae("session_request",r),{error:n.error})}),O(this,"onSessionAuthenticateRequest",async s=>{var n;const{topic:r,payload:i,attestation:o,encryptedId:a,transportType:c}=s;try{const{requester:l,authPayload:u,expiryTimestamp:d}=i.params,h=await this.getVerifyContext({attestationId:o,hash:Bt(JSON.stringify(i)),encryptedId:a,metadata:l.metadata,transportType:c}),p={requester:l,pairingTopic:r,id:i.id,authPayload:u,verifyContext:h,expiryTimestamp:d};await this.setAuthRequest(i.id,{request:p,pairingTopic:r,transportType:c}),c===Pe.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 u=i.params.requester.publicKey,d=await this.client.core.crypto.generateKeyPair(),h=this.getAppLinkIfEnabled(i.params.requester.metadata,c),p={type:Ps,receiverPublicKey:u,senderPublicKey:d};await this.sendError({id:i.id,topic:r,error:l,encodeOpts:p,rpcOpts:Je.wc_sessionAuthenticate.autoReject,appLink:h})}}),O(this,"addSessionRequestToSessionRequestQueue",s=>{this.sessionRequestQueue.queue.push(s)}),O(this,"cleanupAfterResponse",s=>{this.deletePendingSessionRequest(s.response.id,{message:"fulfilled",code:0}),setTimeout(()=>{this.sessionRequestQueue.state=rs.idle,this.processSessionRequestQueue()},F.toMiliseconds(this.requestQueueDelay))}),O(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=>{const o=i.request.id,a=Ae("session_request",o);if(this.events.listenerCount(a)===0)throw new Error(`emitting ${a} without any listeners`);this.events.emit(Ae("session_request",i.request.id),{error:n})})}),O(this,"processSessionRequestQueue",()=>{if(this.sessionRequestQueue.state===rs.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)}}),O(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=rs.active,this.emittedSessionRequests.add(s.id),this.client.events.emit("session_request",s)}),O(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:as("wc_sessionPropose",it(Ie({},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})}),O(this,"isValidConnect",async s=>{if(!gt(s)){const{message:l}=M("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(We(n)||await this.isValidPairingTopic(n),!wE(c)){const{message:l}=M("MISSING_OR_INVALID",`connect() relays: ${c}`);throw new Error(l)}if(r&&!We(r)&&fs(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&&!We(i)&&fs(i)!==0&&this.validateNamespaces(i,"optionalNamespaces"),o&&!We(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!We(a)){this.validateSessionProps(a,"scopedProperties");const l=Object.keys(r||{}).concat(Object.keys(i||{}));if(!Object.keys(a).every(u=>l.includes(u.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)}`)}}),O(this,"validateNamespaces",(s,n)=>{const r=yE(s,"connect()",n);if(r)throw new Error(r.message)}),O(this,"isValidApprove",async s=>{if(!gt(s))throw new Error(M("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=Oa(r,"approve()");if(l)throw new Error(l.message);const u=Wu(c.requiredNamespaces,r,"approve()");if(u)throw new Error(u.message);if(!je(i,!0)){const{message:d}=M("MISSING_OR_INVALID",`approve() relayProtocol: ${i}`);throw new Error(d)}if(o&&!We(o)&&this.validateSessionProps(o,"sessionProperties"),a&&!We(a)){this.validateSessionProps(a,"scopedProperties");const d=new Set(Object.keys(r));if(!Object.keys(a).every(h=>d.has(h.split(":")[0])))throw new Error(`Scoped properties must be a subset of approved namespaces, received: ${JSON.stringify(a)}, approved namespaces: ${Array.from(d).join(", ")}`)}}),O(this,"isValidReject",async s=>{if(!gt(s)){const{message:i}=M("MISSING_OR_INVALID",`reject() params: ${s}`);throw new Error(i)}const{id:n,reason:r}=s;if(this.checkRecentlyDeleted(n),await this.isValidProposalId(n),!vE(r)){const{message:i}=M("MISSING_OR_INVALID",`reject() reason: ${JSON.stringify(r)}`);throw new Error(i)}}),O(this,"isValidSessionSettleRequest",s=>{if(!gt(s)){const{message:l}=M("MISSING_OR_INVALID",`onSessionSettleRequest() params: ${s}`);throw new Error(l)}const{relay:n,controller:r,namespaces:i,expiry:o}=s;if(!xp(n)){const{message:l}=M("MISSING_OR_INVALID","onSessionSettleRequest() relay protocol should be a string");throw new Error(l)}const a=dE(r,"onSessionSettleRequest()");if(a)throw new Error(a.message);const c=Oa(i,"onSessionSettleRequest()");if(c)throw new Error(c.message);if(cs(o)){const{message:l}=M("EXPIRED","onSessionSettleRequest()");throw new Error(l)}}),O(this,"isValidUpdate",async s=>{if(!gt(s)){const{message:c}=M("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=Oa(r,"update()");if(o)throw new Error(o.message);const a=Wu(i.requiredNamespaces,r,"update()");if(a)throw new Error(a.message)}),O(this,"isValidExtend",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`extend() params: ${s}`);throw new Error(r)}const{topic:n}=s;this.checkRecentlyDeleted(n),await this.isValidSessionTopic(n)}),O(this,"isValidRequest",async s=>{if(!gt(s)){const{message:c}=M("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(!qu(a,i)){const{message:c}=M("MISSING_OR_INVALID",`request() chainId: ${i}`);throw new Error(c)}if(!EE(r)){const{message:c}=M("MISSING_OR_INVALID",`request() ${JSON.stringify(r)}`);throw new Error(c)}if(!IE(a,i,r.method)){const{message:c}=M("MISSING_OR_INVALID",`request() method: ${r.method}`);throw new Error(c)}if(o&&!TE(o,Ua)){const{message:c}=M("MISSING_OR_INVALID",`request() expiry: ${o}. Expiry must be a number (in seconds) between ${Ua.min} and ${Ua.max}`);throw new Error(c)}}),O(this,"isValidRespond",async s=>{var n;if(!gt(s)){const{message:a}=M("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(!CE(i)){const{message:a}=M("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}=M("MISMATCHED_TOPIC",`Request response topic mismatch. reqId: ${i.id}, expected topic: ${o.topic}, received topic: ${r}`);throw new Error(a)}}),O(this,"isValidPing",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`ping() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),O(this,"isValidEmit",async s=>{if(!gt(s)){const{message:a}=M("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(!qu(o,i)){const{message:a}=M("MISSING_OR_INVALID",`emit() chainId: ${i}`);throw new Error(a)}if(!AE(r)){const{message:a}=M("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}if(!_E(o,i,r.name)){const{message:a}=M("MISSING_OR_INVALID",`emit() event: ${JSON.stringify(r)}`);throw new Error(a)}}),O(this,"isValidDisconnect",async s=>{if(!gt(s)){const{message:r}=M("MISSING_OR_INVALID",`disconnect() params: ${s}`);throw new Error(r)}const{topic:n}=s;await this.isValidSessionOrPairingTopic(n)}),O(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(!je(r,!1))throw new Error("uri is required parameter");if(!je(i,!1))throw new Error("domain is required parameter");if(!je(o,!1))throw new Error("nonce is required parameter");if([...new Set(n.map(c=>Os(c).namespace))].length>1)throw new Error("Multi-namespace requests are not supported. Please request single namespace only.");const{namespace:a}=Os(n[0]);if(a!=="eip155")throw new Error("Only eip155 namespace is supported for authenticated sessions. Please use .connect() for non-eip155 chains.")}),O(this,"getVerifyContext",async s=>{const{attestationId:n,hash:r,encryptedId:i,metadata:o,transportType:a}=s,c={verified:{verifyUrl:o.verifyUrl||Kr,validation:"UNKNOWN",origin:o.url||""}};try{if(a===Pe.link_mode){const u=this.getAppLinkIfEnabled(o,a);return c.verified.validation=u&&new URL(u).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}),O(this,"validateSessionProps",(s,n)=>{Object.values(s).forEach((r,i)=>{if(r==null){const{message:o}=M("MISSING_OR_INVALID",`${n} must contain an existing value for each key. Received: ${r} for key ${Object.keys(s)[i]}`);throw new Error(o)}})}),O(this,"getPendingAuthRequest",s=>{const n=this.client.auth.requests.get(s);return typeof n=="object"?n:void 0}),O(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)}}}),O(this,"checkRecentlyDeleted",s=>{const n=this.recentlyDeletedMap.get(s);if(n){const{message:r}=M("MISSING_OR_INVALID",`Record was recently deleted - ${n}: ${s}`);throw new Error(r)}}),O(this,"isLinkModeEnabled",(s,n)=>{var r,i,o,a,c,l,u,d,h;return!s||n!==Pe.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)!==""&&((u=s==null?void 0:s.redirect)==null?void 0:u.universal)!==void 0&&((d=s==null?void 0:s.redirect)==null?void 0:d.universal)!==""&&((h=s==null?void 0:s.redirect)==null?void 0:h.linkMode)===!0&&this.client.core.linkModeSupportedApps.includes(s.redirect.universal)&&typeof(global==null?void 0:global.Linking)<"u"}),O(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}),O(this,"handleLinkModeMessage",({url:s})=>{if(!s||!s.includes("wc_ev")||!s.includes("topic"))return;const n=eu(s,"topic")||"",r=decodeURIComponent(eu(s,"wc_ev")||""),i=this.client.session.keys.includes(n);i&&this.client.session.update(n,{transportType:Pe.link_mode}),this.client.core.dispatchEnvelope({topic:n,message:r,sessionExists:i})}),O(this,"registerLinkModeListeners",async()=>{var s;if(Qc()||on()&&(s=this.client.metadata.redirect)!=null&&s.linkMode){const n=global==null?void 0:global.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)}}}),O(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}),O(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}),O(this,"extractTxHashesFromResult",(s,n)=>{var r;try{if(!n)return[];const i=s.method,o=kI[i];if(i==="sui_signTransaction")return[Hb(n.transactionBytes)];if(i==="near_signTransaction")return[cu(n)];if(i==="near_signTransactions")return n.map(c=>cu(c));if(i==="xrpl_signTransactionFor"||i==="xrpl_signTransaction")return[(r=n.tx_json)==null?void 0:r.hash];if(i==="polkadot_signTransaction")return[WE({transaction:s.params.transactionPayload,signature:n.signature})];if(i==="algo_signTxn")return ks(n)?n.map(c=>lu(c)):[lu(n)];if(i==="cosmos_signDirect")return[zb(n)];if(i==="wallet_sendCalls")return Vb(n);if(typeof n=="string")return[n];const a=n[o.key];if(ks(a))return i==="solana_signAllTransactions"?a.map(c=>Wb(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}=M("NOT_INITIALIZED",this.name);throw new Error(e)}}async confirmOnlineStateOrThrow(){await this.client.core.relayer.confirmOnlineStateOrThrow()}registerRelayerEvents(){this.client.core.relayer.on(Le.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(yo)?this.client.auth.authKeys.get(yo):{publicKey:void 0};try{const a=await this.client.core.crypto.decode(s,n,{receiverPublicKey:o,encoding:i===Pe.link_mode?Ys:yt});qc(a)?(this.client.core.history.set(s,a),await this.onRelayEventRequest({topic:s,payload:a,attestation:r,transportType:i,encryptedId:Bt(n)})):Wc(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)):await this.onRelayEventUnknownPayload({topic:s,payload:a,transportType:i}),await this.client.core.relayer.messages.ack(s,n)}catch(a){this.client.logger.error(a)}}registerExpirerEvents(){this.client.core.expirer.on(Mt.expired,async e=>{const{topic:s,id:n}=$h(e.target);if(n&&this.client.pendingRequest.keys.includes(n))return await this.deletePendingSessionRequest(n,M("EXPIRED"),!0);if(n&&this.client.auth.requests.keys.includes(n))return await this.deletePendingAuthRequest(n,M("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(wn.create,e=>this.onPairingCreated(e)),this.client.core.pairing.events.on(wn.delete,e=>{this.addToRecentlyDeleted(e.topic,"pairing")})}isValidPairingTopic(e){if(!je(e,!1)){const{message:s}=M("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}=M("NO_MATCHING_KEY",`pairing topic doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.core.pairing.pairings.get(e).expiry)){const{message:s}=M("EXPIRED",`pairing topic: ${e}`);throw new Error(s)}}async isValidSessionTopic(e){if(!je(e,!1)){const{message:s}=M("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}=M("NO_MATCHING_KEY",`session topic doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.session.get(e).expiry)){await this.deleteSession({topic:e});const{message:s}=M("EXPIRED",`session topic: ${e}`);throw new Error(s)}if(!this.client.core.crypto.keychain.has(e)){const{message:s}=M("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(je(e,!1)){const{message:s}=M("NO_MATCHING_KEY",`session or pairing topic doesn't exist: ${e}`);throw new Error(s)}else{const{message:s}=M("MISSING_OR_INVALID",`session or pairing topic should be a string: ${e}`);throw new Error(s)}}async isValidProposalId(e){if(!bE(e)){const{message:s}=M("MISSING_OR_INVALID",`proposal id should be a number: ${e}`);throw new Error(s)}if(!this.client.proposal.keys.includes(e)){const{message:s}=M("NO_MATCHING_KEY",`proposal id doesn't exist: ${e}`);throw new Error(s)}if(cs(this.client.proposal.get(e).expiryTimestamp)){await this.deleteProposal(e);const{message:s}=M("EXPIRED",`proposal id: ${e}`);throw new Error(s)}}}class KI extends Wn{constructor(e,s){super(e,s,TI,hl),this.core=e,this.logger=s}}let zI=class extends Wn{constructor(e,s){super(e,s,OI,hl),this.core=e,this.logger=s}};class VI extends Wn{constructor(e,s){super(e,s,RI,hl,n=>n.id),this.core=e,this.logger=s}}class GI extends Wn{constructor(e,s){super(e,s,DI,ra,()=>yo),this.core=e,this.logger=s}}class YI extends Wn{constructor(e,s){super(e,s,LI,ra),this.core=e,this.logger=s}}class JI extends Wn{constructor(e,s){super(e,s,MI,ra,n=>n.id),this.core=e,this.logger=s}}var XI=Object.defineProperty,ZI=(t,e,s)=>e in t?XI(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Da=(t,e,s)=>ZI(t,typeof e!="symbol"?e+"":e,s);class QI{constructor(e,s){this.core=e,this.logger=s,Da(this,"authKeys"),Da(this,"pairingTopics"),Da(this,"requests"),this.authKeys=new GI(this.core,this.logger),this.pairingTopics=new YI(this.core,this.logger),this.requests=new JI(this.core,this.logger)}async init(){await this.authKeys.init(),await this.pairingTopics.init(),await this.requests.init()}}var e_=Object.defineProperty,t_=(t,e,s)=>e in t?e_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,fe=(t,e,s)=>t_(t,typeof e!="symbol"?e+"":e,s);let s_=class ef extends Ew{constructor(e){super(e),fe(this,"protocol",Xp),fe(this,"version",Zp),fe(this,"name",$a.name),fe(this,"metadata"),fe(this,"core"),fe(this,"logger"),fe(this,"events",new Mn.EventEmitter),fe(this,"engine"),fe(this,"session"),fe(this,"proposal"),fe(this,"pendingRequest"),fe(this,"auth"),fe(this,"signConfig"),fe(this,"on",(n,r)=>this.events.on(n,r)),fe(this,"once",(n,r)=>this.events.once(n,r)),fe(this,"off",(n,r)=>this.events.off(n,r)),fe(this,"removeListener",(n,r)=>this.events.removeListener(n,r)),fe(this,"removeAllListeners",n=>this.events.removeAllListeners(n)),fe(this,"connect",async n=>{try{return await this.engine.connect(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"pair",async n=>{try{return await this.engine.pair(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"approve",async n=>{try{return await this.engine.approve(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"reject",async n=>{try{return await this.engine.reject(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"update",async n=>{try{return await this.engine.update(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"extend",async n=>{try{return await this.engine.extend(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"request",async n=>{try{return await this.engine.request(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"respond",async n=>{try{return await this.engine.respond(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"ping",async n=>{try{return await this.engine.ping(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"emit",async n=>{try{return await this.engine.emit(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"disconnect",async n=>{try{return await this.engine.disconnect(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"find",n=>{try{return this.engine.find(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"getPendingSessionRequests",()=>{try{return this.engine.getPendingSessionRequests()}catch(n){throw this.logger.error(n.message),n}}),fe(this,"authenticate",async(n,r)=>{try{return await this.engine.authenticate(n,r)}catch(i){throw this.logger.error(i.message),i}}),fe(this,"formatAuthMessage",n=>{try{return this.engine.formatAuthMessage(n)}catch(r){throw this.logger.error(r.message),r}}),fe(this,"approveSessionAuthenticate",async n=>{try{return await this.engine.approveSessionAuthenticate(n)}catch(r){throw this.logger.error(r.message),r}}),fe(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)||$a.name,this.metadata=Dw(e==null?void 0:e.metadata),this.signConfig=e==null?void 0:e.signConfig;const s=dl({logger:(e==null?void 0:e.logger)||$a.logger,name:this.name});this.logger=s,this.core=(e==null?void 0:e.core)||new NI(e),this.session=new zI(this.core,this.logger),this.proposal=new KI(this.core,this.logger),this.pendingRequest=new VI(this.core,this.logger),this.engine=new HI(this),this.auth=new QI(this.core,this.logger)}static async init(e){const s=new ef(e);return await s.initialize(),s}get context(){return Et(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 n_=s_;function pl(t){return t==null||typeof t!="object"&&typeof t!="function"}function tf(t){return Object.getOwnPropertySymbols(t).filter(e=>Object.prototype.propertyIsEnumerable.call(t,e))}function sf(t){return t==null?t===void 0?"[object Undefined]":"[object Null]":Object.prototype.toString.call(t)}const r_="[object RegExp]",nf="[object String]",rf="[object Number]",of="[object Boolean]",af="[object Arguments]",i_="[object Symbol]",o_="[object Date]",a_="[object Map]",c_="[object Set]",l_="[object Array]",u_="[object ArrayBuffer]",d_="[object Object]",h_="[object DataView]",p_="[object Uint8Array]",f_="[object Uint8ClampedArray]",g_="[object Uint16Array]",m_="[object Uint32Array]",y_="[object Int8Array]",w_="[object Int16Array]",b_="[object Int32Array]",v_="[object Float32Array]",E_="[object Float64Array]";function fl(t){return ArrayBuffer.isView(t)&&!(t instanceof DataView)}function C_(t,e){return nr(t,void 0,t,new Map,e)}function nr(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(pl(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]=nr(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,nr(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(nr(a,void 0,s,n,r));return o}if(typeof Buffer<"u"&&Buffer.isBuffer(t))return t.subarray();if(fl(t)){const o=new(Object.getPrototypeOf(t)).constructor(t.length);n.set(t,o);for(let a=0;a<t.length;a++)o[a]=nr(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),bn(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),bn(o,t,s,n,r),o}if(t instanceof Blob){const o=new Blob([t],{type:t.type});return n.set(t,o),bn(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,bn(o,t,s,n,r),o}if(typeof t=="object"&&A_(t)){const o=Object.create(Object.getPrototypeOf(t));return n.set(t,o),bn(o,t,s,n,r),o}return t}function bn(t,e,s=t,n,r){const i=[...Object.keys(e),...tf(e)];for(let o=0;o<i.length;o++){const a=i[o],c=Object.getOwnPropertyDescriptor(t,a);(c==null||c.writable)&&(t[a]=nr(e[a],a,s,n,r))}}function A_(t){switch(sf(t)){case af:case l_:case u_:case h_:case of:case o_:case v_:case E_:case y_:case w_:case b_:case a_:case rf:case d_:case r_:case c_:case nf:case i_:case p_:case f_:case g_:case m_:return!0;default:return!1}}function I_(t,e){return C_(t,(s,n,r,i)=>{if(typeof t=="object")switch(Object.prototype.toString.call(t)){case rf:case nf:case of:{const o=new t.constructor(t==null?void 0:t.valueOf());return bn(o,t),o}case af:{const o={};return bn(o,t),o.length=t.length,o[Symbol.iterator]=t[Symbol.iterator],o}default:return}})}function bd(t){return I_(t)}function vd(t){return t!==null&&typeof t=="object"&&sf(t)==="[object Arguments]"}function Ed(t){return typeof t=="object"&&t!==null}function __(){}function S_(t){return fl(t)}function N_(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 T_(t){if(pl(t))return t;if(Array.isArray(t)||fl(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 O_(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=$c(r,o,n,new Map)}return r}function $c(t,e,s,n){if(pl(t)&&(t=Object(t)),e==null||typeof e!="object")return t;if(n.has(e))return T_(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),...tf(e)];for(let i=0;i<r.length;i++){const o=r[i];let a=e[o],c=t[o];if(vd(a)&&(a={...a}),vd(c)&&(c={...c}),typeof Buffer<"u"&&Buffer.isBuffer(a)&&(a=bd(a)),Array.isArray(a))if(typeof c=="object"&&c!=null){const u=[],d=Reflect.ownKeys(c);for(let h=0;h<d.length;h++){const p=d[h];u[p]=c[p]}c=u}else c=[];const l=s(c,a,o,t,e,n);l!=null?t[o]=l:Array.isArray(a)||Ed(c)&&Ed(a)?t[o]=$c(c,a,s,n):c==null&&N_(a)?t[o]=$c({},a,s,n):c==null&&S_(a)?t[o]=bd(a):(c===void 0||a!==void 0)&&(t[o]=a)}return t}function P_(t,...e){return O_(t,...e,__)}const Cd="error",k_="wss://relay.walletconnect.org",R_="wc",cf="universal_provider",to=`${R_}@2:${cf}:`,lf="https://rpc.walletconnect.org/v1/",uf="generic",x_=`${lf}bundler`,ar="call_status",$_=86400,gl={DEFAULT_CHAIN_CHANGED:"default_chain_changed"};var U_=Object.defineProperty,D_=Object.defineProperties,L_=Object.getOwnPropertyDescriptors,Ad=Object.getOwnPropertySymbols,M_=Object.prototype.hasOwnProperty,B_=Object.prototype.propertyIsEnumerable,Id=(t,e,s)=>e in t?U_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,so=(t,e)=>{for(var s in e||(e={}))M_.call(e,s)&&Id(t,s,e[s]);if(Ad)for(var s of Ad(e))B_.call(e,s)&&Id(t,s,e[s]);return t},j_=(t,e)=>D_(t,L_(e));function df(t,e,s){var n;const r=Os(t);return((n=e.rpcMap)==null?void 0:n[r.reference])||`${lf}?chainId=${r.namespace}:${r.reference}&projectId=${s}`}function F_(t){return t.includes(":")?t.split(":")[1]:t}function hf(t){return t.map(e=>`${e.split(":")[0]}:${e.split(":")[1]}`)}function q_(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 _d(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 no(t={},e={}){const s=_d(Sd(t)),n=_d(Sd(e));return P_(s,n)}function Sd(t){var e,s,n,r,i;const o={};if(!fs(t))return o;for(const[a,c]of Object.entries(t)){const l=sa(a)?[a]:c.chains,u=c.methods||[],d=c.events||[],h=c.rpcMap||{},p=sr(a);o[p]=j_(so(so({},o[p]),c),{chains:ps(l,(e=o[p])==null?void 0:e.chains),methods:ps(u,(s=o[p])==null?void 0:s.methods),events:ps(d,(n=o[p])==null?void 0:n.events)}),(fs(h)||fs(((r=o[p])==null?void 0:r.rpcMap)||{}))&&(o[p].rpcMap=so(so({},h),(i=o[p])==null?void 0:i.rpcMap))}return o}function Nd(t){return t.includes(":")?t.split(":")[2]:t}function Td(t){const e={};for(const[s,n]of Object.entries(t)){const r=n.methods||[],i=n.events||[],o=n.accounts||[],a=sa(s)?[s]:n.chains?n.chains:hf(n.accounts);e[s]={chains:a,methods:r,events:i,accounts:o}}return e}function La(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 W_(t){try{const e=JSON.parse(t);return typeof e=="object"&&e!==null&&!Array.isArray(e)}catch{return!1}}const pf={},cr=t=>pf[t],Ma=(t,e)=>{pf[t]=e};var H_=Object.defineProperty,Od=Object.getOwnPropertySymbols,K_=Object.prototype.hasOwnProperty,z_=Object.prototype.propertyIsEnumerable,Pd=(t,e,s)=>e in t?H_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,kd=(t,e)=>{for(var s in e||(e={}))K_.call(e,s)&&Pd(t,s,e[s]);if(Od)for(var s of Od(e))z_.call(e,s)&&Pd(t,s,e[s]);return t};const Rd="eip155",V_=["atomic","flow-control","paymasterService","sessionKeys","auxiliaryFunds"],G_=t=>t&&t.startsWith("0x")?BigInt(t).toString(10):t,Ba=t=>t&&t.startsWith("0x")?t:`0x${BigInt(t).toString(16)}`,xd=t=>Object.keys(t).filter(e=>V_.includes(e)).reduce((e,s)=>(e[s]=Y_(t[s]),e),{}),Y_=t=>typeof t=="string"&&W_(t)?JSON.parse(t):t,J_=(t,e,s)=>{const{sessionProperties:n={},scopedProperties:r={}}=t,i={};if(!fs(r)&&!fs(n))return;const o=xd(n);for(const a of s){const c=G_(a);if(!c)continue;i[Ba(c)]=o;const l=r==null?void 0:r[`${Rd}:${c}`];if(l){const u=l==null?void 0:l[`${Rd}:${c}:${e}`];i[Ba(c)]=kd(kd({},i[Ba(c)]),xd(u||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 X_=Object.defineProperty,Z_=(t,e,s)=>e in t?X_(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Q_=(t,e,s)=>Z_(t,e+"",s);let ja;class ml{constructor(e){Q_(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 ja||(ja=new ml(e)),ja}}var eS=Object.defineProperty,tS=Object.defineProperties,sS=Object.getOwnPropertyDescriptors,$d=Object.getOwnPropertySymbols,nS=Object.prototype.hasOwnProperty,rS=Object.prototype.propertyIsEnumerable,Ud=(t,e,s)=>e in t?eS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,iS=(t,e)=>{for(var s in e||(e={}))nS.call(e,s)&&Ud(t,s,e[s]);if($d)for(var s of $d(e))rS.call(e,s)&&Ud(t,s,e[s]);return t},oS=(t,e)=>tS(t,sS(e));async function aS(t,e){const s=Os(t.result.capabilities.caip345.caip2),n=t.result.capabilities.caip345.transactionHashes,r=await Promise.allSettled(n.map(d=>cS(s.reference,d,e))),i=r.filter(d=>d.status==="fulfilled").map(d=>d.value).filter(d=>d);r.filter(d=>d.status==="rejected").forEach(d=>console.warn("Failed to fetch transaction receipt:",d.reason));const o=!i.length||i.some(d=>!d),a=i.every(d=>(d==null?void 0:d.status)==="0x1"),c=i.every(d=>(d==null?void 0:d.status)==="0x0"),l=i.some(d=>(d==null?void 0:d.status)==="0x0");let u;return o?u=100:a?u=200:c?u=500:l&&(u=600),{id:t.result.id,version:t.request.version,atomic:t.request.atomicRequired,chainId:t.request.chainId,capabilities:t.result.capabilities,receipts:i,status:u}}async function cS(t,e,s){return await s(parseInt(t)).request(as("eth_getTransactionReceipt",[e]))}async function lS({sendCalls:t,storage:e}){const s=await e.getItem(ar);await e.setItem(ar,oS(iS({},s),{[t.result.id]:{request:t.request,result:t.result,expiry:Be($_)}}))}async function uS({resultId:t,storage:e}){const s=await e.getItem(ar);if(s){delete s[t],await e.setItem(ar,s);for(const n in s)cs(s[n].expiry)&&delete s[n];await e.setItem(ar,s)}}async function dS({resultId:t,storage:e}){const s=await e.getItem(ar),n=s==null?void 0:s[t];if(n&&!cs(n.expiry))return n;await uS({resultId:t,storage:e})}var hS=Object.defineProperty,pS=Object.defineProperties,fS=Object.getOwnPropertyDescriptors,Dd=Object.getOwnPropertySymbols,gS=Object.prototype.hasOwnProperty,mS=Object.prototype.propertyIsEnumerable,Uc=(t,e,s)=>e in t?hS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Fa=(t,e)=>{for(var s in e||(e={}))gS.call(e,s)&&Uc(t,s,e[s]);if(Dd)for(var s of Dd(e))mS.call(e,s)&&Uc(t,s,e[s]);return t},qa=(t,e)=>pS(t,fS(e)),fn=(t,e,s)=>Uc(t,typeof e!="symbol"?e+"":e,s);class yS{constructor(e){fn(this,"name","eip155"),fn(this,"client"),fn(this,"chainId"),fn(this,"namespace"),fn(this,"httpProviders"),fn(this,"events"),fn(this,"storage"),this.namespace=e.namespace,this.events=cr("events"),this.client=cr("client"),this.httpProviders=this.createHttpProviders(),this.chainId=parseInt(this.getDefaultChain()),this.storage=ml.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(gl.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||df(`${this.name}:${e}`,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Fc(new nh(n,cr("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(F_(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=qa(Fa({},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),u=((o=l==null?void 0:l.sessionProperties)==null?void 0:o.capabilities)||{},d=`${a}${c.join(",")}`,h=u==null?void 0:u[d];if(h)return h;let p;try{p=J_(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:qa(Fa({},l.sessionProperties||{}),{capabilities:qa(Fa({},u||{}),{[d]: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(u){console.warn("Failed to fetch call status from bundler",u,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 dS({resultId:(r=e.request.params)==null?void 0:r[0],storage:this.storage});if(c)try{return await aS(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(as("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`${x_}?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,u=(r=c==null?void 0:c.caip345)==null?void 0:r.transactionHashes;return!a||!l||!(u!=null&&u.length)||await lS({sendCalls:{request:o,result:i},storage:this.storage}),i}}var wS=Object.defineProperty,bS=(t,e,s)=>e in t?wS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Xn=(t,e,s)=>bS(t,typeof e!="symbol"?e+"":e,s);class vS{constructor(e){Xn(this,"name",uf),Xn(this,"client"),Xn(this,"httpProviders"),Xn(this,"events"),Xn(this,"namespace"),Xn(this,"chainId"),this.namespace=e.namespace,this.events=cr("events"),this.client=cr("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(gl.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 Os(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=Os(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=Os(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||df(e,this.namespace,this.client.core.projectId);if(!n)throw new Error(`No RPC url provided for chainId: ${e}`);return new Fc(new nh(n,cr("disableProviderPing")))}}var ES=Object.defineProperty,CS=Object.defineProperties,AS=Object.getOwnPropertyDescriptors,Ld=Object.getOwnPropertySymbols,IS=Object.prototype.hasOwnProperty,_S=Object.prototype.propertyIsEnumerable,Dc=(t,e,s)=>e in t?ES(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,xr=(t,e)=>{for(var s in e||(e={}))IS.call(e,s)&&Dc(t,s,e[s]);if(Ld)for(var s of Ld(e))_S.call(e,s)&&Dc(t,s,e[s]);return t},ro=(t,e)=>CS(t,AS(e)),Ut=(t,e,s)=>Dc(t,typeof e!="symbol"?e+"":e,s);let SS=class ff{constructor(e){Ut(this,"client"),Ut(this,"namespaces"),Ut(this,"optionalNamespaces"),Ut(this,"sessionProperties"),Ut(this,"scopedProperties"),Ut(this,"events",new jc),Ut(this,"rpcProviders",{}),Ut(this,"session"),Ut(this,"providerOpts"),Ut(this,"logger"),Ut(this,"uri"),Ut(this,"disableProviderPing",!1);var s,n;this.providerOpts=e,this.logger=dl({logger:(s=e.logger)!=null?s:Cd,name:(n=this.providerOpts.name)!=null?n:cf}),this.disableProviderPing=(e==null?void 0:e.disableProviderPing)||!1}static async init(e){const s=new ff(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:xr({},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,Yr(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:$e("USER_DISCONNECTED")}),await this.cleanup()}async connect(e){if(!this.client)throw new Error("Sign Client not initialized");if(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=Td(this.session.namespaces);this.namespaces=no(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){const{uri:s,approval:n}=await this.client.connect({pairingTopic:e,requiredNamespaces:this.namespaces,optionalNamespaces:this.optionalNamespaces,sessionProperties:this.sessionProperties,scopedProperties:this.scopedProperties});s&&(this.uri=s,this.events.emit("display_uri",s));const r=await n();this.session=r;const i=Td(r.namespaces);return this.namespaces=no(this.namespaces,i),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(!ks(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 n_.init({core:this.providerOpts.core,logger:this.providerOpts.logger||Cd,relayUrl:this.providerOpts.relayUrl||k_,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=>sr(s)))];Ma("client",this.client),Ma("events",this.events),Ma("disableProviderPing",this.disableProviderPing),e.forEach(s=>{if(!this.session)return;const n=q_(s,this.session);if((n==null?void 0:n.length)===0)return;const r=hf(n),i=no(this.namespaces,this.optionalNamespaces),o=ro(xr({},i[s]),{accounts:n,chains:r});switch(s){case"eip155":this.rpcProviders[s]=new yS({namespace:o});break;default:this.rpcProviders[s]=new vS({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&&ks(o)&&this.events.emit("accountsChanged",o.map(Nd))}else if(i.name==="chainChanged"){const o=n.chainId,a=n.event.data,c=sr(o),l=La(o)!==La(a)?`${c}:${La(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=ro(xr({},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",ro(xr({},$e("USER_DISCONNECTED")),{data:e.topic})))}),this.on(gl.DEFAULT_CHAIN_CHANGED,e=>{this.onChainChanged(ro(xr({},e),{internal:!0}))})}getProvider(e){return this.rpcProviders[e]||this.rpcProviders[uf]}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=no(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=>sr(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=sr(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(Nd);if(!ks(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.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(`${to}/${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(`${to}/${e}${n}`)}async deleteFromStore(e){var s;const n=((s=this.session)==null?void 0:s.topic)||"";await this.client.core.storage.removeItem(`${to}/${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(to)&&await this.client.core.storage.removeItem(n)}catch(s){this.logger.warn(s,"Failed to cleanup storage")}}};const Es={EIP155:U.CHAIN.EVM,CONNECTOR_TYPE_WALLET_CONNECT:"WALLET_CONNECT",CONNECTOR_TYPE_INJECTED:"INJECTED",CONNECTOR_TYPE_ANNOUNCED:"ANNOUNCED",CONNECTOR_TYPE_AUTH:"AUTH"},NS={NetworkImageIds:{1:"ba0ba0cd-17c6-4806-ad93-f9d174f17900",42161:"3bff954d-5cb0-47a0-9a23-d20192e74600",43114:"30c46e53-e989-45fb-4549-be3bd4eb3b00",56:"93564157-2e8e-4ce7-81df-b264dbee9b00",250:"06b26297-fe0c-4733-5d6b-ffa5498aac00",10:"ab9c186a-c52f-464b-2906-ca59d760a400",137:"41d04d42-da3b-4453-8506-668cc0727900",5e3:"e86fae9b-b770-4eea-e520-150e12c81100",295:"6a97d510-cac8-4e58-c7ce-e8681b044c00",11155111:"e909ea0a-f92a-4512-c8fc-748044ea6800",84532:"a18a7ecd-e307-4360-4746-283182228e00",1301:"4eeea7ef-0014-4649-5d1d-07271a80f600",130:"2257980a-3463-48c6-cbac-a42d2a956e00",10143:"0a728e83-bacb-46db-7844-948f05434900",100:"02b53f6a-e3d4-479e-1cb4-21178987d100",9001:"f926ff41-260d-4028-635e-91913fc28e00",324:"b310f07f-4ef7-49f3-7073-2a0a39685800",314:"5a73b3dd-af74-424e-cae0-0de859ee9400",4689:"34e68754-e536-40da-c153-6ef2e7188a00",1088:"3897a66d-40b9-4833-162f-a2c90531c900",1284:"161038da-44ae-4ec7-1208-0ea569454b00",1285:"f1d73bb6-5450-4e18-38f7-fb6484264a00",7777777:"845c60df-d429-4991-e687-91ae45791600",42220:"ab781bbc-ccc6-418d-d32d-789b15da1f00",8453:"7289c336-3981-4081-c5f4-efc26ac64a00",1313161554:"3ff73439-a619-4894-9262-4470c773a100",2020:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",2021:"b8101fc0-9c19-4b6f-ec65-f6dfff106e00",80094:"e329c2c9-59b0-4a02-83e4-212ff3779900",2741:"fc2427d1-5af9-4a9c-8da5-6f94627cd900","5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp":"a1b58899-f671-4276-6a5e-56ca5bd59700","4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z":"a1b58899-f671-4276-6a5e-56ca5bd59700",EtWTRABZaYq6iMfeYKouRu166VU2xqa1:"a1b58899-f671-4276-6a5e-56ca5bd59700","000000000019d6689c085ae165831e93":"0b4838db-0161-4ffe-022d-532bf03dba00","000000000933ea01ad0ee984209779ba":"39354064-d79b-420b-065d-f980c4b78200","00000008819873e925422c1ff0f99f7c":"b3406e4a-bbfc-44fb-e3a6-89673c78b700"}},Ai={getCaipTokens(t){if(!t)return;const e={};return Object.entries(t).forEach(([s,n])=>{e[`${Es.EIP155}:${s}`]=n}),e},isLowerCaseMatch(t,e){return(t==null?void 0:t.toLowerCase())===(e==null?void 0:e.toLowerCase())},getActiveNamespaceConnectedToAuth(){const t=m.state.activeChain;return U.AUTH_CONNECTOR_SUPPORTED_CHAINS.find(e=>L.getConnectorId(e)===U.CONNECTOR_ID.AUTH&&e===t)},withRetry({conditionFn:t,intervalMs:e,maxRetries:s}){let n=0;return new Promise(r=>{async function i(){return n+=1,await t()?r(!0):n>=s?r(!1):(setTimeout(i,e),null)}i()})},userChainIdToChainNamespace(t){if(typeof t=="number")return U.CHAIN.EVM;const[e]=t.split(":");return e},getOtherAuthNamespaces(t){return t?U.AUTH_CONNECTOR_SUPPORTED_CHAINS.filter(n=>n!==t):[]},getConnectorStorageInfo(t,e){const n=P.getConnections()[e]??[];return{hasDisconnected:P.isConnectorDisconnected(t,e),hasConnected:n.some(r=>Ai.isLowerCaseMatch(r.connectorId,t))}}},TS=new AbortController,Dt={EmbeddedWalletAbortController:TS,UniversalProviderErrors:{UNAUTHORIZED_DOMAIN_NOT_ALLOWED:{message:"Unauthorized: origin not allowed",alertErrorKey:"ORIGIN_NOT_ALLOWED"},JWT_VALIDATION_ERROR:{message:"JWT validation error: JWT Token is not yet valid",alertErrorKey:"JWT_TOKEN_NOT_VALID"},INVALID_KEY:{message:"Unauthorized: invalid key",alertErrorKey:"INVALID_PROJECT_ID"}},ALERT_ERRORS:{SWITCH_NETWORK_NOT_FOUND:{code:"APKT001",displayMessage:"Network Not Found",debugMessage:"The specified network is not recognized. Please ensure it is included in the `networks` array of your `createAppKit` configuration."},ORIGIN_NOT_ALLOWED:{code:"APKT002",displayMessage:"Invalid App Configuration",debugMessage:()=>`The origin ${Ur()?window.origin:"unknown"} is not in your allow list. Please update your allowed domains at https://dashboard.reown.com. [PID: ${_.state.projectId}]`},IFRAME_LOAD_FAILED:{code:"APKT003",displayMessage:"Network Error: Wallet Load Failed",debugMessage:()=>"Failed to load the embedded wallet. This may be due to network issues or server downtime. Please check your network connection and try again shortly. Contact support if the issue persists."},IFRAME_REQUEST_TIMEOUT:{code:"APKT004",displayMessage:"Wallet Request Timeout",debugMessage:()=>"The request to the embedded wallet timed out. Please check your network connection and try again shortly. Contact support if the issue persists."},UNVERIFIED_DOMAIN:{code:"APKT005",displayMessage:"Unverified Domain",debugMessage:()=>"Embedded wallet load failed. Ensure your domain is verified in https://dashboard.reown.com."},JWT_TOKEN_NOT_VALID:{code:"APKT006",displayMessage:"Session Expired",debugMessage:"Your session is invalid or expired. Please check your system’s date and time settings, then reconnect."},INVALID_PROJECT_ID:{code:"APKT007",displayMessage:"Invalid Project ID",debugMessage:"The specified project ID is invalid. Please visit https://dashboard.reown.com to obtain a valid project ID."},PROJECT_ID_NOT_CONFIGURED:{code:"APKT008",displayMessage:"Project ID Missing",debugMessage:"No project ID is configured. You can create and configure a project ID at https://dashboard.reown.com."},SERVER_ERROR_APP_CONFIGURATION:{code:"APKT009",displayMessage:"Server Error",debugMessage:t=>`Unable to fetch App Configuration. ${t}. Please check your network connection and try again shortly. Contact support if the issue persists.`},RATE_LIMITED_APP_CONFIGURATION:{code:"APKT010",displayMessage:"Rate Limited",debugMessage:"You have been rate limited while retrieving App Configuration. Please wait a few minutes and try again. Contact support if the issue persists."}},ALERT_WARNINGS:{LOCAL_CONFIGURATION_IGNORED:{debugMessage:t=>`[Reown Config Notice] ${t}`},INACTIVE_NAMESPACE_NOT_CONNECTED:{code:"APKTW001",displayMessage:"Inactive Namespace Not Connected",debugMessage:(t,e)=>`An error occurred while connecting an inactive namespace ${t}: "${e}"`},INVALID_EMAIL:{code:"APKTW002",displayMessage:"Invalid Email Address",debugMessage:"Please enter a valid email address"}}},gf={TOKEN_ADDRESSES_BY_SYMBOL:{USDC:{8453:ay.asset,84532:cy.asset}},getTokenSymbolByAddress(t){if(!t)return;const[e]=Object.entries(gf.TOKEN_ADDRESSES_BY_SYMBOL).find(([s,n])=>Object.values(n).includes(t))??[];return e}},OS={level:"info"},yl=1e3*1024;var PS=Object.defineProperty,kS=(t,e,s)=>e in t?PS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Js=(t,e,s)=>kS(t,typeof e!="symbol"?e+"":e,s);let RS=class{constructor(e){Js(this,"nodeValue"),Js(this,"sizeInBytes"),Js(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}},Md=class{constructor(e){Js(this,"lengthInNodes"),Js(this,"sizeInBytes"),Js(this,"head"),Js(this,"tail"),Js(this,"maxSizeInBytes"),this.head=null,this.tail=null,this.lengthInNodes=0,this.maxSizeInBytes=e,this.sizeInBytes=0}append(e){const s=new RS(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 xS=Object.defineProperty,$S=(t,e,s)=>e in t?xS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,io=(t,e,s)=>$S(t,typeof e!="symbol"?e+"":e,s);let mf=class{constructor(e,s=yl){io(this,"logs"),io(this,"level"),io(this,"levelValue"),io(this,"MAX_LOG_SIZE_IN_BYTES"),this.level=e??"error",this.levelValue=Qt.levels.values[this.level],this.MAX_LOG_SIZE_IN_BYTES=s,this.logs=new Md(this.MAX_LOG_SIZE_IN_BYTES)}forwardToConsole(e,s){s===Qt.levels.values.error?console.error(e):s===Qt.levels.values.warn?console.warn(e):s===Qt.levels.values.debug?console.debug(e):s===Qt.levels.values.trace?console.trace(e):console.log(e)}appendToLogs(e){this.logs.append(Rn({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 Md(this.MAX_LOG_SIZE_IN_BYTES)}getLogArray(){return Array.from(this.logs)}logsToBlob(e){const s=this.getLogArray();return s.push(Rn({extraMetadata:e})),new Blob(s,{type:"application/json"})}};var US=Object.defineProperty,DS=(t,e,s)=>e in t?US(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,LS=(t,e,s)=>DS(t,e+"",s);let MS=class{constructor(e,s=yl){LS(this,"baseChunkLogger"),this.baseChunkLogger=new mf(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 BS=Object.defineProperty,jS=(t,e,s)=>e in t?BS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,FS=(t,e,s)=>jS(t,e+"",s);let qS=class{constructor(e,s=yl){FS(this,"baseChunkLogger"),this.baseChunkLogger=new mf(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 WS=Object.defineProperty,HS=Object.defineProperties,KS=Object.getOwnPropertyDescriptors,Bd=Object.getOwnPropertySymbols,zS=Object.prototype.hasOwnProperty,VS=Object.prototype.propertyIsEnumerable,jd=(t,e,s)=>e in t?WS(t,e,{enumerable:!0,configurable:!0,writable:!0,value:s}):t[e]=s,Lo=(t,e)=>{for(var s in e||(e={}))zS.call(e,s)&&jd(t,s,e[s]);if(Bd)for(var s of Bd(e))VS.call(e,s)&&jd(t,s,e[s]);return t},Mo=(t,e)=>HS(t,KS(e));function GS(t){return Mo(Lo({},t),{level:(t==null?void 0:t.level)||OS.level})}function YS(t){var e,s;const n=new MS((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(Mo(Lo({},t.opts),{level:"trace",browser:Mo(Lo({},(s=t.opts)==null?void 0:s.browser),{write:r=>n.write(r)})})),chunkLoggerController:n}}function JS(t){var e;const s=new qS((e=t.opts)==null?void 0:e.level,t.maxSizeInBytes);return{logger:zo(Mo(Lo({},t.opts),{level:"trace"}),s),chunkLoggerController:s}}function XS(t){return typeof t.loggerOverride<"u"&&typeof t.loggerOverride!="string"?{logger:t.loggerOverride,chunkLoggerController:null}:typeof window<"u"?YS(t):JS(t)}const ZS={createLogger(t,e="error"){const s=GS({level:e}),{logger:n}=XS({opts:s});return n.error=(...r)=>{for(const i of r)if(i instanceof Error){t(i,...r);return}t(void 0,...r)},n}},QS="rpc.walletconnect.org";function Fd(t,e){const s=new URL("https://rpc.walletconnect.org/v1/");return s.searchParams.set("chainId",t),s.searchParams.set("projectId",e),s.toString()}const Wa=["near:mainnet","solana:5eykt4UsFv8P8NJdTREpY1vzqKqZKvdp","eip155:1101","eip155:56","eip155:42161","eip155:7777777","eip155:59144","eip155:324","solana:EtWTRABZaYq6iMfeYKouRu166VU2xqa1","eip155:5000","solana:4sgjmw1sunhzsxgspuhpqldx6wiyjntz","eip155:80084","eip155:5003","eip155:100","eip155:8453","eip155:42220","eip155:1313161555","eip155:17000","eip155:1","eip155:300","eip155:1313161554","eip155:1329","eip155:84532","eip155:421614","eip155:11155111","eip155:8217","eip155:43114","solana:4uhcVJyU9pJkvQyS88uRDiswHXSCkY3z","eip155:999999999","eip155:11155420","eip155:80002","eip155:97","eip155:43113","eip155:137","eip155:10","eip155:1301","eip155:80094","eip155:80069","eip155:560048","eip155:31","eip155:2818","eip155:57054","eip155:911867","eip155:534351","eip155:1112","eip155:534352","eip155:1111","eip155:146","eip155:130","eip155:1284","eip155:30","eip155:2810","bip122:000000000019d6689c085ae165831e93","bip122:000000000933ea01ad0ee984209779ba"],Zn={extendRpcUrlWithProjectId(t,e){let s=!1;try{s=new URL(t).host===QS}catch{s=!1}if(s){const n=new URL(t);return n.searchParams.has("projectId")||n.searchParams.set("projectId",e),n.toString()}return t},isCaipNetwork(t){return"chainNamespace"in t&&"caipNetworkId"in t},getChainNamespace(t){return this.isCaipNetwork(t)?t.chainNamespace:U.CHAIN.EVM},getCaipNetworkId(t){return this.isCaipNetwork(t)?t.caipNetworkId:`${U.CHAIN.EVM}:${t.id}`},getDefaultRpcUrl(t,e,s){var r,i,o;const n=(o=(i=(r=t.rpcUrls)==null?void 0:r.default)==null?void 0:i.http)==null?void 0:o[0];return Wa.includes(e)?Fd(e,s):n||""},extendCaipNetwork(t,{customNetworkImageUrls:e,projectId:s,customRpcUrls:n}){var h,p,g,f,y,w,b;const r=this.getChainNamespace(t),i=this.getCaipNetworkId(t),o=(g=(p=(h=t.rpcUrls)==null?void 0:h.default)==null?void 0:p.http)==null?void 0:g[0],a=this.getDefaultRpcUrl(t,i,s),c=((w=(y=(f=t==null?void 0:t.rpcUrls)==null?void 0:f.chainDefault)==null?void 0:y.http)==null?void 0:w[0])||o,l=((b=n==null?void 0:n[i])==null?void 0:b.map(E=>E.url))||[],u=[...l,...a?[a]:[]],d=[...l];return c&&!d.includes(c)&&d.push(c),{...t,chainNamespace:r,caipNetworkId:i,assets:{imageId:NS.NetworkImageIds[t.id],imageUrl:e==null?void 0:e[t.id]},rpcUrls:{...t.rpcUrls,default:{http:u},chainDefault:{http:d}}}},extendCaipNetworks(t,{customNetworkImageUrls:e,projectId:s,customRpcUrls:n}){return t.map(r=>Zn.extendCaipNetwork(r,{customNetworkImageUrls:e,customRpcUrls:n,projectId:s}))},getViemTransport(t,e,s){var r,i,o;const n=[];return s==null||s.forEach(a=>{n.push(Wi(a.url,a.config))}),Wa.includes(t.caipNetworkId)&&n.push(Wi(Fd(t.caipNetworkId,e),{fetchOptions:{headers:{"Content-Type":"text/plain"}}})),(o=(i=(r=t==null?void 0:t.rpcUrls)==null?void 0:r.default)==null?void 0:i.http)==null||o.forEach(a=>{n.push(Wi(a))}),xl(n)},extendWagmiTransports(t,e,s){if(Wa.includes(t.caipNetworkId)){const n=this.getDefaultRpcUrl(t,t.caipNetworkId,e);return xl([s,Wi(n)])}return s},getUnsupportedNetwork(t){return{id:t.split(":")[1],caipNetworkId:t,name:U.UNSUPPORTED_NETWORK_NAME,chainNamespace:t.split(":")[0],nativeCurrency:{name:"",decimals:0,symbol:""},rpcUrls:{default:{http:[]}}}},getCaipNetworkFromStorage(t){var c;const e=P.getActiveCaipNetworkId(),s=m.getAllRequestedCaipNetworks(),n=Array.from(((c=m.state.chains)==null?void 0:c.keys())||[]),r=e==null?void 0:e.split(":")[0],i=r?n.includes(r):!1,o=s==null?void 0:s.find(l=>l.caipNetworkId===e);return i&&!o&&e?this.getUnsupportedNetwork(e):o||t||(s==null?void 0:s[0])}},eN={ACCOUNT_TABS:[{label:"Tokens"},{label:"Activity"}],VIEW_DIRECTION:{Next:"next",Prev:"prev"},DEFAULT_CONNECT_METHOD_ORDER:["email","social","wallet"],ANIMATION_DURATIONS:{HeaderText:120},VIEWS_WITH_LEGAL_FOOTER:["Connect","ConnectWallets","OnRampTokenSelect","OnRampFiatSelect","OnRampProviders"],VIEWS_WITH_DEFAULT_FOOTER:["Networks"]},Br={filterOutDuplicatesByRDNS(t){const e=_.state.enableEIP6963?L.state.connectors:[],s=P.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")&&V.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=L.state.connectors.filter(a=>a.type==="ANNOUNCED"||a.type==="INJECTED"),s=P.getRecentWallets(),n=e.map(a=>a.explorerId),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}=L.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),u=s.indexOf(a.id);if(l!==-1&&u!==-1)return l-u;if(l!==-1)return-1;if(u!==-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||L.state.connectors;if(s)return s;const{injected:r,announced:i}=Ha.getConnectorsByType(n,J.state.recommended,J.state.featured),o=r.filter(Ha.showConnector),a=i.filter(Ha.showConnector);return o.length||a.length?["wallet","email","social"]:eN.DEFAULT_CONNECT_METHOD_ORDER},isExcluded(t){const e=!!t.rdns&&J.state.excludedWallets.some(n=>n.rdns===t.rdns),s=!!t.name&&J.state.excludedWallets.some(n=>Ai.isLowerCaseMatch(n.name,t.name));return e||s},markWalletsWithDisplayIndex(t){return t.map((e,s)=>({...e,display_index:s}))}},Ha={getConnectorsByType(t,e,s){const{customWallets:n}=_.state,r=P.getRecentWallets(),i=Br.filterOutDuplicateWallets(e),o=Br.filterOutDuplicateWallets(s),a=t.filter(d=>d.type==="MULTI_CHAIN"),c=t.filter(d=>d.type==="ANNOUNCED"),l=t.filter(d=>d.type==="INJECTED"),u=t.filter(d=>d.type==="EXTERNAL");return{custom:n,recent:r,external:u,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&&J.state.excludedWallets.some(i=>!!i.rdns&&i.rdns===e),n=!!t.name&&J.state.excludedWallets.some(i=>Ai.isLowerCaseMatch(i.name,t.name));return!(t.type==="INJECTED"&&(t.name==="Browser Wallet"&&(!V.isMobile()||V.isMobile()&&!e&&!j.checkInstalled())||s||n)||(t.type==="ANNOUNCED"||t.type==="EXTERNAL")&&(s||n))},getIsConnectedWithWC(){return Array.from(m.state.chains.values()).some(s=>L.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 d=[{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(d.map(f=>f.type)),p=c.filter(f=>h.has(f)).map(f=>({type:f,isEnabled:!0})),g=d.filter(({type:f})=>!p.some(({type:w})=>w===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"&&!V.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=P.getRecentWallets(),s=L.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")&&V.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 L.state.connectors.some(e=>e.id===t.id||e.name===t.name)},isWalletCompatibleWithCurrentChain(t){const e=m.state.activeChain;return e&&t.chains?t.chains.some(s=>{const n=s.split(":")[0];return e===n}):!0},getFilteredRecentWallets(){return P.getRecentWallets().filter(s=>!Br.isExcluded(s)).filter(s=>!this.hasWalletConnector(s)).filter(s=>this.isWalletCompatibleWithCurrentChain(s))},getCappedRecommendedWallets(t){const{connectors:e}=L.state,{customWallets:s,featuredWalletIds:n}=_.state,r=e.find(b=>b.id==="walletConnect"),i=e.filter(b=>b.type==="INJECTED"||b.type==="ANNOUNCED"||b.type==="MULTI_CHAIN");if(!r&&!i.length&&!(s!=null&&s.length))return[];const o=Qa.isEmailEnabled(),a=Qa.isSocialsEnabled(),c=i.filter(b=>b.name!=="Browser Wallet"),l=(n==null?void 0:n.length)||0,u=(s==null?void 0:s.length)||0,d=c.length||0,h=o?1:0,p=a?1:0,g=l+u+d+h+p,y=Math.max(0,4-g);return y<=0?[]:Br.filterOutDuplicateWallets(t).slice(0,y)}};/**
|
|
20
20
|
* @license
|
|
21
21
|
* Copyright 2019 Google LLC
|
|
22
22
|
* SPDX-License-Identifier: BSD-3-Clause
|
|
@@ -230,4 +230,4 @@ ${t.length}`,s=new TextEncoder().encode(e+t);return"0x"+Buffer.from(vb(s)).toStr
|
|
|
230
230
|
outline: none;
|
|
231
231
|
appearance: none;
|
|
232
232
|
}
|
|
233
|
-
`,oo={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603};class ON extends ny{async setUniversalProvider(e){if(!this.namespace)throw new Error("UniversalAdapter:setUniversalProvider - namespace is required");return this.addConnector(new ry({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,u)=>u.indexOf(c)===l))||[];return Promise.resolve({accounts:n.map(c=>V.createAccount(e,c,e==="bip122"?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){var o,a,c,l,u;if(!(e.caipNetwork&&ye.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=m.getAccountData();if(n!=null&&n.balanceLoading&&e.chainId===((l=m.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 m.fetchTokenBalance()).find(d=>{var h,p;return d.chainId===`${(h=e.caipNetwork)==null?void 0:h.chainNamespace}:${e.chainId}`&&d.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)||((u=e.caipNetwork)==null?void 0:u.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=m.state.activeCaipNetwork)==null?void 0:o.chainNamespace)===U.CHAIN.SOLANA?i=(await s.request({method:"solana_signMessage",params:{message:br.encode(new TextEncoder().encode(n)),pubkey:r}},(a=m.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)).signature:i=await s.request({method:"personal_sign",params:[n,r]},(c=m.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:Pl(s.id)}]}))}catch(u){if(u.code===oo.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||u.code===oo.ERROR_INVALID_CHAIN_ID||u.code===oo.ERROR_CODE_DEFAULT||((o=(i=u==null?void 0:u.data)==null?void 0:i.originalError)==null?void 0:o.code)===oo.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await((l=n.provider)==null?void 0:l.request({method:"wallet_addEthereumChain",params:[{chainId:Pl(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 PN=["email","socials","swaps","onramp","activity","reownBranding","multiWallet","emailCapture","payWithExchange","payments","reownAuthentication"],ao={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?ye.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?ye.DEFAULT_REMOTE_FEATURES.socials:typeof t=="boolean"?t?ye.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?ye.DEFAULT_REMOTE_FEATURES.swaps:typeof t=="boolean"?t?ye.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?ye.DEFAULT_REMOTE_FEATURES.onramp:typeof t=="boolean"?t?ye.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?ye.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?ye.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:()=>ye.DEFAULT_REMOTE_FEATURES.multiWallet},payWithExchange:{apiFeatureName:"fund_from_exchange",localFeatureName:"payWithExchange",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>ye.DEFAULT_REMOTE_FEATURES.payWithExchange},payments:{apiFeatureName:"payments",localFeatureName:"payments",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>ye.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"?ye.DEFAULT_REMOTE_FEATURES.reownAuthentication:!!t}},kN={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=ao[e],n=s.isLegacy?`"features.${s.localFeatureName}" (now "${e}")`:`"features.${e}"`;this.localSettingsOverridden.add(n)}},processFeature(t,e,s,n,r){const i=ao[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 ao[t].processApi(e)},processFallbackFeature(t,e){return ao[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 J.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?ye.DEFAULT_REMOTE_FEATURES:ye.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(const o of PN){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),ye.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.`;It.open({debugMessage:Dt.ALERT_WARNINGS.LOCAL_CONFIGURATION_IGNORED.debugMessage(o)},"warning")}return i}};class RN{constructor(e){this.chainNamespaces=[],this.features={},this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(s,n)=>{var r,i,o;if(s){const a=(r=m.getCaipNetworks(s))==null?void 0:r.find(u=>u.id===n);if(a)return a;const c=(i=m.getNetworkData(s))==null?void 0:i.caipNetwork;return c||((o=m.getRequestedCaipNetworks(s).filter(u=>u.chainNamespace===s))==null?void 0:o[0])}return m.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{const s=this.getCaipNetwork();if(s)return s.id},this.getCaipNetworks=s=>m.getCaipNetworks(s),this.getActiveChainNamespace=()=>m.state.activeChain,this.setRequestedCaipNetworks=(s,n)=>{m.setRequestedCaipNetworks(s,n)},this.getApprovedCaipNetworkIds=()=>m.getAllApprovedCaipNetworkIds(),this.getCaipAddress=s=>{var n,r;return m.state.activeChain===s||!s?m.state.activeCaipAddress:(r=(n=m.state.chains.get(s))==null?void 0:n.accountState)==null?void 0:r.caipAddress},this.setClientId=s=>{te.setClientId(s)},this.getProvider=s=>xe.getProvider(s),this.getProviderType=s=>xe.getProviderId(s),this.getPreferredAccountType=s=>qt(s),this.setCaipAddress=(s,n,r=!1)=>{m.setAccountProp("caipAddress",s,n,r),m.setAccountProp("address",V.getPlainAddress(s),n,r)},this.setBalance=(s,n,r)=>{m.setAccountProp("balance",s,r),m.setAccountProp("balanceSymbol",n,r)},this.setProfileName=(s,n)=>{m.setAccountProp("profileName",s,n)},this.setProfileImage=(s,n)=>{m.setAccountProp("profileImage",s,n)},this.setUser=(s,n)=>{m.setAccountProp("user",s,n)},this.resetAccount=s=>{m.resetAccount(s)},this.setCaipNetwork=s=>{m.setActiveCaipNetwork(s)},this.setCaipNetworkOfNamespace=(s,n)=>{m.setChainNetworkData(n,{caipNetwork:s})},this.setStatus=(s,n)=>{m.setAccountProp("status",s,n),L.isConnected()?P.setConnectionStatus("connected"):P.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=s=>{var n;return(n=m.getAccountData(s))==null?void 0:n.address},this.setConnectors=s=>{const n=[...L.state.allConnectors,...s];L.setConnectors(n)},this.setConnections=(s,n)=>{P.setConnections(s,n),j.setConnections(s,n)},this.fetchIdentity=s=>te.fetchIdentity(s),this.getReownName=s=>Wr.getNamesForAddress(s),this.getConnectors=()=>L.getConnectors(),this.getConnectorImage=s=>Eh.getConnectorImage(s),this.getConnections=s=>this.remoteFeatures.multiWallet?_o.getConnectionsData(s).connections:(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.getRecentConnections=s=>this.remoteFeatures.multiWallet?_o.getConnectionsData(s).recentConnections:(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.switchConnection=async s=>{if(!this.remoteFeatures.multiWallet){It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}await j.switchConnection(s)},this.deleteConnection=s=>{if(!this.remoteFeatures.multiWallet){It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}P.deleteAddressFromConnection(s),j.syncStorageConnections()},this.setConnectedWalletInfo=(s,n)=>{const r=xe.getProviderId(n),i=s?{...s,type:r}:void 0;m.setAccountProp("connectedWalletInfo",i,n)},this.getIsConnectedState=()=>!!m.state.activeCaipAddress,this.addAddressLabel=(s,n,r)=>{var o;const i=((o=m.getAccountData(r))==null?void 0:o.addressLabels)||{};m.setAccountProp("addressLabels",{...i,[s]:n},r)},this.removeAddressLabel=(s,n)=>{var i;const r=((i=m.getAccountData(n))==null?void 0:i.addressLabels)||{};m.setAccountProp("addressLabels",{...r,[s]:void 0},n)},this.getAddress=s=>{var r;const n=s||m.state.activeChain;return(r=m.getAccountData(n))==null?void 0:r.address},this.resetNetwork=s=>{m.resetNetwork(s)},this.addConnector=s=>{L.addConnector(s)},this.resetWcConnection=()=>{j.resetWcConnection()},this.setAddressExplorerUrl=(s,n)=>{m.setAccountProp("addressExplorerUrl",s,n)},this.setSmartAccountDeployed=(s,n)=>{m.setAccountProp("smartAccountDeployed",s,n)},this.setPreferredAccountType=(s,n)=>{m.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;if(this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),_.state.enableReconnect?(await this.syncExistingConnection(),await this.syncAdapterConnections()):await this.unSyncExistingConnection(),this.remoteFeatures=await kN.fetchRemoteFeatures(e),await J.fetchUsage(),_.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&nc.setOnrampProviders(this.remoteFeatures.onramp),((s=_.state.remoteFeatures)!=null&&s.email||Array.isArray((n=_.state.remoteFeatures)==null?void 0:n.socials)&&((r=_.state.remoteFeatures)==null?void 0:r.socials.length)>0)&&await this.checkAllowedOrigins(),(i=_.state.features)!=null&&i.reownAuthentication||(o=_.state.remoteFeatures)!=null&&o.reownAuthentication){const{ReownAuthentication:a}=await vo(async()=>{const{ReownAuthentication:l}=await import("./features-CHnlaMRZ.js");return{ReownAuthentication:l}},__vite__mapDeps([3,1,2])),c=_.state.siwx;c instanceof a||(c&&console.warn("ReownAuthentication option is enabled, SIWX configuration will be overridden."),_.setSIWX(new a))}}async openSend(e){var i;const s=e.namespace||m.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=m.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=gf.getTokenSymbolByAddress(e.assetAddress);o&&await J.fetchTokenImages([o])}catch{}return await de.open({view:"WalletSend",data:{send:e}}),new Promise((o,a)=>{const c=oe.subscribeKey("hash",d=>{d&&(u(),o({hash:d}))}),l=de.subscribe(d=>{d.open||(u(),a(new Error("Modal closed")))}),u=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 J.fetchAllowedOrigins();if(!V.isClient())return;const s=window.location.origin;en.isOriginAllowed(s,e,U.DEFAULT_ALLOWED_ANCESTORS)||It.open(Dt.ALERT_ERRORS.ORIGIN_NOT_ALLOWED,"error")}catch(e){if(!(e instanceof Error))return;switch(e.message){case"RATE_LIMITED":It.open(Dt.ALERT_ERRORS.RATE_LIMITED_APP_CONFIGURATION,"error");break;case"SERVER_ERROR":{const s=e.cause instanceof Error?e.cause:e;It.open({displayMessage:Dt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.displayMessage,debugMessage:Dt.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,ae.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(){Ih.initialize(this.chainAdapters)}initializeThemeController(e){e.themeMode&&St.setThemeMode(e.themeMode),e.themeVariables&&St.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient)throw new Error("ConnectionControllerClient must be set");m.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient});const s=this.getDefaultNetwork();s&&m.setActiveCaipNetwork(s)}initializeConnectionController(e){j.initialize(e.adapters??[]),j.setWcBasic(e.basic??!1)}initializeConnectorController(){L.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){It.open(Dt.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 V.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=Zn.getUnsupportedNetwork(`${s}:${e}`);m.setActiveCaipNetwork(n)}}getDefaultNetwork(){return Zn.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,s){return Zn.extendCaipNetwork(e,{customNetworkImageUrls:s.chainImages,projectId:s.projectId})}extendCaipNetworks(e){return Zn.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?Zn.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=m.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=m.state.activeChain,s=this.getAdapter(e),n=(l=this.getCaipNetwork(e))==null?void 0:l.id,r=j.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),P.setConnectedNamespaces([...m.state.chains.keys()]),await this.syncWalletConnectAccount(),await Zt.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=m.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})),P.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||m.state.activeChain,o=L.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 u=Array.from(m.state.chains.keys());let d=n?[n]:u;(c||a)&&(d=u);const h=d.map(async f=>{const y=L.getConnectorId(f),w=s||y,b=await this.disconnectConnector(f,w);b&&(a&&P.deleteConnectedSocialProvider(),b.connections.forEach(E=>{P.addDisconnectedConnectorId(E.connectorId,f)})),r&&this.onDisconnectNamespace({chainNamespace:f,closeModal:!1})}),p=await Promise.allSettled(h);oe.resetSend(),j.resetWcConnection(),(l=Zt.getSIWX())!=null&&l.signOutOnDisconnect&&await Zt.clearSessions(),L.setFilterByNamespace(void 0),j.syncStorageConnections();const g=p.filter(f=>f.status==="rejected");if(g.length>0)throw new Error(g.map(f=>f.reason.message).join(", "));ae.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:n||"all"}})}catch(u){throw new Error(`Failed to disconnect chains: ${u.message}`)}},checkInstalled:e=>e?e.some(s=>{var n;return!!((n=window.ethereum)!=null&&n[String(s)])}):!!window.ethereum,signMessage:async e=>{const s=m.state.activeChain,n=this.getAdapter(m.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:xe.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(ye.SEND_SUPPORTED_NAMESPACES.includes(s)){const n=this.getAdapter(s);if(!n)throw new Error("sendTransaction: adapter not found");const r=xe.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=xe.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=m.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=m.getAccountData();return(n==null?void 0:n.profileImage)||!1},getEnsAddress:async e=>await en.resolveReownName(e),writeContract:async e=>{const s=m.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=xe.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(m.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(m.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(m.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(m.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(m.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(m.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)}},j.setClient(this.connectionControllerClient)}async onConnectExternal(e){var l,u,d,h,p,g,f,y;const s=m.state.activeChain,n=e.chain||s,r=this.getAdapter(n);let i=!0;if(e.type===Es.CONNECTOR_TYPE_AUTH&&U.AUTH_CONNECTOR_SUPPORTED_CHAINS.some(E=>L.getConnectorId(E)===U.CONNECTOR_ID.AUTH)&&e.chain!==s&&(i=!1),e.chain&&e.chain!==s&&!e.caipNetwork){const w=this.getCaipNetworks().find(b=>b.chainNamespace===e.chain);w&&i&&this.setCaipNetwork(w)}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=(d=(u=e.caipNetwork)==null?void 0:u.rpcUrls)==null?void 0:d.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 P.addConnectedNamespace(n),this.syncProvider({...c,chainNamespace:n}),this.setStatus("connected",n),this.syncConnectedWalletInfo(n),P.removeDisconnectedConnectorId(e.id,n),{address:c.address,connectedCaipNetwork:a}}async connectInactiveNamespaces(e,s){var a;const n=e.type===Es.CONNECTOR_TYPE_AUTH,r=Ai.getOtherAuthNamespaces((a=s==null?void 0:s.connectedCaipNetwork)==null?void 0:a.chainNamespace),i=m.state.activeCaipNetwork,o=this.getAdapter(i==null?void 0:i.chainNamespace);n&&(await Promise.all(r.map(async c=>{var l,u,d;try{const h=xe.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:(d=(u=(l=p==null?void 0:p.rpcUrls)==null?void 0:l.default)==null?void 0:u.http)==null?void 0:d[0]}))&&(P.addConnectedNamespace(c),P.removeDisconnectedConnectorId(e.id,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c))}catch(h){It.warn(Dt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.displayMessage,Dt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.debugMessage(c,h instanceof Error?h.message:void 0),Dt.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(xe.getProviderId(m.state.activeChain)===Es.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=xe.getProviderId(s);if(e.chainNamespace===m.state.activeChain){const i=this.getAdapter(s);await(i==null?void 0:i.switchNetwork({caipNetwork:e}))}else if(this.setCaipNetwork(e),r===Es.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}=Xe.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 ON({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=P.getConnectionStatus();_.state.enableReconnect===!1?this.setStatus("disconnected",e):n==="connected"?this.setStatus("connecting",e):n==="disconnected"?(P.clearAddressCache(),this.setStatus(n,e)):this.setStatus(n,e),s.on("switchNetwork",({address:r,chainId:i})=>{var l,u;const o=this.getCaipNetworks().find(d=>d.id.toString()===i.toString()||d.caipNetworkId.toString()===i.toString()),a=m.state.activeChain===e,c=(u=(l=m.state.chains.get(e))==null?void 0:l.accountState)==null?void 0:u.address;if(o){const d=a&&r?r:c;d&&this.syncAccount({address:d,chainId:o.id,chainNamespace:e})}else this.setUnsupportedNetwork(i)}),s.on("disconnect",()=>{const r=this.remoteFeatures.multiWallet,i=Array.from(j.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=m.state.activeCaipNetwork;!r||!(i!=null&&i.id)||this.updateNativeBalance(r,i.id,i.chainNamespace)}),s.on("accountChanged",({address:r,chainId:i,connector:o})=>{var u,d;this.handlePreviousConnectorConnection(o);const a=m.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=(d=(u=m.getNetworkData(e))==null?void 0:u.caipNetwork)==null?void 0:d.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),P.addConnectedNamespace(e)})}async handlePreviousConnectorConnection(e){var c;const s=e==null?void 0:e.chain,n=e==null?void 0:e.id,r=L.getConnectorId(s),i=(c=_.state.remoteFeatures)==null?void 0:c.multiWallet,a=s&&n&&r&&r!==n&&!i;try{a&&await j.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=>j.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()||P.deleteRecentWallet();const s=P.getRecentWallet();ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:e,properties:{method:V.isMobile()?"mobile":"qrcode",name:(s==null?void 0:s.name)||"Unknown",reconnect:!0,view:ee.state.view,walletRank:s==null?void 0:s.order}})}async syncNamespaceConnection(e){try{e===U.CHAIN.EVM&&V.isSafeApp()&&L.setConnectorId(U.CONNECTOR_ID.SAFE,e);const s=L.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||{};m.resetAccount(s),m.resetNetwork(s),P.removeConnectedNamespace(s);const r=Array.from(m.state.chains.keys());(s?[s]:r).forEach(o=>P.addDisconnectedConnectorId(L.getConnectorId(o)||"",o)),L.removeConnectorId(s),xe.resetChain(s),this.setUser(null,s),this.setStatus("disconnected",s),this.setConnectedWalletInfo(null,s),n!==!1&&de.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,u;const s=this.getAdapter(e),n=this.getCaipNetwork(e),r=L.getConnectorId(e),o=L.getConnectors(e).find(d=>d.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 d=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]}));d?(this.syncProvider({...d,chainNamespace:e}),await this.syncAccount({...d,chainNamespace:e}),this.setStatus("connected",e),ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:d.address,properties:{method:"browser",name:((u=o.info)==null?void 0:u.name)||o.name||"Unknown",reconnect:!0,view:ee.state.view,walletRank:void 0}})):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 d,h,p,g,f;const o=this.getAdapter(i);if(!o)return;const a=((g=(p=(h=(d=this.universalProvider)==null?void 0:d.session)==null?void 0:h.namespaces)==null?void 0:p[i])==null?void 0:g.accounts)||[],c=(f=m.state.activeCaipNetwork)==null?void 0:f.id,l=a.find(y=>{const{chainId:w}=Xe.parseCaipAddress(y);return w===(c==null?void 0:c.toString())})||a[0];if(l){const y=Xe.validateCaipAddress(l),{chainId:w,address:b}=Xe.parseCaipAddress(y);if(xe.setProviderId(i,Es.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&m.state.activeCaipNetwork&&o.namespace!==U.CHAIN.EVM){const E=o.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:m.state.activeCaipNetwork});xe.setProvider(i,E)}else xe.setProvider(i,this.universalProvider);L.setConnectorId(U.CONNECTOR_ID.WALLET_CONNECT,i),P.addConnectedNamespace(i),await this.syncAccount({address:b,chainId:w,chainNamespace:i})}else e.includes(i)&&this.setStatus("disconnected",i);const u=this.getApprovedCaipNetworksData();this.syncConnectedWalletInfo(i),m.setApprovedCaipNetworksData(i,{approvedCaipNetworkIds:u.approvedCaipNetworkIds,supportsAllNetworks:u.supportsAllNetworks})});await Promise.all(s)}syncProvider({type:e,provider:s,id:n,chainNamespace:r}){xe.setProviderId(r,e),xe.setProvider(r,s),L.setConnectorId(n,r)}async syncAccount(e){var d,h;const s=e.chainNamespace===m.state.activeChain,n=m.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:r,chainId:i,chainNamespace:o}=e,{chainId:a}=P.getActiveNetworkProps(),c=(n==null?void 0:n.id)||a,l=((d=m.state.activeCaipNetwork)==null?void 0:d.name)===U.UNSUPPORTED_NETWORK_NAME,u=m.getNetworkProp("supportsAllNetworks",o);if(this.setStatus("connected",o),!(l&&!u)&&c){let p=this.getCaipNetworks().find(w=>w.id.toString()===c.toString()),g=this.getCaipNetworks().find(w=>w.chainNamespace===o);if(!u&&!p&&!g){const w=this.getApprovedCaipNetworkIds()||[],b=w.find(N=>{var x;return((x=Xe.parseCaipNetworkId(N))==null?void 0:x.chainId)===c.toString()}),E=w.find(N=>{var x;return((x=Xe.parseCaipNetworkId(N))==null?void 0:x.chainNamespace)===o});p=this.getCaipNetworks().find(N=>N.caipNetworkId===b),g=this.getCaipNetworks().find(N=>N.caipNetworkId===E||"deprecatedCaipNetworkId"in N&&N.deprecatedCaipNetworkId===E)}const f=p||g;(f==null?void 0:f.chainNamespace)===m.state.activeChain?_.state.enableNetworkSwitch&&!_.state.allowUnsupportedChain&&((h=m.state.activeCaipNetwork)==null?void 0:h.name)===U.UNSUPPORTED_NETWORK_NAME?m.showUnsupportedChainUI():this.setCaipNetwork(f):s||n&&this.setCaipNetworkOfNamespace(n,o),this.syncConnectedWalletInfo(o);const y=this.getAddress(o);Ai.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=L.getConnectorId(e),n=xe.getProviderId(e);if(n===Es.CONNECTOR_TYPE_ANNOUNCED||n===Es.CONNECTOR_TYPE_INJECTED){if(s){const o=this.getConnectors().find(a=>{var d,h;const c=a.id===s,l=((d=a.info)==null?void 0:d.rdns)===s,u=(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||!!u});if(o){const{info:a,name:c,imageUrl:l}=o,u=l||this.getConnectorImage(o);this.setConnectedWalletInfo({name:c,icon:u,...a},e)}}}else if(n===Es.CONNECTOR_TYPE_WALLET_CONNECT){const i=xe.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){!rh.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=m.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 n,r,i,o,a,c,l,u,d,h;const e=ZS.createLogger((p,...g)=>{p&&this.handleAlertError(p),console.error(...g)}),s={projectId:(n=this.options)==null?void 0:n.projectId,metadata:{name:(r=this.options)!=null&&r.metadata?(i=this.options)==null?void 0:i.metadata.name:"",description:(o=this.options)!=null&&o.metadata?(a=this.options)==null?void 0:a.metadata.description:"",url:(c=this.options)!=null&&c.metadata?(l=this.options)==null?void 0:l.metadata.url:"",icons:(u=this.options)!=null&&u.metadata?(d=this.options)==null?void 0:d.metadata.icons:[""]},logger:e};_.setManualWCControl(!!((h=this.options)!=null&&h.manualWCControl)),this.universalProvider=this.options.universalProvider??await SS.init(s),_.state.enableReconnect===!1&&this.universalProvider.session&&await this.universalProvider.disconnect(),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&this.chainNamespaces.forEach(e=>{en.listenWcProvider({universalProvider:this.universalProvider,namespace:e,onDisplayUri:s=>{j.setUri(s)},onConnect:s=>{const{address:n}=V.getAccount(s[0]);j.finalizeWcConnection(n)},onDisconnect:()=>{m.state.noAdapters&&this.resetAccount(e),j.resetWcConnection()},onChainChanged:s=>{const n=m.state.activeChain,r=n&&L.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(m.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=m.state.activeChain,r=n&&L.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(m.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&&V.isClient()&&((e=this.options)!=null&&e.projectId)&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){ae.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=m.getAllApprovedCaipNetworkIds(),s=m.getAllRequestedCaipNetworks();return V.sortRequestedNetworks(e,s).filter(r=>m.isCaipNetworkDisabled(r))}handleAlertError(e){const s=Object.entries(Dt.UniversalProviderErrors).find(([,{message:a}])=>e.message.includes(a)),[n,r]=s??[],{message:i,alertErrorKey:o}=r??{};if(n&&i&&!this.reportedAlertErrors[n]){const a=Dt.ALERT_ERRORS[o];a&&(It.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&&j.setUri(e.uri);const{isSwap:s,isSend:n}=this.toModalOptions();return s(e)?de.open({...e,data:{swap:e.arguments}}):n(e)&&e.arguments?this.openSend(e.arguments):de.open(e)}async close(){await this.injectModalUi(),de.close()}setLoading(e,s){de.setLoading(e,s)}async disconnect(e){await j.disconnect({namespace:e})}getSIWX(){return _.state.siwx}getError(){return""}getChainId(){var e;return(e=m.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){It.open(Dt.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await m.switchActiveNetwork(n,{throwOnFailure:s})}getWalletProvider(){return m.state.activeChain?xe.state.providers[m.state.activeChain]:null}getWalletProviderType(){return xe.getProviderId(m.state.activeChain)}subscribeProviders(e){return xe.subscribeProviders(e)}getThemeMode(){return St.state.themeMode}getThemeVariables(){return St.state.themeVariables}setThemeMode(e){St.setThemeMode(e),Bc(St.state.themeMode)}setTermsConditionsUrl(e){_.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){_.setPrivacyPolicyUrl(e)}setThemeVariables(e){St.setThemeVariables(e),TN(St.state.themeVariables)}subscribeTheme(e){return St.subscribe(e)}subscribeConnections(e){return this.remoteFeatures.multiWallet?j.subscribe(e):(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),()=>{})}getWalletInfo(e){var n,r;if(e)return(r=(n=m.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.connectedWalletInfo;const s=m.getAccountData();return s==null?void 0:s.connectedWalletInfo}getAccount(e){const s=e||m.state.activeChain,n=L.getAuthConnector(s),r=m.getAccountData(s),i=P.getConnectedConnectorId(m.state.activeChain),o=j.getConnections(s);if(!s)throw new Error("AppKit:getAccount - namespace is required");const a=o.flatMap(c=>c.accounts.map(({address:l,type:u,publicKey:d})=>V.createAccount(s,l,u||"eoa",d)));if(r)return{allAccounts:a,caipAddress:r.caipAddress,address:V.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:n&&i===U.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:P.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:qt(s),isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,s){const n=()=>{const r=this.getAccount(s);r&&e(r)};s?m.subscribeChainProp("accountState",n,s):m.subscribe(n),L.subscribe(n)}subscribeNetwork(e){return m.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?m.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo),s):m.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo))}subscribeShouldUpdateToAddress(e){m.subscribeChainProp("accountState",s=>e(s==null?void 0:s.shouldUpdateToAddress))}subscribeCaipNetworkChange(e){m.subscribeKey("activeCaipNetwork",e)}getState(){return Ns.state}getRemoteFeatures(){return _.state.remoteFeatures}subscribeState(e){return Ns.subscribe(e)}subscribeRemoteFeatures(e){return _.subscribeKey("remoteFeatures",e)}showErrorMessage(e){ls.showError(e)}showSuccessMessage(e){ls.showSuccess(e)}getEvent(){return{...ae.state}}subscribeEvents(e){return ae.subscribe(e)}replace(e){ee.replace(e)}redirect(e){ee.push(e)}popTransactionStack(e){ee.popTransactionStack(e)}isOpen(){return de.state.open}isTransactionStackEmpty(){return ee.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 Br.getConnectOrderMethod(_.state.features,L.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)||m.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)&&m.removeNetwork(e,s)}}let Qd=!1;class If extends RN{async open(e){L.isConnected()||await super.open(e)}async close(){var e;if(await super.close(),this.options.manualWCControl){const s=(e=m.getAccountData(this.activeChainNamespace))==null?void 0:e.address;j.finalizeWcConnection(s)}}async syncIdentity(e){return Promise.resolve()}async syncBalance(e){return Promise.resolve()}async injectModalUi(){if(!Qd&&V.isClient()){if(await vo(()=>import("./basic-BH6yc_jn.js"),__vite__mapDeps([4,5,1,2])),await vo(()=>import("./w3m-modal-BqsJdt5C.js"),__vite__mapDeps([6,5,1,2])),!document.querySelector("w3m-modal")){const s=document.createElement("w3m-modal");!_.state.disableAppend&&!_.state.enableEmbedded&&document.body.insertAdjacentElement("beforeend",s)}Qd=!0}}}const xN="1.8.11";function $N(t){return new If({...t,basic:!0,sdkVersion:`html-core-${xN}`})}const jT=Object.freeze(Object.defineProperty({__proto__:null,AppKit:If,createAppKit:$N},Symbol.toStringTag,{value:"Module"}));export{Se as $,J as A,te as B,L as C,Yc as D,ae as E,Ah as F,Qe as G,Ai as H,Ze as I,Zt as J,NN as K,eN as L,de as M,eg as N,_ as O,LT as P,wf as Q,ee as R,ls as S,St as T,Lc as U,mr as V,Br as W,rh as X,Z as Y,Hi as Z,Y as _,V as a,kl as a$,Ol as a0,Ho as a1,Kc as a2,Eg as a3,Pg as a4,Pl as a5,Rg as a6,BN as a7,Cg as a8,Og as a9,zN as aA,jN as aB,Vg as aC,VN as aD,wh as aE,Yg as aF,GN as aG,ZN as aH,YN as aI,XN as aJ,JN as aK,Vc as aL,Fr as aM,qN as aN,QN as aO,eT as aP,zg as aQ,Gg as aR,bh as aS,xl as aT,sm as aU,Wi as aV,Bi as aW,xg as aX,ph as aY,_g as aZ,Sg as a_,Ig as aa,gh as ab,fh as ac,WN as ad,la as ae,FN as af,Ng as ag,On as ah,zc as ai,HN as aj,Io as ak,KN as al,dr as am,ni as an,mh as ao,Gc as ap,Dg as aq,Lg as ar,Mg as as,Bg as at,jg as au,Fg as av,qg as aw,Wg as ax,Hg as ay,Kg as az,j as b,wi as b0,yi as b1,mi as b2,ui as b3,fi as b4,si as b5,ei as b6,oi as b7,pr as b8,ti as b9,Cn as ba,Qr as bb,li as bc,Pt as bd,ri as be,ii as bf,vt as bg,di as bh,hr as bi,ai as bj,gi as bk,Ug as bl,pi as bm,hi as bn,ci as bo,Pn as bp,rm as bq,Ag as br,Qg as bs,jT as bt,U as c,DT as d,jt as e,Ha as f,Eh as g,BT as h,bo as i,$n as j,_s as k,ye as l,UT as m,m as n,Zn as o,P as p,Ve as q,MT as r,Xs as s,ke as t,qt as u,Ss as v,Ht as w,$T as x,Om as y,It as z};
|
|
233
|
+
`,oo={ERROR_CODE_UNRECOGNIZED_CHAIN_ID:4902,ERROR_CODE_DEFAULT:5e3,ERROR_INVALID_CHAIN_ID:32603};class ON extends ny{async setUniversalProvider(e){if(!this.namespace)throw new Error("UniversalAdapter:setUniversalProvider - namespace is required");return this.addConnector(new ry({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,u)=>u.indexOf(c)===l))||[];return Promise.resolve({accounts:n.map(c=>V.createAccount(e,c,e==="bip122"?"payment":"eoa"))})}async syncConnectors(){return Promise.resolve()}async getBalance(e){var o,a,c,l,u;if(!(e.caipNetwork&&ye.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=m.getAccountData();if(n!=null&&n.balanceLoading&&e.chainId===((l=m.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 m.fetchTokenBalance()).find(d=>{var h,p;return d.chainId===`${(h=e.caipNetwork)==null?void 0:h.chainNamespace}:${e.chainId}`&&d.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)||((u=e.caipNetwork)==null?void 0:u.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=m.state.activeCaipNetwork)==null?void 0:o.chainNamespace)===U.CHAIN.SOLANA?i=(await s.request({method:"solana_signMessage",params:{message:br.encode(new TextEncoder().encode(n)),pubkey:r}},(a=m.state.activeCaipNetwork)==null?void 0:a.caipNetworkId)).signature:i=await s.request({method:"personal_sign",params:[n,r]},(c=m.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:Pl(s.id)}]}))}catch(u){if(u.code===oo.ERROR_CODE_UNRECOGNIZED_CHAIN_ID||u.code===oo.ERROR_INVALID_CHAIN_ID||u.code===oo.ERROR_CODE_DEFAULT||((o=(i=u==null?void 0:u.data)==null?void 0:i.originalError)==null?void 0:o.code)===oo.ERROR_CODE_UNRECOGNIZED_CHAIN_ID)try{await((l=n.provider)==null?void 0:l.request({method:"wallet_addEthereumChain",params:[{chainId:Pl(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 PN=["email","socials","swaps","onramp","activity","reownBranding","multiWallet","emailCapture","payWithExchange","payments","reownAuthentication"],ao={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?ye.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?ye.DEFAULT_REMOTE_FEATURES.socials:typeof t=="boolean"?t?ye.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?ye.DEFAULT_REMOTE_FEATURES.swaps:typeof t=="boolean"?t?ye.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?ye.DEFAULT_REMOTE_FEATURES.onramp:typeof t=="boolean"?t?ye.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?ye.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?ye.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:()=>ye.DEFAULT_REMOTE_FEATURES.multiWallet},payWithExchange:{apiFeatureName:"fund_from_exchange",localFeatureName:"payWithExchange",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>ye.DEFAULT_REMOTE_FEATURES.payWithExchange},payments:{apiFeatureName:"payments",localFeatureName:"payments",returnType:!1,isLegacy:!1,isAvailableOnBasic:!1,processApi:t=>!!t.isEnabled,processFallback:()=>ye.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"?ye.DEFAULT_REMOTE_FEATURES.reownAuthentication:!!t}},kN={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=ao[e],n=s.isLegacy?`"features.${s.localFeatureName}" (now "${e}")`:`"features.${e}"`;this.localSettingsOverridden.add(n)}},processFeature(t,e,s,n,r){const i=ao[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 ao[t].processApi(e)},processFallbackFeature(t,e){return ao[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 J.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?ye.DEFAULT_REMOTE_FEATURES:ye.DEFAULT_REMOTE_FEATURES_DISABLED;try{for(const o of PN){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),ye.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.`;It.open({debugMessage:Dt.ALERT_WARNINGS.LOCAL_CONFIGURATION_IGNORED.debugMessage(o)},"warning")}return i}};class RN{constructor(e){this.chainNamespaces=[],this.features={},this.remoteFeatures={},this.reportedAlertErrors={},this.getCaipNetwork=(s,n)=>{var r,i,o;if(s){const a=(r=m.getCaipNetworks(s))==null?void 0:r.find(u=>u.id===n);if(a)return a;const c=(i=m.getNetworkData(s))==null?void 0:i.caipNetwork;return c||((o=m.getRequestedCaipNetworks(s).filter(u=>u.chainNamespace===s))==null?void 0:o[0])}return m.state.activeCaipNetwork||this.defaultCaipNetwork},this.getCaipNetworkId=()=>{const s=this.getCaipNetwork();if(s)return s.id},this.getCaipNetworks=s=>m.getCaipNetworks(s),this.getActiveChainNamespace=()=>m.state.activeChain,this.setRequestedCaipNetworks=(s,n)=>{m.setRequestedCaipNetworks(s,n)},this.getApprovedCaipNetworkIds=()=>m.getAllApprovedCaipNetworkIds(),this.getCaipAddress=s=>{var n,r;return m.state.activeChain===s||!s?m.state.activeCaipAddress:(r=(n=m.state.chains.get(s))==null?void 0:n.accountState)==null?void 0:r.caipAddress},this.setClientId=s=>{te.setClientId(s)},this.getProvider=s=>xe.getProvider(s),this.getProviderType=s=>xe.getProviderId(s),this.getPreferredAccountType=s=>qt(s),this.setCaipAddress=(s,n,r=!1)=>{m.setAccountProp("caipAddress",s,n,r),m.setAccountProp("address",V.getPlainAddress(s),n,r)},this.setBalance=(s,n,r)=>{m.setAccountProp("balance",s,r),m.setAccountProp("balanceSymbol",n,r)},this.setProfileName=(s,n)=>{m.setAccountProp("profileName",s,n)},this.setProfileImage=(s,n)=>{m.setAccountProp("profileImage",s,n)},this.setUser=(s,n)=>{m.setAccountProp("user",s,n)},this.resetAccount=s=>{m.resetAccount(s)},this.setCaipNetwork=s=>{m.setActiveCaipNetwork(s)},this.setCaipNetworkOfNamespace=(s,n)=>{m.setChainNetworkData(n,{caipNetwork:s})},this.setStatus=(s,n)=>{m.setAccountProp("status",s,n),L.isConnected()?P.setConnectionStatus("connected"):P.setConnectionStatus("disconnected")},this.getAddressByChainNamespace=s=>{var n;return(n=m.getAccountData(s))==null?void 0:n.address},this.setConnectors=s=>{const n=[...L.state.allConnectors,...s];L.setConnectors(n)},this.setConnections=(s,n)=>{P.setConnections(s,n),j.setConnections(s,n)},this.fetchIdentity=s=>te.fetchIdentity(s),this.getReownName=s=>Wr.getNamesForAddress(s),this.getConnectors=()=>L.getConnectors(),this.getConnectorImage=s=>Eh.getConnectorImage(s),this.getConnections=s=>this.remoteFeatures.multiWallet?_o.getConnectionsData(s).connections:(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.getRecentConnections=s=>this.remoteFeatures.multiWallet?_o.getConnectionsData(s).recentConnections:(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),[]),this.switchConnection=async s=>{if(!this.remoteFeatures.multiWallet){It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}await j.switchConnection(s)},this.deleteConnection=s=>{if(!this.remoteFeatures.multiWallet){It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info");return}P.deleteAddressFromConnection(s),j.syncStorageConnections()},this.setConnectedWalletInfo=(s,n)=>{const r=xe.getProviderId(n),i=s?{...s,type:r}:void 0;m.setAccountProp("connectedWalletInfo",i,n)},this.getIsConnectedState=()=>!!m.state.activeCaipAddress,this.addAddressLabel=(s,n,r)=>{var o;const i=((o=m.getAccountData(r))==null?void 0:o.addressLabels)||{};m.setAccountProp("addressLabels",{...i,[s]:n},r)},this.removeAddressLabel=(s,n)=>{var i;const r=((i=m.getAccountData(n))==null?void 0:i.addressLabels)||{};m.setAccountProp("addressLabels",{...r,[s]:void 0},n)},this.getAddress=s=>{var r;const n=s||m.state.activeChain;return(r=m.getAccountData(n))==null?void 0:r.address},this.resetNetwork=s=>{m.resetNetwork(s)},this.addConnector=s=>{L.addConnector(s)},this.resetWcConnection=()=>{j.resetWcConnection()},this.setAddressExplorerUrl=(s,n)=>{m.setAccountProp("addressExplorerUrl",s,n)},this.setSmartAccountDeployed=(s,n)=>{m.setAccountProp("smartAccountDeployed",s,n)},this.setPreferredAccountType=(s,n)=>{m.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;if(this.initializeProjectSettings(e),this.initControllers(e),await this.initChainAdapters(),this.sendInitializeEvent(e),_.state.enableReconnect?(await this.syncExistingConnection(),await this.syncAdapterConnections()):await this.unSyncExistingConnection(),this.remoteFeatures=await kN.fetchRemoteFeatures(e),await J.fetchUsage(),_.setRemoteFeatures(this.remoteFeatures),this.remoteFeatures.onramp&&nc.setOnrampProviders(this.remoteFeatures.onramp),((s=_.state.remoteFeatures)!=null&&s.email||Array.isArray((n=_.state.remoteFeatures)==null?void 0:n.socials)&&((r=_.state.remoteFeatures)==null?void 0:r.socials.length)>0)&&await this.checkAllowedOrigins(),(i=_.state.features)!=null&&i.reownAuthentication||(o=_.state.remoteFeatures)!=null&&o.reownAuthentication){const{ReownAuthentication:a}=await vo(async()=>{const{ReownAuthentication:l}=await import("./features-BanUs8Cp.js");return{ReownAuthentication:l}},__vite__mapDeps([3,1,2])),c=_.state.siwx;c instanceof a||(c&&console.warn("ReownAuthentication option is enabled, SIWX configuration will be overridden."),_.setSIWX(new a))}}async openSend(e){var i;const s=e.namespace||m.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=m.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=gf.getTokenSymbolByAddress(e.assetAddress);o&&await J.fetchTokenImages([o])}catch{}return await de.open({view:"WalletSend",data:{send:e}}),new Promise((o,a)=>{const c=oe.subscribeKey("hash",d=>{d&&(u(),o({hash:d}))}),l=de.subscribe(d=>{d.open||(u(),a(new Error("Modal closed")))}),u=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 J.fetchAllowedOrigins();if(!V.isClient())return;const s=window.location.origin;en.isOriginAllowed(s,e,U.DEFAULT_ALLOWED_ANCESTORS)||It.open(Dt.ALERT_ERRORS.ORIGIN_NOT_ALLOWED,"error")}catch(e){if(!(e instanceof Error))return;switch(e.message){case"RATE_LIMITED":It.open(Dt.ALERT_ERRORS.RATE_LIMITED_APP_CONFIGURATION,"error");break;case"SERVER_ERROR":{const s=e.cause instanceof Error?e.cause:e;It.open({displayMessage:Dt.ALERT_ERRORS.SERVER_ERROR_APP_CONFIGURATION.displayMessage,debugMessage:Dt.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,ae.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(){Ih.initialize(this.chainAdapters)}initializeThemeController(e){e.themeMode&&St.setThemeMode(e.themeMode),e.themeVariables&&St.setThemeVariables(e.themeVariables)}initializeChainController(e){if(!this.connectionControllerClient)throw new Error("ConnectionControllerClient must be set");m.initialize(e.adapters??[],this.caipNetworks,{connectionControllerClient:this.connectionControllerClient});const s=this.getDefaultNetwork();s&&m.setActiveCaipNetwork(s)}initializeConnectionController(e){j.initialize(e.adapters??[]),j.setWcBasic(e.basic??!1)}initializeConnectorController(){L.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){It.open(Dt.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 V.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=Zn.getUnsupportedNetwork(`${s}:${e}`);m.setActiveCaipNetwork(n)}}getDefaultNetwork(){return Zn.getCaipNetworkFromStorage(this.defaultCaipNetwork)}extendCaipNetwork(e,s){return Zn.extendCaipNetwork(e,{customNetworkImageUrls:s.chainImages,projectId:s.projectId})}extendCaipNetworks(e){return Zn.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?Zn.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=m.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=m.state.activeChain,s=this.getAdapter(e),n=(l=this.getCaipNetwork(e))==null?void 0:l.id,r=j.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),P.setConnectedNamespaces([...m.state.chains.keys()]),await this.syncWalletConnectAccount(),await Zt.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=m.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})),P.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||m.state.activeChain,o=L.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 u=Array.from(m.state.chains.keys());let d=n?[n]:u;(c||a)&&(d=u);const h=d.map(async f=>{const y=L.getConnectorId(f),w=s||y,b=await this.disconnectConnector(f,w);b&&(a&&P.deleteConnectedSocialProvider(),b.connections.forEach(E=>{P.addDisconnectedConnectorId(E.connectorId,f)})),r&&this.onDisconnectNamespace({chainNamespace:f,closeModal:!1})}),p=await Promise.allSettled(h);oe.resetSend(),j.resetWcConnection(),(l=Zt.getSIWX())!=null&&l.signOutOnDisconnect&&await Zt.clearSessions(),L.setFilterByNamespace(void 0),j.syncStorageConnections();const g=p.filter(f=>f.status==="rejected");if(g.length>0)throw new Error(g.map(f=>f.reason.message).join(", "));ae.sendEvent({type:"track",event:"DISCONNECT_SUCCESS",properties:{namespace:n||"all"}})}catch(u){throw new Error(`Failed to disconnect chains: ${u.message}`)}},checkInstalled:e=>e?e.some(s=>{var n;return!!((n=window.ethereum)!=null&&n[String(s)])}):!!window.ethereum,signMessage:async e=>{const s=m.state.activeChain,n=this.getAdapter(m.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:xe.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(ye.SEND_SUPPORTED_NAMESPACES.includes(s)){const n=this.getAdapter(s);if(!n)throw new Error("sendTransaction: adapter not found");const r=xe.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=xe.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=m.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=m.getAccountData();return(n==null?void 0:n.profileImage)||!1},getEnsAddress:async e=>await en.resolveReownName(e),writeContract:async e=>{const s=m.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=xe.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(m.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(m.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(m.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(m.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(m.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(m.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)}},j.setClient(this.connectionControllerClient)}async onConnectExternal(e){var l,u,d,h,p,g,f,y;const s=m.state.activeChain,n=e.chain||s,r=this.getAdapter(n);let i=!0;if(e.type===Es.CONNECTOR_TYPE_AUTH&&U.AUTH_CONNECTOR_SUPPORTED_CHAINS.some(E=>L.getConnectorId(E)===U.CONNECTOR_ID.AUTH)&&e.chain!==s&&(i=!1),e.chain&&e.chain!==s&&!e.caipNetwork){const w=this.getCaipNetworks().find(b=>b.chainNamespace===e.chain);w&&i&&this.setCaipNetwork(w)}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=(d=(u=e.caipNetwork)==null?void 0:u.rpcUrls)==null?void 0:d.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 P.addConnectedNamespace(n),this.syncProvider({...c,chainNamespace:n}),this.setStatus("connected",n),this.syncConnectedWalletInfo(n),P.removeDisconnectedConnectorId(e.id,n),{address:c.address,connectedCaipNetwork:a}}async connectInactiveNamespaces(e,s){var a;const n=e.type===Es.CONNECTOR_TYPE_AUTH,r=Ai.getOtherAuthNamespaces((a=s==null?void 0:s.connectedCaipNetwork)==null?void 0:a.chainNamespace),i=m.state.activeCaipNetwork,o=this.getAdapter(i==null?void 0:i.chainNamespace);n&&(await Promise.all(r.map(async c=>{var l,u,d;try{const h=xe.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:(d=(u=(l=p==null?void 0:p.rpcUrls)==null?void 0:l.default)==null?void 0:u.http)==null?void 0:d[0]}))&&(P.addConnectedNamespace(c),P.removeDisconnectedConnectorId(e.id,c),this.setStatus("connected",c),this.syncConnectedWalletInfo(c))}catch(h){It.warn(Dt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.displayMessage,Dt.ALERT_WARNINGS.INACTIVE_NAMESPACE_NOT_CONNECTED.debugMessage(c,h instanceof Error?h.message:void 0),Dt.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(xe.getProviderId(m.state.activeChain)===Es.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=xe.getProviderId(s);if(e.chainNamespace===m.state.activeChain){const i=this.getAdapter(s);await(i==null?void 0:i.switchNetwork({caipNetwork:e}))}else if(this.setCaipNetwork(e),r===Es.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}=Xe.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 ON({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=P.getConnectionStatus();_.state.enableReconnect===!1?this.setStatus("disconnected",e):n==="connected"?this.setStatus("connecting",e):n==="disconnected"?(P.clearAddressCache(),this.setStatus(n,e)):this.setStatus(n,e),s.on("switchNetwork",({address:r,chainId:i})=>{var l,u;const o=this.getCaipNetworks().find(d=>d.id.toString()===i.toString()||d.caipNetworkId.toString()===i.toString()),a=m.state.activeChain===e,c=(u=(l=m.state.chains.get(e))==null?void 0:l.accountState)==null?void 0:u.address;if(o){const d=a&&r?r:c;d&&this.syncAccount({address:d,chainId:o.id,chainNamespace:e})}else this.setUnsupportedNetwork(i)}),s.on("disconnect",()=>{const r=this.remoteFeatures.multiWallet,i=Array.from(j.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=m.state.activeCaipNetwork;!r||!(i!=null&&i.id)||this.updateNativeBalance(r,i.id,i.chainNamespace)}),s.on("accountChanged",({address:r,chainId:i,connector:o})=>{var u,d;this.handlePreviousConnectorConnection(o);const a=m.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=(d=(u=m.getNetworkData(e))==null?void 0:u.caipNetwork)==null?void 0:d.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),P.addConnectedNamespace(e)})}async handlePreviousConnectorConnection(e){var c;const s=e==null?void 0:e.chain,n=e==null?void 0:e.id,r=L.getConnectorId(s),i=(c=_.state.remoteFeatures)==null?void 0:c.multiWallet,a=s&&n&&r&&r!==n&&!i;try{a&&await j.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=>j.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()||P.deleteRecentWallet();const s=P.getRecentWallet();ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:e,properties:{method:V.isMobile()?"mobile":"qrcode",name:(s==null?void 0:s.name)||"Unknown",reconnect:!0,view:ee.state.view,walletRank:s==null?void 0:s.order}})}async syncNamespaceConnection(e){try{e===U.CHAIN.EVM&&V.isSafeApp()&&L.setConnectorId(U.CONNECTOR_ID.SAFE,e);const s=L.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||{};m.resetAccount(s),m.resetNetwork(s),P.removeConnectedNamespace(s);const r=Array.from(m.state.chains.keys());(s?[s]:r).forEach(o=>P.addDisconnectedConnectorId(L.getConnectorId(o)||"",o)),L.removeConnectorId(s),xe.resetChain(s),this.setUser(null,s),this.setStatus("disconnected",s),this.setConnectedWalletInfo(null,s),n!==!1&&de.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,u;const s=this.getAdapter(e),n=this.getCaipNetwork(e),r=L.getConnectorId(e),o=L.getConnectors(e).find(d=>d.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 d=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]}));d?(this.syncProvider({...d,chainNamespace:e}),await this.syncAccount({...d,chainNamespace:e}),this.setStatus("connected",e),ae.sendEvent({type:"track",event:"CONNECT_SUCCESS",address:d.address,properties:{method:"browser",name:((u=o.info)==null?void 0:u.name)||o.name||"Unknown",reconnect:!0,view:ee.state.view,walletRank:void 0}})):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 d,h,p,g,f;const o=this.getAdapter(i);if(!o)return;const a=((g=(p=(h=(d=this.universalProvider)==null?void 0:d.session)==null?void 0:h.namespaces)==null?void 0:p[i])==null?void 0:g.accounts)||[],c=(f=m.state.activeCaipNetwork)==null?void 0:f.id,l=a.find(y=>{const{chainId:w}=Xe.parseCaipAddress(y);return w===(c==null?void 0:c.toString())})||a[0];if(l){const y=Xe.validateCaipAddress(l),{chainId:w,address:b}=Xe.parseCaipAddress(y);if(xe.setProviderId(i,Es.CONNECTOR_TYPE_WALLET_CONNECT),this.caipNetworks&&m.state.activeCaipNetwork&&o.namespace!==U.CHAIN.EVM){const E=o.getWalletConnectProvider({caipNetworks:this.getCaipNetworks(),provider:this.universalProvider,activeCaipNetwork:m.state.activeCaipNetwork});xe.setProvider(i,E)}else xe.setProvider(i,this.universalProvider);L.setConnectorId(U.CONNECTOR_ID.WALLET_CONNECT,i),P.addConnectedNamespace(i),await this.syncAccount({address:b,chainId:w,chainNamespace:i})}else e.includes(i)&&this.setStatus("disconnected",i);const u=this.getApprovedCaipNetworksData();this.syncConnectedWalletInfo(i),m.setApprovedCaipNetworksData(i,{approvedCaipNetworkIds:u.approvedCaipNetworkIds,supportsAllNetworks:u.supportsAllNetworks})});await Promise.all(s)}syncProvider({type:e,provider:s,id:n,chainNamespace:r}){xe.setProviderId(r,e),xe.setProvider(r,s),L.setConnectorId(n,r)}async syncAccount(e){var d,h;const s=e.chainNamespace===m.state.activeChain,n=m.getCaipNetworkByNamespace(e.chainNamespace,e.chainId),{address:r,chainId:i,chainNamespace:o}=e,{chainId:a}=P.getActiveNetworkProps(),c=(n==null?void 0:n.id)||a,l=((d=m.state.activeCaipNetwork)==null?void 0:d.name)===U.UNSUPPORTED_NETWORK_NAME,u=m.getNetworkProp("supportsAllNetworks",o);if(this.setStatus("connected",o),!(l&&!u)&&c){let p=this.getCaipNetworks().find(w=>w.id.toString()===c.toString()),g=this.getCaipNetworks().find(w=>w.chainNamespace===o);if(!u&&!p&&!g){const w=this.getApprovedCaipNetworkIds()||[],b=w.find(N=>{var x;return((x=Xe.parseCaipNetworkId(N))==null?void 0:x.chainId)===c.toString()}),E=w.find(N=>{var x;return((x=Xe.parseCaipNetworkId(N))==null?void 0:x.chainNamespace)===o});p=this.getCaipNetworks().find(N=>N.caipNetworkId===b),g=this.getCaipNetworks().find(N=>N.caipNetworkId===E||"deprecatedCaipNetworkId"in N&&N.deprecatedCaipNetworkId===E)}const f=p||g;(f==null?void 0:f.chainNamespace)===m.state.activeChain?_.state.enableNetworkSwitch&&!_.state.allowUnsupportedChain&&((h=m.state.activeCaipNetwork)==null?void 0:h.name)===U.UNSUPPORTED_NETWORK_NAME?m.showUnsupportedChainUI():this.setCaipNetwork(f):s||n&&this.setCaipNetworkOfNamespace(n,o),this.syncConnectedWalletInfo(o);const y=this.getAddress(o);Ai.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=L.getConnectorId(e),n=xe.getProviderId(e);if(n===Es.CONNECTOR_TYPE_ANNOUNCED||n===Es.CONNECTOR_TYPE_INJECTED){if(s){const o=this.getConnectors().find(a=>{var d,h;const c=a.id===s,l=((d=a.info)==null?void 0:d.rdns)===s,u=(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||!!u});if(o){const{info:a,name:c,imageUrl:l}=o,u=l||this.getConnectorImage(o);this.setConnectedWalletInfo({name:c,icon:u,...a},e)}}}else if(n===Es.CONNECTOR_TYPE_WALLET_CONNECT){const i=xe.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){!rh.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=m.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 n,r,i,o,a,c,l,u,d,h;const e=ZS.createLogger((p,...g)=>{p&&this.handleAlertError(p),console.error(...g)}),s={projectId:(n=this.options)==null?void 0:n.projectId,metadata:{name:(r=this.options)!=null&&r.metadata?(i=this.options)==null?void 0:i.metadata.name:"",description:(o=this.options)!=null&&o.metadata?(a=this.options)==null?void 0:a.metadata.description:"",url:(c=this.options)!=null&&c.metadata?(l=this.options)==null?void 0:l.metadata.url:"",icons:(u=this.options)!=null&&u.metadata?(d=this.options)==null?void 0:d.metadata.icons:[""]},logger:e};_.setManualWCControl(!!((h=this.options)!=null&&h.manualWCControl)),this.universalProvider=this.options.universalProvider??await SS.init(s),_.state.enableReconnect===!1&&this.universalProvider.session&&await this.universalProvider.disconnect(),this.listenWalletConnect()}listenWalletConnect(){this.universalProvider&&this.chainNamespaces.forEach(e=>{en.listenWcProvider({universalProvider:this.universalProvider,namespace:e,onDisplayUri:s=>{j.setUri(s)},onConnect:s=>{const{address:n}=V.getAccount(s[0]);j.finalizeWcConnection(n)},onDisconnect:()=>{m.state.noAdapters&&this.resetAccount(e),j.resetWcConnection()},onChainChanged:s=>{const n=m.state.activeChain,r=n&&L.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(m.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=m.state.activeChain,r=n&&L.state.activeConnectorIds[n]===U.CONNECTOR_ID.WALLET_CONNECT;if(n===e&&(m.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&&V.isClient()&&((e=this.options)!=null&&e.projectId)&&(this.universalProviderInitPromise=this.initializeUniversalAdapter()),this.universalProviderInitPromise}async getUniversalProvider(){if(!this.universalProvider)try{await this.createUniversalProvider()}catch(e){ae.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=m.getAllApprovedCaipNetworkIds(),s=m.getAllRequestedCaipNetworks();return V.sortRequestedNetworks(e,s).filter(r=>m.isCaipNetworkDisabled(r))}handleAlertError(e){const s=Object.entries(Dt.UniversalProviderErrors).find(([,{message:a}])=>e.message.includes(a)),[n,r]=s??[],{message:i,alertErrorKey:o}=r??{};if(n&&i&&!this.reportedAlertErrors[n]){const a=Dt.ALERT_ERRORS[o];a&&(It.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&&j.setUri(e.uri);const{isSwap:s,isSend:n}=this.toModalOptions();return s(e)?de.open({...e,data:{swap:e.arguments}}):n(e)&&e.arguments?this.openSend(e.arguments):de.open(e)}async close(){await this.injectModalUi(),de.close()}setLoading(e,s){de.setLoading(e,s)}async disconnect(e){await j.disconnect({namespace:e})}getSIWX(){return _.state.siwx}getError(){return""}getChainId(){var e;return(e=m.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){It.open(Dt.ALERT_ERRORS.SWITCH_NETWORK_NOT_FOUND,"error");return}await m.switchActiveNetwork(n,{throwOnFailure:s})}getWalletProvider(){return m.state.activeChain?xe.state.providers[m.state.activeChain]:null}getWalletProviderType(){return xe.getProviderId(m.state.activeChain)}subscribeProviders(e){return xe.subscribeProviders(e)}getThemeMode(){return St.state.themeMode}getThemeVariables(){return St.state.themeVariables}setThemeMode(e){St.setThemeMode(e),Bc(St.state.themeMode)}setTermsConditionsUrl(e){_.setTermsConditionsUrl(e)}setPrivacyPolicyUrl(e){_.setPrivacyPolicyUrl(e)}setThemeVariables(e){St.setThemeVariables(e),TN(St.state.themeVariables)}subscribeTheme(e){return St.subscribe(e)}subscribeConnections(e){return this.remoteFeatures.multiWallet?j.subscribe(e):(It.open(U.REMOTE_FEATURES_ALERTS.MULTI_WALLET_NOT_ENABLED.DEFAULT,"info"),()=>{})}getWalletInfo(e){var n,r;if(e)return(r=(n=m.state.chains.get(e))==null?void 0:n.accountState)==null?void 0:r.connectedWalletInfo;const s=m.getAccountData();return s==null?void 0:s.connectedWalletInfo}getAccount(e){const s=e||m.state.activeChain,n=L.getAuthConnector(s),r=m.getAccountData(s),i=P.getConnectedConnectorId(m.state.activeChain),o=j.getConnections(s);if(!s)throw new Error("AppKit:getAccount - namespace is required");const a=o.flatMap(c=>c.accounts.map(({address:l,type:u,publicKey:d})=>V.createAccount(s,l,u||"eoa",d)));if(r)return{allAccounts:a,caipAddress:r.caipAddress,address:V.getPlainAddress(r.caipAddress),isConnected:!!r.caipAddress,status:r.status,embeddedWalletInfo:n&&i===U.CONNECTOR_ID.AUTH?{user:r.user?{...r.user,username:P.getConnectedSocialUsername()}:void 0,authProvider:r.socialProvider||"email",accountType:qt(s),isSmartAccountDeployed:!!r.smartAccountDeployed}:void 0}}subscribeAccount(e,s){const n=()=>{const r=this.getAccount(s);r&&e(r)};s?m.subscribeChainProp("accountState",n,s):m.subscribe(n),L.subscribe(n)}subscribeNetwork(e){return m.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?m.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo),s):m.subscribeChainProp("accountState",n=>e(n==null?void 0:n.connectedWalletInfo))}subscribeShouldUpdateToAddress(e){m.subscribeChainProp("accountState",s=>e(s==null?void 0:s.shouldUpdateToAddress))}subscribeCaipNetworkChange(e){m.subscribeKey("activeCaipNetwork",e)}getState(){return Ns.state}getRemoteFeatures(){return _.state.remoteFeatures}subscribeState(e){return Ns.subscribe(e)}subscribeRemoteFeatures(e){return _.subscribeKey("remoteFeatures",e)}showErrorMessage(e){ls.showError(e)}showSuccessMessage(e){ls.showSuccess(e)}getEvent(){return{...ae.state}}subscribeEvents(e){return ae.subscribe(e)}replace(e){ee.replace(e)}redirect(e){ee.push(e)}popTransactionStack(e){ee.popTransactionStack(e)}isOpen(){return de.state.open}isTransactionStackEmpty(){return ee.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 Br.getConnectOrderMethod(_.state.features,L.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)||m.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)&&m.removeNetwork(e,s)}}let Qd=!1;class If extends RN{async open(e){L.isConnected()||await super.open(e)}async close(){var e;if(await super.close(),this.options.manualWCControl){const s=(e=m.getAccountData(this.activeChainNamespace))==null?void 0:e.address;j.finalizeWcConnection(s)}}async syncIdentity(e){return Promise.resolve()}async syncBalance(e){return Promise.resolve()}async injectModalUi(){if(!Qd&&V.isClient()){if(await vo(()=>import("./basic-D0dwyfjS.js"),__vite__mapDeps([4,5,1,2])),await vo(()=>import("./w3m-modal-Bj2hrG0i.js"),__vite__mapDeps([6,5,1,2])),!document.querySelector("w3m-modal")){const s=document.createElement("w3m-modal");!_.state.disableAppend&&!_.state.enableEmbedded&&document.body.insertAdjacentElement("beforeend",s)}Qd=!0}}}const xN="1.8.11";function $N(t){return new If({...t,basic:!0,sdkVersion:`html-core-${xN}`})}const jT=Object.freeze(Object.defineProperty({__proto__:null,AppKit:If,createAppKit:$N},Symbol.toStringTag,{value:"Module"}));export{Se as $,J as A,te as B,L as C,Yc as D,ae as E,Ah as F,Qe as G,Ai as H,Ze as I,Zt as J,NN as K,eN as L,de as M,eg as N,_ as O,LT as P,wf as Q,ee as R,ls as S,St as T,Lc as U,mr as V,Br as W,rh as X,Z as Y,Hi as Z,Y as _,V as a,kl as a$,Ol as a0,Ho as a1,Kc as a2,Eg as a3,Pg as a4,Pl as a5,Rg as a6,BN as a7,Cg as a8,Og as a9,zN as aA,jN as aB,Vg as aC,VN as aD,wh as aE,Yg as aF,GN as aG,ZN as aH,YN as aI,XN as aJ,JN as aK,Vc as aL,Fr as aM,qN as aN,QN as aO,eT as aP,zg as aQ,Gg as aR,bh as aS,xl as aT,sm as aU,Wi as aV,Bi as aW,xg as aX,ph as aY,_g as aZ,Sg as a_,Ig as aa,gh as ab,fh as ac,WN as ad,la as ae,FN as af,Ng as ag,On as ah,zc as ai,HN as aj,Io as ak,KN as al,dr as am,ni as an,mh as ao,Gc as ap,Dg as aq,Lg as ar,Mg as as,Bg as at,jg as au,Fg as av,qg as aw,Wg as ax,Hg as ay,Kg as az,j as b,wi as b0,yi as b1,mi as b2,ui as b3,fi as b4,si as b5,ei as b6,oi as b7,pr as b8,ti as b9,Cn as ba,Qr as bb,li as bc,Pt as bd,ri as be,ii as bf,vt as bg,di as bh,hr as bi,ai as bj,gi as bk,Ug as bl,pi as bm,hi as bn,ci as bo,Pn as bp,rm as bq,Ag as br,Qg as bs,jT as bt,U as c,DT as d,jt as e,Ha as f,Eh as g,BT as h,bo as i,$n as j,_s as k,ye as l,UT as m,m as n,Zn as o,P as p,Ve as q,MT as r,Xs as s,ke as t,qt as u,Ss as v,Ht as w,$T as x,Om as y,It as z};
|